:root{--gold:#d4a332;--gold-bright:#f0c040;--gold-dim:#c49a2a;--casino-red:#cc2936;--casino-red-bright:#e63946;--black:#1a1a1a;--black-light:#2a2a2a;--felt:#237a4b;--felt-light:#2e9e60;--felt-dark:#1a5c38;--bg-deep:#1b7340;--bg-surface:#1e7f47;--bg-card:#19683b;--bg-elevated:#1a5c38;--text:#fff;--text-bright:#fff;--text-muted:#c8e6d3;--border:#ffffff26;--font-heading:"Playfair Display", Georgia, serif;--font-ui:"Space Grotesk", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, Consolas, monospace;font-family:var(--font-ui);color:var(--text);background:var(--bg-deep);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-height:100dvh;margin:0;position:relative;overflow-x:hidden}body:before{content:"";z-index:-1;background:radial-gradient(100% 80% at 50% 30%,#ffffff0a,#0000 60%);position:fixed;inset:0}body:after{content:"";z-index:-1;pointer-events:none;background:radial-gradient(80% 80%,#0000 30%,#00000040 100%);position:fixed;inset:0}#root{flex-direction:column;max-width:1200px;min-height:100dvh;margin:0 auto;display:flex}h1,h2,h3{font-family:var(--font-heading);color:var(--text-bright);margin:0}p{margin:0}button{font-family:var(--font-ui);cursor:pointer;color:inherit;background:0 0;border:none}button:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.back-button{font-family:var(--font-ui);color:#fff;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:color .2s,background .2s,border-color .2s;display:inline-flex}.back-button:hover{color:var(--gold-bright);background:#0003;border-color:#d4a3324d}.back-button-arrow{font-size:1.1em;transition:transform .2s}.back-button:hover .back-button-arrow{transform:translate(-3px)}.dice-area{background:radial-gradient(ellipse 100% 80% at 50% 30%, #ffffff0a, transparent 60%), linear-gradient(180deg, var(--felt-dark), var(--felt));border:3px solid #0000004d;border-radius:20px;flex-direction:column;align-items:center;gap:24px;padding:32px;display:flex;box-shadow:inset 0 2px 8px #0003,0 8px 32px #0000004d}.dice-tray-wrapper{flex-direction:column;align-items:center;width:clamp(340px,80vw,640px);display:flex}.dice-tray{aspect-ratio:5/3;background:radial-gradient(120% 80% at 40% 40%,#ffffff08,#0000 50%),linear-gradient(#1a3a1a,#0f2a0f);border:6px solid #3d2b1a;border-radius:16px;width:100%;position:relative;overflow:hidden;box-shadow:inset 0 4px 16px #00000080,inset 0 1px 4px #0000004d,0 2px 8px #0006}.dice-tray:before{content:"";pointer-events:none;z-index:0;border:1px solid #ffffff0a;position:absolute;inset:0}.dice-tray--rolling{animation:.2s ease-out tray-shake}@keyframes tray-shake{0%{transform:translate(0)}20%{transform:translate(-1.5px,1px)}40%{transform:translate(2px,-1px)}60%{transform:translate(-1px,1.5px)}80%{transform:translate(1px,-.5px)}to{transform:translate(0)}}.dice-box-canvas{z-index:1;width:100%;height:100%;position:absolute;inset:0}.held-zone{pointer-events:none;z-index:2;z-index:0;background:repeating-linear-gradient(175deg,#5032141f 0,#0000 2px 8px,#50321414 10px),linear-gradient(#2a1a0e,#3d2b1a 40%,#4a3520);border-left:3px solid #2a1a0e;justify-content:center;align-items:flex-start;width:24%;padding-top:10px;display:flex;position:absolute;top:0;bottom:0;right:0;box-shadow:inset 3px 0 10px #0006,inset 1px 0 3px #0003}.held-zone__label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:2px;color:#daa52099;text-shadow:0 1px 3px #000000b3;font-size:.55rem;font-weight:700}.dice-hint{font-family:var(--font-ui);color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;text-align:center;margin:6px 0 0;font-size:.7rem}.roll-button{font-family:var(--font-ui);background:linear-gradient(135deg, var(--casino-red), #a82232);color:#fff;letter-spacing:.8px;text-transform:uppercase;border-radius:12px;padding:14px 40px;font-size:1rem;font-weight:700;transition:opacity .2s,transform .15s,box-shadow .25s;box-shadow:0 4px 16px #cc293666,inset 0 1px #fff3}.roll-button:hover:not(:disabled){transform:scale(1.03);box-shadow:0 6px 24px #e6394680,inset 0 1px #fff3}.roll-button:active:not(:disabled){transform:scale(.98)}.roll-button:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.rolls-remaining{font-family:var(--font-mono);color:#fff;opacity:.8;letter-spacing:.5px;font-size:.75rem}@media (width<=480px){.dice-area{gap:14px;padding:20px 12px}.dice-tray-wrapper{width:clamp(300px,96vw,440px)}.dice-tray{border-width:4px}.roll-button{padding:12px 28px;font-size:.9rem}}.score-sheet{border-collapse:collapse;width:100%;max-width:360px;font-family:var(--font-ui);background:linear-gradient(180deg, var(--black-light), var(--black));border:1px solid #ffffff1f;border-radius:16px;font-size:.875rem;overflow:hidden;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff0d}.score-sheet th{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:#ffffff73;text-align:left;background:#ffffff0a;border-bottom:1px solid #ffffff1a;padding:10px 16px;font-size:.6rem}.score-sheet th:last-child{text-align:right}.score-row{transition:background .15s}.score-row td{border-bottom:1px solid #ffffff0f;padding:9px 16px}.score-row td:last-child{text-align:right;font-family:var(--font-mono);font-size:.9rem}.score-row--scored td{color:#ffffff8c}.score-row--scored td:last-child{color:#fff;font-weight:700}.score-check{color:var(--felt-light);margin-right:6px;font-size:.75rem}.score-row--available{cursor:pointer;border-left:3px solid var(--gold)}.score-row--available td{color:var(--gold-bright)}.score-row--available td:first-child{padding-left:13px}.score-row--available td:last-child{opacity:.55;font-style:italic;font-weight:400}.score-row--available:hover{background:#d4a3321f}.score-row--available:hover td:last-child{opacity:1;text-shadow:0 0 8px #f0c04080;font-style:normal;font-weight:700}.score-row--zero td:last-child{color:var(--casino-red);opacity:.45}.score-row--zero:hover td:last-child{color:var(--casino-red-bright);opacity:.8;text-shadow:none}.score-row--locked td{color:#ffffff2e}.score-row--locked td:last-child{font-weight:400}.score-section-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:2px;color:#ffffff59;padding:14px 16px 5px;font-size:.6rem}.score-bonus-row td{border-bottom:1px solid #ffffff0f;padding:6px 16px;font-size:.8rem}.score-bonus-row--active td{color:var(--felt-light);font-weight:600}.score-bonus-row--inactive td{color:#ffffff40}.score-bonus-row td:last-child{text-align:right;font-family:var(--font-mono)}.score-total-row td{color:#fff9;background:#ffffff08;border-top:2px solid #ffffff26;padding:14px 16px;font-weight:700}.score-total-row td:last-child{text-align:right;font-family:var(--font-mono);color:#fff;letter-spacing:.5px;font-size:1.15rem}.game-over-overlay{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000d9;justify-content:center;align-items:center;animation:.3s overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}}.game-over-card{background:radial-gradient(ellipse 80% 60% at 50% 0%, #f0c0401a, transparent 50%), linear-gradient(180deg, var(--black-light), var(--black));border:2px solid var(--gold);text-align:center;border-radius:24px;width:90%;max-width:420px;padding:56px 44px;animation:.5s .1s backwards card-pop;box-shadow:0 24px 80px #0009,0 0 40px #d4a3321a,inset 0 1px #ffffff14}@keyframes card-pop{0%{opacity:0;filter:blur(6px);transform:scale(.85)translateY(20px)}}.game-over-title{color:#fff;text-shadow:0 0 30px #f0c04066,0 2px #00000080;margin-bottom:8px;font-size:3rem;font-weight:900}.game-over-subtitle{color:var(--gold);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;margin-bottom:36px;font-size:.8rem}.game-over-score{font-family:var(--font-mono);color:var(--gold-bright);text-shadow:0 0 30px #f0c04099,0 0 60px #f0c04033;margin-bottom:8px;font-size:5rem;font-weight:700;animation:.7s .35s backwards score-reveal}@keyframes score-reveal{0%{opacity:0;filter:blur(10px);transform:scale(.4)}}.game-over-label{font-family:var(--font-mono);color:#ccc;text-transform:uppercase;letter-spacing:3px;margin-bottom:44px;font-size:.7rem}.game-over-actions{justify-content:center;gap:12px;display:flex}.game-over-btn{font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;border-radius:12px;padding:14px 32px;font-size:.9rem;font-weight:700;transition:opacity .2s,transform .15s,box-shadow .25s}.game-over-btn:hover{transform:scale(1.04)}.game-over-btn--primary{background:linear-gradient(135deg, var(--casino-red), #a82232);color:#fff;box-shadow:0 4px 20px #cc293666,inset 0 1px #fff3}.game-over-btn--primary:hover{box-shadow:0 6px 30px #e6394680,inset 0 1px #fff3}.game-over-btn--secondary{color:#fff;border:1px solid var(--gold);background:0 0}.game-over-btn--secondary:hover{color:var(--gold-bright);background:#d4a33214}.yams-game{flex-direction:column;flex:1;padding:16px 24px 32px;display:flex;position:relative}.yams-game:before{content:"";pointer-events:none;background:radial-gradient(#ffffff0d,#0000 70%);width:700px;height:350px;position:fixed;top:-60px;left:50%;transform:translate(-50%)}.yams-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex;position:relative}.yams-title{letter-spacing:-.5px;color:#fff;text-shadow:0 2px 4px #0006;font-size:1.75rem;font-weight:900}.yams-round{font-family:var(--font-mono);color:var(--gold-bright);letter-spacing:.5px;background:#00000040;border:1px solid #d4a3324d;border-radius:6px;padding:4px 12px;font-size:.8rem}.yams-body{flex-direction:column;flex:1;align-items:center;gap:36px;display:flex}@media (width>=768px){.yams-body{flex-direction:row;justify-content:center;align-items:flex-start;gap:56px}}.yams-dice-section{flex-direction:column;align-items:center;display:flex}.yams-score-section{justify-content:center;width:100%;max-width:360px;display:flex}.yams-spectating{text-align:center;color:var(--text-muted);background:#00000026;border-radius:6px;margin-bottom:.5rem;padding:.5rem 1rem;font-size:.9rem;font-style:italic}@media (width<=480px){.yams-game{padding:12px 12px 24px}.yams-header{margin-bottom:16px}}.player-bar{scrollbar-width:thin;gap:.5rem;padding:.5rem;display:flex;overflow-x:auto}.player-bar__item{background:var(--bg-card);border:2px solid var(--border);border-radius:8px;flex-direction:column;align-items:center;gap:.15rem;min-width:100px;padding:.5rem 1rem;transition:border-color .2s,box-shadow .2s;display:flex}.player-bar__item--active{border-color:var(--gold);box-shadow:0 0 12px #d4a3324d}.player-bar__item--you{background:var(--bg-elevated)}.player-bar__item--disconnected{opacity:.5}.player-bar__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:.85rem;font-weight:600;overflow:hidden}.player-bar__score{font-family:var(--font-mono);color:var(--gold-bright);font-size:1.1rem;font-weight:700}.player-bar__status{color:var(--casino-red-bright);font-size:.7rem;font-style:italic}.mp-game-over-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.mp-game-over-card{background:var(--bg-card);border:2px solid var(--gold-dim);text-align:center;border-radius:16px;width:90%;max-width:400px;padding:2rem}.mp-game-over-title{font-family:var(--font-heading);color:var(--gold-bright);margin-bottom:1.5rem;font-size:2rem}.mp-game-over-leaderboard{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.mp-game-over-row{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.mp-game-over-row--winner{border-color:var(--gold);background:#d4a3321a}.mp-game-over-rank{font-family:var(--font-mono);color:var(--gold-bright);min-width:1.5rem;font-size:1.1rem;font-weight:700}.mp-game-over-row--winner .mp-game-over-rank{color:var(--gold-bright)}.mp-game-over-name{text-align:left;flex:1;font-weight:500}.mp-game-over-score{font-family:var(--font-mono);color:var(--gold-bright);font-size:1.2rem;font-weight:700}.mp-game-over-actions{justify-content:center;gap:.75rem;display:flex}.mp-game-over-btn{text-transform:uppercase;letter-spacing:.05em;background:var(--gold);color:var(--black);border-radius:8px;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:background .15s}.mp-game-over-btn:hover{background:var(--gold-bright)}.lobby{flex-direction:column;align-items:center;gap:2rem;max-width:480px;margin:0 auto;padding:2rem;display:flex}.lobby-code-section{text-align:center;flex-direction:column;align-items:center;gap:.75rem;display:flex}.lobby-code-label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);font-size:.85rem}.lobby-code{gap:.5rem;display:flex}.lobby-code__char{font-family:var(--font-mono);color:var(--gold-bright);background:var(--bg-card);border:2px solid var(--gold-dim);text-shadow:0 0 12px #d4a33266;border-radius:8px;justify-content:center;align-items:center;width:3.5rem;height:4rem;font-size:2.5rem;font-weight:700;display:flex}.lobby-copy-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:.4rem 1rem;font-size:.85rem;transition:background .15s,color .15s}.lobby-copy-btn:hover{background:var(--bg-card);color:var(--text)}.lobby-players{width:100%}.lobby-players-title{font-family:var(--font-ui);color:var(--text-muted);margin-bottom:.75rem;font-size:1rem;font-weight:600}.lobby-player-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.lobby-player{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:border-color .15s;display:flex}.lobby-player--host{border-color:var(--gold-dim)}.lobby-player--disconnected{opacity:.5}.lobby-player__name{flex:1;font-weight:500}.lobby-player__badge{background:var(--gold-dim);color:var(--black);text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.lobby-player__badge--you{background:var(--felt-light);color:var(--text)}.lobby-actions{flex-direction:column;align-items:center;gap:.75rem;width:100%;display:flex}.lobby-btn{text-transform:uppercase;letter-spacing:.05em;border-radius:8px;width:100%;padding:.85rem;font-size:1rem;font-weight:600;transition:background .15s,opacity .15s}.lobby-btn--start{background:var(--gold);color:var(--black)}.lobby-btn--start:hover:not(:disabled){background:var(--gold-bright)}.lobby-btn--start:disabled{opacity:.5;cursor:not-allowed}.lobby-btn--leave{border:1px solid var(--border);color:var(--text-muted);background:0 0}.lobby-btn--leave:hover{border-color:var(--casino-red);color:var(--casino-red-bright)}.lobby-waiting{color:var(--text-muted);font-size:.95rem;font-style:italic}.disconnect-overlay{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.disconnect-card{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2rem;display:flex}.disconnect-spinner{border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;width:40px;height:40px;animation:1s linear infinite disconnect-spin}@keyframes disconnect-spin{to{transform:rotate(360deg)}}.disconnect-title{font-family:var(--font-heading);color:var(--gold-bright);font-size:1.5rem}.disconnect-text{color:var(--text-muted);font-size:.95rem}.disconnect-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.6rem 1.5rem;font-weight:500;transition:border-color .15s}.disconnect-btn:hover:not(:disabled){border-color:var(--gold)}.disconnect-btn:disabled{opacity:.5;cursor:not-allowed}.mode-picker{flex-direction:column;align-items:center;min-height:100dvh;padding:2rem 1rem;display:flex}.mode-picker__title{font-family:var(--font-heading);color:var(--gold-bright);text-shadow:0 0 24px #d4a3324d;margin:1rem 0 .5rem;font-size:2.5rem}.mode-picker__subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:1rem}.mode-picker__buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.mode-picker__btn{background:var(--bg-card);border:2px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;min-width:160px;padding:1.5rem 2.5rem;transition:border-color .15s,transform .1s;display:flex}.mode-picker__btn:hover{border-color:var(--gold);transform:translateY(-2px)}.mode-picker__btn-players{font-family:var(--font-mono);color:var(--gold-bright);font-size:1.5rem;font-weight:700}.mode-picker__btn-label{color:var(--text);font-size:1rem;font-weight:600}.mode-picker__form{flex-direction:column;gap:.75rem;width:100%;max-width:360px;margin-top:1rem;display:flex}.mode-picker__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;font-weight:500}.mode-picker__input{font-family:var(--font-ui);background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;padding:.75rem 1rem;font-size:1rem;transition:border-color .15s}.mode-picker__input:focus{border-color:var(--gold)}.mode-picker__code-inputs{justify-content:center;gap:.5rem;display:flex}.mode-picker__code-char{font-family:var(--font-mono);text-align:center;background:var(--bg-card);border:2px solid var(--border);width:3.5rem;height:4rem;color:var(--gold-bright);text-transform:uppercase;border-radius:8px;outline:none;font-size:2rem;font-weight:700;transition:border-color .15s}.mode-picker__code-char:focus{border-color:var(--gold)}.mode-picker__submit{background:var(--gold);color:var(--black);text-transform:uppercase;letter-spacing:.05em;border-radius:8px;margin-top:.5rem;padding:.85rem;font-size:1rem;font-weight:600;transition:background .15s,opacity .15s}.mode-picker__submit:hover:not(:disabled){background:var(--gold-bright)}.mode-picker__submit:disabled{opacity:.5;cursor:not-allowed}.mode-picker__error{color:var(--casino-red-bright);text-align:center;font-size:.9rem}.imposter{text-align:center;flex-direction:column;align-items:center;min-height:100dvh;padding:2rem 1.5rem;display:flex}.imposter__title{font-family:var(--font-heading);color:var(--gold);margin:0 0 .25rem;font-size:2.5rem}.imposter__subtitle{font-family:var(--font-ui);color:var(--text-muted);margin:0 0 2rem;font-size:1rem}.imposter__setup{flex-direction:column;gap:1.25rem;width:100%;max-width:360px;display:flex}.imposter__label{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;text-align:left;font-size:.85rem}.imposter__player-select{justify-content:center;align-items:center;gap:1.5rem;display:flex}.imposter__stepper{border:2px solid var(--border);background:var(--bg-card);width:48px;height:48px;color:var(--gold);font-size:1.5rem;font-family:var(--font-mono);cursor:pointer;border-radius:50%;transition:border-color .2s,background .2s}.imposter__stepper:hover:not(:disabled){border-color:var(--gold);background:#d4a3321a}.imposter__stepper:disabled{opacity:.3;cursor:not-allowed}.imposter__player-count{font-family:var(--font-mono);color:#fff;min-width:3rem;font-size:2.5rem}.imposter__toggle-row{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:1rem;display:flex}.imposter__toggle-label{font-family:var(--font-ui);color:#fff;text-align:left;flex:1;font-size:1rem}.imposter__toggle-hint{width:100%;font-family:var(--font-ui);color:var(--text-muted);text-align:left;order:3;font-size:.8rem}.imposter__toggle{border:2px solid var(--border);cursor:pointer;background:#ffffff1a;border-radius:14px;width:52px;height:28px;padding:0;transition:background .2s,border-color .2s;position:relative}.imposter__toggle--on{background:var(--gold);border-color:var(--gold-bright)}.imposter__toggle:disabled{opacity:.3;cursor:not-allowed}.imposter__toggle-knob{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px}.imposter__toggle--on .imposter__toggle-knob{transform:translate(24px)}.imposter__lang-row{justify-content:space-between;align-items:center;display:flex}.imposter__lang-buttons{gap:.5rem;display:flex}.imposter__lang-btn{border:2px solid var(--border);color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:border-color .2s,color .2s,background .2s}.imposter__lang-btn:hover{border-color:var(--gold);color:#fff}.imposter__lang-btn--active{border-color:var(--gold);color:var(--gold);background:#d4a33226}.imposter__hint{font-family:var(--font-ui);color:var(--casino-red);margin:0;font-size:.8rem}.imposter__start{background:var(--gold);color:#1a1a2e;font-family:var(--font-ui);cursor:pointer;border:none;border-radius:12px;margin-top:.5rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;transition:background .2s,transform .1s}.imposter__start:hover{background:var(--gold-bright)}.imposter__start:active{transform:scale(.97)}.imposter__reveal{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:400px;margin-top:2rem;display:flex}.imposter__reveal-pass{font-family:var(--font-ui);color:var(--text-muted);margin:0;font-size:1rem}.imposter__reveal-player{font-family:var(--font-heading);color:#fff;margin:0;font-size:2rem}.imposter__reveal-btn{border:2px solid var(--gold);color:var(--gold);font-family:var(--font-ui);cursor:pointer;background:#d4a3321a;border-radius:16px;padding:1.25rem 2.5rem;font-size:1.1rem;font-weight:600;transition:background .2s,transform .1s;animation:2s ease-in-out infinite pulse-border}@keyframes pulse-border{0%,to{border-color:var(--gold)}50%{border-color:var(--gold-bright);box-shadow:0 0 20px #d4a3324d}}.imposter__reveal-btn:hover{background:#d4a33233}.imposter__reveal-btn:active{transform:scale(.97)}.imposter__reveal-word-area{flex-direction:column;align-items:center;gap:1rem;display:flex}.imposter__reveal-word{font-family:var(--font-heading);color:#fff;border:1px solid var(--border);background:#ffffff14;border-radius:16px;min-width:200px;margin:0;padding:1.5rem 2rem;font-size:2.5rem}.imposter__reveal-role-hint{font-family:var(--font-ui);color:var(--casino-red);margin:0;font-size:.9rem}.imposter__reveal-next{background:var(--gold);color:#1a1a2e;font-family:var(--font-ui);cursor:pointer;border:none;border-radius:12px;padding:.9rem 2rem;font-size:1rem;font-weight:600;transition:background .2s}.imposter__reveal-next:hover{background:var(--gold-bright)}.imposter__reveal-progress{gap:.5rem;margin-top:1rem;display:flex}.imposter__reveal-dot{background:#ffffff26;border-radius:50%;width:10px;height:10px;transition:background .3s}.imposter__reveal-dot--done{background:var(--gold)}.imposter__reveal-dot--active{background:var(--gold-bright);box-shadow:0 0 6px #d4a33299}.imposter__players{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;width:100%;max-width:600px;margin-top:1rem;display:grid}.imposter__player-card{border:2px solid var(--border);background:var(--bg-card);color:#fff;font-family:var(--font-ui);cursor:pointer;border-radius:12px;padding:1.25rem 1rem;font-size:1rem;font-weight:600;transition:border-color .2s,background .2s,transform .1s}.imposter__player-card:hover{border-color:var(--casino-red);background:#cc29361a}.imposter__player-card--selected{border-color:var(--casino-red);background:#cc293626;transform:scale(1.02)}.imposter__player-number{display:block}.imposter__vote-confirm{border:1px solid var(--casino-red);background:#cc29361a;border-radius:12px;width:100%;max-width:360px;margin-top:1.5rem;padding:1.25rem}.imposter__vote-confirm p{font-family:var(--font-ui);color:#fff;margin:0 0 1rem;font-size:1.1rem}.imposter__vote-buttons{justify-content:center;gap:.75rem;display:flex}.imposter__btn-eliminate{background:var(--casino-red);color:#fff;font-family:var(--font-ui);cursor:pointer;border:none;border-radius:10px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:background .2s}.imposter__btn-eliminate:hover{background:#e0333f}.imposter__btn-cancel{border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:10px;padding:.75rem 1.5rem;font-size:.95rem;transition:border-color .2s}.imposter__btn-cancel:hover{color:#fff;border-color:#fff}.imposter__eliminated{width:100%;max-width:600px;margin-top:1.5rem}.imposter__eliminated-title{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .5rem;font-size:.85rem}.imposter__eliminated-badge{border:1px solid var(--border);font-family:var(--font-ui);color:var(--text-muted);background:#ffffff0d;border-radius:8px;align-items:center;gap:.5rem;margin:.25rem;padding:.4rem .8rem;font-size:.85rem;text-decoration:line-through;display:inline-flex}.imposter__eliminated-role{opacity:.7;font-size:.75rem}.imposter__alive-count{font-family:var(--font-mono);color:var(--text-muted);margin-top:1.5rem;font-size:.85rem}.imposter__mw-guess{flex-direction:column;align-items:center;gap:1.25rem;width:100%;max-width:400px;margin-top:2rem;display:flex}.imposter__mw-text{font-family:var(--font-ui);color:var(--text-muted);margin:0;font-size:1rem;line-height:1.5}.imposter__mw-input{border:2px solid var(--border);background:var(--bg-card);color:#fff;width:100%;font-family:var(--font-ui);text-align:center;border-radius:10px;outline:none;padding:.9rem 1rem;font-size:1.1rem;transition:border-color .2s}.imposter__mw-input:focus{border-color:var(--gold)}.imposter__mw-submit{background:var(--gold);color:#1a1a2e;font-family:var(--font-ui);cursor:pointer;border:none;border-radius:12px;padding:.9rem 2rem;font-size:1rem;font-weight:600;transition:background .2s}.imposter__mw-submit:hover{background:var(--gold-bright)}.imposter__mw-submit:disabled{opacity:.4;cursor:not-allowed}.imposter__end{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:500px;margin-top:1.5rem;display:flex}.imposter__end-winner{font-family:var(--font-heading);color:var(--gold);margin:0;font-size:2rem}.imposter__end-words{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.imposter__end-word-pair{border:1px solid var(--border);background:#ffffff0f;border-radius:12px;flex-direction:column;gap:.25rem;padding:1rem 1.5rem;display:flex}.imposter__end-word-label{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.imposter__end-word-value{font-family:var(--font-heading);color:#fff;font-size:1.5rem}.imposter__end-roles{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;width:100%;display:grid}.imposter__end-player{border:1px solid var(--border);background:#ffffff0a;border-radius:10px;flex-direction:column;gap:.2rem;padding:.75rem;display:flex}.imposter__end-player--imposter{border-color:var(--casino-red);background:#cc29361a}.imposter__end-player--mister-white{background:#9b59b61a;border-color:#9b59b6}.imposter__end-player-name{font-family:var(--font-ui);color:#fff;font-size:.95rem;font-weight:600}.imposter__end-player-role{font-family:var(--font-ui);color:var(--text-muted);font-size:.8rem}.imposter__play-again{background:var(--gold);color:#1a1a2e;font-family:var(--font-ui);cursor:pointer;border:none;border-radius:12px;margin-top:.5rem;padding:1rem 2.5rem;font-size:1.1rem;font-weight:600;transition:background .2s,transform .1s}.imposter__play-again:hover{background:var(--gold-bright)}.imposter__play-again:active{transform:scale(.97)}.game-card{background:linear-gradient(145deg, var(--black-light), var(--black));cursor:pointer;text-align:left;border:1px solid #d4a33240;border-radius:16px;padding:36px 28px;transition:transform .25s,box-shadow .25s,border-color .3s;animation:.6s backwards card-enter;position:relative;overflow:hidden}.game-card:first-child{animation-delay:.1s}.game-card:nth-child(2){animation-delay:.2s}.game-card:nth-child(3){animation-delay:.3s}.game-card:nth-child(4){animation-delay:.4s}@keyframes card-enter{0%{opacity:0;transform:translateY(30px)scale(.97)}}.game-card:before{content:"";opacity:0;background:radial-gradient(80% 60% at 30% 0,#f0c0401a,#0000 60%);border-radius:16px;transition:opacity .3s;position:absolute;inset:0}.game-card:after{content:"";background:linear-gradient(90deg, transparent, var(--gold), transparent);opacity:.4;height:2px;position:absolute;bottom:0;left:10%;right:10%}.game-card:hover{border-color:var(--gold);transform:translateY(-6px);box-shadow:0 8px 32px #00000080,0 0 20px #d4a33226}.game-card:hover:before{opacity:1}.game-card-emoji{filter:drop-shadow(0 2px 4px #0006);margin-bottom:20px;font-size:3.5rem;display:block}.game-card-name{color:#fff;text-shadow:0 1px 2px #00000080;margin-bottom:8px;font-size:1.75rem;font-weight:700}.game-card-desc{color:#b0b0b0;margin-bottom:20px;font-size:.875rem;line-height:1.7}.game-card-players{font-family:var(--font-mono);color:var(--gold);letter-spacing:1px;text-transform:uppercase;font-size:.7rem}.home-screen{flex-direction:column;flex:1;align-items:center;padding:80px 24px 48px;display:flex;position:relative}.home-screen:before{content:"";pointer-events:none;background:radial-gradient(#ffffff0f,#0000 70%);width:600px;height:400px;position:absolute;top:-100px;left:50%;transform:translate(-50%)}.home-header{text-align:center;margin-bottom:64px;position:relative}.home-title{letter-spacing:-2px;color:var(--text-bright);text-shadow:0 0 40px #f0c04066,0 2px #00000080;margin-bottom:16px;font-size:4.5rem;font-weight:900}.home-subtitle{font-family:var(--font-mono);color:var(--gold-bright);letter-spacing:4px;text-transform:uppercase;font-size:.85rem;font-weight:400}.games-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;width:100%;max-width:900px;display:grid}@media (width<=640px){.home-screen{padding:48px 16px 32px}.home-title{font-size:2.75rem}.home-header{margin-bottom:40px}.games-grid{grid-template-columns:1fr}}.app{flex-direction:column;flex:1;display:flex}
