:root{
  --bg:#0B0712;--bg-2:#140B22;--surface:#190F2A;--surface-2:#231640;--line:#3A2358;
  --ink:#ECE6F7;--muted:#9D8FC0;
  --magenta:#FF2E9A;--lime:#C2FF45;--purple:#7A2BFF;
  --amber:#F0A93A;--amber-deep:#C7811F;
  --display:'Space Grotesk',system-ui,sans-serif;--mono:'Space Mono',ui-monospace,monospace;--body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:radial-gradient(130% 100% at 25% -5%,#1C0C32 0%,var(--bg) 58%);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;min-height:100%}
button{font-family:var(--body);cursor:pointer}
img{display:block}
.hidden{display:none!important}
.glow-mag{text-shadow:0 0 8px var(--magenta),0 0 24px rgba(255,46,154,.5)}
.glow-lime{text-shadow:0 0 8px var(--lime),0 0 20px rgba(194,255,60,.5)}
.sheep{background:#fff;border-radius:12%;padding:3%;object-fit:contain;filter:drop-shadow(0 0 6px rgba(255,46,154,.55)) drop-shadow(0 0 18px rgba(255,46,154,.35))}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime);animation:pulse 2.1s infinite;vertical-align:middle}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(194,255,60,.6)}70%{box-shadow:0 0 0 9px rgba(194,255,60,0)}100%{box-shadow:0 0 0 0 rgba(194,255,60,0)}}
.wordmark{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.02em;line-height:.9;color:#fff}
.mono{font-family:var(--mono)}

/* ===================== SCREEN (TV) ===================== */
.screen-root{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden}
.scr-glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.s-top{display:flex;justify-content:space-between;align-items:flex-start;padding:2.4vmin 3vmin;position:relative;z-index:2}
.s-brand{display:flex;align-items:center;gap:1.4vmin}
.s-brand img{width:7vmin}
.s-brand .wordmark{font-size:3.4vmin}
.s-ig{text-align:right;font-family:var(--mono)}
.s-ig .ig-count{display:flex;align-items:center;justify-content:flex-end;gap:1.1vmin}
.s-ig .ig-ico{display:inline-flex;color:var(--magenta);filter:drop-shadow(0 0 6px rgba(255,46,154,.5))}
.s-ig .ig-ico svg{width:3.2vmin;height:3.2vmin;display:block}
.s-ig .n{display:block;font-weight:700;font-size:3.4vmin;color:var(--lime);letter-spacing:-.02em}
.s-ig .lbl{font-size:1.5vmin;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.s-body{flex:1;position:relative;z-index:2;display:flex;min-height:0}
.s-foot{padding:1.6vmin 3vmin;position:relative;z-index:2}

/* lobby */
.lobby{flex:1;display:flex;align-items:center;gap:5vmin;padding:0 4vmin}
.qr-frame{padding:1.6vmin;border-radius:1.6vmin;background:#05030a;box-shadow:0 0 0 2px var(--magenta),0 0 30px rgba(255,46,154,.45)}
.qr-frame svg,.qr-frame img{width:24vmin;height:24vmin;display:block;border-radius:.6vmin;background:#fff}
.lobby h2{font-family:var(--display);font-weight:700;font-size:7vmin;line-height:.95;text-transform:uppercase;color:#fff}
.lobby h2 em{color:var(--lime);font-style:normal}
.lobby p{color:var(--muted);margin:1.6vmin 0;font-size:2.2vmin;max-width:40vmin}
.code{font-family:var(--mono);display:inline-flex;align-items:center;gap:1.4vmin;background:var(--surface);border:1px solid var(--line);border-radius:1.2vmin;padding:1.2vmin 2vmin}
.code span{font-size:1.6vmin;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.code b{font-size:3.4vmin;letter-spacing:.18em;color:var(--lime)}
.players{display:flex;align-items:center;gap:1vmin;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:1vmin;background:var(--surface);border:1px solid var(--line);border-radius:30px;padding:.7vmin 1.6vmin .7vmin .7vmin;font-size:1.9vmin;font-weight:600}
.chip .ava{width:3vmin;height:3vmin;border-radius:50%;display:grid;place-items:center;font-size:1.5vmin;font-weight:700;color:#0B0712}
.chip.pending{opacity:.5;border-style:dashed}
.waiting{font-family:var(--mono);font-size:1.7vmin;color:var(--muted);margin-top:1vmin}

/* beer */
.arena{flex:1;position:relative;display:flex;flex-direction:column;padding:2vmin 3vmin}
.arena-top{display:flex;justify-content:space-between;align-items:center}
.arena-title{font-family:var(--display);font-weight:700;font-size:3.4vmin;text-transform:uppercase}
.arena-title em{color:var(--magenta);font-style:normal}
.timer{font-family:var(--mono);font-weight:700;font-size:4vmin;color:var(--magenta);background:var(--surface);border:1px solid var(--line);padding:.4vmin 2vmin;border-radius:1.2vmin;box-shadow:0 0 18px rgba(255,46,154,.3)}
.field{flex:1;position:relative;overflow:hidden}
.mug{position:absolute;width:5vmin;height:6vmin;filter:drop-shadow(0 0 8px rgba(240,169,58,.5));will-change:top,left}
.mug .glass{position:absolute;bottom:0;left:0;width:4.4vmin;height:4.4vmin;background:linear-gradient(var(--amber),var(--amber-deep));border-radius:.6vmin .6vmin 1vmin 1vmin;border:.3vmin solid #0B0712}
.mug .foam{position:absolute;top:0;left:-.2vmin;width:4.8vmin;height:1.6vmin;background:#F5EAD2;border-radius:1.2vmin 1.2vmin .4vmin .4vmin;border:.3vmin solid #0B0712}
.catcher{position:absolute;bottom:0;display:flex;flex-direction:column;align-items:center;gap:.6vmin;transform:translateX(-50%);transition:left .08s linear}
.catcher .head{width:4.6vmin;height:4.6vmin;border-radius:50%;border:.3vmin solid #0B0712}
.catcher .tray{width:9vmin;height:1.8vmin;border-radius:.5vmin;background:var(--surface-2);border:.3vmin solid var(--magenta);box-shadow:0 0 14px rgba(255,46,154,.5)}
.catcher .cname{font-family:var(--mono);font-size:1.5vmin;color:var(--muted)}
.board{width:30vmin;background:var(--bg-2);border-left:1px solid var(--line);padding:2vmin}
.board-t{font-family:var(--mono);font-size:1.6vmin;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:1.6vmin}
.rank{display:flex;align-items:center;gap:1.4vmin;padding:1.2vmin 0;border-bottom:1px solid rgba(58,35,88,.6)}
.rank .pos{font-family:var(--display);font-weight:700;font-size:2.6vmin;color:var(--purple);width:3vmin}
.rank .nm{flex:1;font-weight:600;font-size:2.2vmin}
.rank .pts{font-family:var(--mono);font-weight:700;color:var(--magenta);font-size:2.4vmin}
.rank.lead .pos,.rank.lead .pts{color:var(--lime)}

/* duel */
.duel{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;position:relative}
.duel-eyebrow{font-family:var(--mono);font-size:2.4vmin;letter-spacing:.26em;text-transform:uppercase;color:var(--magenta);margin-bottom:2vmin}
.light{width:22vmin;height:22vmin;border-radius:50%;background:var(--surface-2);border:1px solid var(--line);margin-bottom:3vmin;transition:.1s}
.light.go{background:radial-gradient(circle at 38% 32%,#EFFFC0,var(--lime) 55%,#7da316);box-shadow:0 0 60px var(--lime),0 0 130px rgba(194,255,60,.5);border:none}
.go-text{font-family:var(--display);font-weight:700;font-size:16vmin;line-height:.85;color:#fff;text-shadow:0 0 20px var(--lime),0 0 60px rgba(194,255,60,.6)}
.duel-sub{font-family:var(--mono);font-size:2.4vmin;color:var(--muted);margin-top:2vmin}
/* Formula 1 start lights */
.f1-rail{display:flex;gap:2vmin;margin-bottom:3vmin;padding:2vmin 2.4vmin;background:#0a0710;border:.4vmin solid #1c1230;border-radius:2vmin;box-shadow:inset 0 0 4vmin rgba(0,0,0,.6)}
.f1-pod{display:flex;flex-direction:column;gap:1.2vmin;padding:1.2vmin;background:#05030a;border-radius:1.2vmin}
.f1-bulb{width:6vmin;height:6vmin;border-radius:50%;background:radial-gradient(circle at 38% 32%,#3a0d18,#170309);border:.3vmin solid #240612;transition:background .06s,box-shadow .06s}
.f1-bulb.on{background:radial-gradient(circle at 38% 32%,#ff8a8a,#ff1e1e 55%,#9e0000);box-shadow:0 0 5vmin rgba(255,30,30,.85),0 0 1.5vmin rgba(255,60,60,.9)}
.f1-rail.out{animation:lightsout .25s ease}
@keyframes lightsout{0%{box-shadow:inset 0 0 4vmin rgba(0,0,0,.6),0 0 8vmin rgba(194,255,60,.5)}100%{box-shadow:inset 0 0 4vmin rgba(0,0,0,.6)}}
/* phone-sized variant */
.f1-rail.mini{gap:8px;padding:8px 10px;border-width:2px;border-radius:12px}
.f1-rail.mini .f1-pod{gap:5px;padding:5px;border-radius:7px}
.f1-rail.mini .f1-bulb{width:24px;height:24px;border-width:1px}
.f1-rail.mini .f1-bulb.on{box-shadow:0 0 16px rgba(255,30,30,.85),0 0 6px rgba(255,60,60,.9)}

/* bluff */
.bluff{flex:1;display:flex;flex-direction:column;padding:3vmin 5vmin}
.bluff-top{display:flex;justify-content:space-between;align-items:center}
.bluff-eyebrow{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--magenta);font-size:2vmin}
.bluff-round{font-family:var(--mono);color:var(--muted);font-size:1.8vmin}
.q-card{text-align:center;margin:auto;max-width:90vmin}
.q-lab{font-family:var(--mono);font-size:1.8vmin;letter-spacing:.16em;text-transform:uppercase;color:var(--lime);margin-bottom:1.6vmin}
.q-text{font-family:var(--display);font-weight:700;font-size:5vmin;line-height:1.15;color:#fff}
.answers{display:flex;flex-wrap:wrap;gap:1.6vmin;justify-content:center;margin-top:auto;padding-top:3vmin}
.ans{background:var(--surface);border:1px solid var(--line);border-radius:1.4vmin;padding:2vmin 2.4vmin;text-align:center;min-width:18vmin}
.ans .a{font-weight:700;font-size:2.6vmin}
.ans .v{font-family:var(--mono);font-size:1.6vmin;color:var(--muted);margin-top:.8vmin}
.ans.truth{border-color:var(--lime);box-shadow:0 0 20px rgba(194,255,60,.3)}
.ans.truth .a{color:var(--lime)}

/* jukebox (screen) */
.jb-screen{flex:1;display:flex;gap:4vmin;padding:3vmin 5vmin;align-items:center}
.jb-now{flex:1}
.jb-now .k{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--magenta);font-size:2vmin}
.jb-now .art{width:30vmin;height:30vmin;border-radius:2vmin;background:linear-gradient(135deg,var(--magenta),var(--purple));margin:2vmin 0;object-fit:cover;box-shadow:0 0 40px rgba(255,46,154,.4)}
.jb-now .song{font-family:var(--display);font-weight:700;font-size:5vmin;color:#fff}
.jb-now .artist{color:var(--muted);font-size:2.6vmin}
.jb-now a.open{display:inline-block;margin-top:2vmin;background:#1DB954;color:#fff;text-decoration:none;font-weight:700;border-radius:30px;padding:1.4vmin 3vmin;font-size:2.2vmin}
.jb-queue{width:40vmin;background:var(--bg-2);border-left:1px solid var(--line);align-self:stretch;padding:3vmin 2.4vmin;overflow:auto}
.jq{display:flex;align-items:center;gap:1.4vmin;padding:1.4vmin 0;border-bottom:1px solid rgba(58,35,88,.6)}
.jq .s{flex:1;font-weight:600;font-size:2vmin}
.jq .a{font-size:1.6vmin;color:var(--muted)}
.jq .v{font-family:var(--mono);font-weight:700;color:var(--lime);font-size:1.8vmin}

/* ===================== PHONE (client) ===================== */
.phone-root{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding:env(safe-area-inset-top) 18px 20px;touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.phone-root .input{-webkit-user-select:text;user-select:text}
.p-bar{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:12px;color:var(--muted);padding:16px 0 12px}
.p-bar .brand{display:flex;align-items:center;gap:8px}
.p-bar .brand img{width:26px}
.p-stage{flex:1;display:flex;flex-direction:column}
.card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px}
h1.title{font-family:var(--display);font-weight:700;text-transform:uppercase;color:#fff;font-size:28px;line-height:1}
.sub{color:var(--muted);font-size:14px;margin-top:6px}
.input{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:14px;color:var(--ink);font-size:16px;font-family:var(--body)}
.input:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 16px rgba(255,46,154,.25)}
.btn{width:100%;border:none;border-radius:13px;padding:15px;font-weight:700;font-size:16px}
.btn-primary{background:var(--magenta);color:#fff;box-shadow:0 0 20px rgba(255,46,154,.4)}
.btn-lime{background:var(--lime);color:#0B0712}
.btn-ghost{background:var(--surface);border:1px solid var(--line);color:var(--ink)}
.btn:disabled{opacity:.4}
.center-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px}
.you .lab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.you .nm{font-family:var(--display);font-weight:700;font-size:26px;color:#fff;text-transform:uppercase}
/* beer controller */
.score{font-family:var(--mono);font-weight:700;font-size:46px;color:var(--lime);line-height:1;text-shadow:0 0 14px rgba(194,255,60,.5)}
.score-l{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase}
.tilt-track{height:8px;border-radius:6px;background:var(--surface);border:1px solid var(--line);position:relative;width:100%}
.tilt-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:34px;height:34px;border-radius:50%;background:var(--lime);box-shadow:0 0 16px var(--lime);transition:left .05s linear}
.arrows{display:flex;gap:12px;width:100%}
.arrows .btn{height:74px;font-size:30px;color:var(--lime);background:var(--surface);border:1px solid var(--line)}
/* duel button */
.tap-btn{width:230px;height:230px;max-width:78vw;max-height:78vw;border-radius:50%;border:none;background:var(--surface-2);color:var(--muted);font-family:var(--display);font-weight:700;font-size:34px;text-transform:uppercase}
.tap-btn.live{background:radial-gradient(circle at 38% 32%,#EFFFC0,var(--lime) 58%,#7da316);box-shadow:0 0 40px var(--lime),0 0 90px rgba(194,255,60,.5);color:#10210a}
.tap-btn.false{background:var(--magenta);color:#fff}
.chip-res{font-family:var(--mono);font-weight:700;background:var(--surface);border:1px solid var(--lime);border-radius:30px;padding:8px 18px;color:var(--lime)}
/* bluff */
.q-show{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px;font-size:14px;line-height:1.4;margin-bottom:16px}
.q-show u{text-decoration-color:var(--magenta);text-underline-offset:4px}
.opt{width:100%;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px;color:var(--ink);font-size:16px;font-weight:600;margin-bottom:10px}
.opt:disabled{opacity:.45}
.opt.mine{border-color:var(--lime);color:var(--lime)}
.opt.chosen{border-color:var(--magenta);box-shadow:0 0 16px rgba(255,46,154,.3)}
/* jukebox */
.search-row{display:flex;gap:8px}
.search-row .input{flex:1}
.result{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}
.result img,.result .ph{width:42px;height:42px;border-radius:8px;background:linear-gradient(135deg,var(--magenta),var(--purple));object-fit:cover;flex-shrink:0}
.result .info{flex:1;min-width:0}
.result .s{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.result .a{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.result .add{background:var(--magenta);color:#fff;border:none;border-radius:20px;padding:6px 12px;font-weight:700;font-size:13px}
.qitem{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.qitem .info{flex:1;min-width:0}
.qitem .s{font-weight:600;font-size:14px}.qitem .a{font-size:12px;color:var(--muted)}
.vote{display:flex;align-items:center;gap:5px;font-family:var(--mono);font-weight:700;color:var(--lime);background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:5px 11px;font-size:13px}

/* ===================== MANAGER ===================== */
.mgr-root{max-width:980px;margin:0 auto;padding:22px 18px 60px}
.mgr-head{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.mgr-head img{width:40px}
.mgr-head .wordmark{font-size:20px}
.mgr-head .room{margin-left:auto;font-family:var(--mono);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 14px}
.mgr-head .room b{color:var(--lime);letter-spacing:.12em}
.mgr-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.mgr-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px}
.mgr-card.full{grid-column:1/-1}
.card-t{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.badge{background:var(--magenta);color:#fff;border-radius:20px;font-size:11px;padding:2px 9px}
.approve{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(58,35,88,.6)}
.approve .ava{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;color:#0B0712}
.approve .nm{flex:1;font-weight:600;font-size:14px}
.pl-id{flex:1;min-width:0}
.pl-meta{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini{border:none;border-radius:8px;padding:7px 12px;font-weight:700;font-size:12px}
.mini.ok{background:var(--lime);color:#0B0712}.mini.no{background:transparent;border:1px solid var(--line);color:var(--muted)}
.modes{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mode{border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--bg-2);text-align:left;color:var(--ink)}
.mode .mt{font-weight:700;font-size:14px}
.mode .md{font-size:11px;color:var(--muted);margin-top:2px}
.mode.active{border-color:var(--magenta);background:linear-gradient(135deg,rgba(255,46,154,.16),transparent);box-shadow:0 0 16px rgba(255,46,154,.2)}
.mode.active .mt{color:var(--magenta)}
.ctl-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.ctl-row .btn{width:auto;flex:1;min-width:120px;padding:12px}
.row-tog{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.row-tog span{font-size:14px;font-weight:600}
.switch{width:46px;height:26px;border-radius:14px;background:var(--surface-2);position:relative;flex-shrink:0;border:none}
.switch.on{background:var(--lime);box-shadow:0 0 10px rgba(194,255,60,.4)}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#0B0712;transition:.15s}
.switch.on::after{left:23px}
.now-mini{display:flex;align-items:center;gap:10px}
.now-mini .art{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,var(--magenta),var(--purple));object-fit:cover}
.now-mini .s{font-weight:700;font-size:14px}.now-mini .a{font-size:12px;color:var(--muted)}
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--magenta);border-radius:30px;padding:10px 18px;font-size:14px;box-shadow:0 0 20px rgba(255,46,154,.3);z-index:99}

@media (max-width:640px){.mgr-grid{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ===================== QUIZ ===================== */
/* phone */
.quiz-opts{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.qopt{width:100%;text-align:left;border:none;border-radius:14px;padding:18px 16px;font-weight:700;font-size:17px;color:#0B0712}
.qopt.c0{background:var(--magenta);color:#fff}
.qopt.c1{background:var(--lime);color:#10210a}
.qopt.c2{background:var(--purple);color:#fff}
.qopt.c3{background:var(--amber);color:#2a1a02}
.qopt.dim{opacity:.32}
.qopt.ok{outline:3px solid #fff;outline-offset:2px}
/* screen */
.quiz-screen{flex:1;display:flex;flex-direction:column;padding:3vmin 5vmin}
.quiz-meta{display:flex;align-items:center;gap:1.6vmin;font-family:var(--mono)}
.quiz-meta .bluff-round{color:var(--muted);font-size:1.8vmin}
.q-timer{font-weight:700;font-size:2.4vmin;color:var(--lime);background:var(--surface);border:1px solid var(--line);border-radius:1vmin;padding:.3vmin 1.4vmin;min-width:7vmin;text-align:center}
.q-timer.urgent{color:#fff;background:var(--magenta);border-color:var(--magenta);box-shadow:0 0 16px rgba(255,46,154,.5)}
.q-answered{font-size:1.9vmin;color:var(--lime);background:var(--surface);border:1px solid var(--line);border-radius:1vmin;padding:.3vmin 1.4vmin}
.quiz-grid{display:grid;grid-template-columns:1fr 1fr;gap:2vmin;margin-top:auto}
.qcell{border-radius:2vmin;padding:3vmin 3vmin;min-height:14vmin;display:flex;align-items:center;justify-content:space-between;gap:2vmin;font-family:var(--display);font-weight:700;font-size:3.4vmin;position:relative;color:#0B0712}
.qcell .opt-txt{flex:1}
.qcell .cnt{font-family:var(--mono);font-size:2.6vmin;opacity:.85;background:rgba(0,0,0,.18);border-radius:1vmin;padding:.4vmin 1.4vmin}
.qcell .tick{font-size:4vmin}
.qcell.c0{background:var(--magenta);color:#fff}
.qcell.c1{background:var(--lime);color:#10210a}
.qcell.c2{background:var(--purple);color:#fff}
.qcell.c3{background:var(--amber);color:#2a1a02}
.qcell.dim{opacity:.28}
.qcell.ok{outline:.5vmin solid #fff;outline-offset:.4vmin;box-shadow:0 0 30px rgba(255,255,255,.4)}

/* ===================== INSTAGRAM RAIL (screen lobby) ===================== */
.lobby-ig{width:30vmin;background:var(--bg-2);border-left:1px solid var(--line);padding:3vmin 2.2vmin;display:flex;flex-direction:column;gap:1.6vmin;align-self:stretch}
.ig-hd{display:flex;justify-content:space-between;align-items:baseline}
.ig-hd .ig-t{font-family:var(--mono);font-size:1.5vmin;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.ig-hd .ig-at{font-family:var(--mono);font-size:1.7vmin;color:var(--lime)}
.ig-qr{width:100%;aspect-ratio:1;border-radius:1.2vmin;background:#fff;box-shadow:0 0 0 2px var(--magenta),0 0 22px rgba(255,46,154,.4)}
.ig-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8vmin}
.ig-tile{aspect-ratio:1;border-radius:1vmin;background:linear-gradient(135deg,var(--surface-2),var(--surface));position:relative;overflow:hidden}
.ig-tile::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 80% at 30% 25%,rgba(255,46,154,.35),transparent)}
.ig-tile:nth-child(2)::after{background:radial-gradient(80% 80% at 70% 30%,rgba(194,255,60,.3),transparent)}
.ig-tile:nth-child(3)::after{background:radial-gradient(80% 80% at 40% 70%,rgba(122,43,255,.4),transparent)}
.ig-embed{width:100%;flex:1;min-height:40vmin;border:none;border-radius:1.2vmin;background:#fff}
.ig-note{font-family:var(--mono);font-size:1.3vmin;color:var(--muted);text-align:center}

/* ===================== SCREENSAVER (screen) ===================== */
.saver{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.6vmin;padding:3vmin}
.saver-photo{max-width:60vmin;max-height:50vh;border-radius:2vmin;object-fit:cover;box-shadow:0 0 50px rgba(255,46,154,.4),0 0 0 2px var(--magenta)}
.saver-qr{margin-top:2vmin;padding:1.4vmin;border-radius:1.4vmin;background:#fff;box-shadow:0 0 0 2px var(--magenta),0 0 26px rgba(255,46,154,.45)}
.saver-qr img{width:20vmin;height:20vmin;display:block}

/* ===================== AVATAR PICKER (client) ===================== */
.ava-current{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
.ava-big{font-size:30px;line-height:1}
.ava-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;width:100%;max-height:38vh;overflow:auto;padding:4px;background:var(--bg-2);border:1px solid var(--line);border-radius:14px}
.ava-pick{font-size:22px;line-height:1;aspect-ratio:1;border:1px solid transparent;border-radius:10px;background:var(--surface);display:grid;place-items:center;padding:0}
.ava-pick.on{border-color:var(--magenta);box-shadow:0 0 12px rgba(255,46,154,.4);background:var(--surface-2)}
.overlay{position:fixed;inset:0;background:rgba(5,3,10,.82);display:flex;align-items:center;justify-content:center;padding:18px;z-index:120}
.ova-box{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px;max-width:420px;width:100%}

/* ===================== MANAGER: login / stats / editor ===================== */
.login-box{max-width:360px;margin:14vh auto 0;display:flex;flex-direction:column;gap:6px;padding:0 18px}
/* stats */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.stat{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:10px;text-align:center}
.stat .sv{font-family:var(--mono);font-weight:700;font-size:20px;color:var(--lime)}
.stat .sl{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.stat-row{display:flex;flex-wrap:wrap;gap:6px 14px;font-family:var(--mono);font-size:12px;color:var(--ink);margin-top:4px}
.stat-row span{color:var(--muted)}
.top-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid rgba(58,35,88,.5);font-size:13px}
.top-row .pos{font-family:var(--mono);color:var(--purple);width:20px}
.top-row .nm{flex:1;font-weight:600}
.top-row .g{font-family:var(--mono);font-size:11px;color:var(--muted)}
.top-row .pts{font-family:var(--mono);font-weight:700;color:var(--magenta)}
/* editor */
.tabs{display:flex;gap:6px}
.tab{border:1px solid var(--line);background:var(--bg-2);color:var(--muted);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700}
.tab.active{border-color:var(--magenta);color:var(--magenta);background:rgba(255,46,154,.1)}
.edit-q{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}
.edit-q-head{display:flex;gap:8px;align-items:center}
.edit-q-head .input{flex:1}
.edit-opts{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.edit-opt{display:flex;align-items:center;gap:8px}
.edit-opt .input{flex:1;padding:9px}
.edit-opt input[type=radio]{width:18px;height:18px;accent-color:var(--lime);flex-shrink:0}
.edit-b{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.edit-b .input{flex:1}
.edit-field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.edit-field span{font-size:12px;color:var(--muted);font-weight:600}
.gen-box{background:var(--bg-2);border:1px dashed var(--magenta);border-radius:12px;padding:12px;margin-bottom:14px}
.gen-box .card-t{color:var(--magenta);margin-bottom:10px}
textarea.input{min-height:90px;line-height:1.4}

/* ===================== TOWER (Torre più alta) ===================== */
/* phone */
.tower-wrap{display:flex;flex-direction:column;flex:1}
.tower-hud{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.tw-run{font-family:var(--mono);font-weight:700;font-size:40px;color:var(--lime);line-height:1;text-shadow:0 0 14px rgba(194,255,60,.5)}
.tw-run.crash{color:var(--magenta);text-shadow:0 0 14px rgba(255,46,154,.6)}
.tw-run-l{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.tw-meta{display:flex;flex-direction:column;align-items:flex-end;font-family:var(--mono);font-size:13px;color:var(--muted);gap:3px}
.tower-area{position:relative;height:54vh;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;overflow:hidden;touch-action:none}
.tower-stack{position:absolute;inset:0}
.tw-place{position:absolute;border-radius:4px}
.tower-cur{position:absolute;border-radius:4px;box-shadow:0 0 18px rgba(255,255,255,.35),inset 0 0 0 1px rgba(255,255,255,.25)}
.tower-area.shake{animation:tw-shake .4s}
@keyframes tw-shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
/* screen */
.tower-screen{flex:1;display:flex;flex-direction:column;padding:2vmin 3vmin}
.tw-cols{flex:1;display:flex;align-items:flex-end;justify-content:center;gap:2.4vmin;padding:2vmin 0;overflow:hidden}
.tw-col{display:flex;flex-direction:column;align-items:center;gap:.7vmin}
.tw-crown{height:4vmin;font-size:3.4vmin;line-height:1}
.tw-num{font-family:var(--mono);font-weight:700;font-size:3vmin;color:var(--ink)}
.tw-col.lead .tw-num{color:var(--lime);text-shadow:0 0 12px rgba(194,255,60,.5)}
.tw-stack{display:flex;flex-direction:column-reverse;gap:.4vmin}
.tw-blk{width:8vmin;height:2.4vmin;border-radius:.5vmin}
.tw-name{font-family:var(--mono);font-size:1.7vmin;color:var(--muted);max-width:12vmin;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===================== VOTE (i clienti scelgono) ===================== */
.vote-screen{flex:1;display:flex;flex-direction:column;padding:3vmin 5vmin}
.vote-list{display:flex;flex-direction:column;gap:1.6vmin;max-width:80vmin;margin:0 auto;width:100%}
.vote-row{position:relative;display:flex;align-items:center;gap:2vmin;background:var(--surface);border:1px solid var(--line);border-radius:1.4vmin;padding:2vmin 2.6vmin;overflow:hidden}
.vote-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,rgba(255,46,154,.4),rgba(122,43,255,.28));transition:width .4s}
.vote-lbl{position:relative;font-weight:700;font-size:2.6vmin;flex:1}
.vote-cnt{position:relative;font-family:var(--mono);font-weight:700;color:var(--lime);font-size:2.8vmin}

/* ===================== MANAGER TABS (mobile-friendly) ===================== */
.mgr-tabs{position:sticky;top:0;z-index:30;display:flex;gap:8px;padding:10px 0;margin-bottom:14px;background:linear-gradient(180deg,var(--bg) 70%,transparent);backdrop-filter:blur(6px)}
.mtab{flex:1;border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:12px;padding:13px;font-weight:700;font-size:15px}
.mtab.active{border-color:var(--magenta);color:#fff;background:linear-gradient(135deg,rgba(255,46,154,.22),transparent);box-shadow:0 0 16px rgba(255,46,154,.25)}
.mgr-pane{display:block}
@media (max-width:640px){
  .mgr-root{padding:14px 12px 60px}
  .mgr-head .wordmark{font-size:17px}
  .modes{grid-template-columns:repeat(2,1fr)}
  .ctl-row .btn{min-width:46%}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
}

/* ===================== BENCH — Forza Bestiale ===================== */
/* screen */
.bench-screen{flex:1;display:flex;flex-direction:column;padding:2vmin 3vmin}
.bench-rhythm{text-align:center;font-family:var(--mono);font-weight:700;font-size:2.6vmin;color:var(--muted);letter-spacing:.1em;margin:1vmin 0;text-transform:uppercase}
.bench-rhythm.hot{color:var(--lime);text-shadow:0 0 16px rgba(194,255,60,.6)}
.bench-arena{flex:1;display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;gap:2vmin}
.bench-side{display:flex;flex-direction:column;align-items:center;gap:.6vmin;padding:2vmin;border-radius:2vmin;border:1px solid var(--line);background:var(--surface)}
.bench-side.left{box-shadow:inset 0 0 30px rgba(255,46,154,.18)}
.bench-side.right{box-shadow:inset 0 0 30px rgba(94,200,224,.18)}
.bench-side.boost{outline:.4vmin solid var(--lime);box-shadow:0 0 30px rgba(194,255,60,.4)}
.bench-beast{font-size:10vmin;line-height:1}
.bench-team{font-family:var(--display);font-weight:700;font-size:2.2vmin;text-transform:uppercase}
.bench-rpm{font-family:var(--mono);font-weight:700;font-size:3.4vmin;color:var(--lime)}
.bench-cnt{font-size:1.6vmin;color:var(--muted)}
.bench-track{position:relative;height:8vmin;border-radius:4vmin;background:linear-gradient(90deg,rgba(255,46,154,.3),rgba(122,43,255,.2),rgba(94,200,224,.3));border:1px solid var(--line);overflow:hidden}
.bench-track::after{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:rgba(255,255,255,.3)}
.bench-marker{position:absolute;top:50%;width:6vmin;height:6vmin;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff,var(--lime));transform:translate(-50%,-50%);box-shadow:0 0 24px var(--lime);transition:left .15s linear}
/* client */
.bench-c{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center}
.bench-c-team{font-family:var(--display);font-weight:700;font-size:20px;text-transform:uppercase}
.bench-c-rhythm{font-family:var(--mono);font-size:13px;color:var(--muted);min-height:18px;letter-spacing:.06em}
.bench-c-rhythm.hot{color:var(--lime);text-shadow:0 0 10px rgba(194,255,60,.6)}
.bench-c-engine{display:flex;align-items:stretch;gap:10px;width:100%;justify-content:center}
.heat{width:20px;height:240px;max-height:46vh;border-radius:12px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:flex-end;overflow:hidden}
.heat-fill{width:100%;height:0%;background:linear-gradient(0deg,#ffb84d,var(--magenta));transition:height .1s}
.bench-btn{flex:1;max-width:300px;height:240px;max-height:46vh;border:none;border-radius:24px;font-family:var(--display);font-weight:700;font-size:30px;color:#10210a;background:radial-gradient(circle at 38% 30%,#EFFFC0,var(--lime) 60%,#7da316);box-shadow:0 0 40px rgba(194,255,60,.5);text-transform:uppercase}
.bench-btn.hit{transform:scale(.96);filter:brightness(1.25)}
.bench-btn.overheat{background:var(--magenta);color:#fff;box-shadow:0 0 40px rgba(255,46,154,.6)}
.bench-c-hint{font-size:13px;color:var(--muted);max-width:300px}

/* ===================== TRIVIA — extra flair ===================== */
.trivia-fx{margin-top:2vmin;text-align:center;font-family:var(--mono);font-weight:700;font-size:2.4vmin;color:#fff;background:rgba(255,46,154,.25);border:1px solid var(--magenta);border-radius:1.2vmin;padding:1vmin 2vmin;align-self:center}
.hex-banner{background:rgba(122,43,255,.25);border:1px solid var(--purple);border-radius:10px;padding:9px 12px;font-size:13px;font-weight:700;margin:8px 0;text-align:center}
.p-stage.hex-blur .quiz-opts{filter:blur(6px);transition:filter .3s}
.item-tray{margin-top:16px;border-top:1px dashed var(--line);padding-top:12px;display:flex;flex-direction:column;gap:8px}
.item-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;font-weight:600}
.item-ico{font-size:20px}
.item-row .mini{margin-left:0}

/* ===================== ASTER — Scudi Asteroidi ===================== */
/* screen (DOM renderer) */
.aster-screen{flex:1;display:flex;flex-direction:column;min-height:0}
.aster-hud{padding:2vmin 3vmin 0;display:flex;flex-direction:column;gap:1vmin}
.aster-stats{display:flex;gap:2.4vmin;font-family:var(--mono);font-weight:700;font-size:3vmin;color:var(--lime)}
.aster-space{position:relative;flex:1;min-height:0;overflow:hidden}
.aster-planet{position:absolute;border-radius:50%;transform:translate(-50%,-50%);display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:3vmin;color:#04243f;background:radial-gradient(circle at 38% 32%,#aeeaff,#1a4a8a 70%);box-shadow:0 0 40px rgba(126,216,255,.5),inset 0 0 24px rgba(0,0,0,.25)}
.aster-shield{position:absolute;border-radius:40px}
.aster-rock{position:absolute;transform:translate(-50%,-50%);font-size:4.4vmin;line-height:1;filter:drop-shadow(0 0 6px rgba(255,90,120,.7));will-change:left,top}
.aster-rock.boom{animation:rockboom .22s ease-out forwards}
@keyframes rockboom{from{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2.2);opacity:0}}
/* client */
.aster-c{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center}
.aster-c-hp{font-family:var(--mono);font-size:14px;color:var(--lime)}
.dial{position:relative;width:240px;height:240px;max-width:74vw;max-height:74vw;border-radius:50%;background:radial-gradient(circle at 50% 50%,var(--surface) 52%,var(--surface-2) 53%);border:2px solid var(--line);touch-action:none}
.dial::after{content:"";position:absolute;inset:32%;border-radius:50%;background:radial-gradient(circle at 40% 35%,#7fd8ff,#1a4a8a);box-shadow:0 0 24px rgba(127,216,255,.5)}
.dial-knob{position:absolute;width:34px;height:34px;border-radius:50%;background:radial-gradient(circle at 38% 30%,#fff,var(--magenta));transform:translate(-50%,-50%);left:88%;top:50%;box-shadow:0 0 18px var(--magenta)}
.dial-hint{position:absolute;left:0;right:0;bottom:-26px;font-size:12px;color:var(--muted)}
.super-btn{max-width:300px;background:var(--purple);color:#fff;box-shadow:0 0 18px rgba(122,43,255,.4)}
.super-btn.ready{background:var(--lime);color:#10210a;box-shadow:0 0 22px rgba(194,255,60,.6);animation:pulse 1.4s infinite}
.super-bar{width:100%;max-width:300px;height:8px;border-radius:6px;background:var(--surface);overflow:hidden}
.super-fill{height:100%;width:0%;background:var(--purple);transition:width .1s}

/* ===================== RACE — Corse Neon ===================== */
/* screen */
.race-screen{flex:1;display:flex;flex-direction:column;padding:1.6vmin 3vmin;gap:1vmin;background:linear-gradient(180deg,rgba(122,43,255,.08),transparent)}
.race-top{display:flex;justify-content:space-between;align-items:center}
.race-phase{font-family:var(--mono);font-weight:700;font-size:2.6vmin;color:var(--lime)}
.race-pot{color:var(--amber);font-size:2vmin}
.race-track{flex:1;display:flex;flex-direction:column;justify-content:center;gap:1.2vmin}
.race-lane{display:flex;align-items:center;gap:1.4vmin}
.race-odds{font-family:var(--mono);font-weight:700;font-size:1.7vmin;width:18vmin;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.race-rail{position:relative;flex:1;height:5vmin;border-radius:2.5vmin;background:repeating-linear-gradient(90deg,var(--surface),var(--surface) 4vmin,var(--surface-2) 4vmin,var(--surface-2) 8vmin);border:1px solid var(--line)}
.race-car{position:absolute;top:50%;transform:translateY(-50%);font-size:3.6vmin;transition:left .14s linear;filter:drop-shadow(0 0 6px rgba(255,255,255,.3))}
.race-car.boost{filter:drop-shadow(0 0 10px var(--lime))}
.race-car.spin{animation:spin360 .5s linear infinite}
@keyframes spin360{to{transform:translateY(-50%) rotate(360deg)}}
.race-oil{position:absolute;top:50%;transform:translate(-50%,-50%);font-size:2.6vmin}
.race-finish{position:absolute;right:.4vmin;top:50%;transform:translateY(-50%);font-size:2.6vmin;opacity:.6}
.race-place{font-family:var(--mono);font-weight:700;font-size:2vmin;width:5vmin;color:var(--muted)}
.race-place.p1{color:var(--lime)}.race-place.p2{color:#fff}.race-place.p3{color:var(--amber)}
.race-winners{background:var(--surface);border:1px solid var(--line);border-radius:1.4vmin;padding:1.4vmin 2vmin}
.race-win-row{display:flex;gap:2vmin;align-items:center;font-size:2vmin;padding:.4vmin 0}
.race-win-row .nm{flex:1;font-weight:700}.race-win-row .pts{font-family:var(--mono);color:var(--lime);font-weight:700}
.race-board{display:flex;flex-wrap:wrap;gap:.4vmin 2.4vmin}
.race-board .rank{min-width:24vmin}
/* client */
.race-credits{font-family:var(--mono);font-weight:700;color:var(--amber);text-align:center;margin-bottom:8px}
.bet-tabs{display:flex;gap:6px;margin-bottom:10px}
.bet-tab{flex:1;border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:10px;padding:11px;font-weight:700}
.bet-tab.on{border-color:var(--magenta);color:#fff;background:rgba(255,46,154,.15)}
.bet-car{display:flex;align-items:center;gap:10px;width:100%;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:12px;padding:12px;margin-bottom:8px}
.bet-car.on{box-shadow:0 0 14px rgba(255,255,255,.15)}
.bc-emoji{font-size:24px}.bc-name{flex:1;text-align:left;font-weight:700}.bc-odds{font-family:var(--mono);font-weight:700}
.amt-row{display:flex;align-items:center;gap:10px;margin:10px 0}
.amt-row .btn{width:auto;flex:1}
.amt-val{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--lime);min-width:80px;text-align:center}
.sab-box{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:10px}
.sab-lab{font-weight:700;font-size:14px;margin-bottom:8px}
.sab-cars{display:flex;gap:8px;flex-wrap:wrap}
.sab-car{font-size:22px;width:52px;height:52px;border:2px solid var(--line);background:var(--bg-2);border-radius:12px}
.sab-car:disabled{opacity:.4}

/* ===================== IMPOSTOR — L'Impostore ===================== */
/* screen */
.imp-screen{flex:1;display:flex;flex-direction:column;padding:2vmin 4vmin;gap:1.6vmin}
.imp-top{display:flex;justify-content:space-between;align-items:center}
.imp-hint{text-align:center;font-size:2.4vmin;color:var(--ink)}
.imp-hint b{color:var(--lime);font-size:3vmin}
.imp-verdict{text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:2vmin;padding:2vmin}
.imp-verdict.caught{box-shadow:0 0 30px rgba(194,255,60,.3);border-color:var(--lime)}
.imp-verdict.escaped{box-shadow:0 0 30px rgba(255,46,154,.3);border-color:var(--magenta)}
.imp-ledger{display:flex;flex-wrap:wrap;gap:1.4vmin;justify-content:center;margin-top:auto}
.imp-card{display:flex;flex-direction:column;align-items:center;gap:.5vmin;background:var(--surface);border:1px solid var(--line);border-radius:1.4vmin;padding:1.4vmin 2vmin;min-width:16vmin}
.imp-card.exiled{opacity:.45;filter:grayscale(.7)}
.imp-ava{font-size:4vmin}
.imp-nm{font-weight:700;font-size:2vmin}
.imp-state{font-family:var(--mono);font-size:1.4vmin;color:var(--muted);text-transform:uppercase}
.imp-votes{font-family:var(--mono);font-size:1.8vmin;color:var(--magenta)}
/* client */
.role-card{border-radius:14px;padding:16px;border:1px solid var(--line);background:var(--surface);text-align:left}
.role-card.imp{border-color:var(--magenta);box-shadow:0 0 18px rgba(255,46,154,.25)}
.role-card.reg{border-color:var(--lime);box-shadow:0 0 18px rgba(194,255,60,.2)}
.role-t{font-family:var(--display);font-weight:700;font-size:20px;margin-bottom:6px}
.role-d{font-size:14px;color:var(--ink);line-height:1.4}
.role-d b{color:var(--lime);font-size:18px}

/* ===================== SHEEP — Conta le Pecore ===================== */
.sheep-screen{flex:1;display:flex;flex-direction:column;padding:2vmin 3vmin}
.sheep-meta{display:flex;align-items:center;gap:1.6vmin;font-family:var(--mono)}
.sheep-field{position:relative;flex:1;margin-top:1.4vmin;border-radius:2vmin;background:radial-gradient(120% 100% at 50% 0%,rgba(122,43,255,.12),transparent),var(--bg-2);border:1px solid var(--line);overflow:hidden}
.sheep-one{position:absolute;line-height:1;will-change:transform;animation-name:sheep-bob;animation-timing-function:ease-in-out;animation-iteration-count:infinite;animation-direction:alternate}
@keyframes sheep-bob{from{transform:translateY(0) rotate(-6deg)}to{transform:translateY(-14px) rotate(6deg)}}
.sheep-hint{text-align:center;font-family:var(--mono);font-size:1.8vmin;color:var(--muted);margin-top:1.2vmin}
.sheep-count{text-align:center;margin:2vmin 0}
.sheep-big{font-family:var(--display);font-weight:700;font-size:12vmin;color:var(--lime);text-shadow:0 0 28px rgba(194,255,60,.5)}

/* ===================== LED BOARD — teleprompter ===================== */
.led-screen{flex:1;display:flex;align-items:center;justify-content:center;background:#05030a;background-image:radial-gradient(rgba(255,46,154,.10) 1px,transparent 1px);background-size:10px 10px}
.led-row{width:100%;overflow:hidden;white-space:nowrap;padding:4vmin 0;border-top:2px solid rgba(255,46,154,.25);border-bottom:2px solid rgba(255,46,154,.25)}
.led-track{display:inline-flex;animation-name:led-scroll;animation-timing-function:linear;animation-iteration-count:infinite}
.led-seg{font-family:var(--mono);font-weight:700;font-size:13vmin;line-height:1;text-transform:uppercase;letter-spacing:.04em;color:var(--lime);text-shadow:0 0 12px rgba(194,255,60,.55),0 0 38px rgba(194,255,60,.3);padding-right:6vmin;white-space:nowrap}
@keyframes led-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===================== FLOATING JOIN QR (during games) ===================== */
.float-qr{position:absolute;z-index:6;display:flex;flex-direction:column;align-items:center;gap:.6vmin;background:rgba(5,3,10,.78);border:1px solid var(--magenta);border-radius:1.4vmin;padding:1.2vmin;box-shadow:0 0 24px rgba(255,46,154,.4);backdrop-filter:blur(4px)}
.float-qr.br{right:2vmin;bottom:2vmin}
.float-qr.bl{left:2vmin;bottom:2vmin}
.float-qr.tr{right:2vmin;top:2vmin}
.float-qr.tl{left:2vmin;top:2vmin}
.float-qr img{width:14vmin;height:14vmin;background:#fff;border-radius:.6vmin;display:block}
.fq-lab{font-family:var(--mono);font-size:1.4vmin;color:var(--ink);text-transform:uppercase;letter-spacing:.08em}
.fq-lab b{color:var(--lime)}

/* ===================== QUIZ CATEGORIES (manager) ===================== */
.cat-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;width:100%;margin:2px 0 4px}
.cat-lab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.cat-chip{border:1px solid var(--line);background:var(--bg-2);color:var(--muted);border-radius:20px;padding:6px 12px;font-size:12px;font-weight:700}
.cat-chip.on{border-color:var(--lime);color:var(--lime);background:rgba(194,255,60,.12)}
.cat-input{max-width:200px}

/* ===================== LED STYLES: split-flap board + big phrase ===================== */
.flip-screen{flex-direction:column;justify-content:center;gap:1vmin;background:#0a0a0d;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px);background-size:100% 3px}
.flap-board{display:flex;flex-direction:column;gap:.55vmin;align-items:center}
.flap-row{display:flex;gap:.4vmin;justify-content:center}
.flap{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:4.8vmin;height:7.8vmin;min-width:22px;min-height:36px;text-align:center;font-family:var(--mono);font-weight:700;font-size:4.6vmin;color:var(--amber);background:linear-gradient(180deg,#26262b 0 49.5%,#141417 50% 100%);border:1px solid #000;border-radius:.5vmin;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04),0 2px 4px rgba(0,0,0,.5);position:relative;overflow:hidden}
.flap::after{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:rgba(0,0,0,.75);transform:translateY(-1px)}
.flap.flip{animation:flapflip .1s ease-out}
@keyframes flapflip{0%{transform:translateY(-12%);filter:brightness(1.7)}100%{transform:translateY(0);filter:brightness(1)}}
.big-screen{align-items:center;justify-content:center;background:#05030a;background-image:radial-gradient(rgba(194,255,60,.08) 1px,transparent 1px);background-size:12px 12px}
.big-phrase{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:11vmin;line-height:1.05;text-align:center;color:var(--lime);text-shadow:0 0 28px rgba(194,255,60,.55);opacity:0;transition:opacity .45s ease;padding:0 5vmin;max-width:94vw}
.big-phrase.show{opacity:1}

/* LED style: AI writing (ChatGPT-like typewriter) */
.ai-screen{align-items:center;justify-content:center;background:#0a0c10}
.ai-card{width:84vw;max-width:150vmin;background:#13151b;border:1px solid #2a2f3a;border-radius:2vmin;padding:3vmin 4vmin;box-shadow:0 0 60px rgba(0,0,0,.55)}
.ai-head{display:flex;align-items:center;gap:1.2vmin;font-family:var(--mono);font-size:2vmin;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:2.4vmin}
.ai-dot{width:1.6vmin;height:1.6vmin;border-radius:50%;background:var(--lime);box-shadow:0 0 12px var(--lime);animation:pulse 2s infinite}
.ai-body{font-family:var(--mono);font-size:5vmin;line-height:1.35;color:#e9ffd9;min-height:16vmin;word-break:break-word}
.ai-prompt{color:var(--lime)}
.ai-cursor{color:var(--lime);margin-left:.2vmin;animation:aiblink 1s steps(1) infinite}
@keyframes aiblink{50%{opacity:0}}

/* ===================== BRAND LOCKUP: "la Pecora Nera · il pub di Tricesimo" ===================== */
.brand-stack{display:flex;flex-direction:column;justify-content:center;line-height:1.02}
.art{text-transform:none;font-style:italic;font-weight:500;opacity:.92}
.brand-sub{font-family:var(--mono);text-transform:lowercase;letter-spacing:.03em;color:var(--muted);white-space:nowrap}
.s-brand .brand-sub{font-size:1.5vmin;margin-top:.5vmin}
.mgr-head .brand-sub{font-size:11px;margin-top:3px}
.p-bar .brand .brand-sub{font-size:10px;color:var(--muted);font-weight:400}

/* ===================== QUIZ SCOREBOARD (between questions) ===================== */
.score-board{max-width:84vmin;margin:1vmin auto 0;width:100%;display:flex;flex-direction:column;gap:1.2vmin}
.score-board .q-lab{margin-bottom:1vmin}
.score-row{display:flex;align-items:center;gap:1.6vmin;background:var(--surface);border:1px solid var(--line);border-radius:1.4vmin;padding:1.1vmin 2vmin;opacity:0;animation:sb-in .45s ease both}
@keyframes sb-in{from{opacity:0;transform:translateY(1.6vmin) scale(.98)}to{opacity:1;transform:none}}
.score-row.lead{border-color:var(--lime);box-shadow:0 0 22px rgba(194,255,60,.25)}
.sb-pos{font-family:var(--display);font-weight:700;font-size:3vmin;color:var(--purple);width:3.2vmin;text-align:center}
.score-row.lead .sb-pos{color:var(--lime)}
.sb-ava{width:4.6vmin;height:4.6vmin;border-radius:50%;display:grid;place-items:center;font-size:2.6vmin;color:#0B0712;flex:0 0 auto}
.sb-nm{font-weight:700;font-size:2.6vmin;min-width:11vmin;max-width:22vmin;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-bar-wrap{flex:1;height:2.6vmin;background:var(--bg-2);border-radius:1.3vmin;overflow:hidden}
.sb-bar{display:block;height:100%;border-radius:1.3vmin;animation:sb-grow .7s cubic-bezier(.2,.8,.2,1) both}
@keyframes sb-grow{from{width:0!important}}
.sb-pts{font-family:var(--mono);font-weight:700;font-size:3vmin;color:var(--lime);min-width:7vmin;text-align:right}
.qitem.mine{border:1px solid var(--lime);border-radius:10px;padding:6px 8px}

/* ===================== GALLERY (media carousel / dashboard) ===================== */
.gallery-screen{position:absolute;inset:0;background:#05030a;overflow:hidden;display:flex;align-items:center;justify-content:center}
.gallery-screen .slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.06);transition:opacity 1.1s ease,transform 6s ease}
.gallery-screen .slide.on{opacity:1;transform:scale(1)}
.gallery-dots{position:absolute;left:0;right:0;bottom:2.4vmin;display:flex;gap:1.2vmin;justify-content:center;z-index:2}
.gdot{width:1.4vmin;height:1.4vmin;border-radius:50%;background:rgba(255,255,255,.3);transition:.3s}
.gdot.on{background:var(--lime);box-shadow:0 0 10px var(--lime)}
/* smooth transition whenever the screen swaps view (main <-> dashboard) */
@keyframes bodyfade{from{opacity:0;transform:scale(.995)}to{opacity:1;transform:none}}
.s-body{animation:bodyfade .45s ease}
/* gallery editor */
.gal-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.gal-row .input{flex:1}
.gal-thumb{width:52px;height:38px;object-fit:cover;border-radius:6px;background:var(--bg-2);border:1px solid var(--line);flex:0 0 auto}

/* a gallery image that failed to load: show it instead of a black screen */
.gallery-screen .slide.broken{opacity:.9;background:repeating-linear-gradient(45deg,#1a1030,#1a1030 18px,#241640 18px,#241640 36px)}

/* quiz category creation UI */
.help-box{background:rgba(122,43,255,.1);border:1px solid var(--line);border-left:3px solid var(--purple);border-radius:10px;padding:10px 12px;font-size:13px;color:var(--muted);line-height:1.4;margin-bottom:10px}
.help-box b{color:var(--ink)}
.cat-create{display:flex;gap:8px;margin-bottom:10px}
.cat-create .input{flex:1}
