@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Epilogue:wght@400;500;600;700&family=Noto+Sans+JP:wght@300;400;500;600;700&family=Bitcount+Single:wght@100..900&display=swap");:root{--bg:#05060a;--bg-2:#0a0f1d;--ink:#e8ecf2;--muted:#9ba3b5;--accent:#a855f7;--accent-2:#0b6623;--panel:rgba(10,12,18,.95);--panel-border:hsla(0,0%,100%,.08);--glow:rgba(168,85,247,.45);--outline:rgba(232,236,242,.4);--sky-darken:0}*{box-sizing:border-box}*,body,html{font-weight:400}body,html{margin:0;padding:0;min-height:100%;scroll-snap-type:y mandatory;background:radial-gradient(1200px 800px at 15% 10%,rgba(20,40,90,.28),transparent),radial-gradient(1000px 700px at 80% 20%,rgba(15,118,110,.12),transparent),linear-gradient(160deg,#0b1b3a,#05060a 60%);color:var(--ink);font-family:Space Grotesk,Epilogue,Noto Sans JP,sans-serif;overflow-x:hidden}main{position:relative;min-height:100vh}body:before{background-image:radial-gradient(hsla(0,0%,100%,.08) 1px,transparent 0);background-size:3px 3px;opacity:.12;mix-blend-mode:screen}body:after,body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1}body:after{background:#020205;opacity:var(--sky-darken);transition:opacity .2s ease}body[data-theme=light]{--bg:#f6f2e9;--bg-2:#fdfcf9;--ink:#121317;--muted:#5d616b;--accent:#7c3aed;--accent-2:#0b6623;--panel:hsla(0,0%,100%,.9);--panel-border:rgba(18,19,23,.12);--glow:rgba(124,58,237,.2);--outline:rgba(18,19,23,.45);background:radial-gradient(900px 500px at 15% 10%,rgba(124,58,237,.12),transparent),radial-gradient(900px 600px at 80% 20%,rgba(11,102,35,.12),transparent),linear-gradient(160deg,#fdfcf9,#f3efe7 60%)}body[data-theme=light]:before{opacity:.06}body[data-theme=light]:after{opacity:0}body[data-theme=light] .earth-horizon{opacity:.2}body[data-theme=light] .btn.primary{background:#e6e7eb;color:#121317;border:1px solid #cfd2da}body[data-theme=light] .btn.secondary{background:#fff;color:#121317;border:1px solid rgba(18,19,23,.14)}.canvas-shell{position:fixed;inset:0;z-index:0}.model-shell{position:fixed;right:6vw;top:18vh;width:280px;height:280px;z-index:2;pointer-events:none;filter:drop-shadow(0 18px 40px rgba(0,0,0,.45))}.sketchfab-embed-wrapper{position:fixed;inset:0;width:100vw;height:100vh;z-index:0}.sketchfab-embed-wrapper iframe{width:100%;height:100%;border:0;pointer-events:none;filter:brightness(.6) contrast(1.08) saturate(.85)}.sketchfab-mask{position:fixed;left:0;right:0;bottom:0;height:72px;background:linear-gradient(0deg,rgba(5,6,10,.9),rgba(5,6,10,0));z-index:2;pointer-events:none}body[data-theme=light] .sketchfab-mask{background:linear-gradient(0deg,hsla(42,42%,94%,.95),hsla(42,42%,94%,0))}.viewport-fade{position:fixed;left:0;right:0;height:10vh;z-index:3;pointer-events:none}.viewport-fade--top{top:0;background:linear-gradient(180deg,rgba(5,6,10,.9),rgba(5,6,10,0))}.viewport-fade--bottom{bottom:0;background:linear-gradient(0deg,rgba(5,6,10,.9),rgba(5,6,10,0))}body[data-theme=light] .viewport-fade--top{background:linear-gradient(180deg,hsla(42,42%,94%,.9),hsla(42,42%,94%,0))}body[data-theme=light] .viewport-fade--bottom{background:linear-gradient(0deg,hsla(42,42%,94%,.9),hsla(42,42%,94%,0))}body[data-theme=light] .sketchfab-embed-wrapper iframe{filter:brightness(1.05) contrast(1.05) saturate(1)}.sketchfab-credit{font-size:12px;margin:0;color:rgba(232,236,242,.7);bottom:12px;background:rgba(10,12,18,.65);border:1px solid hsla(0,0%,100%,.1);padding:6px 10px;border-radius:999px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.sketchfab-credit,.top-controls{position:fixed;left:12px;z-index:3}.top-controls{top:12px;display:flex;gap:10px;align-items:center}.audio-player{position:static}.audio-btn{background:rgba(10,12,18,.65);color:rgba(232,236,242,.8);border:1px solid hsla(0,0%,100%,.12);width:34px;height:34px;border-radius:999px;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:border-color .2s ease,color .2s ease,transform .2s ease;display:grid;place-items:center}.audio-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.audio-btn svg{width:18px;height:18px}.theme-toggle{position:static;z-index:3;background:rgba(10,12,18,.65);color:rgba(232,236,242,.8);border:1px solid hsla(0,0%,100%,.12);width:34px;height:34px;border-radius:999px;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:border-color .2s ease,color .2s ease,transform .2s ease;display:grid;place-items:center}body[data-theme=light] .theme-toggle{background:hsla(0,0%,100%,.8);color:rgba(18,19,23,.8);border:1px solid rgba(18,19,23,.12)}body[data-theme=light] .audio-btn{background:hsla(0,0%,100%,.85);color:rgba(18,19,23,.85);border:1px solid rgba(18,19,23,.12)}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.theme-toggle svg{width:18px;height:18px}.sketchfab-credit a{color:#1caad9;text-decoration:none;font-weight:600}.earth-horizon{position:fixed;left:50%;bottom:-120px;width:120vw;height:320px;transform:translateX(-50%);background:radial-gradient(60% 80% at 50% 0,rgba(12,66,120,.8),transparent 70%),radial-gradient(60% 80% at 50% 0,rgba(11,102,35,.4),transparent 80%);opacity:calc(1 - var(--sky-darken));transition:opacity .2s ease;pointer-events:none;filter:blur(6px);z-index:1}.overlay{position:relative;z-index:2;padding:96px 8vw 120px 18vw}.content,.overlay{display:grid;grid-gap:0;gap:0}.content{width:100%;max-width:900px}.screen-section{min-height:100vh;scroll-snap-align:start;scroll-snap-stop:always;padding:64px 0;transition:opacity .5s ease,transform .5s ease;opacity:.35;transform:translateY(18px);color:var(--muted)}.screen-section.is-active{opacity:1;transform:none;color:var(--ink)}.side-nav{position:fixed;top:120px;left:32px;width:200px;display:grid;grid-gap:20px;gap:20px;z-index:3;color:var(--muted);font-size:12px;letter-spacing:.16em;text-transform:uppercase}.side-nav__title{opacity:.7}.side-nav__list{display:grid;grid-gap:16px;gap:16px}.side-nav__link{display:grid;grid-gap:6px;gap:6px;text-decoration:none;color:var(--ink);padding-left:10px;border-left:1px solid hsla(0,0%,100%,.08);transition:transform .2s ease,color .2s ease,border-color .2s ease}.side-nav__link:hover{transform:translateX(4px)}.side-nav__link.is-active,.side-nav__link:hover{border-color:var(--accent);color:var(--accent)}.side-nav__link.is-active .side-nav__jp,.side-nav__num{color:var(--accent)}.side-nav__jp{color:rgba(232,236,242,.6);font-size:10px;letter-spacing:.2em}.topline{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;font-size:12px;letter-spacing:.28em;color:var(--muted);text-transform:uppercase}.topline .index:last-child{text-align:right}.hero{max-width:760px}.hero-meta{display:flex;justify-content:space-between;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid hsla(0,0%,100%,.08);padding-bottom:16px}.hero-title{margin:24px 0 16px}.hero-title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-start}.hero-flag{display:inline-flex;align-items:center;justify-content:center}.hero-title span{display:block;font-size:clamp(20px,3vw,28px);color:var(--muted);margin-top:16px;text-transform:uppercase;letter-spacing:.16em}.matrix-title{font-family:Bitcount Single,Space Grotesk,sans-serif;font-size:clamp(32px,6vw,92px);line-height:1;text-transform:uppercase;letter-spacing:.08em;-webkit-text-stroke:1px rgba(232,236,242,.45);display:inline-flex;align-items:center}.flag-3d{width:48px;height:48px;display:inline-block;align-self:center;filter:drop-shadow(0 6px 12px rgba(0,0,0,.3));transform-origin:left center;animation:flagWave 2.6s ease-in-out infinite}@keyframes flagWave{0%{transform:perspective(360px) rotateY(12deg) rotateX(2deg) skewY(1deg) translateZ(2px)}50%{transform:perspective(360px) rotateY(-12deg) rotateX(-2deg) skewY(-1deg) translateY(1px)}to{transform:perspective(360px) rotateY(12deg) rotateX(2deg) skewY(1deg) translateZ(2px)}}.jp-text{font-family:Noto Sans JP,Space Grotesk,sans-serif;letter-spacing:.08em}.jp-subtle{font-size:13px;text-transform:uppercase;color:rgba(232,236,242,.65)}.hero-social{margin-top:12px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}.social-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);text-decoration:none;padding:6px 0;border-bottom:1px solid hsla(0,0%,100%,.25);transition:color .2s ease,border-color .2s ease}.social-link svg{width:16px;height:16px;fill:currentColor}.social-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.matrix-text{margin-top:18px;font-family:Noto Sans JP,Space Grotesk,sans-serif;font-size:clamp(14px,1.4vw,18px);letter-spacing:.18em;text-transform:uppercase;color:transparent;-webkit-text-stroke:.6px rgba(232,236,242,.5);background:radial-gradient(circle at 1px 1px,rgba(232,236,242,.65) 1px,transparent 1.2px);background-size:6px 6px;-webkit-background-clip:text;background-clip:text;text-shadow:0 0 18px rgba(125,211,252,.2)}.hero-copy{font-size:18px;line-height:1.6;color:var(--muted);max-width:560px}.hero-footer{margin-top:22px;display:flex;gap:24px;flex-wrap:wrap;font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid hsla(0,0%,100%,.08)}.index{letter-spacing:.22em;text-transform:uppercase;font-size:12px;color:var(--muted)}.cta-row{margin-top:28px;display:flex;gap:16px;flex-wrap:wrap}.btn{padding:12px 20px;border-radius:999px;text-decoration:none;font-weight:600;letter-spacing:.02em;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;border:1px solid transparent;display:inline-flex;align-items:center;gap:8px}.btn.primary{background:#2b2f3a;color:#e8ecf2;box-shadow:none}.btn.secondary{background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.12);color:var(--ink)}.btn.ghost{background:transparent;border:1px solid hsla(0,0%,100%,.2);color:var(--ink)}.btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(125,211,252,.35)}.section-card{border:none;border-radius:0;padding:0;box-shadow:none}.section-card,.section-card.awards{background:transparent}.section-card h2{margin:0 0 16px;font-size:clamp(28px,4vw,42px);text-transform:uppercase;letter-spacing:.08em;font-family:Bitcount Single,Space Grotesk,sans-serif}.section-card p{color:var(--muted);line-height:1.6}.grid{display:grid;grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.tag{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;background:transparent;border:1px solid hsla(0,0%,100%,.18);color:var(--accent)}.award-grid{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:20px;gap:20px}.award-list{display:grid;grid-gap:12px;gap:12px;color:var(--muted);font-size:14px}.timeline{display:grid;grid-gap:16px;gap:16px}.timeline-rail{position:relative;display:grid;grid-gap:32px;gap:32px;padding:10px 0}.timeline-rail:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:hsla(0,0%,100%,.06);transform:translateX(-50%)}.timeline-node{position:relative;display:grid;grid-template-columns:1fr 40px 1fr;align-items:start;grid-gap:20px;gap:20px;opacity:1;transform:none}.timeline-node.is-left .timeline-card{grid-column:1/2}.timeline-node.is-right .timeline-card{grid-column:3/4}.timeline-node.is-left .timeline-date{grid-column:1/2;justify-self:end}.timeline-node.is-right .timeline-date{grid-column:3/4;justify-self:start}.timeline-date{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}.timeline-dot{width:12px;height:12px;border-radius:999px;background:var(--ink);box-shadow:none;grid-column:2/3;justify-self:center;margin-top:4px}.timeline-card{padding:18px 0;border-radius:0;background:transparent;border:none}.timeline-card h3{margin:0 0 6px;font-size:22px;letter-spacing:.02em}.timeline-card,.timeline-card li,.timeline-card p,.timeline-card ul,.timeline-date,.timeline-stack{color:var(--ink)}.timeline-card li,.timeline-card p,.timeline-card ul{opacity:.92}.timeline-stack{opacity:.85}.experience-link{color:var(--ink);text-decoration:none;border-bottom:1px solid hsla(0,0%,100%,.35)}.experience-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.timeline-card ul{margin:12px 0 0;padding-left:18px;color:var(--muted);line-height:1.6}.timeline-stack{margin-top:10px;color:var(--accent);font-size:13px;letter-spacing:.08em;text-transform:uppercase}.project-list{display:grid;grid-gap:18px;gap:18px}.project-links{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:18px 0 32px}.project-links__label{letter-spacing:.24em;color:var(--muted)}.project-link,.project-links__label{font-size:12px;text-transform:uppercase}.project-link{letter-spacing:.12em;color:var(--ink);text-decoration:none;border-bottom:1px solid hsla(0,0%,100%,.3)}.project-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.project-row{display:grid;grid-template-columns:auto 1fr auto;grid-gap:20px;gap:20px;align-items:center;padding:18px 0;border-radius:0;background:transparent;border:none;opacity:1;transform:none}.project-index{font-size:18px;color:var(--accent);letter-spacing:.08em}.project-content h3{margin:0 0 8px;font-size:20px}.project-content p{margin:0 0 10px;color:var(--muted)}.project-meta{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.award-list div,.is-visible{opacity:1;transform:none}.skills{display:flex;flex-wrap:wrap;gap:10px}.skills-panel{width:100%;border-radius:28px;border:1px solid hsla(0,0%,100%,.08);background:radial-gradient(circle at top,rgba(24,34,56,.75),rgba(10,12,18,.9));padding:20px 22px;box-shadow:0 24px 40px rgba(4,8,16,.55);display:grid;grid-gap:16px;gap:16px}.skills-row{display:grid;grid-template-columns:minmax(160px,220px) 1fr;grid-gap:16px;gap:16px;align-items:start;padding-bottom:12px;border-bottom:1px dashed hsla(0,0%,100%,.12)}.skills-row:last-child{border-bottom:none;padding-bottom:0}.skills-label{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:rgba(232,236,242,.85)}.skills-pills{display:flex;flex-wrap:wrap;gap:10px}.skill-chip{padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.04em;color:#f8fafc;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.15),0 6px 14px rgba(4,8,16,.35);border:1px solid hsla(0,0%,100%,.12)}.tone-saffron{background:linear-gradient(135deg,#c0831d,#f5a623)}.tone-blue{background:linear-gradient(135deg,#225ac6,#2f80ed)}.tone-graphite{background:linear-gradient(135deg,#2d2f3c,#4c5166)}.tone-crimson{background:linear-gradient(135deg,#7b1e1e,#d64545)}.tone-emerald{background:linear-gradient(135deg,#1d5f35,#2fbf71)}.tone-violet{background:linear-gradient(135deg,#4a2b6f,#7b3ff2)}.tone-cobalt{background:linear-gradient(135deg,#123b7a,#2f6fe6)}.tone-amber{background:linear-gradient(135deg,#7a4b12,#f2a23f)}@media (max-width:720px){.skills-row{grid-template-columns:1fr}}.skill-pill{padding:8px 14px;border-radius:999px;border:1px solid hsla(0,0%,100%,.12);background:hsla(0,0%,100%,.04);color:var(--ink);font-size:13px;display:inline-flex;align-items:center;gap:8px}.footer{display:grid;place-items:center;text-align:center;color:var(--muted);font-size:13px;padding:0}.scroll-hint{bottom:32px;padding:10px 16px;border-radius:999px;background:rgba(10,16,30,.65);border:1px solid rgba(125,211,252,.2);color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hud,.scroll-hint{position:fixed;right:32px;z-index:3}.hud{top:32px;display:grid;grid-gap:12px;gap:12px;max-width:240px}.hud-panel{border:1px solid hsla(0,0%,100%,.08);padding:12px 14px;border-radius:14px;background:transparent;box-shadow:none}.hud-title{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}.hud-value{margin-top:6px;font-size:16px;color:var(--ink)}.hud-sub{margin-top:4px;font-size:11px;letter-spacing:.08em;color:rgba(232,236,242,.6)}.hud-combat .hud-value,.hud-metrics .hud-sub{text-transform:uppercase}.hud-combat .hud-value{font-size:14px;letter-spacing:.12em}.hud-progress{margin-top:10px;height:4px;background:hsla(0,0%,100%,.08);border-radius:999px;overflow:hidden}.hud-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));box-shadow:0 0 12px rgba(168,85,247,.35)}.hud-coords .hud-value{font-family:Space Grotesk,Noto Sans JP,sans-serif;letter-spacing:.12em}.loader{position:fixed;inset:0;background:#05060a;display:grid;place-items:center;z-index:10;transition:opacity .4s ease,visibility .4s ease}.loader--done{opacity:0;visibility:hidden}.loader__inner{min-width:min(360px,80vw);text-align:center}.loader__label{letter-spacing:.32em;text-transform:uppercase;font-size:12px;color:var(--muted)}.loader__value{font-size:48px;margin:12px 0 16px}.loader__bar{width:100%;height:4px;border-radius:999px;background:hsla(0,0%,100%,.08);overflow:hidden}.loader__bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2))}@media (max-width:720px){.overlay{padding:96px 5vw}.content{max-width:100%}.hud{display:none;position:static;max-width:none}.model-shell{position:static;width:220px;height:220px;margin:0 auto 32px}.sketchfab-embed-wrapper{position:fixed;inset:0;width:100vw;height:100vh}.side-nav{position:static;width:100%;letter-spacing:.2em}.side-nav__list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.side-nav__link{border-left:none;border-top:1px solid hsla(0,0%,100%,.08);padding:10px 0 0}.topline{grid-template-columns:1fr;gap:8px}.hero-meta{gap:12px}.cta-row,.hero-meta{flex-direction:column}.cta-row{align-items:flex-start}.project-row{justify-items:start}.award-grid,.project-row{grid-template-columns:1fr}.timeline-rail:before{left:12px}.timeline-node{grid-template-columns:24px 1fr;gap:12px}.timeline-node.is-left .timeline-card,.timeline-node.is-right .timeline-card{grid-column:2/3}.timeline-date,.timeline-node.is-left .timeline-date,.timeline-node.is-right .timeline-date{grid-column:2/3;justify-self:start}.timeline-dot{grid-column:1/2}.timeline-card{grid-column:2/3;width:100%}.certs-list .timeline-node{grid-template-columns:1fr}.certs-list .timeline-node .timeline-date,.certs-list .timeline-node .timeline-dot{display:none}}