:root{--ink:#0e2327;--surface:#15393f;--surface-2:#1b454c;--line:#2a565d;--text:#e7efe9;--text-dim:#9db8b3;--accent:#e8b931;--accent-ink:#1d1607;--green:#5fb39a;--rust:#d96c4f;--mono:"IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--sans:"IBM Plex Sans", system-ui, -apple-system, sans-serif;--disp:"Fraunces", Georgia, serif}*{box-sizing:border-box}html,body{height:100%;margin:0}body{background:var(--ink);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.55}.app{height:100vh;grid-template-rows:56px 1fr auto;grid-template-columns:268px minmax(0,1fr);height:100dvh;display:grid}header{border-bottom:1px solid var(--line);background:var(--surface);grid-column:1/3;align-items:center;gap:14px;padding:0 18px;display:flex}header h1{font-family:var(--disp);letter-spacing:.2px;margin:0;font-size:19px;font-weight:600}header h1 span{color:var(--accent)}.status{font-family:var(--mono);color:var(--text-dim);align-items:center;gap:8px;margin-left:auto;font-size:12px;display:flex}.status .dot{background:var(--rust);border-radius:50%;width:8px;height:8px;transition:background .3s}.status.ok .dot{background:var(--green)}.duck{flex:none;width:26px;height:26px}.duck.bob{animation:1.1s ease-in-out infinite bob}@keyframes bob{0%,to{transform:translateY(0)rotate(-3deg)}50%{transform:translateY(-3px)rotate(3deg)}}@media (prefers-reduced-motion:reduce){.duck.bob{animation:none}}.foot{border-top:1px solid var(--line);background:var(--surface);font-family:var(--mono);color:var(--text-dim);grid-column:1/3;align-items:center;gap:10px;padding:8px 18px;font-size:11.5px;display:flex}.foot a{color:var(--accent);text-decoration:none}.foot a:hover{text-decoration:underline}nav{border-right:1px solid var(--line);background:var(--surface);padding:14px 10px;overflow-y:auto}nav .grp{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;color:var(--text-dim);margin:14px 8px 6px;font-size:10.5px}nav .grp:first-child{margin-top:0}nav button{text-align:left;width:100%;color:var(--text);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:7px;padding:7px 10px;font-size:13.5px;display:block}nav button:hover{background:var(--surface-2)}nav button.active{background:var(--accent);color:var(--accent-ink);font-weight:600}nav button:focus-visible,.chip:focus-visible,.btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}main{min-width:0;padding:22px 26px 60px;overflow-y:auto}.lesson h2{font-family:var(--disp);margin:0 0 2px;font-size:26px;font-weight:700}.lvl{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:11px}.prose{max-width:72ch;color:var(--text)}.prose p{margin:10px 0}.prose code{font-family:var(--mono);background:var(--surface-2);border-radius:4px;padding:1px 5px;font-size:.92em}.prose .note{border-left:3px solid var(--accent);background:var(--surface);color:var(--text-dim);border-radius:0 6px 6px 0;padding:6px 12px}.prose table.cmp{border-collapse:collapse;max-width:100%;margin:14px 0;font-size:13px}.prose table.cmp th,.prose table.cmp td{border:1px solid var(--line);text-align:left;vertical-align:top;padding:6px 10px}.prose table.cmp th{background:var(--surface-2);color:var(--accent);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;font-size:11px}.prose table.cmp td:first-child{color:var(--text-dim)}.prose table.cmp code{background:var(--ink);white-space:nowrap}.diagram{border:1px solid var(--line);background:var(--surface);border-radius:10px;max-width:740px;margin:16px 0 0;padding:14px 16px 8px}.diagram svg{width:100%;height:auto;display:block}.diagram text{font-family:var(--mono)}.chips{flex-wrap:wrap;gap:8px;margin:14px 0 4px;display:flex}.chip{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--line);color:var(--text);cursor:pointer;border-radius:999px;padding:6px 11px;font-size:12px}.chip:hover{border-color:var(--accent);color:var(--accent)}.bench{border:1px solid var(--line);background:var(--surface);border-radius:10px;margin-top:18px;overflow:hidden}.bench .bar{border-bottom:1px solid var(--line);background:var(--surface-2);align-items:center;gap:10px;padding:8px 12px;display:flex}.bench .bar .hint{font-family:var(--mono);color:var(--text-dim);margin-left:auto;font-size:11px}textarea{resize:vertical;background:var(--surface);width:100%;min-height:130px;color:var(--text);font-family:var(--mono);tab-size:4;border:0;outline:none;padding:12px 14px;font-size:13.5px;line-height:1.6;display:block}.btn{font:inherit;cursor:pointer;border:0;border-radius:7px;padding:7px 14px;font-size:13px;font-weight:600}.btn.run{background:var(--accent);color:var(--accent-ink)}.btn.run:disabled{opacity:.45;cursor:wait}.btn.ghost{color:var(--text-dim);border:1px solid var(--line);background:0 0}.btn.ghost:hover{color:var(--text);border-color:var(--text-dim)}.out{padding:0 12px 12px}.meta{font-family:var(--mono);color:var(--text-dim);padding:10px 2px;font-size:11.5px}.err{font-family:var(--mono);white-space:pre-wrap;color:#ffd9cd;border:1px solid var(--rust);background:#d96c4f24;border-radius:8px;margin-top:10px;padding:10px 12px;font-size:12.5px}.pass{color:var(--accent-ink);background:var(--green);border-radius:8px;margin-top:10px;padding:8px 12px;font-weight:600}.fail{color:#ffd9cd;border:1px solid var(--rust);background:#d96c4f24;border-radius:8px;margin-top:10px;padding:8px 12px}.tablewrap{border:1px solid var(--line);border-radius:8px;max-height:380px;overflow:auto}table.res{border-collapse:collapse;font-family:var(--mono);width:100%;font-size:12.5px}table.res th{background:var(--surface-2);color:var(--accent);text-align:left;border-bottom:1px solid var(--line);white-space:nowrap;padding:6px 10px;position:sticky;top:0}table.res td{white-space:nowrap;border-bottom:1px solid #2a565d80;padding:5px 10px}table.res td.null{color:var(--text-dim);font-style:italic}pre.plan{font-family:var(--mono);background:var(--ink);border:1px solid var(--line);border-radius:8px;margin:10px 0 0;padding:12px;font-size:12px;line-height:1.45;overflow:auto}.ex{border:1px dashed var(--line);background:#e8b9310d;border-radius:10px;margin-top:22px;padding:14px 16px}.ex h3{font-size:14px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:0 0 6px}.ex p{max-width:70ch;margin:4px 0 10px}.schema{margin-top:26px}.schema summary{cursor:pointer;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-size:12px}.cards{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;margin-top:12px;display:grid}.card{border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:12px 14px}.card h4{font-family:var(--mono);color:var(--accent);margin:0 0 6px;font-size:13px}.card ul{font-family:var(--mono);color:var(--text-dim);margin:0;padding:0;font-size:12px;list-style:none}.card li b{color:var(--text);font-weight:500}.card .peek{margin-top:8px}@media (max-width:780px){.app{grid-template-rows:56px auto 1fr auto;grid-template-columns:minmax(0,1fr)}header,.foot{grid-column:auto}header{gap:10px;padding:0 12px}header h1{white-space:nowrap;font-size:17px}.status{min-width:0}.status span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}nav{border-right:0;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:4px;padding:8px;display:flex}nav .grp{display:none}nav button{white-space:nowrap;background:var(--surface-2);border:1px solid var(--line);width:auto;padding:6px 10px;font-size:12.5px}nav button.active{border-color:var(--accent)}main{padding:16px 14px 50px}textarea{font-size:16px}}
