:root{--bg: #faf9f7;--panel: #ffffff;--panel-2: #f3f1ed;--ink: #1c1c1e;--muted: #6e6b66;--faint: #706d67;--border: #e6e3dd;--border-strong: #d4d0c8;--accent: #4f57d2;--accent-soft: #ecedfb;--good: #1a7f5c;--good-soft: #e4f3ec;--bad: #c2453a;--bad-soft: #faeae8;--warn: #9a6b15;--warn-soft: #faf2e0;--code-bg: #f6f5f2;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: ui-monospace, "SF Mono", SFMono-Regular, Menlo, Consolas, monospace}[data-theme=dark]{--bg: #131316;--panel: #1b1b1f;--panel-2: #222226;--ink: #e9e8e6;--muted: #9b99a0;--faint: #8e8c96;--border: #2a2a30;--border-strong: #3a3a42;--accent: #8b91f0;--accent-soft: #26284a;--good: #4cc193;--good-soft: #15302a;--bad: #e57368;--bad-soft: #3a201d;--warn: #d9a84e;--warn-soft: #332a16;--code-bg: #232328}*{box-sizing:border-box}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}code{font-family:var(--mono);font-size:.86em;background:var(--code-bg);border:1px solid var(--border);border-radius:4px;padding:.08em .35em}pre.codeblock{font-family:var(--mono);font-size:13px;line-height:1.55;background:var(--code-bg);border:1px solid var(--border);border-radius:8px;padding:14px 16px;overflow-x:auto;margin:0;white-space:pre}.app{display:flex;min-height:100vh}.sidebar{width:248px;flex-shrink:0;border-right:1px solid var(--border);padding:22px 14px;position:sticky;top:0;height:100vh;overflow-y:auto;background:var(--bg)}.brand{display:block;font-weight:650;font-size:15px;letter-spacing:.01em;color:var(--ink);padding:4px 10px 14px}.brand:hover{text-decoration:none}.brand .sub{display:block;font-size:11.5px;font-weight:400;color:var(--muted);margin-top:1px}.navgroup{margin-top:12px}.navgroup-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);padding:0 10px 6px}.navlink{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:7px;font-size:13.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navlink:hover{background:var(--panel-2);text-decoration:none;color:var(--ink)}.navlink.active{background:var(--accent-soft);color:var(--accent);font-weight:550}.navlink .code{font-family:var(--mono);font-size:11px;color:var(--faint);flex-shrink:0;width:30px}.navlink.active .code{color:var(--accent)}.navlink .dot{margin-left:auto;flex-shrink:0;width:7px;height:7px;border-radius:50%}.dot.done{background:var(--good)}.dot.partial{background:var(--warn)}.dot.todo{background:var(--border-strong)}.main{flex:1;min-width:0;padding:40px 48px 96px}.content{max-width:860px;margin:0 auto}.theme-toggle{margin-top:18px;width:100%;text-align:left;background:none;border:1px solid var(--border);border-radius:7px;color:var(--muted);font-size:12.5px;padding:6px 10px;cursor:pointer;font-family:var(--sans)}.theme-toggle:hover{background:var(--panel-2)}.account-link{margin-top:18px}.text-input{font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--panel);border:1px solid var(--border-strong);border-radius:7px;padding:9px 12px}.text-input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.text-input::placeholder{color:var(--faint)}@media (max-width: 860px){.app{flex-direction:column}.sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--border)}.main{padding:24px 18px 80px}}h1{font-size:28px;line-height:1.25;font-weight:650;margin:0 0 6px;letter-spacing:-.015em}h2{font-size:19px;font-weight:620;margin:40px 0 10px;letter-spacing:-.01em}h3{font-size:16px;font-weight:600;margin:26px 0 8px}p{margin:0 0 14px}.lede{font-size:17px;color:var(--muted);margin-bottom:26px}.kicker{font-family:var(--mono);font-size:12.5px;color:var(--accent);letter-spacing:.04em;margin-bottom:8px}.card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:18px 20px}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;margin-top:26px}.module-card{display:block;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px 18px;color:var(--ink);transition:border-color .12s ease}.module-card:hover{border-color:var(--border-strong);text-decoration:none}.module-card .mc-code{font-family:var(--mono);font-size:11.5px;color:var(--faint)}.module-card .mc-title{font-weight:600;font-size:14.5px;margin:3px 0 4px;line-height:1.35}.module-card .mc-tag{font-size:12.5px;color:var(--muted);line-height:1.5}.module-card .mc-progress{display:flex;gap:5px;margin-top:12px}.mc-step{flex:1;height:4px;border-radius:2px;background:var(--panel-2);border:1px solid var(--border)}.mc-step.done{background:var(--good);border-color:var(--good)}.pill{display:inline-block;font-size:11.5px;font-weight:550;padding:2px 9px;border-radius:999px;border:1px solid var(--border);color:var(--muted);background:var(--panel)}.pill.accent{background:var(--accent-soft);color:var(--accent);border-color:transparent}.pill.good{background:var(--good-soft);color:var(--good);border-color:transparent}.pill.bad{background:var(--bad-soft);color:var(--bad);border-color:transparent}.pill.warn{background:var(--warn-soft);color:var(--warn);border-color:transparent}.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:13.5px;font-weight:550;border-radius:8px;padding:8px 16px;cursor:pointer;border:1px solid var(--border-strong);background:var(--panel);color:var(--ink)}.btn:hover{background:var(--panel-2)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{opacity:.92;background:var(--accent)}[data-theme=dark] .btn.primary{color:var(--bg)}.btn.subtle{border-color:transparent;background:none;color:var(--muted)}.btn.subtle:hover{background:var(--panel-2)}.btn:disabled{opacity:.5;cursor:default}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin:22px 0 30px}.tab{font-family:var(--sans);font-size:13.5px;font-weight:550;padding:8px 14px 10px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:7px}.tab:hover{color:var(--ink)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab .check{color:var(--good);font-size:12px}.diagram-wrap{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:22px 18px 10px;margin:22px 0 6px}.diagram-wrap svg{width:100%;height:auto;display:block}.diagram-caption{font-size:12.5px;color:var(--muted);text-align:center;padding:8px 16px 12px}.examples{display:grid;gap:12px;margin:14px 0}.example{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;padding:13px 16px}.example .ex-title{font-weight:600;font-size:14px}.example .ex-year{font-family:var(--mono);font-size:11.5px;color:var(--faint);margin-left:8px}.example p{font-size:13.5px;color:var(--muted);margin:5px 0 0}ul.defenses{padding-left:0;list-style:none;margin:14px 0}ul.defenses li{position:relative;padding:4px 0 4px 26px;font-size:14.5px}ul.defenses li:before{content:"✓";position:absolute;left:2px;color:var(--good);font-weight:650}.lesson-footer{margin-top:44px;padding-top:20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px}.quiz-q{margin-bottom:34px}.quiz-prompt{font-weight:600;font-size:15px;margin-bottom:12px}.quiz-prompt .qnum{color:var(--faint);font-family:var(--mono);font-size:12.5px;margin-right:8px}.quiz-options{display:grid;gap:8px;margin-top:12px}.quiz-option{text-align:left;font-family:var(--sans);font-size:14px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:10px 14px;cursor:pointer;color:var(--ink);line-height:1.55}.quiz-option:hover{border-color:var(--border-strong)}.quiz-option.selected{border-color:var(--accent);background:var(--accent-soft)}.quiz-option.correct{border-color:var(--good);background:var(--good-soft)}.quiz-option.wrong{border-color:var(--bad);background:var(--bad-soft)}.quiz-option:disabled{cursor:default}.quiz-option pre.codeblock{margin-top:6px;background:var(--bg)}.quiz-explain{margin-top:10px;font-size:13.5px;color:var(--muted);background:var(--panel-2);border-radius:8px;padding:10px 14px}.quiz-score{margin-top:8px}.lab{margin-bottom:48px}.lab-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.lab-head h3{margin:0}.editor-wrap{border:1px solid var(--border-strong);border-radius:8px;overflow:hidden;margin:14px 0 12px}.editor-wrap .cm-editor{font-size:13px}.lab-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.lab-status{font-size:13px;color:var(--muted)}.results{margin-top:14px;display:grid;gap:6px}.result{display:flex;gap:10px;align-items:baseline;font-size:13.5px;border:1px solid var(--border);border-radius:8px;padding:8px 13px;background:var(--panel)}.result .mark{font-weight:700;flex-shrink:0}.result.pass .mark{color:var(--good)}.result.fail .mark{color:var(--bad)}.result.fail{border-color:color-mix(in srgb,var(--bad) 35%,var(--border))}.result .msg{color:var(--muted);font-size:12.5px;font-family:var(--mono)}.runner-error{margin-top:14px;border:1px solid color-mix(in srgb,var(--bad) 40%,var(--border));background:var(--bad-soft);color:var(--bad);font-family:var(--mono);font-size:12.5px;border-radius:8px;padding:10px 14px;white-space:pre-wrap}details.hints{margin-top:16px}details.hints summary{cursor:pointer;font-size:13.5px;color:var(--muted);font-weight:550}details.hints li{font-size:13.5px;color:var(--muted);margin:6px 0}.banner{border-radius:8px;padding:12px 16px;font-size:13.5px;margin:14px 0}.banner.good{background:var(--good-soft);color:var(--good)}.banner.warn{background:var(--warn-soft);color:var(--warn)}.gt-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:4px 0 18px}.gt-review{display:grid;gap:10px;margin-top:18px}.gt-cat-row{display:flex;align-items:center;gap:12px;font-size:13.5px}.gt-cat-row .label{width:270px;flex-shrink:0;color:var(--muted)}.gt-bar{flex:1;height:8px;border-radius:4px;background:var(--panel-2);border:1px solid var(--border);overflow:hidden}.gt-bar>div{height:100%;background:var(--good)}.gt-bar>div.low{background:var(--bad)}.gt-bar>div.mid{background:var(--warn)}.score-hero{font-size:42px;font-weight:650;letter-spacing:-.02em}.score-hero .of{font-size:20px;color:var(--muted);font-weight:450}
