:root{
  --bg:#0d1117; --bg2:#161b22; --bg3:#1c2230; --panel:#171c26;
  --line:#2a3140; --line2:#39414f;
  --txt:#e6edf3; --muted:#9aa7b8; --dim:#6b7686;
  --orange:#ff9900; --orange-d:#e88a00; --blue:#4493f8; --blue2:#1f6feb;
  --green:#3fb950; --green-bg:#102b18; --red:#f85149; --red-bg:#2d1517;
  --amber:#d29922; --purple:#a371f7;
  --radius:12px; --radius-s:8px;
  --shadow:0 6px 24px rgba(0,0,0,.35);
  --mono:ui-monospace,SFMono-Regular,"SF 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;-webkit-font-smoothing:antialiased}
#app{display:flex;min-height:100vh}
a{color:var(--blue);text-decoration:none}
::selection{background:rgba(255,153,0,.3)}

/* ---------- Sidebar ---------- */
#sidebar{width:248px;flex:0 0 248px;background:var(--bg2);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:12px;padding:20px 18px 16px}
.brand-mark{background:linear-gradient(135deg,var(--orange),#ff7a00);color:#111;font-weight:800;
  font-size:14px;letter-spacing:.5px;padding:8px 9px;border-radius:8px}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-size:15px}
.brand-text span{font-size:12px;color:var(--muted)}
#nav{display:flex;flex-direction:column;padding:8px;gap:2px;flex:1}
#nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-s);
  color:var(--muted);font-weight:500;font-size:14px;transition:.12s}
#nav a .ico{font-size:15px;width:18px;text-align:center;opacity:.85}
#nav a:hover{background:var(--bg3);color:var(--txt)}
#nav a.active{background:rgba(255,153,0,.12);color:var(--orange)}
#nav a.active .ico{opacity:1}
.badge{margin-left:auto;font-style:normal;font-size:11px;background:var(--bg3);color:var(--muted);
  padding:1px 7px;border-radius:20px;border:1px solid var(--line)}
.sidebar-foot{padding:14px 16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.link-btn{background:none;border:none;color:var(--dim);font-size:12px;cursor:pointer;text-align:left;padding:0}
.link-btn:hover{color:var(--red)}
.ver{font-size:11px;color:var(--dim)}

/* ---------- Main ---------- */
#main{flex:1;min-width:0;display:flex;justify-content:center}
#view{width:100%;max-width:920px;padding:32px 36px 80px}
@media(max-width:760px){
  #app{flex-direction:column}
  #sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center}
  #nav{flex-direction:row;flex-wrap:wrap;flex:1}
  #nav a{padding:8px 10px}
  .sidebar-foot{flex-direction:row;border:none}
  #view{padding:20px 16px 60px}
}

h1{font-size:26px;margin:0 0 6px;font-weight:700}
h2{font-size:20px;margin:28px 0 10px;font-weight:650}
.sub{color:var(--muted);margin:0 0 22px;font-size:14px}
.pill{display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;
  background:var(--bg3);color:var(--muted);border:1px solid var(--line)}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:14px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:680px){.grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.card.hover{cursor:pointer;transition:.14s}
.card.hover:hover{border-color:var(--line2);transform:translateY(-2px);box-shadow:var(--shadow)}
.card h3{margin:0 0 4px;font-size:16px}
.card p{margin:0;color:var(--muted);font-size:13px}

.stat{display:flex;flex-direction:column;gap:2px}
.stat .num{font-size:30px;font-weight:750;line-height:1}
.stat .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.stat.accent .num{color:var(--orange)}

/* progress bar */
.bar{height:8px;background:var(--bg3);border-radius:20px;overflow:hidden;margin-top:8px}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--orange),#ffb84d);border-radius:20px;transition:width .4s}
.bar.green > i{background:linear-gradient(90deg,var(--green),#56d364)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);color:var(--txt);
  border:1px solid var(--line2);padding:10px 18px;border-radius:var(--radius-s);font-size:14px;
  font-weight:600;cursor:pointer;transition:.12s;font-family:inherit}
.btn:hover{border-color:var(--dim)}
.btn.primary{background:var(--orange);color:#1a1a1a;border-color:var(--orange)}
.btn.primary:hover{background:var(--orange-d)}
.btn.ghost{background:transparent}
.btn.sm{padding:6px 12px;font-size:13px}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:18px}

/* ---------- Topic chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 20px}
.chip{font-size:13px;padding:6px 13px;border-radius:20px;background:var(--bg2);color:var(--muted);
  border:1px solid var(--line);cursor:pointer;transition:.12s;font-family:inherit}
.chip:hover{color:var(--txt);border-color:var(--line2)}
.chip.on{background:var(--orange);color:#1a1a1a;border-color:var(--orange);font-weight:600}

/* ---------- Learn / markdown ---------- */
.md{font-size:15px;line-height:1.7}
.md h1{font-size:24px;margin:18px 0 8px}
.md h2{font-size:20px;margin:26px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.md h3{font-size:16.5px;margin:20px 0 6px;color:var(--orange)}
.md p{margin:10px 0}
.md ul,.md ol{margin:10px 0;padding-left:24px}
.md li{margin:5px 0}
.md code{font-family:var(--mono);background:var(--bg3);padding:1.5px 6px;border-radius:5px;font-size:.88em;color:#ffd9a0}
.md pre{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:14px;overflow:auto}
.md pre code{background:none;padding:0;color:var(--txt)}
.md blockquote{margin:12px 0;padding:8px 16px;border-left:3px solid var(--orange);background:var(--bg2);color:var(--muted);border-radius:0 8px 8px 0}
.md table{border-collapse:collapse;width:100%;margin:14px 0;font-size:13.5px}
.md th,.md td{border:1px solid var(--line2);padding:8px 11px;text-align:left;vertical-align:top}
.md th{background:var(--bg3);font-weight:650}
.md tr:nth-child(even) td{background:rgba(255,255,255,.018)}
.md hr{border:none;border-top:1px solid var(--line);margin:22px 0}
.md strong{color:#fff}
.md a{border-bottom:1px dotted}

.keyfacts{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;margin:18px 0}
.keyfacts h3{margin:0 0 10px;font-size:15px;color:var(--orange)}
.keyfacts ul{margin:0;padding-left:20px}
.keyfacts li{margin:6px 0;font-size:14px}

/* topic header */
.topic-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:6px}
.topic-nav{display:flex;justify-content:space-between;margin-top:32px;gap:12px}

/* ---------- Flashcard ---------- */
.session-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.session-top .meta{display:flex;gap:14px;align-items:center;color:var(--muted);font-size:13px}
.q-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow)}
.q-topic{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--orange);font-weight:700;margin-bottom:10px}
.q-text{font-size:19px;line-height:1.5;font-weight:550;margin-bottom:20px}
.q-text.small{font-size:17px}
textarea.answer{width:100%;min-height:90px;background:var(--bg);border:1px solid var(--line2);border-radius:var(--radius-s);
  color:var(--txt);padding:13px 15px;font-family:inherit;font-size:15px;resize:vertical}
textarea.answer:focus{outline:none;border-color:var(--orange)}

/* answer input mode toggle (type / draw) */
.ans-modes{display:inline-flex;gap:4px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-s);padding:4px;margin-bottom:10px}
.ans-mode{background:none;border:none;color:var(--muted);padding:6px 14px;border-radius:6px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600}
.ans-mode.on{background:var(--bg3);color:var(--orange)}
.draw-wrap{margin-top:2px}
.draw-canvas{width:100%;height:240px;background:#0a0e14;border:1px solid var(--line2);border-radius:var(--radius-s);
  touch-action:none;display:block;cursor:crosshair}
.draw-tools{display:flex;align-items:center;gap:12px;margin-top:8px}

/* write-once reinforcement */
.reinforce{margin-top:20px;border-top:1px solid var(--line);padding-top:18px;animation:fade .25s}
.reinforce .lbl{font-size:13px;font-weight:600;color:var(--orange);margin-bottom:6px}
.reinforce .ans{font-size:17px;font-weight:600;margin-bottom:12px}
input.reinforce-input{width:100%;background:var(--bg);border:1px solid var(--line2);border-radius:var(--radius-s);
  color:var(--txt);padding:12px 14px;font-family:inherit;font-size:15px}
input.reinforce-input:focus{outline:none;border-color:var(--orange)}
.rf-status{font-size:13px;margin:8px 0;min-height:18px;color:var(--muted)}
.reveal{margin-top:20px;border-top:1px solid var(--line);padding-top:18px;animation:fade .25s}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.reveal .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:4px}
.reveal .ans{font-size:17px;font-weight:600;color:var(--green);margin-bottom:14px}
.reveal .exp{color:var(--txt);font-size:14.5px;line-height:1.65}
.your-answer{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:10px 14px;margin-bottom:16px;font-size:14px;color:var(--muted)}
.your-answer b{color:var(--txt);font-weight:500}
.grade-row{display:flex;gap:10px;margin-top:18px}
.grade-row .btn{flex:1;justify-content:center}
.btn.good{background:var(--green-bg);border-color:#1f5130;color:var(--green)}
.btn.good:hover{background:#143b22}
.btn.bad{background:var(--red-bg);border-color:#5a2327;color:var(--red)}
.btn.bad:hover{background:#3a1a1d}

/* ---------- MCQ options ---------- */
.options{display:flex;flex-direction:column;gap:10px;margin:6px 0 4px}
.opt{display:flex;align-items:flex-start;gap:12px;background:var(--bg);border:1px solid var(--line2);
  border-radius:var(--radius-s);padding:13px 15px;cursor:pointer;transition:.1s;font-size:15px}
.opt:hover{border-color:var(--dim)}
.opt .mark{flex:0 0 22px;height:22px;border:2px solid var(--dim);border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-size:12px;color:transparent;margin-top:1px}
.opt.multi .mark{border-radius:6px}
.opt.sel{border-color:var(--orange);background:rgba(255,153,0,.08)}
.opt.sel .mark{border-color:var(--orange);background:var(--orange);color:#111}
.opt.correct{border-color:var(--green);background:var(--green-bg)}
.opt.correct .mark{border-color:var(--green);background:var(--green);color:#06210f}
.opt.wrong{border-color:var(--red);background:var(--red-bg)}
.opt.wrong .mark{border-color:var(--red);background:var(--red);color:#2a0b0d}
.opt.locked{cursor:default}
.opt .otext{flex:1}
.feedback{margin-top:18px;border-radius:var(--radius-s);padding:14px 16px;font-size:14.5px;animation:fade .25s}
.feedback.ok{background:var(--green-bg);border:1px solid #1f5130}
.feedback.no{background:var(--red-bg);border:1px solid #5a2327}
.feedback .ftitle{font-weight:700;margin-bottom:5px;display:flex;align-items:center;gap:8px}
.feedback.ok .ftitle{color:var(--green)}
.feedback.no .ftitle{color:var(--red)}
.feedback .exp{color:var(--txt);line-height:1.6}
.hint-multi{font-size:12px;color:var(--dim);margin-top:2px}

/* source image toggle */
.src-toggle{font-size:12px;color:var(--dim);cursor:pointer;margin-top:14px;display:inline-block}
.src-toggle:hover{color:var(--muted)}
.src-img{margin-top:12px;max-width:100%;border:1px solid var(--line);border-radius:8px;display:none}
.src-img.show{display:block}

/* ---------- Result / exam summary ---------- */
.result-hero{text-align:center;padding:40px 20px}
.result-score{font-size:64px;font-weight:800;line-height:1}
.result-score.pass{color:var(--green)} .result-score.fail{color:var(--red)}
.result-sub{color:var(--muted);margin-top:8px}
.tbreak{margin-top:24px}
.tbreak .row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--line)}
.tbreak .row .name{flex:0 0 200px;font-weight:500}
.tbreak .row .bar{flex:1;margin:0}
.tbreak .row .pct{flex:0 0 56px;text-align:right;font-variant-numeric:tabular-nums;color:var(--muted)}

/* empty / misc */
.empty{text-align:center;color:var(--muted);padding:60px 20px}
.empty .big{font-size:40px;margin-bottom:10px;opacity:.5}
.mastery-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
kbd{font-family:var(--mono);background:var(--bg3);border:1px solid var(--line2);border-bottom-width:2px;
  border-radius:5px;padding:1px 6px;font-size:12px;color:var(--muted)}
.flash-note{font-size:12.5px;color:var(--dim);margin-top:14px}
.inline-tag{font-size:11px;padding:1px 7px;border-radius:5px;background:var(--bg3);color:var(--muted);border:1px solid var(--line);margin-left:6px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--bg3);
  border:1px solid var(--line2);padding:10px 18px;border-radius:10px;box-shadow:var(--shadow);
  font-size:14px;opacity:0;pointer-events:none;transition:.25s;z-index:50}
.toast.show{opacity:1}

/* ---------- Level hero ---------- */
.level-hero{display:flex;align-items:center;gap:24px;background:linear-gradient(135deg,var(--panel),var(--bg3));
  border:1px solid var(--line);border-radius:var(--radius);padding:22px 26px;margin-bottom:22px}
.level-hero .ring{flex:0 0 96px;width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.level-hero .ring-in{width:78px;height:78px;border-radius:50%;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;line-height:1}
.level-hero .ring-in .lv{font-size:30px;font-weight:800;color:var(--orange)}
.level-hero .ring-in .lvl{font-size:10px;letter-spacing:.15em;color:var(--muted);margin-top:2px}
.level-meta{flex:1;min-width:0}
.level-meta h1{margin:0 0 2px;font-size:22px}
@media(max-width:680px){.level-hero{flex-direction:column;text-align:center}}

/* ---------- Badges ---------- */
.badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin:4px 0 8px}
.badge-card{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius-s);padding:14px;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;opacity:.45;filter:grayscale(.7);transition:.15s}
.badge-card.got{opacity:1;filter:none;border-color:var(--orange);background:rgba(255,153,0,.06)}
.badge-card .bico{font-size:30px}
.badge-card .bname{font-weight:650;font-size:13.5px}
.badge-card .bdesc{font-size:11.5px;color:var(--muted);line-height:1.35}

/* ---------- Auth screen ---------- */
#authwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%,rgba(255,153,0,.10),transparent),var(--bg)}
.auth-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow)}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.auth-brand strong{font-size:17px}
.auth-tabs{display:flex;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-s);padding:4px;margin-bottom:20px}
.auth-tabs button{flex:1;background:none;border:none;color:var(--muted);padding:8px;border-radius:6px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600}
.auth-tabs button.on{background:var(--bg3);color:var(--txt)}
.auth-tabs button:disabled{opacity:.4;cursor:not-allowed}
#auth-form label{display:block;font-size:12px;color:var(--muted);margin:12px 0 5px;text-transform:uppercase;letter-spacing:.04em}
#auth-form input{width:100%;background:var(--bg);border:1px solid var(--line2);border-radius:var(--radius-s);
  color:var(--txt);padding:11px 13px;font-size:15px;font-family:inherit}
#auth-form input:focus{outline:none;border-color:var(--orange)}
.auth-err{color:var(--red);font-size:13px;margin-top:12px;min-height:16px}

/* ---------- User bar ---------- */
#userbar{padding-bottom:10px;margin-bottom:6px;border-bottom:1px solid var(--line);width:100%}
#userbar .ubname{font-size:13px;font-weight:600;margin-bottom:2px}
#userbar .syncdot{font-size:11px;color:var(--green);margin-bottom:6px;transition:color .2s}

/* ---------- Admin table ---------- */
.admin-table{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:13.5px}
.atr{display:grid;grid-template-columns:1.6fr .6fr 1fr .9fr .9fr .8fr 1fr 1.1fr;gap:10px;padding:11px 14px;align-items:center;border-bottom:1px solid var(--line)}
.atr:last-child{border-bottom:none}
.atr.ath{background:var(--bg3);font-weight:650;color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.03em}
.arow-actions{display:flex;gap:10px;justify-content:flex-end}
.link-btn.danger:hover{color:var(--red)}
@media(max-width:760px){.admin-table{overflow-x:auto}.atr{min-width:720px}}
