*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:#0A0B1A;font-family:'Inter',system-ui,sans-serif;color:#fff}
body{display:flex;justify-content:center;align-items:center}

:root{
  --bg:#0A0B1A;--bg2:#0F1128;--bg3:#141735;
  --purple:#7C3AED;--purple-l:#9F67FF;--purple-d:#5B21B6;
  --red:#DC2626;--red-l:#EF4444;--red-d:#7F1D1D;
  --gold:#F59E0B;--green:#22C55E;
  --text:#fff;--text2:#A5B4FC;--text3:#64748B;
  --border:rgba(255,255,255,0.1);
  --glow-p:0 0 30px rgba(124,58,237,0.5);
  --glow-r:0 0 30px rgba(220,38,38,0.6);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --ease:cubic-bezier(0.4,0,0.2,1);
}

#app{width:100%;max-width:420px;height:100vh;height:100dvh;position:relative;overflow:hidden;background:var(--bg)}

.screen{position:absolute;inset:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;
  transition:transform .3s var(--ease),opacity .3s var(--ease);will-change:transform,opacity}
.screen.hidden{display:none}
.screen.slide-out-left{transform:translateX(-100%);opacity:0;pointer-events:none}
.screen.slide-out-right{transform:translateX(100%);opacity:0;pointer-events:none}
.screen.slide-in{transform:translateX(0);opacity:1}

/* ══ SPLASH ══ */
#splash{justify-content:center;align-items:center;background:radial-gradient(ellipse at 60% 40%,#1a0533 0%,#0A0B1A 70%);gap:16px}
.splash-logo{text-align:center;animation:splashPop .6s var(--ease-spring) .2s both}
.splash-find{display:block;font-family:'Poppins',sans-serif;font-weight:900;font-size:56px;color:#fff;letter-spacing:-2px;line-height:1}
.splash-imposter{display:block;font-family:'Poppins',sans-serif;font-weight:900;font-size:56px;color:var(--purple-l);letter-spacing:-2px;line-height:1;text-shadow:0 0 40px rgba(124,58,237,.8)}
.splash-eye{color:#fff;filter:drop-shadow(0 0 8px #fff)}
.splash-tag{color:var(--text2);font-size:14px;margin-top:8px;opacity:0;animation:fadeUp .5s ease .9s both}
.splash-figure{width:120px;animation:splashPop .6s var(--ease-spring) .5s both;filter:drop-shadow(0 0 24px rgba(124,58,237,.6))}
@keyframes splashPop{from{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes fadeUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ══ HOME ══ */
#home{background:var(--bg);padding-bottom:80px}
.home-hero{position:relative;padding:20px 16px 8px;background:radial-gradient(ellipse at 80% 20%,#1a0533 0%,transparent 65%);
  display:flex;align-items:flex-start;justify-content:space-between;overflow:hidden;gap:8px}
.hero-text{flex:1;min-width:0}
.hero-title-find{font-family:'Poppins',sans-serif;font-weight:900;font-size:36px;color:#fff;letter-spacing:-1px;line-height:1}
.hero-title-imp{font-family:'Poppins',sans-serif;font-weight:900;font-size:36px;color:var(--purple-l);letter-spacing:-1px;line-height:1.1;text-shadow:0 0 30px rgba(124,58,237,.6)}
.hero-sub{font-size:13px;color:var(--text2);margin-top:8px;line-height:1.5}
.hero-sub span{color:var(--gold);font-weight:700}
.hero-figure-wrap{flex-shrink:0;width:108px;margin-top:-4px}
.hero-figure-wrap img{width:100%;display:block;filter:drop-shadow(0 8px 24px rgba(124,58,237,.4))}
.home-settings-btn{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:var(--bg3);
  border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;z-index:2}

.section-card{margin:12px 16px 0;padding:16px;background:var(--bg2);border-radius:16px;border:1px solid var(--border)}
.section-label{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text2);text-transform:uppercase;display:flex;align-items:center;gap:6px;margin-bottom:12px}

.players-row{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}
.players-row::-webkit-scrollbar{display:none}
.player-chip{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;flex-shrink:0;min-width:56px}
.player-avatar{width:52px;height:52px;border-radius:50%;border:2px solid transparent;position:relative;overflow:hidden;
  background:var(--bg3);transition:all .2s}
.player-avatar svg,.player-avatar img{width:100%;height:100%}
.player-chip.selected .player-avatar{border-color:var(--purple-l);box-shadow:0 0 12px rgba(124,58,237,.5)}
.player-name{font-size:11px;color:var(--text2);text-align:center;max-width:56px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-chip.selected .player-name{color:var(--purple-l);font-weight:600}
.add-player-btn{width:52px;height:52px;border-radius:50%;border:2px dashed var(--border);display:flex;align-items:center;
  justify-content:center;font-size:22px;color:var(--text3);cursor:pointer;transition:all .2s;flex-shrink:0}
.add-player-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}

.imposter-row{display:flex;align-items:center;justify-content:space-between;padding-top:12px;margin-top:12px;border-top:1px solid var(--border)}
.imposter-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text2);text-transform:uppercase}
.imposter-select{display:flex;align-items:center;gap:6px;color:var(--red-l);font-size:14px;font-weight:700;cursor:pointer}

.cats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.see-all{font-size:13px;color:var(--purple-l);font-weight:600;cursor:pointer}
.cats-row{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;margin:0 -4px;padding:4px}
.cats-row::-webkit-scrollbar{display:none}
.cat-card{flex-shrink:0;width:88px;border-radius:12px;overflow:hidden;cursor:pointer;border:2px solid transparent;
  transition:all .2s;position:relative}
.cat-card.selected{border-color:#fff;box-shadow:0 0 16px rgba(255,255,255,.2)}
.cat-card-bg{height:72px;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative}
.cat-check{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:#fff;
  display:flex;align-items:center;justify-content:center;font-size:10px;opacity:0;transition:opacity .2s;color:#000;font-weight:900}
.cat-card.selected .cat-check{opacity:1}
.cat-info{background:rgba(0,0,0,.5);padding:6px 6px 4px;text-align:center}
.cat-name{font-size:10px;font-weight:600;color:#fff;line-height:1.2;min-height:24px;display:flex;align-items:center;justify-content:center;text-align:center}
.cat-badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;padding:1px 6px;border-radius:4px;margin-top:2px}
.cat-badge.free{background:#065f46;color:#6ee7b7}
.cat-badge.premium{background:#92400e;color:#fcd34d}

.toggles-row{display:flex;gap:10px;margin:12px 16px 0}
.toggle-card{flex:1;padding:12px;background:var(--bg2);border-radius:12px;border:1px solid var(--border);display:flex;align-items:center;gap:10px}
.toggle-icon{font-size:24px}
.toggle-info{flex:1;min-width:0}
.toggle-title{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text2)}
.toggle-state{font-size:12px;font-weight:600;color:var(--text3);margin-top:1px}
.toggle-state.on-purple{color:var(--purple-l)}
.toggle-state.on-gold{color:var(--gold)}
.toggle-switch{width:40px;height:22px;border-radius:11px;background:var(--bg3);border:1px solid var(--border);
  position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.toggle-switch.on-purple{background:var(--purple)}
.toggle-switch.on-gold{background:var(--gold)}
.toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;
  transition:transform .2s var(--ease-spring);box-shadow:0 1px 4px rgba(0,0,0,.4)}
.toggle-switch.on-purple .toggle-knob,.toggle-switch.on-gold .toggle-knob{transform:translateX(18px)}

.share-banner{margin:12px 16px 0;padding:14px 16px;background:linear-gradient(135deg,#1a0a3d,#0f1128);
  border-radius:16px;border:1px solid rgba(124,58,237,.3);display:flex;align-items:center;gap:12px}
.share-gifts{font-size:28px;position:relative}
.share-coins{font-size:14px;position:absolute;bottom:-4px;right:-8px}
.share-text{flex:1;min-width:0}
.share-text strong{font-size:13px;font-weight:700}
.share-text p{font-size:11px;color:var(--text2);margin-top:2px}
.share-btn{padding:8px 14px;background:var(--purple);border-radius:10px;font-size:12px;font-weight:700;white-space:nowrap;
  border:none;color:#fff;cursor:pointer;display:flex;align-items:center;gap:6px;flex-shrink:0}

.play-wrap{padding:14px 16px 0}
.play-btn{width:100%;height:64px;border-radius:32px;background:linear-gradient(135deg,#e11d48,#be123c);
  border:none;color:#fff;font-family:'Poppins',sans-serif;font-size:24px;font-weight:900;letter-spacing:2px;
  cursor:pointer;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:12px;
  box-shadow:0 8px 30px rgba(225,29,72,.4);transition:all .2s}
.play-btn:disabled{background:#333;box-shadow:none;color:var(--text3);cursor:not-allowed}
.play-btn:not(:disabled):active{transform:scale(.97)}
.play-btn .rays{position:absolute;inset:0;background:repeating-conic-gradient(rgba(255,255,255,.05) 0deg,transparent 5deg,transparent 30deg);
  animation:raysRotate 8s linear infinite}
@keyframes raysRotate{to{transform:rotate(360deg)}}
.play-icon{font-size:22px;position:relative;z-index:1}
.play-text{position:relative;z-index:1}

.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;
  background:rgba(10,11,26,.95);backdrop-filter:blur(20px);border-top:1px solid var(--border);
  display:flex;padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:100}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:4px;
  color:var(--text3);font-size:10px;font-weight:500;transition:color .2s;border:none;background:none}
.nav-item.active{color:var(--red-l)}
.nav-item svg{width:22px;height:22px}
.nav-dot{width:4px;height:4px;border-radius:50%;background:var(--red-l);margin:0 auto;opacity:0}
.nav-item.active .nav-dot{opacity:1}

/* ══ REVEAL — FULL CARD, NO BACK ══ */
#reveal{background:var(--bg);padding:0;overflow:hidden;justify-content:flex-start}
.reveal-header{width:100%;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) 20px 6px;position:relative}
.reveal-progress{font-size:13px;font-weight:700;color:var(--text2);background:var(--bg3);padding:6px 16px;border-radius:20px;border:1px solid var(--border)}
.reveal-players-btn{position:absolute;right:20px;width:36px;height:36px;border-radius:50%;background:var(--bg3);
  border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer}
.reveal-subtitle{font-size:11px;font-weight:700;letter-spacing:3px;color:var(--text3);text-transform:uppercase;
  text-align:center;margin-bottom:6px}
.reveal-identity{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:14px}
.reveal-player-name{font-family:'Poppins',sans-serif;font-size:20px;font-weight:800;color:#fff}
.reveal-player-avatar{width:48px;height:48px;border-radius:50%;border:3px solid var(--purple-l);overflow:hidden;
  background:var(--bg3);box-shadow:0 0 20px rgba(124,58,237,.4)}
.reveal-player-avatar svg{width:100%;height:100%}

/* THE FULL CARD — entire surface is hold target */
.card-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:0 24px;min-height:0}
.card-wrap{perspective:1200px;width:100%;max-width:300px;height:100%;max-height:440px;position:relative;
  cursor:pointer;user-select:none;touch-action:none}
.card{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s var(--ease);border-radius:28px}
.card.flipped{transform:rotateY(180deg)}
.card-face{position:absolute;inset:0;border-radius:28px;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;
  box-shadow:0 24px 70px rgba(0,0,0,.55)}
.card-front{background:linear-gradient(145deg,#3b1f7a,#7C3AED);border:1px solid rgba(159,103,255,.3)}
.card-back{transform:rotateY(180deg);background:linear-gradient(145deg,#3b1f7a,#7C3AED);border:1px solid rgba(159,103,255,.3)}
.card-back.imposter-card{background:linear-gradient(145deg,#7f1d1d,#DC2626);border:1px solid rgba(239,68,68,.4);
  box-shadow:0 24px 70px rgba(220,38,38,.45)}

/* Hold progress ring around entire card border */
.card-front::before{content:'';position:absolute;inset:-3px;border-radius:31px;pointer-events:none;
  background:conic-gradient(#fff var(--hold-pct,0%),transparent var(--hold-pct,0%));
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 5px),#fff calc(100% - 5px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 5px),#fff calc(100% - 5px));
  opacity:.9;transition:none}

.card-mask-icon{font-size:48px;opacity:.3}
.card-front-name{font-family:'Poppins',sans-serif;font-size:30px;font-weight:900;color:#fff;text-align:center}
.hold-indicator{display:flex;flex-direction:column;align-items:center;gap:6px}
.hold-icon{font-size:30px;animation:holdPulse 1.5s ease-in-out infinite}
@keyframes holdPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}
.hold-text{font-size:11px;font-weight:700;letter-spacing:2px;color:rgba(255,255,255,.6);text-transform:uppercase}

.word-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:6px}
.word-revealed{font-family:'Poppins',sans-serif;font-size:40px;font-weight:900;color:#fff;text-align:center;line-height:1.05;
  text-shadow:0 0 30px rgba(255,255,255,.3)}
.word-emoji{font-size:52px;line-height:1}
.release-hint{font-size:11px;color:rgba(255,255,255,.4);letter-spacing:1px;display:flex;align-items:center;gap:4px}

.imp-mask{font-size:42px}
.imp-title{font-size:13px;font-weight:700;letter-spacing:2px;color:rgba(255,100,100,.9);text-transform:uppercase}
.imp-word{font-family:'Poppins',sans-serif;font-size:34px;font-weight:900;color:#fca5a5;text-align:center;line-height:1.1;text-shadow:var(--glow-r)}
.hint-box{background:rgba(0,0,0,.3);border-radius:12px;padding:10px 20px;border:1px solid rgba(255,100,100,.3);text-align:center}
.hint-label{font-size:10px;font-weight:700;letter-spacing:2px;color:rgba(255,150,150,.7);text-transform:uppercase;margin-bottom:4px}
.hint-word{font-size:20px;font-weight:800;color:#fff}
.hint-tip{font-size:11px;color:rgba(255,200,200,.7);display:flex;align-items:center;gap:4px;text-align:center}

.next-btn-wrap{width:100%;padding:14px 24px max(14px,env(safe-area-inset-bottom));display:flex;justify-content:center}
.next-btn{width:100%;max-width:280px;height:54px;border-radius:27px;background:var(--purple);border:none;color:#fff;
  font-family:'Poppins',sans-serif;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;transition:all .2s;box-shadow:0 4px 20px rgba(124,58,237,.4);opacity:.35;pointer-events:none}
.next-btn.enabled{opacity:1;pointer-events:all}
.next-btn.enabled:active{transform:scale(.96)}
.next-btn.imposter-next{background:var(--red);box-shadow:0 4px 20px rgba(220,38,38,.4)}

/* ══ DISCUSSION ══ */
#discussion{background:var(--bg);align-items:center;justify-content:center;gap:0;padding:24px}
.disc-title{font-size:13px;font-weight:700;letter-spacing:2px;color:var(--text2);text-transform:uppercase;margin-bottom:28px;text-align:center}
.timer-wrap{position:relative;width:200px;height:200px;margin-bottom:28px}
.timer-svg{width:200px;height:200px;transform:rotate(-90deg)}
.timer-track{fill:none;stroke:var(--bg3);stroke-width:10}
.timer-fill{fill:none;stroke:var(--green);stroke-width:10;stroke-linecap:round;stroke-dasharray:565;stroke-dashoffset:0;
  transition:stroke-dashoffset 1s linear,stroke .5s}
.timer-fill.warning{stroke:var(--gold)}
.timer-fill.urgent{stroke:var(--red-l)}
.timer-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-size:52px;font-weight:900}
.timer-num.warning{color:var(--gold)}
.timer-num.urgent{color:var(--red-l);animation:timerPulse .5s ease infinite}
@keyframes timerPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.disc-category{font-size:14px;color:var(--text2);margin-bottom:20px;display:flex;align-items:center;gap:8px;text-align:center}
.disc-category span{font-weight:700;color:#fff}
.disc-speaker{background:var(--bg2);border-radius:16px;border:1px solid var(--border);padding:12px 20px;
  display:flex;align-items:center;gap:12px;margin-bottom:24px;width:100%;max-width:280px}
.disc-speaker-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:var(--bg3);flex-shrink:0}
.disc-speaker-avatar svg{width:100%;height:100%}
.disc-speaker-label{font-size:11px;color:var(--text3);font-weight:600;letter-spacing:1px;text-transform:uppercase}
.disc-speaker-name{font-size:16px;font-weight:700;color:#fff}
.disc-btns{display:flex;gap:12px;width:100%;max-width:280px}
.disc-pause{flex:1;height:48px;border-radius:24px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);
  font-size:14px;font-weight:600;cursor:pointer}
.disc-skip{flex:1;height:48px;border-radius:24px;background:var(--purple);border:none;color:#fff;font-size:14px;font-weight:700;cursor:pointer}

/* ══ VOTING ══ */
#voting{background:var(--bg);align-items:center;padding:24px;overflow-y:auto}
.voting-header{width:100%;display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:20px}
.voting-title{font-family:'Poppins',sans-serif;font-size:21px;font-weight:800;color:#fff;text-align:center}
.voting-sub{font-size:13px;color:var(--text2);text-align:center}
.voting-voter{display:flex;align-items:center;gap:8px;background:var(--bg2);border-radius:30px;padding:6px 16px 6px 6px;
  border:1px solid var(--border);margin-top:10px}
.voting-voter-avatar{width:30px;height:30px;border-radius:50%;overflow:hidden;background:var(--bg3)}
.voting-voter-avatar svg{width:100%;height:100%}
.voting-voter-name{font-size:13px;font-weight:600;color:var(--purple-l)}

.vote-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:320px}
.vote-card{padding:14px 10px;background:var(--bg2);border-radius:14px;border:2px solid var(--border);
  display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s}
.vote-card.selected{border-color:var(--red-l);background:rgba(220,38,38,.15);box-shadow:0 0 20px rgba(220,38,38,.3)}
.vote-card-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;background:var(--bg3)}
.vote-card-avatar svg{width:100%;height:100%}
.vote-card-name{font-size:13px;font-weight:700;color:#fff;text-align:center}
.vote-card.selected .vote-card-name{color:var(--red-l)}

.skip-vote-btn{width:100%;max-width:320px;height:44px;border-radius:22px;background:transparent;border:1px solid var(--border);
  color:var(--text3);font-size:13px;font-weight:600;cursor:pointer;margin-top:14px}
.confirm-vote-btn{width:100%;max-width:320px;height:52px;border-radius:26px;background:var(--red);border:none;color:#fff;
  font-family:'Poppins',sans-serif;font-size:16px;font-weight:700;cursor:pointer;margin-top:10px;
  box-shadow:0 4px 20px rgba(220,38,38,.4);opacity:.35;pointer-events:none;transition:all .2s}
.confirm-vote-btn.enabled{opacity:1;pointer-events:all}
.voting-secret{font-size:11px;color:var(--text3);text-align:center;margin-top:10px}

/* ══ VOTE CONFIRM MODAL ══ */
.confirm-vote-content{text-align:center;padding:8px 0}
.confirm-vote-icon{font-size:48px;margin-bottom:8px}
.confirm-vote-text{font-size:15px;color:var(--text2);margin-bottom:4px}
.confirm-vote-name{font-family:'Poppins',sans-serif;font-size:24px;font-weight:800;color:var(--red-l);margin-bottom:20px}
.confirm-vote-btns{display:flex;gap:10px}
.cv-btn{flex:1;height:48px;border-radius:24px;font-size:14px;font-weight:700;cursor:pointer;border:none}
.cv-btn-back{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}
.cv-btn-confirm{background:var(--red);color:#fff}

/* ══ RESULTS ══ */
#results{background:var(--bg);align-items:center;justify-content:center;padding:24px;gap:16px}
.results-title{font-family:'Poppins',sans-serif;font-size:23px;font-weight:800;text-align:center}
.results-list{width:100%;max-width:320px}
.result-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.result-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:var(--bg3);flex-shrink:0}
.result-avatar svg{width:100%;height:100%}
.result-info{flex:1;min-width:0}
.result-name{font-size:14px;font-weight:700}
.result-bar-wrap{height:8px;background:var(--bg3);border-radius:4px;margin-top:4px;overflow:hidden}
.result-bar{height:100%;border-radius:4px;background:var(--purple);width:0%}
.result-votes{font-size:13px;font-weight:700;color:var(--text2);min-width:54px;text-align:right}
.result-crown{font-size:18px}
.accused-section{width:100%;max-width:320px;text-align:center;background:var(--bg2);border-radius:16px;border:1px solid var(--border);padding:16px}
.accused-label{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-bottom:8px}
.accused-player{font-family:'Poppins',sans-serif;font-size:24px;font-weight:900;color:var(--red-l)}
.reveal-imposter-btn{width:100%;max-width:320px;height:56px;border-radius:28px;background:linear-gradient(135deg,var(--red),var(--red-d));
  border:none;color:#fff;font-family:'Poppins',sans-serif;font-size:17px;font-weight:800;cursor:pointer;
  animation:resultPulse 1.5s ease-in-out infinite;box-shadow:0 8px 30px rgba(220,38,38,.5)}
@keyframes resultPulse{0%,100%{box-shadow:0 8px 30px rgba(220,38,38,.5)}50%{box-shadow:0 8px 40px rgba(220,38,38,.8),0 0 60px rgba(220,38,38,.3)}}

/* ══ WINNER ══ */
#winner{background:var(--bg);align-items:center;justify-content:center;padding:24px;text-align:center;gap:16px}
.winner-emoji{font-size:78px;animation:winnerBounce .6s var(--ease-spring) both}
@keyframes winnerBounce{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.winner-title{font-family:'Poppins',sans-serif;font-size:30px;font-weight:900;line-height:1.1;animation:fadeUp .5s ease .2s both}
.winner-title.players{color:var(--green)}
.winner-title.imposter{color:var(--red-l)}
.winner-sub{font-size:15px;color:var(--text2);animation:fadeUp .5s ease .3s both}
.winner-word-box{background:var(--bg2);border-radius:16px;border:1px solid var(--border);padding:16px 24px;animation:fadeUp .5s ease .4s both}
.winner-word-label{font-size:11px;color:var(--text3);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.winner-word{font-family:'Poppins',sans-serif;font-size:26px;font-weight:900;display:flex;align-items:center;gap:10px;justify-content:center}
.winner-imposter-box{background:rgba(220,38,38,.1);border-radius:16px;border:1px solid rgba(220,38,38,.3);padding:12px 24px;animation:fadeUp .5s ease .5s both}
.winner-imposter-label{font-size:11px;color:rgba(255,150,150,.7);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.winner-imposter-name{font-size:22px;font-weight:800;color:var(--red-l)}
.play-again-btn{width:100%;max-width:280px;height:54px;border-radius:27px;background:linear-gradient(135deg,var(--purple),var(--purple-d));
  border:none;color:#fff;font-family:'Poppins',sans-serif;font-size:16px;font-weight:800;cursor:pointer;
  box-shadow:0 8px 30px rgba(124,58,237,.4);animation:fadeUp .5s ease .6s both}
.home-btn{background:transparent;border:1px solid var(--border);color:var(--text2);font-size:14px;font-weight:600;
  padding:12px 32px;border-radius:24px;cursor:pointer;animation:fadeUp .5s ease .7s both}
.confetti-particle{position:fixed;pointer-events:none;z-index:9999;border-radius:2px}

/* ══ MODALS ══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:flex-end;justify-content:center;
  z-index:200;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(4px)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-sheet{width:100%;max-width:420px;background:var(--bg2);border-radius:24px 24px 0 0;padding:20px max(20px,env(safe-area-inset-left)) max(20px,env(safe-area-inset-bottom));
  transform:translateY(100%);transition:transform .3s var(--ease-spring);max-height:80vh;overflow-y:auto}
.modal-overlay.open .modal-sheet{transform:translateY(0)}
.modal-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 16px}
.modal-title{font-family:'Poppins',sans-serif;font-size:18px;font-weight:800;margin-bottom:16px;text-align:center}
.name-input{width:100%;height:52px;border-radius:12px;background:var(--bg3);border:2px solid var(--border);color:#fff;
  font-size:16px;padding:0 16px;outline:none;font-family:'Inter',sans-serif;transition:border-color .2s}
.name-input:focus{border-color:var(--purple-l)}
.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin:16px 0}
.avatar-option{width:44px;height:44px;border-radius:50%;background:var(--bg3);border:2px solid transparent;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;overflow:hidden}
.avatar-option svg{width:100%;height:100%}
.avatar-option.selected{border-color:var(--purple-l);box-shadow:0 0 10px rgba(124,58,237,.5)}
.modal-btn{width:100%;height:52px;border-radius:12px;background:var(--purple);border:none;color:#fff;font-size:16px;
  font-weight:700;cursor:pointer;margin-top:8px}
.modal-btn-danger{background:var(--red)}
.modal-btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text2);margin-top:8px}
.imposter-opts{display:flex;gap:8px;margin:8px 0}
.imposter-opt{flex:1;height:48px;border-radius:12px;background:var(--bg3);border:2px solid var(--border);color:var(--text2);
  font-size:16px;font-weight:700;cursor:pointer;transition:all .2s}
.imposter-opt.selected{border-color:var(--red-l);background:rgba(220,38,38,.15);color:var(--red-l)}

.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--bg3);
  border:1px solid var(--border);padding:10px 20px;border-radius:24px;font-size:13px;font-weight:600;color:#fff;
  z-index:500;opacity:0;transition:all .3s;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.4);max-width:90%;text-overflow:ellipsis;overflow:hidden}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

::-webkit-scrollbar{width:0;height:0}

@media(max-height:700px){
  .word-revealed{font-size:32px}
  .word-emoji{font-size:42px}
  .timer-wrap{width:170px;height:170px}
  .timer-svg{width:170px;height:170px}
}
@media(max-width:360px){
  .hero-title-find,.hero-title-imp{font-size:30px}
  .hero-figure-wrap{width:90px}
}
