:root{--fg: #e8eaf0;--muted: rgba(232,234,240,.5);--cyan: #00f0ff;--violet: #a78bfa;--gold: #ffcc00;--font: "Space Grotesk", system-ui, sans-serif;--mono: "Space Mono", monospace;--glass: rgba(8, 10, 24, .55);--glass-border: rgba(255,255,255,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{background:#00000a;color:var(--fg);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow-x:hidden}#app{position:relative}#webgl{position:fixed;inset:0;width:100vw;height:100vh;display:block}.ui-root{position:fixed;inset:0;z-index:5;pointer-events:none}.brand{position:absolute;top:1.4rem;left:2rem;display:flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;pointer-events:none}.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold),0 0 28px #ffc80073;animation:sunPulse 2.8s ease-in-out infinite}@keyframes sunPulse{0%,to{box-shadow:0 0 10px var(--gold),0 0 28px #ffc80073}50%{box-shadow:0 0 4px var(--gold),0 0 10px #ffc80033}}.section-hud{position:absolute;top:1.2rem;right:1.8rem;display:flex;align-items:center;gap:.3rem;font-family:var(--mono);font-size:.82rem;letter-spacing:.14em;color:#fff;pointer-events:none;background:#0000008c;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.18);padding:.45rem 1rem}.section-hud__num{color:var(--gold);font-size:1rem;font-weight:700}.section-hud__sep{color:#fff6;font-size:.75rem}.section-hud__name{margin-left:.5rem;text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;color:#fff}.panel{position:fixed;left:2rem;top:50%;transform:translateY(-50%);width:min(420px,44vw);max-height:85vh;overflow-y:visible;pointer-events:auto;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border:none;border-left:2px solid rgba(255,204,0,.35);padding:1.8rem 1.6rem;z-index:20}.panel--off{display:none;pointer-events:none}.panel__eyebrow{font-family:var(--mono);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem;text-shadow:0 0 20px rgba(0,0,0,.9),0 1px 4px rgba(0,0,0,1)}.panel__name{font-size:clamp(3.2rem,7.5vw,6rem);font-weight:700;line-height:.9;letter-spacing:-.04em;text-transform:uppercase;margin-bottom:1rem;text-shadow:0 0 40px rgba(0,0,0,1),0 2px 8px rgba(0,0,0,1),0 0 80px rgba(0,0,0,.8)}.panel__heading{font-size:clamp(2rem,3.8vw,3.2rem);font-weight:700;letter-spacing:-.03em;text-transform:uppercase;margin-bottom:.75rem;text-shadow:0 0 30px rgba(0,0,0,1),0 2px 6px rgba(0,0,0,1)}.panel__sub{font-family:var(--mono);font-size:.88rem;letter-spacing:.1em;color:var(--muted);line-height:1.7;margin-bottom:1.1rem;text-shadow:0 1px 6px rgba(0,0,0,1),0 0 20px rgba(0,0,0,.9)}.panel__body{font-size:1rem;line-height:1.72;color:var(--muted);margin-bottom:1.2rem;max-width:38ch;text-shadow:0 1px 6px rgba(0,0,0,1),0 0 20px rgba(0,0,0,.9)}.panel__chips{display:flex;flex-wrap:wrap;gap:.4rem}.chip{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .7rem;backdrop-filter:blur(6px)}.chip--c{border:1px solid rgba(0,240,255,.45);color:var(--cyan);background:#00f0ff14}.chip--v{border:1px solid rgba(167,139,250,.45);color:var(--violet);background:#7b2fff14}.chip--d{border:1px solid rgba(232,234,240,.18);color:var(--muted);background:#0000004d}.skill-rows{display:flex;flex-direction:column;gap:.95rem}.skill-row__cat{display:block;font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:#e8eaf073;margin-bottom:.4rem;text-shadow:0 1px 4px rgba(0,0,0,1)}.skill-row__chips{display:flex;flex-wrap:wrap;gap:.35rem}.proj-list{display:flex;flex-direction:column;gap:1.2rem}.proj{border-left:1px solid rgba(0,240,255,.25);padding-left:.9rem;transition:border-color .2s}.proj:hover{border-color:var(--cyan)}.proj__meta{display:flex;align-items:center;gap:.6rem;margin-bottom:.2rem}.proj__num{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;color:var(--cyan)}.proj__role{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.proj__title{font-size:1.15rem;font-weight:600;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:.32rem;text-shadow:0 1px 6px rgba(0,0,0,1)}.proj__desc{font-size:.92rem;line-height:1.58;color:var(--muted);margin-bottom:.5rem;max-width:34ch;text-shadow:0 1px 4px rgba(0,0,0,1)}.proj__chips{display:flex;flex-wrap:wrap;gap:.32rem;margin-bottom:.45rem}.proj__link{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);text-decoration:none;opacity:.75;transition:opacity .2s}.proj__link:hover{opacity:1}.contact-rows{display:flex;flex-direction:column;margin-bottom:1.4rem}.crow{display:flex;flex-direction:column;gap:.08rem;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.07);text-decoration:none}.crow__k{font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);text-shadow:0 1px 4px rgba(0,0,0,1)}.crow__v{font-size:1rem;color:var(--fg);transition:color .2s;text-shadow:0 1px 6px rgba(0,0,0,1)}a.crow:hover .crow__v{color:var(--cyan)}.exp-rows{display:flex;flex-direction:column;gap:.8rem}.exp{display:grid;grid-template-columns:7rem 1fr;gap:0 .8rem}.exp__time{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--muted);padding-top:.1rem;text-shadow:0 1px 4px rgba(0,0,0,1)}.exp__role{font-weight:600;font-size:.92rem;text-transform:uppercase;letter-spacing:.02em;text-shadow:0 1px 6px rgba(0,0,0,1)}.exp__detail{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;color:var(--muted);margin-top:.12rem;text-shadow:0 1px 4px rgba(0,0,0,1)}.action-bar{position:absolute;bottom:2.4rem;right:2rem;display:flex;flex-direction:column;gap:.55rem;align-items:flex-end;pointer-events:auto}.action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg);text-decoration:none;background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);cursor:pointer;transition:background .2s,border-color .2s,color .2s;white-space:nowrap}.action-btn:hover{background:#00f0ff1f;border-color:#00f0ff66;color:var(--cyan)}.action-btn--work{border-color:#ffcc004d;color:var(--gold)}.action-btn--work:hover{background:#ffcc001a;border-color:#fc09;color:var(--gold)}.scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none}.scroll-hint__bar{display:block;width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);animation:barDrop 2s ease-in-out infinite}@keyframes barDrop{0%{transform:scaleY(0);transform-origin:top;opacity:1}60%{transform:scaleY(1);transform-origin:top;opacity:1}to{transform:scaleY(1);transform-origin:bottom;opacity:0}}.scroll-hint__txt{font-family:var(--mono);font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:#e8eaf059;text-shadow:0 1px 4px rgba(0,0,0,1)}.planet-label{position:fixed;display:flex;flex-direction:column;align-items:center;gap:.22rem;transform:translate(-50%);pointer-events:auto;cursor:pointer;background:#080a18a6;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.14);padding:.4rem .85rem .45rem;white-space:nowrap;transition:background .2s,border-color .2s;visibility:hidden;z-index:30}.planet-label:hover,.planet-label.is-hovered{background:#00f0ff1f;border-color:#00f0ff8c}.planet-label:hover,.planet-label.is-hovered{background:#00f0ff1a;border-color:#00f0ff80;transform:translate(-50%,-3px)}.planet-label__dot{display:none}.planet-label__name,.planet-label__hint{font-family:var(--mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:#fff;line-height:1}.planet-label__desc{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:#64ffb4bf;line-height:1}.planet-label:hover .planet-label__desc,.planet-label.is-hovered .planet-label__desc{color:var(--cyan)}.planet-line{position:fixed;width:1px;background:linear-gradient(to bottom,#ffffff4d,#fff0);transform:translate(-50%);pointer-events:none;visibility:hidden;z-index:29}.ui-footer{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-between;padding:.75rem 2rem;font-family:var(--mono);font-size:.54rem;letter-spacing:.14em;text-transform:uppercase;color:#e8eaf02e;pointer-events:none}.scroll-track{position:relative;z-index:1}.scroll-section{height:100vh}.cursor{position:fixed;inset:0;pointer-events:none;z-index:50;mix-blend-mode:screen}.cursor__dot{position:absolute;width:4px;height:4px;background:var(--gold);box-shadow:0 0 8px var(--gold)}.cursor__ring{position:absolute;width:30px;height:30px;border:1px solid rgba(255,204,0,.55);border-radius:50%;opacity:.7}.film{position:fixed;inset:0;z-index:4;pointer-events:none}.film__vignette{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 30%,rgba(0,0,0,.7) 100%)}.film__grain{position:absolute;inset:0;opacity:.03;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.04),rgba(255,255,255,.04) 1px,transparent 1px,transparent 3px),repeating-linear-gradient(90deg,rgba(255,255,255,.03),rgba(255,255,255,.03) 1px,transparent 1px,transparent 4px);mix-blend-mode:overlay;animation:grain 6s steps(5) infinite}@keyframes grain{0%{transform:translateZ(0)}20%{transform:translate3d(-2%,1%,0)}40%{transform:translate3d(1%,-2%,0)}60%{transform:translate3d(-1%,-1%,0)}80%{transform:translate3d(2%,1%,0)}to{transform:translateZ(0)}}@media(max-width:1024px){.panel{width:min(400px,52vw)}}@media(max-width:768px){.panel{inset:52px 0 64px!important;width:100%!important;max-height:none;height:calc(100vh - 116px);overflow-y:auto;transform:none!important;border:none;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;padding:1rem 1.2rem 1.2rem}.panel__name{font-size:clamp(1.8rem,11vw,2.8rem)}.panel__heading{font-size:clamp(1.2rem,7vw,1.7rem)}.panel__body{font-size:.85rem;max-width:100%}.panel__sub{font-size:.75rem}.proj__desc{max-width:100%}.exp{grid-template-columns:1fr;gap:.15rem}.crow__v{font-size:.85rem}.brand{left:1rem;top:.9rem;font-size:.6rem}.action-bar{bottom:auto;top:.6rem;right:1rem;flex-direction:row;gap:.3rem}.action-btn{padding:.35rem .6rem;font-size:.54rem}.scroll-hint,.cursor,.planet-label,.planet-line{display:none}.mobile-nav{display:flex}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;z-index:40;background:#040610eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);pointer-events:auto}.mobile-nav__btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;background:none;border:none;cursor:pointer;color:#e8eaf066;font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;transition:color .2s;-webkit-tap-highlight-color:transparent}.mobile-nav__btn.is-active,.mobile-nav__btn:active{color:var(--gold)}.mobile-nav__dot{width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7}
