*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif;background:#1a1a2e;color:#e0e0e0;min-height:100vh;display:flex;align-items:center;justify-content:center}#root{width:100%;display:flex;align-items:center;justify-content:center}.card{background:#16213e;border:1px solid #0f3460;border-radius:12px;padding:2rem;width:100%;max-width:420px}.card h1{font-size:1.8rem;margin-bottom:1.5rem;text-align:center;color:#e94560}.card h2{font-size:1.3rem;margin-bottom:1rem;text-align:center}.input{width:100%;padding:.65rem .9rem;border:1px solid #0f3460;border-radius:8px;background:#0f3460;color:#e0e0e0;font-size:1rem;outline:none;margin-bottom:.75rem}.input:focus{border-color:#e94560}.input.code{text-transform:uppercase;letter-spacing:.25em;font-size:1.4rem;text-align:center}.btn{display:block;width:100%;padding:.7rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;margin-bottom:.5rem;transition:opacity .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:#e94560;color:#fff}.btn-secondary{background:#0f3460;color:#e0e0e0}.btn-ghost{background:transparent;color:#aaa;font-size:.9rem}.error{color:#e94560;font-size:.9rem;margin-bottom:.75rem;text-align:center}.room-code{text-align:center;font-size:2.5rem;font-weight:700;letter-spacing:.3em;color:#e94560;margin-bottom:.25rem}.room-hint{text-align:center;font-size:.85rem;color:#888;margin-bottom:1.5rem}.player-list{list-style:none;margin-bottom:1.5rem}.player-list li{padding:.45rem .75rem;border-radius:6px;display:flex;align-items:center;gap:.5rem}.player-list li:nth-child(odd){background:#0f3460}.host-badge{font-size:.75rem;background:#e94560;color:#fff;padding:.1rem .4rem;border-radius:4px}.waiting-text{text-align:center;color:#888;font-size:.95rem;margin-bottom:1rem}.start-hint{text-align:center;font-size:.8rem;color:#888;margin-top:.25rem}.role-reveal-card{display:flex;flex-direction:column;gap:1rem}.role-reveal-label{text-align:center;text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;color:#888}.role-banner{border-radius:8px;padding:1.25rem 1rem;text-align:center;border-left:4px solid transparent}.role-banner h2{font-size:1.6rem;margin-bottom:.5rem}.role-banner p{font-size:.88rem;line-height:1.5;color:#c8c8c8}.role-banner-liberal{background:#4a9eff1a;border-left-color:#4a9eff}.role-banner-liberal h2{color:#4a9eff}.role-banner-fascist{background:#e945601a;border-left-color:#e94560}.role-banner-fascist h2{color:#e94560}.role-banner-hitler{background:#ff8c001a;border-left-color:#ff8c00}.role-banner-hitler h2{color:#ff8c00}.role-info-box{background:#0f3460;border-radius:6px;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.2rem}.role-info-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:#888}.role-info-value{font-size:1rem;font-weight:600;color:#e0e0e0}.role-reveal-caution{font-size:.8rem;color:#888;text-align:center;font-style:italic}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{position:relative;background:#16213e;border:1px solid #0f3460;border-radius:12px;padding:2rem;width:100%;max-width:560px;max-height:85vh;overflow-y:auto}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#aaa;font-size:1.2rem;cursor:pointer;line-height:1;padding:.25rem .5rem;border-radius:4px}.modal-close:hover{color:#e0e0e0;background:#0f3460}.modal-title{font-size:1.4rem;color:#e94560;margin-bottom:1.5rem;padding-right:2rem}.modal-section{margin-bottom:1.5rem}.modal-section h3{font-size:1rem;text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:.75rem;border-bottom:1px solid #0f3460;padding-bottom:.35rem}.modal-section p{font-size:.9rem;line-height:1.55;color:#c8c8c8}.role-card{border-left:3px solid transparent;padding:.6rem .75rem;border-radius:6px;margin-bottom:.6rem;background:#0f3460}.role-card strong{display:block;margin-bottom:.3rem;font-size:.95rem}.role-liberal{border-left-color:#4a9eff}.role-liberal strong{color:#4a9eff}.role-fascist{border-left-color:#e94560}.role-fascist strong{color:#e94560}.role-hitler{border-left-color:#ff8c00}.role-hitler strong{color:#ff8c00}.phase-item{padding:.6rem .75rem;border-radius:6px;margin-bottom:.6rem;background:#0f3460}.phase-item strong{display:block;margin-bottom:.3rem;font-size:.95rem;color:#e0e0e0}.card--wide{max-width:560px}.btn-sm{width:auto;padding:.35rem .75rem;font-size:.85rem;margin-bottom:0}.nom-status{font-size:.9rem;color:#aaa;text-align:center;margin-bottom:1.25rem}.nom-player-list{list-style:none;display:flex;flex-direction:column;gap:.4rem}.nom-player-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;border-radius:8px;background:#0f3460;border:1px solid transparent;gap:.5rem}.nom-player-row--president{border-color:#e94560;background:#e9456014}.nom-player-row--ineligible{opacity:.5}.nom-player-row--dead{opacity:.35;text-decoration:line-through}.nom-player-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.nom-player-name{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nom-player-badges{display:flex;gap:.3rem;flex-wrap:wrap}.nom-player-action{flex-shrink:0}.nom-badge{display:inline-block;font-size:.7rem;padding:.1rem .4rem;border-radius:4px;font-weight:600;white-space:nowrap}.nom-badge--president{background:#e94560;color:#fff}.nom-badge--term-limit{background:#0f3460;color:#888;border:1px solid #1a4a80}.nom-badge--dead{background:#2a2a2a;color:#666}.nom-ineligible-reason{font-size:.78rem;color:#666;font-style:italic;cursor:default;max-width:160px;text-align:right;line-height:1.3}.vote-government{display:flex;align-items:center;justify-content:center;gap:1rem;background:#0f3460;border-radius:8px;padding:.85rem 1rem;margin-bottom:1rem}.vote-government-role{display:flex;flex-direction:column;align-items:center;gap:.2rem}.vote-role-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#888}.vote-role-name{font-size:1.1rem;font-weight:700;color:#e0e0e0}.vote-government-divider{font-size:1.2rem;color:#555}.vote-tracker{display:flex;flex-direction:column;align-items:center;gap:.2rem;font-size:.85rem;color:#888;background:#0f3460;border-radius:6px;padding:.4rem .75rem;margin-bottom:1rem;border:1px solid transparent}.vote-tracker--warning{color:#ff8c00;border-color:#ff8c00;background:#ff8c0014}.vote-tracker-warning-text{font-size:.78rem;font-style:italic}.vote-btn-group{display:flex;gap:.75rem;margin-bottom:1rem}.vote-btn{flex:1;font-size:1.1rem;font-weight:700;letter-spacing:.05em;margin-bottom:0}.vote-btn--ja{background:#2a7a2a;color:#fff}.vote-btn--ja:hover:not(:disabled){background:#393}.vote-btn--nein{background:#7a2a2a;color:#fff}.vote-btn--nein:hover:not(:disabled){background:#933}.vote-cast-status{text-align:center;margin-bottom:1rem}.vote-cast-message{color:#4a9eff;font-size:.95rem;margin-bottom:.25rem}.vote-waiting{font-size:.85rem;color:#888}.vote-status-list{list-style:none;display:flex;flex-direction:column;gap:.3rem;margin-top:.5rem}.vote-status-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;border-radius:6px;font-size:.88rem;background:#0f3460}.vote-status-name{color:#e0e0e0}.vote-status-row--voted .vote-status-indicator{color:#4a9eff;font-size:.8rem}.vote-status-row--pending .vote-status-indicator{color:#555;font-size:.8rem}.vote-result-banner{font-size:1.8rem;font-weight:700;text-align:center;padding:.75rem;border-radius:8px;margin-bottom:.75rem}.vote-result-banner--passed{background:#2a7a2a26;color:#4caf50;border:1px solid #4caf50}.vote-result-banner--failed{background:#e945601a;color:#e94560;border:1px solid #e94560}.vote-tally{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem;font-size:1rem;font-weight:600}.vote-tally-ja{color:#4caf50}.vote-tally-nein{color:#e94560}.vote-reveal-list{list-style:none;display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.vote-reveal-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;border-radius:6px;font-size:.9rem;border-left:3px solid transparent}.vote-reveal-row--ja{background:#2a7a2a1a;border-left-color:#4caf50}.vote-reveal-row--nein{background:#e9456014;border-left-color:#e94560}.vote-reveal-name{color:#e0e0e0}.vote-reveal-row--ja .vote-reveal-value{color:#4caf50;font-weight:700}.vote-reveal-row--nein .vote-reveal-value{color:#e94560;font-weight:700}.vote-continuing{text-align:center;font-size:.8rem;color:#555;font-style:italic}.leg-policy-board{display:flex;justify-content:center;gap:1.5rem;margin-bottom:.75rem}.leg-counter{display:flex;flex-direction:column;align-items:center;gap:.3rem}.leg-counter-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.leg-counter--liberal .leg-counter-label{color:#4a9eff}.leg-counter--fascist .leg-counter-label{color:#e94560}.leg-pips{display:flex;gap:.25rem}.leg-pip{width:.9rem;height:1.2rem;border-radius:3px;border:1px solid transparent}.leg-pip--liberal{border-color:#4a9eff;background:transparent}.leg-pip--liberal.leg-pip--filled{background:#4a9eff}.leg-pip--fascist{border-color:#e94560;background:transparent}.leg-pip--fascist.leg-pip--filled{background:#e94560}.leg-counter-tally{font-size:.72rem;color:#666}.leg-status{text-align:center;font-size:.9rem;color:#aaa;margin-bottom:.75rem}.leg-instruction{text-align:center;font-size:.9rem;color:#c8c8c8;margin-bottom:.75rem}.leg-cards{display:flex;gap:.75rem;justify-content:center;margin-bottom:.75rem}.leg-card{flex:1;max-width:130px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:.65rem;padding:1rem .75rem;border-radius:8px;border:2px solid transparent;min-height:90px}.leg-card--liberal{background:#4a9eff1a;border-color:#4a9eff}.leg-card--fascist{background:#e945601a;border-color:#e94560}.leg-card--facedown{background:#0b2a50;border-color:#1a4a80}.leg-card-type{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.leg-card--liberal .leg-card-type{color:#4a9eff}.leg-card--fascist .leg-card-type{color:#e94560}.leg-card-back{font-size:1.6rem;font-weight:700;color:#2a4a6a}.leg-card-btn{width:100%}.leg-card-btn--liberal{background:#4a9eff;color:#fff}.leg-card-btn--liberal:hover{background:#3a8eef}.leg-card-btn--fascist{background:#e94560;color:#fff}.leg-card-btn--fascist:hover{background:#d93550}.vote-tracker--danger{color:#e94560;border-color:#e94560;background:#e9456014}.leg-veto-section{display:flex;flex-direction:column;gap:.6rem;background:#ff8c000f;border:1px solid #ff8c00;border-radius:8px;padding:1rem;margin-bottom:.5rem}.leg-veto-title{font-size:1rem;font-weight:700;color:#ff8c00;text-align:center}.leg-veto-hint{font-size:.83rem;color:#aaa;line-height:1.45;text-align:center}.leg-veto-actions{display:flex;gap:.5rem}.leg-veto-actions .btn{flex:1;margin-bottom:0}.leg-veto-btn{margin-top:.25rem;border:1px solid #555;color:#888;font-size:.85rem}.leg-veto-btn:hover{border-color:#ff8c00;color:#ff8c00}.leg-enacted-card{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.leg-enacted-banner{font-size:1.8rem;font-weight:700;padding:1.5rem 2rem;border-radius:10px;width:100%}.leg-enacted-banner--liberal{background:#4a9eff1f;color:#4a9eff;border:2px solid #4a9eff}.leg-enacted-banner--fascist{background:#e945601a;color:#e94560;border:2px solid #e94560}.leg-enacted-continuing{font-size:.8rem;color:#555;font-style:italic}.exec-header{display:flex;align-items:center;justify-content:space-between;background:#0f3460;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;gap:.75rem}.exec-header-president{display:flex;flex-direction:column;gap:.15rem}.exec-role-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#888}.exec-role-name{font-size:1.1rem;font-weight:700;color:#e0e0e0}.exec-power-badge{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ff8c00;background:#ff8c001a;border:1px solid #ff8c00;border-radius:6px;padding:.3rem .6rem;white-space:nowrap}.exec-status{text-align:center;font-size:.9rem;color:#aaa;margin-bottom:1rem}.exec-instruction{text-align:center;font-size:.9rem;color:#c8c8c8;margin-bottom:.75rem}.exec-player-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem}.exec-player-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;border-radius:8px;background:#0f3460;gap:.5rem}.exec-player-row--ineligible{opacity:.45}.exec-player-name{font-size:.95rem;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.exec-player-reason{font-size:.78rem;color:#666;font-style:italic;flex-shrink:0}.exec-peek-cards{margin-bottom:1rem}.exec-investigate-result{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 0}.exec-result-target{font-size:1.3rem;font-weight:700;color:#e0e0e0}.exec-result-heading{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:#888}.exec-result-party{font-size:1.6rem;font-weight:700}.exec-result-party--liberal{color:#4a9eff}.exec-result-party--fascist{color:#e94560}.exec-result-hint{font-size:.82rem;color:#666;font-style:italic}.exec-confirm-dialog{display:flex;flex-direction:column;gap:.6rem;background:#e945600f;border:1px solid #e94560;border-radius:8px;padding:1.25rem}.exec-confirm-message{font-size:.9rem;color:#c8c8c8;line-height:1.5;text-align:center}.phase-stub{color:#888;font-size:1.1rem;text-transform:uppercase;letter-spacing:.15em;text-align:center;padding:3rem 1rem}.disconnection-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.disconnection-box{background:#16213e;border:1px solid #e94560;border-radius:12px;padding:2rem;max-width:360px;width:100%;text-align:center;display:flex;flex-direction:column;gap:.6rem}.disconnection-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:#e94560}.disconnection-username{font-size:1.4rem;font-weight:700;color:#e0e0e0}.disconnection-message{font-size:.9rem;color:#aaa}.disconnection-new-host{font-size:.82rem;color:#4a9eff;margin-top:.25rem;font-style:italic}.disconnection-countdown{font-size:.85rem;color:#e94560;margin-top:.25rem}.btn-danger{background:transparent;border:1px solid #e94560;color:#e94560}.btn-danger:hover:not(:disabled){background:#e945601f}.abandoned-notice{background:#e9456014;border:1px solid #e94560;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.abandoned-notice-message{font-size:.88rem;color:#e94560;margin-bottom:.3rem}.abandoned-notice-hint{font-size:.8rem;color:#aaa}.game-over-card{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.game-over-title{font-size:1.1rem;text-transform:uppercase;letter-spacing:.12em;color:#888;margin-bottom:0}.game-over-winner{font-size:2rem;font-weight:700}.game-over-winner--liberal{color:#4a9eff}.game-over-winner--fascist{color:#e94560}.game-over-reason{font-size:.95rem;color:#c8c8c8;line-height:1.5}.game-over-roles{width:100%;text-align:left}.game-over-roles-heading{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:#888;margin-bottom:.6rem;text-align:center}.game-over-role-list{list-style:none;display:flex;flex-direction:column;gap:.35rem}.game-over-role-item{display:flex;justify-content:space-between;align-items:center;padding:.45rem .75rem;border-radius:6px;font-size:.9rem;background:#0f3460;border-left:3px solid transparent}.game-over-role-item--liberal{border-left-color:#4a9eff}.game-over-role-item--fascist{border-left-color:#e94560}.game-over-role-item--hitler{border-left-color:#ff8c00}.game-over-player-name{color:#e0e0e0}.game-over-role-name{font-weight:600;font-size:.85rem}.game-over-role-item--liberal .game-over-role-name{color:#4a9eff}.game-over-role-item--fascist .game-over-role-name{color:#e94560}.game-over-role-item--hitler .game-over-role-name{color:#ff8c00}.game-over-waiting{font-size:.88rem;color:#888;font-style:italic}.game-ended-card{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.game-ended-title{font-size:1.1rem;text-transform:uppercase;letter-spacing:.12em;color:#888;margin-bottom:0}.game-ended-winner{font-size:2rem;font-weight:700}.game-ended-winner--liberal{color:#4a9eff}.game-ended-winner--fascist{color:#e94560}.game-ended-reason{font-size:.95rem;color:#c8c8c8;line-height:1.5}.btn-rejoin{background:transparent;border:1px solid #ff8c00;color:#ff8c00;font-size:.9rem}.btn-rejoin:hover:not(:disabled){background:#ff8c001a}.rejoin-notice{background:#ff8c0014;border:1px solid #ff8c00;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.rejoin-notice-message{font-size:.88rem;color:#ff8c00;margin-bottom:.3rem}.rejoin-notice-hint{font-size:.8rem;color:#aaa}.btn-instructions{background:transparent;border:1px solid #0f3460;color:#aaa;font-size:.9rem}.btn-instructions:hover{border-color:#e94560;color:#e0e0e0}.btn-instructions-corner{position:fixed;top:.75rem;right:.75rem;padding:.35rem .75rem;background:#16213e;border:1px solid #0f3460;border-radius:6px;color:#aaa;font-size:.8rem;cursor:pointer;z-index:50;transition:border-color .15s,color .15s}.btn-instructions-corner:hover{border-color:#e94560;color:#e0e0e0}.attribution-footer{position:fixed;bottom:0;left:0;right:0;text-align:center;font-size:.65rem;color:#555;padding:.3rem 1rem;pointer-events:none;line-height:1.4}.attribution-footer a{color:inherit;text-decoration:underline;pointer-events:auto}.attribution-footer a:hover{color:#888}.game-header{position:fixed;top:.6rem;left:.75rem;display:flex;align-items:center;gap:.5rem;z-index:50}.game-header-username{font-size:.8rem;color:#888;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-header-btn{padding:.3rem .65rem;background:#16213e;border:1px solid #0f3460;border-radius:6px;color:#aaa;font-size:.78rem;cursor:pointer;transition:border-color .15s,color .15s;line-height:1}.game-header-btn:hover{border-color:#e94560;color:#e0e0e0}.game-header-btn--danger{border-color:#4a2020;color:#966}.game-header-btn--danger:hover{border-color:#e94560;color:#e94560}.gh-role-modal{max-width:380px}.gh-role-banner{margin-bottom:1rem}.gh-role-banner h2{font-size:1.2rem;margin-bottom:0}.gh-role-objective{font-size:.9rem;line-height:1.55;color:#c8c8c8}.gh-confirm-modal{max-width:360px}.gh-confirm-warning{font-size:.9rem;color:#c8c8c8;line-height:1.5;margin-bottom:1.25rem}.gh-confirm-actions{display:flex;flex-direction:column;gap:.5rem}
