/* ============================================================
   Agora Live Arena — REIMAGINED flow (ported design)
   Source of truth: live-arena-reimagined.css
   Scoped under #la-overlay.reimagined so the generic class names
   (.btn/.scr/.toggle/.ans/.phone…) never leak into the rest of the
   site. Keyframes are lifted to top level + la- prefixed.
   SymposiON identity: gold · olive · charcoal · Cinzel/Cormorant/Raleway
   ============================================================ */

:root {
  --la-rx-base:#0d0b08; --la-rx-base-2:#0a0806;
  --la-rx-panel:#151009; --la-rx-panel-2:#1c140d; --la-rx-panel-3:#221810;
  --la-rx-border:rgba(201,164,74,0.18); --la-rx-border-2:rgba(201,164,74,0.30);
  --la-rx-gold:#c9a44a; --la-rx-gold-lt:#e3c878; --la-rx-gold-dim:rgba(201,164,74,0.38);
  --la-rx-olive:#3a5c25; --la-rx-olive-dk:#243a17; --la-rx-sage:#8eba72;
  --la-rx-rose:#c47fa9; --la-rx-terra:#cd8b5a; --la-rx-sky:#7fa9c4;
  --la-rx-text:#e8dfc8; --la-rx-text-dim:#c3b596; --la-rx-muted:#8a7a60; --la-rx-cream:#f4ecd8;
  --la-rx-serif:'Cormorant Garamond',Georgia,serif;
  --la-rx-body:'Raleway','Inter',sans-serif;
  --la-rx-display:'Cinzel','Trajan Pro',Georgia,serif;
}

/* ── Keyframes (top-level, la- prefixed) ───────────────── */
@keyframes la-scr-in { from { transform:translateY(12px); } to { transform:none; } }
@keyframes la-live-pulse { 0%{box-shadow:0 0 0 0 rgba(142,186,114,0.5);} 70%{box-shadow:0 0 0 8px rgba(142,186,114,0);} 100%{box-shadow:0 0 0 0 rgba(142,186,114,0);} }
@keyframes la-chip-pop { from{opacity:0; transform:scale(.82) translateY(8px);} to{opacity:1; transform:none;} }
@keyframes la-pod-rise { to { opacity:1; transform:none; } }
@keyframes la-confetti-fall { to { transform:translateY(110vh) rotate(720deg); opacity:.4; } }
@keyframes la-fo-bob { 0%,100%{ transform:translateY(0) rotate(-6deg); } 50%{ transform:translateY(-8px) rotate(6deg); } }

/* ════════════════════════════════════════════════════════
   Everything below is scoped to the reimagined overlay.
   Local aliases map the design tokens to the --la-rx-* vars.
   ════════════════════════════════════════════════════════ */
#la-overlay.reimagined {
  --base:var(--la-rx-base); --base-2:var(--la-rx-base-2);
  --panel:var(--la-rx-panel); --panel-2:var(--la-rx-panel-2); --panel-3:var(--la-rx-panel-3);
  --border:var(--la-rx-border); --border-2:var(--la-rx-border-2);
  --gold:var(--la-rx-gold); --gold-lt:var(--la-rx-gold-lt); --gold-dim:var(--la-rx-gold-dim);
  --olive:var(--la-rx-olive); --olive-dk:var(--la-rx-olive-dk); --sage:var(--la-rx-sage);
  --rose:var(--la-rx-rose); --terra:var(--la-rx-terra); --sky:var(--la-rx-sky);
  --text:var(--la-rx-text); --text-dim:var(--la-rx-text-dim); --muted:var(--la-rx-muted); --cream:var(--la-rx-cream);
  --serif:var(--la-rx-serif); --body:var(--la-rx-body); --display:var(--la-rx-display);

  /* #arena base — self-sufficient overlay shell */
  position:fixed; inset:0; z-index:9000;
  background:var(--base); overflow:hidden; flex-direction:column; align-items:stretch;
  color:var(--text); font-family:var(--body); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;

  & * { box-sizing:border-box; margin:0; padding:0; }

  &::before {
    content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
    background:
      radial-gradient(ellipse 70% 50% at 50% -10%, rgba(201,164,74,0.07), transparent 60%),
      radial-gradient(ellipse 60% 40% at 12% 110%, rgba(58,92,37,0.10), transparent 55%),
      radial-gradient(ellipse 50% 40% at 92% 100%, rgba(61,36,16,0.16), transparent 55%);
  }

  /* ── Icons ─────────────────────────────────────────────── */
  .ico { display:inline-flex; align-items:center; justify-content:center; }
  .ico svg { display:block; width:1em; height:1em; stroke-width:1.5; }

  /* ════════ TOP BAR + BREADCRUMB ════════ */
  .topbar { display:flex; align-items:center; gap:18px; padding:14px 24px; border-bottom:1px solid var(--border); flex-shrink:0; position:relative; z-index:5; }
  .brand { display:flex; align-items:center; gap:13px; min-width:0; flex-shrink:0; }
  .brand-logo { width:36px; height:36px; color:var(--gold); flex-shrink:0; }
  .brand-logo-host { width:36px; height:36px; color:var(--gold); flex-shrink:0; display:inline-flex; }
  .brand-text { display:flex; flex-direction:column; gap:2px; min-width:0; }
  .brand-name { font-family:var(--display); font-size:15px; font-weight:600; letter-spacing:.5px; color:var(--text); line-height:1; }
  .brand-name b { color:var(--gold); font-weight:600; }
  .brand-sub { font-family:var(--body); font-size:9px; letter-spacing:2.4px; text-transform:uppercase; color:var(--muted); white-space:nowrap; }

  .crumbs { display:flex; align-items:center; gap:2px; flex:1; min-width:0; overflow:hidden; }
  .crumb { display:inline-flex; align-items:center; gap:8px; font-family:var(--body); font-size:11px; font-weight:600; letter-spacing:.6px; color:var(--muted); background:none; border:none; cursor:pointer; padding:7px 12px; border-radius:999px; white-space:nowrap; transition:color .18s, background .18s; max-width:240px; overflow:hidden; text-overflow:ellipsis; }
  .crumb .ci { font-size:14px; color:var(--gold); opacity:.65; flex-shrink:0; }
  .crumb:hover { color:var(--text-dim); background:rgba(201,164,74,0.06); }
  .crumb.current { color:var(--text); cursor:default; }
  .crumb.current .ci { opacity:1; }
  .crumb.current:hover { background:none; }
  .crumb-sep { color:var(--gold-dim); font-size:11px; flex-shrink:0; opacity:.5; }
  .crumb-text { overflow:hidden; text-overflow:ellipsis; }

  .topbar-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }

  .icon-btn { background:transparent; border:1px solid var(--border); color:var(--muted); width:36px; height:36px; border-radius:50%; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; transition:color .2s, border-color .2s, background .2s; }
  .icon-btn .ico { font-size:16px; }
  .icon-btn:hover { color:var(--text); border-color:var(--gold-dim); background:rgba(201,164,74,0.06); }
  .icon-btn.back { width:auto; border-radius:999px; padding:0 16px 0 12px; gap:7px; font-family:var(--body); font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gold); }
  .icon-btn.back:hover { color:var(--gold-lt); }
  .icon-btn.back[disabled] { opacity:.3; pointer-events:none; }

  /* ── Buttons ───────────────────────────────────────────── */
  .btn { font-family:var(--body); font-size:12px; font-weight:600; letter-spacing:1.6px; text-transform:uppercase; display:inline-flex; align-items:center; justify-content:center; gap:9px; cursor:pointer; border:1px solid var(--border); background:rgba(255,255,255,0.03); color:var(--text-dim); padding:12px 18px; transition:background .2s, border-color .2s, color .2s, transform .15s; }
  .btn .ico { font-size:16px; }
  .btn:hover { background:rgba(201,164,74,0.08); border-color:var(--border-2); color:var(--text); }
  .btn:active { transform:translateY(1px); }
  .btn-primary { background:var(--gold); color:#1a1206; border:none; font-weight:700; letter-spacing:2px; clip-path:polygon(8px 0,calc(100% - 8px) 0,100% 8px,100% calc(100% - 8px),calc(100% - 8px) 100%,8px 100%,0 calc(100% - 8px),0 8px); }
  .btn-primary:hover { background:var(--gold-lt); transform:translateY(-2px); }
  .btn-primary:active { transform:translateY(0); }
  .btn-primary:disabled { opacity:.4; cursor:default; transform:none; filter:grayscale(.4); }
  .btn-ghost { background:none; border-color:var(--border-2); color:var(--text-dim); }

  /* ════════ SCREEN MANAGER ════════ */
  .stage { flex:1; min-height:0; position:relative; z-index:1; }
  .scr { position:absolute; inset:0; display:none; flex-direction:column; overflow:hidden; }
  .scr.active { display:flex; opacity:1; animation:la-scr-in .42s cubic-bezier(0.16,1,0.3,1) both; }
  @media (prefers-reduced-motion: reduce) { .scr.active { animation:none; } }

  .scroll-body { flex:1; overflow-y:auto; }
  .scroll-body::-webkit-scrollbar { width:6px; }
  .scroll-body::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }

  .section-eyebrow { font-family:var(--display); font-size:11px; letter-spacing:5px; text-transform:uppercase; color:var(--gold); opacity:.8; display:flex; align-items:center; justify-content:center; gap:16px; }
  .section-eyebrow::before, .section-eyebrow::after { content:''; width:40px; height:1px; background:linear-gradient(90deg, transparent, var(--gold-dim)); }
  .section-eyebrow::after { background:linear-gradient(90deg, var(--gold-dim), transparent); }
  .section-title { font-family:var(--serif); font-size:34px; font-weight:500; color:var(--text); text-align:center; letter-spacing:.3px; }
  .section-sub { font-family:var(--serif); font-size:18px; font-style:italic; color:var(--muted); text-align:center; }

  /* ════════ 1 · ROLE PICKER ════════ */
  #s-picker .picker-body { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:40px 24px; gap:36px; }
  .picker-cards { display:flex; gap:22px; flex-wrap:wrap; justify-content:center; width:100%; max-width:720px; }
  .picker-card { flex:1 1 280px; max-width:320px; display:flex; flex-direction:column; align-items:center; gap:13px; padding:42px 28px 34px; background:var(--panel); border:1px solid var(--border); border-top:2px solid var(--gold-dim); cursor:pointer; text-align:center; position:relative; overflow:hidden; transition:background .25s, border-color .25s, transform .25s; }
  .picker-card::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 50% at 50% 0%, rgba(201,164,74,0.10), transparent 65%); opacity:0; transition:opacity .3s; }
  .picker-card:hover { background:var(--panel-2); border-top-color:var(--gold); transform:translateY(-4px); }
  .picker-card:hover::after { opacity:1; }
  .picker-card-ico { width:60px; height:60px; color:var(--gold); display:flex; align-items:center; justify-content:center; position:relative; z-index:1; }
  .picker-card-ico svg { width:52px; height:52px; stroke-width:1.3; }
  .picker-card-label { font-family:var(--display); font-size:17px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--text); position:relative; z-index:1; }
  .picker-card-en { font-family:var(--body); font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); opacity:.6; margin-top:-7px; position:relative; z-index:1; }
  .picker-card-desc { font-family:var(--serif); font-size:18px; font-style:italic; color:var(--muted); line-height:1.4; position:relative; z-index:1; }

  /* ════════ 2 · COLLECTION / 3 · LEVEL select ════════ */
  .pick-wrap { max-width:960px; width:100%; margin:0 auto; padding:34px max(24px,5vw) 40px; display:flex; flex-direction:column; gap:8px; }
  .pick-head { text-align:center; display:flex; flex-direction:column; gap:10px; margin-bottom:14px; }

  .col-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(250px,1fr)); gap:14px; }
  .col-card { display:flex; align-items:center; gap:16px; padding:18px 20px; text-align:left; width:100%; color:var(--text); background:rgba(255,255,255,0.025); border:1px solid var(--border); border-left:3px solid var(--gold-dim); border-radius:5px; cursor:pointer; transition:background .2s, border-color .2s, transform .15s; position:relative; }
  .col-card:hover { background:rgba(201,164,74,0.07); border-left-color:var(--gold); transform:translateY(-2px); }
  .col-ico { width:48px; height:48px; flex-shrink:0; color:var(--gold); display:flex; align-items:center; justify-content:center; background:var(--panel-2); border:1px solid var(--border); border-radius:50%; }
  .col-ico svg { width:24px; height:24px; }
  .col-info { flex:1; min-width:0; }
  .col-subject { font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold); opacity:.75; }
  .col-name { font-family:var(--serif); font-size:21px; font-weight:600; color:var(--text); line-height:1.15; margin-top:2px; }
  .col-meta { font-family:var(--body); font-size:11px; color:var(--muted); margin-top:4px; letter-spacing:.3px; }
  .col-arrow { color:var(--gold); opacity:.45; font-size:18px; flex-shrink:0; transition:opacity .18s, transform .18s; }
  .col-card:hover .col-arrow { opacity:1; transform:translateX(3px); }

  /* upload custom */
  .ds-upload { display:flex; align-items:center; gap:18px; padding:22px 24px; width:100%; text-align:left; color:var(--text); border:1.5px dashed var(--border-2); background:linear-gradient(135deg, rgba(201,164,74,0.05), transparent 70%); border-radius:5px; cursor:pointer; transition:background .2s, border-color .2s; position:relative; overflow:hidden; }
  .ds-upload:hover, .ds-upload.drag { background:rgba(201,164,74,0.09); border-color:var(--gold); }
  .ds-upload-ico { width:48px; height:48px; flex-shrink:0; color:var(--gold); display:flex; align-items:center; justify-content:center; border:1px solid var(--border-2); border-radius:50%; background:rgba(201,164,74,0.06); }
  .ds-upload-ico svg { width:24px; height:24px; }
  .ds-upload-title { display:block; font-family:var(--serif); font-size:20px; font-weight:600; color:var(--text); }
  .ds-upload-sub { display:block; font-family:var(--body); font-size:12px; color:var(--muted); margin-top:3px; }
  .fmt-tags { display:inline-flex; gap:6px; margin-top:8px; }
  .fmt-tag { font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1px; color:var(--gold); border:1px solid var(--border-2); border-radius:999px; padding:3px 9px; text-transform:uppercase; }

  /* level groups */
  .lvl-group { margin-top:8px; }
  .lvl-group-head { display:flex; align-items:center; gap:12px; margin:18px 0 12px; }
  .lvl-group-name { font-family:var(--display); font-size:13px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--text-dim); white-space:nowrap; }
  .lvl-group-line { flex:1; height:1px; background:linear-gradient(90deg, var(--border-2), transparent); }
  .lvl-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:12px; }
  .lvl-card { display:flex; align-items:center; gap:14px; padding:15px 17px; text-align:left; width:100%; color:var(--text); background:rgba(255,255,255,0.022); border:1px solid var(--border); border-radius:5px; cursor:pointer; transition:background .2s, border-color .2s, transform .15s; }
  .lvl-card:hover { background:rgba(201,164,74,0.06); border-color:var(--gold-dim); transform:translateX(4px); }
  .lvl-num { width:40px; height:40px; flex-shrink:0; border-radius:8px; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:17px; font-weight:600; color:#1a1206; }
  .lvl-num.lgreen { background:var(--sage); } .lvl-num.lyellow { background:var(--gold); }
  .lvl-num.lred { background:var(--terra); } .lvl-num.lpurple { background:var(--rose); }
  .lvl-info { flex:1; min-width:0; }
  .lvl-desc { font-family:var(--serif); font-size:17px; font-weight:500; color:var(--text); line-height:1.25; }
  .lvl-tag { font-family:var(--body); font-size:9.5px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); margin-top:3px; }
  .lvl-go { color:var(--gold); opacity:.4; font-size:16px; flex-shrink:0; }
  .lvl-card:hover .lvl-go { opacity:1; }

  /* ════════ 4 · SETUP / OPTIONS ════════ */
  .setup-wrap { max-width:720px; width:100%; margin:0 auto; padding:32px max(24px,5vw) 30px; display:flex; flex-direction:column; gap:6px; }
  .setup-card-target { display:flex; align-items:center; gap:14px; padding:14px 18px; margin-bottom:14px; background:var(--panel); border:1px solid var(--border); border-left:3px solid var(--gold); border-radius:6px; }
  .sct-ico { width:42px; height:42px; flex-shrink:0; color:var(--gold); display:flex; align-items:center; justify-content:center; background:var(--panel-2); border:1px solid var(--border); border-radius:50%; }
  .sct-ico svg { width:21px; height:21px; }
  .sct-info { flex:1; min-width:0; }
  .sct-name { font-family:var(--serif); font-size:20px; font-weight:600; color:var(--text); line-height:1.1; }
  .sct-sub { font-family:var(--body); font-size:11px; color:var(--muted); margin-top:3px; letter-spacing:.3px; }

  .opt-row { display:flex; align-items:center; gap:16px; padding:16px 4px; border-bottom:1px solid var(--border); }
  .opt-row:last-of-type { border-bottom:none; }
  .opt-label { flex-shrink:0; width:180px; }
  .opt-label-main { display:flex; align-items:center; gap:9px; font-family:var(--serif); font-size:19px; font-weight:600; color:var(--text); }
  .opt-label-main .ico { font-size:17px; color:var(--gold); opacity:.85; }
  .opt-label-sub { font-family:var(--body); font-size:11px; color:var(--muted); margin-top:2px; letter-spacing:.2px; }
  .opt-control { flex:1; min-width:0; display:flex; justify-content:flex-end; }

  /* segmented control */
  .seg { display:inline-flex; flex-wrap:wrap; gap:5px; justify-content:flex-end; }
  .seg-btn { font-family:var(--body); font-size:12px; font-weight:600; letter-spacing:.4px; color:var(--text-dim); background:rgba(255,255,255,0.03); border:1px solid var(--border); border-radius:999px; padding:9px 16px; cursor:pointer; transition:all .16s; white-space:nowrap; display:inline-flex; align-items:center; gap:6px; }
  .seg-btn .ico { font-size:14px; color:var(--gold); opacity:.7; }
  .seg-btn:hover { background:rgba(201,164,74,0.07); border-color:var(--border-2); color:var(--text); }
  .seg-btn.on { background:var(--gold); border-color:var(--gold); color:#1a1206; }
  .seg-btn.on .ico { color:#1a1206; opacity:1; }
  .seg-btn.free.on { background:var(--sage); border-color:var(--sage); }

  /* toggle */
  .toggle { width:52px; height:28px; border-radius:999px; background:var(--panel-3); border:1px solid var(--border); cursor:pointer; position:relative; transition:background .2s, border-color .2s; flex-shrink:0; }
  .toggle::after { content:''; position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:var(--muted); transition:transform .2s, background .2s; }
  .toggle.on { background:rgba(142,186,114,0.25); border-color:var(--sage); }
  .toggle.on::after { transform:translateX(24px); background:var(--sage); }

  /* win condition detail */
  .win-detail { max-height:0; overflow:hidden; opacity:0; transition:max-height .3s ease, opacity .25s ease, margin .3s ease; }
  .win-detail.show { max-height:160px; opacity:1; margin:2px 0 10px; padding:14px 16px; background:rgba(201,164,74,0.05); border:1px solid var(--border); border-left:2px solid var(--gold-dim); border-radius:6px; }
  .wd-row { display:flex; align-items:center; gap:14px; }
  .wd-ico { color:var(--gold); display:flex; flex-shrink:0; } .wd-ico svg { width:18px; height:18px; }
  .wd-slider { -webkit-appearance:none; appearance:none; flex:1; height:6px; border-radius:999px; outline:none; cursor:pointer; background:linear-gradient(90deg, var(--olive), var(--sage)); }
  .wd-slider::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:22px; height:22px; border-radius:50%; background:var(--gold); border:3px solid var(--base); box-shadow:0 0 0 1px var(--gold-dim), 0 4px 12px rgba(0,0,0,0.5); cursor:pointer; }
  .wd-slider::-moz-range-thumb { width:18px; height:18px; border-radius:50%; background:var(--gold); border:3px solid var(--base); cursor:pointer; }
  .wd-val { font-family:var(--body); font-size:13px; color:var(--text-dim); white-space:nowrap; flex-shrink:0; }
  .wd-val b { font-family:var(--display); font-size:20px; color:var(--gold); }
  .wd-note { font-family:var(--serif); font-size:15px; font-style:italic; color:var(--muted); margin-top:10px; line-height:1.4; }
  .wd-note b { color:var(--text-dim); font-style:normal; font-weight:600; }
  .wd-targets { display:flex; gap:7px; flex-wrap:wrap; }
  .wd-target { font-family:var(--display); font-size:15px; font-weight:600; color:var(--text-dim); cursor:pointer; background:rgba(255,255,255,0.03); border:1px solid var(--border); border-radius:8px; padding:9px 16px; transition:all .15s; }
  .wd-target:hover { background:rgba(201,164,74,0.08); color:var(--text); }
  .wd-target.on { background:var(--gold); border-color:var(--gold); color:#1a1206; }
  .set-pill-win .ico { color:var(--gold-lt); }
  .set-pop-win { min-width:250px; }
  .set-pop-detail { border-top:1px solid var(--border); margin-top:6px; padding-top:10px; }
  .set-pop-note { font-family:var(--serif); font-size:14px; font-style:italic; color:var(--muted); padding:2px 10px 4px; line-height:1.35; }
  .set-pop-detail .wd-row { padding:4px 8px; } .set-pop-detail .wd-targets { padding:2px 6px; }

  .setup-footer { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:16px max(24px,5vw); border-top:1px solid var(--border); flex-shrink:0; }
  .setup-summary { font-family:var(--body); font-size:11px; letter-spacing:.4px; color:var(--muted); }
  .setup-summary b { color:var(--text-dim); font-weight:600; }

  /* ════════ 5 · LOBBY ════════ */
  #s-lobby { background:transparent; }
  .lobby-main { flex:1; min-height:0; display:grid; grid-template-columns:minmax(430px,0.92fr) 1.08fr; position:relative; }
  .join-panel { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; padding:28px 40px; min-width:0; overflow-y:auto; }
  .join-instruct { text-align:center; }
  .join-instruct-label { font-family:var(--body); font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
  .join-instruct-url { font-family:var(--serif); font-size:clamp(20px,2.4vw,27px); font-weight:500; color:var(--text); }
  .join-instruct-url b { color:var(--gold); font-weight:600; }
  .code-row { display:flex; align-items:stretch; gap:26px; flex-wrap:wrap; justify-content:center; }
  .qr-card { background:var(--cream); width:170px; padding:13px; border-radius:6px; position:relative; flex-shrink:0; box-shadow:0 18px 50px rgba(0,0,0,0.5), 0 0 0 1px rgba(201,164,74,0.25); }
  .qr-card::after { content:''; position:absolute; inset:7px; border:1px solid rgba(26,18,6,0.12); border-radius:3px; pointer-events:none; }
  .qr-card svg { display:block; width:144px; height:144px; aspect-ratio:1; }
  .qr-scan-hint { font-family:var(--body); font-size:8.5px; letter-spacing:2px; text-transform:uppercase; color:#6b5a36; text-align:center; margin-top:8px; }
  .pin-cluster { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; }
  .pin-label { font-family:var(--body); font-size:9.5px; letter-spacing:4px; text-transform:uppercase; color:var(--muted); }
  .pin-display { font-family:var(--display); font-weight:600; font-size:clamp(46px,6.2vw,72px); line-height:1; color:var(--gold); letter-spacing:6px; text-shadow:0 0 44px rgba(201,164,74,0.4); display:flex; gap:3px; }
  .pin-display .digit { min-width:0.62em; text-align:center; }
  .pin-display .gap { width:0.22em; }
  .pin-share { display:flex; gap:10px; margin-top:12px; }
  .pin-share .btn { padding:10px 15px; font-size:10.5px; letter-spacing:1.2px; }

  .host-identity { display:flex; align-items:center; gap:14px; padding:11px 15px; width:100%; max-width:420px; background:var(--panel); border:1px solid var(--border); border-radius:6px; }
  .host-avatar { width:50px; height:50px; border-radius:50%; flex-shrink:0; background:var(--olive-dk); border:1px solid var(--border-2); display:flex; align-items:center; justify-content:center; color:var(--gold); }
  .host-avatar .av-initials { font-family:var(--serif); font-size:21px; font-weight:600; color:var(--gold); }
  .host-id-text { flex:1; min-width:0; }
  .host-id-name { font-family:var(--serif); font-size:19px; font-weight:600; color:var(--text); line-height:1.1; }
  .host-id-role { font-family:var(--body); font-size:9.5px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); opacity:.65; margin-top:3px; display:inline-flex; align-items:center; gap:6px; }
  .host-id-role .ico { font-size:12px; }

  .players-panel { display:flex; flex-direction:column; min-width:0; padding:28px 40px 20px; }
  .players-head { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-shrink:0; margin-bottom:16px; }
  .players-title { font-family:var(--body); font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); display:inline-flex; align-items:center; gap:10px; }
  .players-title .ico { font-size:15px; color:var(--gold); opacity:.8; }
  .player-count { font-family:var(--display); font-size:15px; font-weight:600; color:var(--sage); background:var(--olive-dk); border:1px solid rgba(142,186,114,0.35); border-radius:999px; padding:3px 14px; letter-spacing:1px; display:inline-flex; align-items:center; gap:7px; }
  .player-count .pulse { width:7px; height:7px; border-radius:50%; background:var(--sage); box-shadow:0 0 0 0 rgba(142,186,114,0.6); animation:la-live-pulse 1.8s ease-out infinite; }
  .player-grid { flex:1; min-height:0; overflow-y:auto; display:grid; grid-template-columns:repeat(auto-fill, minmax(150px,1fr)); gap:10px; align-content:flex-start; padding-right:4px; }
  .player-grid::-webkit-scrollbar { width:5px; } .player-grid::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }
  .player-chip { display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:999px; background:rgba(255,255,255,0.04); border:1px solid var(--border); position:relative; transition:background .2s, border-color .2s; }
  .player-chip.pop { animation:la-chip-pop .45s cubic-bezier(0.34,1.56,0.64,1); }
  .player-chip:hover { background:rgba(201,164,74,0.07); border-color:var(--border-2); }
  .player-av { width:30px; height:30px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:14px; font-weight:600; color:#1a1206; }
  .player-name { font-family:var(--body); font-size:13px; font-weight:500; color:var(--text); flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .player-kick { width:20px; height:20px; border-radius:50%; flex-shrink:0; border:none; background:transparent; color:var(--muted); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:12px; opacity:0; transition:opacity .18s, color .18s, background .18s; }
  .player-chip:hover .player-kick { opacity:1; }
  .player-kick:hover { color:#e87575; background:rgba(192,57,43,0.12); }
  .players-empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; color:var(--muted); text-align:center; }
  .players-empty .ico { font-size:38px; color:var(--gold); opacity:.3; }
  .players-empty .pe-txt { font-family:var(--serif); font-style:italic; font-size:19px; opacity:.7; }

  .lobby-footer { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:16px 40px; border-top:1px solid var(--border); flex-shrink:0; position:relative; z-index:2; flex-wrap:wrap; background:rgba(8,6,4,0.94); backdrop-filter:blur(12px); }
  .lobby-recap { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
  .recap-pill { display:inline-flex; align-items:center; gap:7px; font-family:var(--body); font-size:11px; font-weight:600; letter-spacing:.3px; color:var(--text-dim); background:rgba(255,255,255,0.03); border:1px solid var(--border); border-radius:999px; padding:7px 13px; }
  .recap-pill .ico { font-size:14px; color:var(--gold); opacity:.8; }
  .recap-pill b { color:var(--gold); font-weight:700; }
  .recap-edit { font-family:var(--body); font-size:10px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; color:var(--muted); background:none; border:1px solid var(--border); border-radius:999px; padding:0; cursor:pointer; transition:all .18s; width:34px; height:34px; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
  .recap-edit:hover { color:var(--text); border-color:var(--gold-dim); }
  .recap-edit .ico { font-size:15px; }
  .start-btn { padding:16px 44px; font-size:13px; }

  .lobby-settings { display:flex; align-items:center; gap:8px; flex-wrap:wrap; position:relative; }
  .set-pill { display:inline-flex; align-items:center; gap:8px; cursor:pointer; font-family:var(--body); background:rgba(255,255,255,0.03); border:1px solid var(--border); border-radius:999px; padding:7px 14px; color:var(--text-dim); transition:background .18s, border-color .18s, color .18s; }
  .set-pill:hover { background:rgba(201,164,74,0.08); border-color:var(--border-2); color:var(--text); }
  .set-pill .ico { font-size:15px; color:var(--gold); opacity:.85; }
  .set-pill .set-k { font-size:9px; font-weight:700; letter-spacing:1.6px; text-transform:uppercase; color:var(--muted); }
  .set-pill .set-v { font-family:var(--display); font-size:13px; font-weight:600; color:var(--gold-lt); }
  .set-pill .set-caret { font-size:12px; opacity:.5; color:var(--muted); }
  .set-pill.on { background:rgba(142,186,114,0.12); border-color:rgba(142,186,114,0.4); }
  .set-pill.on .ico { color:var(--sage); }
  .set-pill.on .set-v { color:var(--sage); }
  .set-pop { position:absolute; bottom:calc(100% + 10px); left:0; z-index:60; min-width:230px; background:var(--panel-2); border:1px solid var(--border-2); border-radius:8px; padding:8px; box-shadow:0 18px 50px rgba(0,0,0,0.55); display:flex; flex-direction:column; gap:3px; animation:la-scr-in .2s ease both; }
  .set-pop-title { font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--muted); padding:6px 10px 8px; }
  .set-opt { display:flex; align-items:center; gap:11px; width:100%; text-align:left; cursor:pointer; background:none; border:1px solid transparent; border-radius:6px; padding:10px 12px; color:var(--text-dim); font-family:var(--serif); font-size:16px; font-weight:500; transition:background .15s, color .15s; }
  .set-opt svg { width:17px; height:17px; color:var(--gold); opacity:.7; flex-shrink:0; }
  .set-opt:hover { background:rgba(201,164,74,0.08); color:var(--text); }
  .set-opt.on { background:rgba(201,164,74,0.14); color:var(--text); border-color:var(--gold-dim); }
  .set-opt.on svg { opacity:1; }
  .set-opt.free.on { background:rgba(142,186,114,0.14); border-color:rgba(142,186,114,0.4); }
  .set-opt.free.on svg { color:var(--sage); }

  .class-banner { display:flex; align-items:center; gap:12px; width:100%; max-width:420px; cursor:pointer; min-height:54px; padding:14px 18px; text-align:left; color:var(--text-dim); background-size:cover; background-position:center; border:1.5px dashed var(--border-2); border-radius:6px; transition:background .2s, border-color .2s, color .2s; }
  .class-banner:hover { border-color:var(--gold); color:var(--text); background-color:rgba(201,164,74,0.05); }
  .class-banner.filled { border-style:solid; border-color:var(--gold-dim); color:var(--cream); min-height:88px; align-items:flex-end; }
  .cb-ico { width:24px; height:24px; flex-shrink:0; color:var(--gold); display:flex; align-items:center; justify-content:center; }
  .cb-ico svg { width:20px; height:20px; }
  .cb-txt { font-family:var(--body); font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
  .cb-txt em { font-style:normal; color:var(--muted); font-weight:600; }
  .class-banner.filled .cb-txt { text-shadow:0 1px 8px rgba(0,0,0,0.8); }

  /* ════════ 6 · LIVE HOST GAME ════════ */
  #s-game { background:transparent; }
  .game-top { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:14px 30px; border-bottom:1px solid var(--border); flex-shrink:0; }
  .game-prog { font-family:var(--body); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
  .game-prog b { color:var(--gold); font-family:var(--display); font-size:14px; }
  .game-timer { display:flex; align-items:center; gap:12px; }
  .timer-ring { width:54px; height:54px; position:relative; }
  .timer-ring svg { transform:rotate(-90deg); width:54px; height:54px; }
  .timer-ring .tr-bg { stroke:var(--border); }
  .timer-ring .tr-fg { stroke:var(--gold); stroke-linecap:round; transition:stroke-dashoffset .9s linear; }
  .timer-num { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:18px; font-weight:600; color:var(--text); }
  .timer-free { font-family:var(--body); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--sage); display:inline-flex; align-items:center; gap:8px; }
  .timer-free .ico { font-size:16px; }
  .game-answered { font-family:var(--display); font-size:15px; color:var(--sage); display:flex; align-items:center; gap:8px; }
  .game-answered b { font-size:22px; }

  .game-body { flex:1; min-height:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:30px; padding:30px max(24px,5vw); overflow-y:auto; }
  .game-q { font-family:var(--serif); font-size:clamp(28px,3.6vw,44px); font-weight:500; color:var(--text); text-align:center; line-height:1.25; max-width:880px; text-wrap:balance; }
  .game-q em { color:var(--gold); font-style:italic; }
  .game-qtags { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; }
  .game-qtag { font-family:var(--body); font-size:11px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--text-dim); background:var(--panel-2); border:1px solid var(--border); border-radius:999px; padding:6px 14px; }

  .answers { display:grid; grid-template-columns:1fr 1fr; gap:14px; width:100%; max-width:860px; }
  .ans { display:flex; align-items:center; gap:16px; padding:20px 22px; border-radius:8px; cursor:pointer; position:relative; overflow:hidden; border:1px solid var(--border); background:var(--panel); transition:transform .15s, border-color .2s; text-align:left; }
  .ans:hover { transform:translateY(-2px); border-color:var(--border-2); }
  .ans-fill { position:absolute; left:0; top:0; bottom:0; width:0; background:rgba(201,164,74,0.14); transition:width .8s cubic-bezier(0.16,1,0.3,1); z-index:0; }
  .ans-glyph { width:38px; height:38px; flex-shrink:0; border-radius:7px; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:18px; font-weight:700; color:#1a1206; position:relative; z-index:1; }
  .ans:nth-child(1) .ans-glyph { background:var(--terra); } .ans:nth-child(2) .ans-glyph { background:var(--sky); }
  .ans:nth-child(3) .ans-glyph { background:var(--sage); } .ans:nth-child(4) .ans-glyph { background:var(--rose); }
  .ans-text { flex:1; font-family:var(--serif); font-size:24px; font-weight:500; color:var(--text); position:relative; z-index:1; }
  .ans-pct { font-family:var(--display); font-size:18px; font-weight:600; color:var(--muted); position:relative; z-index:1; opacity:0; transition:opacity .3s; }
  .game-body.revealed .ans-pct { opacity:1; }
  .game-body.revealed .ans.correct { border-color:var(--sage); box-shadow:0 0 0 1px var(--sage); }
  .game-body.revealed .ans.correct .ans-fill { background:rgba(142,186,114,0.2); }
  .game-body.revealed .ans.correct .ans-pct { color:var(--sage); }
  .game-body.revealed .ans.wrong { opacity:.55; }
  .ans-check { position:absolute; right:18px; top:50%; transform:translateY(-50%); color:var(--sage); font-size:22px; opacity:0; z-index:2; }
  .game-body.revealed .ans.correct .ans-check { opacity:1; }

  .game-foot { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:16px 30px; border-top:1px solid var(--border); flex-shrink:0; }
  .game-foot-left { display:flex; gap:10px; }

  /* ════════ 7 · PODIUM ════════ */
  #s-podium { background:transparent; align-items:center; }
  #s-podium .scroll-body { width:100%; display:flex; flex-direction:column; align-items:center; }
  .podium-wrap { max-width:960px; width:100%; padding:30px 24px 40px; display:flex; flex-direction:column; align-items:center; gap:6px; }
  .podium-eyebrow { font-family:var(--display); font-size:12px; letter-spacing:6px; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:16px; }
  .podium-eyebrow::before, .podium-eyebrow::after { content:''; width:44px; height:1px; background:linear-gradient(90deg, transparent, var(--gold-dim)); }
  .podium-eyebrow::after { background:linear-gradient(90deg, var(--gold-dim), transparent); }
  .podium-title { font-family:var(--serif); font-size:40px; font-weight:500; color:var(--text); margin-top:6px; }
  .podium-sub { font-family:var(--serif); font-size:18px; font-style:italic; color:var(--muted); margin-bottom:18px; }

  .podium-stage { display:flex; align-items:flex-end; justify-content:center; gap:18px; width:100%; max-width:680px; margin-bottom:8px; }
  .pod-col { display:flex; flex-direction:column; align-items:center; gap:12px; flex:1; max-width:200px; }
  .pod-laurel { display:flex; flex-direction:column; align-items:center; gap:8px; opacity:0; transform:translateY(16px); }
  .pod-col.show .pod-laurel { opacity:1; transform:none; animation:la-pod-rise .6s cubic-bezier(0.16,1,0.3,1) both; }
  .pod-col.c1 .pod-laurel { animation-delay:.5s; } .pod-col.c2 .pod-laurel { animation-delay:.15s; } .pod-col.c3 .pod-laurel { animation-delay:.3s; }
  .pod-medal { font-family:var(--display); font-size:18px; font-weight:700; width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#1a1206; }
  .pod-rank-1 .pod-medal { background:var(--gold); box-shadow:0 0 28px rgba(201,164,74,0.55); }
  .pod-rank-2 .pod-medal { background:#c4c2b6; }
  .pod-rank-3 .pod-medal { background:var(--terra); }
  .pod-avatar { width:64px; height:64px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:28px; font-weight:600; color:#1a1206; border:2px solid var(--border-2); }
  .pod-rank-1 .pod-avatar { width:80px; height:80px; font-size:34px; border-color:var(--gold); box-shadow:0 0 36px rgba(201,164,74,0.4); }
  .pod-name { font-family:var(--serif); font-size:21px; font-weight:600; color:var(--text); text-align:center; line-height:1.1; }
  .pod-rank-1 .pod-name { font-size:24px; color:var(--gold-lt); }
  .pod-score { font-family:var(--display); font-size:15px; font-weight:600; color:var(--muted); }
  .pod-block { width:100%; border-radius:6px 6px 0 0; display:flex; align-items:flex-start; justify-content:center; padding-top:14px; font-family:var(--display); font-size:40px; font-weight:700; color:rgba(244,236,216,0.16); background:linear-gradient(180deg, var(--panel-2), var(--panel)); border:1px solid var(--border); border-bottom:none; }
  .pod-rank-1 .pod-block { height:150px; border-top:2px solid var(--gold); }
  .pod-rank-2 .pod-block { height:104px; border-top:2px solid #c4c2b6; }
  .pod-rank-3 .pod-block { height:78px; border-top:2px solid var(--terra); }

  .leaderboard { width:100%; max-width:560px; margin-top:22px; display:flex; flex-direction:column; gap:7px; }
  .lb-row { display:flex; align-items:center; gap:14px; padding:11px 16px; border-radius:6px; background:rgba(255,255,255,0.022); border:1px solid var(--border); }
  .lb-rank { font-family:var(--display); font-size:15px; font-weight:600; color:var(--muted); width:26px; text-align:center; flex-shrink:0; }
  .lb-av { width:32px; height:32px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:14px; font-weight:600; color:#1a1206; }
  .lb-name { flex:1; font-family:var(--serif); font-size:18px; font-weight:500; color:var(--text); }
  .lb-correct { font-family:var(--body); font-size:11px; color:var(--muted); letter-spacing:.3px; }
  .lb-score { font-family:var(--display); font-size:17px; font-weight:600; color:var(--gold); }
  .podium-actions { display:flex; gap:12px; margin-top:26px; flex-wrap:wrap; justify-content:center; }

  /* ════════ JOIN (mobile) ════════ */
  #s-join { align-items:center; justify-content:center; background:radial-gradient(ellipse 50% 40% at 50% 50%, rgba(58,92,37,0.10), transparent 60%); }
  .phone { width:360px; max-width:calc(100vw - 32px); height:min(700px, calc(100vh - 120px)); background:var(--base); border:1px solid var(--border-2); border-radius:34px; box-shadow:0 30px 90px rgba(0,0,0,0.6), inset 0 0 0 8px #050403; overflow:hidden; position:relative; display:flex; flex-direction:column; }
  .phone-notch { position:absolute; top:12px; left:50%; transform:translateX(-50%); width:110px; height:5px; border-radius:999px; background:rgba(255,255,255,0.1); z-index:5; }
  .jstep { flex:1; display:none; flex-direction:column; align-items:center; justify-content:center; gap:16px; padding:40px 30px; text-align:center; }
  .jstep.active { display:flex; }
  .join-logo { font-family:var(--serif); font-size:36px; font-weight:300; color:var(--text); line-height:1.1; }
  .join-logo em { display:block; font-style:italic; color:var(--gold); font-size:24px; margin-top:4px; white-space:nowrap; }
  .join-prompt { font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:3.5px; text-transform:uppercase; color:var(--muted); }
  .pin-input, .name-input { width:100%; font-family:var(--display); font-weight:600; text-align:center; color:var(--gold); background:rgba(255,255,255,0.04); border:1px solid var(--border); border-radius:4px; outline:none; caret-color:var(--gold); transition:border-color .25s, background .25s; }
  .pin-input { font-size:38px; letter-spacing:10px; padding:16px 8px; }
  .name-input { font-size:24px; letter-spacing:1px; padding:14px; }
  .pin-input::placeholder { color:rgba(201,164,74,0.2); } .name-input::placeholder { color:rgba(201,164,74,0.25); letter-spacing:.5px; font-style:italic; font-size:18px; }
  .pin-input:focus, .name-input:focus { border-color:var(--gold-dim); background:rgba(201,164,74,0.05); }
  .join-btn { width:100%; padding:16px; font-size:12px; }
  .join-cancel { background:none; border:none; color:var(--muted); cursor:pointer; font-family:var(--body); font-size:10px; letter-spacing:2px; text-transform:uppercase; padding:4px; transition:color .2s; }
  .join-cancel:hover { color:var(--text); }
  .phone-caption { position:absolute; bottom:-32px; left:0; right:0; text-align:center; font-family:var(--body); font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }

  /* waiting lobby + Flappy */
  .wait-step { padding:0 !important; justify-content:flex-start !important; gap:0 !important; }
  .swait-head { display:flex; align-items:center; gap:12px; width:100%; padding:18px 18px 14px; flex-shrink:0; }
  .swait-av { width:44px; height:44px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:19px; font-weight:600; color:#1a1206; background:var(--gold); }
  .swait-you-txt { flex:1; min-width:0; text-align:left; }
  .swait-name { font-family:var(--serif); font-size:19px; font-weight:600; color:var(--text); line-height:1.1; }
  .swait-game { font-family:var(--body); font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); opacity:.7; margin-top:2px; }
  .swait-live { display:inline-flex; align-items:center; gap:7px; flex-shrink:0; font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--sage); background:var(--olive-dk); border:1px solid rgba(142,186,114,0.35); border-radius:999px; padding:5px 11px; }
  .swait-live .pulse { width:6px; height:6px; border-radius:50%; background:var(--sage); animation:la-live-pulse 1.8s ease-out infinite; }
  .flappy-wrap { position:relative; flex:1; min-height:0; width:100%; overflow:hidden; border-top:1px solid var(--border); border-bottom:1px solid var(--border); cursor:pointer; touch-action:none; }
  .flappy-canvas { display:block; width:100%; height:100%; }
  .flappy-score { position:absolute; top:14px; left:0; right:0; text-align:center; z-index:3; pointer-events:none; font-family:var(--display); font-size:46px; font-weight:700; color:var(--cream); text-shadow:0 2px 14px rgba(0,0,0,0.7), 0 0 30px rgba(201,164,74,0.4); opacity:0; transition:opacity .25s; }
  .flappy-wrap.playing .flappy-score { opacity:1; }
  .flappy-best { position:absolute; top:12px; right:14px; z-index:3; pointer-events:none; font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
  .flappy-best b { font-family:var(--display); font-size:13px; color:var(--gold); }
  .flappy-wrap.playing .flappy-best { opacity:0; }
  .flappy-overlay { position:absolute; inset:0; z-index:4; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:30px; text-align:center; background:radial-gradient(ellipse at center, rgba(13,11,8,0.62), rgba(13,11,8,0.9)); backdrop-filter:blur(2px); transition:opacity .25s; }
  .flappy-overlay.hide { opacity:0; pointer-events:none; }
  .fo-bird { width:54px; height:54px; border-radius:50%; background:radial-gradient(circle at 35% 30%, #f0d585, #c9a44a); border:1px solid rgba(60,40,16,0.4); position:relative; animation:la-fo-bob 1.6s ease-in-out infinite; box-shadow:0 8px 24px rgba(0,0,0,0.5); }
  .fo-bird::after { content:''; position:absolute; top:32%; right:24%; width:9px; height:9px; border-radius:50%; background:#1a1206; }
  .fo-title { font-family:var(--serif); font-size:24px; font-weight:600; color:var(--text); }
  .fo-sub { font-family:var(--body); font-size:11px; letter-spacing:.4px; color:var(--text-dim); line-height:1.5; max-width:230px; }
  .fo-sub b { color:var(--gold); font-family:var(--display); font-size:14px; }
  .fo-btn { margin-top:6px; display:inline-flex; align-items:center; gap:9px; cursor:pointer; font-family:var(--body); font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:#1a1206; background:var(--gold); border:none; border-radius:999px; padding:13px 22px; transition:background .2s, transform .15s; }
  .fo-btn .ico { font-size:15px; } .fo-btn svg { width:15px; height:15px; }
  .fo-btn:hover { background:var(--gold-lt); transform:translateY(-2px); }
  .fo-btn:active { transform:translateY(0); }
  .wait-step .swait-status { padding:14px 18px; flex-shrink:0; text-align:center; font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:var(--muted); }

  /* ════════ MODE SELECT (grand) ════════ */
  .mode-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(300px,1fr)); gap:18px; }
  .mode-tile { display:flex; flex-direction:column; gap:13px; padding:30px 28px 26px; text-align:left; width:100%; color:var(--text); background:linear-gradient(165deg, var(--panel-2), var(--panel) 70%); border:1px solid var(--border); border-radius:10px; cursor:pointer; position:relative; overflow:hidden; isolation:isolate; transition:background .25s, border-color .25s, transform .25s, box-shadow .25s; }
  .mode-tile::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, transparent, var(--gold-dim) 30%, var(--gold) 50%, var(--gold-dim) 70%, transparent); opacity:.5; transition:opacity .3s; z-index:2; }
  .mode-tile::after { content:''; position:absolute; inset:0; z-index:-1; background:radial-gradient(ellipse 90% 70% at 50% -10%, rgba(201,164,74,0.12), transparent 60%); opacity:0; transition:opacity .35s; }
  .mode-tile:hover { background:linear-gradient(165deg, var(--panel-3), var(--panel-2) 70%); border-color:var(--gold-dim); transform:translateY(-5px); box-shadow:0 24px 60px rgba(0,0,0,0.45), 0 0 0 1px rgba(201,164,74,0.12); }
  .mode-tile:hover::before { opacity:1; }
  .mode-tile:hover::after { opacity:1; }
  .mode-tile.locked { opacity:.62; }
  .mode-tile.locked:hover { transform:none; border-color:var(--border); box-shadow:none; }
  .mode-tile.locked:hover::before { opacity:.5; }
  .mode-watermark { position:absolute; top:-22px; right:-26px; width:150px; height:150px; color:var(--gold); opacity:.05; pointer-events:none; z-index:0; transition:opacity .35s, transform .35s; }
  .mode-watermark svg { width:100%; height:100%; stroke-width:1; }
  .mode-tile:hover .mode-watermark { opacity:.1; transform:scale(1.08) rotate(-4deg); }
  .mode-medallion { width:64px; height:64px; flex-shrink:0; color:var(--gold); position:relative; z-index:1; display:flex; align-items:center; justify-content:center; border-radius:50%; background:radial-gradient(circle at 35% 30%, rgba(201,164,74,0.18), var(--panel-3)); border:1px solid var(--gold-dim); box-shadow:inset 0 1px 0 rgba(227,200,120,0.25), 0 6px 18px rgba(0,0,0,0.35); }
  .mode-medallion::after { content:''; position:absolute; inset:5px; border:1px solid rgba(201,164,74,0.22); border-radius:50%; }
  .mode-medallion svg { width:30px; height:30px; stroke-width:1.4; }
  .mode-tile:hover .mode-medallion { border-color:var(--gold); box-shadow:inset 0 1px 0 rgba(227,200,120,0.3), 0 0 26px rgba(201,164,74,0.3); }
  .mode-titles { position:relative; z-index:1; }
  .mode-name { font-family:var(--serif); font-size:27px; font-weight:600; color:var(--text); line-height:1.05; }
  .mode-tile:hover .mode-name { color:var(--gold-lt); }
  .mode-en { font-family:var(--body); font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); opacity:.6; margin-top:4px; }
  .mode-desc { font-family:var(--serif); font-size:17px; font-style:italic; color:var(--muted); line-height:1.4; position:relative; z-index:1; flex:1; }
  .mode-tags { display:flex; flex-wrap:wrap; gap:6px; position:relative; z-index:1; }
  .mode-tag { font-family:var(--body); font-size:9px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--text-dim); background:rgba(255,255,255,0.04); border:1px solid var(--border); border-radius:999px; padding:5px 11px; }
  .mode-go { display:inline-flex; align-items:center; gap:8px; position:relative; z-index:1; margin-top:4px; font-family:var(--body); font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold); opacity:.45; transform:translateX(-4px); transition:opacity .25s, transform .25s; }
  .mode-go .ico { font-size:14px; }
  .mode-tile:hover .mode-go { opacity:1; transform:translateX(0); }
  .mode-tile.locked .mode-go { color:var(--muted); }
  .mode-lock { position:absolute; top:16px; right:16px; z-index:3; display:inline-flex; align-items:center; gap:6px; font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gold); background:rgba(13,11,8,0.75); border:1px solid var(--gold-dim); border-radius:999px; padding:5px 11px; }
  .mode-lock .ico { font-size:12px; }
  #s-mode .section-eyebrow { font-size:12px; letter-spacing:6px; }
  #s-mode .section-title { font-size:46px; }
  #s-mode .pick-head { gap:12px; margin-bottom:24px; }

  /* game select */
  .cat-group { margin-top:6px; }
  .col-card.locked { opacity:.6; cursor:not-allowed; }
  .col-card.locked:hover { transform:none; background:rgba(255,255,255,0.025); border-left-color:var(--gold-dim); }
  .col-lock { display:inline-flex; align-items:center; gap:6px; font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gold); background:rgba(201,164,74,0.1); border:1px solid var(--gold-dim); border-radius:999px; padding:5px 11px; flex-shrink:0; }
  .col-lock .ico { font-size:12px; }

  /* multi-select levels */
  .lvl-progress { width:100%; height:6px; border-radius:999px; background:var(--panel-3); border:1px solid var(--border); overflow:hidden; margin:4px 0 6px; }
  .lvl-progress-fill { height:100%; background:linear-gradient(90deg, var(--olive), var(--sage)); border-radius:999px; transition:width .4s cubic-bezier(0.16,1,0.3,1); }
  .lvl-progress-label { font-family:var(--body); font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--muted); text-align:center; margin-bottom:12px; }
  .lvl-all { display:flex; align-items:center; gap:14px; padding:16px 18px; width:100%; text-align:left; color:var(--text); cursor:pointer; background:linear-gradient(135deg, rgba(201,164,74,0.08), transparent 70%); border:1px solid var(--gold-dim); border-radius:6px; transition:background .2s, border-color .2s; margin-bottom:8px; }
  .lvl-all:hover { background:rgba(201,164,74,0.12); }
  .lvl-all.on { background:rgba(201,164,74,0.16); border-color:var(--gold); }
  .lvl-all-ico { width:44px; height:44px; flex-shrink:0; color:var(--gold); display:flex; align-items:center; justify-content:center; background:var(--panel-2); border:1px solid var(--border); border-radius:50%; }
  .lvl-all-ico svg { width:22px; height:22px; }
  .lvl-all-info { flex:1; }
  .lvl-all-name { font-family:var(--serif); font-size:20px; font-weight:600; color:var(--text); }
  .lvl-all-sub { font-family:var(--body); font-size:11px; color:var(--muted); margin-top:2px; }
  .lvl-card.multi { cursor:pointer; }
  .lvl-card.multi.on { background:rgba(201,164,74,0.09); border-color:var(--gold-dim); }
  .lvl-check { width:24px; height:24px; flex-shrink:0; border-radius:6px; border:1.5px solid var(--border-2); background:var(--panel-2); display:flex; align-items:center; justify-content:center; color:#1a1206; font-size:15px; transition:background .15s, border-color .15s; }
  .lvl-card.multi.on .lvl-check { background:var(--gold); border-color:var(--gold); }
  .lvl-card.multi .lvl-check .ico { opacity:0; transition:opacity .15s; }
  .lvl-card.multi.on .lvl-check .ico { opacity:1; }
  .lvl-dot { width:9px; height:9px; border-radius:50%; flex-shrink:0; }
  .lvl-dot.lgreen { background:var(--sage); } .lvl-dot.lyellow { background:var(--gold); }
  .lvl-dot.lred { background:var(--terra); } .lvl-dot.lpurple { background:var(--rose); }
  .lvl-footer { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px max(24px,5vw); border-top:1px solid var(--border); flex-shrink:0; background:rgba(10,8,6,0.6); backdrop-filter:blur(8px); }
  .lvl-count { font-family:var(--body); font-size:12px; letter-spacing:.4px; color:var(--text-dim); }
  .lvl-count b { font-family:var(--display); font-size:18px; color:var(--gold); }
  .lvl-count .qest { color:var(--muted); }

  /* per-question results */
  #s-results { background:transparent; }
  .results-wrap { flex:1; min-height:0; display:grid; grid-template-columns:1.4fr 1fr; gap:0; }
  .results-main { padding:28px max(24px,4vw); display:flex; flex-direction:column; gap:18px; overflow-y:auto; min-width:0; }
  .results-q { font-family:var(--serif); font-size:clamp(22px,2.6vw,30px); font-weight:500; color:var(--text); line-height:1.25; text-wrap:balance; }
  .results-q em { color:var(--gold); font-style:italic; }
  .bar-chart { display:flex; flex-direction:column; gap:12px; }
  .bar-row { display:flex; align-items:center; gap:14px; }
  .bar-glyph { width:34px; height:34px; flex-shrink:0; border-radius:7px; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:16px; font-weight:700; color:#1a1206; }
  .bar-row:nth-child(1) .bar-glyph { background:var(--terra); } .bar-row:nth-child(2) .bar-glyph { background:var(--sky); }
  .bar-row:nth-child(3) .bar-glyph { background:var(--sage); } .bar-row:nth-child(4) .bar-glyph { background:var(--rose); }
  .bar-body { flex:1; min-width:0; }
  .bar-top { display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom:5px; }
  .bar-label { font-family:var(--serif); font-size:18px; font-weight:500; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .bar-count { font-family:var(--display); font-size:15px; font-weight:600; color:var(--muted); flex-shrink:0; }
  .bar-track { height:18px; border-radius:5px; background:var(--panel-3); border:1px solid var(--border); overflow:hidden; }
  .bar-fill { height:100%; width:0; border-radius:4px; background:rgba(201,164,74,0.3); transition:width .9s cubic-bezier(0.16,1,0.3,1); }
  .bar-row.correct .bar-fill { background:linear-gradient(90deg, var(--olive), var(--sage)); }
  .bar-row.correct .bar-label { color:var(--sage); }
  .bar-row.correct .bar-label::after { content:' ✓'; color:var(--sage); }
  .results-side { padding:28px 28px; border-left:1px solid var(--border); display:flex; flex-direction:column; min-width:0; }
  .results-side-title { font-family:var(--body); font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
  .mini-lb { display:flex; flex-direction:column; gap:7px; overflow-y:auto; flex:1; }
  .mini-row { display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:6px; background:rgba(255,255,255,0.022); border:1px solid var(--border); }
  .mini-row.up { border-color:var(--sage); background:rgba(142,186,114,0.06); }
  .mini-rank { font-family:var(--display); font-size:13px; font-weight:600; color:var(--muted); width:20px; flex-shrink:0; text-align:center; }
  .mini-av { width:28px; height:28px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:13px; font-weight:600; color:#1a1206; }
  .mini-name { flex:1; font-family:var(--serif); font-size:16px; font-weight:500; color:var(--text); min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .mini-score { font-family:var(--display); font-size:14px; font-weight:600; color:var(--gold); flex-shrink:0; }
  .mini-delta { font-family:var(--body); font-size:10px; font-weight:700; color:var(--sage); flex-shrink:0; }

  /* student answer screen */
  .sa-top { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid var(--border); flex-shrink:0; }
  .sa-q { font-family:var(--body); font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); }
  .sa-q b { color:var(--gold); font-family:var(--display); }
  .sa-timer { font-family:var(--display); font-size:18px; font-weight:600; color:var(--gold); }
  .sa-prompt { flex:1; display:flex; align-items:center; justify-content:center; padding:20px 24px; text-align:center; }
  .sa-prompt-text { font-family:var(--serif); font-size:24px; font-weight:500; color:var(--text); line-height:1.3; }
  .sa-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:14px 16px 18px; flex-shrink:0; }
  .sa-btn { aspect-ratio:1.5; border:none; border-radius:10px; cursor:pointer; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:30px; font-weight:700; color:#1a1206; position:relative; transition:transform .12s, filter .15s; }
  .sa-btn:active { transform:scale(.95); }
  .sa-btn.a { background:var(--terra); } .sa-btn.b { background:var(--sky); } .sa-btn.c { background:var(--sage); } .sa-btn.d { background:var(--rose); }
  .sa-btn.dim { filter:grayscale(.6) brightness(.6); }
  .sa-grid.locked .sa-btn { pointer-events:none; }
  .sa-feedback { position:absolute; inset:0; display:none; flex-direction:column; align-items:center; justify-content:center; gap:18px; z-index:8; padding:40px; text-align:center; }
  .sa-feedback.show { display:flex; animation:la-scr-in .4s ease; }
  .sa-feedback.correct { background:radial-gradient(ellipse at center, rgba(58,92,37,0.5), var(--base) 75%); }
  .sa-feedback.wrong { background:radial-gradient(ellipse at center, rgba(120,40,30,0.45), var(--base) 75%); }
  .sa-fb-ico { width:96px; height:96px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:48px; color:#1a1206; }
  .sa-feedback.correct .sa-fb-ico { background:var(--sage); box-shadow:0 0 50px rgba(142,186,114,0.6); }
  .sa-feedback.wrong .sa-fb-ico { background:#c0392b; box-shadow:0 0 50px rgba(192,57,43,0.5); }
  .sa-fb-title { font-family:var(--serif); font-size:34px; font-weight:600; color:var(--text); }
  .sa-fb-points { font-family:var(--display); font-size:18px; font-weight:600; color:var(--gold); }
  .sa-fb-rank { font-family:var(--body); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }

  /* ── Responsive ── */
  @media (max-width:900px) {
    .results-wrap { grid-template-columns:1fr; overflow-y:auto; }
    .results-side { border-left:none; border-top:1px solid var(--border); }
    .lobby-main { grid-template-columns:1fr; grid-template-rows:auto 1fr; overflow-y:auto; }
    .join-panel { border-bottom:1px solid var(--border); }
    .players-panel { min-height:260px; }
    .answers { grid-template-columns:1fr; }
    .crumbs .crumb-text { max-width:90px; }
  }
  @media (max-width:560px) {
    .topbar { padding:12px 14px; gap:10px; }
    .opt-row { flex-direction:column; align-items:flex-start; gap:10px; }
    .opt-control { justify-content:flex-start; width:100%; }
    .seg { justify-content:flex-start; }
    .lobby-footer, .setup-footer, .game-foot { flex-direction:column; align-items:stretch; }
    .start-btn { width:100%; }
    .brand-text { display:none; }
  }
}

/* confetti + toast live at body level in the reference; keep them scoped too */
#la-overlay.reimagined .confetti { position:fixed; inset:0; pointer-events:none; z-index:150; overflow:hidden; }
#la-overlay.reimagined .confetti i { position:absolute; top:-12px; width:9px; height:14px; opacity:.9; animation:la-confetti-fall linear forwards; }
#la-overlay.reimagined .toast { position:fixed; bottom:30px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--la-rx-panel-2); border:1px solid var(--la-rx-gold-dim); color:var(--la-rx-text); font-family:var(--la-rx-body); font-size:12px; letter-spacing:.4px; padding:11px 20px; border-radius:6px; z-index:200; opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; display:inline-flex; align-items:center; gap:9px; box-shadow:0 12px 40px rgba(0,0,0,0.5); }
#la-overlay.reimagined .toast .ico { color:var(--la-rx-gold); font-size:15px; display:inline-flex; }
#la-overlay.reimagined .toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
