:root{--font-display: "Bricolage Grotesque", "Hanken Grotesk", system-ui, sans-serif;--font-body: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", monospace;--r-xs: 6px;--r-sm: 9px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--z-nav: 50;--z-drawer: 60;--z-scrim: 55;--z-palette: 80;--z-toast: 90;--ease: cubic-bezier(.16, 1, .3, 1);--bg: oklch(.17 .022 250);--bg-2: oklch(.2 .024 250);--surface: oklch(.225 .026 252);--surface-2: oklch(.26 .028 252);--surface-3: oklch(.3 .03 252);--ink: oklch(.97 .01 240);--ink-soft: oklch(.82 .02 240);--ink-faint: oklch(.66 .022 245);--line: oklch(.35 .025 250);--line-soft: oklch(.3 .022 250);--primary: oklch(.82 .15 188);--primary-ink: oklch(.2 .04 200);--primary-dim: oklch(.62 .1 190);--accent: oklch(.84 .15 84);--accent-ink: oklch(.24 .05 80);--secondary: oklch(.74 .15 300);--rose: oklch(.72 .16 18);--success: oklch(.78 .16 158);--danger: oklch(.7 .18 22);--warn: oklch(.83 .15 78);--shadow-sm: 0 1px 2px oklch(0 0 0 / .4);--shadow-md: 0 8px 24px -8px oklch(0 0 0 / .55);--shadow-lg: 0 24px 60px -18px oklch(0 0 0 / .65);--glow: 0 0 0 1px oklch(.82 .15 188 / .25), 0 0 28px -6px oklch(.82 .15 188 / .4);color-scheme:dark}[data-theme=light]{--bg: oklch(.985 .005 240);--bg-2: oklch(.965 .006 240);--surface: oklch(1 0 0);--surface-2: oklch(.97 .006 240);--surface-3: oklch(.94 .008 240);--ink: oklch(.24 .03 250);--ink-soft: oklch(.4 .025 250);--ink-faint: oklch(.54 .02 250);--line: oklch(.88 .01 250);--line-soft: oklch(.92 .008 250);--primary: oklch(.6 .13 195);--primary-ink: oklch(.99 .01 200);--primary-dim: oklch(.68 .11 192);--accent: oklch(.7 .14 70);--accent-ink: oklch(.99 .01 80);--secondary: oklch(.55 .16 300);--rose: oklch(.6 .17 18);--success: oklch(.6 .15 158);--danger: oklch(.58 .2 25);--warn: oklch(.7 .14 70);--shadow-sm: 0 1px 2px oklch(.5 .02 250 / .1);--shadow-md: 0 10px 30px -12px oklch(.4 .04 250 / .22);--shadow-lg: 0 28px 60px -22px oklch(.4 .04 250 / .28);--glow: 0 0 0 1px oklch(.6 .13 195 / .2), 0 0 24px -8px oklch(.6 .13 195 / .25);color-scheme:light}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;background-image:radial-gradient(900px 500px at 12% -8%,oklch(.82 .15 188 / .08),transparent 60%),radial-gradient(800px 520px at 100% 0%,oklch(.74 .15 300 / .07),transparent 55%),radial-gradient(700px 600px at 50% 120%,oklch(.84 .15 84 / .05),transparent 60%);background-attachment:fixed}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.12;letter-spacing:-.015em;color:var(--ink)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.mono,code,kbd{font-family:var(--font-mono)}::selection{background:#00e1d54d;background:oklch(.82 .15 188 / .3)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}*{scrollbar-width:thin;scrollbar-color:var(--surface-3) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:99px;border:2px solid var(--bg)}.app{min-height:100vh}.shell{display:grid;grid-template-columns:270px 1fr}@media (max-width: 980px){.shell{grid-template-columns:1fr}}.main{min-width:0;padding:0 clamp(16px,4vw,56px) 120px}.container{max-width:1080px;margin:0 auto;width:100%}.topbar{position:sticky;top:0;z-index:var(--z-nav);display:flex;align-items:center;gap:14px;padding:12px clamp(16px,4vw,32px);background:#081019b8;-webkit-backdrop-filter:saturate(1.4) blur(14px);backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--line-soft)}[data-theme=light] .topbar{background:#ffffffb8}.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;font-size:1.05rem}.brand .mark{width:30px;height:30px;flex:none}.brand small{font-family:var(--font-mono);font-weight:500;color:var(--ink-faint);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase}.topbar-spacer{flex:1}.icon-btn{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-soft);transition:border-color .2s,color .2s,background .2s}.icon-btn:hover{color:var(--ink);border-color:var(--primary-dim)}.kbtn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-faint);font-size:.85rem;transition:border-color .2s,color .2s}.kbtn:hover{color:var(--ink-soft);border-color:var(--primary-dim)}.kbtn kbd{font-family:var(--font-mono);font-size:.7rem;padding:2px 6px;border:1px solid var(--line);border-radius:5px;color:var(--ink-faint);background:var(--bg-2)}.sidebar{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;border-right:1px solid var(--line-soft);padding:18px 14px 40px;background:#070f1880}[data-theme=light] .sidebar{background:#f6f9fb99}@media (max-width: 980px){.sidebar.desktop{display:none}}.nav-group{margin-bottom:18px}.nav-group h4{font-family:var(--font-mono);font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint);padding:0 10px;margin-bottom:6px}.nav-link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);color:var(--ink-soft);font-size:.92rem;font-weight:500;position:relative;transition:background .18s,color .18s}.nav-link:hover{background:var(--surface);color:var(--ink)}.nav-link.active{background:var(--surface-2);color:var(--ink)}.nav-link.active:before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:99px;background:var(--primary);box-shadow:0 0 12px var(--primary)}.nav-link svg{flex:none;opacity:.85}.nav-link .badge{margin-left:auto;font-family:var(--font-mono);font-size:.7rem;color:var(--ink-faint)}.nav-link .dot{margin-left:auto;width:7px;height:7px;border-radius:99px;background:var(--success);box-shadow:0 0 8px var(--success)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:42px;padding:0 18px;border-radius:var(--r-sm);font-weight:600;font-size:.92rem;border:1px solid transparent;transition:transform .12s var(--ease),background .2s,border-color .2s,color .2s}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--primary);color:var(--primary-ink)}.btn-primary:hover{box-shadow:var(--glow)}.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line)}.btn-ghost:hover{border-color:var(--primary-dim)}.btn-sm{height:34px;padding:0 13px;font-size:.84rem}.btn-lg{height:50px;padding:0 24px;font-size:1rem}.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:20px}.card-pad-lg{padding:26px}.card-link{transition:transform .18s var(--ease),border-color .2s,box-shadow .2s}.card-link:hover{transform:translateY(-3px);border-color:var(--primary-dim);box-shadow:var(--shadow-md)}.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.04em;padding:3px 9px;border-radius:99px;border:1px solid var(--line);color:var(--ink-faint);background:var(--bg-2);white-space:nowrap}.chip.solid{background:#00e1d51f;background:oklch(.82 .15 188 / .12);color:var(--primary);border-color:#00e1d54d;border-color:oklch(.82 .15 188 / .3)}.chip.amber{background:#f8c14321;color:var(--accent);border-color:#f8c1434d}.chip.violet{background:#ba93fb21;color:var(--secondary);border-color:#ba93fb4d}.chip.rose{background:#f8767e21;color:var(--rose);border-color:#f8767e4d}.page-head{padding:40px 0 26px}.kicker{font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:12px}.page-head h1{font-size:clamp(2rem,5vw,3rem)}.page-head p.lede{color:var(--ink-soft);font-size:1.06rem;max-width:62ch;margin-top:14px}.eyebrow{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 860px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.stack{display:flex;flex-direction:column;gap:14px}.muted{color:var(--ink-faint)}@media (max-width: 560px){.no-mobile{display:none}}.soft{color:var(--ink-soft)}.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.center{text-align:center}.ledger{display:grid;gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:var(--r-md);overflow:hidden}.ledger .row-item{display:grid;grid-template-columns:1fr auto;gap:12px;padding:12px 16px;background:var(--surface);align-items:center}.ledger .row-item .l{color:var(--ink-soft);font-size:.9rem}.ledger .row-item .v{font-family:var(--font-mono);font-weight:600}.ledger .row-item .v.pos{color:var(--success)}.ledger .row-item .v.neg{color:var(--danger)}.ledger .row-item .v.warn{color:var(--warn)}.stat{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:18px}.stat .big{font-family:var(--font-mono);font-weight:600;font-size:1.8rem;letter-spacing:-.02em}.stat .lbl{color:var(--ink-faint);font-size:.82rem;margin-top:4px}.table-wrap{overflow-x:auto;border:1px solid var(--line-soft);border-radius:var(--r-md)}table.t{width:100%;border-collapse:collapse;font-size:.92rem;min-width:460px}table.t th,table.t td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line-soft);vertical-align:top}table.t th{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);background:var(--bg-2)}table.t tr:last-child td{border-bottom:none}table.t td.num{font-family:var(--font-mono)}.callout{border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:14px 16px;background:#00e1d50f;background:oklch(.82 .15 188 / .06)}.callout.amber{background:#f8c1430f}.callout.rose{background:#f8767e0f}.callout.violet{background:#ba93fb0f}.callout h5{font-family:var(--font-display);font-size:.95rem;margin-bottom:4px;display:flex;align-items:center;gap:8px}.callout h5:before{content:"";width:7px;height:7px;border-radius:99px;flex:none;background:var(--primary);box-shadow:0 0 8px var(--primary)}.callout.amber h5:before{background:var(--accent);box-shadow:0 0 8px var(--accent)}.callout.rose h5:before{background:var(--rose);box-shadow:0 0 8px var(--rose)}.callout.violet h5:before{background:var(--secondary);box-shadow:0 0 8px var(--secondary)}.formula{font-family:var(--font-mono);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:12px 14px;display:flex;flex-direction:column;gap:4px}.formula .eq{font-size:1rem;color:var(--ink)}.formula .nm{color:var(--primary);font-size:.78rem}.formula .nt{color:var(--ink-faint);font-size:.8rem;font-family:var(--font-body)}.pbar{height:8px;border-radius:99px;background:var(--surface-3);overflow:hidden}.pbar>span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--primary),var(--secondary));transform-origin:left}.spine-list{display:flex;flex-direction:column}.spine-item{display:grid;grid-template-columns:46px 1fr;gap:16px;padding:13px 0;border-bottom:1px solid var(--line-soft);align-items:baseline}.spine-item:last-child{border-bottom:none}.spine-item .bl{font-family:var(--font-display);font-weight:800;font-size:2.1rem;color:var(--primary);line-height:.9;text-align:center;letter-spacing:-.03em}.spine-item:nth-child(2n) .bl{color:var(--accent)}.spine-item .term{font-weight:600}.spine-item .det{color:var(--ink-soft);font-size:.9rem;margin-top:2px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px;overflow-x:auto}.tab{position:relative;padding:10px 14px;color:var(--ink-faint);font-weight:600;font-size:.92rem;white-space:nowrap;background:none;border:none}.tab:hover{color:var(--ink-soft)}.tab.active{color:var(--ink)}.tab .underline{position:absolute;left:10px;right:10px;bottom:-1px;height:2px;background:var(--primary);border-radius:2px}.flip{perspective:1400px}.flip-inner{position:relative;transform-style:preserve-3d;transition:transform .5s var(--ease)}.flip.flipped .flip-inner{transform:rotateY(180deg)}.flip-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;display:grid;place-content:center;text-align:center;padding:30px;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--surface)}.flip-face.back{transform:rotateY(180deg);background:var(--surface-2)}.opt{display:flex;gap:12px;align-items:flex-start;width:100%;text-align:left;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink);transition:border-color .16s,background .16s}.opt:hover:not(:disabled){border-color:var(--primary-dim)}.opt .mk{flex:none;width:24px;height:24px;border-radius:7px;border:1px solid var(--line);display:grid;place-items:center;font-family:var(--font-mono);font-size:.78rem;color:var(--ink-faint)}.opt.correct{border-color:var(--success);background:#43d58f1a}.opt.correct .mk{border-color:var(--success);color:var(--success)}.opt.wrong{border-color:var(--danger);background:#fa686a1a}.opt.wrong .mk{border-color:var(--danger);color:var(--danger)}.opt.chosen{border-color:var(--primary)}.opt:disabled{cursor:default}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0104088c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:var(--z-scrim)}.palette{position:fixed;z-index:var(--z-palette);top:12vh;left:50%;transform:translate(-50%);width:min(620px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}.palette input{width:100%;border:none;background:none;color:var(--ink);font-size:1.05rem;padding:18px 20px;font-family:var(--font-body);border-bottom:1px solid var(--line-soft)}.palette input:focus{outline:none}.palette .results{max-height:52vh;overflow-y:auto;padding:8px}.palette .res{display:flex;gap:12px;align-items:center;padding:11px 12px;border-radius:var(--r-sm)}.palette .res.sel{background:var(--surface-2)}.palette .res .k{font-family:var(--font-mono);font-size:.66rem;color:var(--ink-faint);border:1px solid var(--line);padding:2px 7px;border-radius:5px;text-transform:uppercase}.palette .res .t{font-weight:600}.palette .res .s{color:var(--ink-faint);font-size:.85rem}.drawer{position:fixed;z-index:var(--z-drawer);top:0;left:0;bottom:0;width:280px;background:var(--bg-2);border-right:1px solid var(--line);overflow-y:auto;padding:18px 14px 40px}.tl{display:grid;gap:0;position:relative;padding-left:26px}.tl:before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}.tl-item{position:relative;padding:0 0 18px}.tl-item:before{content:"";position:absolute;left:-26px;top:5px;width:14px;height:14px;border-radius:99px;background:var(--surface);border:2px solid var(--primary)}.tl-item .when{font-family:var(--font-mono);font-size:.74rem;color:var(--primary)}.divider{height:1px;background:var(--line-soft);margin:26px 0;border:none}.pill-tabs{display:inline-flex;padding:4px;gap:4px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:99px}.pill-tabs button{border:none;background:none;color:var(--ink-faint);font-weight:600;font-size:.85rem;padding:6px 14px;border-radius:99px}.pill-tabs button.on{background:var(--surface-2);color:var(--ink)}ul.clean{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}ul.clean li{display:flex;gap:10px;align-items:flex-start}ul.clean li:before{content:"";flex:none;width:6px;height:6px;border-radius:99px;background:var(--primary);margin-top:9px}ul.dash{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px;color:var(--ink-soft)}ul.dash li{padding-left:16px;position:relative}ul.dash li:before{content:"–";position:absolute;left:0;color:var(--ink-faint)}.toast{position:fixed;z-index:var(--z-toast);bottom:24px;left:50%;transform:translate(-50%);background:var(--surface-2);border:1px solid var(--line);border-radius:99px;padding:10px 18px;font-size:.9rem;box-shadow:var(--shadow-md)}@media print{.topbar,.sidebar,.no-print{display:none!important}body{background:#fff;color:#000}.main{padding:0}.card,.table-wrap{break-inside:avoid;border-color:#ccc}a{color:#000}}@media (max-width: 720px){.home-hero{grid-template-columns:1fr!important}.home-ring{justify-self:start}}input[type=range]{height:6px}.mobile-bar{display:none}@media (max-width: 980px){.mobile-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:var(--z-nav);background:#081019eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:6px 8px calc(6px + env(safe-area-inset-bottom));justify-content:space-around}[data-theme=light] .mobile-bar{background:#ffffffeb}.mobile-bar a{display:grid;place-items:center;gap:2px;color:var(--ink-faint);font-size:.64rem;padding:6px 10px;border-radius:var(--r-sm)}.mobile-bar a.active{color:var(--primary)}.main{padding-bottom:96px}}
