:root{
  --bg:#0b0c0f; --bg-2:#101217; --bg-3:#15181f; --raise:#181b23;
  --line:#23262f; --line-2:#2d313c;
  --ink:#e9eaee; --dim:#a1a7b2; --faint:#6b7280; --ghost:#454a55;
  --graph:#5fd3c4; --log:#e7b15a; --behavior:#8ed99b; --llm:#9db0ff; --danger:#ff8585;
  --graph-dim:rgba(95,211,196,.14); --log-dim:rgba(231,177,90,.14);
  --behavior-dim:rgba(142,217,155,.14); --llm-dim:rgba(157,176,255,.14); --danger-dim:rgba(255,133,133,.13);
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --disp:"Bricolage Grotesque",sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --sidebar:312px; --topbar:58px; --maxw:860px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--ink); font-family:var(--body);
  font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 18% -10%,rgba(95,211,196,.06),transparent 45%),
                   radial-gradient(circle at 88% 4%,rgba(231,177,90,.05),transparent 42%),
                   radial-gradient(rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:auto,auto,22px 22px;
  background-attachment:fixed;
}
a{color:inherit;text-decoration:none}
::selection{background:var(--graph-dim);color:#fff}
.mono{font-family:var(--mono)}

/* ---------- topbar ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar);z-index:60;
  display:flex;align-items:center;gap:18px;padding:0 20px;
  background:rgba(11,12,15,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:600;font-size:15px;letter-spacing:-.01em}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--graph);box-shadow:0 0 0 4px var(--graph-dim)}
.brand .slash{color:var(--ghost);font-weight:400}
.brand .sub{color:var(--dim);font-weight:400}
.top-links{margin-left:auto;display:flex;align-items:center;gap:4px}
.top-links a,.gloss-btn,.menu-btn{
  font-family:var(--mono);font-size:12.5px;color:var(--dim);padding:7px 11px;border-radius:7px;
  border:1px solid transparent;background:none;cursor:pointer;transition:.16s;line-height:1;
}
.top-links a:hover,.gloss-btn:hover{color:var(--ink);background:var(--bg-3);border-color:var(--line)}
.gloss-btn{display:inline-flex;align-items:center;gap:6px}
.gloss-btn .k{border:1px solid var(--line-2);border-radius:4px;padding:1px 5px;font-size:10.5px;color:var(--faint)}
.menu-btn{display:none}

/* ---------- shell ---------- */
.shell{display:flex;min-height:100vh;padding-top:var(--topbar)}
.sidebar{
  width:var(--sidebar);flex:0 0 var(--sidebar);position:sticky;top:var(--topbar);align-self:flex-start;
  height:calc(100vh - var(--topbar));overflow-y:auto;border-right:1px solid var(--line);
  padding:20px 14px 60px;background:rgba(13,14,18,.4);
}
.sidebar.hidden{display:none}
.main{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;padding:0 28px 120px}
.wrap{width:100%;max-width:var(--maxw)}

/* ---------- sidebar tutorial nav ---------- */
.sb-back{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;color:var(--faint);
  padding:6px 8px;border-radius:6px;margin-bottom:14px;transition:.15s}
.sb-back:hover{color:var(--ink);background:var(--bg-3)}
.sb-title{font-family:var(--disp);font-weight:700;font-size:16px;line-height:1.25;padding:0 8px;margin-bottom:4px}
.sb-meta{font-family:var(--mono);font-size:11px;color:var(--faint);padding:0 8px 14px;display:flex;gap:10px;flex-wrap:wrap}
.progress{margin:0 8px 16px}
.progress .bar{height:4px;background:var(--bg-3);border-radius:99px;overflow:hidden}
.progress .fill{height:100%;width:0;background:linear-gradient(90deg,var(--log),var(--graph));border-radius:99px;transition:width .4s}
.progress .lab{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:6px;letter-spacing:.04em}
.part{margin-bottom:6px}
.part-h{font-family:var(--mono);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);
  padding:12px 10px 6px;display:flex;align-items:center;gap:8px}
.part-h .ix{color:var(--ghost)}
.part-h.adv{color:var(--log)}
.lnk{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:7px;color:var(--dim);font-size:13.5px;
  cursor:pointer;transition:.13s;border:1px solid transparent;line-height:1.3}
.lnk:hover{color:var(--ink);background:var(--bg-3)}
.lnk.active{color:var(--ink);background:var(--graph-dim);border-color:rgba(95,211,196,.22)}
.lnk .tick{width:15px;height:15px;flex:0 0 15px;border-radius:50%;border:1.5px solid var(--ghost);
  display:grid;place-items:center;font-size:9px;color:transparent;transition:.15s}
.lnk.seen .tick{border-color:var(--graph);color:var(--graph)}
.lnk.active .tick{border-color:var(--graph)}

/* ---------- content typography ---------- */
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);
  margin:0 0 14px;display:flex;align-items:center;gap:8px}
.eyebrow .sl{color:var(--graph)}
h1.lh{font-family:var(--disp);font-weight:700;font-size:clamp(30px,4.4vw,46px);line-height:1.04;letter-spacing:-.02em;margin:0 0 18px}
h2.lh{font-family:var(--disp);font-weight:700;font-size:26px;line-height:1.12;letter-spacing:-.01em;margin:46px 0 14px}
h3.lh{font-family:var(--disp);font-weight:600;font-size:18.5px;margin:30px 0 10px;letter-spacing:-.01em}
.lead{font-size:19px;line-height:1.62;color:#cfd2da;margin:0 0 20px}
p{margin:0 0 16px;color:#c8ccd5}
.main strong{color:var(--ink);font-weight:600}
em.term{font-style:normal;border-bottom:1px dotted var(--ghost);cursor:help;color:var(--ink)}
.reveal{opacity:0;transform:translateY(10px);animation:rv .5s cubic-bezier(.2,.7,.3,1) forwards}
@keyframes rv{to{opacity:1;transform:none}}

/* ---------- callouts ---------- */
.note{border:1px solid var(--line);background:var(--bg-2);border-radius:11px;padding:15px 17px;margin:20px 0;
  display:flex;gap:13px;font-size:14.5px;line-height:1.55}
.note .ic{flex:0 0 auto;font-family:var(--mono);font-size:11px;padding:3px 7px;border-radius:6px;height:fit-content;
  letter-spacing:.06em;text-transform:uppercase}
.note.key{border-color:rgba(95,211,196,.3);background:var(--graph-dim)} .note.key .ic{background:var(--graph);color:#04201c}
.note.warn{border-color:rgba(231,177,90,.3);background:var(--log-dim)} .note.warn .ic{background:var(--log);color:#2a1c02}
.note.stop{border-color:rgba(255,133,133,.3);background:var(--danger-dim)} .note.stop .ic{background:var(--danger);color:#2a0606}
.pull{font-family:var(--disp);font-weight:600;font-size:23px;line-height:1.25;letter-spacing:-.01em;color:#fff;
  border-left:3px solid var(--graph);padding:6px 0 6px 20px;margin:30px 0}

/* ---------- code blocks ---------- */
.code{margin:20px 0;border:1px solid var(--line);border-radius:11px;overflow:hidden;background:#0a0b0e}
.code-top{display:flex;align-items:center;gap:9px;padding:9px 13px;border-bottom:1px solid var(--line);background:var(--bg-2)}
.code-top .fn{font-family:var(--mono);font-size:12px;color:var(--dim)}
.code-top .dots{display:flex;gap:5px;margin-right:4px}
.code-top .dots i{width:9px;height:9px;border-radius:50%;background:var(--line-2)}
.badge{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:99px;border:1px solid var(--line-2);color:var(--faint)}
.badge.run{color:var(--behavior);border-color:rgba(142,217,155,.4);background:var(--behavior-dim)}
.badge.con{color:var(--llm);border-color:rgba(157,176,255,.35);background:var(--llm-dim)}
pre{margin:0;padding:15px 16px;overflow-x:auto;font-family:var(--mono);font-size:13px;line-height:1.66}
pre .ln{display:block;padding:0 6px;margin:0 -6px;border-radius:3px}
pre .ln.mk{background:var(--log-dim);box-shadow:inset 2px 0 0 var(--log)}
.t-kw{color:#c98bdb} .t-def{color:var(--graph)} .t-str{color:var(--log)} .t-num{color:#e7977a}
.t-com{color:var(--faint);font-style:italic} .t-dec{color:var(--behavior)} .t-fn{color:#9db0ff} .t-self{color:#7a8089}

/* ---------- tabs ---------- */
.tabs{margin:22px 0}
.tab-row{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:0;flex-wrap:wrap}
.tab-btn{font-family:var(--mono);font-size:12.5px;color:var(--dim);padding:9px 14px;border:none;background:none;cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;transition:.14s}
.tab-btn:hover{color:var(--ink)}
.tab-btn.on{color:var(--ink);border-bottom-color:var(--graph)}
.tab-pane{display:none;animation:rv .3s ease forwards}.tab-pane.on{display:block}

/* ---------- mapping table ---------- */
.maptable{border:1px solid var(--line);border-radius:11px;overflow:hidden;margin:22px 0}
.maprow{display:grid;grid-template-columns:1fr 30px 1fr;align-items:center;border-bottom:1px solid var(--line)}
.maprow:last-child{border-bottom:none}
.maprow>div{padding:13px 15px;font-size:14px}
.maprow .from{color:var(--dim);font-family:var(--mono);font-size:12.5px}
.maprow .arr{text-align:center;color:var(--graph);font-family:var(--mono)}
.maprow .to{color:var(--ink);font-family:var(--mono);font-size:12.5px;background:var(--graph-dim)}
.maprow .hd{font-family:var(--disp);font-weight:600;color:var(--ink);background:var(--bg-2)}
.maprow.head .to{background:var(--bg-2);color:var(--graph)}

/* ---------- generic sim panel ---------- */
.sim{border:1px solid var(--line-2);border-radius:13px;overflow:hidden;margin:24px 0;background:var(--bg-2)}
.sim-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--line);background:var(--bg-3)}
.sim-bar .ttl{font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:.03em}
.sim-bar .sp{margin-left:auto}
.btn{font-family:var(--mono);font-size:12px;color:var(--ink);background:var(--raise);border:1px solid var(--line-2);
  padding:6px 12px;border-radius:7px;cursor:pointer;transition:.14s}
.btn:hover{border-color:var(--graph);color:var(--graph)}
.btn.pri{background:var(--graph);color:#04201c;border-color:var(--graph);font-weight:600}
.btn.pri:hover{filter:brightness(1.08);color:#04201c}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn.gho{color:var(--dim)}
.sim-body{display:grid;grid-template-columns:1fr 1fr;gap:0}
.sim-col{padding:14px;min-height:230px}
.sim-col+.sim-col{border-left:1px solid var(--line)}
.col-h{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;margin:0 0 11px;
  display:flex;align-items:center;gap:7px}
.col-h .d{width:7px;height:7px;border-radius:50%}
.step-cap{font-family:var(--mono);font-size:11.5px;color:var(--dim);padding:10px 14px;border-top:1px solid var(--line);
  background:var(--bg-3);min-height:38px;display:flex;align-items:center}
.step-cap b{color:var(--graph);font-weight:500}

/* event log items */
.evt{font-family:var(--mono);font-size:11.5px;border:1px solid var(--line);border-radius:7px;padding:7px 9px;margin-bottom:6px;
  opacity:0;transform:translateX(-6px);animation:slin .3s ease forwards;background:#0a0b0e}
@keyframes slin{to{opacity:1;transform:none}}
.evt .ty{color:var(--log);font-weight:600}
.evt .pl{color:var(--dim);display:block;margin-top:2px;font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.evt.beh{border-color:rgba(142,217,155,.3)} .evt.beh .ty{color:var(--behavior)}
.evt.llm .ty{color:var(--llm)} .evt.goal .ty{color:var(--graph)}

/* messages (naive) */
.msg{font-family:var(--mono);font-size:11.5px;border-radius:7px;padding:7px 9px;margin-bottom:6px;
  opacity:0;animation:rv .3s ease forwards;border:1px solid var(--line)}
.msg .r{color:var(--faint);font-size:10px;text-transform:uppercase;letter-spacing:.08em}
.msg.trunc{opacity:.35;font-style:italic}
.msg .warn{color:var(--danger)}

/* graph svg */
.gwrap{width:100%;height:100%;min-height:200px;display:grid;place-items:center}
svg.graph{width:100%;height:auto;max-height:260px}
.gnode circle{transition:.3s} .gnode text{font-family:var(--mono);font-size:9px;fill:var(--ink)}
.gedge{stroke:var(--line-2);stroke-width:1.5;transition:.3s} .gedge.on{stroke:var(--graph)}
.gedge-lab{font-family:var(--mono);font-size:7.5px;fill:var(--faint)}

/* raw json toggle */
.rawbox{border-top:1px solid var(--line);background:#08090b}
.rawbox pre{font-size:11px;max-height:200px;overflow:auto;color:var(--dim)}
.rawtoggle{font-family:var(--mono);font-size:11px;color:var(--faint);cursor:pointer;padding:8px 14px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:6px;user-select:none}
.rawtoggle:hover{color:var(--ink)}

/* anatomy */
.anat{font-family:var(--mono);font-size:13.5px;line-height:2;background:#0a0b0e;border:1px solid var(--line);border-radius:11px;padding:18px;margin:22px 0}
.arg{cursor:pointer;border-radius:5px;padding:1px 3px;transition:.13s;border-bottom:1.5px dotted transparent}
.arg:hover{background:var(--bg-3)} .arg.on{background:var(--graph-dim);border-bottom-color:var(--graph)}
.anat-exp{margin-top:14px;border-top:1px solid var(--line);padding-top:14px;font-family:var(--body);font-size:14px;color:var(--dim);min-height:46px}
.anat-exp b{color:var(--graph);font-family:var(--mono);font-size:13px}

/* fork viz */
.forkviz{padding:18px;background:#0a0b0e}
.timeline{display:flex;align-items:center;gap:0;margin:6px 0 18px;flex-wrap:wrap}
.tev{display:flex;flex-direction:column;align-items:center;gap:5px;position:relative}
.tev .c{width:15px;height:15px;border-radius:50%;background:var(--bg-3);border:2px solid var(--line-2);transition:.3s;z-index:2}
.tev.done .c{background:var(--log);border-color:var(--log)} .tev.fk .c{background:var(--graph);border-color:var(--graph);transform:scale(1.3)}
.tev .lab{font-family:var(--mono);font-size:8.5px;color:var(--faint)}
.tconn{width:26px;height:2px;background:var(--line-2);transition:.3s}.tconn.done{background:var(--log)}.tconn.fork{background:var(--graph)}
.diffgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.diffcell{border:1px solid var(--line);border-radius:9px;padding:11px 13px;font-family:var(--mono);font-size:11.5px}
.diffcell h5{margin:0 0 8px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.dl{padding:3px 0;color:var(--dim)} .dl .a{color:var(--graph)} .dl .b{color:var(--log)} .dl.same{opacity:.4}

/* arch diagram */
.arch{border:1px solid var(--line-2);border-radius:13px;background:#0a0b0e;padding:24px 18px;margin:24px 0;overflow-x:auto}
.archflow{display:flex;align-items:stretch;gap:0;min-width:600px}
.archbox{flex:1;border:1px solid var(--line);border-radius:9px;padding:13px 11px;text-align:center;background:var(--bg-2);
  display:flex;flex-direction:column;gap:5px;justify-content:center;min-width:96px}
.archbox .n{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.06em}
.archbox .t{font-family:var(--disp);font-weight:600;font-size:13px;line-height:1.2}
.archbox.log{border-color:rgba(231,177,90,.4)} .archbox.log .t{color:var(--log)}
.archbox.graph{border-color:rgba(95,211,196,.4)} .archbox.graph .t{color:var(--graph)}
.archbox.beh{border-color:rgba(142,217,155,.4)} .archbox.beh .t{color:var(--behavior)}
.archarrow{display:flex;align-items:center;color:var(--ghost);font-family:var(--mono);padding:0 7px;font-size:15px}
.archloop{text-align:center;font-family:var(--mono);font-size:11px;color:var(--graph);margin-top:16px;
  border-top:1px dashed var(--line-2);padding-top:12px}

/* ---------- pager ---------- */
.pager{display:flex;gap:12px;margin-top:54px;border-top:1px solid var(--line);padding-top:26px}
.pg{flex:1;border:1px solid var(--line);border-radius:11px;padding:15px 17px;cursor:pointer;transition:.16s;background:var(--bg-2)}
.pg:hover{border-color:var(--graph);background:var(--bg-3)}
.pg.next{text-align:right} .pg .dir{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.05em}
.pg .t{font-family:var(--disp);font-weight:600;font-size:15px;margin-top:4px}
.pg.empty{visibility:hidden}
.nexttut{border:1px solid rgba(95,211,196,.3);background:var(--graph-dim);border-radius:13px;padding:20px 22px;margin-top:40px}
.nexttut .e{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--graph);margin-bottom:8px}
.nexttut .t{font-family:var(--disp);font-weight:700;font-size:20px;margin-bottom:6px}
.nexttut .go{display:inline-block;margin-top:12px;font-family:var(--mono);font-size:13px;color:var(--graph)}

/* ---------- HOME ---------- */
.home{width:100%;max-width:1040px;margin:0 auto;padding:46px 28px 120px}
.home-hero{padding:30px 0 18px;border-bottom:1px solid var(--line);margin-bottom:38px}
.home-hero .eyebrow{margin-bottom:18px}
.home-hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(34px,5.4vw,58px);line-height:1;letter-spacing:-.03em;margin:0 0 18px}
.home-hero h1 .hl{color:var(--graph)}
.home-hero .lead{max-width:680px;font-size:19px}
.home-hero .quotes{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.qchip{font-family:var(--mono);font-size:12px;color:var(--dim);border:1px solid var(--line);border-radius:99px;padding:6px 13px;background:var(--bg-2)}
.qchip b{color:var(--graph);font-weight:500}
.track-h{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin:0 0 18px;display:flex;align-items:center;gap:8px}
.track-h .sl{color:var(--graph)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.card{border:1px solid var(--line);border-radius:14px;padding:20px;background:var(--bg-2);transition:.18s;cursor:pointer;
  display:flex;flex-direction:column;position:relative;overflow:hidden}
.card:hover{border-color:var(--graph);transform:translateY(-2px)}
.card.soon{cursor:default;opacity:.72} .card.soon:hover{border-color:var(--line);transform:none}
.card .num{font-family:var(--mono);font-size:11px;color:var(--ghost);margin-bottom:12px}
.card h3{font-family:var(--disp);font-weight:700;font-size:20px;line-height:1.12;margin:0 0 9px;letter-spacing:-.01em}
.card p{font-size:14px;color:var(--dim);line-height:1.5;margin:0 0 16px;flex:1}
.card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.card .tg{font-family:var(--mono);font-size:10.5px;color:var(--faint);border:1px solid var(--line);border-radius:99px;padding:3px 9px}
.card .foot{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;color:var(--faint);border-top:1px solid var(--line);padding-top:13px}
.card .foot .diff{color:var(--graph)}
.card .start{margin-left:auto;color:var(--graph)}
.card .ribbon{position:absolute;top:13px;right:-30px;transform:rotate(45deg);background:var(--log);color:#2a1c02;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;padding:3px 34px;font-weight:600}
.home-foot{margin-top:54px;border-top:1px solid var(--line);padding-top:24px;display:flex;gap:18px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12.5px;color:var(--faint)}
.home-foot a:hover{color:var(--graph)}

/* ---------- glossary ---------- */
.gloss-scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:70;opacity:0;pointer-events:none;transition:.2s}
.gloss-scrim.on{opacity:1;pointer-events:auto}
.gloss{position:fixed;top:0;right:0;height:100vh;width:380px;max-width:90vw;background:var(--bg-2);border-left:1px solid var(--line-2);
  z-index:71;transform:translateX(100%);transition:transform .26s cubic-bezier(.3,.7,.3,1);overflow-y:auto;padding:22px 22px 60px}
.gloss.on{transform:none}
.gloss-h{display:flex;align-items:center;margin-bottom:6px}
.gloss-h h3{font-family:var(--disp);font-weight:700;font-size:20px;margin:0}
.gloss-h .x{margin-left:auto;cursor:pointer;color:var(--faint);font-size:20px;padding:4px 8px;border-radius:6px}
.gloss-h .x:hover{color:var(--ink);background:var(--bg-3)}
.gloss .hint{font-family:var(--mono);font-size:11px;color:var(--faint);margin-bottom:18px}
.gterm{border-bottom:1px solid var(--line);padding:13px 0}
.gterm dt{font-family:var(--mono);font-size:13.5px;font-weight:600;color:var(--graph);margin-bottom:4px}
.gterm dd{margin:0;font-size:13.5px;color:var(--dim);line-height:1.5}

/* ---------- responsive ---------- */
@media(max-width:980px){
  :root{--sidebar:0px}
  .menu-btn{display:inline-flex}
  .sidebar{position:fixed;top:var(--topbar);left:0;width:300px;z-index:55;background:var(--bg-2);transform:translateX(-100%);transition:.24s;border-right:1px solid var(--line-2)}
  .sidebar.open{transform:none} .sidebar.hidden{display:block;transform:translateX(-100%)}
  .main{padding:0 18px 100px}
  .sim-body{grid-template-columns:1fr}.sim-col+.sim-col{border-left:none;border-top:1px solid var(--line)}
  .top-links a.hideable{display:none}
}
@media(max-width:560px){
  .diffgrid{grid-template-columns:1fr}.maprow{grid-template-columns:1fr 24px 1fr}
  .gloss-btn .k{display:none}
}
