/* * BELAJAR SERU ANAK ISLAM - Gaya Tampilan
 * Copyright (c) 2024-2026 Luqmanulhakim.net - 087770010006
 * All rights reserved.
 */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Fredoka+One&display=swap');

:root {
  --bg:      #FFFBF2;
  --white:   #FFFFFF;
  --primary: #FF6B35;
  --prim2:   #FFB347;
  --green:   #22C55E;
  --green2:  #16A34A;
  --teal:    #0EA5E9;
  --gold:    #F59E0B;
  --gold2:   #D97706;
  --purple:  #A855F7;
  --red:     #EF4444;
  --text:    #1E1B18;
  --muted:   #6B7280;
  --border:  #E5E7EB;
  --r:       16px;
  --r-sm:    10px;
  --sh:      0 4px 20px rgba(0,0,0,.09);
  --sh-lg:   0 12px 40px rgba(0,0,0,.18);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Nunito',sans-serif; background:var(--bg); color:var(--text); min-height:100vh; overflow-x:hidden; }


/* ══ HEADER ══ */
/* yang asli diganti
header {
  background:linear-gradient(135deg,#FF6B35 0%,#FF8C42 45%,#FFB347 100%);
  padding:12px 16px 56px;
  position:relative; overflow:hidden;
}
header::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='52' height='52' viewBox='0 0 52 52' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.07'%3E%3Cpath d='M30 28v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-26V0h-2v2h-4v2h4v2h2V4h4V2h-4zM4 28v-4H2v4H0v2h2v4h2v-4h4v-2H4zM4 2V0H2v2H0v2h2v2h2V4h4V2H4z'/%3E%3C/g%3E%3C/svg%3E");
}
sampai sini*/

/* ===HEADER (ORANYE + LOGO WATERMARK TENGAH) ══ */
header {
  /* Logo ditaruh di tengah (center), ukuran besar (280px) */
  background: 
    url('../assets/img/logo-sekolah.png') no-repeat center center / 280px, 
    linear-gradient(135deg, #FF6B35 0%, #FF8C42 45%, #FFB347 100%);
  
  /* PENTING: Membuat logo menyatu transparan agar teks tetap terbaca */
  background-blend-mode: soft-light; 
  
  padding: 12px 16px 56px;
  position: relative; 
  overflow: hidden; /* Memastikan logo yang meluber terpotong rapi */
}

/* Pattern kotak-kotak tetap ada di lapisan atas */
header::before {
  content: ''; 
  position: absolute; 
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='52' height='52' viewBox='0 0 52 52' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.07'%3E%3Cpath d='M30 28v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-26V0h-2v2h-4v2h4v2h2V4h4V2h-4zM4 28v-4H2v4H0v2h2v4h2v-4h4v-2H4zM4 2V0H2v2H0v2h2v2h2V4h4V2H4z'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 1;
}

/* Pastikan konten (teks & XP) berada di depan watermark */
.header-top {
  position: relative;
  z-index: 2;
}
/* === smpai sini ya === */

.header-top { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; position:relative; }
.header-title-wrap h1 { font-family:'Fredoka One',cursive; font-size:clamp(1.2rem,3.5vw,1.8rem); color:white; text-shadow:1px 2px 0 rgba(0,0,0,.15); line-height:1.1; }
.header-title-wrap p  { color:rgba(255,255,255,.85); font-size:.75rem; font-weight:700; margin-top:2px; }
.header-meta { display:flex; flex-direction:column; align-items:flex-end; gap:3px; flex-shrink:0; }
.hm-level  { font-size:.75rem; font-weight:800; color:white; display:flex; align-items:center; gap:3px; }
.hm-xpbar  { width:90px; height:5px; background:rgba(255,255,255,.3); border-radius:50px; overflow:hidden; }
.hm-xpfill { height:100%; background:white; border-radius:50px; transition:width .6s ease; }
.hm-score  { font-size:.72rem; font-weight:800; color:rgba(255,255,255,.9); transition:transform .2s; }
.hm-score.xp-pulse { animation:xpPulse .6s ease; }
@keyframes xpPulse { 0%{transform:scale(1)} 30%{transform:scale(1.3);color:white} 100%{transform:scale(1)} }
.hm-lb-btn { margin-top:2px; padding:4px 10px; border-radius:50px; border:1.5px solid rgba(255,255,255,.45); background:rgba(255,255,255,.15); color:white; font-size:.78rem; font-weight:800; cursor:pointer; transition:all .2s; backdrop-filter:blur(4px); }
.hm-lb-btn:hover { background:rgba(255,255,255,.3); }
#leaderboard-strip { display:flex; justify-content:center; gap:7px; margin-top:8px; flex-wrap:wrap; position:relative; }
#lb-empty { color:rgba(255,255,255,.65); font-size:.72rem; font-weight:700; font-style:italic; }
.lb-entry { background:rgba(255,255,255,.14); border:1.5px solid rgba(255,255,255,.3); border-radius:50px; padding:3px 10px; display:flex; align-items:center; gap:4px; font-size:.72rem; font-weight:800; color:white; animation:slideIn .4s ease both; }
@keyframes slideIn { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:translateY(0)} }
.wave { width:100%; margin-top:-44px; line-height:0; }
.wave svg { display:block; }

/* ══ MAIN ══ */
main { padding:0 12px 80px; max-width:800px; margin:0 auto; }

/* ══ SELECTOR BAR — dropdown modern 1 baris ══ */
#selector-bar {
  display:flex;
  align-items:center;
  gap:6px;
  background:white;
  border-radius:var(--r);
  padding:10px 12px;
  box-shadow:var(--sh);
  margin-bottom:14px;
  flex-wrap:wrap;
  position:relative;
  z-index:100;
}
.dd-sep { color:var(--border); font-size:1.1rem; font-weight:900; flex-shrink:0; user-select:none; }

/* Dropdown wrapper */
.dd-wrap { position:relative; flex-shrink:0; }

/* Dropdown trigger button */
.dd-btn {
  display:flex; align-items:center; gap:5px;
  padding:7px 12px;
  border-radius:50px;
  border:2px solid var(--border);
  background:white;
  font-family:'Nunito',sans-serif; font-size:.82rem; font-weight:800;
  cursor:pointer; transition:all .18s; white-space:nowrap; color:var(--text);
}
.dd-btn:hover     { border-color:var(--primary); background:#FFF5F2; }
.dd-wrap.open .dd-btn { border-color:var(--primary); background:var(--primary); color:white; }
.dd-icon   { font-size:.9rem; }
.dd-label  { max-width:120px; overflow:hidden; text-overflow:ellipsis; }
.dd-arrow  { font-size:.65rem; opacity:.7; transition:transform .2s; }
.dd-wrap.open .dd-arrow { transform:rotate(180deg); }

/* Dropdown menu */
.dd-menu {
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  background:white;
  border-radius:var(--r-sm);
  box-shadow:var(--sh-lg);
  border:1.5px solid var(--border);
  min-width:220px;
  width: max-content; /* Memaksa kotak keluar dari batas tombol induk */
  max-width: 90vw;    /* Supaya tidak melebihi lebar layar HP */
  z-index:200;
  overflow:hidden;
  display:none;
  animation:ddOpen .15s ease;
}
.dd-menu.open { display:block; }
@keyframes ddOpen { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

.dd-item {
  display:block; width:100%;
  padding:9px 14px;
  text-align:left;
  font-family:'Nunito',sans-serif; font-size:.85rem; font-weight:700;
  border:none; background:white; cursor:pointer;
  transition:background .12s;
  color:var(--text);
}
.dd-item:hover  { background:#FFF5F2; color:var(--primary); }
.dd-item.active { background:#FFF0EB; color:var(--primary); font-weight:900; }
.dd-item.active::before { content:'✓ '; }

/* Start button */
.dd-start-btn {
  margin-left:auto;
  padding:8px 18px;
  border-radius:50px;
  border:none;
  background:linear-gradient(135deg,var(--primary),var(--prim2));
  color:white;
  font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:800;
  cursor:pointer; transition:all .2s;
  box-shadow:0 4px 14px rgba(255,107,53,.35);
  white-space:nowrap; flex-shrink:0;
}
.dd-start-btn:hover { transform:translateY(-2px); box-shadow:0 6px 18px rgba(255,107,53,.45); }
.dd-start-btn:active { transform:scale(.97); }

/* ══ WELCOME CARD ══ */
.welcome-card {
  background:white; border-radius:var(--r); box-shadow:var(--sh);
  padding:36px 24px; text-align:center; animation:fadeUp .4s ease;
}
.wc-emoji { font-size:4rem; margin-bottom:10px; }
.wc-title { font-family:'Fredoka One',cursive; font-size:1.6rem; margin-bottom:8px; }
.wc-desc  { color:var(--muted); font-size:.9rem; font-weight:700; line-height:1.7; margin-bottom:20px; }
.wc-stats { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.wc-stats span { background:#F3F4F6; border-radius:50px; padding:7px 16px; font-size:.8rem; font-weight:800; color:var(--muted); }

/* ══ QUIZ TOPBAR ══ */
.quiz-topbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; gap:8px; flex-wrap:wrap; }
.round-indicator { display:flex; align-items:center; gap:5px; }
.round-dot { width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.68rem; font-weight:900; color:white; transition:all .3s; font-family:'Fredoka One',cursive; }
.round-dot.done    { background:var(--green); }
.round-dot.active  { background:var(--primary); box-shadow:0 0 0 3px rgba(255,107,53,.25); }
.round-dot.pending { background:#D1D5DB; }
.round-label { font-size:.75rem; font-weight:800; color:var(--muted); margin-left:4px; }
.topbar-stats { display:flex; gap:6px; align-items:center; }
.ts-pill { padding:5px 10px; border-radius:50px; font-size:.78rem; font-weight:800; background:white; box-shadow:var(--sh); }
.ts-pill.ts-correct { color:var(--green2); }
.ts-pill.ts-wrong   { color:var(--red); }
.ts-pill.ts-timer   { color:var(--teal); min-width:62px; text-align:center; }
.ts-pill.ts-timer.warn   { color:var(--gold2); }
.ts-pill.ts-timer.danger { color:var(--red); animation:blink .5s ease infinite alternate; }
@keyframes blink { from{opacity:1} to{opacity:.3} }

/* ══ QUIZ CARD ══ */
.quiz-card { background:white; border-radius:var(--r); box-shadow:var(--sh); padding:18px; margin-bottom:14px; animation:fadeUp .3s ease; }
@keyframes fadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.quiz-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; flex-wrap:wrap; gap:5px; }
.quiz-meta { display:flex; gap:4px; align-items:center; flex-wrap:wrap; }
.badge { padding:4px 10px; border-radius:50px; font-size:.7rem; font-weight:800; display:inline-flex; align-items:center; }
.badge.mat-badge   { background:#FFF0EB; color:#FF6B35; }
.badge.bind-badge  { background:#EFF9FF; color:#0EA5E9; }
.badge.ipas-badge  { background:#F0FFF4; color:#22C55E; }
.badge.mix-badge   { background:#FDF4FF; color:#A855F7; }
.badge.class-badge { background:#F3F0FF; color:#7C3AED; }
.badge.chap-badge  { background:#ECFDF5; color:#059669; }
.score-display { font-family:'Fredoka One',cursive; font-size:.9rem; background:#F8F9FA; padding:5px 12px; border-radius:50px; white-space:nowrap; }
.progress-bar-wrap { background:#F0F2F5; border-radius:50px; height:6px; margin-bottom:12px; overflow:hidden; }
.progress-bar-fill { height:100%; border-radius:50px; background:linear-gradient(90deg,var(--primary),var(--prim2)); transition:width .4s ease; }
.question-num  { font-size:.72rem; color:var(--muted); font-weight:700; margin-bottom:4px; }
.question-text { font-size:1.05rem; font-weight:800; color:var(--text); margin-bottom:14px; line-height:1.55; }
.question-img  { width:100%; max-width:360px; border-radius:var(--r-sm); margin-bottom:12px; }

/* Options */
.options { display:flex; flex-direction:column; gap:6px; }
.option-btn { padding:10px 13px; border-radius:var(--r-sm); border:2px solid #F0F2F5; background:#FAFBFC; font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:700; text-align:left; cursor:pointer; transition:all .15s; display:flex; align-items:center; gap:8px; }
.option-btn:hover:not(:disabled) { border-color:var(--primary); background:#FFF5F2; transform:translateX(3px); }
.option-btn.correct { border-color:var(--green); background:#F0FFF4; color:#166534; }
.option-btn.wrong   { border-color:var(--red);   background:#FFF5F5; color:#991B1B; }
.option-btn.reveal  { border-color:var(--green);  background:#F0FFF4; color:#166534; opacity:.75; }
.option-btn:disabled { cursor:default; }
.option-letter { width:28px; height:28px; border-radius:50%; background:#F0F2F5; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:.8rem; flex-shrink:0; transition:all .15s; }
.option-btn.correct .option-letter { background:var(--green); color:white; }
.option-btn.wrong   .option-letter { background:var(--red);   color:white; }
.option-btn.reveal  .option-letter { background:var(--green); color:white; }

/* Feedback */
.feedback { margin-top:12px; padding:11px 14px; border-radius:var(--r-sm); font-weight:700; display:none; align-items:center; gap:7px; font-size:.85rem; line-height:1.4; }
.feedback.show      { display:flex; animation:feedbackPop .25s ease; }
.feedback.correct-fb { background:#F0FFF4; color:#166534; border:2px solid var(--green); }
.feedback.wrong-fb   { background:#FFF5F5; color:#991B1B; border:2px solid var(--red); }
@keyframes feedbackPop { 0%{transform:scale(.88);opacity:0} 70%{transform:scale(1.02)} 100%{transform:scale(1);opacity:1} }

.btn-next { margin-top:12px; padding:11px 24px; border-radius:50px; border:none; background:linear-gradient(135deg,var(--primary),var(--prim2)); color:white; font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:800; cursor:pointer; transition:all .2s; box-shadow:0 4px 14px rgba(255,107,53,.35); display:none; }
.btn-next.show { display:inline-flex; align-items:center; gap:5px; }
.btn-next:hover { transform:translateY(-2px); }

/* ══ ROUND RESULT ══ */
.round-result { background:white; border-radius:var(--r); box-shadow:var(--sh); padding:22px 18px; text-align:center; animation:fadeUp .35s ease; }
.rr-emoji  { font-size:3rem; margin-bottom:6px; }
.rr-title  { font-family:'Fredoka One',cursive; font-size:1.4rem; margin-bottom:4px; }
.rr-score  { font-family:'Fredoka One',cursive; font-size:1.8rem; color:var(--primary); margin-bottom:5px; }
.rr-msg    { font-size:.85rem; color:var(--muted); font-weight:700; margin-bottom:14px; }
.rr-review { text-align:left; max-height:220px; overflow-y:auto; border:1.5px solid var(--border); border-radius:var(--r-sm); padding:8px; margin-bottom:14px; }
.rr-review::-webkit-scrollbar { width:3px; }
.rr-review::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
.rr-item { display:flex; gap:6px; padding:5px 7px; border-radius:7px; margin-bottom:4px; font-size:.78rem; font-weight:700; align-items:flex-start; }
.rr-item.ri-ok   { background:#F0FFF4; }
.rr-item.ri-fail { background:#FFF5F5; }
.rr-icon { flex-shrink:0; }
.rr-body { flex:1; }
.rr-q    { color:var(--text); line-height:1.3; }
.rr-ans  { margin-top:2px; font-size:.73rem; }
.rr-ans-ok   { color:var(--green2); }
.rr-ans-fail { color:var(--red); }
.rr-actions { display:flex; gap:7px; flex-wrap:wrap; justify-content:center; }
.rr-btn { padding:10px 16px; border-radius:50px; border:none; font-family:'Nunito',sans-serif; font-size:.82rem; font-weight:800; cursor:pointer; transition:all .2s; display:flex; align-items:center; gap:4px; }
.rr-repeat { background:#EFF9FF; color:var(--teal); border:2px solid #BAE6FD; }
.rr-repeat:hover { background:var(--teal); color:white; }
.rr-save   { background:#FFFBEB; color:var(--gold2); border:2px solid #FDE68A; }
.rr-save:hover { background:var(--gold2); color:white; }
.rr-next   { background:linear-gradient(135deg,var(--primary),var(--prim2)); color:white; box-shadow:0 4px 12px rgba(255,107,53,.35); }
.rr-next:hover { transform:translateY(-2px); }

/* ══ FINAL RESULT ══ */
.result-screen { background:white; border-radius:var(--r); box-shadow:var(--sh); padding:26px 18px; text-align:center; animation:fadeUp .4s ease; }
.result-emoji  { font-size:3.5rem; margin-bottom:8px; }
.result-title  { font-family:'Fredoka One',cursive; font-size:1.7rem; margin-bottom:4px; }
.result-score  { font-family:'Fredoka One',cursive; font-size:2.8rem; margin:8px 0; }
.result-score.great { color:var(--green); }
.result-score.good  { color:var(--gold2); }
.result-score.low   { color:var(--red); }
.result-msg { font-size:.88rem; color:#555; font-weight:700; margin-bottom:12px; }
.xp-gained { font-family:'Fredoka One',cursive; font-size:.95rem; color:var(--gold2); background:#FFFBEB; border:2px solid #FDE68A; padding:6px 16px; border-radius:50px; display:inline-block; margin-bottom:16px; animation:bounceIn .5s ease; }
@keyframes bounceIn { 0%{transform:scale(.5);opacity:0} 80%{transform:scale(1.1)} 100%{transform:scale(1);opacity:1} }
.result-stats { display:flex; gap:7px; flex-wrap:wrap; justify-content:center; margin-bottom:16px; }
.result-stat-card { background:#F9FAFB; border-radius:var(--r-sm); padding:9px 14px; min-width:76px; }
.result-stat-card .rs-num { font-family:'Fredoka One',cursive; font-size:1.5rem; }
.result-stat-card .rs-lbl { font-size:.68rem; color:var(--muted); font-weight:700; }
.rs-correct .rs-num { color:var(--green); }
.rs-wrong   .rs-num { color:var(--red); }
.rs-time    .rs-num { color:var(--teal); }
.rs-xp      .rs-num { color:var(--gold2); }
.review-section { text-align:left; background:#F9FAFB; border-radius:var(--r-sm); padding:12px; margin-bottom:16px; }
.review-section h3 { font-family:'Fredoka One',cursive; font-size:.95rem; margin-bottom:8px; }
.review-round-header { font-family:'Fredoka One',cursive; font-size:.82rem; color:var(--primary); padding:5px 0 3px; border-bottom:2px solid var(--border); margin:8px 0 5px; }
.review-round-header:first-child { margin-top:0; }
.review-item { border-radius:7px; padding:7px 9px; margin-bottom:4px; }
.review-item.ri-correct { background:#F0FFF4; border-left:3px solid var(--green); }
.review-item.ri-wrong   { background:#FFF5F5; border-left:3px solid var(--red); }
.ri-q { font-weight:800; font-size:.8rem; color:var(--text); margin-bottom:2px; line-height:1.4; }
.ri-ans { font-size:.75rem; font-weight:700; }
.ri-correct-ans { color:var(--green2); }
.ri-wrong-ans   { color:var(--red); display:block; }
.ri-actual-ans  { color:var(--green2); display:block; }
.final-actions { display:flex; gap:7px; justify-content:center; flex-wrap:wrap; }
.btn-restart, .btn-change { padding:11px 22px; border-radius:50px; font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:800; cursor:pointer; transition:all .2s; }
.btn-restart { border:none; background:linear-gradient(135deg,var(--teal),#0284C7); color:white; box-shadow:0 4px 14px rgba(14,165,233,.4); }
.btn-restart:hover { transform:translateY(-2px); }
.btn-change  { border:2px solid var(--primary); background:white; color:var(--primary); }
.btn-change:hover { background:var(--primary); color:white; }

/* ══ MODALS ══ */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.55); backdrop-filter:blur(5px); z-index:1000; display:none; align-items:center; justify-content:center; padding:16px; }
.modal-overlay.show { display:flex; }
.modal-box { background:white; border-radius:var(--r); padding:26px 22px; max-width:370px; width:100%; box-shadow:var(--sh-lg); animation:fadeUp .3s ease; text-align:center; }
.modal-emoji { font-size:2.8rem; margin-bottom:8px; }
.modal-box h2 { font-family:'Fredoka One',cursive; font-size:1.4rem; margin-bottom:5px; }
.modal-box p  { font-size:.85rem; color:var(--muted); font-weight:700; margin-bottom:14px; line-height:1.5; }
#name-input-field, #player-name-input { width:100%; padding:11px 15px; border-radius:50px; border:2px solid var(--border); font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:700; outline:none; margin-bottom:11px; text-align:center; }
#name-input-field:focus, #player-name-input:focus { border-color:var(--primary); }
.modal-actions { display:flex; flex-direction:column; gap:7px; }
.modal-btn-primary { padding:12px; border-radius:50px; border:none; background:linear-gradient(135deg,var(--primary),var(--prim2)); color:white; font-family:'Nunito',sans-serif; font-size:.95rem; font-weight:800; cursor:pointer; box-shadow:0 4px 14px rgba(255,107,53,.4); transition:all .2s; }
.modal-btn-primary:hover { transform:translateY(-2px); }
.modal-btn-skip { padding:9px; border-radius:50px; border:2px solid var(--border); background:white; font-family:'Nunito',sans-serif; font-size:.85rem; font-weight:800; cursor:pointer; color:var(--muted); transition:all .2s; }
.lb-subtitle { margin-bottom:12px !important; }
#lb-list { text-align:left; margin-bottom:12px; }
.lb-row { display:flex; align-items:center; gap:9px; padding:8px 10px; border-radius:var(--r-sm); margin-bottom:4px; background:#F9FAFB; }
.lb-row.lb-me { background:#FFF0EB; border:2px solid #FDBA74; }
.lb-r  { font-family:'Fredoka One',cursive; font-size:.95rem; width:22px; text-align:center; }
.lb-n  { flex:1; font-weight:800; font-size:.85rem; }
.lb-lv { font-size:.7rem; color:var(--muted); font-weight:700; }
.lb-p  { font-family:'Fredoka One',cursive; color:var(--gold2); font-size:.88rem; }
.lb-empty-msg { text-align:center; color:var(--muted); font-size:.85rem; font-weight:700; padding:14px 0; }
.lb-name-edit { border-top:2px solid var(--border); padding-top:12px; margin-bottom:9px; }
.lb-name-edit p { font-size:.8rem; font-weight:700; color:var(--muted); margin-bottom:7px; text-align:left; }
.name-input-row { display:flex; gap:6px; }
#player-name-input { margin-bottom:0; flex:1; text-align:left; }
.btn-save-name { padding:9px 14px; border-radius:50px; border:none; background:var(--primary); color:white; font-family:'Nunito',sans-serif; font-weight:800; font-size:.82rem; cursor:pointer; white-space:nowrap; transition:all .2s; flex-shrink:0; }
.btn-close-lb { width:100%; padding:10px; border-radius:50px; border:2px solid var(--border); background:white; font-family:'Nunito',sans-serif; font-weight:800; cursor:pointer; font-size:.85rem; margin-top:10px; transition:all .2s; }
.btn-close-lb:hover { background:#F3F4F6; }

footer { text-align:center; padding:14px; color:var(--muted); font-size:.75rem; font-weight:700; }

/* ══ RESPONSIVE MOBILE ══ */
@media (max-width:480px) {
  header { padding:10px 12px 52px; }
  .hm-xpbar { width:70px; }
  .header-title-wrap h1 { font-size:1.1rem; }
  main { padding:0 10px 60px; }
  #selector-bar { padding:8px 10px; gap:5px; }
  .dd-btn { padding:6px 10px; font-size:.78rem; }
  .dd-label { max-width:80px; }
  .dd-start-btn { padding:7px 14px; font-size:.82rem; }
  .question-text { font-size:.97rem; }
  .result-score  { font-size:2.2rem; }
  .rr-actions    { flex-direction:column; align-items:stretch; }
  .rr-btn        { justify-content:center; }
  .dd-menu       { min-width:150px; }
}
