:root{
  --bg:#0f1419; --panel:#161c24; --panel2:#1d242e; --line:#2a333f;
  --txt:#e6edf3; --muted:#8b97a6; --accent:#4aa3ff; --accent2:#0a84ff;
  --green:#3fb950; --green2:#2ea043; --red:#f85149; --amber:#d29922;
  --code:#0b0f14; --pgblue:#336791;
  --mono:'SF Mono',ui-monospace,'JetBrains Mono','Menlo',Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--txt);font-family:var(--sans);font-size:15px;line-height:1.55}
button{font-family:inherit}
.muted{color:var(--muted);font-size:13px}
.hidden{display:none !important}

#app{display:grid;grid-template-columns:280px 1fr 46%;height:100vh;overflow:hidden}
@media (max-width:1100px){#app{grid-template-columns:240px 1fr}#workbench{display:none}}

/* ---------- Sidebar ---------- */
#sidebar{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}
.brand{display:flex;gap:10px;align-items:center;padding:16px 16px 10px}
.brand h1{font-size:17px;margin:0;letter-spacing:.2px}
.brand p{margin:2px 0 0;font-size:11px;color:var(--muted)}
.logo{font-size:26px}.logo.big{font-size:54px}
#progressBar{height:6px;background:var(--panel2);border-radius:6px;margin:4px 16px 4px}
#progressFill{height:100%;width:0;background:linear-gradient(90deg,var(--green2),var(--green));border-radius:6px;transition:width .3s}
#progressText{margin:0 16px 8px}
#toc{overflow-y:auto;flex:1;padding:4px 8px 16px}
.mod{margin-bottom:10px;padding-left:9px;border-left:3px solid var(--wk,var(--line))}
.mod-h{font-size:14px;font-weight:700;color:var(--txt);padding:6px 8px 2px;cursor:pointer;display:flex;align-items:baseline;gap:8px;user-select:none}
.mod-h:hover .wk-title{color:var(--accent)}
.wk-no{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--wk,var(--muted))}
.wk-title{font-size:15px}
.mod-h .chev{margin-left:auto;color:var(--muted);transition:transform .2s;font-size:11px}
.mod.collapsed .chev{transform:rotate(-90deg)}
.mod.collapsed .les-list,.mod.collapsed .wk-sub,.mod.collapsed .checkpoint{display:none}
.wk-sub{font-size:11px;color:var(--muted);padding:0 8px 6px}
.les{font-size:13px;color:var(--muted);padding:6px 8px;border-radius:7px;cursor:pointer;display:flex;align-items:center;gap:9px}
.les:hover{background:var(--panel2);color:var(--txt)}
.les.active{background:rgba(74,163,255,.14);color:var(--accent)}
.les .snum{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);flex:none;display:grid;place-items:center;font-size:10px;font-weight:600;color:var(--muted)}
.les.active .snum{border-color:var(--accent);color:var(--accent)}
.les.done .snum{background:var(--green2);border-color:var(--green2);color:#fff}
.les .ltitle{line-height:1.25}
.checkpoint{display:flex;align-items:center;justify-content:space-between;margin:8px 6px 2px;padding:5px 9px;border-radius:7px;background:var(--panel2);font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--muted)}
.checkpoint .cp-pct{font-weight:700;color:var(--muted)}
.checkpoint.reached{background:rgba(63,185,80,.12)}
.checkpoint.reached .cp-label::before{content:"✓ "}
.checkpoint.reached,.checkpoint.reached .cp-pct{color:var(--green)}
.crumb-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
.side-foot{padding:10px 16px;border-top:1px solid var(--line)}

/* ---------- Main ---------- */
#main{overflow-y:auto;padding:30px 38px 80px}
#lesson{max-width:760px}
.crumb{font-size:12px;color:var(--muted);letter-spacing:.4px;text-transform:uppercase;margin-bottom:6px}
#lesson h2{font-size:26px;margin:0 0 4px}
.les-meta{color:var(--muted);font-size:13px;margin-bottom:20px}
.concept p{margin:0 0 12px}
.concept ul{margin:0 0 14px;padding-left:22px}
.concept li{margin:3px 0}
.concept b{color:#fff}
code{font-family:var(--mono);background:var(--code);border:1px solid var(--line);padding:1px 6px;border-radius:5px;font-size:13px;color:#c7e0ff}

.block{margin:22px 0}
.block h3{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0 0 10px}
.example{background:var(--panel);border:1px solid var(--line);border-radius:10px;margin-bottom:10px;overflow:hidden}
.example .ex-head{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border-bottom:1px solid var(--line)}
.example .ex-head .lbl{font-size:13px;font-weight:600}
.example pre{margin:0;padding:12px;font-family:var(--mono);font-size:13px;color:#d7e6f5;overflow-x:auto;background:var(--code);line-height:1.5}
.try{font-size:12px;border:1px solid var(--accent);color:var(--accent);background:transparent;padding:3px 10px;border-radius:6px;cursor:pointer}
.try:hover{background:var(--accent);color:#06121f}

.exercise{background:linear-gradient(180deg,rgba(74,163,255,.07),transparent);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px;padding:16px 18px;margin-top:18px}
.exercise .tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.6px;color:var(--accent);text-transform:uppercase;margin-bottom:6px}
.exercise .prompt{margin:0 0 10px}
.exercise .hint{font-size:13px;color:var(--amber);margin-top:8px}
.load-ex{font-size:13px;background:var(--accent2);color:#fff;border:none;padding:7px 14px;border-radius:7px;cursor:pointer}
.load-ex:hover{filter:brightness(1.1)}

.navbtns{display:flex;justify-content:space-between;margin-top:34px;gap:10px}
.navbtns button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:10px 16px;border-radius:9px;cursor:pointer;font-size:14px}
.navbtns button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.navbtns button:disabled{opacity:.35;cursor:default}

/* ---------- Workbench ---------- */
#workbench{background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden;position:relative}
.wb-toolbar{display:flex;gap:8px;align-items:center;padding:10px;border-bottom:1px solid var(--line);background:var(--panel2)}
.spacer{flex:1}
.btn{border:1px solid var(--line);background:var(--panel);color:var(--txt);padding:7px 13px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500}
.btn:hover{border-color:var(--accent)}
.btn.primary{background:var(--accent2);border-color:var(--accent2);color:#fff}
.btn.primary:hover{filter:brightness(1.1)}
.btn.success{background:var(--green2);border-color:var(--green2);color:#fff}
.btn.success:hover{filter:brightness(1.1)}
.btn.ghost{background:transparent}
#editor{height:34%;min-height:150px;resize:none;border:none;outline:none;background:var(--code);color:#e7f0fb;font-family:var(--mono);font-size:13.5px;padding:14px;line-height:1.55;tab-size:2}
.msg{padding:8px 14px;font-size:13px;font-family:var(--mono);border-bottom:1px solid var(--line);min-height:0;white-space:pre-wrap}
.msg.err{color:var(--red);background:rgba(248,81,73,.08)}
.msg.ok{color:var(--green);background:rgba(63,185,80,.08)}
.msg.info{color:var(--muted)}
#results{flex:1;overflow:auto;padding:0}
table.grid{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--mono)}
table.grid th{position:sticky;top:0;background:var(--panel2);color:var(--accent);text-align:left;padding:7px 12px;border-bottom:2px solid var(--line);white-space:nowrap;z-index:1}
table.grid td{padding:6px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
table.grid tr:hover td{background:rgba(74,163,255,.05)}
table.grid td.null{color:var(--muted);font-style:italic}
.rowcount{padding:8px 14px;color:var(--muted);font-size:12px;border-bottom:1px solid var(--line)}

#schemaPanel{position:absolute;right:0;top:53px;bottom:0;width:300px;background:var(--panel2);border-left:1px solid var(--line);overflow-y:auto;padding:14px 16px;box-shadow:-12px 0 24px rgba(0,0,0,.3)}
#schemaPanel h3{margin:0 0 10px;font-size:14px}
.grp-label{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--accent);margin:6px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--line)}
.tbl{margin-bottom:14px}
.tbl .tname{font-weight:600;color:var(--accent);font-family:var(--mono);font-size:13px;cursor:pointer}
.tbl .cols{font-family:var(--mono);font-size:12px;color:var(--muted);margin:4px 0 0;padding-left:10px}
.tbl .cols div{padding:1px 0}
.tbl .cols .ctype{color:#6f7d8c}

/* ---------- Boot ---------- */
.boot{position:fixed;inset:0;background:var(--bg);display:grid;place-items:center;z-index:100;transition:opacity .4s}
.boot.gone{opacity:0;pointer-events:none}
.boot-card{text-align:center;max-width:380px;padding:20px}
.boot-card h2{margin:10px 0 6px}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;margin:22px auto 0;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#2c3744;border-radius:6px}
::-webkit-scrollbar-track{background:transparent}
