:root{--bg: #07090d;--bg-2: #0b0f17;--bg-3: #11151f;--panel: rgba(13, 18, 28, .72);--panel-line: rgba(120, 200, 240, .12);--panel-line-strong: rgba(120, 200, 240, .24);--fg: #d8e4f0;--fg-mute: #8a98ad;--fg-dim: #5a6679;--cyan: #00e5ff;--cyan-soft: rgba(0, 229, 255, .18);--cyan-glow: rgba(0, 229, 255, .45);--magenta: #ff2bd6;--magenta-soft: rgba(255, 43, 214, .18);--magenta-glow: rgba(255, 43, 214, .45);--grid-line: rgba(120, 200, 240, .05);--grid-line-bright: rgba(0, 229, 255, .18);--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sans: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif}.theme-light{--bg: #f4f6fa;--bg-2: #eaeef5;--bg-3: #dfe4ee;--panel: rgba(255, 255, 255, .85);--panel-line: rgba(20, 40, 80, .1);--panel-line-strong: rgba(20, 40, 80, .22);--fg: #0d1626;--fg-mute: #4d5a72;--fg-dim: #8290a8;--cyan: #007a99;--cyan-soft: rgba(0, 122, 153, .1);--cyan-glow: rgba(0, 122, 153, .35);--magenta: #b81e95;--magenta-soft: rgba(184, 30, 149, .1);--magenta-glow: rgba(184, 30, 149, .3);--grid-line: rgba(20, 40, 80, .05);--grid-line-bright: rgba(0, 122, 153, .18)}.theme-reading{--bg: #f7f4ec;--bg-2: #f1ede2;--bg-3: #e8e3d4;--panel: rgba(255, 252, 244, .96);--panel-line: rgba(40, 32, 16, .14);--panel-line-strong: rgba(40, 32, 16, .28);--fg: #1a1410;--fg-mute: #4a3f33;--fg-dim: #7a6e5f;--cyan: #1f5d6e;--cyan-soft: rgba(31, 93, 110, .08);--cyan-glow: rgba(31, 93, 110, 0);--magenta: #8a2868;--magenta-soft: rgba(138, 40, 104, .08);--magenta-glow: rgba(138, 40, 104, 0);--grid-line: rgba(40, 32, 16, 0);--grid-line-bright: rgba(40, 32, 16, 0)}.theme-reading body,.theme-reading{font-size:16.5px;line-height:1.7}.intensity-restrained{--cyan-glow: rgba(0, 229, 255, .18);--magenta-glow: rgba(255, 43, 214, .18);--grid-line-bright: rgba(0, 229, 255, .1)}.theme-light.intensity-restrained{--cyan-glow: rgba(0, 122, 153, .18);--magenta-glow: rgba(184, 30, 149, .15)}.theme-switch{display:inline-flex;border:1px solid var(--panel-line-strong);background:var(--panel);padding:3px;gap:2px}.theme-switch button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--fg-mute);font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;cursor:pointer;transition:all .14s;display:inline-flex;align-items:center;gap:6px}.theme-switch button:hover{color:var(--fg)}.theme-switch button.active{background:var(--cyan-soft);color:var(--cyan)}.theme-switch button .glyph{display:inline-block;width:10px;height:10px;border:1px solid currentColor}.theme-switch button[data-mode=dark] .glyph{background:currentColor}.theme-switch button[data-mode=light] .glyph{border-radius:50%}.theme-switch button[data-mode=reading] .glyph{border:0;width:auto;height:auto;font-style:italic;font-family:Inter,serif;font-size:12px;letter-spacing:0;line-height:1;padding:0 2px}.theme-switch button{white-space:nowrap;min-width:0}.sidebar .theme-switch{margin-top:12px;width:100%;display:grid;grid-template-columns:1fr 1fr 1fr}.sidebar .theme-switch button{padding:5px 2px;font-size:9px;letter-spacing:.04em;justify-content:center;overflow:hidden;gap:4px}.sidebar .theme-switch button .glyph{flex-shrink:0}.page-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap}.page-head-row .theme-switch{margin-top:8px}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{min-height:100vh}.grid-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-color:var(--bg);background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:48px 48px}.grid-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle 360px at var(--mx, 50%) var(--my, 50%),var(--cyan-soft) 0%,transparent 60%);mix-blend-mode:screen;transition:background .12s linear}.theme-light .grid-bg:after{mix-blend-mode:multiply}.theme-reading .grid-bg:after{display:none}.theme-reading .grid-bg{background-image:none}.grid-bg .vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 50%,var(--bg) 100%)}.app{position:relative;z-index:1;display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;align-self:start;height:100vh;border-right:1px solid var(--panel-line);background:linear-gradient(180deg,#0b0f1766,#0b0f1700);padding:28px 20px 20px;display:flex;flex-direction:column;gap:28px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.theme-light .sidebar{background:linear-gradient(180deg,#ffffff80,#fff0)}.brand{display:flex;flex-direction:column;gap:4px}.brand-mark{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:8px}.brand-mark:before{content:"";width:8px;height:8px;background:var(--cyan);box-shadow:0 0 10px var(--cyan-glow);display:inline-block}.brand-name{font-size:18px;font-weight:600;letter-spacing:-.01em}.brand-role{font-family:var(--mono);font-size:11px;color:var(--fg-mute)}.nav{display:flex;flex-direction:column;gap:2px}.nav-section{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);padding:0 12px 6px}.nav-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--fg-mute);text-align:left;font-family:var(--mono);font-size:13px;padding:10px 12px;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:10px;position:relative;transition:background .12s,color .12s}.nav-item:hover{color:var(--fg);background:var(--cyan-soft)}.nav-item .nav-idx{font-size:10px;color:var(--fg-dim);width:22px}.nav-item.active{color:var(--cyan);background:var(--cyan-soft)}.nav-item.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow)}.nav-item.active .nav-idx{color:var(--cyan)}.sidebar-foot{margin-top:auto;font-family:var(--mono);font-size:10px;color:var(--fg-dim);display:flex;flex-direction:column;gap:4px}.status-row{display:flex;align-items:center;gap:6px}.status-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 6px #4ade8099;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.main{position:relative;min-height:100vh;padding:56px 64px 80px;max-width:1200px}.page-head{margin-bottom:48px}.page-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:10px;margin-bottom:14px}.page-eyebrow:before{content:"";display:inline-block;width:24px;height:1px;background:var(--cyan);box-shadow:0 0 6px var(--cyan-glow)}.page-title{font-size:44px;font-weight:600;letter-spacing:-.02em;margin:0 0 14px;line-height:1.05}.page-sub{color:var(--fg-mute);font-size:16px;max-width:64ch;margin:0}.page-enter{animation:glitchIn .36s cubic-bezier(.2,.8,.3,1) both}@keyframes glitchIn{0%{opacity:0;transform:translateZ(0);clip-path:inset(0 0 0 0)}10%{opacity:1;transform:translate3d(2px,0,0);clip-path:inset(20% 0 60% 0)}20%{transform:translate3d(-3px,0,0);clip-path:inset(60% 0 10% 0)}30%{transform:translate3d(1px,0,0);clip-path:inset(5% 0 80% 0)}40%{transform:translateZ(0);clip-path:inset(0 0 0 0)}to{opacity:1;transform:translateZ(0)}}.panel{background:var(--panel);border:1px solid var(--panel-line);border-radius:6px;position:relative}.panel-corner{position:absolute;width:10px;height:10px;border-color:var(--cyan)}.panel-corner.tl{top:-1px;left:-1px;border-top:1px solid;border-left:1px solid}.panel-corner.tr{top:-1px;right:-1px;border-top:1px solid;border-right:1px solid}.panel-corner.bl{bottom:-1px;left:-1px;border-bottom:1px solid;border-left:1px solid}.panel-corner.br{bottom:-1px;right:-1px;border-bottom:1px solid;border-right:1px solid}.mono{font-family:var(--mono)}.mono-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-mute)}.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;margin-bottom:80px}.hero-left h1{font-size:64px;line-height:1;letter-spacing:-.03em;font-weight:600;margin:16px 0 24px}.hero-left h1 .accent{color:var(--cyan);text-shadow:0 0 24px var(--cyan-glow)}.hero-left h1 .accent-mag{color:var(--magenta);text-shadow:0 0 24px var(--magenta-glow)}.hero-tag{color:var(--fg-mute);font-size:17px;max-width:52ch;margin:0 0 32px;line-height:1.55}.hero-cta{display:flex;gap:12px;flex-wrap:wrap}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--panel-line-strong);background:var(--panel);color:var(--fg);font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:12px 18px;cursor:pointer;transition:all .14s;display:inline-flex;align-items:center;gap:8px}.btn:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 0 1px var(--cyan-soft),0 0 16px var(--cyan-soft)}.btn-primary{background:var(--cyan-soft);border-color:var(--cyan);color:var(--cyan)}.btn-primary:hover{background:var(--cyan);color:#07090d;text-shadow:none}.theme-light .btn-primary:hover{color:#fff}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:40px}.stat{padding:16px;border:1px solid var(--panel-line);background:var(--panel)}.stat-num{font-family:var(--mono);font-size:28px;color:var(--cyan);font-weight:500;letter-spacing:-.02em;text-shadow:0 0 12px var(--cyan-glow)}.stat-label{font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase;margin-top:4px}.hero-term{background:linear-gradient(180deg,rgba(0,229,255,.02) 0%,transparent 100%),var(--bg-2);border:1px solid var(--cyan);font-family:var(--mono);font-size:12.5px;line-height:1.65;align-self:start;position:relative;overflow:hidden;box-shadow:0 0 0 1px #00e5ff26,0 0 24px #00e5ff14,inset 0 0 0 1px #00e5ff0f}.hero-term:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:repeating-linear-gradient(180deg,transparent 0px,transparent 3px,rgba(0,229,255,.025) 3px,rgba(0,229,255,.025) 4px);z-index:1}.theme-light .hero-term:before,.theme-reading .hero-term:before{display:none}.intensity-restrained .hero-term:before{opacity:.4}.hero-term:after{content:"";position:absolute;top:4px;left:4px;width:14px;height:14px;border-top:1px solid var(--cyan);border-left:1px solid var(--cyan);pointer-events:none;z-index:2}.hero-term-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 14px;border-bottom:1px solid var(--cyan);background:#00e5ff0f;color:var(--cyan);font-size:10px;letter-spacing:.16em;text-transform:uppercase;position:relative;z-index:2}.hero-term-bar .term-id{color:var(--cyan);text-shadow:0 0 8px var(--cyan-glow);font-weight:600}.hero-term-bar .term-mid{color:var(--fg-mute);font-size:9.5px;letter-spacing:.12em;flex:1;text-align:center}.hero-term-bar .term-stat{color:var(--magenta);text-shadow:0 0 6px var(--magenta-glow);animation:termPulse 1.4s ease-in-out infinite}@keyframes termPulse{0%,to{opacity:1}50%{opacity:.45}}.theme-reading .hero-term{border-color:var(--panel-line-strong);box-shadow:none}.theme-reading .hero-term-bar{background:var(--bg-3);border-bottom-color:var(--panel-line);color:var(--fg)}.theme-reading .hero-term-bar .term-id,.theme-reading .hero-term-bar .term-stat{text-shadow:none}.theme-reading .hero-term:after{display:none}.hero-term-body{padding:18px 18px 22px;position:relative;z-index:2}.hero-term-body .ln{display:block;white-space:pre-wrap}.hero-term-body .prompt{color:var(--cyan);font-weight:600}.hero-term-body .key{color:var(--magenta)}.hero-term-body .str{color:#b8e986}.theme-light .hero-term-body .str,.theme-reading .hero-term-body .str{color:#2e6b1f}.theme-reading .hero-term-body .key{color:#8a2868}.hero-term-body .com{color:var(--fg-dim)}.cursor{display:inline-block;width:8px;height:14px;background:var(--cyan);vertical-align:middle;margin-left:2px;animation:blink 1.1s steps(2,end) infinite;box-shadow:0 0 6px var(--cyan-glow)}@keyframes blink{50%{opacity:0}}.now-block{margin-top:60px;display:grid;grid-template-columns:240px 1fr;gap:32px;padding-top:40px;border-top:1px solid var(--panel-line)}.now-block h3{margin:0;font-size:13px;font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute)}.now-list{display:flex;flex-direction:column;gap:16px}.now-row{display:grid;grid-template-columns:100px 1fr auto;gap:16px;align-items:baseline;font-size:14px;padding-bottom:14px;border-bottom:1px dashed var(--panel-line)}.now-row:last-child{border-bottom:0}.now-row .when{font-family:var(--mono);font-size:11px;color:var(--cyan);letter-spacing:.06em}.now-row .what strong{color:var(--fg);font-weight:500}.now-row .what span{color:var(--fg-mute)}.now-row .where{font-family:var(--mono);font-size:11px;color:var(--fg-dim)}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.skill-cat{padding:22px 24px;border:1px solid var(--panel-line);background:var(--panel);position:relative}.skill-cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.skill-cat-name{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan)}.skill-cat-num{font-family:var(--mono);font-size:11px;color:var(--fg-dim)}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{font-family:var(--mono);font-size:12px;padding:5px 10px;border:1px solid var(--panel-line-strong);color:var(--fg);background:#78c8f00a;transition:all .14s;cursor:default}.chip:hover,.chip.primary{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-soft)}.chip.accent{border-color:var(--magenta);color:var(--magenta);background:var(--magenta-soft)}.proj-hero{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;margin-bottom:32px;padding:28px;border:1px solid var(--panel-line);background:var(--panel);position:relative}.proj-title{font-size:36px;font-weight:600;letter-spacing:-.02em;margin:8px 0 12px}.proj-tag{color:var(--fg-mute);margin:0 0 18px;font-size:15px;line-height:1.55}.proj-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:18px}.meta-item{font-family:var(--mono);font-size:11px}.meta-item .lbl{color:var(--fg-dim);display:block;margin-bottom:2px;letter-spacing:.06em;text-transform:uppercase}.meta-item .val{color:var(--fg)}.proj-stats{display:flex;flex-direction:column;gap:10px;align-self:start}.proj-stat{padding:14px 16px;border:1px solid var(--panel-line);background:var(--bg-2);display:flex;align-items:baseline;justify-content:space-between;gap:12px}.proj-stat .v{font-family:var(--mono);font-size:22px;color:var(--cyan);text-shadow:0 0 12px var(--cyan-glow)}.proj-stat .l{font-family:var(--mono);font-size:11px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.06em;text-align:right}.pipeline-wrap{margin-top:16px;padding:32px 28px 28px;border:1px solid var(--panel-line);background:var(--panel)}.pipeline-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.pipeline-head h3{margin:0;font-size:18px;font-weight:600;letter-spacing:-.01em}.pipeline-controls{display:flex;gap:8px}.pl-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--panel-line-strong);color:var(--fg-mute);font-family:var(--mono);font-size:11px;padding:6px 10px;cursor:pointer;letter-spacing:.06em;text-transform:uppercase}.pl-btn:hover{color:var(--cyan);border-color:var(--cyan)}.pl-btn.active{color:var(--cyan);border-color:var(--cyan);background:var(--cyan-soft)}.pipeline{position:relative;height:360px;background:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:24px 24px;border:1px solid var(--panel-line);overflow:hidden}.stack-diagram{margin-top:20px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.stack-col{border:1px solid var(--panel-line);padding:14px 16px;background:var(--bg-2)}.stack-col h4{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--magenta);margin:0 0 10px}.stack-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.stack-col li{font-family:var(--mono);font-size:12px;color:var(--fg);display:flex;align-items:center;gap:8px}.stack-col li:before{content:"›";color:var(--cyan);font-weight:600}.resume-list{display:flex;flex-direction:column;gap:12px}.role{border:1px solid var(--panel-line);background:var(--panel);overflow:hidden;transition:border-color .14s}.role.open{border-color:var(--panel-line-strong)}.role-head{display:grid;grid-template-columns:1fr auto auto;gap:20px;padding:20px 24px;cursor:pointer;align-items:center;-webkit-user-select:none;user-select:none}.role-head:hover{background:#00e5ff0a}.role-title{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px}.role-org{font-family:var(--mono);font-size:12px;color:var(--fg-mute)}.role-org .sep{color:var(--fg-dim);margin:0 6px}.role-when{font-family:var(--mono);font-size:11px;color:var(--cyan);letter-spacing:.06em;text-align:right}.role-toggle{width:28px;height:28px;border:1px solid var(--panel-line-strong);display:grid;place-items:center;font-family:var(--mono);color:var(--fg-mute);transition:all .14s}.role.open .role-toggle{background:var(--cyan);color:#07090d;border-color:var(--cyan)}.theme-light .role.open .role-toggle{color:#fff}.role-body{padding:24px;border-top:1px solid var(--panel-line);display:grid;grid-template-columns:1fr 200px;gap:32px}.role-body p.lead{margin:0 0 14px;color:var(--fg-mute);line-height:1.6}.role-body ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px}.role-body li{position:relative;padding-left:18px;line-height:1.55;color:var(--fg)}.role-body li:before{content:"▸";position:absolute;left:0;color:var(--cyan)}.role-body li strong{color:var(--fg);font-weight:600}.role-side h5{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);margin:0 0 8px}.role-side .stack-list{display:flex;flex-wrap:wrap;gap:5px}.role-side .stack-list span{font-family:var(--mono);font-size:11px;color:var(--fg-mute);border:1px solid var(--panel-line);padding:3px 7px}.edu-block{margin-top:32px;padding:22px 24px;border:1px solid var(--panel-line);background:var(--panel);display:grid;grid-template-columns:1fr auto;align-items:center}.edu-block .school{font-size:16px;font-weight:600}.edu-block .deg{color:var(--fg-mute);font-size:14px;margin-top:2px}.edu-block .when{font-family:var(--mono);font-size:12px;color:var(--cyan)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:760px}.contact-card{padding:24px;border:1px solid var(--panel-line);background:var(--panel);display:flex;flex-direction:column;gap:8px;text-decoration:none;color:inherit;transition:all .14s}.contact-card:hover{border-color:var(--cyan);box-shadow:0 0 0 1px var(--cyan-soft),0 0 24px var(--cyan-soft)}.contact-card .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute)}.contact-card .val{font-size:20px;font-weight:500;letter-spacing:-.01em}.contact-card .arrow{font-family:var(--mono);color:var(--cyan);margin-top:8px;font-size:12px}::selection{background:var(--cyan);color:var(--bg)}@media(max-width:980px){.phase-ticker>div{flex:1 1 calc(33.333% - 4px)!important;min-width:92px}}.mobile-preview .phase-ticker>div{flex:1 1 calc(33.333% - 4px)!important;min-width:92px}.mobile-preview{background:#000}.mobile-preview .grid-bg{display:none}.mobile-preview .app{display:block;max-width:390px;margin:24px auto;min-height:calc(100vh - 48px);border:1px solid var(--cyan);border-radius:28px;overflow:hidden;box-shadow:0 0 0 6px #1a1a1a,0 0 60px #00e5ff33;background:var(--bg);position:relative}.mobile-preview .sidebar{display:none}.mobile-preview .main{padding:24px 20px 110px;max-width:100%}.mobile-preview .hero,.mobile-preview .proj-hero{grid-template-columns:1fr;gap:28px}.mobile-preview .proj-hero{padding:24px}.mobile-preview .skills-grid,.mobile-preview .stack-diagram,.mobile-preview .contact-grid{grid-template-columns:1fr}.mobile-preview .role-body{grid-template-columns:1fr;gap:20px;padding:0 18px 20px}.mobile-preview .role-head{grid-template-columns:1fr auto;gap:12px;padding:16px 18px}.mobile-preview .role-when{grid-column:1;grid-row:2;text-align:left}.mobile-preview .role-toggle{grid-column:2;grid-row:1 / span 2;align-self:center}.mobile-preview .hero-left h1{font-size:32px;line-height:1.05}.mobile-preview .page-title{font-size:26px}.mobile-preview .hero-stats{grid-template-columns:1fr 1fr;gap:8px}.mobile-preview .hero-stats .stat:nth-child(3){grid-column:1 / -1}.mobile-preview .stat{padding:12px}.mobile-preview .stat-num{font-size:22px}.mobile-preview .stat-label{font-size:9.5px;line-height:1.3}.mobile-preview .now-block{grid-template-columns:1fr;gap:16px;padding-top:28px;margin-top:40px}.mobile-preview .now-row{grid-template-columns:1fr;gap:4px}.mobile-preview .now-row .when{order:-1}.mobile-preview .pipeline-wrap{padding:20px 16px}.mobile-preview .pipeline{height:280px}.mobile-preview .pipeline-head{flex-direction:column;align-items:flex-start;gap:12px}.mobile-preview .proj-stats{flex-direction:row;flex-wrap:wrap}.mobile-preview .proj-stat{flex:1 1 calc(50% - 5px)}.mobile-preview .page-head-row{flex-direction:column;align-items:flex-start;gap:16px}.mobile-preview .page-head-row .theme-switch{width:100%;display:grid;grid-template-columns:1fr 1fr 1fr}.mobile-preview .edu-block{grid-template-columns:1fr;gap:10px}.mobile-preview .hero-term-bar{flex-wrap:wrap;gap:6px;padding:8px 10px}.mobile-preview .hero-term-bar .term-mid{display:none}.mobile-preview .hero-term-body{padding:14px 14px 18px;font-size:11.5px}.mobile-preview .mobile-drawer{position:absolute}.mobile-bar{display:none;position:sticky;top:0;z-index:50;align-items:center;gap:12px;padding:10px 14px;background:#07090dd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--panel-line);grid-template-columns:auto 1fr auto}.theme-light .mobile-bar{background:#f4f6fae6}.theme-reading .mobile-bar{background:#f7f4ecf2}@media(max-width:980px){.mobile-bar{display:grid}}.mobile-preview .mobile-bar{display:grid}.mobile-bar .mb-brand{display:flex;flex-direction:column;gap:1px;min-width:0}.mobile-bar .mb-mark{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:6px}.mobile-bar .mb-mark:before{content:"";width:6px;height:6px;background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow);display:inline-block}.mobile-bar .mb-name{font-size:14px;font-weight:600;letter-spacing:-.01em}.mobile-bar .mb-section{justify-self:end;display:flex;align-items:baseline;gap:6px;padding:4px 10px;border:1px solid var(--panel-line-strong);background:var(--panel);font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;line-height:1}.mobile-bar.open .mb-section{opacity:.4}.mobile-bar .mb-section-idx{font-size:9px;color:var(--fg-dim)}.mobile-bar .mb-section-label{font-size:10.5px;color:var(--cyan)}.mobile-bar .mb-progress{position:absolute;left:0;right:0;bottom:-1px;height:1.5px;background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow);transform-origin:0 0;transition:transform 80ms linear;z-index:1}.mobile-bar .mb-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--cyan);color:var(--cyan);width:38px;height:38px;display:grid;place-items:center;cursor:pointer;font-family:var(--mono)}.mobile-bar .mb-toggle .bar{display:block;width:18px;height:1.5px;background:var(--cyan);margin:3px 0;transition:all .2s}.mobile-bar.open .mb-toggle .bar:nth-child(1){transform:translateY(4.5px) rotate(45deg)}.mobile-bar.open .mb-toggle .bar:nth-child(2){opacity:0}.mobile-bar.open .mb-toggle .bar:nth-child(3){transform:translateY(-4.5px) rotate(-45deg)}.mobile-drawer{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;background:#07090df5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px 18px 24px;flex-direction:column;gap:14px;overflow-y:auto}.theme-light .mobile-drawer{background:#f4f6faf7}.theme-reading .mobile-drawer{background:#f7f4ecfa}.mobile-drawer.open{display:flex;animation:drawerIn .28s cubic-bezier(.2,.8,.3,1)}@keyframes drawerIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-drawer .md-status{position:relative;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:14px 14px 12px;border:1px solid var(--cyan);background:linear-gradient(180deg,rgba(0,229,255,.06),transparent),var(--bg-2);font-family:var(--mono);margin-top:56px}.mobile-drawer .md-status:before{content:"// NODE_STATUS";position:absolute;top:-7px;left:12px;padding:0 6px;background:var(--bg);font-size:9px;letter-spacing:.18em;color:var(--cyan)}.mobile-drawer .md-status-row{display:flex;flex-direction:column;gap:3px;min-width:0}.mobile-drawer .md-key{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-dim)}.mobile-drawer .md-val{font-size:12px;color:var(--fg);display:flex;align-items:center;gap:5px}.mobile-drawer .md-val.ok{color:#4ade80}.theme-light .mobile-drawer .md-val.ok{color:#1f8a4c}.theme-reading .mobile-drawer .md-val.ok{color:#2a6c3d}.mobile-drawer .md-dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor;animation:pulse 2s infinite}.mobile-drawer .md-close{position:absolute;top:8px;right:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--panel-line-strong);color:var(--fg-mute);width:26px;height:26px;display:grid;place-items:center;font-family:var(--mono);font-size:16px;line-height:1;cursor:pointer}.mobile-drawer .md-close:hover{color:var(--cyan);border-color:var(--cyan)}.mobile-drawer .nav-section{padding:4px 6px;font-size:10px;color:var(--fg-mute)}.mobile-drawer .nav-item-lg{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:14px;border:1px solid var(--panel-line);background:var(--panel);border-radius:0;margin-bottom:4px}.mobile-drawer .nav-item-lg:hover,.mobile-drawer .nav-item-lg.active{border-color:var(--cyan);background:var(--cyan-soft)}.mobile-drawer .nav-item-lg .nav-idx{font-size:11px;color:var(--cyan);letter-spacing:.04em;width:auto}.mobile-drawer .nav-item-lg .nav-label{display:flex;flex-direction:column;gap:2px;min-width:0}.mobile-drawer .nav-item-lg .nav-label-main{font-family:var(--sans);font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--fg)}.mobile-drawer .nav-item-lg.active .nav-label-main{color:var(--cyan)}.mobile-drawer .nav-item-lg .nav-label-hint{font-family:var(--mono);font-size:10.5px;color:var(--fg-mute);letter-spacing:.04em}.mobile-drawer .nav-item-lg .nav-chev{font-family:var(--mono);font-size:18px;color:var(--fg-dim);transition:transform .16s,color .16s}.mobile-drawer .nav-item-lg:hover .nav-chev,.mobile-drawer .nav-item-lg.active .nav-chev{color:var(--cyan);transform:translate(2px)}.mobile-drawer .nav-item-lg.active:before{display:none}.mobile-drawer .theme-switch{margin-top:6px;display:grid;grid-template-columns:1fr 1fr 1fr}.mobile-drawer .mb-foot{margin-top:auto;padding-top:18px;border-top:1px dashed var(--panel-line);font-family:var(--mono);font-size:10px;color:var(--fg-dim);display:flex;flex-direction:column;gap:10px}.mobile-drawer .mb-foot-row{display:flex;justify-content:space-between;gap:8px;letter-spacing:.04em}.mobile-drawer .mb-foot-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--cyan);background:var(--cyan-soft);color:var(--cyan);text-decoration:none;font-size:12px;letter-spacing:.06em}.mobile-drawer .mb-foot-cta:hover{background:var(--cyan);color:var(--bg)}.theme-light .mobile-drawer .mb-foot-cta:hover{color:#fff}.mobile-quick{display:none;position:fixed;left:12px;right:12px;bottom:12px;z-index:48;gap:8px;align-items:stretch;pointer-events:none}@media(max-width:980px){.mobile-quick{display:flex}}.mobile-preview .mobile-quick{display:flex;position:absolute;left:14px;right:14px;bottom:14px}.mobile-quick>*{pointer-events:auto}.mobile-quick .mq-mail{flex:0 0 auto;width:50px;display:grid;place-items:center;border:1px solid var(--cyan);background:#07090dd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--cyan);font-size:18px;text-decoration:none;transition:all .14s}.theme-light .mobile-quick .mq-mail{background:#f4f6faeb}.theme-reading .mobile-quick .mq-mail{background:#f7f4ecf5}.mobile-quick .mq-mail:hover{background:var(--cyan);color:var(--bg)}.mobile-quick .mq-go{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;display:grid;grid-template-columns:1fr auto;align-items:center;text-align:left;border:1px solid var(--cyan);background:var(--cyan);color:var(--bg);padding:10px 14px;cursor:pointer;font-family:var(--mono);letter-spacing:.04em;box-shadow:0 0 0 1px var(--cyan-soft),0 8px 24px #00000073,0 0 24px var(--cyan-glow)}.theme-light .mobile-quick .mq-go{color:#fff;box-shadow:0 0 0 1px var(--cyan-soft),0 8px 24px #00000026}.theme-reading .mobile-quick .mq-go{color:#f7f4ec;box-shadow:0 0 0 1px var(--panel-line),0 8px 24px #00000026}.mobile-quick .mq-go-label{font-size:14px;font-weight:600;letter-spacing:-.01em;font-family:var(--sans)}.mobile-quick .mq-go-hint{font-size:10px;opacity:.75;letter-spacing:.06em;text-transform:uppercase;font-family:var(--mono);text-align:right}@media(max-width:980px){.app{grid-template-columns:1fr}.sidebar{display:none}.main{padding:24px 20px 110px;max-width:100%}.hero,.proj-hero{grid-template-columns:1fr;gap:28px;padding:0;border:0;background:transparent;margin-bottom:48px}.proj-hero{padding:24px;border:1px solid var(--panel-line);background:var(--panel)}.skills-grid,.stack-diagram,.contact-grid{grid-template-columns:1fr}.role-body{grid-template-columns:1fr;gap:20px}.role-head{grid-template-columns:1fr auto;gap:12px;padding:16px 18px}.role-when{grid-column:1;grid-row:2;text-align:left}.role-toggle{grid-column:2;grid-row:1 / span 2;align-self:center}.role-body{padding:0 18px 20px}.hero-left h1{font-size:38px}.page-title{font-size:30px}.page-head{margin-bottom:32px}.hero-stats{grid-template-columns:repeat(3,1fr);gap:8px}.stat{padding:12px}.stat-num{font-size:22px}.stat-label{font-size:9.5px;line-height:1.3}.now-block{grid-template-columns:1fr;gap:16px;padding-top:28px;margin-top:40px}.now-row{grid-template-columns:1fr;gap:4px}.now-row .when{order:-1}.now-row .where{font-size:10px}.pipeline-wrap{padding:20px 16px}.pipeline{height:280px}.pipeline-head{flex-direction:column;align-items:flex-start;gap:12px}.proj-stats{flex-direction:row;flex-wrap:wrap}.proj-stat{flex:1 1 calc(50% - 5px)}.page-head-row{flex-direction:column;align-items:flex-start;gap:16px}.page-head-row .theme-switch{width:100%;display:grid;grid-template-columns:1fr 1fr 1fr}.edu-block{grid-template-columns:1fr;gap:10px}.hero-cta{gap:8px}.hero-cta .btn{font-size:11px;padding:10px 14px}.proj-hero+.pipeline-wrap+.stack-diagram+div>div{grid-template-columns:1fr!important}.grid-bg:after{opacity:.4}}@media(max-width:520px){.main{padding:20px 16px 60px}.hero-left h1{font-size:32px;line-height:1.05}.page-title{font-size:26px}.hero-stats{grid-template-columns:1fr 1fr}.hero-stats .stat:nth-child(3){grid-column:1 / -1}.hero-term-bar{flex-wrap:wrap;gap:6px;padding:8px 10px}.hero-term-bar .term-mid{display:none}.hero-term-body{padding:14px 14px 18px;font-size:11.5px}.role-title{font-size:16px}.proj-stat .v{font-size:18px}}
