*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--black: #000000;--white: #f0f1fa;--white-pure: #ffffff;--accent: #0016ec;--accent-alt: #1a2ffb;--green: #c1ff00;--grey: #2b2e3a;--grey-light: rgba(240, 241, 250, .7);--grey-dim: rgba(240, 241, 250, .4);--grey-muted: rgba(240, 241, 250, .12);--font-sans: "Inter", -apple-system, "Helvetica Neue", sans-serif;--font-serif: "Cormorant Garamond", "Georgia", serif;--font-mono: "JetBrains Mono", "IBM Plex Mono", monospace;--ease-out: cubic-bezier(.4, 0, .1, 1);--ease-smooth: cubic-bezier(.22, 1, .36, 1);--padding-x: max(5vw, 40px);--radius: 15px}html{background:var(--black);color:var(--white);font-family:var(--font-sans);font-weight:400;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;cursor:none;overflow-x:hidden}body{cursor:none;overflow-x:hidden;background:var(--black)}a{color:inherit;text-decoration:none;cursor:none}button{background:none;border:none;color:inherit;font:inherit;cursor:none}ul{list-style:none}img{display:block;max-width:100%}.preloader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--black);display:flex;align-items:flex-end;justify-content:flex-start;padding:var(--padding-x);transition:opacity .8s var(--ease-out),visibility .8s}.preloader.done{opacity:0;visibility:hidden;pointer-events:none}.preloader-count{font-family:var(--font-serif);font-size:clamp(5em,12vw,18em);font-weight:300;line-height:.85;color:var(--white);letter-spacing:-.03em}.grain-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;pointer-events:none;opacity:.04;mix-blend-mode:overlay;background-repeat:repeat;background-size:128px 128px;will-change:background-image}#cursor{position:fixed;top:0;left:0;z-index:9998;pointer-events:none;mix-blend-mode:difference}.cursor-dot{width:12px;height:12px;background:var(--white-pure);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease-out),height .3s var(--ease-out),opacity .3s}.cursor-ring{position:absolute;top:50%;left:50%;width:40px;height:40px;border:1.5px solid rgba(255,255,255,.4);border-radius:50%;transform:translate(-50%,-50%);transition:width .4s var(--ease-smooth),height .4s var(--ease-smooth),border-color .4s}#cursor.hovering .cursor-dot{width:6px;height:6px;opacity:.4}#cursor.hovering .cursor-ring{width:64px;height:64px;border-color:#ffffffb3}#webgl-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}#nav{position:fixed;top:0;left:0;width:100%;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px var(--padding-x);mix-blend-mode:difference}.nav-logo{font-family:var(--font-mono);font-size:clamp(.7rem,1vw,.85rem);font-weight:500;letter-spacing:.2em;text-transform:uppercase}.nav-right{display:flex;align-items:center;gap:12px}.nav-pill{height:44px;padding:0 20px;border:1px solid var(--grey-muted);border-radius:30px;font-size:.75rem;font-weight:500;letter-spacing:.08em;display:flex;align-items:center;justify-content:center;gap:8px;transition:border-color .3s var(--ease-out),background .3s,color .3s,transform .3s}.nav-pill:hover{border-color:var(--white);background:#ffffff14}.nav-contact{background:var(--accent);border-color:var(--accent);color:var(--white-pure);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out),border-color .3s var(--ease-out),background .3s}body.menu-open .nav-contact{opacity:0;pointer-events:none;transform:scale(.9)}.nav-contact:hover{background:var(--accent-alt);border-color:var(--accent-alt);transform:scale(1.05)}.menu-dot{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block}.bgm-btn.nav-pill{position:static;width:44px;padding:0;-webkit-backdrop-filter:none;backdrop-filter:none;background:transparent}.bgm-icon{width:18px;height:18px;color:var(--grey-dim);transition:color .3s}.bgm-btn.playing .bgm-icon{color:var(--green)}.bgm-btn .bgm-bar{stroke-linecap:round;transform-origin:center}.bgm-btn.playing .bar-1{animation:bgm-eq .8s ease-in-out infinite alternate}.bgm-btn.playing .bar-2{animation:bgm-eq .6s ease-in-out infinite alternate .1s}.bgm-btn.playing .bar-3{animation:bgm-eq .7s ease-in-out infinite alternate .2s}.bgm-btn.playing .bar-4{animation:bgm-eq .65s ease-in-out infinite alternate .15s}.bgm-btn.playing .bar-5{animation:bgm-eq .75s ease-in-out infinite alternate .05s}@keyframes bgm-eq{0%{transform:scaleY(.3)}to{transform:scaleY(1)}}.menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:#000;clip-path:inset(0 0 100% 0);visibility:hidden;pointer-events:none;transition:clip-path .75s var(--ease-out),visibility .75s}.menu-overlay.open{clip-path:inset(0 0 0% 0);visibility:visible;pointer-events:auto}.menu-overlay.closing{clip-path:inset(0 0 100% 0)}.menu-overlay-inner{width:100%;height:100%;display:grid;grid-template-rows:auto 1fr auto;padding:max(6vw,48px) var(--padding-x)}.menu-top{display:flex;align-items:center;height:var(--nav-h, 72px)}.menu-logo{font-family:var(--font-sans);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grey-dim)}.menu-links{display:flex;flex-direction:column;justify-content:center;gap:clamp(4px,1vw,14px);padding:20px 0;overflow:hidden}.menu-link-wrap{overflow:hidden}.menu-link{display:block;font-family:var(--font-serif);font-size:clamp(2.2rem,7vw,7.5rem);font-weight:300;letter-spacing:-.02em;line-height:1.05;color:var(--grey-dim);transform:translateY(110%);transition:color .35s var(--ease-out);will-change:transform}.menu-link:hover{color:var(--white-pure)}.menu-link:before{content:attr(data-index);font-family:var(--font-mono);font-size:.65rem;letter-spacing:.15em;vertical-align:super;margin-right:.6em;opacity:.4}.menu-bottom{display:flex;align-items:flex-end;justify-content:space-between;padding-bottom:max(4vw,32px)}.menu-bottom-left,.menu-bottom-right{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;color:var(--grey-dim);line-height:1.8}.menu-bottom-right{text-align:right}.menu-bottom a{color:var(--grey-dim)}.menu-bottom a:hover{color:var(--white-pure)}.menu-divider{width:100%;height:1px;background:var(--grey-muted);margin-bottom:max(4vw,40px)}#hero{position:relative;z-index:1;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:flex-start;padding:0 var(--padding-x)}.hero-particles-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.hero-content{position:relative;z-index:2;max-width:1200px;width:100%}.hero-label{font-family:var(--font-mono);font-size:clamp(.6rem,.8vw,.75rem);letter-spacing:.4em;color:var(--grey-dim);margin-bottom:clamp(32px,5vw,64px);text-transform:uppercase}.hero-title{font-family:var(--font-serif);font-size:clamp(3rem,8vw,9rem);font-weight:300;line-height:1.02;letter-spacing:-.03em}.hero-title .line{display:block;overflow:hidden}.hero-title .word{display:inline-block;transform:translateY(110%);opacity:0}.hero-title em{font-style:italic;color:var(--white-pure)}.hero-scroll-hint{position:absolute;bottom:36px;left:var(--padding-x);display:flex;align-items:center;gap:16px;z-index:3}.hero-scroll-hint span{font-size:.65rem;letter-spacing:.3em;color:var(--grey-dim);text-transform:uppercase}.scroll-line{width:48px;height:1px;background:var(--grey-muted);position:relative;overflow:hidden}.scroll-line:after{content:"";position:absolute;left:-100%;top:0;width:100%;height:100%;background:var(--white);animation:scroll-line 2.5s ease-in-out infinite}@keyframes scroll-line{0%{left:-100%}50%{left:0}to{left:100%}}.section{position:relative;z-index:1;padding:clamp(100px,12vw,200px) var(--padding-x)}.section-grid{display:grid;grid-template-columns:minmax(140px,200px) 1fr;gap:clamp(40px,6vw,100px);max-width:1300px;margin:0 auto}.section-sub{margin-top:clamp(80px,10vw,160px)}.section-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.35em;color:var(--grey-dim);padding-top:10px;text-transform:uppercase}.section-label-full{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.35em;color:var(--grey-dim);padding:0 var(--padding-x);margin-bottom:clamp(48px,6vw,100px);text-transform:uppercase}.about-intro{font-family:var(--font-serif);font-size:clamp(1.5rem,3vw,2.8rem);font-weight:300;line-height:1.35;color:var(--white);margin-bottom:clamp(48px,6vw,100px);max-width:720px}.about-intro strong{color:var(--white-pure);font-weight:500}.about-traits{display:grid;grid-template-columns:1fr 1fr;gap:20px}.trait{padding:clamp(28px,3vw,48px);border:1px solid var(--grey-muted);border-radius:var(--radius);transition:border-color .4s var(--ease-out),transform .4s var(--ease-out),background .4s}.trait:hover{border-color:#ffffff40;transform:translateY(-4px);background:#ffffff05}.trait-icon{font-size:24px;display:block;margin-bottom:20px;filter:grayscale(1) brightness(.8);transition:filter .5s var(--ease-out)}.trait:hover .trait-icon{filter:grayscale(0) brightness(1)}.trait h3{font-family:var(--font-sans);font-size:1rem;font-weight:500;margin-bottom:10px}.trait p{font-size:.8rem;color:var(--grey-dim);line-height:1.5}.timeline{position:relative;padding-left:48px}.timeline-vine{position:absolute;left:8px;top:0;width:1.5px;height:100%;background:linear-gradient(180deg,var(--white) 0%,var(--grey-muted) 80%,transparent 100%);transform-origin:top center}.exp-item{position:relative;margin-bottom:48px}.exp-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-48px;top:12px;width:18px;height:18px;border-radius:50%;border:2px solid var(--white);background:var(--black);z-index:2;transition:background .3s var(--ease-out),box-shadow .3s,transform .3s}.exp-item:hover .timeline-dot{background:var(--white);transform:scale(1.2);box-shadow:0 0 24px #f0f1fa4d}.exp-card{padding:clamp(24px,3vw,40px);border:1px solid var(--grey-muted);border-radius:var(--radius);transition:border-color .4s var(--ease-out),transform .4s,background .4s}.exp-item:hover .exp-card{border-color:#fff3;background:#ffffff05;transform:translate(8px)}.exp-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;flex-wrap:wrap;gap:12px}.exp-header h3{font-family:var(--font-sans);font-size:clamp(1rem,1.5vw,1.3rem);font-weight:500;letter-spacing:-.01em}.exp-date{font-family:var(--font-mono);font-size:.7rem;color:var(--grey-dim);letter-spacing:.08em}.exp-desc{font-size:.85rem;color:var(--grey-dim);line-height:1.6;margin-bottom:20px}.exp-metrics{display:flex;gap:40px;flex-wrap:wrap}.metric{display:flex;flex-direction:column;gap:6px}.metric-value{font-family:var(--font-sans);font-size:clamp(2rem,3vw,3rem);font-weight:500;color:var(--white-pure);line-height:1;letter-spacing:-.02em}.metric-label{font-size:.7rem;color:var(--grey-dim);letter-spacing:.04em}.hobbies-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.hobby-item{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 16px;border:1px solid var(--grey-muted);border-radius:var(--radius);transition:border-color .3s var(--ease-out),transform .3s,background .3s}.hobby-item:hover{border-color:#ffffff40;transform:translateY(-4px);background:#ffffff05}.hobby-emoji{font-size:28px;filter:grayscale(1);transition:filter .4s}.hobby-item:hover .hobby-emoji{filter:grayscale(0)}.hobby-name{font-size:.75rem;color:var(--grey-dim);text-align:center;letter-spacing:.02em}.insights-list{display:flex;flex-direction:column;gap:36px}.insight-item{font-family:var(--font-serif);font-size:clamp(1.2rem,2.2vw,1.8rem);font-weight:300;font-style:italic;line-height:1.4;color:var(--grey-dim);padding-left:28px;border-left:1.5px solid var(--grey-muted);transition:color .4s var(--ease-out),border-color .4s,transform .4s;max-width:680px}.insight-item:hover{color:var(--white);border-left-color:var(--white);transform:translate(6px)}.bookshelf{display:flex;gap:4px;align-items:flex-end;height:220px;padding-bottom:20px;border-bottom:2px solid var(--grey-muted)}.book-item{position:relative;transition:transform .4s var(--ease-out)}.book-item:hover{transform:translateY(-16px)}.book-spine{width:44px;height:clamp(140px,18vw,200px);background:var(--book-color, #2d3e4a);border-radius:3px 6px 6px 3px;display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;text-orientation:mixed;padding:12px 4px;border-left:3px solid rgba(255,255,255,.08);transition:box-shadow .3s}.book-item:hover .book-spine{box-shadow:0 8px 24px #0006}.book-title-spine{font-size:.6rem;font-weight:400;color:#ffffffb3;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:160px}.book-info{position:absolute;bottom:-60px;left:50%;transform:translate(-50%);text-align:center;opacity:0;transition:opacity .3s;pointer-events:none;width:120px}.book-item:hover .book-info{opacity:1}.book-info h4{font-size:.7rem;font-weight:500;margin-bottom:2px;white-space:nowrap}.book-info p{font-size:.6rem;color:var(--grey-dim);white-space:nowrap}.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,3vw,48px);max-width:1400px;margin:0 auto;padding:0 var(--padding-x)}.project-card{position:relative;display:block;overflow:hidden;border-radius:var(--radius);transition:transform .6s var(--ease-out)}.project-card:hover{transform:scale(.98)}.project-img-wrap{position:relative;width:100%;padding-top:65%;overflow:hidden;background:#0a0a0a;border-radius:var(--radius)}.project-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;filter:grayscale(.6) brightness(.75);transition:filter .6s var(--ease-out),transform .8s var(--ease-out);transform:scale(1.04)}.project-card:hover .project-img{filter:grayscale(0) brightness(1);transform:scale(1)}.project-info{padding:24px 4px 32px}.project-info h3{font-family:var(--font-sans);font-size:clamp(1rem,1.5vw,1.4rem);font-weight:500;margin-bottom:12px;transition:color .3s var(--ease-out)}.project-card:hover .project-info h3{color:var(--white-pure)}.project-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.project-tags span{font-size:.65rem;letter-spacing:.04em;color:var(--grey-dim);padding:5px 12px;border:1px solid var(--grey-muted);border-radius:30px;transition:border-color .3s var(--ease-out),color .3s}.project-card:hover .project-tags span{border-color:#fff3;color:var(--white)}.project-stat{font-size:.75rem;color:var(--grey-dim);margin-top:4px}.playground-title{font-family:var(--font-serif);font-size:clamp(2rem,4.5vw,4.5rem);font-weight:300;margin-bottom:12px;letter-spacing:-.02em}.tarot-prompt{font-size:.85rem;color:var(--grey-dim);margin-bottom:48px;letter-spacing:.03em}.tarot-cards{display:flex;gap:32px;justify-content:flex-start;flex-wrap:wrap;margin-bottom:48px;perspective:1200px}.tarot-card{width:240px;height:360px;cursor:pointer;perspective:1200px;transition:transform .3s var(--ease-out)}.tarot-card:hover{transform:translateY(-10px)}.tarot-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .8s var(--ease-smooth)}.tarot-card.flipped .tarot-inner{transform:rotateY(180deg)}.tarot-front,.tarot-back{position:absolute;top:0;right:0;bottom:0;left:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.tarot-front{background:#0a0a0e;border:1px solid var(--grey-muted)}.tarot-pattern{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.06);border-radius:8px;background:repeating-conic-gradient(rgba(255,255,255,.02) 0% 25%,transparent 0% 50%) 0 0 / 20px 20px}.tarot-front-symbol{font-size:40px;color:var(--white);opacity:.2;transition:opacity .3s var(--ease-out)}.tarot-card:hover .tarot-front-symbol{opacity:.6}.tarot-back{background:#0a0a0e;border:1px solid rgba(255,255,255,.15);transform:rotateY(180deg);text-align:center}.tarot-card-symbol{font-size:36px;color:var(--white);margin-bottom:16px}.tarot-card-name{font-family:var(--font-serif);font-size:1.4rem;font-weight:400;margin-bottom:16px;color:var(--white-pure)}.tarot-card-meaning{font-size:.8rem;line-height:1.6;color:var(--grey-light);font-style:italic;margin-bottom:12px}.tarot-card-cn{font-size:.7rem;line-height:1.5;color:var(--grey-dim);border-top:1px solid var(--grey-muted);padding-top:10px;margin-top:4px}.tarot-result{text-align:left;margin-bottom:48px}.tarot-result-text{font-family:var(--font-serif);font-size:1.2rem;font-style:italic;color:var(--white)}.playground-creed{font-family:var(--font-serif);font-size:clamp(1rem,1.5vw,1.2rem);letter-spacing:.2em;color:var(--grey-dim);padding-top:36px;border-top:1px solid var(--grey-muted);animation:creed-breathe 5s ease-in-out infinite}@keyframes creed-breathe{0%,to{opacity:.35}50%{opacity:.7}}.gesture-area{margin-top:32px}.gesture-header{display:flex;align-items:center;gap:20px;margin-bottom:16px}.gesture-btn{height:40px;padding:0 20px;border:1px solid var(--grey-muted);border-radius:30px;font-size:.75rem;font-weight:500;letter-spacing:.06em;color:var(--white);transition:border-color .3s,background .3s;cursor:pointer!important}.gesture-btn:hover{border-color:var(--white);background:#ffffff0f}.gesture-status{font-size:.75rem;color:var(--grey-dim);letter-spacing:.03em}.gesture-canvas-wrap{position:relative;display:block;width:320px;height:180px;border:1px solid var(--grey-muted);border-radius:var(--radius);overflow:hidden}.gesture-canvas{display:block;width:100%;height:100%}.tarot-card.gesture-highlight .tarot-inner{box-shadow:0 0 0 2px #c1ff0099,0 0 30px #c1ff0026;border-radius:14px}.tarot-card.gesture-highlight{transform:translateY(-12px) scale(1.03)}.skills-constellation{width:100%;height:clamp(350px,40vw,550px);position:relative}#skills-canvas{display:block}.skills-legend{display:flex;gap:20px;flex-wrap:wrap;margin-top:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.7rem;color:var(--grey-dim);letter-spacing:.03em}.legend-item i{width:7px;height:7px;border-radius:50%;display:inline-block}.section-contact{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.contact-title{font-family:var(--font-serif);font-size:clamp(3rem,8vw,9rem);font-weight:300;line-height:1.02;letter-spacing:-.03em;margin-bottom:clamp(40px,5vw,80px)}.contact-title .line{display:block;overflow:hidden}.contact-title .word{display:inline-block}.contact-title em{font-style:italic}.contact-links{display:flex;gap:20px;margin-bottom:clamp(60px,8vw,120px)}.contact-links a{font-size:.85rem;letter-spacing:.03em;padding:14px 28px;border:1px solid var(--grey-muted);border-radius:30px;transition:border-color .3s var(--ease-out),color .3s,background .3s,transform .3s}.contact-links a:hover{border-color:var(--white);background:var(--white);color:var(--black);transform:scale(1.05)}.contact-creed{font-family:var(--font-serif);font-size:clamp(.9rem,1.3vw,1.1rem);letter-spacing:.2em;color:var(--grey-dim);margin-bottom:100px}.footer{display:flex;justify-content:space-between;width:100%;max-width:1300px;padding:32px var(--padding-x) 0;border-top:1px solid var(--grey-muted);font-size:.7rem;color:var(--grey-dim);letter-spacing:.04em}@media (max-width: 900px){:root{--padding-x: 24px;--radius: 10px}#nav{padding:16px var(--padding-x)}.nav-contact{display:none}.section-grid{grid-template-columns:1fr;gap:32px}.section-label{padding-top:0;margin-bottom:6px}.about-traits{grid-template-columns:1fr}.hobbies-grid{grid-template-columns:repeat(2,1fr)}.projects-grid{grid-template-columns:1fr;padding:0 var(--padding-x)}.contact-links{flex-direction:column;gap:12px;align-items:center}.section-label-full,#hero{padding:0 var(--padding-x)}.hero-scroll-hint{left:var(--padding-x)}#cursor{display:none}html,body,a,button{cursor:auto}.tarot-cards{gap:20px;justify-content:center}.tarot-card{width:180px;height:270px}.timeline{padding-left:36px}.timeline-dot{left:-36px;width:14px;height:14px}.exp-card{padding:20px}.exp-metrics{gap:24px}.bookshelf{flex-wrap:wrap;height:auto}.book-spine{height:140px}.preloader-count{font-size:clamp(4rem,20vw,8rem)}}@media (max-width: 480px){.projects-grid{gap:32px}.project-img-wrap{padding-top:56%}.tarot-card{width:150px;height:225px}.hobbies-grid{grid-template-columns:repeat(2,1fr);gap:12px}}
