
:root{ /* === Graphite & Vermilion — light (default) === */
--bg:#fbfbf9;--fg:#16181d;--muted:#737880;--accent:#d7401f;--accent-strong:#b5331a;--accent2:#d7401f;
--accent-soft:rgba(215,64,31,.10);--accent-soft-2:rgba(215,64,31,.16);--hover:rgba(115,120,128,.08);
--line:#e4e3de;--navline:#e4e3de;--code:#f4f3ef;--side:#faf9f6;--card:#fff;--surface:#fff;--surface-2:#f4f3ef;
--easy:#1f8a52;--easy-soft:rgba(31,138,82,.12);--med:#c9831a;--med-soft:rgba(201,131,26,.13);
--hard:#d7401f;--hard-soft:rgba(215,64,31,.12);--ok:#1f8a52;
--display:"Spline Sans",system-ui,-apple-system,sans-serif;
--sans:"Spline Sans",system-ui,-apple-system,sans-serif;
--mono:"Spline Sans Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
--radius:12px;--bar:56px;--rail:296px;--maxw:760px}
[data-theme=dark]{ /* === Signal Room — dark IDE control-room, signal-amber === */
--bg:#0e1116;--fg:#e6eaf0;--muted:#7c8696;--accent:#f2a33c;--accent-strong:#f6b65b;--accent2:#f2a33c;
--accent-soft:rgba(242,163,60,.16);--accent-soft-2:rgba(242,163,60,.24);--hover:rgba(124,134,150,.10);
--line:#222a35;--navline:#222a35;--code:#12161c;--side:#10141b;--card:#151a21;--surface:#151a21;--surface-2:#1a212b;
--easy:#3fb68b;--easy-soft:rgba(63,182,139,.16);--med:#e6b450;--med-soft:rgba(230,180,80,.16);
--hard:#e5484d;--hard-soft:rgba(229,72,77,.16);--ok:#3fb68b;
--display:"Archivo",system-ui,sans-serif;--sans:"Public Sans",system-ui,sans-serif;
--mono:"JetBrains Mono",ui-monospace,Menlo,monospace}
*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--fg);font:16px/1.65 var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,.brand{font-family:var(--display)}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
button{font-family:inherit}
#appbar{position:sticky;top:0;z-index:30;height:var(--bar);display:flex;align-items:center;gap:10px;padding:0 12px;
background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
#appbar .brand{font-weight:800;font-size:16px;letter-spacing:-.02em;white-space:nowrap;color:var(--fg)}.brand span{color:var(--accent)}
#menu{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--line);border-radius:11px;background:var(--card);color:var(--fg);cursor:pointer;font-size:19px;flex:none}
#searchwrap{position:relative;flex:1;max-width:440px}
#searchbox{width:100%;font:15px inherit;padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:var(--card);color:var(--fg)}
#searchbox:focus{outline:2px solid var(--accent)}
#results{position:absolute;left:0;right:0;top:48px;max-height:70vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:12px;display:none;box-shadow:0 14px 44px rgba(0,0,0,.24);z-index:40}
#results a{display:block;padding:11px 14px;border-bottom:1px solid var(--line);color:var(--fg)}#results a small{color:var(--muted)}
#theme{width:42px;height:42px;border:1px solid var(--line);border-radius:11px;background:var(--card);color:var(--fg);cursor:pointer;font-size:16px;flex:none}
#side{position:fixed;top:var(--bar);bottom:0;left:0;width:var(--rail);overflow:auto;background:var(--side);border-right:1px solid var(--line);
padding:8px 10px 90px;transform:translateX(-100%);transition:transform .25s ease;z-index:26}
#scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:opacity .25s;z-index:25}
body.drawer #side{transform:translateX(0)}body.drawer #scrim{opacity:1;visibility:visible}
/* ---- 3-level tree nav: Subject (eyebrow) > Topic (collapsible) > Lesson (leaf w/ rail) ---- */
#side{font-family:var(--sans)}
.nav-subject{margin:1px 0}
.nav-subject-h{display:flex;align-items:center;gap:7px;width:100%;text-align:left;cursor:pointer;
font:700 11px/1.3 var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);background:none;border:0;padding:17px 10px 7px}
.nav-subject-h:hover{color:var(--fg)}
.nav-subject-h .chev{font-size:8px;transition:transform .15s}
.nav-subject.open>.nav-subject-h .chev{transform:rotate(90deg)}
.nav-topics{display:none}.nav-subject.open>.nav-topics{display:block}
.nav-topic{margin:1px 0}
.nav-topic-h{display:flex;align-items:center;gap:6px;padding:6px 10px 6px 8px;border-radius:8px;min-height:38px}
.nav-topic-h:hover{background:var(--hover)}
.nav-twist{display:inline-flex;align-items:center;justify-content:center;width:22px;height:30px;flex:none;background:none;border:0;color:var(--muted);cursor:pointer;padding:0}
.nav-twist .chev{font-size:8px;transition:transform .15s}
.nav-topic.open>.nav-topic-h .nav-twist .chev{transform:rotate(90deg)}
.nav-twist-spacer{width:22px;flex:none}
.nav-topic-h .tname{flex:1;color:var(--fg);font:500 13.5px/1.35 var(--sans);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-topic-h .tname:hover{text-decoration:none;color:var(--accent-strong)}
.nav-topic.cur>.nav-topic-h .tname{color:var(--accent-strong);font-weight:600}
.nav-topic-h.pending{opacity:.42;pointer-events:none}
.tfrac{font:500 11px var(--mono);color:var(--muted);font-variant-numeric:tabular-nums;flex:none}
.nav-topic.tdone>.nav-topic-h .tfrac{color:var(--ok)}
.nav-lessons{display:none;list-style:none;margin:1px 0 5px 19px;padding:0;border-left:1px solid var(--navline)}
.nav-topic.open>.nav-lessons{display:block}
.nav-lesson{display:flex;align-items:center;gap:8px;padding:6px 9px 6px 13px;color:var(--muted);font-size:13px;line-height:1.35;border-radius:0 8px 8px 0;min-height:34px}
.nav-lesson:hover{background:var(--hover);color:var(--fg);text-decoration:none}
.nav-lesson.cur{background:var(--accent-soft);color:var(--accent-strong);font-weight:600;box-shadow:inset 2px 0 0 var(--accent)}
.nav-lesson .ldot{width:6px;height:6px;border-radius:50%;background:var(--muted);opacity:.5;flex:none}
.nav-lesson .ldot.ld-easy{background:var(--easy);opacity:1}.nav-lesson .ldot.ld-medium{background:var(--med);opacity:1}.nav-lesson .ldot.ld-hard{background:var(--hard);opacity:1}
.nav-lesson .ltext{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-lesson .lchk{flex:none;width:12px;text-align:center;font-size:11px;color:var(--ok)}
.nav-lesson.done{color:var(--fg)}.nav-lesson.done .ldot{opacity:.25}
main{max-width:var(--maxw);margin:0 auto;padding:22px 18px 130px}
.crumb{color:var(--muted);font-size:13px;margin-bottom:10px}.crumb a{color:var(--muted)}
h1{font-size:clamp(24px,5.5vw,32px);line-height:1.18;letter-spacing:-.02em;margin:.1em 0 .35em}
.sub{color:var(--muted);font-size:14px;margin:-.1em 0 1.2em}
.prose{font-size:16.5px;overflow-wrap:break-word}.prose h2{font-size:22px;margin:1.5em 0 .4em;padding-bottom:5px;border-bottom:1px solid var(--line)}
.prose h3{font-size:18px;margin:1.3em 0 .3em}.prose h4{font-size:16px;color:var(--muted)}
.prose img{max-width:100%;height:auto}.prose table{border-collapse:collapse;margin:1em 0;display:block;overflow:auto;max-width:100%}
.prose td,.prose th{border:1px solid var(--line);padding:7px 11px}.prose th{background:var(--code)}
.prose blockquote{border-left:3px solid var(--accent);margin:1em 0;padding:.5em 1em;color:var(--muted);background:var(--code);border-radius:0 8px 8px 0}
.prose code{background:var(--code);padding:1px 6px;border-radius:5px;font-size:.88em;overflow-wrap:break-word}
figure{margin:1.4em 0;text-align:center}figure img{max-width:100%;height:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 1px 3px rgba(0,0,0,.07)}
figcaption{color:var(--muted);font-size:13px;margin-top:7px}
pre{background:var(--code);border:1px solid var(--line);border-radius:var(--radius);padding:14px;overflow:auto;-webkit-overflow-scrolling:touch}
pre code{background:none;padding:0;font:13px/1.55 var(--mono)}
.codehdr{display:inline-block;font:600 10.5px/1 var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;
background:var(--surface-2);border:1px solid var(--line);border-bottom:0;border-radius:8px 8px 0 0;padding:7px 12px;margin:1.4em 0 0}
.codehdr+pre{margin-top:0;border-top-left-radius:0}
.recog,.enrich{border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius);padding:14px 18px;margin:1.4em 0;background:var(--card)}
.recog h3,.enrich h3{margin:.1em 0 .5em;font-size:17px}.enrich-todo{color:var(--muted);font-style:italic}
.enrich-tag{color:var(--muted);font-size:12px;margin-top:10px;border-top:1px dashed var(--line);padding-top:6px}
.recog ul,.enrich ul{margin:.3em 0;padding-left:1.1em}.recog li,.enrich li{margin:.3em 0}
.learn{border:1px solid var(--line);border-radius:var(--radius);margin:1.4em 0;background:var(--card);overflow:hidden}
.learn>summary{cursor:pointer;padding:14px 18px;font-weight:700;font-size:15.5px;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 14%,transparent),transparent);list-style:none}
.learn>summary::-webkit-details-marker{display:none}
.learn-intro{padding:0 18px;color:var(--muted);font-size:14px}
.prompt{margin:12px 14px;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.prompt-h{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 12px;background:var(--code)}
.prompt-t{font-weight:600;font-size:14px}.prompt-why{margin:8px 12px 4px;color:var(--muted);font-size:13px}
.prompt-body{margin:0 12px 12px;padding:11px;background:var(--bg);font-size:12.5px;white-space:pre-wrap;border:1px dashed var(--line);border-radius:8px;overflow-wrap:break-word}
.copy{font:12px inherit;border:1px solid var(--line);background:var(--bg);color:var(--fg);border-radius:8px;padding:6px 12px;cursor:pointer;min-height:34px;flex:none}
.copy:hover{background:var(--accent);color:#fff}
.diff{display:inline-block;font-size:10.5px;font-weight:800;padding:2px 9px;border-radius:20px;text-transform:uppercase;vertical-align:middle}
.easy{background:var(--easy-soft);color:var(--easy)}.medium{background:var(--med-soft);color:var(--med)}.hard{background:var(--hard-soft);color:var(--hard)}
.lesson-list{list-style:none;padding:0;margin:1em 0}
.lesson-list li{padding:11px 4px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;min-height:44px}
.lesson-list li.done .chk{color:var(--ok)}.lesson-list .chk{width:15px;color:var(--muted);font-weight:700;flex:none}
.sol{border:1px solid var(--line);border-radius:10px;margin:1.2em 0;background:var(--code)}
.sol summary{cursor:pointer;font-weight:600;padding:12px 16px;color:var(--accent)}
.sol[open] summary{border-bottom:1px solid var(--line)}.sol>*:not(summary){margin-left:16px;margin-right:16px}
.progwrap{margin:1.1em 0}.progbar{height:9px;background:var(--line);border-radius:99px;overflow:hidden}
.progbar>i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));width:0;transition:width .4s}
.progtext{font-size:13px;color:var(--muted);margin-top:5px}
.donebtn{font:15px inherit;font-weight:600;border:1px solid var(--accent);background:var(--bg);color:var(--accent);border-radius:11px;padding:11px 20px;cursor:pointer;min-height:44px}
.donebtn.is-done{background:var(--ok);border-color:var(--ok);color:#fff}
.notes{border:1px solid var(--line);border-radius:var(--radius);background:var(--card);padding:14px 18px;margin:1.6em 0}
.notes h3{margin:.1em 0 .5em;font-size:16px}
.notes textarea{width:100%;min-height:110px;resize:vertical;font:14.5px/1.6 inherit;color:var(--fg);background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:11px}
.notes textarea:focus{outline:2px solid var(--accent)}
.notes .saved{font-size:12px;color:var(--ok);margin-top:6px;height:15px}
.note-card{border:1px solid var(--line);border-radius:12px;background:var(--card);padding:14px 16px;margin:12px 0}
.note-card .nt{white-space:pre-wrap;font-size:14.5px;color:var(--fg);margin:.4em 0 0}
.nav-bottom{display:flex;justify-content:space-between;gap:12px;margin-top:50px;border-top:1px solid var(--line);padding-top:18px}
.nav-bottom a{max-width:46%;min-height:44px;display:flex;align-items:center}
#bbar{position:fixed;bottom:0;left:0;right:0;z-index:30;display:flex;background:color-mix(in srgb,var(--bg) 92%,transparent);
backdrop-filter:blur(10px);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
#bbar a,#bbar button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:0;color:var(--muted);font:11px inherit;cursor:pointer;min-height:56px;text-decoration:none}
#bbar .ic{font-size:20px;line-height:1}
.walk{border:1px solid var(--line);border-radius:14px;background:var(--card);padding:16px 18px;margin:1.4em 0}
.walk h3{margin:.1em 0 .6em;font-size:17px}
.wbar{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.wbtn{font:600 14px inherit;border:1px solid var(--accent);background:var(--bg);color:var(--accent);border-radius:9px;padding:8px 14px;cursor:pointer;min-height:40px}
.wbtn:disabled{opacity:.4;cursor:default;border-color:var(--line);color:var(--muted)}
.wcount{font:600 13px ui-monospace,Menlo,monospace;color:var(--muted);font-variant-numeric:tabular-nums}
.wstep{display:none}.wstep.on{display:block;animation:wfade .2s ease}
.wstep-t{font-weight:700;color:var(--accent);margin-bottom:6px}
.wstep img{max-width:100%;height:auto;border:1px solid var(--line);border-radius:10px;margin:.6em 0}
.wstep pre{background:var(--code);border:1px solid var(--line);border-radius:8px;padding:12px;overflow:auto;font:12.5px/1.55 ui-monospace,Menlo,monospace;white-space:pre}
@keyframes wfade{from{opacity:.35}to{opacity:1}}
.wstep details{margin:.7em 0;border:1px solid var(--line);border-radius:9px;background:var(--bg);padding:0 12px}
.wstep details[open]{padding-bottom:8px}
.wstep summary{cursor:pointer;color:var(--accent);font-weight:600;padding:10px 0;list-style:none}
.wstep summary::-webkit-details-marker{display:none}
.wstep summary::before{content:"▸ ";transition:transform .2s}.wstep details[open] summary::before{content:"▾ "}
.wgal{margin-top:14px;border-top:1px solid var(--line);padding-top:10px}
.wgal>summary{cursor:pointer;font-weight:600;color:var(--accent);font-size:14px}
.wgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:12px}
.wgrid figure{margin:0}.wgrid img{width:100%;height:auto;border:1px solid var(--line);border-radius:10px}
.wgrid figcaption{font-size:12px;color:var(--muted);margin-top:4px}
a:focus-visible,button:focus-visible,summary:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
body.drawer #bbar{display:none}
.prose svg,.wstep svg,.recog svg,.enrich svg{max-height:1.5em;width:auto;vertical-align:middle}
.prose mjx-container svg,.wstep mjx-container svg{max-height:none;vertical-align:baseline}
.lfilter{width:100%;font:15px inherit;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--card);color:var(--fg);margin:6px 0 4px}
.lfilter:focus{outline:2px solid var(--accent)}
.lgroup{margin:8px 0}.lgroup>summary{cursor:pointer;font-weight:700;font-size:14px;padding:8px 2px;color:var(--fg)}
.lgroup>summary .gc{color:var(--muted);font:600 12px ui-monospace,Menlo,monospace}
#totop{position:fixed;right:16px;bottom:74px;z-index:28;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--accent);font-size:18px;cursor:pointer;display:none;box-shadow:0 4px 14px rgba(0,0,0,.18)}
#totop.show{display:block}
@media(min-width:1024px){#totop{bottom:24px}}
@media(min-width:1024px){#menu{display:none}#side{transform:none}#scrim{display:none}main{margin-left:var(--rail);padding:30px 40px 120px}#bbar{display:none}}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
