:root{
  --bg:#0a0e1a; --bg-glow:rgba(109,124,255,.16);
  --panel:#121a2e; --panel2:#0e1526; --raised:#1a2238;
  --line:#222c46; --line2:#2c385a;
  --text:#eef2fb; --muted:#94a1c2; --muted2:#65728f;
  --accent:#6d7cff; --accent2:#a855f7; --accent-soft:rgba(109,124,255,.14);
  --good:#34d399; --bad:#fb6f6f; --warn:#fbbf24;
  --r:18px; --r-sm:12px;
  --shadow:0 18px 40px -18px rgba(0,0,0,.7);
  --grad:linear-gradient(135deg,var(--accent),var(--accent2));
}
:root.light{
  --bg:#f4f6fc; --bg-glow:rgba(109,124,255,.12);
  --panel:#ffffff; --panel2:#eef1f9; --raised:#f5f7fd;
  --line:#e3e8f4; --line2:#d4dbec;
  --text:#141a2b; --muted:#5d6a86; --muted2:#8b97b3;
  --accent:#5a63f0; --accent2:#9333ea; --accent-soft:rgba(90,99,240,.10);
  --good:#10b981; --bad:#e5484d; --warn:#d08700;
  --shadow:0 18px 40px -22px rgba(40,55,100,.28);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(900px 500px at 85% -8%,var(--bg-glow),transparent 70%),var(--bg);
  color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.5;
}
a{color:var(--accent);text-decoration:none}
svg.ic,svg.i{display:inline-block;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
svg.ic{width:18px;height:18px;vertical-align:-4px}
svg.i{width:22px;height:22px}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:40;backdrop-filter:blur(12px);
  background:color-mix(in srgb,var(--bg) 80%,transparent);border-bottom:1px solid var(--line)}
.topbar-in{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:12px 18px}
.brand{display:flex;align-items:center;gap:11px;flex:none}
.logo{width:40px;height:40px;border-radius:12px;background:var(--grad);display:grid;place-items:center;color:#fff;flex:none;box-shadow:0 6px 18px -6px var(--accent)}
.logo svg{width:23px;height:23px;stroke:#fff;fill:none;stroke-width:1.6}
.brand h1{font-size:16px;margin:0;letter-spacing:-.2px;font-weight:700;white-space:nowrap}
.brand p{margin:0;font-size:11.5px;color:var(--muted);white-space:nowrap;display:none}
@media(min-width:1281px){.brand p{display:block}}
.topnav{display:flex;gap:2px;margin-left:auto}
.topnav button{display:flex;align-items:center;gap:6px;background:none;border:0;color:var(--muted);
  font-size:12.5px;font-weight:600;padding:8px 10px;border-radius:11px;cursor:pointer;transition:.15s}
.topnav button svg{width:19px;height:19px}
.topnav button:hover{color:var(--text);background:var(--panel)}
.topnav button.active{color:var(--text);background:var(--accent-soft)}
.topnav button.active svg{color:var(--accent)}
.actions{display:flex;gap:8px;margin-left:8px}
.iconbtn{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);background:var(--panel);
  color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:.15s}
.iconbtn:hover{color:var(--text);border-color:var(--line2)}

/* ---------- layout ---------- */
.app{max-width:1100px;margin:0 auto;padding:22px 18px 100px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.card + .card{margin-top:14px}
.grid{display:grid;gap:12px}
.cols2{grid-template-columns:1fr 1fr}.cols3{grid-template-columns:repeat(3,1fr)}
@media(max-width:600px){.cols3{grid-template-columns:1fr}.cols2{grid-template-columns:1fr}}
.section{font-size:12px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted2);margin:24px 6px 11px}
.muted{color:var(--muted)} .small{font-size:12.5px} .center{text-align:center}
h2.h{font-size:18px;margin:0 0 4px;letter-spacing:-.3px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line2);
  background:var(--raised);color:var(--text);padding:12px 17px;border-radius:13px;cursor:pointer;
  font-size:14px;font-weight:600;transition:.15s;text-align:center}
.btn:hover{border-color:var(--accent);transform:translateY(-1px)}
.btn svg{color:var(--muted)} .btn:hover svg{color:var(--accent)}
.btn.primary{background:var(--grad);border:0;color:#fff;box-shadow:0 10px 24px -10px var(--accent)}
.btn.primary svg{color:#fff}
.btn.primary:hover{filter:brightness(1.06)}
.btn.block{display:flex;width:100%}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn.ghost:hover{color:var(--text);background:var(--panel);transform:none}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btnrow{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- dashboard ---------- */
.hero{display:flex;align-items:center;gap:22px}
@media(max-width:520px){
  .hero{flex-direction:column;text-align:center;align-items:stretch}
  .hero>div{display:flex;flex-direction:column;align-items:center}
  .hero .btnrow{width:100%;flex-direction:column;gap:8px}
  .hero .btnrow .btn{width:100%;justify-content:center}
}
.ring-wrap{display:flex;flex-direction:column;align-items:center;gap:7px;flex:none;align-self:center}
.ring{position:relative;width:124px;height:124px}
.ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring .lab{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.ring .lab b{font-size:32px;display:block;line-height:1;letter-spacing:-1.5px;font-weight:800}
.ring-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
@media(max-width:520px){
  .ring{width:150px;height:150px}
  .ring .lab b{font-size:38px}
}
.statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:600px){.statrow{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.statrow{grid-template-columns:1fr}}
.stat{position:relative;background:var(--raised);border:1px solid var(--line2);border-radius:var(--r-sm);padding:18px;overflow:hidden}
.stat .si{position:absolute;top:13px;right:13px;color:var(--muted2);opacity:.5}
.stat .n{font-size:28px;font-weight:800;line-height:1;letter-spacing:-1px}
.stat .n small{font-size:14px;color:var(--muted);font-weight:600}
.stat .l{color:var(--muted);font-size:12px;margin-top:6px}

/* topic rows */
.bar{height:8px;border-radius:6px;background:var(--line);overflow:hidden}
.bar>i{display:block;height:100%;border-radius:6px;background:var(--grad)}
.toprow{display:flex;align-items:center;gap:12px;padding:11px 6px;border-radius:10px;cursor:pointer;transition:.12s}
.toprow:hover{background:var(--panel2)}
.toprow .nm{flex:1;font-size:14px;font-weight:600;min-width:0}
.toprow .nm small{display:block;color:var(--muted);font-weight:400;font-size:11.5px}
.toprow .bar{width:120px;flex:none}
.toprow .pc{width:46px;text-align:right;font-size:12.5px;color:var(--muted);font-variant-numeric:tabular-nums}
@media(max-width:520px){.toprow .bar{width:70px}}
.pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;background:var(--raised);border:1px solid var(--line);color:var(--muted)}
.pill.good{color:var(--good);border-color:color-mix(in srgb,var(--good) 40%,var(--line))}
.pill.bad{color:var(--bad);border-color:color-mix(in srgb,var(--bad) 40%,var(--line))}
.notice{display:flex;align-items:center;gap:14px}
.notice .ni{width:42px;height:42px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex:none}

/* ---------- quiz ---------- */
.qbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;color:var(--muted);font-size:13px}
.qbar b{color:var(--text)}
.progbar{height:6px;border-radius:6px;background:var(--line);overflow:hidden;margin-bottom:18px}
.progbar>i{display:block;height:100%;background:var(--grad);transition:width .3s}
.qsrc{font-size:11px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.qtext{font-size:19px;font-weight:600;margin:0 0 18px;line-height:1.45;letter-spacing:-.2px}
.opt{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:var(--raised);
  border:1.5px solid var(--line);color:var(--text);padding:14px 16px;border-radius:14px;cursor:pointer;
  font-size:15px;margin-bottom:10px;transition:.12s}
.opt:hover:not(:disabled){border-color:var(--accent);background:var(--panel2)}
.opt .key{width:28px;height:28px;border-radius:9px;background:var(--panel);border:1px solid var(--line2);
  display:grid;place-items:center;font-weight:700;font-size:13px;flex:none;transition:.12s}
.opt:disabled{cursor:default}
.opt .mk{margin-left:auto;display:grid;place-items:center}
.opt.correct{border-color:var(--good);background:color-mix(in srgb,var(--good) 13%,var(--raised))}
.opt.correct .key{background:var(--good);color:#04130d;border-color:var(--good)}
.opt.correct .mk{color:var(--good)}
.opt.wrong{border-color:var(--bad);background:color-mix(in srgb,var(--bad) 13%,var(--raised))}
.opt.wrong .key{background:var(--bad);color:#fff;border-color:var(--bad)}
.opt.wrong .mk{color:var(--bad)}
.opt.chosen{border-color:var(--accent);background:var(--accent-soft)}
.opt.chosen .key{background:var(--accent);color:#fff;border-color:var(--accent)}

.explain{border-radius:14px;padding:16px;margin-top:8px;border:1px solid var(--line);
  border-left-width:4px;background:var(--panel2);animation:rise .25s ease}
.explain.ok{border-left-color:var(--good)} .explain.no{border-left-color:var(--bad)}
.explain .eh{font-weight:800;margin-bottom:6px;display:flex;align-items:center;gap:8px;font-size:15px}
.explain.ok .eh{color:var(--good)} .explain.no .eh{color:var(--bad)}
.explain .ca{font-size:13px;margin-bottom:6px}
.explain .rule{margin-top:12px;font-size:13px;color:var(--muted);border-top:1px dashed var(--line2);padding-top:11px}
.explain .rule b{color:var(--text)} .explain .rule b[style]{color:var(--accent2)!important}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- result ---------- */
.result{text-align:center;padding:6px 0}
.result .score{font-size:56px;font-weight:800;line-height:1;letter-spacing:-2px;margin-top:8px}
.verdict{display:inline-flex;align-items:center;gap:7px;margin-top:10px;padding:7px 18px;border-radius:999px;font-weight:800;font-size:14px}
.verdict.pass{background:color-mix(in srgb,var(--good) 16%,transparent);color:var(--good)}
.verdict.fail{background:color-mix(in srgb,var(--bad) 16%,transparent);color:var(--bad)}
.reviewq{border:1px solid var(--line);border-radius:13px;padding:14px 16px;margin-bottom:10px;background:var(--panel)}
.reviewq .q{font-weight:600;margin-bottom:7px}
.reviewq .ln{font-size:13.5px;margin:3px 0;display:flex;gap:7px;align-items:flex-start}
.reviewq .ln svg{flex:none;margin-top:3px}
.your{color:var(--bad)} .corr{color:var(--good)}
.tag{font-size:11px;color:var(--muted);background:var(--raised);border:1px solid var(--line);padding:2px 9px;border-radius:7px;white-space:nowrap}
details summary{cursor:pointer;padding:8px;color:var(--muted);font-size:13px}

/* ---------- lessons ---------- */
.lesson{border:1px solid var(--line);border-radius:14px;margin-bottom:11px;overflow:hidden;background:var(--panel)}
.lesson>button{width:100%;text-align:left;background:none;border:0;color:var(--text);padding:15px 17px;
  font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:11px}
.lesson>button svg:first-child{color:var(--accent)}
.lesson>button .ch{margin-left:auto;color:var(--muted2);transition:.2s}
.lesson.open>button .ch{transform:rotate(90deg)}
.lesson .body{padding:0 17px 17px;font-size:14px;display:none;line-height:1.6}
.lesson.open .body{display:block;animation:rise .2s}
.lesson .body b{color:var(--accent2)}

/* ---------- tips & tricks ---------- */
ol.golden{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:11px}
ol.golden li{font-size:14px;line-height:1.55;padding-left:4px}
ol.golden li::marker{color:var(--accent);font-weight:700}
ol.golden b{color:var(--text)}
.tipspot{background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 28%,var(--line));border-radius:11px;padding:11px 13px;font-size:13.5px;line-height:1.5}
.tipspot b{color:var(--accent2)}
ul.tiplist{margin:12px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:7px}
ul.tiplist li{font-size:13.5px;line-height:1.55}
ul.tiplist li::marker{color:var(--accent)}
ul.tiplist b{color:var(--accent2)}
.tiptrap{margin-top:12px;font-size:13px;line-height:1.5;color:var(--muted);border-top:1px dashed var(--line2);padding-top:10px}
.tiptrap b{color:var(--warn)}

/* interactive decoder */
.dechead{display:flex;align-items:center;gap:9px;font-size:14px;margin-bottom:14px}
.dechead svg{color:var(--accent)}
.decsent{font-size:18px;font-weight:600;line-height:1.5;margin-bottom:16px;letter-spacing:-.2px}
mark.clue{background:linear-gradient(transparent 52%,color-mix(in srgb,var(--accent2) 48%,transparent) 0);color:var(--text);padding:0 2px;border-radius:3px;font-weight:700}
.decpanel{background:var(--panel2);border:1px solid var(--line);border-radius:13px;padding:15px;animation:rise .25s}
.decrow{display:flex;align-items:baseline;gap:12px;margin-bottom:9px}
.declabel{flex:none;width:60px;font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted2);font-weight:700}
.decclue{font-weight:600}
.decrule{color:var(--accent2);font-weight:700}
.decans{color:var(--good);font-weight:700}
.decwhy{font-size:13px;line-height:1.55;color:var(--muted);border-top:1px dashed var(--line2);padding-top:11px;margin-top:3px}

/* ---------- modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;display:grid;place-items:center;padding:20px;animation:fadeoverlay .15s}
@keyframes fadeoverlay{from{opacity:0}to{opacity:1}}
.modal-card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:24px;width:100%;max-width:340px;box-shadow:var(--shadow);animation:rise .2s}
.modal-h{margin:0 0 8px;font-size:17px;font-weight:700;letter-spacing:-.2px}
.modal-sub{margin:0 0 16px;font-size:13.5px;color:var(--muted);line-height:1.55}
.modal-name{color:var(--accent)}
.modal-inp{width:100%;background:var(--raised);border:1.5px solid var(--line2);border-radius:11px;color:var(--text);padding:11px 14px;font-size:15px;outline:none;transition:.15s;font-family:inherit}
.modal-inp:focus{border-color:var(--accent)}
.modal-delbtn{background:var(--bad)!important;border-color:var(--bad)!important;color:#fff!important}
.modal-delbtn:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* ---------- profile menu ---------- */
.profbtn{font-size:12px!important;font-weight:800!important;letter-spacing:-.3px;background:var(--grad)!important;color:#fff!important;border-color:transparent!important}
.pmenu{position:fixed;background:var(--panel);border:1px solid var(--line2);border-radius:14px;padding:8px;min-width:190px;box-shadow:var(--shadow);z-index:200;animation:rise .15s}
.pmenu-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted2);padding:4px 8px 8px}
.pmenu-row{display:flex;align-items:center;justify-content:space-between;padding:7px 9px;border-radius:9px;cursor:pointer;font-size:14px;font-weight:600;transition:.12s}
.pmenu-row:hover{background:var(--panel2)}
.pmenu-row.active{color:var(--accent);background:var(--accent-soft)}
.pmenu-name{flex:1}
.pmenu-chk{color:var(--accent);display:grid;place-items:center}
.pmenu-del{background:none;border:0;color:var(--muted2);cursor:pointer;padding:2px;display:grid;place-items:center;border-radius:6px;transition:.12s}
.pmenu-del:hover{color:var(--bad);background:color-mix(in srgb,var(--bad) 12%,transparent)}
.pmenu-sep{border-top:1px solid var(--line);margin:6px 0}
.pmenu-act{width:100%;text-align:left;background:none;border:0;color:var(--muted);padding:7px 9px;border-radius:9px;cursor:pointer;font-size:13.5px;font-weight:600;transition:.12s;display:block}
.pmenu-act:hover{background:var(--panel2);color:var(--text)}

/* ---------- lesson progress badge ---------- */
.lbadge{font-size:11.5px;font-weight:700;margin-left:auto;margin-right:4px;letter-spacing:.2px}

/* ---------- flashcards ---------- */
.deckpick{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
@media(max-width:600px){
  .deckpick{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}
  .deckpick::-webkit-scrollbar{display:none}
  .deckpick .chip{flex:none}
}
.chip{padding:9px 15px;border-radius:999px;border:1px solid var(--line2);background:var(--raised);
  cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);transition:.15s}
.chip:hover{color:var(--text)}
.chip.active{background:var(--grad);color:#fff;border:0}
.flash{perspective:1400px;height:210px;cursor:pointer;margin:6px 0 16px}
.flash .inner{position:relative;width:100%;height:100%;transition:transform .5s cubic-bezier(.4,.1,.2,1);transform-style:preserve-3d}
.flash.flipped .inner{transform:rotateY(180deg)}
.flash .face{position:absolute;inset:0;backface-visibility:hidden;border-radius:var(--r);border:1px solid var(--line2);
  display:grid;place-items:center;padding:28px;text-align:center;background:var(--panel);
  overflow-wrap:break-word;word-break:break-word;line-height:1.3}
.flash .front{font-size:27px;font-weight:800;letter-spacing:-.5px;padding-bottom:48px}
.flash .front::after{content:"tap to flip";position:absolute;bottom:14px;font-size:11px;font-weight:500;color:var(--muted2);letter-spacing:.5px}
.flash .back{transform:rotateY(180deg);font-size:22px;font-weight:700;background:var(--grad);color:#fff;border:0}
.fc-progress{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.fc-prog-bar{flex:1;height:6px;border-radius:99px;background:var(--line2);overflow:hidden}
.fc-prog-fill{height:100%;background:var(--good);border-radius:99px;transition:width .4s}
.fc-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.fc-judgebar{gap:10px;margin-top:0}
.fc-judgebar .btn{flex:1;justify-content:center}
.fc-notyetbtn{border-color:var(--line2)}
.fc-notyetbtn.active{background:color-mix(in srgb,var(--bad) 15%,transparent);border-color:var(--bad);color:var(--bad)}
.fc-gotitbtn{border-color:var(--line2)}
.fc-gotitbtn.active{background:color-mix(in srgb,var(--good) 15%,transparent);border-color:var(--good);color:var(--good)}

/* ---------- empty / misc ---------- */
.empty{text-align:center;color:var(--muted);padding:38px 14px}
.empty .ei{color:var(--muted2);margin-bottom:12px;opacity:.7}
.empty svg{width:38px;height:38px}
.empty b{color:var(--text);display:block;font-size:15px;margin-bottom:6px}
hr.sep{border:0;border-top:1px solid var(--line);margin:18px 0}
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);background:var(--panel);
  border:1px solid var(--line2);color:var(--text);padding:11px 19px;border-radius:12px;
  box-shadow:var(--shadow);z-index:60;font-size:13px;font-weight:600;animation:rise .2s}

/* ---------- bottom tab bar (mobile) ---------- */
.tabbar{display:none}
@media(max-width:400px){
  .app{padding:16px 12px 96px}
  .card{padding:16px}
  .stat .n{font-size:24px}
}
@media(max-width:1000px){
  .topnav{display:none}
  .brand p{display:none}
  .brand{margin-right:auto}
  .app{padding-bottom:96px}
  .tabbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:40;
    background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(12px);
    border-top:1px solid var(--line);padding:7px 6px;justify-content:space-around}
  .tabbar button{flex:1;background:none;border:0;color:var(--muted);cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10.5px;font-weight:600;padding:5px 2px;border-radius:12px}
  .tabbar button svg{width:21px;height:21px}
  .tabbar button.active{color:var(--accent)}
}
