/* ═══════════════════════════════════════
NEXUS PARTY — GLOBAL STYLES
═══════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
–bg:#04040e;–s1:#08081a;–s2:#0d0d20;
–panel:rgba(8,8,26,.92);–card:rgba(12,12,28,.88);
–border:rgba(80,180,255,.12);–border2:rgba(80,180,255,.22);
–cy:#00cfff;–mg:#ff2d78;–gold:#ffd700;–green:#00e676;–purple:#a855f7;
–dim:#4a5568;–text:#e2e8f0;–text2:#94a3b8;
–hover:rgba(0,207,255,.07);–r:12px;
–nexon:#f59e0b;
}
html,body{height:100%;overflow-x:hidden;scroll-behavior:smooth}
body{font-family:‘Space Grotesk’,system-ui,sans-serif;background:var(–bg);color:var(–text);overscroll-behavior:none;user-select:none}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-thumb{background:var(–cy);border-radius:2px}
::-webkit-scrollbar-track{background:transparent}
input,textarea,select{user-select:text}

/* ═══ CANVAS BG ═══ */
#bgCanvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.25}
.mesh{position:fixed;inset:0;z-index:0;pointer-events:none;
background:radial-gradient(ellipse 700px 500px at 15% 25%,rgba(0,207,255,.06),transparent),
radial-gradient(ellipse 600px 400px at 80% 75%,rgba(255,45,120,.05),transparent),
radial-gradient(ellipse 500px 400px at 50% 50%,rgba(168,85,247,.03),transparent);
animation:meshAnim 30s ease-in-out infinite alternate}
@keyframes meshAnim{0%{transform:scale(1)}100%{transform:scale(1.04) translate(10px,-10px)}}

/* ═══ LIVE ROULETTE TOP BAR ═══ */
.live-bar{position:relative;z-index:25;height:36px;background:rgba(0,0,0,.7);
border-bottom:1px solid var(–border);overflow:hidden;display:flex;align-items:center;gap:0}
.live-label{flex-shrink:0;padding:0 10px;font-size:9px;font-weight:800;color:var(–cy);
font-family:‘JetBrains Mono’,monospace;letter-spacing:1px;border-right:1px solid var(–border);
text-transform:uppercase;white-space:nowrap}
.roulette-track{display:flex;white-space:nowrap;animation:rouletteScroll 30s linear infinite;will-change:transform}
.roulette-track:hover{animation-play-state:paused}
@keyframes rouletteScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.rou-item{display:inline-flex;align-items:center;gap:5px;padding:0 14px;height:36px;
border-right:1px solid rgba(255,255,255,.04);font-size:11px;flex-shrink:0}
.rou-icon{width:22px;height:22px;background:var(–card);border:1px solid var(–border);
border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.rou-name{color:var(–cy);font-weight:700;font-size:10px;max-width:60px;overflow:hidden;text-overflow:ellipsis}
.rou-vs{color:var(–dim);font-size:9px;margin:0 2px}
.rou-opp{color:var(–text2);font-size:10px;max-width:50px;overflow:hidden;text-overflow:ellipsis}
.rou-win{color:var(–green);font-size:9px;font-weight:700}
.rou-nexon{color:var(–nexon);font-size:9px;font-weight:700}

/* ═══ HEADER ═══ */
.hd{position:sticky;top:0;z-index:30;margin:6px 10px;
display:flex;align-items:center;justify-content:space-between;padding:8px 14px;
background:rgba(4,4,20,.9);backdrop-filter:blur(20px);
border:1px solid var(–border);border-radius:14px}
.logo{display:flex;align-items:center;gap:8px;cursor:pointer;text-decoration:none}
.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(–cy),var(–mg));
border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;
box-shadow:0 0 18px rgba(0,207,255,.25);flex-shrink:0}
.logo-text{font-size:16px;font-weight:900;letter-spacing:1px;
background:linear-gradient(135deg,var(–cy),var(–mg));
-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hd-right{display:flex;align-items:center;gap:6px}
.onl-pill{display:flex;align-items:center;gap:4px;padding:4px 9px;
background:var(–card);border:1px solid var(–border);border-radius:16px;
font-size:9px;font-weight:700;font-family:‘JetBrains Mono’,monospace;color:var(–text2)}
.onl-dot{width:6px;height:6px;background:var(–green);border-radius:50%;
box-shadow:0 0 6px var(–green);animation:blink 2s ease infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.nexon-pill{display:flex;align-items:center;gap:4px;padding:4px 9px;
background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.25);
border-radius:16px;font-size:10px;font-weight:800;color:var(–nexon);cursor:pointer;transition:.2s}
.nexon-pill:hover{background:rgba(245,158,11,.2)}
.hd-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;
justify-content:center;font-size:13px;font-weight:800;border:2px solid var(–cy);
cursor:pointer;transition:.2s;flex-shrink:0}
.hd-av:hover{box-shadow:0 0 12px rgba(0,207,255,.4);transform:scale(1.05)}
.hd-btn{padding:5px 10px;background:var(–card);border:1px solid var(–border);
border-radius:8px;font-size:10px;font-weight:700;cursor:pointer;color:var(–text2);
transition:.2s;display:flex;align-items:center;justify-content:center}
.hd-btn:hover{border-color:var(–cy);color:var(–cy)}

/* ═══ MAIN WRAP ═══ */
.wrap{position:relative;z-index:1;max-width:500px;margin:0 auto;padding:0 10px 90px}

/* ═══ NAV TABS ═══ */
.ntabs{display:flex;gap:5px;padding:8px 0;overflow-x:auto}
.ntabs::-webkit-scrollbar{display:none}
.ntab{padding:7px 14px;background:var(–card);border:1px solid var(–border);
border-radius:9px;font-size:11px;font-weight:700;cursor:pointer;
transition:.2s;white-space:nowrap;color:var(–text2)}
.ntab:hover{border-color:var(–cy)}
.ntab.active{background:var(–hover);border-color:var(–cy);color:var(–cy)}

/* ═══ GAMES GRID ═══ */
.games-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.gc{padding:18px 12px 14px;background:var(–card);border:1px solid var(–border);
border-radius:14px;cursor:pointer;transition:.28s;text-align:center;
position:relative;overflow:hidden}
.gc::before{content:’’;position:absolute;inset:0;opacity:0;transition:.28s;
background:linear-gradient(135deg,rgba(0,207,255,.06),rgba(255,45,120,.04))}
.gc:hover{transform:translateY(-4px);border-color:rgba(0,207,255,.35);
box-shadow:0 12px 32px rgba(0,207,255,.1)}
.gc:hover::before{opacity:1}
.gc:active{transform:translateY(-1px)}
.gc-icon{font-size:34px;margin-bottom:7px;display:block;
filter:drop-shadow(0 0 8px rgba(0,207,255,.4));transition:.28s}
.gc:hover .gc-icon{transform:scale(1.12) rotate(-3deg)}
.gc-name{font-size:11px;font-weight:700;color:var(–text);line-height:1.3}
.gc-reward{position:absolute;top:7px;right:7px;font-size:8px;font-weight:800;
color:var(–nexon);font-family:‘JetBrains Mono’,monospace}
.gc-badge{position:absolute;top:7px;left:7px;padding:2px 6px;border-radius:5px;
font-size:8px;font-weight:800;font-family:‘JetBrains Mono’,monospace}
.badge-new{background:rgba(0,230,118,.15);color:var(–green);border:1px solid rgba(0,230,118,.25)}
.badge-hot{background:rgba(255,45,120,.15);color:var(–mg);border:1px solid rgba(255,45,120,.25)}

/* ═══ PANEL / CARD ═══ */
.pnl{background:var(–panel);border:1px solid var(–border);border-radius:14px;padding:16px}
.inp{width:100%;padding:11px 14px;background:rgba(255,255,255,.04);
border:1.5px solid var(–border);border-radius:10px;color:var(–text);
font-size:13px;font-family:inherit;outline:none;transition:.2s}
.inp:focus{border-color:var(–cy);background:rgba(0,207,255,.04);box-shadow:0 0 0 3px rgba(0,207,255,.06)}
.inp::placeholder{color:var(–dim)}
.inp.err{border-color:var(–mg)!important}
.btn{padding:11px 22px;background:linear-gradient(135deg,var(–cy),var(–mg));
color:#000;border:none;border-radius:10px;font-size:12px;font-weight:800;
cursor:pointer;transition:.25s;font-family:inherit;letter-spacing:.2px;
display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,207,255,.28)}
.btn:active{transform:translateY(0);box-shadow:none}
.btn-g{background:transparent;color:var(–cy);border:1.5px solid var(–cy)}
.btn-g:hover{background:var(–hover)}
.btn-r{background:transparent;color:var(–mg);border:1.5px solid var(–mg)}
.btn-r:hover{background:rgba(255,45,120,.08)}
.btn-gold{background:linear-gradient(135deg,#f59e0b,#d97706);color:#000}
.btn-sm{padding:7px 13px;font-size:11px;border-radius:8px}
.btn:disabled{opacity:.4;pointer-events:none}

/* ═══ MODAL ═══ */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:flex-end;
justify-content:center;background:rgba(0,0,0,.65);backdrop-filter:blur(6px)}
.modal.show{display:flex}
.mbox{width:100%;max-width:500px;max-height:90vh;overflow-y:auto;
background:var(–s1);border-radius:22px 22px 0 0;
border:1px solid var(–border);border-bottom:none;
padding:20px 16px 32px;position:relative;
animation:slideUp .3s cubic-bezier(.25,.8,.25,1)}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.mclose{position:sticky;top:0;z-index:10;display:flex;justify-content:flex-end;margin-bottom:12px}
.mclose-btn{width:30px;height:30px;background:var(–card);border:1px solid var(–border);
border-radius:8px;display:flex;align-items:center;justify-content:center;
cursor:pointer;font-size:13px;color:var(–text2);transition:.2s}
.mclose-btn:hover{border-color:var(–mg);color:var(–mg)}
.mh{font-size:17px;font-weight:800;margin-bottom:14px}

/* ═══ AUTH ═══ */
.auth-wrap{max-width:360px;margin:40px auto;text-align:center;padding:0 16px}
.auth-logo{font-size:68px;animation:float 4s ease-in-out infinite;display:block;margin-bottom:12px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.auth-title{font-size:38px;font-weight:900;letter-spacing:2px;margin-bottom:6px;
background:linear-gradient(135deg,var(–cy),var(–mg));
-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-sub{font-size:12px;color:var(–text2);margin-bottom:28px;line-height:1.6}
.auth-input-wrap{position:relative;margin-bottom:10px}
.auth-input-wrap .inp{padding-left:40px;font-size:14px;text-align:left}
.auth-inp-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:16px}
.auth-tg-btn{width:100%;padding:13px;background:linear-gradient(135deg,#229ED9,#1a7bbf);
color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:800;
cursor:pointer;transition:.25s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px}
.auth-tg-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(34,158,217,.35)}
.auth-divider{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(–dim);font-size:11px}
.auth-divider::before,.auth-divider::after{content:’’;flex:1;height:1px;background:var(–border)}

/* ═══ CHAT ═══ */
.chat-box{height:300px;overflow-y:auto;padding:10px;
background:var(–card);border:1px solid var(–border);border-radius:10px;
display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.chat-msg{display:flex;gap:7px;animation:msgIn .2s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.chat-msg.me{flex-direction:row-reverse}
.chat-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;
justify-content:center;font-size:10px;font-weight:800;flex-shrink:0;border:1.5px solid rgba(255,255,255,.1)}
.chat-body{max-width:72%;display:flex;flex-direction:column;gap:2px}
.chat-msg.me .chat-body{align-items:flex-end}
.chat-name{font-size:9px;font-weight:700;color:var(–dim)}
.chat-text{font-size:12px;line-height:1.45;padding:7px 10px;
background:var(–s2);border:1px solid var(–border);
border-radius:9px;word-break:break-word;color:var(–text);max-width:100%}
.chat-msg.me .chat-text{background:var(–hover);border-color:rgba(0,207,255,.18)}
.chat-time{font-size:8px;color:var(–dim);font-family:‘JetBrains Mono’,monospace}
.chat-inp-row{display:flex;gap:6px;align-items:center}
.emoji-toggle{width:38px;height:38px;background:var(–card);border:1px solid var(–border);
border-radius:8px;display:flex;align-items:center;justify-content:center;
cursor:pointer;font-size:17px;flex-shrink:0;transition:.2s}
.emoji-toggle:hover{border-color:var(–cy)}
.emoji-tray{display:none;flex-wrap:wrap;gap:3px;padding:8px;
background:var(–card);border:1px solid var(–border);border-radius:10px;margin-bottom:8px}
.emoji-tray.open{display:flex}
.ep{font-size:21px;cursor:pointer;padding:3px;border-radius:5px;transition:.1s;line-height:1}
.ep:hover{background:var(–hover);transform:scale(1.2)}

/* ═══ STATS ═══ */
.stat-row{display:flex;gap:8px;margin:12px 0}
.stat-b{flex:1;padding:11px 8px;background:var(–card);border:1px solid var(–border);
border-radius:11px;text-align:center}
.stat-v{font-size:22px;font-weight:800;font-family:‘JetBrains Mono’,monospace;
background:linear-gradient(135deg,var(–cy),var(–mg));
-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1}
.stat-l{font-size:8px;color:var(–dim);text-transform:uppercase;font-weight:700;margin-top:3px}

/* ═══ PROFILE ═══ */
.prof-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);
backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:16px}
.prof-overlay.show{display:flex}
.prof-box{background:var(–s1);border:1px solid var(–border);border-radius:18px;
padding:22px;width:100%;max-width:380px;position:relative}
.prof-av-big{width:72px;height:72px;border-radius:50%;margin:0 auto 10px;
display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;
border:3px solid var(–cy);box-shadow:0 0 20px rgba(0,207,255,.2)}
.inventory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:10px 0}
.inv-item{aspect-ratio:1;background:var(–card);border:1.5px solid var(–border);
border-radius:9px;display:flex;align-items:center;justify-content:center;
font-size:22px;cursor:pointer;transition:.2s;position:relative}
.inv-item:hover{border-color:var(–cy);transform:scale(1.05)}
.inv-item.owned{border-color:rgba(0,207,255,.3)}
.inv-item.equipped{border-color:var(–cy);box-shadow:0 0 10px rgba(0,207,255,.3)}
.inv-price{position:absolute;bottom:2px;right:2px;font-size:7px;color:var(–nexon);font-weight:800}

/* ═══ PRIZE WHEEL ═══ */
.wheel-wrap{position:relative;width:280px;height:280px;margin:0 auto}
.wheel-canvas{border-radius:50%;box-shadow:0 0 40px rgba(0,207,255,.2)}
.wheel-arrow{position:absolute;top:-16px;left:50%;transform:translateX(-50%);
font-size:28px;filter:drop-shadow(0 2px 6px rgba(0,207,255,.5));animation:arrowBob .5s ease-in-out infinite alternate}
@keyframes arrowBob{0%{transform:translateX(-50%) translateY(0)}100%{transform:translateX(-50%) translateY(4px)}}
.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
width:50px;height:50px;background:var(–s1);border-radius:50%;
border:3px solid var(–cy);display:flex;align-items:center;justify-content:center;font-size:20px;
box-shadow:0 0 16px rgba(0,207,255,.3)}

/* ═══ CONFETTI ═══ */
.confetti-piece{position:fixed;width:10px;height:10px;border-radius:2px;
animation:confettiFall 2s ease forwards;pointer-events:none;z-index:9999}
@keyframes confettiFall{
0%{transform:translateY(-20px) rotate(0deg);opacity:1}
100%{transform:translateY(100vh) rotate(720deg);opacity:0}
}

/* ═══ COIN ANIM ═══ */
.coin-fly{position:fixed;font-size:20px;font-weight:800;color:var(–nexon);
pointer-events:none;z-index:9998;animation:coinFly 1.2s ease forwards}
@keyframes coinFly{
0%{transform:translateY(0) scale(1);opacity:1}
50%{transform:translateY(-60px) scale(1.4);opacity:1}
100%{transform:translateY(-100px) scale(.5);opacity:0}
}

/* ═══ ROOMS ═══ */
.room-card{padding:12px;background:var(–card);border:1px solid var(–border);
border-radius:11px;cursor:pointer;transition:.22s;margin-bottom:8px}
.room-card:hover{border-color:rgba(0,207,255,.35);transform:translateY(-2px)}
.room-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.room-name{font-size:13px;font-weight:700}
.room-sub{font-size:10px;color:var(–text2);margin-bottom:3px}
.room-meta{font-size:9px;color:var(–dim);font-family:‘JetBrains Mono’,monospace;display:flex;gap:8px}
.bdg{padding:2px 7px;border-radius:5px;font-size:8px;font-weight:800;text-transform:uppercase}
.bdg-open{background:rgba(0,230,118,.12);color:var(–green);border:1px solid rgba(0,230,118,.22)}
.bdg-full{background:rgba(255,45,120,.12);color:var(–mg);border:1px solid rgba(255,45,120,.22)}
.bdg-cy{background:rgba(0,207,255,.1);color:var(–cy);border:1px solid rgba(0,207,255,.2)}

/* ═══ GAMES ═══ */
/* TTT */
.ttt-b{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;max-width:252px;margin:14px auto}
.ttt-c{aspect-ratio:1;background:var(–card);border:2px solid var(–border);
border-radius:11px;display:flex;align-items:center;justify-content:center;
font-size:30px;font-weight:900;cursor:pointer;transition:.22s;user-select:none}
.ttt-c:hover:not(.filled){border-color:var(–cy);background:var(–hover);transform:scale(1.04)}
.ttt-c.x{color:var(–mg);animation:pop .28s cubic-bezier(.34,1.56,.64,1)}
.ttt-c.o{color:var(–cy);animation:pop .28s cubic-bezier(.34,1.56,.64,1)}
.ttt-c.win{box-shadow:0 0 22px var(–cy);border-color:var(–cy);animation:winGlow 1s ease infinite}
@keyframes pop{from{transform:scale(0) rotate(-180deg)}to{transform:scale(1) rotate(0)}}
@keyframes winGlow{0%,100%{box-shadow:0 0 22px var(–cy)}50%{box-shadow:0 0 44px var(–cy)}}

/* Math */
.math-q{font-size:38px;font-weight:900;text-align:center;margin:12px 0;
color:var(–cy);font-family:‘JetBrains Mono’,monospace;letter-spacing:1px;
text-shadow:0 0 20px rgba(0,207,255,.3)}
.math-opts{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:14px 0}
.math-opt{padding:14px;background:var(–card);border:2px solid var(–border);
border-radius:11px;text-align:center;font-size:20px;font-weight:800;cursor:pointer;
transition:.2s;font-family:‘JetBrains Mono’,monospace;color:var(–text)}
.math-opt:hover{border-color:var(–cy);background:var(–hover)}
.math-opt.cor{border-color:var(–green)!important;background:rgba(0,230,118,.1)!important;color:var(–green)!important}
.math-opt.wrg{border-color:var(–mg)!important;background:rgba(255,45,120,.1)!important;color:var(–mg)!important}
.math-opt:disabled,.math-opt.cor,.math-opt.wrg{pointer-events:none}

/* Timer bar */
.timer-bar{height:6px;background:rgba(255,255,255,.07);border-radius:3px;overflow:hidden;margin-bottom:14px}
.timer-fill{height:100%;border-radius:3px;transition:width .1s linear;
background:linear-gradient(90deg,var(–green),var(–cy))}
.timer-fill.warn{background:linear-gradient(90deg,var(–mg),#ff6b00)!important}

/* Cities */
.city-chain{display:flex;flex-wrap:wrap;gap:5px;margin:10px 0;max-height:100px;overflow-y:auto}
.city-tag{padding:3px 9px;background:var(–hover);border:1px solid rgba(0,207,255,.25);
border-radius:7px;font-size:10px;color:var(–text)}
.city-tag.last{border-color:var(–cy);color:var(–cy);font-weight:700}

/* Memory */
.mem-grid{display:grid;gap:7px;margin:10px auto}
.mem-c{aspect-ratio:1;background:var(–card);border:2px solid var(–border);
border-radius:9px;display:flex;align-items:center;justify-content:center;
font-size:26px;cursor:pointer;transition:.25s;user-select:none}
.mem-c:hover{border-color:rgba(0,207,255,.3)}
.mem-c.flip{animation:flipCard .35s ease}
.mem-c.matched{border-color:var(–green);background:rgba(0,230,118,.07)}
@keyframes flipCard{0%,100%{transform:rotateY(0)}50%{transform:rotateY(90deg)}}

/* Word Guess */
.wg-display{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:14px 0}
.wg-l{width:34px;height:42px;background:var(–card);border:2px solid var(–border);
border-radius:7px;display:flex;align-items:center;justify-content:center;
font-size:18px;font-weight:800;font-family:‘JetBrains Mono’,monospace;transition:.2s}
.wg-l.rev{border-color:var(–cy);color:var(–cy);animation:pop .25s ease}
.alpha{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin:10px 0}
.akey{width:30px;height:30px;background:var(–card);border:1px solid var(–border);
border-radius:7px;display:flex;align-items:center;justify-content:center;
font-size:11px;font-weight:700;cursor:pointer;transition:.18s;font-family:‘JetBrains Mono’,monospace}
.akey:hover:not(.used){border-color:var(–cy);background:var(–hover)}
.akey.used{opacity:.25;pointer-events:none}
.akey.hit{border-color:var(–green);color:var(–green)}
.akey.miss{border-color:var(–mg);color:var(–mg)}

/* Reaction */
.react-zone{width:190px;height:190px;border-radius:50%;margin:20px auto;
display:flex;align-items:center;justify-content:center;font-size:52px;
cursor:pointer;transition:.3s;user-select:none;border:4px solid var(–border)}
.react-zone.wait{background:rgba(255,45,120,.08);border-color:var(–mg)}
.react-zone.ready{background:rgba(0,230,118,.12);border-color:var(–green);
animation:readyPulse .6s ease-in-out infinite}
@keyframes readyPulse{0%,100%{box-shadow:0 0 0 rgba(0,230,118,0)}50%{box-shadow:0 0 40px rgba(0,230,118,.35)}}

/* Roulette Wheel */
.rps-btns{display:flex;gap:10px;justify-content:center;margin:14px 0}
.rps-b{width:68px;height:68px;border-radius:14px;background:var(–card);
border:2px solid var(–border);display:flex;align-items:center;justify-content:center;
font-size:30px;cursor:pointer;transition:.22s}
.rps-b:hover{border-color:var(–cy);transform:scale(1.07);background:var(–hover)}

/* Numguess */
.ng-bar{height:7px;background:var(–card);border-radius:4px;overflow:hidden;margin:10px 0}
.ng-fill{height:100%;background:linear-gradient(90deg,var(–cy),var(–mg));border-radius:4px;transition:width .5s}

/* Quiz */
.q-opts{display:flex;flex-direction:column;gap:7px;margin:12px 0}
.q-opt{padding:11px 14px;background:var(–card);border:2px solid var(–border);
border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;
transition:.22s;text-align:left;color:var(–text)}
.q-opt:hover{border-color:var(–cy);background:var(–hover)}
.q-opt.cor{border-color:var(–green)!important;background:rgba(0,230,118,.08)!important;color:var(–green)!important;pointer-events:none}
.q-opt.wrg{border-color:var(–mg)!important;background:rgba(255,45,120,.08)!important;color:var(–mg)!important;pointer-events:none}
.q-opt.disabled{pointer-events:none;opacity:.7}

/* Bingo */
.bingo-g{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;max-width:290px;margin:0 auto}
.bingo-c{aspect-ratio:1;background:var(–card);border:1px solid var(–border);
border-radius:7px;display:flex;align-items:center;justify-content:center;
font-size:12px;font-weight:700;cursor:pointer;transition:.22s;
font-family:‘JetBrains Mono’,monospace}
.bingo-c:hover{border-color:var(–cy)}
.bingo-c.marked{background:var(–hover);border-color:var(–cy);color:var(–cy)}
.bingo-c.free{background:rgba(255,215,0,.08);border-color:var(–gold);color:var(–gold)}

/* Mafia */
.pl-slot{display:flex;align-items:center;gap:8px;padding:8px 10px;
background:var(–card);border:1px solid var(–border);border-radius:9px;margin-bottom:6px}
.pl-slot.dead{opacity:.35;text-decoration:line-through}
.pl-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;
justify-content:center;font-size:12px;font-weight:800;border:1.5px solid rgba(255,255,255,.1);flex-shrink:0}
.role-b{margin-left:auto;padding:2px 7px;border-radius:5px;font-size:8px;font-weight:800;text-transform:uppercase}
.role-mafia{background:rgba(255,45,120,.18);color:var(–mg);border:1px solid rgba(255,45,120,.28)}
.role-civ{background:var(–hover);color:var(–cy);border:1px solid rgba(0,207,255,.25)}
.role-doc{background:rgba(0,230,118,.12);color:var(–green);border:1px solid rgba(0,230,118,.22)}
.role-sher{background:rgba(255,215,0,.12);color:var(–gold);border:1px solid rgba(255,215,0,.22)}

/* Anagram */
.ana-letters{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:14px 0}
.ana-l{width:42px;height:42px;background:var(–card);border:2px solid var(–cy);
border-radius:9px;display:flex;align-items:center;justify-content:center;
font-size:20px;font-weight:700;cursor:pointer;transition:.18s;font-family:‘JetBrains Mono’,monospace}
.ana-l:hover{background:var(–hover);transform:scale(1.07)}
.ana-l.used{opacity:.25;pointer-events:none;border-color:var(–border)}
.ana-inp{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;
min-height:50px;padding:6px;background:var(–card);border:1.5px dashed var(–border);
border-radius:10px;margin:10px 0}
.ana-il{width:38px;height:38px;background:var(–hover);border:2px solid var(–cy);
border-radius:7px;display:flex;align-items:center;justify-content:center;
font-size:18px;font-weight:700;cursor:pointer;font-family:‘JetBrains Mono’,monospace}
.ana-il:hover{border-color:var(–mg)}

/* Typing */
.typing-t{font-size:14px;line-height:1.85;padding:14px;background:var(–card);
border:1px solid var(–border);border-radius:11px;margin-bottom:10px;
font-family:‘JetBrains Mono’,monospace;letter-spacing:.3px}
.t-typed{color:var(–green)}
.t-cur{background:rgba(0,207,255,.3);border-radius:2px}
.t-rem{color:var(–text2)}

/* Screamer */
.scream-fab{position:fixed;bottom:90px;right:14px;width:52px;height:52px;
border-radius:50%;background:linear-gradient(135deg,#ff3300,#cc0000);border:none;
cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;
font-size:24px;box-shadow:0 4px 20px rgba(255,50,0,.45);
animation:screamPulse 2.5s ease infinite;transition:.15s}
.scream-fab:active{transform:scale(.9)}
@keyframes screamPulse{0%,100%{box-shadow:0 4px 20px rgba(255,50,0,.45)}50%{box-shadow:0 4px 44px rgba(255,50,0,.75)}}
.scream-overlay{position:fixed;inset:0;z-index:9999;display:none;
flex-direction:column;align-items:center;justify-content:center;
cursor:pointer;background:#ff0000}
.scream-overlay.show{display:flex;animation:screamFlash .12s ease infinite}
@keyframes screamFlash{0%,100%{background:#ff0000}50%{background:#ff4400}}
.scream-emoji{font-size:150px;animation:screamShake .1s ease infinite}
@keyframes screamShake{0%,100%{transform:rotate(-6deg) scale(1.2)}50%{transform:rotate(6deg) scale(1.3)}}

/* Dice */
.dice-face{width:78px;height:78px;background:var(–card);border:2px solid var(–border);
border-radius:14px;display:flex;align-items:center;justify-content:center;
font-size:38px;cursor:pointer;transition:.25s}
.dice-face:hover{border-color:var(–cy);transform:scale(1.04)}
.dice-face.rolling{animation:diceRoll .4s ease infinite}
@keyframes diceRoll{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(.85)}100%{transform:rotate(360deg) scale(1)}}

/* Top list */
.top-item{display:flex;align-items:center;gap:10px;padding:9px 12px;
background:var(–card);border:1px solid var(–border);border-radius:10px;margin-bottom:7px;transition:.2s}
.top-item:hover{border-color:rgba(0,207,255,.28)}
.top-rank{width:26px;font-size:15px;text-align:center;font-weight:800;flex-shrink:0}
.top-info{flex:1;min-width:0}
.top-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-sub{font-size:9px;color:var(–dim);font-family:‘JetBrains Mono’,monospace;margin-top:1px}
.top-score{font-size:16px;font-weight:800;color:var(–cy);font-family:‘JetBrains Mono’,monospace;flex-shrink:0}

/* Toast */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(16px);
background:var(–s2);border:1px solid var(–border);border-radius:10px;
padding:9px 18px;font-size:12px;font-weight:700;z-index:600;
opacity:0;transition:.25s;white-space:nowrap;pointer-events:none;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Misc */
.empty{text-align:center;color:var(–dim);padding:28px;font-size:12px}
.lbl{font-size:10px;color:var(–dim);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.divider{height:1px;background:var(–border);margin:14px 0}
.suc{color:var(–green);background:rgba(0,230,118,.07);border:1px solid rgba(0,230,118,.18);border-radius:9px;padding:9px 12px;font-size:12px;font-weight:700;text-align:center;margin:7px 0}
.err{color:var(–mg);background:rgba(255,45,120,.07);border:1px solid rgba(255,45,120,.18);border-radius:9px;padding:9px 12px;font-size:12px;font-weight:700;text-align:center;margin:7px 0}
.flex{display:flex;gap:7px;align-items:center}
.mb8{margin-bottom:8px}
.mb12{margin-bottom:12px}
.mb16{margin-bottom:16px}
.spin{display:inline-block;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.player-list{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin:12px 0}
.pl-chip{display:flex;align-items:center;gap:5px;padding:5px 10px;
background:var(–card);border:1px solid var(–border);border-radius:8px;font-size:11px;font-weight:700}
</style>