:root{
  --bg:#0b0613; --bg2:#140a22; --ink:#f4ecff; --muted:#a99bc7;
  --p1:#ff3d81; --p2:#7c5cff; --p3:#19e3c2; --p4:#ffd23f;
  --card:rgba(28,18,46,.72); --line:rgba(168,140,255,.22);
  --glow:0 0 40px rgba(124,92,255,.45);
  --r:22px;
  --kymber:#ff3d81; --jess:#19e3c2; --marci:#ffd23f; --matt:#7c5cff;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:'Outfit',system-ui,sans-serif;background:var(--bg);color:var(--ink);
  overflow-x:hidden;min-height:100dvh;
}
#bg{position:fixed;inset:0;z-index:0;display:block}
#app{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column;align-items:center;
  padding:max(20px,env(safe-area-inset-top)) 18px calc(28px + env(safe-area-inset-bottom))}
.wrap{width:100%;max-width:560px;margin:auto;animation:rise .5s cubic-bezier(.2,.8,.2,1)}
.wrap.tv{max-width:1100px}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

.brand{font-family:'Space Grotesk';font-weight:700;text-align:center;letter-spacing:-.03em;line-height:.95;padding:0 6px}
.brand .big{display:block;font-size:clamp(38px,8vw,92px);max-width:100%;overflow-wrap:break-word;
  background:linear-gradient(100deg,var(--p1),var(--p2) 40%,var(--p3) 75%,var(--p4));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 4px 30px rgba(124,92,255,.4));animation:hue 9s linear infinite}
@keyframes hue{to{filter:drop-shadow(0 4px 30px rgba(124,92,255,.4)) hue-rotate(360deg)}}
.brand .sub{display:block;margin-top:8px;color:var(--muted);font-family:'Outfit';font-weight:500;
  font-size:clamp(13px,2.6vw,18px);letter-spacing:.18em;text-transform:uppercase}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:26px;backdrop-filter:blur(18px) saturate(1.3);box-shadow:var(--glow);margin-top:26px}
.card.center{text-align:center}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;
  font-family:'Space Grotesk';font-weight:600;font-size:19px;color:#0b0613;cursor:pointer;
  border:0;border-radius:16px;padding:18px 22px;margin-top:14px;
  background:linear-gradient(100deg,var(--p3),var(--p4));transition:transform .12s, filter .12s;
  box-shadow:0 8px 26px rgba(25,227,194,.3)}
.btn:hover{transform:translateY(-2px);filter:brightness(1.07)}
.btn:active{transform:translateY(0) scale(.99)}
.btn.alt{background:linear-gradient(100deg,var(--p1),var(--p2));color:#fff;box-shadow:0 8px 26px rgba(124,92,255,.34)}
.btn.ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink);box-shadow:none}
.btn[disabled]{opacity:.45;cursor:not-allowed;transform:none}

.field{width:100%;font-family:'Space Grotesk';font-size:22px;color:var(--ink);text-align:center;
  background:rgba(11,6,19,.6);border:1.5px solid var(--line);border-radius:16px;padding:18px;margin-top:8px;
  outline:none;transition:border-color .15s, box-shadow .15s}
.field:focus{border-color:var(--p2);box-shadow:0 0 0 4px rgba(124,92,255,.18)}
textarea.field{resize:none;min-height:120px;line-height:1.4;text-align:left;font-family:'Outfit'}
.code-in{letter-spacing:.4em;text-transform:uppercase;font-size:32px}

.label{color:var(--muted);font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}

.names{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.name-btn{font-family:'Space Grotesk';font-weight:700;font-size:22px;padding:22px;border-radius:18px;cursor:pointer;
  border:2px solid transparent;color:#0b0613;transition:transform .12s, box-shadow .15s, opacity .15s}
.name-btn:hover{transform:translateY(-3px)}
.name-btn[data-n="Kymber"]{background:var(--kymber);box-shadow:0 8px 24px rgba(255,61,129,.4)}
.name-btn[data-n="Jess"]{background:var(--jess);box-shadow:0 8px 24px rgba(25,227,194,.4)}
.name-btn[data-n="Marci"]{background:var(--marci);box-shadow:0 8px 24px rgba(255,210,63,.4)}
.name-btn[data-n="Matt"]{background:var(--matt);color:#fff;box-shadow:0 8px 24px rgba(124,92,255,.4)}
.name-btn.taken{opacity:.32;pointer-events:none;filter:grayscale(.4)}

/* code display (host/TV) */
.code-show{font-family:'Space Grotesk';font-weight:700;font-size:clamp(64px,16vw,160px);letter-spacing:.1em;
  text-align:center;line-height:1;margin:10px 0;
  background:linear-gradient(120deg,var(--p4),var(--p1));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.join-hint{text-align:center;color:var(--muted);font-size:clamp(15px,2.4vw,22px);margin-top:6px}
.join-hint b{color:var(--p3)}

/* lobby player chips */
.roster{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:22px}
.chip{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:999px;font-weight:700;
  font-family:'Space Grotesk';font-size:clamp(16px,2.4vw,24px);border:2px solid var(--line);
  background:rgba(11,6,19,.5);animation:pop .35s cubic-bezier(.2,1.4,.4,1)}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.chip .dot{width:14px;height:14px;border-radius:50%}
.chip.off{opacity:.4}
.chip[data-n="Kymber"]{color:var(--kymber)} .chip[data-n="Kymber"] .dot{background:var(--kymber)}
.chip[data-n="Jess"]{color:var(--jess)} .chip[data-n="Jess"] .dot{background:var(--jess)}
.chip[data-n="Marci"]{color:var(--marci)} .chip[data-n="Marci"] .dot{background:var(--marci)}
.chip[data-n="Matt"]{color:var(--matt)} .chip[data-n="Matt"] .dot{background:var(--matt)}

.game-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:18px}
@media(min-width:680px){.game-grid{grid-template-columns:1fr 1fr 1fr}}
.game-card{padding:22px;border-radius:18px;cursor:pointer;border:1.5px solid var(--line);
  background:linear-gradient(160deg,rgba(124,92,255,.14),rgba(255,61,129,.07));transition:transform .14s, box-shadow .15s}
.game-card:hover{transform:translateY(-4px);box-shadow:var(--glow)}
.game-card h3{font-family:'Space Grotesk';font-size:26px;margin-bottom:6px}
.game-card p{color:var(--muted);font-size:15px;line-height:1.45}
.game-card .emoji{font-size:40px;display:block;margin-bottom:8px}

.prompt-big{font-family:'Space Grotesk';font-weight:600;font-size:clamp(24px,5vw,52px);line-height:1.15;
  text-align:center;margin:6px 0 4px}
.q-card{background:rgba(11,6,19,.5);border:1.5px solid var(--line);border-radius:18px;padding:24px;margin-top:16px}

.duel{display:grid;grid-template-columns:1fr;gap:16px;margin-top:20px}
@media(min-width:680px){.duel{grid-template-columns:1fr 1fr}}
.ans{background:rgba(11,6,19,.55);border:2px solid var(--line);border-radius:18px;padding:24px;font-size:clamp(20px,3vw,30px);
  font-family:'Outfit';font-weight:500;line-height:1.3;position:relative;transition:transform .15s}
.ans .by{position:absolute;top:-12px;left:18px;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:3px 12px;border-radius:999px;background:var(--bg2);border:1px solid var(--line)}
.ans.win{border-color:var(--p4);box-shadow:0 0 36px rgba(255,210,63,.4);transform:scale(1.03)}
.ans .votes{margin-top:12px;font-weight:700;color:var(--p4)}

.vote-grid{display:grid;gap:12px;margin-top:16px}
.vote-btn{font-family:'Outfit';font-weight:600;font-size:18px;text-align:left;line-height:1.3;color:var(--ink);
  background:rgba(11,6,19,.55);border:2px solid var(--line);border-radius:16px;padding:18px 20px;cursor:pointer;transition:.13s}
.vote-btn:hover{border-color:var(--p2);transform:translateX(4px)}
.vote-btn:active{transform:scale(.98)}

.standings{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.row{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:16px;background:rgba(11,6,19,.5);border:1px solid var(--line)}
.row .rank{font-family:'Space Grotesk';font-weight:700;font-size:24px;width:36px;color:var(--muted)}
.row .nm{font-family:'Space Grotesk';font-weight:700;font-size:clamp(20px,3vw,30px);flex:1}
.row .sc{font-weight:700;font-size:clamp(20px,3vw,30px);color:var(--p3)}
.row.first{background:linear-gradient(100deg,rgba(255,210,63,.18),rgba(255,61,129,.1));border-color:var(--p4)}
.row.first .rank{color:var(--p4)}

.status{text-align:center;color:var(--muted);font-size:17px;margin-top:18px;min-height:24px}
.waiting-dots::after{content:'';animation:dots 1.4s steps(4) infinite}
@keyframes dots{0%{content:''}25%{content:'.'}50%{content:'..'}75%{content:'...'}}
.big-emoji{font-size:clamp(60px,16vw,140px);text-align:center;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.toast{position:fixed;left:50%;bottom:calc(24px + env(safe-area-inset-bottom));transform:translateX(-50%);
  background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:14px 22px;font-weight:600;z-index:9;
  box-shadow:var(--glow);animation:rise .3s}
.foot{margin-top:26px;text-align:center;color:var(--muted);font-size:13px;opacity:.7}
.foot a{color:var(--p3);text-decoration:none}
.confetti{position:fixed;inset:0;pointer-events:none;z-index:5}

.vault-list{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.vault-item{background:rgba(11,6,19,.5);border:1px solid var(--line);border-radius:16px;padding:18px}
.vault-item .vp{color:var(--muted);font-size:14px;font-weight:600;margin-bottom:8px}
.vault-item .va{font-size:18px;line-height:1.4}
.vault-item .va b{color:var(--p3);font-family:'Space Grotesk'}
.seg{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.seg button{font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;cursor:pointer;
  border:1px solid var(--line);background:rgba(11,6,19,.5);color:var(--muted)}
.seg button.on{color:#0b0613;background:var(--p3);border-color:var(--p3)}

/* hero banner art on home */
.hero-banner{width:100%;border-radius:var(--r);overflow:hidden;margin-bottom:10px;
  box-shadow:var(--glow);border:1px solid var(--line);aspect-ratio:16/10;max-height:320px;
  background:radial-gradient(120% 120% at 50% 30%,#1a0f2e,#0b0613);display:flex;align-items:center;justify-content:center}
/* emblem/crest art shows whole (contain); its own dark bg blends into the band */
.hero-banner img{max-width:100%;max-height:100%;width:auto;height:100%;object-fit:contain;display:block}
@media(max-width:480px){.hero-banner{max-height:240px}}

/* ---- timer bar ---- */
.timer-wrap{width:100%;height:6px;border-radius:999px;background:rgba(11,6,19,.6);overflow:hidden;margin-bottom:14px;border:1px solid var(--line)}
.timer-bar{height:100%;width:100%;background:var(--p3);transition:background .3s;border-radius:999px}

/* ---- emoji avatar picker ---- */
.emoji-pick{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;margin-top:8px}
.emoji-btn{font-size:26px;padding:8px 0;border-radius:12px;cursor:pointer;border:2px solid transparent;background:rgba(11,6,19,.5);transition:.12s}
.emoji-btn:hover{transform:scale(1.12)}
.emoji-btn.on{border-color:var(--p3);background:rgba(25,227,194,.18)}
.chip .av{font-size:20px}

/* ---- draw pad ---- */
.pad{border-radius:16px;border:2px solid var(--line);touch-action:none;margin:14px auto 0;display:block;cursor:crosshair;box-shadow:var(--glow)}
.pad-tools{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.swatch{width:42px;height:42px;border-radius:12px;cursor:pointer;border:2px solid var(--line);font-size:18px;display:flex;align-items:center;justify-content:center;color:#fff}
.swatch.on{border-color:var(--p3);transform:scale(1.1);box-shadow:0 0 14px rgba(25,227,194,.5)}
.swatch.erase,.swatch.clearp{background:rgba(11,6,19,.6)}

/* ---- drawing display ---- */
.draw-show{width:100%;max-width:360px;border-radius:16px;border:2px solid var(--line);display:block;margin:0 auto;background:#140a22}
.draw-show.big{max-width:560px;box-shadow:var(--glow)}

/* ---- hot takes ---- */
.ad-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}
.ad-btn{font-family:'Space Grotesk';font-weight:700;font-size:20px;padding:22px;border-radius:16px;cursor:pointer;border:2px solid var(--line);background:rgba(11,6,19,.5);color:var(--ink);transition:.13s}
.ad-btn.agree.on{background:var(--p3);color:#0b0613;border-color:var(--p3)}
.ad-btn.disagree.on{background:var(--p1);color:#fff;border-color:var(--p1)}
.pred-row{display:flex;gap:8px;justify-content:center;margin-top:8px;flex-wrap:wrap}
.pred-btn{width:54px;height:54px;border-radius:14px;font-family:'Space Grotesk';font-weight:700;font-size:22px;cursor:pointer;border:2px solid var(--line);background:rgba(11,6,19,.5);color:var(--ink);transition:.12s}
.pred-btn.on{background:var(--p2);color:#fff;border-color:var(--p2);transform:scale(1.08)}
.hot-meter{position:relative;height:54px;border-radius:14px;background:rgba(255,61,129,.15);border:2px solid var(--line);overflow:hidden;margin-top:10px}
.hot-fill{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--p3),var(--p4));transition:width 1s cubic-bezier(.2,.8,.2,1)}
.hot-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk';font-weight:700;font-size:22px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}

/* ---- QR + join layout ---- */
.join-split{display:flex;gap:30px;align-items:center;justify-content:center;flex-wrap:wrap;margin-bottom:10px}
.join-left,.join-right{display:flex;flex-direction:column;align-items:center;gap:8px}
.qr{background:#fff;border-radius:16px;padding:10px;line-height:0;box-shadow:var(--glow);width:200px;height:200px;display:flex;align-items:center;justify-content:center}
.qr svg{width:100%;height:100%;display:block}
@media(max-width:600px){.join-split{gap:18px}.qr{width:160px;height:160px}}

/* ---- per-game background art layer (behind plasma) ---- */
#bgart{position:fixed;inset:0;z-index:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;pointer-events:none;filter:saturate(1.1)}
#bgart.on{opacity:0.30}
#bg{opacity:0.85}  /* let bgart show through the plasma a touch */

/* ---- mute button ---- */
#muteBtn{position:fixed;top:14px;right:14px;z-index:20;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--line);background:rgba(11,6,19,.6);backdrop-filter:blur(8px);color:#fff;
  font-size:20px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:.15s}
#muteBtn:hover{transform:scale(1.08);box-shadow:var(--glow)}

/* ---- AI Showdown ---- */
.game-card.showdown{background:linear-gradient(160deg,rgba(255,61,129,.18),rgba(25,227,194,.12));border-color:rgba(255,61,129,.4)}
.new-tag{font-size:11px;font-weight:800;background:var(--p1);color:#fff;padding:2px 8px;border-radius:999px;vertical-align:middle;letter-spacing:.05em}
.img-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
@media(min-width:680px){.img-grid.host{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}
.img-opt{position:relative;border:2px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;
  background:rgba(11,6,19,.5);transition:.15s;padding:0;display:flex;flex-direction:column}
.img-opt:hover{transform:translateY(-3px);border-color:var(--p2);box-shadow:var(--glow)}
.img-opt img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.img-opt.win{border-color:var(--p4);box-shadow:0 0 40px rgba(255,210,63,.5)}
.img-cap{padding:8px 10px;font-size:12px;line-height:1.3;color:var(--ink);text-align:left}
.img-fail{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:28px;text-align:center;color:var(--muted)}
.paint-shimmer{height:8px;border-radius:999px;margin-top:18px;background:linear-gradient(90deg,var(--p1),var(--p2),var(--p3),var(--p4),var(--p1));background-size:300% 100%;animation:shimmer 1.5s linear infinite}
@keyframes shimmer{to{background-position:300% 0}}

/* ---- championship podium ---- */
.podium{display:flex;justify-content:center;align-items:flex-end;gap:14px;margin:24px auto 6px;max-width:560px}
.pod-col{display:flex;flex-direction:column;align-items:center;flex:1;animation:podrise .6s cubic-bezier(.2,1.3,.4,1) both}
.pod-col.place-1{animation-delay:.3s}.pod-col.place-2{animation-delay:.1s}.pod-col.place-3{animation-delay:.5s}
@keyframes podrise{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:none}}
.pod-av{width:54px;height:54px;border-radius:50%;border:3px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:28px;background:rgba(11,6,19,.6);margin-bottom:6px}
.pod-name{font-family:'Space Grotesk';font-weight:700;font-size:clamp(14px,2.4vw,20px);margin-bottom:6px;text-align:center}
.pod-bar{width:100%;border-radius:12px 12px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:10px 4px;gap:4px;
  background:linear-gradient(180deg,rgba(124,92,255,.4),rgba(124,92,255,.1));border:1px solid var(--line);border-bottom:0}
.pod-bar.place-1{height:140px;background:linear-gradient(180deg,rgba(255,210,63,.5),rgba(255,61,129,.15))}
.pod-bar.place-2{height:100px;background:linear-gradient(180deg,rgba(180,180,200,.4),rgba(124,92,255,.1))}
.pod-bar.place-3{height:76px;background:linear-gradient(180deg,rgba(205,127,50,.4),rgba(124,92,255,.1))}
.pod-medal{font-size:26px}.pod-score{font-family:'Space Grotesk';font-weight:700;font-size:18px;color:#fff}
.pod-col.empty{visibility:hidden}

/* ---- Cine Guess ---- */
.cine-pts{font-family:'Space Grotesk';font-weight:700;font-size:18px;color:var(--p4);text-align:center;margin-bottom:12px}
.cine-pts.big{font-size:clamp(20px,3vw,30px)}
.cine-clues{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.cine-clue{background:rgba(11,6,19,.5);border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:clamp(15px,2.4vw,20px);line-height:1.35}
.cine-clue b{color:var(--p3)}
.cine-clue.new{animation:cluein .5s cubic-bezier(.2,1.2,.4,1)}
@keyframes cluein{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:none}}
.cine-stage{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
@media(max-width:760px){.cine-stage{grid-template-columns:1fr}}
.cine-imgwrap{position:relative;aspect-ratio:1;border-radius:16px;overflow:hidden;border:2px solid var(--line);background:#140a22}
.cine-img{width:100%;height:100%;object-fit:cover;display:block}
.cine-img.reveal{max-width:420px;aspect-ratio:1;margin:14px auto 0;border-radius:16px;border:2px solid var(--p4);box-shadow:0 0 40px rgba(255,210,63,.3)}
.cine-paint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:20px}
.cine-paint .paint-shimmer{width:70%}
#cineG.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}

/* ---- Cine Guess category picker ---- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:24px}
.cat-card{padding:28px 20px;border-radius:18px;cursor:pointer;border:1.5px solid var(--line);text-align:center;
  font-family:'Space Grotesk';font-weight:700;font-size:clamp(20px,3vw,28px);
  background:linear-gradient(160deg,rgba(124,92,255,.16),rgba(25,227,194,.08));transition:transform .14s, box-shadow .15s}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--glow);border-color:var(--p2)}

/* ---- VIP phone game picker ---- */
.vipgrid{grid-template-columns:1fr;margin-top:12px}
.vipgrid .game-card{padding:16px 18px;text-align:left}
.vipgrid .game-card .emoji{font-size:28px;display:inline-block;margin:0 10px 0 0;vertical-align:middle}
.vipgrid .game-card h3{display:inline-block;font-size:20px;margin:0;vertical-align:middle}
.vipgrid .game-card p{font-size:13px;margin-top:6px}

/* ---- numeric countdown ---- */
.timer-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.timer-row .timer-wrap{flex:1;margin-bottom:0}
.timer-num{font-family:'Space Grotesk';font-weight:700;font-size:20px;min-width:34px;text-align:right;color:var(--muted);transition:.2s}
.timer-num.urgent{color:var(--p1);font-size:24px;animation:pulse 1s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}
/* ---- narrator/mute combo ---- */
#narBtn{position:fixed;top:14px;right:68px;z-index:20;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:rgba(11,6,19,.6);backdrop-filter:blur(8px);color:#fff;font-size:20px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:.15s}
#narBtn:hover{transform:scale(1.08);box-shadow:var(--glow)}

/* ---- AI Showdown: BIGGER host gallery images (was ~1/6 screen) ---- */
.wrap.tv .img-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px;max-width:none}
.wrap.tv .img-grid.host{grid-template-columns:repeat(auto-fit,minmax(380px,1fr))}
.wrap.tv .img-opt img{aspect-ratio:1;width:100%}
.wrap.tv .img-cap{font-size:16px;padding:12px 14px}
/* reveal: make the winning image really large */
.wrap.tv .img-opt.win img{box-shadow:0 0 50px rgba(255,210,63,.5)}

/* ---- per-game winner banner ---- */
.game-winner{text-align:center;margin:18px auto 6px;animation:pop .5s cubic-bezier(.2,1.4,.4,1)}
.gw-label{font-size:13px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:600}
.gw-name{font-family:'Space Grotesk';font-weight:700;font-size:clamp(32px,7vw,60px);line-height:1.05;margin-top:4px;
  filter:drop-shadow(0 4px 24px rgba(255,210,63,.4))}

/* ---- sign-in buttons (Google / Apple OAuth) ---- */
.signin-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;padding:12px 16px;border-radius:12px;
  text-decoration:none;margin-top:10px;cursor:pointer;transition:transform .12s,filter .12s;border:1px solid transparent}
.signin-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.signin-btn.google{background:#fff;color:#1f1f1f;border-color:#dadce0}
.signin-btn.google .g-ic{font-family:'Space Grotesk';font-weight:700;color:#4285F4;font-size:18px;line-height:1}
.signin-btn.apple{background:#000;color:#fff}
.signin-btn.apple .a-ic::before{content:'';font-size:17px}
.acct-row{box-sizing:border-box}

/* ===== Slopular — Y2K Sticker Pop home (2026-06-16) ===== */
body.home-mode{background:#fff7ec}
body.home-mode #bg,body.home-mode #bgart{display:none}
body.home-mode #app{color:#231a12}
/* fixed, continuously-drifting mesh-gradient backdrop (no scroll repeat, always moving) */
#slbg{display:none}
body.home-mode #slbg{display:block;position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
#slbg span{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;will-change:transform}
#slbg span:nth-child(1){width:62vw;height:62vw;left:-12vw;top:-10vh;background:#37c4ff;animation:slm1 19s ease-in-out infinite alternate}
#slbg span:nth-child(2){width:58vw;height:58vw;right:-14vw;top:-6vh;background:#ff5fa2;animation:slm2 23s ease-in-out infinite alternate}
#slbg span:nth-child(3){width:66vw;height:66vw;left:-8vw;bottom:-18vh;background:#9ee04b;animation:slm3 21s ease-in-out infinite alternate}
#slbg span:nth-child(4){width:54vw;height:54vw;right:-10vw;bottom:-14vh;background:#ffc83d;opacity:.45;animation:slm4 26s ease-in-out infinite alternate}
@keyframes slm1{to{transform:translate3d(16vw,18vh,0) scale(1.2)}}
@keyframes slm2{to{transform:translate3d(-14vw,22vh,0) scale(1.15)}}
@keyframes slm3{to{transform:translate3d(20vw,-16vh,0) scale(1.25)}}
@keyframes slm4{to{transform:translate3d(-18vw,-12vh,0) scale(1.18)}}
@media(prefers-reduced-motion:reduce){#slbg span{animation:none}}
.home{--si:#231a12;--lime:#9ee04b;--orange:#ff7a2f;--sky:#37c4ff;--pink:#ff5fa2;--gold:#ffc83d;
  max-width:480px;width:100%;color:var(--si);margin:auto}
.sl-bar{display:flex;justify-content:space-between;align-items:center;font-family:'Fredoka';font-weight:600;font-size:13px}
.sl-bar .pill{background:#fff;border:2.5px solid var(--si);border-radius:999px;padding:5px 13px;box-shadow:3px 3px 0 var(--si)}
.sl-logo{font-family:'Fredoka';font-weight:700;font-size:clamp(60px,17vw,86px);line-height:.9;text-align:center;margin:18px 0 0;letter-spacing:-.01em}
.sl-logo .a{color:var(--orange)}.sl-logo .b{color:var(--sky)}.sl-logo .c{color:var(--pink)}.sl-logo .d{color:var(--lime)}
.sl-badge{display:block;width:fit-content;margin:12px auto 0;background:var(--gold);border:2.5px solid var(--si);border-radius:999px;
  font-family:'Fredoka';font-weight:600;font-size:12px;padding:5px 15px;box-shadow:3px 3px 0 var(--si);transform:rotate(-2deg)}
.sl-sub{text-align:center;font-size:15px;font-weight:500;line-height:1.5;margin:16px auto 0;max-width:350px;color:#4a3d30}
.sl-sub b{background:var(--lime);padding:0 4px;border-radius:4px}
.sl-float{display:flex;justify-content:center;margin:22px 0 0}
.sl-float .s{width:31%;background:#fff;border:3px solid var(--si);border-radius:14px;overflow:hidden;box-shadow:4px 4px 0 var(--si)}
.sl-float .s img{width:100%;display:block;background:#eee}
.sl-float .s:nth-child(1){transform:rotate(-7deg)}
.sl-float .s:nth-child(2){transform:rotate(3deg) translateY(-10px);margin:0 -7px;z-index:2}
.sl-float .s:nth-child(3){transform:rotate(8deg)}
.sl-cta{display:flex;flex-direction:column;gap:12px;margin:26px 0 0}
.sl-btn{display:flex;align-items:center;justify-content:space-between;font-family:'Fredoka';font-weight:600;font-size:20px;
  padding:16px 20px;border-radius:16px;border:3px solid var(--si);color:#fff;box-shadow:5px 5px 0 var(--si);cursor:pointer;
  transition:transform .12s,box-shadow .12s}
.sl-btn:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--si)}
.sl-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--si)}
.sl-btn.h{background:var(--orange)}.sl-btn.j{background:var(--sky)}
.sl-sec{font-family:'Fredoka';font-weight:600;font-size:21px;margin:36px 0 14px;display:flex;align-items:center;gap:8px}
.sl-games{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sl-g{background:#fff;border:3px solid var(--si);border-radius:16px;padding:13px;box-shadow:4px 4px 0 var(--si)}
.sl-g:nth-child(odd){transform:rotate(-1.3deg)}.sl-g:nth-child(even){transform:rotate(1.3deg)}
.sl-g .e{font-size:24px}
.sl-g .n{font-family:'Fredoka';font-weight:600;font-size:17px;margin-top:3px}
.sl-g .d{font-size:11.5px;color:#6a5a4b;margin-top:3px;line-height:1.35}
.sl-g .tag{display:inline-block;font-family:'Fredoka';font-size:10px;border-radius:7px;padding:2px 7px;margin-top:8px;border:2px solid var(--si)}
.sl-g:nth-child(6n+1) .tag{background:var(--lime)}.sl-g:nth-child(6n+2) .tag{background:var(--pink);color:#fff}
.sl-g:nth-child(6n+3) .tag{background:var(--gold)}.sl-g:nth-child(6n+4) .tag{background:var(--sky);color:#fff}
.sl-g:nth-child(6n+5) .tag{background:var(--orange);color:#fff}.sl-g:nth-child(6n) .tag{background:var(--lime)}
.sl-wall{display:grid;grid-template-columns:1fr 1fr 1fr;gap:9px}
.sl-wall .t{background:#fff;border:2.5px solid var(--si);border-radius:12px;overflow:hidden;box-shadow:3px 3px 0 var(--si)}
.sl-wall .t:nth-child(even){transform:rotate(2deg)}.sl-wall .t:nth-child(odd){transform:rotate(-2deg)}
.sl-wall .t img{width:100%;display:block}
.sl-quick{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:22px 0 0}
.sl-chip{font-family:'Fredoka';font-weight:500;font-size:13px;color:var(--si);text-decoration:none;background:#fff;
  border:2.5px solid var(--si);border-radius:999px;padding:7px 14px;box-shadow:2px 2px 0 var(--si);transition:transform .1s}
.sl-chip:hover{transform:translate(-1px,-1px)}
.sl-acct{margin:24px 0 0;padding:15px 16px;border-radius:16px;border:2.5px solid var(--si);background:#fff;box-shadow:4px 4px 0 var(--si);
  text-align:center;font-size:14px;color:#4a3d30}
.sl-acct a{color:var(--si)}
.sl-foot{margin-top:26px;text-align:center;font-size:12px;color:#6a5a4b;font-weight:500}

/* Slopular wordmark usable on any background (in-game dark screens) */
.slmark{font-family:'Fredoka',sans-serif;font-weight:700;letter-spacing:-.01em;line-height:.9;display:inline-block}
.slmark .a{color:#ff7a2f}.slmark .b{color:#37c4ff}.slmark .c{color:#ff5fa2}.slmark .d{color:#9ee04b}
.sl-mono{font-family:'Fredoka',sans-serif}
