:root{
  --bg:#f4f6fb; --panel:#ffffff; --panel-2:#f8fafc; --border:#e5e9f2;
  --text:#1a2233; --muted:#697089; --brand:#2563eb; --brand-2:#1d4ed8;
  --green:#15a36e; --green-bg:#e7f7ef; --red:#e0455e; --red-bg:#fdebee;
  --amber:#e0a127; --amber-bg:#fdf6e7; --shadow:0 1px 3px rgba(20,30,60,.08),0 8px 24px rgba(20,30,60,.06);
  --radius:14px;
}
[data-theme="dark"]{
  --bg:#0e1117; --panel:#161b24; --panel-2:#1b212c; --border:#262d3a;
  --text:#e6e9f0; --muted:#8b93a7; --brand:#4f86ff; --brand-2:#3a72f0;
  --green:#36c98c; --green-bg:#11281f; --red:#ff6b82; --red-bg:#2a1419;
  --amber:#f0bd5a; --amber-bg:#2a2110; --shadow:0 1px 3px rgba(0,0,0,.4),0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
#app{display:grid;grid-template-columns:300px 1fr;height:100vh;overflow:hidden}
#app>*{min-height:0}

/* ---------- Sidebar ---------- */
#sidebar{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}
.sb-head{padding:18px 18px 12px}
.brand{display:flex;align-items:center;gap:11px}
.brand-logo{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--brand),#7c3aed);color:#fff;font-weight:800;display:grid;place-items:center;font-size:16px;letter-spacing:.5px}
.brand-title{font-weight:700;font-size:15px}
.brand-sub{font-size:11.5px;color:var(--muted)}
.sb-stats{display:flex;gap:8px;padding:4px 18px 12px}
.stat{flex:1;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:9px 6px;text-align:center}
.stat span{font-weight:700;font-size:18px;display:block}
.stat label{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.sb-search{padding:0 18px 10px}
.sb-search input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);color:var(--text);font-size:13.5px;outline:none}
.sb-search input:focus{border-color:var(--brand)}
.sb-filter{display:flex;flex-wrap:wrap;gap:6px;padding:0 18px 12px}
.chip{font-size:12px;padding:5px 11px;border-radius:20px;border:1px solid var(--border);background:var(--panel-2);color:var(--muted);cursor:pointer;transition:.15s}
.chip:hover{color:var(--text)}
.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.palette{flex:1;overflow-y:auto;padding:8px 14px 24px;display:grid;grid-template-columns:repeat(5,1fr);gap:7px;align-content:start}
.pq{position:relative;aspect-ratio:1;border:1px solid var(--border);border-radius:9px;background:var(--panel-2);color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;display:grid;place-items:center;transition:.12s}
.pq:hover{border-color:var(--brand);color:var(--text)}
.pq.active{outline:2px solid var(--brand);outline-offset:1px;color:var(--text)}
.pq.correct{background:var(--green-bg);color:var(--green);border-color:transparent}
.pq.wrong{background:var(--red-bg);color:var(--red);border-color:transparent}
.pq .flag{position:absolute;top:-3px;right:-2px;font-size:10px;color:var(--amber)}

/* ---------- Main ---------- */
#main{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}
#topbar{display:flex;align-items:center;gap:16px;padding:12px 22px;background:var(--panel);border-bottom:1px solid var(--border)}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;font-size:16px}
.icon-btn:hover{border-color:var(--brand)}
#menuBtn{display:none}
.progress-wrap{flex:1;max-width:420px}
.progress-label{font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:600}
.progress-bar{height:7px;background:var(--panel-2);border-radius:10px;overflow:hidden;border:1px solid var(--border)}
#progressFill{height:100%;width:0;background:linear-gradient(90deg,var(--brand),#7c3aed);transition:width .3s}
.jump{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}
.jump input{width:74px;padding:7px 9px;border:1px solid var(--border);border-radius:9px;background:var(--panel-2);color:var(--text);outline:none}
.jump input:focus{border-color:var(--brand)}

#card-area{flex:1 1 auto;min-height:0;overflow-y:auto;padding:26px 28px;display:flex;justify-content:center}
.card{width:100%;max-width:880px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 30px 30px;height:fit-content;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.q-meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:16px}
.badge{font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:20px;border:1px solid var(--border);color:var(--muted);background:var(--panel-2)}
.badge.num{background:var(--brand);color:#fff;border-color:var(--brand)}
.badge.multi{background:var(--amber-bg);color:var(--amber);border-color:transparent}
.q-text{font-size:16px;line-height:1.65;white-space:pre-wrap;margin-bottom:18px;font-weight:450}
.q-images{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.q-images img{max-width:100%;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:zoom-in}

.choices{display:flex;flex-direction:column;gap:10px}
.choice{display:flex;gap:12px;align-items:flex-start;padding:13px 15px;border:1.5px solid var(--border);border-radius:11px;cursor:pointer;transition:.13s;background:var(--panel)}
.choice:hover{border-color:var(--brand);background:var(--panel-2)}
.choice .mark{flex-shrink:0;width:26px;height:26px;border-radius:7px;border:1.5px solid var(--border);display:grid;place-items:center;font-weight:700;font-size:13px;color:var(--muted);background:var(--panel-2)}
.choice .ctext{flex:1;font-size:14.5px}
.choice.selected{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 8%,var(--panel))}
.choice.selected .mark{background:var(--brand);color:#fff;border-color:var(--brand)}
.choice.correct{border-color:var(--green);background:var(--green-bg)}
.choice.correct .mark{background:var(--green);color:#fff;border-color:var(--green)}
.choice.incorrect{border-color:var(--red);background:var(--red-bg)}
.choice.incorrect .mark{background:var(--red);color:#fff;border-color:var(--red)}
.choice.revealed{cursor:default}
.choice .tag{margin-left:auto;font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;align-self:center}
.choice.correct .tag{background:var(--green);color:#fff}
.choice.incorrect .tag{background:var(--red);color:#fff}

/* ---------- Explanation ---------- */
.explain{margin-top:22px;border-top:1px dashed var(--border);padding-top:20px;animation:fade .25s ease}
.exp-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.answer-pill{font-size:14px;font-weight:700;padding:7px 14px;border-radius:10px;background:var(--green-bg);color:var(--green);border:1px solid color-mix(in srgb,var(--green) 30%,transparent)}
.verdict{font-size:13px;font-weight:600;padding:6px 12px;border-radius:8px}
.verdict.win{background:var(--green-bg);color:var(--green)}
.verdict.lose{background:var(--red-bg);color:var(--red)}
.community{font-size:12.5px;color:var(--muted)}
.exp-section-title{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:700;margin:18px 0 10px;display:flex;align-items:center;gap:8px}
.explanation-box{background:var(--green-bg);border:1px solid color-mix(in srgb,var(--green) 28%,transparent);border-radius:11px;padding:15px 18px;font-size:14px;line-height:1.65}
.explanation-box p{margin:0 0 10px}
.explanation-box p:last-child{margin-bottom:0}
.explanation-box ul{margin:6px 0 10px;padding-left:20px}
.explanation-box li{margin-bottom:5px}
.explanation-box strong{color:var(--text)}
.explanation-box code{background:var(--panel);border:1px solid var(--border);border-radius:5px;padding:1px 6px;font-size:12.5px;font-family:ui-monospace,Menlo,Consolas,monospace}
.vote-dist{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:6px}
.vote-bar{font-size:12px;padding:5px 11px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);font-weight:600}
.vote-bar.top{background:var(--brand);color:#fff;border-color:var(--brand)}
.comment{border:1px solid var(--border);border-radius:11px;padding:13px 15px;margin-bottom:10px;background:var(--panel-2)}
.cm-head{display:flex;align-items:center;gap:9px;margin-bottom:7px;font-size:12.5px}
.cm-user{font-weight:700}
.cm-sel{font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;background:var(--amber-bg);color:var(--amber)}
.cm-up{margin-left:auto;color:var(--muted);font-size:12px}
.cm-up b{color:var(--green)}
.cm-text{font-size:13.5px;line-height:1.6;white-space:pre-wrap}
.exp-note{font-size:12px;color:var(--muted);font-style:italic;margin-top:6px}

/* ---------- Footer nav ---------- */
#navbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;background:var(--panel);border-top:1px solid var(--border)}
.nav-mid{display:flex;gap:10px}
.btn{font-family:inherit;font-size:13.5px;font-weight:600;padding:10px 18px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;transition:.14s}
.btn:hover{border-color:var(--brand)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-primary:hover{background:var(--brand-2)}
.btn-ghost{background:transparent}
.btn-flagged{background:var(--amber-bg);color:var(--amber);border-color:var(--amber)}

/* ---------- Image lightbox ---------- */
#lightbox{position:fixed;inset:0;background:rgba(8,12,20,.86);display:none;place-items:center;z-index:100;padding:30px;cursor:zoom-out}
#lightbox.open{display:grid}
#lightbox img{max-width:96vw;max-height:92vh;border-radius:10px}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  #app{grid-template-columns:1fr}
  #sidebar{position:fixed;inset:0 auto 0 0;width:280px;z-index:50;transform:translateX(-100%);transition:.25s;box-shadow:var(--shadow)}
  #sidebar.open{transform:none}
  #menuBtn{display:block}
  .jump span{display:none}
  #card-area{padding:18px 14px}
  .card{padding:22px 18px}
}
