:root{
  --bg:#0f1720; --panel:#16212e; --panel2:#1d2b3a; --ink:#e8eef5; --muted:#9fb0c3;
  --brand:#3aa0ff; --brand2:#1e6fd0; --good:#2ecc71; --bad:#ff5c5c; --line:#26364a;
  --shadow:0 6px 22px rgba(0,0,0,.35);
}
[data-theme="light"]{
  --bg:#eef2f7; --panel:#ffffff; --panel2:#f4f7fb; --ink:#12202e; --muted:#5a6b7d;
  --brand:#1e6fd0; --brand2:#155bb0; --good:#178a4c; --bad:#c0392b; --line:#d8e0ea;
  --shadow:0 6px 22px rgba(20,40,70,.12);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.5}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:16px 22px;background:linear-gradient(90deg,var(--brand2),var(--brand));color:#fff}
.brand{display:flex;gap:14px;align-items:center}
.logo{font-size:30px}
.topbar h1{font-size:19px;margin:0}
.sub{margin:2px 0 0;font-size:12.5px;opacity:.9}
main{max-width:900px;margin:0 auto;padding:22px}
.view{animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1}}
.hidden{display:none}
h2{font-size:17px;margin:26px 0 12px;border-left:4px solid var(--brand);padding-left:10px}
.notice{background:var(--panel2);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;font-size:13.5px;color:var(--muted)}
.notice strong{color:var(--ink)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.grid.small{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
.tile{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;
  cursor:pointer;transition:.15s;box-shadow:var(--shadow)}
.tile:hover{transform:translateY(-3px);border-color:var(--brand)}
.tile h3{margin:0 0 4px;font-size:16px}
.tile .meta{font-size:12px;color:var(--muted)}
.tile .best{font-size:12px;margin-top:8px;color:var(--good);font-weight:600}
.row{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
button{font:inherit;border:none;border-radius:10px;padding:10px 16px;cursor:pointer}
.primary{background:var(--brand);color:#fff}
.primary:hover{background:var(--brand2)}
.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.ghost:hover{border-color:var(--brand)}
.wide{width:100%}
.quizbar{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.progress{flex:1;height:8px;background:var(--panel2);border-radius:6px;overflow:hidden}
#progressFill{height:100%;width:0;background:var(--brand);transition:.3s}
.counter{font-size:13px;color:var(--muted);min-width:64px;text-align:right}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:22px;box-shadow:var(--shadow)}
.card.center{text-align:center}
.tag{display:inline-block;font-size:11px;letter-spacing:.03em;text-transform:uppercase;
  background:var(--panel2);color:var(--muted);border:1px solid var(--line);
  padding:3px 9px;border-radius:20px;margin-bottom:12px}
.qtext{font-size:16.5px;font-weight:600;margin:0 0 16px}
.opt{display:flex;gap:10px;align-items:flex-start;background:var(--panel2);
  border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;margin:8px 0;
  cursor:pointer;transition:.12s}
.opt:hover{border-color:var(--brand)}
.opt .key{font-weight:700;color:var(--brand)}
.opt.sel{border-color:var(--brand);background:rgba(58,160,255,.12)}
.opt.correct{border-color:var(--good);background:rgba(46,204,113,.14)}
.opt.wrong{border-color:var(--bad);background:rgba(255,92,92,.14)}
.opt.lock{cursor:default}
.explain{margin-top:14px;padding:12px 14px;border-left:4px solid var(--brand);
  background:var(--panel2);border-radius:8px;font-size:13.5px;color:var(--muted)}
.explain b{color:var(--ink)}
.quiznav{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:16px}
.chk{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
#scoreCard h2{border:none;padding:0}
.big{font-size:52px;font-weight:800;margin:6px 0}
.pass{color:var(--good)} .fail{color:var(--bad)}
.rev{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;margin:10px 0}
.rev .q{font-weight:600;margin-bottom:8px}
.rev .a{font-size:13.5px;margin:3px 0}
.rev .a.you{color:var(--bad)} .rev .a.ok{color:var(--good)}
.rev .ex{font-size:13px;color:var(--muted);margin-top:6px}
.foot{max-width:900px;margin:10px auto 30px;padding:0 22px;font-size:12px;color:var(--muted)}
code{background:var(--panel2);padding:1px 5px;border-radius:5px}
@media(max-width:560px){.topbar h1{font-size:16px}.sub{display:none}}

/* ---- top bar right cluster + logout ---- */
.topbar-right{display:flex;align-items:center;gap:10px}
.whoami{font-size:12.5px;opacity:.92;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logout{color:#fff;text-decoration:none;border-color:rgba(255,255,255,.5)}
.logout:hover{background:rgba(255,255,255,.15)}
@media(max-width:560px){.whoami{display:none}}

/* ---- login gate ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow);padding:30px 28px;width:100%;max-width:380px;text-align:center}
.login-logo{font-size:40px;margin-bottom:6px}
.login-card h1{font-size:18px;margin:0 0 6px}
.login-sub{font-size:13px;color:var(--muted);margin:0 0 18px}
.login-card label{display:block;text-align:left;font-size:12.5px;color:var(--muted);margin:12px 0 0}
.login-card input{width:100%;margin-top:5px;padding:11px 12px;border-radius:10px;
  border:1.5px solid var(--line);background:var(--panel2);color:var(--ink);font:inherit}
.login-card input:focus{outline:none;border-color:var(--brand)}
.login-card button{margin-top:18px}
.login-error{background:rgba(255,92,92,.14);border:1px solid var(--bad);color:var(--ink);
  border-radius:10px;padding:9px 12px;font-size:13px;margin-bottom:6px}
.login-foot{font-size:11.5px;color:var(--muted);margin:16px 0 0}
