:root{--color-bg: #121414;--color-fg: #e3e2e2;--color-muted: #c4c7c8;--color-border: #444748;--color-surface: #1f2020;--color-accent-sky: #7dd3fc;--color-accent-sky-muted:#38bdf8;--hud-paper: #121414;--hud-ink: #eceae7;--hud-muted: #a3a098;--hud-wire: rgba(236,234,231,.38);--hud-cyan: #22d3ee;--hud-status: #7dd3fc;--hud-phosphor: #38bdf8;--hud-warning: #d97842;--hud-hairline: #2d2a24;--project-accent: #4ade80;--font-body: "Inter", ui-sans-serif, system-ui, sans-serif;--font-display: "Bodoni Moda", Georgia, serif;--font-label: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;--font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;--gutter-mobile: 20px;--gutter-desktop: 48px;--content-max: 1100px;--header-height: 72px}[data-theme=light]{--color-bg: #eae6dc;--color-fg: #383838;--color-muted: #5c5753;--color-border: rgba(60,60,58,.12);--color-surface: #e8e1db;--hud-paper: #eae6dc;--hud-ink: #292929;--hud-muted: #736c65;--hud-wire: rgba(41,41,41,.5);--hud-cyan: #0f766e;--hud-status: #0284c7;--hud-phosphor: #0369a1;--hud-warning: #b85a1f;--hud-hairline: #c4beb0;--project-accent: #15803d}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{background:var(--color-bg);color:var(--color-fg);font-family:var(--font-body);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}a:focus-visible{outline:2px solid var(--color-accent-sky);outline-offset:2px;border-radius:4px}.nav{position:fixed;top:0;left:0;right:0;height:var(--header-height);z-index:100;display:flex;align-items:center;padding:0 var(--gutter-mobile);transition:border-color .3s,background .3s}@media (min-width: 768px){.nav{padding:0 var(--gutter-desktop)}}.nav.scrolled{border-bottom:1px solid var(--hud-hairline);background:color-mix(in srgb,var(--color-bg) 82%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.nav-monogram-wrap{flex:1;display:inline-flex;justify-content:flex-start;min-width:11em;text-decoration:none;align-items:center}.nav-monogram.monogram{--mono-size: 13px;--beam-h: 1.45em;--mono-gap: .72em;--beam-scale: .06;--flare-opacity: 0;--flare-scale: 0;--track-full: .16em;--mono-glow: color-mix(in srgb, var(--hud-ink) 55%, transparent);display:inline-flex;align-items:center;justify-content:center;gap:var(--mono-gap);font-family:Barlow Semi Condensed,Helvetica Neue,Arial,sans-serif;font-weight:200;font-size:var(--mono-size);letter-spacing:0;color:var(--hud-ink);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1;text-transform:uppercase;font-feature-settings:"kern" 1,"liga" 0;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased}.mono-left,.mono-right{display:block;white-space:nowrap;flex:0 0 auto;color:color-mix(in srgb,var(--hud-ink) 88%,transparent);text-shadow:0 0 1px color-mix(in srgb,var(--hud-ink) 40%,transparent),0 0 16px color-mix(in srgb,var(--mono-glow) 25%,transparent);transition:color .28s ease,text-shadow .28s ease}.mono-left .txt,.mono-right .txt{display:inline-block;letter-spacing:0;transition:letter-spacing .42s cubic-bezier(.25,.8,.25,1)}.monogram.is-initial .mono-left,.monogram.is-initial .mono-right{width:.58em;display:inline-flex;align-items:center;justify-content:center}.monogram:not(.is-initial) .mono-left,.monogram:not(.is-initial) .mono-right{width:auto;display:block}.monogram.is-full .mono-left .txt,.monogram.is-full .mono-right .txt{letter-spacing:var(--track-full)}.monogram.is-active .mono-left,.monogram.is-active .mono-right{color:var(--hud-ink);text-shadow:0 0 1px var(--hud-ink),0 0 20px color-mix(in srgb,var(--mono-glow) 45%,transparent)}.mono-sep{position:relative;width:1px;align-self:stretch;min-height:1.05em;flex:0 0 1px}.beam-glow,.beam-core{position:absolute;top:50%;left:50%;height:var(--beam-h);transform:translate(-50%,-50%) scaleY(var(--beam-scale));transform-origin:center;pointer-events:none}.beam-glow{width:5px;border-radius:3px;filter:blur(2.5px);opacity:.85;background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--hud-ink) 18%,transparent) 18%,color-mix(in srgb,var(--hud-ink) 55%,transparent) 50%,color-mix(in srgb,var(--hud-ink) 18%,transparent) 82%,transparent)}.beam-core{width:1px;border-radius:1px;box-shadow:0 0 6px 1px var(--mono-glow);background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--hud-ink) 70%,transparent) 12%,var(--hud-ink) 50%,color-mix(in srgb,var(--hud-ink) 70%,transparent) 88%,transparent)}.beam-hot{position:absolute;top:50%;left:50%;width:3px;height:3px;border-radius:50%;background:var(--hud-ink);pointer-events:none;transform:translate(-50%,-50%) scale(calc(.6 + (1 - var(--beam-scale)) * .8));box-shadow:0 0 4px 1px var(--hud-ink),0 0 14px 3px var(--mono-glow);opacity:calc(.35 + (1 - var(--beam-scale)) * .65)}.flare{position:absolute;top:50%;left:50%;height:1px;width:2.8em;pointer-events:none;transform:translate(-50%,-50%) scaleX(var(--flare-scale));opacity:var(--flare-opacity);background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--hud-ink) 55%,transparent) 42%,var(--hud-ink) 50%,color-mix(in srgb,var(--hud-ink) 55%,transparent) 58%,transparent)}.monogram.is-collapsing{--beam-scale: 1 !important}.monogram.is-collapsing .beam-glow,.monogram.is-collapsing .beam-core{animation:mono-beam-collapse 1.1s cubic-bezier(.45,.02,.2,1) forwards}.monogram.is-collapsing .flare{animation:mono-flare-final 1.1s ease-out forwards}@keyframes mono-beam-collapse{0%,22%{transform:translate(-50%,-50%) scaleY(1)}to{transform:translate(-50%,-50%) scaleY(.06)}}@keyframes mono-flare-final{0%{transform:translate(-50%,-50%) scaleX(0);opacity:0}10%{transform:translate(-50%,-50%) scaleX(1);opacity:.92}28%,to{transform:translate(-50%,-50%) scaleX(0);opacity:0}}@media (prefers-reduced-motion: reduce){.beam-glow,.beam-core,.flare{animation:none!important}}.nav-links{position:relative;display:flex;gap:28px;list-style:none}.nav-links a{font-family:var(--font-label);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--hud-muted);transition:color .2s;text-decoration:none}.nav-links a:hover,.nav-links a.nav-active{color:var(--hud-ink)}.nav-beam-indicator{position:absolute;bottom:-4px;left:0;width:0;height:1px;pointer-events:none;opacity:0;will-change:left,width,opacity}.nav-beam-indicator.is-visible{opacity:1}.nav-beam-indicator .nb-glow{position:absolute;left:0;right:0;top:50%;height:5px;transform:translateY(-50%);border-radius:2px;filter:blur(2px);opacity:.85;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--hud-ink) 20%,transparent) 12%,color-mix(in srgb,var(--hud-ink) 50%,transparent) 50%,color-mix(in srgb,var(--hud-ink) 20%,transparent) 88%,transparent)}.nav-beam-indicator .nb-core{position:absolute;left:0;right:0;top:0;height:1px;box-shadow:0 0 6px 1px color-mix(in srgb,var(--hud-ink) 55%,transparent);background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--hud-ink) 65%,transparent) 6%,var(--hud-ink) 50%,color-mix(in srgb,var(--hud-ink) 65%,transparent) 94%,transparent)}.nav-beam-indicator .nb-tip{position:absolute;top:50%;right:0;width:3px;height:3px;border-radius:50%;background:var(--hud-ink);transform:translate(50%,-50%);box-shadow:0 0 4px 1px var(--hud-ink),0 0 10px 2px color-mix(in srgb,var(--hud-ink) 55%,transparent);opacity:0;transition:opacity .18s ease}.nav-beam-indicator.is-drawing .nb-tip{opacity:1}.has-dropdown{position:relative}.nav-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(-6px);min-width:220px;padding-top:14px;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:300}.nav-dropdown-inner{background:var(--color-bg);border:1px solid var(--hud-hairline);border-radius:6px;list-style:none;padding:5px 0;position:relative}.has-dropdown:hover .nav-dropdown,.has-dropdown:focus-within .nav-dropdown{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.nav-dropdown-inner li a{display:flex;align-items:center;gap:10px;padding:9px 16px;font-family:var(--font-label);font-size:11px;font-weight:600;letter-spacing:.12em;color:var(--hud-muted);text-transform:uppercase;transition:color .15s,background .15s;white-space:nowrap;position:relative;overflow:hidden}.nav-dropdown-inner li a:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--hud-ink) 65%,transparent) 6%,var(--hud-ink) 50%,color-mix(in srgb,var(--hud-ink) 65%,transparent) 94%,transparent);box-shadow:0 0 6px 1px color-mix(in srgb,var(--hud-ink) 55%,transparent);transform:scaleX(0);transform-origin:left;transition:transform .48s cubic-bezier(.22,.61,.36,1)}.nav-dropdown-inner li a:hover{color:var(--hud-ink)}.nav-dropdown-inner li a:hover:after{transform:scaleX(1)}.nav-dropdown-inner li a .dd-arrow{display:none}.nav-right{flex:1;display:flex;justify-content:flex-end}.theme-toggle{background:none;border:1px solid var(--hud-wire);color:var(--hud-muted);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:3px 9px;border-radius:4px;cursor:pointer;transition:border-color .2s,color .2s}.theme-toggle:hover{border-color:var(--hud-ink);color:var(--hud-ink)}.proj-hero{padding-top:calc(var(--header-height) + 64px);padding-bottom:80px;padding-left:var(--gutter-mobile);padding-right:var(--gutter-mobile);background:var(--hud-paper);border-bottom:1px solid var(--hud-hairline);transition:background .3s;position:relative;overflow:hidden}.proj-hero-bg{position:absolute;bottom:-20px;right:-40px;width:720px;height:auto;opacity:.22;filter:invert(1) brightness(2);transform:scaleX(-1);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:0}@media (min-width: 768px){.proj-hero{padding-left:var(--gutter-desktop);padding-right:var(--gutter-desktop)}}.proj-hero-inner{max-width:var(--content-max);margin:0 auto}.proj-code{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:var(--hud-muted);margin-bottom:16px;display:flex;align-items:center;gap:12px}.proj-code:before{content:"";width:32px;height:1px;background:var(--hud-hairline)}.proj-title{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,4.5rem);font-weight:400;line-height:1.04;color:var(--hud-ink);letter-spacing:-.02em;margin-bottom:40px}.proj-title em{font-style:italic;color:var(--hud-muted)}.proj-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;max-width:680px}@media (min-width: 640px){.proj-meta-grid{grid-template-columns:repeat(4,1fr)}}.proj-meta-item{padding:20px 24px 20px 0}.proj-meta-label{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.15em;color:var(--hud-muted);margin-bottom:6px}.proj-meta-value{font-family:var(--font-mono);font-size:13px;color:var(--hud-ink);line-height:1.4}.proj-meta-value.live{color:var(--project-accent)}.proj-body{padding:60px var(--gutter-mobile)}@media (min-width: 768px){.proj-body{padding:80px var(--gutter-desktop)}}.proj-body-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px}@media (min-width: 960px){.proj-body-inner{grid-template-columns:240px 1fr;gap:64px;align-items:start}}.sidebar{display:flex;flex-direction:column;gap:0;position:sticky;top:calc(var(--header-height) + 20px);max-height:calc(100vh - var(--header-height) - 40px);overflow-y:auto;scrollbar-width:none;border-right:1px solid var(--color-border);padding-right:40px}.sidebar::-webkit-scrollbar{display:none}@media (max-width: 959px){.sidebar{position:static;max-height:none;border-right:none;padding-right:0;border-bottom:1px solid var(--color-border);padding-bottom:40px}}.sidebar-block{border-top:1px solid var(--hud-hairline);padding:20px 0}.sidebar-label{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--hud-muted);margin-bottom:12px}.tech-chips{display:flex;flex-wrap:wrap;gap:5px}.tech-chip{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--hud-muted);border:1px solid var(--color-border);padding:3px 8px;border-radius:2px}.sidebar-list{list-style:none;display:flex;flex-direction:column;gap:8px}.sidebar-list li{font-family:var(--font-mono);font-size:12px;color:var(--color-muted);line-height:1.4}.sidebar-spec{display:flex;flex-direction:column}.spec-row{display:flex;justify-content:space-between;gap:8px;font-family:var(--font-mono);font-size:11px;padding:6px 0;border-bottom:1px solid var(--hud-hairline)}.spec-row:last-child{border-bottom:none}.spec-k{color:var(--hud-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;white-space:nowrap}.spec-v{color:var(--hud-ink);font-variant-numeric:tabular-nums;text-align:right;font-size:11px}.narrative{display:flex;flex-direction:column;gap:48px}.block-heading{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:var(--hud-muted);margin-bottom:20px;display:flex;align-items:center;gap:12px}.block-heading:after{content:"";flex:1;height:1px;background:var(--hud-hairline)}.narrative-block p{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--color-muted);margin-bottom:16px;text-align:justify;hyphens:auto;overflow-wrap:break-word}.narrative-block p:last-child{margin-bottom:0}.narrative-block p code{font-family:var(--font-mono);font-size:13px;background:var(--hud-hairline);padding:1px 5px;border-radius:3px;color:var(--color-fg)}.fh-diagram{width:100%;margin:8px 0 0;overflow:visible;display:block}.narrative-block.hardest{border-left:2px solid var(--project-accent);padding-left:20px}.narrative-block.key-decision{border-left:2px solid var(--hud-ink);padding-left:20px}.narrative-block p strong{color:var(--color-fg);font-weight:500}.bullet-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:4px}.bullet-list li{display:flex;gap:12px;font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--color-muted)}.bullet-list li:before{content:"—";font-family:var(--font-mono);color:var(--hud-hairline);flex-shrink:0;margin-top:1px}.bullet-list li strong{color:var(--color-fg);font-weight:500}.bullet-list li:has(strong){flex-direction:column;gap:4px}.bullet-list li:has(strong):before{display:none}.outcomes-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:4px}@media (min-width: 480px){.outcomes-grid{grid-template-columns:repeat(2,1fr)}}.outcome-card{border:1px solid var(--hud-hairline);padding:20px 24px;border-radius:4px;background:var(--color-surface)}.outcome-value{font-family:var(--font-mono);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:600;color:var(--project-accent);font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1;margin-bottom:8px}.outcome-label{font-family:var(--font-body);font-size:13px;color:var(--color-muted);line-height:1.4}.proj-gallery-section{padding:0 var(--gutter-mobile) 80px}@media (min-width: 768px){.proj-gallery-section{padding:0 var(--gutter-desktop) 100px}}.proj-gallery-inner{max-width:var(--content-max);margin:0 auto}.gallery-heading{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:var(--hud-muted);margin-bottom:24px;display:flex;align-items:center;gap:12px}.gallery-heading:after{content:"";flex:1;height:1px;background:var(--hud-hairline)}.proj-image-grid{display:grid;grid-template-columns:1fr;gap:2px}@media (min-width: 640px){.proj-image-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 960px){.proj-image-grid{grid-template-columns:repeat(3,1fr)}}.proj-image-grid img{width:100%;height:280px;-o-object-fit:cover;object-fit:cover;display:block;transition:opacity .3s}.proj-image-grid img:hover{opacity:.9}.site-footer{border-top:1px solid var(--hud-hairline);padding:28px var(--gutter-mobile);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}@media (min-width: 768px){.site-footer{padding:28px var(--gutter-desktop)}}.sf-copy{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--hud-muted)}.sf-back{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--hud-muted);transition:color .2s}.sf-back:hover{color:var(--color-accent-sky)}.arch-diagram{margin-top:28px;border:1px solid var(--hud-hairline);border-radius:4px;padding:28px 20px;background:var(--color-surface);overflow-x:auto}.arch-diagram svg,.arch-diagram img{display:block;margin:0 auto;max-width:100%}.arch-diagram img{height:auto;border-radius:4px}.fcr-gallery{position:relative;width:100%;aspect-ratio:760 / 430;margin:24px 0 0;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border:1px solid var(--hud-hairline);border-radius:4px;background:var(--color-surface);overflow:hidden}.fcr-slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease;display:flex;align-items:center;justify-content:center;padding:8px 12px}.fcr-slide.active{opacity:1}.fcr-slide svg{width:100%;height:100%}.fcr-slide img{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;border-radius:4px}.fcr-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:10;padding:4px 8px;border-radius:999px;background:#00000047}.fcr-dot{width:5px;height:5px;border-radius:50%;background:#ffffff59;transition:background .25s,transform .25s}.fcr-dot.active{background:#ffffffeb;transform:scale(1.3)}.fcr-pause-hint{position:absolute;top:10px;right:12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:#ffffff73;opacity:0;transition:opacity .25s ease;pointer-events:none;z-index:10}.fcr-gallery:hover .fcr-pause-hint{opacity:1}.fcr-caption{margin-top:10px;font-family:var(--font-mono);font-size:11px;line-height:1.55;color:var(--hud-muted)}.algo-block{margin-top:24px;background:var(--color-surface);border:1px solid var(--hud-hairline);border-radius:4px;padding:20px 24px}.algo-label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--hud-muted);margin-bottom:14px}.algo-line{font-family:var(--font-mono);font-size:13px;line-height:1.8;color:var(--hud-muted)}.algo-line .kw{color:var(--project-accent)}.algo-line .val{color:var(--hud-ink)}.algo-line .cmt{color:var(--hud-hairline);font-size:12px}.algo-line .ph{color:var(--project-accent)}.algo-indent{padding-left:28px}.algo-divider{border:none;border-top:1px solid var(--hud-hairline);margin:10px 0}.skills-banner{margin-top:8px;border:1px solid var(--hud-hairline);border-left:3px solid var(--project-accent);border-radius:4px;padding:20px 24px;background:var(--color-surface)}.skills-banner-heading{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--hud-muted);margin-bottom:14px}.skills-banner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px 24px}.skill-item{display:flex;align-items:baseline;gap:8px;font-family:var(--font-body);font-size:13px;color:var(--color-muted);line-height:1.4}.skill-item:before{content:"→";font-family:var(--font-mono);font-size:11px;color:var(--project-accent);flex-shrink:0}.reveal{opacity:0;transform:translateY(8px);transition:opacity .6s ease-out,transform .6s ease-out}.reveal.visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}.reveal-left{opacity:0;transform:translate(-36px);transition:opacity .55s ease-out,transform .55s ease-out}.reveal-left.visible{opacity:1;transform:translate(0)}.narrative-block .block-heading{transform:translate(-28px);transition:transform .5s ease-out .12s}.narrative-block.visible .block-heading{transform:translate(0)}.narrative-block .algo-label,.narrative-block .outcome-label{transform:translate(-20px);transition:transform .45s ease-out .18s}.narrative-block.visible .algo-label,.narrative-block.visible .outcome-label{transform:translate(0)}@media (prefers-reduced-motion: reduce){.reveal-left{opacity:1;transform:none;transition:none}.narrative-block .block-heading,.narrative-block .algo-label,.narrative-block .outcome-label{transform:none;transition:none}}.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:42px;height:42px;margin-left:auto;padding:9px;background:none;border:none;cursor:pointer;z-index:320}.nav-toggle-bar{display:block;width:22px;height:1.5px;background:var(--hud-ink);border-radius:1px;transition:transform .25s cubic-bezier(.23,1,.32,1),opacity .18s ease}@media (max-width: 767px){.nav-monogram-wrap{flex:0 0 auto;min-width:0}.nav>span[aria-hidden=true]{display:none}.nav-toggle{display:inline-flex}.nav.menu-open .nav-toggle-bar:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav.menu-open .nav-toggle-bar:nth-child(2){opacity:0}.nav.menu-open .nav-toggle-bar:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.nav-links{position:absolute;top:var(--header-height);left:0;right:0;flex-direction:column;align-items:stretch;gap:0;padding:4px var(--gutter-mobile) 14px;background:color-mix(in srgb,var(--color-bg) 94%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--hud-hairline);opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .2s cubic-bezier(.23,1,.32,1),transform .2s cubic-bezier(.23,1,.32,1)}.nav.menu-open .nav-links{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-links>li{width:100%}.nav-links>li>a{display:block;padding:15px 2px;font-size:14px;border-bottom:1px solid var(--hud-hairline)}.nav-beam-indicator{display:none}.has-dropdown{position:static}.nav-dropdown,.has-dropdown:hover .nav-dropdown,.has-dropdown:focus-within .nav-dropdown{position:static;transform:none;transition:none;left:auto;top:auto;opacity:1;pointer-events:inherit;min-width:0;padding-top:0;z-index:auto}.nav-dropdown-inner{background:transparent;border:none;border-radius:0;padding:2px 0 6px 16px}.nav-dropdown-inner li a{padding:11px 2px;font-size:12px;white-space:normal;transition:none}.nav-dropdown-inner li a:after{display:none}.proj-hero{padding-top:calc(var(--header-height) + 40px);padding-bottom:56px}.proj-hero-bg{width:280px;right:-48px;bottom:0;opacity:.1}.proj-code{display:block;letter-spacing:.16em;margin-bottom:14px}.proj-code:before{display:none}.proj-title{font-size:2rem;line-height:1.12;margin-bottom:28px}.proj-meta-grid{grid-template-columns:1fr 1fr;gap:2px 16px}.proj-meta-item{padding:14px 10px 14px 0}.proj-body-inner,.narrative,.sidebar,.narrative-block *{min-width:0}.proj-body p,.bullet-list li,.compare-items li,.outcome-label,.traj-detail{overflow-wrap:break-word}.bullet-list li:has(strong){flex-direction:column;gap:2px}.bullet-list li:has(strong):before{display:none}.bullet-list li strong{color:var(--color-fg)}}@media (min-width: 768px){:root{--header-height: clamp(72px, min(9.2vh, 8.5vw), 120px)}.nav-links{gap:clamp(28px,3.4vh,52px)}.nav-links a{font-size:clamp(11px,min(1.3vh,1.25vw),17px)}.nav-dropdown-inner li a{font-size:clamp(10px,min(1.2vh,1.16vw),15px)}.nav-monogram.monogram{--mono-size: clamp(11px, min(1.46vh, 1.42vw), 18px)}}@media (min-width: 1600px){body>section,body>.site-footer{zoom:1.12}}@media (min-width: 2000px){body>section,body>.site-footer{zoom:1.24}}@media (min-width: 2560px){body>section,body>.site-footer{zoom:1.42}}@media (min-width: 3400px){body>section,body>.site-footer{zoom:1.7}}@keyframes ns-pulse{0%,to{box-shadow:0 0 0 0 transparent,0 0 0 0 transparent;border-color:color-mix(in srgb,var(--project-accent) 30%,transparent)}45%,55%{box-shadow:0 0 8px 2px color-mix(in srgb,var(--project-accent) 18%,transparent),0 0 0 4px color-mix(in srgb,var(--project-accent) 7%,transparent);border-color:color-mix(in srgb,var(--project-accent) 70%,transparent)}}.nutshell-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--project-accent);background:transparent;border:1px solid color-mix(in srgb,var(--project-accent) 30%,transparent);border-radius:3px;padding:8px 16px;cursor:pointer;transition:background .18s,border-color .18s,box-shadow .18s;animation:ns-pulse 2.8s ease-in-out 1.2s infinite}.nutshell-btn:hover{background:color-mix(in srgb,var(--project-accent) 8%,transparent);border-color:color-mix(in srgb,var(--project-accent) 65%,transparent);animation:none;box-shadow:none}.nutshell-btn svg{width:14px;height:14px;flex-shrink:0}@media (prefers-reduced-motion: reduce){.nutshell-btn{animation:none}}.ns-overlay{position:fixed;inset:0;z-index:90;opacity:0;pointer-events:none;transition:opacity .38s ease;background:#04050a99;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:calc(var(--header-height) + 12px) clamp(14px,3vw,40px) 16px;perspective:1200px;perspective-origin:50% 46%}.ns-overlay.is-open{opacity:1;pointer-events:auto}[data-theme=light] .ns-overlay{background:#14120e80}.ns-card{width:100%;max-width:min(1180px,calc(100vw - clamp(24px,4vw,72px)));height:auto;max-height:calc(100vh - var(--header-height) - 28px);position:relative;display:flex;flex-direction:column;overflow:hidden;transform:rotateY(90deg) scale(.96);transition:transform .68s cubic-bezier(.23,1,.32,1);border-radius:12px;box-shadow:0 24px 80px #0000008c,0 0 0 1px var(--project-accent)}.ns-overlay.is-open .ns-card{transform:rotateY(0) scale(1)}@media (prefers-reduced-motion: reduce){.ns-overlay{transition:opacity .18s ease}.ns-card{transition:none;transform:rotateY(0) scale(1)}.ns-overlay:not(.is-open){display:none}}.ns-face--back{position:relative;flex:1 1 auto;min-height:0;border-radius:12px;background:var(--color-bg);border:1px solid var(--project-accent);display:flex;flex-direction:column}.ns-back-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 26px;border-bottom:1px solid var(--hud-hairline);background:var(--color-bg)}.ns-back-eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--project-accent)}.ns-close-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--hud-muted);background:transparent;border:1px solid var(--hud-hairline);border-radius:3px;padding:6px 12px;cursor:pointer;transition:color .18s,border-color .18s;white-space:nowrap}.ns-close-btn:hover{color:var(--hud-ink);border-color:var(--hud-muted)}.ns-close-btn svg{width:11px;height:11px}.ns-inner{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:18px 26px}@media (min-width: 768px){.ns-inner{padding:22px 38px}}.ns-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px}@media (max-width: 620px){.ns-grid{grid-template-columns:1fr}}.ns-block{display:flex;flex-direction:column;gap:6px}.ns-block.full{grid-column:1 / -1}.ns-lbl{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--project-accent);display:flex;align-items:center;gap:12px}.ns-lbl:after{content:"";flex:1;height:1px;background:var(--hud-hairline)}.ns-text{font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--hud-ink)}.ns-text.dim{color:var(--hud-ink)}.ns-bullets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.ns-bullets li{font-family:var(--font-body);font-size:14px;line-height:1.45;color:var(--hud-ink);display:flex;gap:10px;align-items:flex-start}.ns-bullets li:before{content:"→";font-family:var(--font-mono);font-size:12px;color:var(--project-accent);flex-shrink:0;margin-top:2px}.ns-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 500px){.ns-metrics{grid-template-columns:1fr 1fr}}.ns-metric{border:1px solid color-mix(in srgb,var(--project-accent) 18%,transparent);background:color-mix(in srgb,var(--project-accent) 4%,transparent);border-radius:4px;padding:12px 14px}.ns-metric-val{font-family:var(--font-mono);font-size:clamp(1.05rem,1.8vw,1.35rem);font-weight:600;color:var(--project-accent);line-height:1;margin-bottom:6px;letter-spacing:-.01em}.ns-metric-desc{font-family:var(--font-body);font-size:13px;line-height:1.4;color:var(--hud-ink)}.ns-artifacts{display:flex;flex-wrap:wrap;gap:7px}.ns-artifact{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--hud-muted);border:1px solid var(--hud-hairline);border-radius:3px;padding:5px 10px}.ns-divider{height:1px;background:var(--hud-hairline);grid-column:1 / -1;margin:2px 0}
