:root{--bg: #0e1116;--bg-2: #161b22;--bg-3: #1f2630;--border: #2a313c;--text: #e6edf3;--muted: #8b949e;--accent: #58a6ff;--accent-2: #7ee787;--warn: #f0883e;--error: #ff7b72;--ok: #3fb950;--radius: 8px;--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.55}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app-header{display:flex;align-items:center;gap:18px;padding:14px 22px;border-bottom:1px solid var(--border);background:var(--bg-2);position:sticky;top:0;z-index:10}.brand{font-weight:600;color:var(--text);letter-spacing:.2px}.brand:hover{text-decoration:none;color:var(--accent)}.crumbs{color:var(--muted);font-size:14px}.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--accent)}.crumbs .sep{margin:0 6px;opacity:.5}main{max-width:1100px;margin:0 auto;padding:24px 22px 80px}h1,h2,h3{line-height:1.25}h1{font-size:26px;margin:6px 0 14px}h2{font-size:20px;margin:22px 0 10px}h3{font-size:16px;margin:16px 0 6px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-weight:600}p{margin:8px 0}code,pre{font-family:var(--mono);font-size:13.5px}:not(pre)>code{background:var(--bg-3);padding:1px 6px;border-radius:4px;border:1px solid var(--border)}pre{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;overflow-x:auto}button{background:var(--bg-3);color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:var(--radius);font-size:14px;cursor:pointer;font-family:inherit;transition:background .12s,border-color .12s}button:hover:not(:disabled){background:#2a3340;border-color:#3a4350}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#0e1116;font-weight:600}button.primary:hover:not(:disabled){background:#79b8ff;border-color:#79b8ff}button.ghost{background:transparent}input[type=text],textarea{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:8px 10px;font-family:inherit;font-size:14px;width:100%}input[type=text]:focus,textarea:focus{outline:none;border-color:var(--accent)}textarea{resize:vertical;min-height:80px;font-family:var(--mono)}.topic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:18px}.topic-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:block;color:var(--text)}.topic-card:hover{border-color:var(--accent);text-decoration:none}.topic-card h2{margin:0 0 6px;font-size:17px}.topic-card .progress{color:var(--muted);font-size:13px;margin-top:10px}.topic-card .progress .bar{display:inline-block;width:80px;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden;vertical-align:middle;margin-left:6px}.topic-card .progress .bar>div{height:100%;background:var(--accent-2)}.q-list{list-style:none;padding:0;margin:14px 0}.q-list li{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-2);margin-bottom:8px}.q-list li a{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;color:var(--text)}.q-list li a:hover{background:var(--bg-3);text-decoration:none}.q-list .tag{font-size:11px;background:var(--bg-3);padding:2px 8px;border-radius:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-right:8px}.q-list .check{color:var(--ok)}.question-wrap{display:grid;grid-template-columns:1fr 320px;gap:22px;margin-top:12px}@media (max-width: 900px){.question-wrap{grid-template-columns:1fr}}.question-main{min-width:0}.prompt{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.prompt h1{margin-top:0}.options{list-style:none;padding:0;margin:12px 0}.options li{margin:6px 0}.options label{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-2);cursor:pointer}.options label:hover{border-color:#3a4350}.options input{margin-top:3px}.options label.correct{border-color:var(--ok);background:#14241b}.options label.wrong{border-color:var(--error);background:#2a1818}.actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}.feedback{margin-top:14px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-2)}.feedback.ok{border-color:var(--ok)}.feedback.err{border-color:var(--error)}.feedback h3{margin-top:0;color:var(--text)}.side{display:flex;flex-direction:column;gap:14px}.panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.panel h3{margin-top:0}.hint{background:var(--bg-3);border-left:3px solid var(--accent);padding:8px 12px;border-radius:4px;margin:8px 0;font-size:14px}.editor-host{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:12px}.cm-editor{font-size:13.5px}.cm-editor.cm-focused{outline:none}.test-output{margin-top:12px;background:#06090e;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-family:var(--mono);font-size:12.5px;white-space:pre-wrap;max-height:320px;overflow-y:auto}.test-output.passing{border-color:var(--ok)}.test-output.failing{border-color:var(--error)}.pseudo{background:#11161e;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-family:var(--mono);font-size:13.5px;white-space:pre;overflow-x:auto}.muted{color:var(--muted)}.small{font-size:13px}.spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.kbd{font-family:var(--mono);background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:12px;color:var(--muted)}
