*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark: #0d0d1a;--bg-card: #1a1a2e;--bg-card-hover: #222240;--bg-input: #13132a;--border: #2a2a4a;--accent: #e94560;--accent-glow: #e9456080;--safe: #4ecca3;--safe-glow: #4ecca380;--text: #eee;--text-dim: #888;--text-muted: #555;--vampire-red: #e94560;--seer-purple: #b56eff;--doctor-green: #4ecca3;--sheriff-gold: #f0c040;--villager-blue: #6ec6ff;--system-gray: #777}html,body{height:100%;background:var(--bg-dark);color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.5;overflow:hidden}#root{height:100%}h1,h2,h3,h4{font-family:Cinzel,serif;font-weight:700;letter-spacing:.02em}.app{height:100%;display:flex;flex-direction:column;background:radial-gradient(ellipse at 20% 80%,#1a0a2e33 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,#2e0a1a33 0%,transparent 50%),var(--bg-dark)}.error-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;padding:10px 24px;border-radius:8px;z-index:1000;font-weight:500;animation:slideDown .3s ease;box-shadow:0 4px 20px var(--accent-glow)}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:8px;font-family:Cinzel,serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.btn-primary:hover:not(:disabled){background:#d63a52;box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--text-dim)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:14px 32px;font-size:16px;width:100%}input[type=text],select{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:8px;font-size:14px;font-family:Inter,sans-serif;outline:none;transition:border-color .2s;width:100%}input[type=text]:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}input[type=text]::placeholder{color:var(--text-muted)}label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:6px}.input-group{margin-bottom:16px}.home{height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.home-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:48px 40px;width:100%;max-width:420px;text-align:center;box-shadow:0 8px 40px #0006}.title{font-size:48px;color:var(--accent);margin-bottom:4px;text-shadow:0 0 30px var(--accent-glow)}.subtitle{color:var(--text-dim);font-size:14px;margin-bottom:32px;font-style:italic}.button-group{display:flex;flex-direction:column;gap:10px;margin-top:8px}.lobby{height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.lobby-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:36px 32px;width:100%;max-width:520px;box-shadow:0 8px 40px #0006}.room-code-display{display:flex;align-items:center;gap:12px;background:var(--bg-dark);padding:12px 16px;border-radius:10px;margin-bottom:24px}.room-code-display .label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:0}.room-code-display .code{font-family:Cinzel,serif;font-size:28px;font-weight:900;color:var(--accent);letter-spacing:.15em;flex:1;text-align:center}.player-list-lobby h3{font-size:16px;margin-bottom:12px;color:var(--text-dim)}.player-list-lobby ul{list-style:none;margin-bottom:20px}.player-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.player-item:last-child{border-bottom:none}.player-name{font-weight:500}.you-badge{color:var(--safe);font-size:12px}.host-badge{background:var(--sheriff-gold);color:#000;font-size:10px;padding:2px 6px;border-radius:4px;font-weight:700;text-transform:uppercase;margin-left:6px}.ai-badge{font-size:12px;color:var(--seer-purple);display:flex;align-items:center;gap:6px}.btn-remove{background:none;border:none;color:var(--accent);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.btn-remove:hover{color:#ff6b7f}.waiting-text{text-align:center;color:var(--text-dim);font-style:italic;margin-top:16px}.add-ai-panel{border-top:1px solid var(--border);padding-top:16px;margin-bottom:20px}.add-ai-panel h3{font-size:14px;margin-bottom:10px;color:var(--text-dim)}.add-ai-row{display:flex;gap:8px;align-items:center}.model-select{flex:1;min-width:0}.ai-name-input{flex:.8;min-width:0}.game{height:100%;display:flex;flex-direction:column;overflow:hidden}.game-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.phase-info{display:flex;align-items:center;gap:12px}.phase-badge{padding:4px 14px;border-radius:20px;font-family:Cinzel,serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.phase-badge[data-phase=NIGHT]{background:#1a0a2e;color:#b56eff;border:1px solid #b56eff44}.phase-badge[data-phase=DAY_ANNOUNCE]{background:#2e2a0a;color:#f0c040;border:1px solid #f0c04044}.phase-badge[data-phase=DAY_DISCUSS]{background:#0a2e1a;color:#4ecca3;border:1px solid #4ecca344}.phase-badge[data-phase=DAY_VOTE]{background:#2e0a0a;color:#e94560;border:1px solid #e9456044}.day-count{color:var(--text-dim);font-size:13px}.role-info{display:flex;align-items:center;gap:8px}.role-badge{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase}.role-badge[data-role=Vampire]{background:#2e0a1a;color:var(--vampire-red)}.role-badge[data-role=Seer]{background:#1a0a2e;color:var(--seer-purple)}.role-badge[data-role=Doctor]{background:#0a2e1a;color:var(--doctor-green)}.role-badge[data-role=Sheriff]{background:#2e2a0a;color:var(--sheriff-gold)}.role-badge[data-role=Villager]{background:#0a1a2e;color:var(--villager-blue)}.dead-badge{background:#333;color:#999;padding:2px 8px;border-radius:4px;font-size:11px;text-transform:uppercase}.phase-timer{font-family:Cinzel,serif;font-size:20px;font-weight:700;color:var(--accent);min-width:50px;text-align:right}.game-layout{display:grid;grid-template-columns:220px 1fr 260px;flex:1;overflow:hidden}.game-sidebar{background:var(--bg-card);border-right:1px solid var(--border);padding:16px;overflow-y:auto}.player-list h3{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:8px;margin-top:16px}.player-list h3:first-child{margin-top:0}.player-list ul{list-style:none}.player-entry{padding:6px 8px;border-radius:6px;font-size:13px;display:flex;justify-content:space-between;align-items:center}.player-entry.alive:hover{background:var(--bg-card-hover)}.player-entry.dead{opacity:.5}.dead-name{text-decoration:line-through}.you-tag{color:var(--safe);font-size:11px}.ai-tag{color:var(--seer-purple);font-size:11px}.vote-count{background:var(--accent);color:#fff;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:700}.dead-role{font-size:11px;color:var(--text-muted)}.role-history{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.role-history h4{font-size:12px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}.role-history p{font-size:12px;padding:3px 0;line-height:1.4}.seer-results h4{color:var(--seer-purple)}.doctor-results h4{color:var(--doctor-green)}.vampire-history h4{color:var(--vampire-red)}.vampire-result{color:var(--vampire-red);font-weight:600;font-size:13px}.innocent-result{color:var(--safe);font-size:13px}.save-result{color:var(--doctor-green);font-weight:600}.no-attack-result{color:var(--text-dim)}.kill-result{color:var(--vampire-red)}.saved-result{color:var(--sheriff-gold)}.game-main{display:flex;flex-direction:column;overflow:hidden}.announcement{padding:12px 20px;text-align:center;font-family:Cinzel,serif;font-size:14px;font-weight:600;border-bottom:1px solid var(--border);flex-shrink:0}.death-announcement{background:linear-gradient(135deg,#2e0a0a,#1a0a15);color:var(--accent)}.safe-announcement{background:linear-gradient(135deg,#0a2e1a,#0a1a15);color:var(--safe)}.chat{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:4px}.chat-msg{padding:4px 0;font-size:14px;line-height:1.5;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.msg-sender{font-weight:600;margin-right:8px}.msg-sender:after{content:":"}.system-msg{color:var(--system-gray);font-style:italic;font-size:13px;padding:4px 8px;border-left:2px solid var(--text-muted);margin:4px 0}.system-msg .msg-sender{display:none}.vampire-msg{color:var(--vampire-red);background:#2e0a0a22;padding:4px 8px;border-radius:4px}.vampire-msg .msg-sender{color:var(--vampire-red)}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-style:italic}.chat-input{display:flex;gap:8px;padding:10px 16px;border-top:1px solid var(--border);background:var(--bg-card);flex-shrink:0}.chat-input input{flex:1}.game-actions{background:var(--bg-card);border-left:1px solid var(--border);padding:16px;overflow-y:auto}.action-placeholder{height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px}.ghost-text{color:var(--text-muted);font-style:italic;font-size:14px}.action-hint{color:var(--text-dim);font-size:14px}.night-action h3{font-size:16px;margin-bottom:4px;color:var(--seer-purple)}.action-desc{color:var(--text-dim);font-size:13px;margin-bottom:16px}.action-status{color:var(--safe);font-style:italic;text-align:center;margin-top:20px}.target-grid{display:flex;flex-direction:column;gap:8px}.target-btn{background:var(--bg-dark);border:1px solid var(--border);color:var(--text);padding:12px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-family:Inter,sans-serif;transition:all .2s;text-align:left}.target-btn:hover{border-color:var(--seer-purple);background:#1a0a2e;transform:translate(2px)}.vote-panel h3{font-size:16px;margin-bottom:12px;color:var(--accent)}.vote-status{color:var(--safe);font-style:italic;text-align:center}.vote-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.vote-btn{display:flex;justify-content:space-between;align-items:center;background:var(--bg-dark);border:1px solid var(--border);color:var(--text);padding:12px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-family:Inter,sans-serif;transition:all .2s}.vote-btn:hover{border-color:var(--accent);background:#2e0a1a}.vote-name{font-weight:500}.vote-indicator{background:var(--accent);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.btn-skip{width:100%;margin-top:4px}.role-reveal{height:100%;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .6s ease}.role-reveal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:60px 48px;text-align:center;max-width:440px;width:100%;box-shadow:0 12px 60px #00000080;animation:revealPulse 2s ease infinite}@keyframes revealPulse{0%,to{box-shadow:0 12px 60px #00000080}50%{box-shadow:0 12px 60px var(--accent-glow)}}.role-emoji{font-size:72px;margin-bottom:16px}.role-title{font-size:32px;color:var(--accent);margin-bottom:12px}.role-desc{color:var(--text-dim);font-size:15px;line-height:1.6;margin-bottom:20px}.role-hint{color:var(--text-muted);font-style:italic;font-size:13px}.game-over{height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.game-over-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:48px 40px;text-align:center;max-width:480px;width:100%;box-shadow:0 12px 60px #00000080}.game-over-title{font-size:48px;margin-bottom:8px}.game-over-title.win{color:var(--safe);text-shadow:0 0 30px var(--safe-glow)}.game-over-title.lose{color:var(--accent);text-shadow:0 0 30px var(--accent-glow)}.game-over-message{font-size:16px;color:var(--text-dim);margin-bottom:8px}.game-over-role{color:var(--text-dim);margin-bottom:24px}.roles-reveal{text-align:left;margin-bottom:24px}.roles-reveal h3{font-size:14px;color:var(--text-dim);margin-bottom:10px;text-align:center}.roles-reveal ul{list-style:none}.role-entry{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);font-size:14px}.role-entry:last-child{border-bottom:none}.role-entry.dead{opacity:.6}.reveal-name{flex:1;font-weight:500}.reveal-role{font-size:12px;font-weight:600;padding:2px 8px;border-radius:4px;text-transform:uppercase}.reveal-role.vampire{background:#2e0a1a;color:var(--vampire-red)}.reveal-role.village{background:#0a2e1a;color:var(--safe)}.reveal-dead{font-size:10px;color:var(--text-muted);text-transform:uppercase}.reveal-you{font-size:10px;color:var(--safe);text-transform:uppercase;font-weight:700}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 900px){.game-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.game-sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:120px}.game-actions{border-left:none;border-top:1px solid var(--border);max-height:250px}.player-list ul{display:flex;flex-wrap:wrap;gap:4px}.player-entry{padding:4px 8px;font-size:12px}}
