*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f1a;--bg-card: #1a1a2e;--bg-elevated: #16213e;--text: #e0e0e0;--text-muted: #8888aa;--accent: #e94560;--accent-2: #533483;--gold: #f4c542;--success: #27ae60;--danger: #e74c3c;--role-duke: #9b59b6;--role-assassin: #2c3e50;--role-ambassador: #27ae60;--role-captain: #2980b9;--role-contessa: #e74c3c;--radius: 8px;--radius-lg: 12px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}.app{max-width:800px;margin:0 auto;padding:16px;min-height:100vh}.title{font-size:3rem;text-align:center;color:var(--accent);margin-bottom:8px;font-weight:800;letter-spacing:-1px}.subtitle{text-align:center;color:var(--text-muted);margin-bottom:32px;font-size:1.1rem}.btn{padding:10px 20px;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#d63a52}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover:not(:disabled){background:#1c2a4a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#219a52}.btn-small{padding:4px 12px;font-size:.8rem}.btn-large{padding:14px 32px;font-size:1.1rem}.btn-action{background:var(--bg-elevated);color:var(--text);border:2px solid rgba(255,255,255,.1);flex-direction:column;padding:12px 16px;min-width:120px}.btn-action:hover:not(:disabled){border-color:var(--accent)}.btn-target{background:var(--bg-elevated);color:var(--text);border:1px solid rgba(255,255,255,.15)}.btn-target:hover{border-color:var(--accent);background:#e945601a}.input{width:100%;padding:12px 16px;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);color:var(--text);font-size:1rem}.input::placeholder{color:var(--text-muted)}.input:focus{outline:none;border-color:var(--accent)}.home-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh}.mode-selection{display:flex;flex-direction:column;gap:16px;width:100%;max-width:360px}.mode-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;width:100%;padding:20px 24px;background:var(--bg-card);border:2px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);cursor:pointer;transition:all .15s ease;text-align:left;color:var(--text);font-family:inherit;font-size:inherit}.mode-card:hover{border-color:var(--accent);background:var(--bg-elevated)}.mode-card-icon{font-size:1.5rem;font-weight:700;color:var(--accent);line-height:1}.mode-card-title{font-size:1.15rem;font-weight:700;color:var(--text)}.mode-card-desc{font-size:.85rem;color:var(--text-muted);line-height:1.4}.home-form{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px}.back-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:0;align-self:flex-start;font-family:inherit;transition:color .15s ease}.back-link:hover{color:var(--text)}.form-heading{font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:4px}.game-header{display:flex;align-items:center;gap:12px;padding:8px 0;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.room-code{font-weight:600;color:var(--gold);font-family:monospace;font-size:.9rem}.connection-status{font-size:.8rem}.connection-status[data-status=connected]{color:var(--success)}.connection-status[data-status=disconnected],.connection-status[data-status=error]{color:var(--danger)}.game-header .btn{margin-left:auto}.error-banner{background:#e74c3c26;border:1px solid var(--danger);padding:8px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:.9rem;color:var(--danger)}.loading,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:var(--text-muted)}.lobby{text-align:center;padding:40px 0}.lobby h2{margin-bottom:8px}.room-invite{color:var(--text-muted);margin-bottom:24px}.room-invite strong{color:var(--gold);font-family:monospace;font-size:1.2rem;letter-spacing:2px}.player-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:24px 0}.lobby-player{display:flex;align-items:center;gap:8px;background:var(--bg-card);padding:8px 16px;border-radius:var(--radius)}.player-count{color:var(--text-muted);margin-bottom:24px}.player-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.players-ring{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.player-info{background:var(--bg-card);border:2px solid transparent;border-radius:var(--radius-lg);padding:12px;flex:1;min-width:140px;transition:border-color .2s}.player-info.current-turn{border-color:var(--gold)}.player-info.self{background:var(--bg-elevated)}.player-info.eliminated{opacity:.5}.player-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.player-name{font-weight:600;font-size:.9rem}.turn-indicator{color:var(--gold);margin-left:auto}.player-stats{display:flex;gap:12px;font-size:.85rem}.revealed-cards{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}.card-badge{padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.card-badge.revealed{opacity:.7;text-decoration:line-through}.eliminated-badge{margin-top:8px;color:var(--danger);font-size:.8rem;font-weight:600}.player-hand{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.player-hand h3{margin-bottom:12px;font-size:1rem}.challenge-header{background:#e945601a;border:1px solid rgba(233,69,96,.3);border-radius:var(--radius);padding:12px;margin-bottom:12px}.challenge-header h3{margin-bottom:4px;color:var(--accent)}.challenge-desc{font-size:.85rem;color:var(--text-muted);line-height:1.4}.challenge-desc strong{color:var(--text)}.hand-cards{display:flex;gap:12px;margin-bottom:12px}.card{background:var(--bg-elevated);color:var(--text);border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:16px;min-width:120px;text-align:center;transition:all .2s}.card.revealed{opacity:.5;border-style:dashed}.card.selectable{cursor:pointer}.card.selectable:hover{border-color:var(--accent)}.card.selected{border-color:var(--gold);box-shadow:0 0 12px #f4c5424d}.card-role{font-weight:700;font-size:1rem;margin-bottom:4px}.card-status{font-size:.8rem;color:var(--text-muted)}.card-hint{display:block;font-size:.7rem;margin-top:4px;line-height:1.3}.card-hint-match{color:var(--success)}.card-hint-fail{color:var(--text-muted)}.role-duke{border-color:var(--role-duke)}.role-assassin{border-color:var(--role-assassin)}.role-ambassador{border-color:var(--role-ambassador)}.role-captain{border-color:var(--role-captain)}.role-contessa{border-color:var(--role-contessa)}.card-badge.role-duke{background:var(--role-duke);color:#fff}.card-badge.role-assassin{background:var(--role-assassin);color:#fff}.card-badge.role-ambassador{background:var(--role-ambassador);color:#fff}.card-badge.role-captain{background:var(--role-captain);color:#fff}.card-badge.role-contessa{background:var(--role-contessa);color:#fff}.action-panel{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.action-panel h3{margin-bottom:12px;font-size:1rem}.action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-bottom:12px}.action-name{font-weight:600}.action-cost{font-size:.8rem;color:var(--gold)}.action-role{font-size:.75rem;color:var(--text-muted)}.action-desc{display:block;font-size:.7rem;color:var(--text-muted);font-weight:400;margin-top:4px;line-height:1.3}.targeting-you{color:var(--danger);font-weight:600}.response-buttons{display:flex;gap:8px;flex-wrap:wrap}.target-selector{background:#0000004d;border-radius:var(--radius);padding:16px;margin-top:12px}.target-selector h4{margin-bottom:8px}.target-list{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.waiting{color:var(--text-muted);text-align:center;padding:12px}.exchange-selector{margin-top:16px;padding:16px;background:#0003;border-radius:var(--radius)}.exchange-selector h4{margin-bottom:12px}.exchange-cards{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.game-log{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px}.game-log h3{margin-bottom:8px;font-size:.9rem;color:var(--text-muted)}.log-entries{max-height:200px;overflow-y:auto;font-size:.85rem}.log-entry{padding:4px 0;border-bottom:1px solid rgba(255,255,255,.05)}.log-entry:last-child{border-bottom:none}.log-empty{color:var(--text-muted);font-style:italic}.game-over-banner{text-align:center;padding:24px;background:linear-gradient(135deg,var(--accent-2),var(--accent));border-radius:var(--radius-lg);margin-bottom:16px}.game-over-banner h2{font-size:1.8rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}
