/* ═══════════════════════════════════════════════════════════
   THEMES — 10 dark atmospheric variants
   ═══════════════════════════════════════════════════════════ */
:root,
body[data-theme="default"] {
  --bg:#0d1629; --card:#16213e; --card-alt:#1e2f52;
  --text:#e8f0ff; --muted:rgba(232,240,255,.52);
  --primary:#ff4757; --primary-sh:#7a1020;
  --secondary:#ffd32a; --secondary-sh:#8a6800;
  --danger:#ff4757; --danger-sh:#7a1020;
  --border:1px solid rgba(255,255,255,.09);
  --radius:16px;
  --glow:rgba(255,71,87,.28); --glow2:rgba(255,211,42,.10);
}
body[data-theme="neon-purple"] {
  --bg:#070410; --card:#0f0820; --card-alt:#180d30;
  --text:#ecdeff; --muted:rgba(236,222,255,.52);
  --primary:#b848ff; --primary-sh:#5c00a8;
  --secondary:#00d4f0; --secondary-sh:#007888;
  --danger:#ff3068; --danger-sh:#980040;
  --border:1px solid rgba(184,72,255,.18);
  --radius:16px;
  --glow:rgba(184,72,255,.32); --glow2:rgba(0,212,240,.12);
}
body[data-theme="movie-theater"] {
  --bg:#140800; --card:#1e1000; --card-alt:#2a1800;
  --text:#fff4e0; --muted:rgba(255,244,224,.52);
  --primary:#ff8800; --primary-sh:#6a3200;
  --secondary:#ffd700; --secondary-sh:#806800;
  --danger:#ff3820; --danger-sh:#980800;
  --border:1px solid rgba(255,136,0,.18);
  --radius:16px;
  --glow:rgba(255,136,0,.30); --glow2:rgba(255,215,0,.10);
}
body[data-theme="rustic-bar"] {
  --bg:#0e0c06; --card:#1a1810; --card-alt:#252018;
  --text:#f0dcc0; --muted:rgba(240,220,192,.52);
  --primary:#d09020; --primary-sh:#604000;
  --secondary:#e06840; --secondary-sh:#782818;
  --danger:#e05050; --danger-sh:#801818;
  --border:1px solid rgba(208,144,32,.18);
  --radius:16px;
  --glow:rgba(208,144,32,.28); --glow2:rgba(224,104,64,.10);
}
body[data-theme="dark-mode"] {
  --bg:#030408; --card:#07090f; --card-alt:#0d1020;
  --text:#c8d8f8; --muted:rgba(200,216,248,.52);
  --primary:#4898ff; --primary-sh:#0c3080;
  --secondary:#5060d0; --secondary-sh:#181e80;
  --danger:#ff5050; --danger-sh:#900808;
  --border:1px solid rgba(72,152,255,.15);
  --radius:16px;
  --glow:rgba(72,152,255,.28); --glow2:rgba(80,96,208,.10);
}
body[data-theme="slate-blue"] {
  --bg:#050e1c; --card:#0a1828; --card-alt:#102038;
  --text:#c0d8f8; --muted:rgba(192,216,248,.52);
  --primary:#3888e8; --primary-sh:#082890;
  --secondary:#40c8e8; --secondary-sh:#106090;
  --danger:#e83030; --danger-sh:#880000;
  --border:1px solid rgba(56,136,232,.18);
  --radius:16px;
  --glow:rgba(56,136,232,.28); --glow2:rgba(64,200,232,.10);
}
body[data-theme="soft-light"] {
  --bg:#130010; --card:#1e0018; --card-alt:#2a0024;
  --text:#fce8ff; --muted:rgba(252,232,255,.52);
  --primary:#ff48a8; --primary-sh:#800048;
  --secondary:#ff80cc; --secondary-sh:#902060;
  --danger:#ff3838; --danger-sh:#900000;
  --border:1px solid rgba(255,72,168,.18);
  --radius:16px;
  --glow:rgba(255,72,168,.32); --glow2:rgba(255,128,204,.10);
}
body[data-theme="forest"] {
  --bg:#020b04; --card:#071408; --card-alt:#0e2010;
  --text:#c8f0d0; --muted:rgba(200,240,208,.52);
  --primary:#28c840; --primary-sh:#065810;
  --secondary:#c8d800; --secondary-sh:#607000;
  --danger:#e83838; --danger-sh:#800808;
  --border:1px solid rgba(40,200,64,.16);
  --radius:16px;
  --glow:rgba(40,200,64,.28); --glow2:rgba(200,216,0,.10);
}
body[data-theme="ocean"] {
  --bg:#010810; --card:#041220; --card-alt:#081a30;
  --text:#a8d8f8; --muted:rgba(168,216,248,.52);
  --primary:#0090c8; --primary-sh:#002c68;
  --secondary:#0058a8; --secondary-sh:#001860;
  --danger:#ff4060; --danger-sh:#980028;
  --border:1px solid rgba(0,144,200,.18);
  --radius:16px;
  --glow:rgba(0,144,200,.30); --glow2:rgba(0,88,168,.12);
}
body[data-theme="volcanic"] {
  --bg:#0c0200; --card:#180400; --card-alt:#240800;
  --text:#ffe0c0; --muted:rgba(255,224,192,.52);
  --primary:#ff4808; --primary-sh:#780e00;
  --secondary:#ff8800; --secondary-sh:#783000;
  --danger:#ff2020; --danger-sh:#880000;
  --border:1px solid rgba(255,72,8,.18);
  --radius:16px;
  --glow:rgba(255,72,8,.30); --glow2:rgba(255,136,0,.12);
}

/* ═══════════════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════════════ */
*,*::before,*::after {
  box-sizing:border-box; margin:0; padding:0;
  font-family:'Poppins',sans-serif;
  transition:background-color .3s,color .3s,border-color .3s,box-shadow .3s;
}
html,body { height:100%; }
body { background:var(--bg); color:var(--text); min-height:100%; overflow-x:hidden; }

/* ═══════════════════════════════════════════════════════════
   GLOBAL ATMOSPHERIC BACKGROUND
   ═══════════════════════════════════════════════════════════ */
.global-bg { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.global-dotgrid {
  position:absolute; inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:28px 28px;
}
.global-glow { position:absolute; border-radius:50%; }
.global-glow-1 {
  top:-25%; left:-15%; width:65%; height:65%;
  background:radial-gradient(circle,var(--glow) 0%,transparent 68%);
  transition:background .6s;
}
.global-glow-2 {
  bottom:-20%; right:-10%; width:55%; height:60%;
  background:radial-gradient(circle,var(--glow2) 0%,transparent 68%);
  transition:background .6s;
}

/* ═══════════════════════════════════════════════════════════
   SCREENS
   ═══════════════════════════════════════════════════════════ */
.screen { display:none; position:relative; z-index:1; }
#auth-screen.active { display:flex; width:100%; min-height:100vh; }
#reminisce-screen.active {
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; min-height:100vh;
  padding:max(20px,env(safe-area-inset-top,0px)) max(20px,env(safe-area-inset-right,0px)) 20px max(20px,env(safe-area-inset-left,0px));
}
#home-screen.active { display:flex; flex-direction:column; height:100vh; align-items:stretch; overflow:hidden; }
.home-body {
  flex:1; display:flex; align-items:center; justify-content:center;
  padding:max(16px,env(safe-area-inset-top,16px)) max(20px,env(safe-area-inset-right,20px)) 12px max(20px,env(safe-area-inset-left,20px));
  overflow:hidden;
}
#room-screen.active,
#local-player-screen.active { display:flex; flex-direction:column; position:fixed; inset:0; overflow:hidden; }

/* ═══════════════════════════════════════════════════════════
   AUTH — split layout
   ═══════════════════════════════════════════════════════════ */
.auth-split { display:flex; width:100%; min-height:100vh; }

/* LEFT: brand panel */
.auth-brand-panel {
  flex:0 0 58%;
  position:relative; overflow:hidden;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  padding:48px 52px;
  border-right:1px solid rgba(255,255,255,.06);
}
.auth-brand-panel::before {
  content:''; position:absolute; top:-20%; left:-10%; width:70%; height:70%;
  background:radial-gradient(circle,var(--glow) 0%,transparent 65%);
  pointer-events:none;
}
.auth-brand-panel::after {
  content:''; position:absolute; bottom:-15%; right:5%; width:50%; height:60%;
  background:radial-gradient(circle,var(--glow2) 0%,transparent 65%);
  pointer-events:none;
}

/* floating emojis */
.auth-floaters { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.af { position:absolute; font-size:1.55rem; opacity:.5; user-select:none; animation:authFloat var(--dur,6s) ease-in-out infinite; animation-delay:var(--del,0s); }
.af-1{left:5%;top:12%;--dur:7s;--del:0s}
.af-2{left:88%;top:8%;--dur:5.5s;--del:1.2s}
.af-3{left:18%;top:82%;--dur:8s;--del:.4s}
.af-4{left:78%;top:75%;--dur:6.5s;--del:2s}
.af-5{left:45%;top:5%;--dur:7.5s;--del:.8s}
.af-6{left:92%;top:45%;--dur:6s;--del:1.8s}
.af-7{left:3%;top:52%;--dur:5s;--del:2.5s}
.af-8{left:60%;top:88%;--dur:9s;--del:.2s}
.af-9{left:30%;top:40%;--dur:6.8s;--del:3.1s;opacity:.18}
.af-10{left:72%;top:25%;--dur:7.2s;--del:1.5s}
@keyframes authFloat {
  0%,100%{transform:translateY(0) scale(1) rotate(-4deg)}
  33%{transform:translateY(-18px) scale(1.1) rotate(4deg)}
  66%{transform:translateY(8px) scale(.95) rotate(-2deg)}
}

/* brand content */
.auth-brand-inner { position:relative; z-index:2; max-width:520px; width:100%; display:flex; flex-direction:column; gap:26px; }
.auth-logo-wrap { display:flex; align-items:center; gap:16px; }
.auth-logo-icon { font-size:3rem; filter:drop-shadow(0 4px 12px var(--glow)); animation:authLogoPulse 3s ease-in-out infinite; }
@keyframes authLogoPulse { 0%,100%{transform:scale(1) rotate(-3deg)} 50%{transform:scale(1.12) rotate(3deg)} }
.auth-brand-title { font-family:'Fredoka One',cursive; font-size:3.2rem; color:var(--primary); text-shadow:3px 3px 0 rgba(0,0,0,.4); line-height:1; }
.auth-brand-tagline { font-size:1.05rem; color:rgba(255,255,255,.78); line-height:1.65; }
.auth-brand-tagline strong { color:var(--secondary); }
.auth-features-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.auth-feat-card {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09); border-radius:14px;
  padding:14px 16px; display:flex; align-items:flex-start; gap:12px;
  transition:background .2s,border-color .2s;
}
.auth-feat-card:hover { background:rgba(255,255,255,.09); border-color:rgba(255,255,255,.15); }
.af-icon { font-size:1.4rem; flex-shrink:0; margin-top:1px; }
.auth-feat-card strong { display:block; color:#fff; font-size:.86rem; font-weight:700; margin-bottom:3px; }
.auth-feat-card p { color:rgba(255,255,255,.55); font-size:.75rem; line-height:1.5; margin:0; }
.auth-player-row { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.auth-mock-bubble { display:flex; flex-direction:column; align-items:center; gap:6px; animation:authFloat 5s ease-in-out infinite; }
.auth-mock-bubble:nth-child(2){animation-delay:.8s}
.auth-mock-bubble:nth-child(3){animation-delay:1.4s}
.auth-mock-bubble:nth-child(4){animation-delay:.4s}
.auth-mock-bubble img { width:54px; height:54px; border-radius:50%; border:2px solid rgba(255,255,255,.2); background:var(--primary); object-fit:cover; box-shadow:0 4px 14px rgba(0,0,0,.4); }
.auth-mock-bubble span { font-size:.68rem; color:rgba(255,255,255,.7); font-weight:600; background:rgba(255,255,255,.08); border-radius:20px; padding:2px 10px; white-space:nowrap; }
.auth-mock-bubble--winner img { border-color:var(--secondary); box-shadow:0 0 0 3px var(--secondary),0 4px 18px rgba(0,0,0,.4); }
.auth-mock-bubble--winner span { background:rgba(255,255,255,.12); color:var(--secondary); }
.auth-brand-sub { font-size:.75rem; color:rgba(255,255,255,.3); letter-spacing:.03em; }

/* RIGHT: form panel */
.auth-form-panel {
  flex:1; background:var(--card);
  display:flex; flex-direction:column; align-items:stretch;
  position:relative; overflow:hidden;
}
.auth-form-panel::before {
  content:''; position:absolute; top:-80px; right:-80px; width:260px; height:260px;
  background:radial-gradient(circle,var(--glow) 0%,transparent 70%);
  opacity:.35; pointer-events:none;
}
.auth-mobile-brand { display:none; align-items:center; justify-content:center; gap:10px; padding:24px 24px 0; font-size:1.5rem; }
.auth-mobile-title { font-family:'Fredoka One',cursive; font-size:1.8rem; color:var(--primary); }
.auth-form-scroll { flex:1; display:flex; align-items:center; justify-content:center; padding:40px 44px; overflow-y:auto; }
.auth-form-card { width:100%; max-width:400px; display:flex; flex-direction:column; }
.auth-form-heading { font-family:'Fredoka One',cursive; font-size:1.9rem; color:var(--text); margin-bottom:4px; }
.auth-form-sub { font-size:.86rem; color:var(--muted); margin-bottom:24px; }
.auth-label { display:block; font-size:.75rem; font-weight:700; color:var(--muted); margin-bottom:5px; letter-spacing:.06em; text-transform:uppercase; }
.auth-switch-text { margin-top:14px; font-size:.86rem; color:var(--muted); text-align:center; }
.auth-link-btn { background:none; border:none; padding:0; font-size:.86rem; font-weight:800; font-family:'Poppins',sans-serif; color:var(--primary); cursor:pointer; text-decoration:underline; transition:opacity .15s; }
.auth-link-btn:hover { opacity:.7; }

/* ═══════════════════════════════════════════════════════════
   TYPOGRAPHY
   ═══════════════════════════════════════════════════════════ */
h1.game-title { font-family:'Fredoka One',cursive; font-size:2.8rem; color:var(--primary); text-shadow:3px 3px 0 rgba(0,0,0,.4); margin-bottom:20px; text-align:center; line-height:1.1; }
h2,h3 { font-family:'Fredoka One',cursive; margin-bottom:10px; }
.section-heading { font-family:'Fredoka One',cursive; font-size:1.4rem; color:var(--primary); margin-bottom:14px; }
.section-heading-sm { font-family:'Fredoka One',cursive; font-size:1.05rem; color:var(--text); margin-bottom:6px; opacity:.85; }

/* ═══════════════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════════════ */
.card {
  background:var(--card);
  border:var(--border);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:0 8px 40px rgba(0,0,0,.55),0 1px 0 rgba(255,255,255,.04);
  width:100%; max-width:500px; text-align:center;
  position:relative; overflow:hidden;
}
.card::before {
  content:''; position:absolute; top:0; left:10%; right:10%; height:1px;
  background:linear-gradient(90deg,transparent,var(--primary),transparent);
  opacity:.4;
}

/* ═══════════════════════════════════════════════════════════
   INPUTS
   ═══════════════════════════════════════════════════════════ */
.jackbox-input {
  width:100%; padding:13px 16px; margin-bottom:14px;
  border:1.5px solid rgba(255,255,255,.1); border-radius:10px;
  font-size:1.1rem; font-weight:600;
  background:rgba(0,0,0,.3); color:var(--text);
  transition:border-color .2s,box-shadow .2s;
}
.jackbox-input::placeholder { color:var(--muted); font-weight:400; }
.jackbox-input:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--glow); }
.jackbox-input:disabled { opacity:.45; cursor:not-allowed; }
.small-input { padding:9px 12px; font-size:.95rem; margin-bottom:0; }
.join-code-input { text-transform:uppercase; text-align:center; font-size:2rem!important; letter-spacing:12px; font-weight:900!important; }

/* ═══════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════ */
.jackbox-btn {
  width:100%; padding:14px; margin-bottom:14px;
  font-size:1.15rem; font-weight:800; font-family:'Fredoka One',cursive;
  border:none; border-radius:12px; cursor:pointer;
  transition:transform .1s,box-shadow .15s,filter .15s;
  text-decoration:none; display:block; text-align:center; letter-spacing:.01em;
}
.jackbox-btn:active { transform:translateY(4px)!important; box-shadow:none!important; filter:brightness(.9); }
.primary-btn   { background:var(--primary); color:#fff; box-shadow:0 5px 0 var(--primary-sh),0 0 20px var(--glow); }
.primary-btn:hover { filter:brightness(1.1); }
.secondary-btn { background:var(--secondary); color:#0d0d0d; box-shadow:0 5px 0 var(--secondary-sh); }
.secondary-btn:hover { filter:brightness(1.08); }
.danger-btn    { background:var(--danger); color:#fff; box-shadow:0 5px 0 var(--danger-sh); }
.danger-btn:hover { filter:brightness(1.1); }
.action-btn    { background:var(--primary); color:#fff; box-shadow:0 5px 0 var(--primary-sh),0 0 20px var(--glow); }
.disabled-btn  { background:rgba(255,255,255,.08); color:rgba(255,255,255,.3); box-shadow:none; cursor:not-allowed; }
.small-btn { width:auto; padding:9px 20px; font-size:.95rem; margin-bottom:0; display:inline-block; }
.mt-20 { margin-top:20px; }
.toggle-state-btn { display:flex; flex-direction:column; align-items:center; line-height:1.25; gap:1px; }
.toggle-state-btn span:first-child { font-size:.75rem; opacity:.75; font-weight:600; }
.toggle-state-btn span:last-child { font-size:1rem; font-weight:900; letter-spacing:.04em; }
body[data-theme="dark-mode"] .secondary-btn,
body[data-theme="ocean"] .secondary-btn,
body[data-theme="forest"] .secondary-btn { color:#fff; }

/* compact room buttons */
.r-btn { font-family:'Fredoka One',cursive; font-size:.95rem; font-weight:800; padding:9px 20px; border:none; border-radius:10px; cursor:pointer; white-space:nowrap; transition:transform .1s,box-shadow .15s,filter .15s; }
.r-btn:active { transform:translateY(3px)!important; box-shadow:none!important; }
.r-btn.primary-btn   { background:var(--primary); color:#fff; box-shadow:0 4px 0 var(--primary-sh),0 0 14px var(--glow); }
.r-btn.secondary-btn { background:var(--secondary); color:#0d0d0d; box-shadow:0 4px 0 var(--secondary-sh); }
.r-btn.danger-btn    { background:var(--danger); color:#fff; box-shadow:0 4px 0 var(--danger-sh); }
body[data-theme="dark-mode"] .r-btn.secondary-btn,
body[data-theme="ocean"] .r-btn.secondary-btn,
body[data-theme="forest"] .r-btn.secondary-btn { color:#fff; }
.big-footer-btn { font-size:1.1rem; padding:11px 36px; }
.hidden { display:none!important; }

/* ═══════════════════════════════════════════════════════════
   AUTH HELPERS
   ═══════════════════════════════════════════════════════════ */
.signup-avatar-wrapper {
  position:relative; width:90px; height:90px; margin:0 auto 6px;
  border-radius:50%; border:2px solid rgba(255,255,255,.15);
  overflow:hidden; cursor:pointer; background:var(--primary);
  box-shadow:0 0 0 0 var(--glow); transition:box-shadow .3s;
}
.signup-avatar-wrapper:hover { box-shadow:0 0 0 4px var(--glow); }
.signup-avatar-wrapper img { width:100%; height:100%; object-fit:cover; display:block; }
.avatar-required-hint { font-size:.75rem; color:var(--danger); margin-bottom:10px; font-weight:600; opacity:0; transition:opacity .25s; text-align:center; }
.avatar-required-hint.show { opacity:1; }
.tos-check-row { display:flex; align-items:flex-start; gap:10px; text-align:left; margin-bottom:6px; margin-top:2px; }
.tos-checkbox { width:18px; height:18px; flex-shrink:0; margin-top:2px; accent-color:var(--primary); cursor:pointer; }
.tos-label { font-size:.82rem; line-height:1.55; cursor:pointer; color:var(--muted); }
.tos-hint { font-size:.75rem; color:var(--danger); font-weight:600; margin-bottom:8px; opacity:0; transition:opacity .25s; }
.tos-hint.show { opacity:1; }

/* ═══════════════════════════════════════════════════════════
   HOME LAYOUT
   ═══════════════════════════════════════════════════════════ */
.home-layout { display:flex; width:100%; max-width:1100px; gap:24px; align-items:stretch; height:95%; }
.home-layout .card { max-width:100%; flex:1; display:flex; flex-direction:column; justify-content:center; overflow:hidden; }
.profile-col { flex:0 0 auto; width:330px; max-width:330px; overflow:hidden; }
.home-right-col { flex:1; display:flex; flex-direction:column; gap:20px; min-height:0; }
.menu-col { max-width:100%; width:100%; overflow:hidden; }
.utilities-col { max-width:100%; width:100%; flex:1; overflow:hidden; }
.utilities-title { font-size:2rem; margin-bottom:12px; }
.utilities-buttons { display:flex; flex-direction:column; }
.utilities-buttons .jackbox-btn:last-child { margin-bottom:0; }

/* Avatar */
.profile-avatar-wrapper {
  position:relative; width:130px; height:130px; flex-shrink:0; margin:0 auto 18px;
  border-radius:50%; border:2px solid rgba(255,255,255,.12);
  overflow:hidden; cursor:pointer; background:var(--primary);
  box-shadow:0 0 0 4px var(--glow),0 8px 24px rgba(0,0,0,.4);
  transition:box-shadow .3s;
}
.profile-avatar-wrapper:hover { box-shadow:0 0 0 6px var(--glow),0 8px 24px rgba(0,0,0,.5); }
.profile-avatar-wrapper img,.signup-avatar-wrapper img { width:100%; height:100%; object-fit:cover; display:block; }
.edit-overlay { position:absolute; bottom:0; left:0; width:100%; background:rgba(0,0,0,.7); color:#fff; font-size:.85rem; font-weight:bold; padding:7px 0; transform:translateY(100%); transition:transform .2s; }
.profile-avatar-wrapper:hover .edit-overlay,
.signup-avatar-wrapper:hover .edit-overlay { transform:translateY(0); }
.profile-details { text-align:left; margin-bottom:12px; flex-shrink:0; }
.profile-details label { font-weight:700; font-size:.78rem; margin-bottom:4px; display:block; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; }
.input-group { display:flex; gap:8px; margin-bottom:12px; }
.liked-count-row { display:flex; align-items:center; justify-content:center; gap:8px; background:rgba(0,0,0,.2); border:var(--border); border-radius:12px; padding:8px 16px; margin-bottom:4px; flex-shrink:0; }
.liked-count-label { font-size:.82rem; font-weight:600; color:var(--muted); }
.liked-count-num { font-family:'Fredoka One',cursive; font-size:1.3rem; color:var(--primary); min-width:28px; text-align:center; text-shadow:0 0 10px var(--glow); }

/* compact viewports */
@media(max-height:820px) and (min-width:900px) {
  .home-body{padding-top:max(10px,env(safe-area-inset-top,10px));padding-bottom:8px}
  .home-layout{gap:16px}
  .home-layout .card{padding:20px 22px}
  .profile-avatar-wrapper{width:96px;height:96px;margin-bottom:10px}
  .profile-details{margin-bottom:8px}
  .profile-details label{margin-bottom:2px;font-size:.74rem}
  .input-group{margin-bottom:8px}
  .liked-count-row{padding:5px 12px;margin-bottom:2px}
  .liked-count-num{font-size:1.05rem}
  h1.game-title{font-size:2.2rem;margin-bottom:12px}
  h2{font-size:1.15rem;margin-bottom:5px}
  h3{margin-bottom:5px}
  .jackbox-btn{padding:10px;margin-bottom:9px;font-size:1rem}
  .jackbox-input{padding:9px 12px;margin-bottom:9px;font-size:.95rem}
  .small-input{padding:7px 10px}
  .input-group{gap:6px}
  .theme-selector,.sound-selector{margin:2px 0 5px;gap:5px}
  .theme-btn,.sound-btn{width:26px;height:26px}
  .utilities-title{font-size:1.7rem;margin-bottom:8px}
  .small-btn{padding:7px 14px;font-size:.85rem}
  .mt-20{margin-top:12px}
  .home-right-col{gap:14px}
}

/* ═══════════════════════════════════════════════════════════
   HOME FOOTER
   ═══════════════════════════════════════════════════════════ */
.home-footer { flex-shrink:0; width:100%; background:var(--card); border-top:var(--border); padding:10px max(20px,env(safe-area-inset-right,20px)) max(10px,env(safe-area-inset-bottom,10px)) max(20px,env(safe-area-inset-left,20px)); }
.home-footer-inner { max-width:1100px; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.footer-copy { font-family:'Fredoka One',cursive; font-size:.82rem; color:var(--muted); white-space:nowrap; }
.footer-links { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.footer-link-btn { background:none; border:none; cursor:pointer; font-family:'Poppins',sans-serif; font-size:.78rem; font-weight:700; color:var(--primary); text-decoration:underline; padding:2px 0; transition:opacity .15s; }
.footer-link-btn:hover { opacity:.7; }
.footer-sep { font-size:.78rem; color:var(--muted); user-select:none; }

/* ═══════════════════════════════════════════════════════════
   GAME MODE LOCK
   ═══════════════════════════════════════════════════════════ */
.game-mode-wrapper { position:relative; width:100%; }
.menu-buttons { display:flex; flex-direction:column; }
.game-mode-lock-overlay { position:absolute; inset:0; background:rgba(0,0,0,.78); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); border-radius:var(--radius); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:20px; border:var(--border); z-index:10; }
.lock-icon { font-size:2.8rem; line-height:1; }
.lock-msg { font-family:'Fredoka One',cursive; font-size:.95rem; color:var(--text); text-align:center; opacity:.9; line-height:1.4; }
.mode-locked { opacity:.3; pointer-events:none; }

/* ═══════════════════════════════════════════════════════════
   THEME SWATCHES
   ═══════════════════════════════════════════════════════════ */
.theme-selector { display:flex; flex-wrap:wrap; justify-content:center; gap:6px; margin:4px 0 8px; }
.theme-btn { width:28px; height:28px; border-radius:50%; border:2px solid rgba(255,255,255,.2); cursor:pointer; transition:transform .2s,box-shadow .2s; flex-shrink:0; }
.theme-btn:hover { transform:scale(1.22); box-shadow:0 4px 12px rgba(0,0,0,.5); }
.theme-btn[data-theme="default"]      { background:linear-gradient(135deg,#0d1629 50%,#ff4757 50%); }
.theme-btn[data-theme="neon-purple"]  { background:linear-gradient(135deg,#070410 50%,#b848ff 50%); }
.theme-btn[data-theme="movie-theater"]{ background:linear-gradient(135deg,#140800 50%,#ff8800 50%); }
.theme-btn[data-theme="rustic-bar"]   { background:linear-gradient(135deg,#0e0c06 50%,#d09020 50%); }
.theme-btn[data-theme="dark-mode"]    { background:linear-gradient(135deg,#030408 50%,#4898ff 50%); }
.theme-btn[data-theme="slate-blue"]   { background:linear-gradient(135deg,#050e1c 50%,#3888e8 50%); }
.theme-btn[data-theme="soft-light"]   { background:linear-gradient(135deg,#130010 50%,#ff48a8 50%); }
.theme-btn[data-theme="forest"]       { background:linear-gradient(135deg,#020b04 50%,#28c840 50%); }
.theme-btn[data-theme="ocean"]        { background:linear-gradient(135deg,#010810 50%,#0090c8 50%); }
.theme-btn[data-theme="volcanic"]     { background:linear-gradient(135deg,#0c0200 50%,#ff4808 50%); }

/* ═══════════════════════════════════════════════════════════
   SOUND SELECTOR
   ═══════════════════════════════════════════════════════════ */
.sound-selector { display:flex; flex-wrap:wrap; justify-content:center; gap:6px; margin:4px 0 8px; }
.sound-btn { width:28px; height:28px; border-radius:50%; border:2px solid rgba(255,255,255,.15); cursor:pointer; font-size:.8rem; line-height:1; display:flex; align-items:center; justify-content:center; transition:transform .2s,box-shadow .2s,border-color .15s; flex-shrink:0; background:rgba(255,255,255,.06); }
.sound-btn:hover { transform:scale(1.22); box-shadow:0 4px 12px rgba(0,0,0,.4); }
.sound-btn-active { border-color:var(--primary)!important; box-shadow:0 0 0 2px var(--glow),0 4px 12px rgba(0,0,0,.3)!important; transform:scale(1.1); }

/* ═══════════════════════════════════════════════════════════
   REMINISCE
   ═══════════════════════════════════════════════════════════ */
.reminisce-layout { display:flex; width:100%; gap:20px; align-items:stretch; height:85vh; }
.rem-side-col { flex:1; display:flex; align-items:center; justify-content:center; }
.rem-panel { width:100%; max-width:220px; display:flex; flex-direction:column; align-items:center; gap:12px; background:var(--card); border:var(--border); border-radius:var(--radius); box-shadow:0 8px 32px rgba(0,0,0,.5); padding:26px 18px; text-align:center; }
.rem-panel .jackbox-btn { width:100%; margin-bottom:0; }
.rem-video-col { flex:2; display:flex; align-items:center; justify-content:center; }
.avatar-container { width:100px; height:100px; border-radius:50%; border:2px solid rgba(255,255,255,.15); overflow:hidden; background:var(--primary); display:flex; align-items:center; justify-content:center; box-shadow:0 0 0 3px var(--glow); }
.avatar-container img { width:100%; height:100%; object-fit:cover; display:block; }
.rem-nameplate { background:var(--primary); color:#fff; padding:7px 20px; border-radius:50px; box-shadow:0 3px 12px var(--glow); }
.rem-nameplate h2 { margin:0; font-size:.95rem; color:inherit; }
.stats-box { text-align:center; }
.stats-box h3 { font-family:'Fredoka One',cursive; font-size:.9rem; color:var(--muted); margin-bottom:2px; }
#video-count { font-size:2.2rem; font-weight:800; color:var(--primary); font-family:'Fredoka One',cursive; text-shadow:0 0 12px var(--glow); }
.video-frame { width:100%; height:100%; background:#000; border:var(--border); border-radius:var(--radius); box-shadow:0 8px 40px rgba(0,0,0,.6); position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
#video-placeholder { color:rgba(255,255,255,.55); font-family:'Fredoka One',cursive; font-size:1.3rem; z-index:5; text-align:center; padding:20px; }
#tiktok-embed-container { position:absolute; inset:0; width:100%; height:100%; }
.back-btn { position:absolute; top:max(20px,env(safe-area-inset-top,20px)); left:max(20px,env(safe-area-inset-left,20px)); z-index:100; }

/* ═══════════════════════════════════════════════════════════
   ROOM TOPBAR
   ═══════════════════════════════════════════════════════════ */
.room-topbar { flex-shrink:0; height:calc(60px + env(safe-area-inset-top,0px)); display:grid; grid-template-columns:1fr auto 1fr; align-items:end; gap:8px; padding:0 14px; padding-top:env(safe-area-inset-top,0px); padding-bottom:10px; background:var(--card); border-bottom:var(--border); z-index:200; }
.topbar-left  { display:flex; align-items:center; gap:10px; justify-content:flex-start; overflow:hidden; }
.topbar-right { display:flex; align-items:center; gap:10px; justify-content:flex-end; overflow:hidden; }
.room-phase-text { font-family:'Fredoka One',cursive; font-size:1.05rem; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-align:center; pointer-events:none; }
.room-code-badge { display:flex; align-items:center; font-family:'Fredoka One',cursive; font-size:.85rem; background:rgba(0,0,0,.3); border:var(--border); border-radius:30px; padding:5px 14px; flex-shrink:0; white-space:nowrap; color:var(--text); }
.room-code-badge span { color:var(--primary); font-size:1rem; letter-spacing:3px; font-weight:800; text-shadow:0 0 8px var(--glow); }
.room-round-badge { font-family:'Fredoka One',cursive; font-size:.88rem; color:#fff; background:var(--primary); border-radius:30px; padding:5px 14px; flex-shrink:0; white-space:nowrap; box-shadow:0 0 12px var(--glow); }
.settings-gear-btn { width:40px; height:40px; background:rgba(255,255,255,.07); border:var(--border); border-radius:50%; font-size:1.2rem; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 8px rgba(0,0,0,.3); transition:transform .35s,background .2s; flex-shrink:0; color:var(--text); }
.settings-gear-btn:hover { transform:rotate(72deg); background:rgba(255,255,255,.12); }

/* ═══════════════════════════════════════════════════════════
   ROOM BODY
   ═══════════════════════════════════════════════════════════ */
.room-body { flex:1; display:flex; overflow:hidden; background:var(--bg); position:relative; }
.room-player-col { width:25%; flex-shrink:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:28px; padding:14px 8px; overflow-y:auto; }
.room-center-col { width:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; padding:8px; overflow:hidden; position:relative; }
.room-video-wrapper { position:relative; height:100%; max-width:100%; background:#000; border:var(--border); border-radius:var(--radius); box-shadow:0 8px 40px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04); overflow:hidden; transition:opacity .4s ease; width:100%; }
.room-video-wrapper.fade-out { opacity:0; pointer-events:none; }
.room-tiktok-inner { position:absolute; inset:0; width:100%; height:100%; }
.room-tiktok-inner iframe { width:100%; height:100%; border:none; }
.room-video-ph { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,.85); z-index:5; }
#room-ph-text { color:var(--muted); font-family:'Fredoka One',cursive; font-size:1.1rem; text-align:center; padding:20px; }
.host-reveal-overlay { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; background:var(--bg); z-index:10; padding:20px; }
.host-reveal-text { font-family:'Fredoka One',cursive; font-size:2.2rem; color:var(--primary); text-align:center; line-height:1.3; text-shadow:0 0 20px var(--glow); transition:all .6s cubic-bezier(.4,0,.2,1); }
.host-reveal-sub { font-family:'Fredoka One',cursive; font-size:1.1rem; color:var(--text); opacity:.7; text-align:center; margin-top:12px; transition:opacity .4s ease; }
.host-reveal-overlay.text-top { justify-content:flex-start; padding-top:50px; pointer-events:none; }
.host-reveal-overlay.text-top .host-reveal-text { font-size:2.2rem; }
.host-reveal-overlay.text-top .host-reveal-sub { opacity:1; margin-top:10px; font-size:1.3rem; }

/* ═══════════════════════════════════════════════════════════
   ROOM FOOTER
   ═══════════════════════════════════════════════════════════ */
.room-footer { flex-shrink:0; height:calc(66px + env(safe-area-inset-bottom,0px)); background:var(--card); border-top:var(--border); display:flex; align-items:center; justify-content:space-between; padding:0 18px; padding-bottom:env(safe-area-inset-bottom,0px); z-index:100; }
.footer-left  { flex:1; }
.footer-center { flex:1; display:flex; align-items:center; justify-content:center; gap:10px; }
.footer-right  { flex:1; display:flex; align-items:center; justify-content:flex-end; gap:10px; }

/* ═══════════════════════════════════════════════════════════
   COL BUBBLES
   ═══════════════════════════════════════════════════════════ */
.col-bubble { display:flex; flex-direction:column; align-items:center; gap:10px; animation:floatBob 3s ease-in-out infinite; flex-shrink:0; position:relative; }
@keyframes floatBob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.bub-ring { width:110px; height:110px; border-radius:50%; border:3px solid rgba(255,255,255,.18); overflow:hidden; display:flex; align-items:center; justify-content:center; flex-shrink:0; background:var(--card); box-shadow:0 6px 18px rgba(0,0,0,.4); transition:box-shadow .25s ease,transform .25s ease; position:relative; }
.bub-ring img { width:110px; height:110px; object-fit:cover; display:block; flex-shrink:0; }
.bub-ring.voted-ring { box-shadow:0 0 0 5px var(--ring-color,var(--primary)),0 0 22px var(--ring-color,var(--primary)),0 6px 18px rgba(0,0,0,.4); transform:scale(1.06); }
.bub-ring.owner-glow { animation:ownerGlow 1.4s ease-in-out infinite; }
@keyframes ownerGlow { 0%,100%{box-shadow:0 0 0 4px var(--primary),0 0 18px var(--primary)} 50%{box-shadow:0 0 0 8px var(--primary),0 0 48px var(--primary)} }
.bub-ring.gold-ring { border-color:#f5c000; box-shadow:0 0 0 5px #f5c000,0 0 32px rgba(245,192,0,.65); }
.bub-ring.winner-idle { animation:winnerIdle 3.4s ease-in-out infinite; }
@keyframes winnerIdle {
  0%,50%{transform:translateY(0) rotateY(0deg)} 52%{transform:translateY(-6px) rotateY(0deg)}
  55%{transform:translateY(-18px) rotateY(90deg)} 60%{transform:translateY(-24px) rotateY(180deg)}
  65%{transform:translateY(-18px) rotateY(270deg)} 70%{transform:translateY(-8px) rotateY(360deg)}
  74%{transform:translateY(0) rotateY(360deg)} 78%{transform:translateY(-5px) rotateY(360deg)}
  82%{transform:translateY(0) rotateY(360deg)} 100%{transform:translateY(0) rotateY(360deg)}
}
.bub-plate { padding:5px 14px; border:2px solid transparent; border-radius:30px; font-weight:700; font-size:.8rem; white-space:nowrap; max-width:150px; overflow:hidden; text-overflow:ellipsis; display:flex; align-items:center; gap:5px; box-shadow:0 3px 10px rgba(0,0,0,.3); }
.bub-tick { font-weight:900; font-size:.75rem; display:none; }
.bub-skip { font-size:.72rem; display:none; }
/* Badge appears centered ABOVE the avatar ring, styled like a smaller nameplate pill */
.bub-badge {
  position:absolute; top:0; left:50%;
  padding:4px 13px;
  font-family:'Fredoka One',cursive; font-size:.78rem; font-weight:700;
  background:#22c55e; color:#fff;
  border:2px solid rgba(255,255,255,.25); border-radius:30px;
  display:none; white-space:nowrap;
  animation:badgePop .4s cubic-bezier(.175,.885,.32,1.275) forwards;
  box-shadow:0 3px 10px rgba(0,0,0,.35); pointer-events:none; z-index:10;
}
/* translate is baked into the keyframe so it persists via animation-fill-mode:forwards
   even when the parent bubble is scaled (the translate is in the parent's local space
   and correctly positions the badge above the visual ring at any scale) */
@keyframes badgePop {
  0%  { transform:translateX(-50%) translateY(-100%) scale(0) rotate(-8deg); opacity:0; }
  100%{ transform:translateX(-50%) translateY(-100%) scale(1) rotate(0deg);  opacity:1; }
}
.s-score { font-family:'Fredoka One',cursive; font-size:.85rem; color:var(--primary); margin-top:2px; text-align:center; text-shadow:0 0 8px var(--glow); }
.win-crown { font-size:2rem; position:absolute; top:-44px; left:50%; transform:translateX(-50%); pointer-events:none; animation:crownDrop .65s cubic-bezier(.175,.885,.32,1.275) .3s both; }
@keyframes crownDrop { 0%{transform:translateX(-50%) translateY(-30px) scale(0);opacity:0} 100%{transform:translateX(-50%) translateY(0) scale(1);opacity:1} }

/* ═══════════════════════════════════════════════════════════
   BUBBLE STAGE
   ═══════════════════════════════════════════════════════════ */
#bubble-stage { position:fixed; inset:0; z-index:500; pointer-events:none; overflow:visible; }
/* Fixed width so offsetWidth is always 150px — ring (110px) and plate (max 150px) both fit.
   All JS centering code reads this via offsetWidth for reliable pixel-perfect placement. */
.s-bubble { position:fixed; width:150px; display:flex; flex-direction:column; align-items:center; gap:10px; pointer-events:none; z-index:501; perspective:600px; }
.s-bubble.clickable { pointer-events:auto; cursor:pointer; }
.s-bubble.clickable:hover .bub-ring { box-shadow:0 8px 28px rgba(0,0,0,.4),0 0 0 3px var(--primary); transform:scale(1.05); }

/* ═══════════════════════════════════════════════════════════
   PHASE TEXT
   ═══════════════════════════════════════════════════════════ */
@keyframes phasePulse { 0%,100%{opacity:1} 50%{opacity:.5} }
.phase-selecting { animation:phasePulse .9s ease-in-out infinite; color:var(--primary)!important; }
@keyframes urgentFlash { 0%,100%{color:var(--text)} 50%{color:var(--danger)} }
.phase-urgent { animation:urgentFlash .5s ease-in-out infinite; }

/* ═══════════════════════════════════════════════════════════
   LOCAL PLAYER SCREEN
   ═══════════════════════════════════════════════════════════ */
#local-player-screen.active { background:var(--bg); }
.lp-topbar { flex-shrink:0; height:calc(58px + env(safe-area-inset-top,0px)); display:grid; grid-template-columns:auto 1fr auto; align-items:end; gap:6px; padding:0 10px; padding-top:env(safe-area-inset-top,0px); padding-bottom:8px; background:var(--card); border-bottom:var(--border); z-index:200; }
.lp-top-left  { display:flex; align-items:center; }
.lp-top-center { text-align:center; overflow:hidden; }
.lp-top-right  { display:flex; align-items:center; justify-content:flex-end; }
.lp-title { font-family:'Fredoka One',cursive; font-size:1.05rem; color:var(--primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-shadow:0 0 10px var(--glow); }
.lp-code-badge { font-size:.72rem; padding:4px 10px; }
.lp-code-badge span { font-size:.82rem; letter-spacing:2px; }
.lp-leave-btn { padding:7px 14px; font-size:.88rem; }
.lp-status-bar { flex-shrink:0; min-height:38px; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:5px 16px; background:var(--card); border-bottom:var(--border); gap:2px; }
.lp-status-text { display:none; }
.lp-round-badge { font-family:'Fredoka One',cursive; font-size:.8rem; color:#fff; background:var(--primary); border-radius:20px; padding:3px 12px; box-shadow:0 0 10px var(--glow); }
.lp-body { flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:14px 10px; display:flex; flex-direction:column; }
.lp-players-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; width:100%; }
@media(min-width:400px){.lp-players-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:600px){.lp-players-grid{grid-template-columns:repeat(4,1fr)}}
.lp-player-card { display:flex; flex-direction:column; align-items:center; gap:7px; padding:12px 6px; background:var(--card); border:var(--border); border-radius:14px; cursor:default; user-select:none; transition:transform .15s,box-shadow .15s,border-color .15s; position:relative; -webkit-tap-highlight-color:transparent; }
.lp-player-card.voting-active { cursor:pointer; }
.lp-player-card.voting-active:active { transform:scale(.95); }
.lp-player-card.voted-for { border-color:var(--primary)!important; box-shadow:0 0 0 2px var(--glow),0 4px 16px rgba(0,0,0,.3); transform:scale(1.04); }
.lp-player-card.voted-other { opacity:.45; }
.lp-ring { width:68px; height:68px; border-radius:50%; overflow:hidden; border:2px solid rgba(255,255,255,.15); flex-shrink:0; background:var(--card); }
.lp-ring img { width:100%; height:100%; object-fit:cover; display:block; }
.lp-name { font-weight:700; font-size:.75rem; text-align:center; max-width:80px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lp-score-badge { display:none!important; }
.lp-footer { flex-shrink:0; background:var(--card); border-top:var(--border); display:flex; align-items:center; justify-content:center; padding:12px 20px; padding-bottom:max(16px,env(safe-area-inset-bottom,16px)); }
.lp-footer-inner { display:flex; gap:10px; align-items:center; }
.lp-skip-btn { font-size:.92rem; padding:10px 20px; }

/* ─── LP multi-vote hint ─── */
.lp-vote-hint { font-family:'Fredoka One',cursive; font-size:.78rem; color:var(--primary); text-align:center; padding:2px 0 6px; opacity:.9; letter-spacing:.01em; }

/* ═══════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════ */
.modal { 
  position:fixed; inset:0; 
  background:rgba(0,0,0,.95);
  display:flex; align-items:center; justify-content:center; 
  z-index:1000; 
  padding:max(16px,env(safe-area-inset-top,16px)) max(16px,env(safe-area-inset-right,16px)) max(16px,env(safe-area-inset-bottom,16px)) max(16px,env(safe-area-inset-left,16px));
  transform: translateZ(0); 
  will-change: opacity;
}
.modal.hidden { display:none; }
.modal-content { max-width:600px; width:100%; max-height:calc(100dvh - 32px); overflow-y:auto; }
.online-modal-card { max-width:700px; padding:32px 28px; }
.online-modal-cols { display:flex; align-items:stretch; margin:18px 0; }
.online-col { flex:1; padding:14px 18px; display:flex; flex-direction:column; align-items:center; gap:10px; }
.online-col h3 { font-family:'Fredoka One',cursive; font-size:1.4rem; color:var(--primary); }
.col-desc { font-size:.84rem; color:var(--muted); text-align:center; line-height:1.5; }
.online-col-divider { width:1px; background:rgba(255,255,255,.08); margin:10px 0; flex-shrink:0; }
.created-room-code-display { width:100%; padding:16px; background:rgba(0,0,0,.3); border:var(--border); border-radius:12px; text-align:center; animation:fadeInUp .4s ease forwards; }
.created-room-code-display p { font-size:.84rem; font-weight:600; margin-bottom:4px; color:var(--muted); }
.big-room-code { font-family:'Fredoka One',cursive; font-size:2.8rem; color:var(--primary); letter-spacing:10px; text-shadow:0 0 20px var(--glow); }
.share-hint { font-size:.75rem; color:var(--muted); margin-top:4px; }
.avatar-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:16px; }
.avatar-option { width:100%; aspect-ratio:1; border-radius:50%; border:2px solid rgba(255,255,255,.12); cursor:pointer; background:var(--card); transition:transform .2s,box-shadow .2s; display:block; object-fit:cover; }
.avatar-option:hover { transform:scale(1.1); box-shadow:0 0 0 3px var(--glow); }
.preview-frame { width:100%; aspect-ratio:9/16; max-height:40vh; background:#000; border:var(--border); border-radius:8px; margin:18px 0; position:relative; overflow:hidden; }
.modal-actions { display:flex; gap:10px; justify-content:center; }
.settings-row { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; text-align:left; }
.settings-label { font-family:'Fredoka One',cursive; font-size:1.05rem; color:var(--text); display:flex; align-items:center; gap:6px; }
.settings-input { font-size:1.2rem!important; text-align:center; font-weight:900!important; padding:10px!important; }
.settings-note { font-size:.84rem; color:var(--muted); font-style:italic; margin-bottom:10px; }
.auto-next-controls { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.auto-next-toggle-btn { width:auto; margin-bottom:0; padding:9px 18px; font-size:.9rem; min-width:130px; display:inline-flex; flex-direction:column; align-items:center; }
.reveal-time-inline { display:flex; flex-direction:column; gap:4px; align-items:center; }
.reveal-time-label { font-family:'Fredoka One',cursive; font-size:.78rem; color:var(--muted); white-space:nowrap; }
.reveal-time-input { width:80px!important; font-size:1rem!important; padding:7px!important; }
.reveal-time-input:disabled { opacity:.35; }

/* ─── Settings tooltip ─── */
.setting-info-tooltip {
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  width:20px; height:20px; border-radius:50%;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18);
  font-size:.75rem; cursor:help; color:var(--muted);
  flex-shrink:0; font-style:normal; font-family:'Poppins',sans-serif;
}
.setting-info-tooltip:hover,
.setting-info-tooltip:focus { background:rgba(255,255,255,.2); outline:none; }
.tooltip-bubble {
  position:absolute; bottom:calc(100% + 8px); left:50%;
  transform:translateX(-50%);
  background:var(--card-alt); color:var(--text);
  font-size:.76rem; font-family:'Poppins',sans-serif; font-weight:500; font-style:normal;
  padding:9px 13px; border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  width:220px; text-align:center;
  opacity:0; pointer-events:none;
  transition:opacity .18s ease;
  z-index:200; line-height:1.55;
  box-shadow:0 6px 20px rgba(0,0,0,.5);
  white-space:normal;
}
.tooltip-bubble::after {
  content:''; position:absolute; top:100%; left:50%; transform:translateX(-50%);
  border:5px solid transparent; border-top-color:var(--card-alt);
}
.setting-info-tooltip:hover .tooltip-bubble,
.setting-info-tooltip:focus .tooltip-bubble { opacity:1; }

.tiktok-modal-card { max-width:640px; padding:32px 28px; text-align:left; }
.tiktok-modal-card h2 { text-align:center; margin-bottom:16px; }
.tiktok-intro { font-size:.9rem; line-height:1.65; margin-bottom:18px; color:var(--muted); }
.tiktok-steps { padding-left:20px; display:flex; flex-direction:column; gap:12px; margin-bottom:22px; }
.tiktok-steps li { font-size:.88rem; line-height:1.6; color:var(--text); }
.tiktok-link { color:var(--primary); font-weight:700; text-decoration:underline; }
.tiktok-dl-btn { margin-bottom:10px; }
.feedback-modal-card { max-width:520px; padding:32px 28px; text-align:left; }
.feedback-modal-card h2 { text-align:center; margin-bottom:12px; }
.feedback-intro { font-size:.88rem; line-height:1.6; color:var(--muted); margin-bottom:16px; }
.feedback-textarea { width:100%; min-height:130px; resize:vertical; font-size:.95rem!important; padding:12px!important; line-height:1.55; margin-bottom:0; border:1.5px solid rgba(255,255,255,.1); border-radius:8px; background:rgba(0,0,0,.3); color:var(--text); }
.feedback-textarea:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--glow); }
.feedback-confirm { display:flex; align-items:center; gap:10px; background:rgba(34,197,94,.12); border:1.5px solid #22c55e; border-radius:10px; padding:12px 16px; margin-top:12px; font-family:'Fredoka One',cursive; font-size:.95rem; color:#4ade80; }
.feedback-confirm-icon { font-size:1.3rem; color:#4ade80; }
.legal-modal-card { max-width:680px; padding:32px 28px; text-align:left; }
.legal-modal-card h2 { text-align:center; margin-bottom:6px; }
.legal-date { margin-bottom:16px; color:var(--muted); font-size:.82rem; }
.legal-body { display:flex; flex-direction:column; gap:8px; }
.legal-body h3 { font-family:'Fredoka One',cursive; font-size:1rem; color:var(--primary); margin-bottom:0; margin-top:6px; }
.legal-body p { font-size:.86rem; line-height:1.65; color:var(--muted); }
.legal-body a { color:var(--primary); font-weight:600; text-decoration:underline; }
.legal-list { padding-left:20px; display:flex; flex-direction:column; gap:5px; }
.legal-list li { font-size:.86rem; line-height:1.55; color:var(--muted); }
.contact-body { display:flex; flex-direction:column; gap:12px; padding:8px 0 4px; }
.contact-body > p { font-size:.88rem; line-height:1.65; color:var(--muted); }
.contact-email-box { background:rgba(0,0,0,.25); border:var(--border); border-radius:12px; padding:14px 18px; display:flex; flex-direction:column; align-items:center; gap:4px; }
.contact-label { font-family:'Fredoka One',cursive; font-size:.82rem; color:var(--muted); }
.contact-email { font-family:'Fredoka One',cursive; font-size:1.05rem; color:var(--primary); text-decoration:underline; font-weight:800; word-break:break-all; text-shadow:0 0 10px var(--glow); }
.contact-note { font-size:.78rem; color:var(--muted); font-style:italic; }

/* ═══════════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════════ */
.status-toast { position:fixed; top:max(20px,env(safe-area-inset-top,20px)); left:50%; transform:translateX(-50%); background:var(--card); color:var(--text); padding:10px 22px; border-radius:50px; font-weight:bold; white-space:nowrap; z-index:3000; border:var(--border); box-shadow:0 8px 24px rgba(0,0,0,.5),0 0 0 1px var(--glow); transition:opacity .3s; }
.status-toast.hidden { opacity:0; pointer-events:none; }

/* ═══════════════════════════════════════════════════════════
   KEYFRAMES
   ═══════════════════════════════════════════════════════════ */
.bounce-in  { animation:bounceIn .5s cubic-bezier(.175,.885,.32,1.275) forwards; }
.slide-up   { animation:slideUp .4s ease-out forwards; }
.float-anim { animation:floatBob 3s ease-in-out infinite; }
@keyframes bounceIn { 0%{transform:scale(.5);opacity:0} 100%{transform:scale(1);opacity:1} }
@keyframes slideUp  { 0%{transform:translateY(50px);opacity:0} 100%{transform:translateY(0);opacity:1} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════════════════════════
   AUTH RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:1024px) {
  .auth-brand-panel{flex:0 0 52%;padding:36px 36px}
  .auth-brand-title{font-size:2.7rem}
  .auth-features-grid{gap:10px}
  .auth-feat-card{padding:12px 14px}
  .auth-form-scroll{padding:32px 30px}
}
@media(max-width:860px) {
  .auth-split{flex-direction:column}
  .auth-brand-panel{flex:0 0 auto;padding:28px 24px 20px;border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}
  .auth-brand-inner{gap:16px}
  .auth-brand-title{font-size:2.1rem}
  .auth-logo-icon{font-size:2rem}
  .auth-brand-tagline{font-size:.88rem}
  .auth-features-grid{gap:8px}
  .auth-feat-card p{display:none}
  .auth-player-row{display:none}
  .auth-brand-sub{display:none}
  .auth-form-panel{flex:1;min-height:0}
  .auth-form-scroll{padding:22px 22px;align-items:flex-start}
}
@media(max-width:600px) {
  /* ── Mobile: hide brand, show mobile header, CENTRE the form ── */
  .auth-brand-panel{display:none}
  .auth-mobile-brand{display:flex}
  /* Larger, bolder mobile brand */
  .auth-mobile-brand{
    padding:max(env(safe-area-inset-top,0px) + 24px, 36px) 24px 8px;
    flex-direction:column; gap:6px;
  }
  .auth-mobile-title{font-size:2.2rem}
  .auth-mobile-brand > span:first-child{font-size:2.2rem}
  /* Centre the form card both axes */
  .auth-form-scroll{
    padding:20px 20px 36px;
    align-items:center;
    justify-content:center;
    flex:1;
  }
  .auth-form-card{max-width:100%}
  .auth-form-heading{font-size:1.5rem}
}

/* ═══════════════════════════════════════════════════════════
   HOME + ROOM RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:900px) {
  .home-layout{flex-direction:column;align-items:center;height:auto}
  .home-body{align-items:flex-start;overflow-y:auto}
  .profile-col{width:100%;max-width:100%}
  .home-right-col{width:100%}
  .online-modal-cols{flex-direction:column}
  .online-col-divider{width:100%;height:1px;margin:4px 0}
  .room-player-col{width:20%;gap:14px;padding:8px 4px}
  .room-center-col{width:60%}
  .room-video-wrapper { 
    position:relative; height:100%; max-width:100%; background:#000; 
    border:var(--border); border-radius:var(--radius); 
    box-shadow:0 8px 40px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04); 
    overflow:hidden; transition:opacity .4s ease; width:100%;
  }
  .room-phase-text{font-size:.88rem}
  .room-topbar{padding:0 8px;padding-top:env(safe-area-inset-top,0px);padding-bottom:8px}
  .room-footer{height:auto;min-height:calc(58px + env(safe-area-inset-bottom,0px));padding:8px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom,0px));flex-wrap:wrap;gap:8px}
  .footer-center,.footer-right{flex:none}
  .reminisce-layout{flex-direction:column;height:auto}
  .rem-video-col{min-height:60vh;width:100%}
  .video-frame{aspect-ratio:9/16;max-height:70vh}
}
@media(max-width:600px) {
  body{font-size:14px}
  #home-screen.active{height:auto;min-height:100vh;overflow:visible}
  /* ── Extra top padding on home to clear the phone's status bar / notch ── */
  .home-body{
    padding-top:max(56px, env(safe-area-inset-top, 56px));
    padding-left:max(12px,env(safe-area-inset-left,12px));
    padding-right:max(12px,env(safe-area-inset-right,12px));
    padding-bottom:12px;
    overflow:visible;
  }
  .card{padding:20px 16px;max-width:100%}
  h1.game-title{font-size:2rem;margin-bottom:12px}
  .jackbox-input{padding:11px 13px;font-size:.95rem;margin-bottom:10px}
  .jackbox-btn{padding:11px;font-size:1rem;margin-bottom:10px}
  .home-layout{flex-direction:column;gap:14px;height:auto}
  .profile-col{width:100%;max-width:100%}
  .profile-avatar-wrapper{width:90px;height:90px}
  h1.game-title{font-size:1.9rem}
  .utilities-title{font-size:1.6rem}
  .theme-btn,.sound-btn{width:26px;height:26px}
  .online-modal-card{padding:20px 14px}
  .big-room-code{font-size:2.2rem;letter-spacing:6px}
  .join-code-input{font-size:1.6rem!important;letter-spacing:8px}
  .modal-content{max-height:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 20px)}
  .lp-footer{padding-top:14px;padding-bottom:max(24px,env(safe-area-inset-bottom,24px))}
  .home-footer{padding:8px max(14px,env(safe-area-inset-right,14px)) max(8px,env(safe-area-inset-bottom,8px)) max(14px,env(safe-area-inset-left,14px))}
  .auth-features-grid{grid-template-columns:1fr}
  .bub-ring{width:80px;height:80px}
  .bub-ring img{width:80px;height:80px}
}
@media(min-width:600px) and (orientation:landscape) {
  .lp-players-grid{grid-template-columns:repeat(5,1fr)}
  .lp-ring{width:60px;height:60px}
}
@media(display-mode:standalone) {
  .room-topbar{height:calc(68px + env(safe-area-inset-top,0px))}
  .lp-topbar{height:calc(64px + env(safe-area-inset-top,0px))}
}
/* ═══════════════════════════════════════════════════════════
   INFO / HOW-TO-PLAY CIRCLE BUTTON
   ═══════════════════════════════════════════════════════════ */
.info-circle-btn {
  position: fixed;
  top: max(18px, env(safe-area-inset-top, 18px));
  right: max(18px, env(safe-area-inset-right, 18px));
  z-index: 900;
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.18);
  background: var(--card);
  color: var(--primary);
  font-size: 1.15rem;
  font-weight: 900;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,.45), 0 0 0 2px var(--glow);
  transition: transform .2s, box-shadow .2s, background .2s;
  /* Only visible on home screen */
  opacity: 0; pointer-events: none;
}
#home-screen.active .info-circle-btn {
  opacity: 1; pointer-events: auto;
}
.info-circle-btn:hover {
  transform: scale(1.15) rotate(15deg);
  box-shadow: 0 6px 22px rgba(0,0,0,.55), 0 0 0 4px var(--glow);
  background: var(--card-alt);
}
.info-circle-btn:active { transform: scale(.92); }

/* ═══════════════════════════════════════════════════════════
   TUTORIAL / ONBOARDING MODAL
   ═══════════════════════════════════════════════════════════ */
.tutorial-card {
  max-width: 520px;
  padding: 36px 32px 24px;
  text-align: center;
  overflow: visible;
}

/* Pages container — fixed height so the card doesn't resize between pages */
.tutorial-pages-wrap {
  min-height: 320px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}

.tutorial-page {
  width: 100%;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  animation: tutPageIn .32s cubic-bezier(.4,0,.2,1) forwards;
}
.tutorial-page.hidden { display: none !important; }
.tutorial-page.tut-pg-active { display: flex; }
.tutorial-page.tut-pg-exit {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: flex;
  animation: tutPageOut .28s cubic-bezier(.4,0,.2,1) forwards;
}

@keyframes tutPageIn {
  from { opacity: 0; transform: translateX(28px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes tutPageOut {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(-28px); }
}

/* Icon */
.tut-icon {
  font-size: 3rem;
  line-height: 1;
  filter: drop-shadow(0 4px 12px var(--glow));
  animation: tutIconPulse 2.8s ease-in-out infinite;
}
@keyframes tutIconPulse {
  0%,100% { transform: scale(1) rotate(-4deg); }
  50%      { transform: scale(1.12) rotate(4deg); }
}

/* Title */
.tut-title {
  font-family: 'Fredoka One', cursive;
  font-size: 1.65rem;
  color: var(--primary);
  text-shadow: 2px 2px 0 rgba(0,0,0,.35);
  margin: 0;
  line-height: 1.2;
}
.tut-title span { color: var(--secondary); }

/* Body text */
.tut-body {
  font-size: .9rem;
  color: var(--muted);
  line-height: 1.7;
  max-width: 420px;
  margin: 0;
}
.tut-body strong { color: var(--text); }

/* Pills (game mode tags) */
.tut-pills {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 8px;
  margin-top: 4px;
}
.tut-pill {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 30px;
  padding: 5px 14px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
}

/* Step list */
.tut-steps {
  display: flex; flex-direction: column; gap: 10px;
  width: 100%; max-width: 360px; text-align: left;
}
.tut-step {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 10px;
  padding: 10px 14px;
  font-size: .86rem;
  color: var(--text);
  font-weight: 600;
}
.tut-step-num {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-family: 'Fredoka One', cursive;
  font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 0 10px var(--glow);
}

/* Chrome extension button on last page */
.tut-ext-btn {
  margin-top: 4px;
  margin-bottom: 0;
  font-size: 1rem;
  padding: 12px 20px;
  max-width: 340px;
}

/* Mobile-only note */
.tut-mobile-note {
  display: none; /* shown via JS only on mobile */
  font-size: .82rem;
  line-height: 1.65;
  color: var(--muted);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  padding: 12px 16px;
  text-align: left;
  margin-top: 4px;
  max-width: 380px;
}
.tut-mobile-note strong { color: var(--secondary); }

/* Dot indicators */
.tutorial-dots {
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  margin: 20px 0 16px;
}
.tut-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
  transition: background .25s, transform .25s, width .25s;
  cursor: default;
}
.tut-dot-active {
  background: var(--primary);
  box-shadow: 0 0 8px var(--glow);
  width: 26px;
  border-radius: 5px;
  transform: scale(1.1);
}

/* Navigation area */
.tutorial-actions {
  display: flex; flex-direction: column; align-items: center;
  gap: 0;
  width: 100%;
}
.tut-action-btn {
  max-width: 260px;
  padding: 13px 24px;
  font-size: 1.05rem;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-bottom: 8px;
  transition: opacity .2s, transform .1s, box-shadow .15s;
}
.tut-action-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
  filter: none !important;
}
.tut-btn-label { font-size: 1.05rem; }
.tut-btn-cd {
  font-size: .8rem;
  font-weight: 600;
  opacity: .75;
  font-family: 'Poppins', sans-serif;
}
.tut-action-btn:not(:disabled) .tut-btn-cd { display: none; }

/* Skip link */
.tut-skip-btn {
  display: block;
  margin-top: 2px;
  font-size: .8rem;
  opacity: .6;
}
.tut-skip-btn:hover { opacity: 1; }

/* ── Tutorial mobile responsive ── */
@media (max-width: 600px) {
  .tutorial-card {
    padding: 28px 18px 20px;
    max-width: 100%;
  }
  .tutorial-pages-wrap { min-height: 280px; }
  .tut-title { font-size: 1.4rem; }
  .tut-body  { font-size: .85rem; }
  .tut-icon  { font-size: 2.4rem; }
  .tut-step  { padding: 8px 12px; font-size: .82rem; }
  .tut-ext-btn { max-width: 100%; }
  .tut-mobile-note { max-width: 100%; }
}

.tut-nav-row {
  display: flex; align-items: center; justify-content: center;
  gap: 10px; width: 100%;
}
.tut-prev-btn {
  max-width: 110px;
  padding: 13px 18px;
  font-size: .95rem;
  margin-bottom: 8px;
}