/* Quiz2 — webapp styles */
:root {
  --bg: #0f0e17; --card: #1a1932; --surface: #232146; --hover: #2d2a54;
  --text: #fffffe; --dim: #a7a9be; --muted: #6c6f85;
  --accent: #e53170; --accent2: #ff6e96; --purple: #7f5af0; --green: #2cb67d;
  --blue: #58a6ff; --gold: #f2c94c;
  --border: rgba(255,255,255,0.08);
  --r: 14px; --shadow: 0 4px 20px rgba(0,0,0,0.4);
  --font: 'Nunito', -apple-system, sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%;margin:0}
body{font-family:var(--font);font-size:15px;line-height:1.5;color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:contain}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
h1,h2,h3{margin:0;font-weight:800}
a{color:var(--blue);text-decoration:none}

#app{height:100%;overflow:hidden;position:relative}
.screen{position:absolute;inset:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;
  padding:0 16px 24px;opacity:0;pointer-events:none;transition:opacity .2s}
.screen.active{opacity:1;pointer-events:auto;z-index:1}
.hidden{display:none!important}

.center-box{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;gap:12px}
.logo{font-size:72px;filter:drop-shadow(0 4px 24px rgba(229,49,112,0.5))}
.sub{color:var(--dim);font-size:14px;margin-bottom:16px}

.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;border-radius:var(--r);font-weight:700;font-size:15px;transition:transform .08s,background .15s}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-green{background:var(--green);color:#fff}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--dim)}
.btn-purple{background:var(--purple);color:#fff}

.main-hdr{padding:20px 0 8px}
.user-row{display:flex;align-items:center;gap:12px}
.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}
.uname{font-weight:700;font-size:17px}
.umeta{font-size:12px;color:var(--dim)}

.sub-hdr{display:flex;align-items:center;gap:12px;padding:16px 0 8px;position:sticky;top:0;z-index:5;background:var(--bg)}
.sub-hdr h2{font-size:18px}
.back{width:36px;height:36px;border-radius:50%;background:var(--card);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--dim);border:1px solid var(--border)}

.chips{display:flex;gap:8px;margin:6px 0 14px;flex-wrap:wrap}
.chip{background:var(--card);border:1px solid var(--border);padding:6px 14px;border-radius:20px;font-size:13px}

.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mbtn{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:22px 16px;display:flex;flex-direction:column;align-items:flex-start;gap:10px;transition:background .15s,border-color .15s}
.mbtn:hover{background:var(--hover);border-color:var(--accent)}
.mi{font-size:28px}.ml{font-weight:700;font-size:14px}

.cards{display:flex;flex-direction:column;gap:10px;padding-bottom:20px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;transition:background .15s,border-color .15s}
.card-click{cursor:pointer}
.card-click:hover{background:var(--hover);border-color:var(--accent)}
.card-head{display:flex;align-items:center;gap:12px}
.card-emoji{font-size:28px;flex-shrink:0}
.card-main{flex:1;min-width:0}
.card-title{font-weight:700;font-size:15px}
.card-desc{font-size:13px;color:var(--dim);margin-top:2px}
.card-meta{font-size:12px;color:var(--muted);margin-top:4px}
.card-chev{color:var(--muted);font-size:20px}

.quiz-info{padding:20px;text-align:center}
.qi-title{font-size:22px;font-weight:900;margin-bottom:8px}
.qi-cat{color:var(--accent);font-size:14px;margin-bottom:12px}
.qi-desc{color:var(--dim);font-size:14px;margin-bottom:20px}
.qi-stats{display:flex;justify-content:center;gap:20px;margin-bottom:24px}
.qi-stat{text-align:center}
.qi-val{font-size:20px;font-weight:800}
.qi-lbl{font-size:11px;color:var(--muted)}
.qi-actions{display:flex;gap:10px;justify-content:center}

.q-counter{font-size:13px;color:var(--muted);margin-bottom:12px;text-align:center}
.q-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px}
.q-text{font-weight:700;font-size:16px;margin-bottom:16px;text-align:center}
.q-opt{display:block;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;margin-bottom:8px;font-size:14px;text-align:left;transition:background .15s,border-color .15s}
.q-opt:hover{background:var(--hover);border-color:var(--accent)}
.q-opt.correct{border-color:var(--green);background:rgba(44,182,125,.12)}
.q-opt.wrong{border-color:var(--accent);background:rgba(229,49,112,.12)}
.q-opt.off{pointer-events:none}
.q-explain{margin-top:10px;padding:10px;background:rgba(88,166,255,.08);border-radius:8px;font-size:13px;color:var(--dim)}

.res-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:28px;text-align:center}
.res-pct{font-size:56px;font-weight:900;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.res-sub{font-size:14px;color:var(--dim);margin-top:4px}
.res-details{margin-top:20px}
.res-btns{display:flex;gap:10px;justify-content:center;margin-top:20px}

.st-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.st-item{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px}
.st-val{font-size:24px;font-weight:800;color:var(--accent)}
.st-lbl{font-size:12px;color:var(--dim);margin-top:4px}

.ach-card{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:8px}
.ach-card.locked{opacity:.35}
.ach-e{font-size:28px}
.ach-n{font-weight:700;font-size:14px}
.ach-d{font-size:12px;color:var(--dim)}

.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:10px 20px;border-radius:20px;font-weight:700;font-size:14px;z-index:99;opacity:0;transition:opacity .3s}

.inp{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color .15s}
.inp:focus{border-color:var(--accent)}
.inp.big{font-size:17px;font-weight:700;padding:12px 14px}
select.inp{appearance:none;cursor:pointer}
.btn-sm{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px 10px;font-size:12px;color:var(--dim);cursor:pointer}
.btn-sm:hover{border-color:var(--accent);color:var(--accent)}
