*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{--primary:#DC2626;--primary-glow:#EF4444;--success:#22C55E;--warning:#F59E0B;--info:#3B82F6;--bg:#1a0a0a;--surface:#251515;--card:#2a1a1a;--text:#fff;--dim:#aa8888;--night-bg:#0a0a1a;--day-bg:#1a1500}
html{height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;user-select:none;-webkit-user-select:none;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}
.screen{display:none;min-height:100dvh;padding:24px 20px}
.screen.active{display:flex;align-items:center;justify-content:center}
.screen.night{background:var(--night-bg)}.screen.day{background:var(--day-bg)}
.container{width:100%;max-width:500px;text-align:center}
.logo{font-size:5rem;margin-bottom:8px}
.title{font-size:2.8rem;font-weight:900;letter-spacing:6px;color:var(--primary);margin-bottom:4px}
.subtitle{color:var(--dim);font-size:1rem;margin-bottom:32px}
h2{font-size:1.5rem;margin-bottom:20px}
.menu-buttons{display:flex;flex-direction:column;gap:14px}
.btn-primary{width:100%;padding:18px;border:none;border-radius:14px;background:linear-gradient(135deg,var(--primary),#991B1B);color:#fff;font-size:1.1rem;font-weight:700;letter-spacing:2px;cursor:pointer}
.btn-primary:active{transform:scale(.97);opacity:.9}
.btn-primary:disabled{opacity:.4}
.btn-secondary{width:100%;padding:18px;border:2px solid rgba(255,255,255,.1);border-radius:14px;background:0 0;color:var(--dim);font-size:1.1rem;font-weight:700;letter-spacing:2px;cursor:pointer}
.btn-back{background:0 0;border:none;color:var(--dim);font-size:.9rem;margin-top:16px;cursor:pointer;padding:8px}
.btn-invite{width:100%;padding:14px;border:2px dashed rgba(220,38,38,.4);border-radius:12px;background:rgba(220,38,38,.08);color:var(--primary);font-size:1rem;font-weight:700;cursor:pointer;margin-bottom:16px}
.input-group{margin-bottom:20px;text-align:left}
.input-group label{display:block;color:var(--dim);font-size:.85rem;margin-bottom:8px}
.input-group input{width:100%;padding:14px 16px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:var(--surface);color:var(--text);font-size:1.1rem;outline:none}
.input-group input:focus{border-color:var(--primary)}
.code-input{text-transform:uppercase;letter-spacing:8px;text-align:center;font-size:1.8rem!important}
.stepper{display:flex;align-items:center;justify-content:center;gap:20px}
.stepper span{font-size:1.5rem;font-weight:700;min-width:40px;text-align:center}
.stepper-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--primary);background:0 0;color:var(--primary);font-size:1.4rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}
.stepper-btn:active{background:var(--primary);color:#fff}
.roles-info{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}
.roles-info span{background:var(--surface);padding:6px 12px;border-radius:8px;font-size:.8rem;color:var(--dim)}
.room-code-box{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--surface);border-radius:16px;padding:20px;margin-bottom:16px}
.room-label{color:var(--dim);font-size:.8rem;text-transform:uppercase;letter-spacing:2px}
.room-code{font-size:3rem;font-weight:900;letter-spacing:12px;color:var(--primary)}
.players-list{background:var(--surface);border-radius:12px;padding:12px;margin-bottom:16px}
.player-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px}
.player-item:not(:last-child){border-bottom:1px solid rgba(255,255,255,.05)}
.player-name{font-weight:600}.player-tag{font-size:.75rem;color:var(--warning)}
.info{color:var(--dim);font-size:.9rem;margin-bottom:16px}
.role-reveal{background:var(--card);border-radius:20px;padding:40px 24px;margin-bottom:20px;border:2px solid rgba(220,38,38,.3)}
.role-emoji{font-size:5rem;margin-bottom:12px}
.role-title{font-size:2rem;font-weight:900;color:var(--primary);margin-bottom:8px}
.role-desc{color:var(--dim);font-size:1rem}
.phase-icon{font-size:4rem;margin-bottom:12px}
.action-label{color:var(--text);font-size:1.1rem;font-weight:600;margin-bottom:12px}
.vote-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.vote-item{padding:16px;background:var(--surface);border-radius:12px;font-weight:600;font-size:1.1rem;cursor:pointer;border:2px solid transparent;transition:all .15s}
.vote-item:active{border-color:var(--primary);background:rgba(220,38,38,.1)}
.vote-item.selected{border-color:var(--primary);background:rgba(220,38,38,.15)}
.vote-item.dead{opacity:.3;text-decoration:line-through;pointer-events:none}
.announcement{background:var(--surface);border-radius:12px;padding:16px;margin-bottom:20px;font-size:1.1rem}
.announcement .dead-name{color:var(--primary);font-weight:700}
.result-box{background:var(--surface);border-radius:12px;padding:20px;margin-bottom:20px;text-align:left}
.result-row{display:flex;justify-content:space-between;padding:8px 0}
.result-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,.05)}
.result-vamp{color:var(--primary);font-weight:700}
.toast{position:fixed;bottom:-60px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid rgba(255,255,255,.1);padding:12px 24px;border-radius:12px;font-size:.9rem;color:var(--text);transition:bottom .3s;z-index:100}
.toast.show{bottom:40px}
