
:root{
  --bg0:#071020;
  --bg1:#0b1a33;
  --card:rgba(255,255,255,0.06);
  --card2:rgba(255,255,255,0.09);
  --stroke:rgba(255,255,255,0.14);
  --text:#f3f6ff;
  --muted:rgba(243,246,255,0.75);

  /* VBS energy accents */
  --a1:#7c3aed;   /* purple */
  --a2:#22c55e;   /* green */
  --a3:#06b6d4;   /* cyan */
  --a4:#f59e0b;   /* amber */
  --shadow: 0 18px 50px rgba(0,0,0,0.40);
  --r: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  font-family: ui-rounded, system-ui, -apple-system, "Trebuchet MS", "Segoe UI", Arial, sans-serif;
  font-size:18px;
  line-height:1.35;
  background:
    radial-gradient(900px 500px at 10% 10%, rgba(124,58,237,0.30), transparent 60%),
    radial-gradient(800px 520px at 95% 20%, rgba(34,197,94,0.24), transparent 60%),
    radial-gradient(650px 460px at 70% 95%, rgba(6,182,212,0.20), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x:hidden;
}

/* subtle confetti dots */
body:before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  opacity:.22;
  background-image:
    radial-gradient(circle at 12px 12px, rgba(255,255,255,0.22) 2px, transparent 3px),
    radial-gradient(circle at 18px 22px, rgba(245,158,11,0.22) 2px, transparent 3px),
    radial-gradient(circle at 28px 10px, rgba(34,197,94,0.20) 2px, transparent 3px),
    radial-gradient(circle at 8px 28px, rgba(6,182,212,0.18) 2px, transparent 3px);
  background-size: 60px 60px;
  filter: blur(0.1px);
}

.container{max-width:1100px;margin:0 auto;padding:22px}

.topbar{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-bottom:16px;
}
.brand{display:flex; align-items:center; gap:10px}
.brandIcon{font-size:26px}
.brandText{font-size:22px; font-weight:900; letter-spacing:.2px}
.topnav{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end}

.card{
  background:var(--card);
  border:1px solid var(--stroke);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding:18px;
}
.card-hero{padding:20px}

label{
  display:block;
  font-size:14px;
  letter-spacing:.25px;
  text-transform:uppercase;
  color:rgba(243,246,255,0.78);
  margin-bottom:6px;
}

input, select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(0,0,0,0.18);
  color:var(--text);
  outline:none;
}
input:focus, select:focus{
  border-color: rgba(124,58,237,0.75);
  box-shadow: 0 0 0 4px rgba(124,58,237,0.18);
}
.input-lg{font-size:18px; padding:14px 14px}

.helper{font-size:14px; color:var(--muted); margin-top:6px}
.fineprint{font-size:13px; color:rgba(243,246,255,0.70); margin-top:14px}

.grid2{display:grid; grid-template-columns: 1.2fr 1fr; gap:16px}
@media (max-width: 860px){
  .grid2{grid-template-columns:1fr}
}

.sectionTitle{
  margin:16px 0 10px;
  font-size:20px;
  font-weight:900;
}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.06);
  color:var(--text);
  text-decoration:none;
  cursor:pointer;
  user-select:none;
  transition: transform .08s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform: translateY(-1px); background:rgba(255,255,255,0.10)}
.btn:active{transform: translateY(0px) scale(0.99)}
.btn-ghost{background:rgba(255,255,255,0.06)}
.btn-primary{
  border:none;
  background: linear-gradient(90deg, var(--a1), var(--a3), var(--a2));
  box-shadow: 0 12px 30px rgba(124,58,237,0.28);
  font-weight:900;
}
.btn-primary:hover{filter:saturate(1.1) brightness(1.05)}
.btn-big{font-size:18px; padding:14px 18px; min-width:180px}

.modeGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
@media (max-width: 860px){
  .modeGrid{grid-template-columns:1fr}
}
.modeCard{
  text-align:left;
  padding:16px;
  border-radius:16px;
  border:2px solid rgba(255,255,255,0.14);
  background:
    radial-gradient(550px 240px at 10% 10%, rgba(124,58,237,0.20), transparent 55%),
    radial-gradient(420px 220px at 90% 10%, rgba(245,158,11,0.14), transparent 55%),
    rgba(255,255,255,0.04);
  cursor:pointer;
  color:var(--text);
  transition: transform .10s ease, border-color .18s ease, box-shadow .18s ease;
}
.modeCard:hover{
  transform: translateY(-1px);
  border-color: rgba(6,182,212,0.55);
  box-shadow: 0 14px 35px rgba(0,0,0,0.35);
}
.modeCard.selected{
  border-color: rgba(34,197,94,0.85);
  box-shadow: 0 18px 42px rgba(34,197,94,0.10), 0 18px 42px rgba(124,58,237,0.10);
}
.modeBadge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.25px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(34,197,94,0.16);
  border:1px solid rgba(34,197,94,0.30);
}
.modeBadge.alt{
  background: rgba(245,158,11,0.16);
  border-color: rgba(245,158,11,0.30);
}
.modeTitle{font-size:22px; font-weight:950; margin:10px 0 6px}
.modeDesc{color:rgba(243,246,255,0.82); font-size:15px}
.modeBullets{margin:10px 0 0; padding-left:18px; color:rgba(243,246,255,0.84); font-size:14px}
.modeBullets li{margin:4px 0}

.rulesStrip{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}
.rulePill{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.16);
  font-size:14px;
}

.disclaimer{
  margin-top:12px;
  padding:12px 14px;
  border-radius:14px;
  background: rgba(245,158,11,0.12);
  border:1px solid rgba(245,158,11,0.20);
}
.checkRow{display:flex; gap:10px; align-items:flex-start; font-size:14px; color:rgba(243,246,255,0.90)}
.checkRow input{width:auto; margin-top:2px}

.footerRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:14px;
  flex-wrap:wrap;
}

/* Result page action buttons */
.resultActions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
}
.resultActionsSecondary {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
.statusText{font-size:14px; color:rgba(243,246,255,0.80)}

/* Table styles (leaderboards) */
.lbControls{
  display:grid;
  grid-template-columns: 1.2fr 1fr 0.7fr;
  gap:14px;
  align-items:start;
}
.lbControls--2col{
  grid-template-columns: 1fr 0.7fr;
}
@media (max-width: 860px){
  .lbControls, .lbControls--2col{grid-template-columns:1fr}
}

/* Season value — large centered text in practice leaderboard */
.seasonVal{
  font-size:26px;
  font-weight:900;
  padding:10px 0 4px;
  letter-spacing:1px;
}

/* Read-only leaderboard control cell (e.g. "All Categories" on daily) */
.lbFixed{
  color: var(--muted);
  cursor: default;
  pointer-events: none;
  user-select: none;
}
.tableWrap{margin-top:10px; overflow:auto; border-radius:14px; border:1px solid rgba(255,255,255,0.12)}
table{width:100%; border-collapse:collapse; min-width:680px; background:rgba(0,0,0,0.14)}
th,td{padding:12px 12px; border-bottom:1px solid rgba(255,255,255,0.08); text-align:left; font-size:14px}
th{position:sticky; top:0; background:rgba(0,0,0,0.22); font-weight:900}
tr:hover td{background:rgba(255,255,255,0.04)}

/* Shared UI primitives */
.pillRow{display:flex; gap:8px; flex-wrap:wrap; align-items:center;}
.pill{padding:7px 13px; border-radius:999px; border:1px solid rgba(255,255,255,0.14); background:rgba(0,0,0,0.20); font-size:13px; font-weight:600; white-space:nowrap;}
.small{font-size:14px; color:var(--muted)}
.hr{height:1px; background:rgba(255,255,255,0.10); margin:16px 0;}
.num{text-align:right;}

/* Horizontal rule divider */
.static-pill{display:inline-block;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-weight:800;}

.static-pill{display:inline-block;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-weight:800;}


/* Smooth show/hide sections */
.fade-section{
  transition: opacity 0.35s ease, transform 0.35s ease, height 0.35s ease, margin 0.35s ease;
}
.fade-hidden{
  opacity: 0;
  transform: translateY(-8px);
  height: 0 !important;
  margin: 0 !important;
  overflow: hidden;
  pointer-events: none;
}


@keyframes pulseGlow {
  0% { filter: brightness(1); box-shadow: 0 0 0 rgba(0,0,0,0); }
  50% { filter: brightness(1.08); box-shadow: 0 0 22px rgba(140, 90, 255, 0.35); }
  100% { filter: brightness(1); box-shadow: 0 0 0 rgba(0,0,0,0); }
}
.modeCard.selected{
  animation: pulseGlow 1.8s ease-in-out infinite;
}


.rankLine{
  margin: 10px 0 4px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  font-size: 1.05rem;
  font-weight: 800;
}


/* Confetti */
.confetti{
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 9999;
}
.confetti-piece{
  position: absolute;
  top: -10px;
  width: 10px;
  height: 14px;
  border-radius: 3px;
  opacity: 0.9;
  animation: confettiFall 1.4s linear forwards;
}
@keyframes confettiFall{
  to{ transform: translateY(110vh) rotate(540deg); opacity: 0.2; }
}


/* ===== Bible Battle Theme ===== */
.theme-bible-battle{
  font-family: 'Nunito', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.theme-bible-battle .brandText{
  font-family: 'Nunito', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 900;
  letter-spacing: 0.2px;
  font-size: 1.55rem;
}
.brandLogo{
  width: 36px;
  height: 36px;
  border-radius: 10px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.35);
  margin-right: 10px;
}
.theme-bible-battle:before{
  content:"";
  position:fixed;
  inset:-40px;
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(0,210,255,0.22), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(255,176,0,0.16), transparent 60%),
    radial-gradient(900px 600px at 70% 90%, rgba(127,0,255,0.18), transparent 60%),
    url("assets/bible-battle-hero.png");
  background-size: cover;
  background-position: center;
  filter: blur(8px) saturate(1.15);
  opacity: 0.35;
  z-index:-2;
}
.theme-bible-battle:after{
  content:"";
  position:fixed;
  inset:0;
  background: linear-gradient(180deg, rgba(6,10,24,0.70), rgba(6,10,24,0.86));
  z-index:-1;
}

/* Bigger, bolder UI */
h1,h2,.modeTitle{ font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; font-weight:800; letter-spacing:0.2px; }
label{ font-size: 0.95rem; opacity:0.92; }
input, select{ font-size: 1.05rem; }
.btn, .btn-primary, .startBtn{ font-size: 1.05rem; }

/* Playful glow accents */
:root{
  --accentA:#00d2ff;
  --accentB:#7f00ff;
  --gold:#ffb000;
  --good:#38ef7d;
  --danger:#ff4d6d;
}
.btn-primary, .startBtn{
  background: linear-gradient(90deg, var(--accentA), var(--accentB), var(--gold));
  box-shadow: 0 18px 40px rgba(0,0,0,0.38), 0 0 0 1px rgba(255,255,255,0.10) inset;
}
.btn-primary:hover, .startBtn:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 52px rgba(0,0,0,0.42), 0 0 0 1px rgba(255,255,255,0.12) inset;
}
.modeCard[aria-checked="true"]{
  box-shadow: 0 0 0 2px rgba(0,210,255,0.45), 0 22px 60px rgba(0,0,0,0.45);
}

/* Top nav chips a bit punchier */
.topnav .btn{
  border-color: rgba(255,255,255,0.22);
  background: rgba(10,18,40,0.55);
}
.topnav .btn:hover{
  border-color: rgba(0,210,255,0.35);
}

/* Confetti canvas sits above everything */
#confettiCanvas{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
}


/* Play answers */
.choices{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:18px;
  margin-top:18px;
}
@media (max-width: 820px){
  .choices{ grid-template-columns: 1fr; }
}
.choice{
  appearance:none;
  -webkit-appearance:none;
  width:100%;
  text-align:left;
  font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-weight:700;
  font-size:1.08rem;
  line-height:1.35;
  padding:16px 18px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(10, 16, 36, 0.50);
  color: rgba(255,255,255,0.92);
  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
  backdrop-filter: blur(10px);
  cursor:pointer;
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
}
.choice:hover{
  transform: translateY(-1px);
  background: rgba(20, 30, 60, 0.58);
  border-color: rgba(255,255,255,0.22);
}
.choice:active{
  transform: translateY(0px);
}
.choice.correct{
  border-color: rgba(80, 220, 150, 0.55);
  background: rgba(20, 90, 55, 0.45);
}
.choice.wrong{
  border-color: rgba(255, 90, 90, 0.55);
  background: rgba(90, 20, 30, 0.45);
}


/* Play page question spacing */
.qPrompt{ margin-top:12px; }
#question{ margin-top:6px; }


/* ===== Audio Settings Modal ===== */
.modalOverlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.45);
  display:none;
  z-index:50;
}
.modalOverlay.open{ display:block; }

.modal{
  position:fixed;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(520px, calc(100vw - 28px));
  background:rgba(20,24,40,0.92);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:18px;
  box-shadow:0 20px 70px rgba(0,0,0,0.45);
  display:none;
  z-index:60;
  color:#fff;
}
.modal.open{ display:block; }

.modalHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px 10px 18px;
}
.modalTitle{
  font-weight:800;
  letter-spacing:0.2px;
}
.iconBtn{
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.08);
  color:#fff;
  border-radius:12px;
  padding:6px 10px;
  cursor:pointer;
}
.modalBody{ padding:10px 18px 18px 18px; }

.settingRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:10px 0;
}
.settingLabel{ font-weight:700; opacity:0.95; }
.settingControl{
  display:flex;
  align-items:center;
  gap:12px;
  width:min(320px, 62vw);
}
.settingControl input[type="range"]{ width:100%; }
.settingVal{ width:52px; text-align:right; opacity:0.9; font-variant-numeric: tabular-nums; }

.toggleRow{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 0 0 0;
  cursor:pointer;
  user-select:none;
}
.toggleRow input{ transform:scale(1.1); }

/* Pill groups in play header */
.kv{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}

/* Make brand title readable everywhere (keep fun, but legible) */
.brandText{
  font-family: 'Nunito', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
  font-weight: 800 !important;
  letter-spacing: 0.2px;
}

/* ═══════════════════════════════════════════════════════════════
   AGE GROUP — home page selector
   ═══════════════════════════════════════════════════════════════ */
.ageGroupNote{
  font-size:12px;
  opacity:0.65;
  font-weight:400;
}

.ageGroupBtns{
  display:flex;
  gap:10px;
  margin-top:6px;
  flex-wrap:wrap;
}

.ageBtn{
  flex:1;
  min-width:130px;
  padding:10px 14px;
  border-radius:12px;
  border:2px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.18);
  color:#fff;
  font-family:inherit;
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  transition:background 0.15s, border-color 0.15s, transform 0.1s;
  text-align:center;
}
.ageBtn:hover{
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.35);
}
.ageBtn.selected{
  background:rgba(255,200,50,0.22);
  border-color:#f5c842;
  box-shadow:0 0 0 3px rgba(245,200,66,0.25);
}
.ageSub{
  display:block;
  font-size:11px;
  font-weight:400;
  opacity:0.75;
  margin-top:2px;
}

/* ═══════════════════════════════════════════════════════════════
   AGE GROUP PICK MODAL
   ═══════════════════════════════════════════════════════════════ */
.ageModal{
  max-width:420px;
}

.ageModalQuestion{
  text-align:center;
  font-size:18px;
  font-weight:700;
  margin:0 0 20px;
  color:var(--text);
}

.agePickBtns{
  display:flex;
  gap:16px;
}

.agePickBtn{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:22px 14px;
  border-radius:16px;
  border:2px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.22);
  color:#fff;
  font-family:inherit;
  cursor:pointer;
  transition:background 0.15s, border-color 0.15s, transform 0.1s;
}
.agePickBtn:hover{
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.40);
  transform:translateY(-2px);
}
.agePickBtn:active{
  transform:translateY(0);
}

.agePickIcon{
  font-size:40px;
  line-height:1;
}
.agePickLabel{
  font-size:18px;
  font-weight:800;
}
.agePickSub{
  font-size:12px;
  opacity:0.70;
  font-weight:400;
}

/* ═══════════════════════════════════════════════════════════════
   WINNER BANNERS — daily leaderboard
   ═══════════════════════════════════════════════════════════════ */
.winnerBanners{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:18px;
}
@media(max-width:540px){
  .winnerBanners{ grid-template-columns:1fr; }
}

.winnerBanner{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 18px;
  border-radius:16px;
  border:2px solid rgba(255,255,255,0.15);
  background:rgba(0,0,0,0.22);
}
.winnerBanner--kids{
  border-color:rgba(80,200,120,0.45);
  background:rgba(40,140,80,0.18);
}
.winnerBanner--adults{
  border-color:rgba(245,200,66,0.40);
  background:rgba(180,130,20,0.18);
}

.winnerBannerIcon{
  font-size:28px;
  flex-shrink:0;
}
.winnerBannerLabel{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.6px;
  opacity:0.72;
  font-weight:700;
  margin-bottom:3px;
}
.winnerBannerName{
  font-size:15px;
  font-weight:800;
  line-height:1.3;
}
.winnerBannerRange{
  font-size:11px;
  opacity:0.6;
  margin-top:2px;
}

/* ═══════════════════════════════════════════════════════════════
   AGE GROUP TABS — daily leaderboard
   ═══════════════════════════════════════════════════════════════ */
.lbTabs{
  display:flex;
  gap:6px;
  margin:16px 0 10px;
  flex-wrap:wrap;
}

.lbTab{
  padding:8px 18px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.18);
  color:#fff;
  font-family:inherit;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  transition:background 0.15s, border-color 0.15s;
  white-space:nowrap;
}
.lbTab:hover{
  background:rgba(255,255,255,0.1);
  border-color:rgba(255,255,255,0.3);
}
.lbTab.selected{
  background:rgba(255,200,50,0.22);
  border-color:#f5c842;
  box-shadow:0 0 0 3px rgba(245,200,66,0.2);
}

/* ── Age pill in table rows (All tab) ── */
.agePill{
  display:inline-block;
  font-size:13px;
  margin-left:4px;
  vertical-align:middle;
  opacity:0.85;
}

/* ═══════════════════════════════════════════════════════════════
   RESULT PAGE — score display
   ═══════════════════════════════════════════════════════════════ */
.scoreDisplay{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:40px;
  padding:24px 0 20px;
}

.statBlock{
  text-align:center;
}

.statLabel{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.3px;
  color:var(--muted);
  margin-bottom:6px;
  font-weight:700;
}

.statVal{
  font-size:2.8rem;
  font-weight:900;
  line-height:1;
  letter-spacing:-1px;
}

.statDivider{
  width:1px;
  height:64px;
  background:rgba(255,255,255,0.13);
  flex-shrink:0;
}

/* Pill row bottom margin */
.pillRow{
  margin-bottom:4px;
}

/* ═══════════════════════════════════════════════════════════════
   REVIEW ANSWERS MODAL
   ═══════════════════════════════════════════════════════════════ */
.reviewModal{
  width: min(680px, calc(100vw - 28px));
  max-height: 80vh;
  display: none;
  flex-direction: column;
}
.reviewModal.open{
  display: flex;
}

.reviewModalBody{
  overflow-y: auto;
  padding: 6px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Individual review item */
.reviewItem{
  display: flex;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  align-items: flex-start;
}
.reviewItem--correct{
  border-color: rgba(56,220,120,0.28);
  background: rgba(30,100,60,0.18);
}
.reviewItem--wrong{
  border-color: rgba(255,80,80,0.28);
  background: rgba(90,20,30,0.18);
}
.reviewItem--timeout{
  border-color: rgba(245,158,11,0.28);
  background: rgba(100,70,10,0.18);
}

.reviewItemIcon{
  font-size: 20px;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}

.reviewItemBody{
  flex: 1;
  min-width: 0;
}

.reviewItemMeta{
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--muted);
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.reviewOutcomeLabel{
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2px;
}
.reviewOutcomeLabel--correct{ background: rgba(56,220,120,0.20); color: #5fe0a0; }
.reviewOutcomeLabel--wrong  { background: rgba(255,80,80,0.20);  color: #ff9090; }
.reviewOutcomeLabel--timeout{ background: rgba(245,158,11,0.20); color: #f5c842; }

.reviewItemPrompt{
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 8px;
}

.reviewAnswerLine{
  font-size: 13px;
  line-height: 1.35;
  margin-top: 3px;
  padding: 5px 10px;
  border-radius: 8px;
}
.reviewAnswerLine--correct{
  background: rgba(56,220,120,0.12);
  color: #70e8b0;
  font-weight: 700;
}
.reviewAnswerLine--wrong{
  background: rgba(255,80,80,0.12);
  color: #ff9090;
  font-weight: 600;
}
.reviewAnswerLine--timeout{
  background: rgba(245,158,11,0.12);
  color: #f5c842;
  font-weight: 600;
}


/* ═══════════════════════════════════════════════════════════════
   MOBILE — touch / tap friendliness
   ═══════════════════════════════════════════════════════════════ */

/* Eliminate 300ms tap delay everywhere */
button, a, input, select, .choice, .modeCard, .lbTab, .agePickBtn {
  touch-action: manipulation;
}

/* iOS safe-area padding so content clears the home bar */
body {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* ── Game pill row stacks vertically on narrow screens ── */
.pillRow--game {
  display: flex;
  flex-wrap: wrap;
}
.pillRow--game .kv--right {
  margin-left: auto;
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE — phones up to 640 px wide
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
  /* Container tighter on small screens */
  .container { padding: 10px 10px 24px; }

  /* ── Topbar ── */
  .topbar { gap: 6px; margin-bottom: 10px; }
  .brandLogo { width: 26px; height: 26px; margin-right: 4px; }
  .brandText { font-size: 1rem !important; }
  .topnav { gap: 5px; }
  .topnav .btn { padding: 7px 9px; font-size: 0.85rem; }

  /* ── Card ── */
  .card { padding: 14px 12px; }

  /* ── Pills (play page header) ── */
  .pill { font-size: 11px; padding: 5px 9px; }
  .pillRow { gap: 5px; }
  .kv { gap: 5px; }

  /* ── Game pill rows: left group on top, right group below ── */
  .pillRow--game {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }
  .pillRow--game .kv {
    flex-wrap: wrap;
  }
  .pillRow--game .kv--right {
    margin-left: 0;
    justify-content: flex-end;
  }

  /* ── Choice buttons: full-width, thumb-friendly ── */
  .choices { gap: 10px; margin-top: 12px; }
  .choice {
    padding: 18px 14px;
    min-height: 58px;
    font-size: 1rem;
  }

  /* ── Question text ── */
  .qPrompt, #question { font-size: 1rem; }

  /* ── Score display ── */
  .scoreDisplay { gap: 20px; padding: 16px 0 12px; }
  .statVal { font-size: 2.2rem; }
  .statDivider { height: 44px; }

  /* ── Result page: stack all action buttons full-width ── */
  .resultActions { gap: 10px; }
  .resultActionsSecondary {
    flex-direction: column;
    align-items: stretch;
  }
  .resultActionsSecondary .btn { justify-content: center; }
  .btn-big { width: 100%; min-width: unset; }

  /* ── Leaderboard table: ditch the desktop min-width, hide less-critical columns ── */
  table { min-width: 0; }
  th, td { padding: 10px 8px; font-size: 12px; }
  .tableWrap { border-radius: 10px; }
  /* Hide Date on daily, hide Category+Date on practice to avoid horizontal scroll */
  .col-date, .col-cat { display: none; }

  /* ── Leaderboard age tabs ── */
  .lbTab { padding: 7px 12px; font-size: 13px; }
  .lbTabs { gap: 5px; }

  /* ── Winner banners ── */
  .winnerBannerName { font-size: 14px; }
  .winnerBannerIcon { font-size: 22px; }

  /* ── Season display ── */
  .seasonVal { font-size: 20px; padding: 6px 0 2px; }

  /* ── Modal slider control ── */
  .settingControl { width: min(260px, 60vw); }

  /* ── Mode cards ── */
  .modeTitle { font-size: 18px; }
  .modeDesc  { font-size: 14px; }
  .modeBullets { font-size: 13px; }
  .modeCard { padding: 14px; }

  /* ── Rule strip pills ── */
  .rulePill { font-size: 13px; padding: 8px 10px; }
  .rulesStrip { gap: 7px; }

  /* ── Footer row: stack buttons ── */
  .footerRow {
    flex-direction: column;
    align-items: stretch;
  }
  .footerRow > * { justify-content: center; text-align: center; }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE — very small phones (≤ 390 px, e.g. iPhone SE)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 390px) {
  .container { padding: 8px 8px 20px; }
  .brandText { font-size: 0.9rem !important; }
  .topnav .btn { padding: 6px 8px; font-size: 0.8rem; }
  .statVal { font-size: 1.9rem; }
  .scoreDisplay { gap: 14px; }
  .statDivider { height: 38px; }
  .pill { font-size: 10px; padding: 4px 7px; }
}
