:root{
  --bg:#0f1623; --panel:#172234; --panel2:#1e2c42; --line:#2a3a55;
  --text:#e8eef7; --muted:#9fb0c8; --accent:#3b82f6; --accent2:#2563eb;
  --green:#22c55e; --green-bg:#14361f; --red:#ef4444; --red-bg:#3a1717;
  --amber:#f59e0b; --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(180deg,#0b1220,#0f1623 240px);
  color:var(--text); line-height:1.55; min-height:100vh;
  display:flex; flex-direction:column;
}
.wrap{width:100%;max-width:920px;margin:0 auto;padding:0 18px}
a{color:var(--accent)}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(15,22,35,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:18px;height:60px}
.brand{font-weight:800;font-size:1.25rem;text-decoration:none;color:var(--text)}
.brand span{color:var(--accent)}
nav{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}
nav a{padding:8px 12px;border-radius:9px;text-decoration:none;color:var(--muted);font-weight:600;font-size:.92rem}
nav a:hover{background:var(--panel2);color:var(--text)}
nav a.active{background:var(--accent);color:#fff}
#navToggle{display:none;margin-left:auto;background:var(--panel2);color:var(--text);border:1px solid var(--line);border-radius:9px;font-size:1.2rem;padding:6px 12px;cursor:pointer}

main{flex:1;padding:30px 0 60px}

/* generic */
h1{font-size:1.9rem;margin-bottom:6px}
h2{font-size:1.35rem;margin:0 0 14px}
.muted{color:var(--muted)}
.lead{color:var(--muted);margin-bottom:26px;font-size:1.05rem}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.grid{display:grid;gap:16px}
.grid.cols2{grid-template-columns:repeat(2,1fr)}
.grid.cols3{grid-template-columns:repeat(3,1fr)}
.grid.cols4{grid-template-columns:repeat(4,1fr)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:none;border-radius:11px;
  padding:12px 20px;font-size:1rem;font-weight:700;cursor:pointer;text-decoration:none;transition:.15s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:var(--panel2);color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent)}
.btn-block{width:100%}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* home tiles */
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
.tile{display:block;text-decoration:none;color:var(--text);background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;transition:.15s;cursor:pointer}
.tile:hover{transform:translateY(-3px);border-color:var(--accent)}
.tile .ico{font-size:2rem}
.tile h3{margin:10px 0 4px;font-size:1.15rem}
.tile p{color:var(--muted);font-size:.92rem}

.stat-row{display:flex;gap:14px;flex-wrap:wrap;margin:18px 0 4px}
.stat{flex:1;min-width:120px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;text-align:center}
.stat .num{font-size:1.8rem;font-weight:800;color:var(--accent)}
.stat .lbl{color:var(--muted);font-size:.85rem}

/* category list */
.cat-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.cat{display:flex;justify-content:space-between;align-items:center;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;cursor:pointer;transition:.15s}
.cat:hover{border-color:var(--accent);background:var(--panel2)}
.cat .meta{font-size:.82rem;color:var(--muted)}
.cat .nm{font-weight:700}
.bar{height:6px;background:var(--panel2);border-radius:4px;overflow:hidden;margin-top:6px}
.bar>span{display:block;height:100%;background:var(--green)}

/* quiz */
.quiz-top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.progress-line{height:8px;background:var(--panel2);border-radius:5px;overflow:hidden;margin-bottom:20px}
.progress-line>span{display:block;height:100%;background:var(--accent);transition:width .3s}
.timer{font-variant-numeric:tabular-nums;font-weight:800;background:var(--panel2);border:1px solid var(--line);padding:6px 12px;border-radius:9px}
.timer.warn{color:var(--amber);border-color:var(--amber)}
.timer.danger{color:var(--red);border-color:var(--red)}
.qcount{font-weight:700;color:var(--muted)}
.qtext{font-size:1.25rem;font-weight:700;margin:6px 0 20px}
.cat-tag{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);
  background:rgba(59,130,246,.12);padding:3px 9px;border-radius:20px;margin-bottom:12px;font-weight:700}
.options{display:grid;gap:12px}
.opt{display:flex;gap:12px;align-items:flex-start;background:var(--panel2);border:2px solid var(--line);
  border-radius:12px;padding:14px 16px;cursor:pointer;transition:.12s;text-align:left;font-size:1rem;color:var(--text)}
.opt:hover{border-color:var(--accent)}
.opt .key{font-weight:800;background:var(--panel);border:1px solid var(--line);border-radius:7px;
  width:30px;height:30px;display:grid;place-items:center;flex:none}
.opt.selected{border-color:var(--accent);background:rgba(59,130,246,.12)}
.opt.correct{border-color:var(--green);background:var(--green-bg)}
.opt.wrong{border-color:var(--red);background:var(--red-bg)}
.opt[disabled]{cursor:default}
.explain{margin-top:16px;padding:14px 16px;border-radius:12px;background:var(--panel2);border-left:4px solid var(--accent)}
.explain.ok{border-left-color:var(--green)}
.explain.no{border-left-color:var(--red)}
.explain b{display:block;margin-bottom:4px}
.quiz-nav{display:flex;justify-content:space-between;gap:12px;margin-top:22px}

/* result */
.score-ring{width:160px;height:160px;border-radius:50%;display:grid;place-items:center;margin:10px auto 20px;
  background:conic-gradient(var(--ring) calc(var(--pct)*1%),var(--panel2) 0)}
.score-ring .inner{width:128px;height:128px;border-radius:50%;background:var(--panel);display:grid;place-items:center;text-align:center}
.score-ring .pct{font-size:2rem;font-weight:800}
.verdict{text-align:center;font-size:1.5rem;font-weight:800;margin-bottom:6px}
.verdict.pass{color:var(--green)}
.verdict.fail{color:var(--red)}
.review-item{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:12px;background:var(--panel)}
.review-item.r-ok{border-left:4px solid var(--green)}
.review-item.r-no{border-left:4px solid var(--red)}
.review-item .q{font-weight:700;margin-bottom:8px}
.review-item .a{font-size:.92rem;margin:2px 0}
.review-item .a.yours{color:var(--red)}
.review-item .a.right{color:var(--green)}

/* signs */
.signs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.sign-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;text-align:center}
.sign-card svg{width:84px;height:84px}
.sign-card .nm{font-weight:700;margin-top:8px;font-size:.9rem}
.sign-card .ds{color:var(--muted);font-size:.78rem;margin-top:3px}
.sign-section h2{margin-top:30px;border-bottom:1px solid var(--line);padding-bottom:8px}

.empty{text-align:center;color:var(--muted);padding:40px}
.spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

footer{border-top:1px solid var(--line);padding:24px 0;color:var(--muted);font-size:.85rem}
footer p{margin:4px 0}
footer a{color:var(--accent)}

@media(max-width:720px){
  nav{position:fixed;top:60px;left:0;right:0;background:var(--panel);flex-direction:column;gap:0;padding:8px;
    border-bottom:1px solid var(--line);display:none}
  nav.open{display:flex}
  nav a{padding:12px}
  #navToggle{display:block}
  .tiles,.cat-list,.grid.cols2,.grid.cols3,.grid.cols4{grid-template-columns:1fr}
  .qtext{font-size:1.1rem}
}
