:root{
  --bg:#0f1419; --panel:#11161d; --ink:#1a1f29; --paper:#f7f5ef; --paper2:#efece2;
  --txt:#222831; --muted:#5d6b7a; --line:#d8d3c4;
  --accent:#2f81f7; --accent2:#e8590c; --good:#1e9e6a; --warn:#c9344a; --gold:#caa64b;
  --c0:#3b6ea5; --c1:#2f9e7d; --c2:#caa64b; --core:#e8590c;
  --mono:"SF Mono",ui-monospace,Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--txt);background:var(--paper);line-height:1.6;font-size:16px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:var(--mono);background:var(--paper2);padding:1px 5px;border-radius:4px;font-size:.9em}
.wrap{display:grid;grid-template-columns:230px 1fr;max-width:1280px;margin:0 auto}

/* ---- nav ---- */
nav{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;padding:28px 18px;border-right:1px solid var(--line);background:var(--paper)}
nav .brand{font-weight:700;font-size:15px;letter-spacing:.2px;margin-bottom:4px}
nav .sub{font-size:12px;color:var(--muted);margin-bottom:20px}
nav ol{list-style:none;padding:0;margin:0;counter-reset:s}
nav ol li{counter-increment:s;margin:2px 0}
nav ol li a{display:block;padding:6px 10px;border-radius:6px;color:var(--muted);font-size:13px;border-left:2px solid transparent}
nav ol li a::before{content:counter(s);display:inline-block;width:20px;color:var(--gold);font-family:var(--mono);font-weight:600}
nav ol li a:hover{background:var(--paper2);text-decoration:none;color:var(--txt)}
nav ol li a.active{color:var(--txt);border-left-color:var(--accent);background:var(--paper2);font-weight:600}

/* ---- content ---- */
main{padding:48px 56px 120px;max-width:860px}
header.hero{margin-bottom:48px}
header.hero h1{font-size:34px;line-height:1.15;margin:0 0 12px}
header.hero .lede{font-size:18px;color:var(--muted);max-width:680px}
.tag{display:inline-block;font-size:12px;font-family:var(--mono);color:var(--accent2);background:#fbeee4;border:1px solid #f3d6c0;border-radius:20px;padding:3px 11px;margin-bottom:16px}

section{margin:0 0 72px;scroll-margin-top:20px}
section h2{font-size:25px;margin:0 0 6px;display:flex;align-items:baseline;gap:12px}
section h2 .num{font-family:var(--mono);font-size:15px;color:var(--gold);font-weight:700}
section h3{font-size:17px;margin:26px 0 8px;color:var(--ink)}
section p{margin:12px 0}
.muted{color:var(--muted)}

/* ---- viz panel ---- */
.viz{background:var(--panel);border-radius:12px;padding:18px;margin:22px 0;box-shadow:0 1px 0 rgba(0,0,0,.04),0 8px 28px -18px rgba(0,0,0,.5)}
.viz canvas{display:block;width:100%;height:auto;border-radius:6px;touch-action:none}
.viz .stage{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-start}
.viz .stage .col{flex:1 1 0;min-width:0}
.viz .caption{color:#9fb0c0;font-size:13px;margin-top:10px;min-height:18px}
.viz .label{color:#7e8ea0;font-size:11px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}

.controls{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin:4px 0 14px;color:#c8d2dc;font-size:13px}
.controls label{display:flex;gap:8px;align-items:center;font-family:var(--mono);font-size:12px;color:#9fb0c0}
.controls input[type=range]{width:160px;accent-color:var(--accent)}
.controls .val{font-family:var(--mono);color:#fff;background:#1d2630;border-radius:4px;padding:1px 7px;min-width:30px;text-align:center;display:inline-block}
.btn{font-family:var(--sans);font-size:13px;color:#dfe7ee;background:#1d2630;border:1px solid #2b3744;border-radius:6px;padding:6px 13px;cursor:pointer;transition:.15s}
.btn:hover{background:#26323e;border-color:var(--accent)}
.btn.on{background:var(--accent);border-color:var(--accent);color:#fff}
.chip{font-family:var(--mono);font-size:12px;padding:3px 9px;border-radius:5px;color:#0f1419;font-weight:600}

.tooltip{position:fixed;pointer-events:none;background:#0b0f14;color:#e7eef5;border:1px solid #2b3744;border-radius:6px;padding:6px 9px;font-family:var(--mono);font-size:12px;z-index:50;opacity:0;transition:opacity .08s;white-space:pre;box-shadow:0 8px 24px -8px #000}

/* ---- callouts ---- */
.note{border-left:3px solid var(--accent);background:linear-gradient(90deg,#eef4fe,transparent 80%);padding:14px 18px;border-radius:0 8px 8px 0;margin:20px 0;font-size:15px}
.note.find{border-color:var(--good);background:linear-gradient(90deg,#e9f7f0,transparent 80%)}
.note.hard{border-color:var(--warn);background:linear-gradient(90deg,#fbecef,transparent 80%)}
.note.proof{border-color:var(--gold);background:linear-gradient(90deg,#faf3e0,transparent 80%)}
.note b{font-weight:700}
.note .h{display:block;font-size:11px;font-family:var(--mono);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;opacity:.8}
.note.find .h{color:var(--good)} .note.hard .h{color:var(--warn)} .note.proof .h{color:#a07d1e} .note .h{color:var(--accent)}
.note.hyp{border-left-width:5px;border-color:var(--accent2);background:linear-gradient(90deg,#fdeee2,#faf3e0 55%,transparent);font-size:16.5px}
.note.hyp .h{color:var(--accent2)} .note.hyp b{color:#9a3d05}

table.seq{border-collapse:collapse;font-family:var(--mono);font-size:12.5px;margin:8px 0}
table.seq td,table.seq th{padding:3px 9px;text-align:right;border-bottom:1px solid var(--line)}
table.seq th{color:var(--muted);font-weight:600;text-align:left}
table.seq .zero{color:#bcc}
table.seq .lead{color:var(--accent2);font-weight:700}

.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:#9fb0c0;margin-top:10px;align-items:center}
.legend .sw{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:5px;vertical-align:-1px}

.kpi{display:flex;gap:20px;flex-wrap:wrap;margin:16px 0}
.kpi .k{background:var(--paper2);border:1px solid var(--line);border-radius:10px;padding:12px 18px;min-width:120px}
.kpi .k .n{font-size:24px;font-weight:700;font-family:var(--mono)}
.kpi .k .l{font-size:12px;color:var(--muted)}

.refs{font-size:14px}
.refs li{margin:7px 0}
.pipeline{display:flex;flex-direction:column;gap:0;margin:18px 0}
.pipeline .step{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px dashed var(--line)}
.pipeline .step .ix{font-family:var(--mono);font-weight:700;color:#fff;background:var(--ink);border-radius:50%;width:26px;height:26px;display:grid;place-items:center;flex:none;font-size:13px}
.pipeline .step.free .ix{background:var(--good)} .pipeline .step.hard .ix{background:var(--core)}
.pipeline .step .t b{font-size:15px}
.pipeline .step .t .d{font-size:13px;color:var(--muted)}
footer{color:var(--muted);font-size:13px;border-top:1px solid var(--line);padding-top:22px}
@media(max-width:900px){.wrap{grid-template-columns:1fr}nav{display:none}main{padding:28px 20px 80px}}
