:root{--bg:#0a0a0f;--bg-card:#14141f;--bg-elevated:#1c1c2e;--border:#2a2a40;--text:#e0dcdc;--text-dim:#888;--primary:#8b0000;--primary-hover:#a00;--accent:#c9a84c;--danger:#dc3545;--success:#2ecc71;--warning:#e67e22;--info:#3498db}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}#root{min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex}.btn{cursor:pointer;border:none;border-radius:4px;padding:6px 16px;font-size:12px;font-weight:600;line-height:1.3;transition:all .2s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#d35400}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-text{color:var(--text-dim);background:0 0;text-decoration:underline}.btn-text:hover{color:var(--text)}.btn-large{padding:8px 20px;font-size:13px}.landing{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.landing-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:10px;width:100%;max-width:380px;padding:32px 28px}.title{color:var(--accent);margin-bottom:4px;font-size:28px}.subtitle{color:var(--text-dim);margin-bottom:20px;font-size:13px}.name-input,.code-input{text-align:left;margin-bottom:12px}.name-input label,.code-input label{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:11px;display:block}.name-input input,.code-input input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:4px;padding:8px 12px;font-size:14px}.name-input input:focus,.code-input input:focus{border-color:var(--accent);outline:none}.mode-buttons{gap:8px;display:flex}.mode-buttons .btn{flex:1}.lobby{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.lobby-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;width:100%;max-width:460px;padding:20px}.lobby-card h2{text-align:center;color:var(--accent);margin-bottom:10px;font-size:18px}.room-code-display{text-align:center;color:var(--text-dim);margin-bottom:12px;font-size:12px}.room-code-display .code{color:var(--accent);letter-spacing:4px;font-family:monospace;font-size:22px;font-weight:700}.invite-section{text-align:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;margin-bottom:12px;padding:12px}.invite-section h3{color:var(--accent);margin-bottom:8px;font-size:13px}.invite-qr{background:#fff;border-radius:6px;margin-bottom:8px;padding:8px;display:inline-block}.invite-link input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);cursor:text;border-radius:4px;margin-bottom:6px;padding:6px 10px;font-family:monospace;font-size:11px}.invite-link input:focus{border-color:var(--accent);outline:none}.btn-small{padding:4px 10px;font-size:11px}.player-list h3{color:var(--text-dim);margin-bottom:8px;font-size:12px}.player-list ul{flex-direction:column;gap:4px;margin-bottom:12px;list-style:none;display:flex}.player-item{background:var(--bg-elevated);border-radius:4px;align-items:center;gap:8px;padding:6px 10px;font-size:13px;display:flex}.player-item.disconnected{opacity:.5}.host-badge{background:var(--accent);color:var(--bg);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.dc-badge{background:var(--danger);color:#fff;border-radius:4px;padding:2px 8px;font-size:11px}.lobby-info{text-align:center}.hint{color:var(--text-dim);font-style:italic}.game-board{flex-direction:column;flex:1;min-height:100dvh;display:flex}.game-layout{flex:1;gap:12px;padding:8px 12px;display:flex}.game-main{flex:1}.game-sidebar{flex-shrink:0;width:240px}.phase-banner{text-align:center;text-transform:uppercase;letter-spacing:2px;padding:6px 16px;font-size:13px;font-weight:700;line-height:1.3}.phase-role_assignment{background:var(--info);color:#fff}.phase-killer_selection{background:var(--danger);color:#fff}.phase-clue_reveal{background:var(--bg-elevated);color:var(--accent);border-bottom:1px solid var(--border)}.phase-discussion{background:var(--warning);color:#fff}.phase-voting{background:var(--danger);color:#fff}.phase-witness_hunt{background:var(--warning);color:#fff}.phase-devil_wins{background:var(--danger);color:#fff;font-size:18px}.phase-angel_wins{background:var(--success);color:#fff;font-size:18px}.role-badge{text-align:center;letter-spacing:2px;text-transform:uppercase;padding:2px 0;font-size:10px;font-weight:700;line-height:1.2}.role-badge.role-killer{color:var(--danger);background:#dc354533}.role-badge.role-assistant{color:var(--warning);background:#e67e2233}.role-badge.role-witness{color:var(--success);background:#2ecc7133}.role-badge.role-investigator{color:var(--info);background:#3498db33}.role-overlay{z-index:100;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.role-card{background:var(--bg-card);text-align:center;border:2px solid;border-radius:12px;width:90%;max-width:400px;padding:24px}.role-card h2{margin-bottom:8px;font-size:18px}.role-card p{color:var(--text-dim);margin-bottom:12px;font-size:13px;line-height:1.4}.hand-preview{text-align:left;margin-bottom:12px}.hand-section{margin-bottom:6px}.hand-section h4{color:var(--text-dim);margin-bottom:3px;font-size:11px}.hand-items{flex-wrap:wrap;gap:3px;display:flex}.hand-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:3px;padding:2px 6px;font-size:10px}.hand-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;margin-bottom:8px;padding:8px}.hand-panel-title{color:var(--accent);text-align:center;margin-bottom:6px;font-size:11px}.hand-player-section{border:1px solid var(--border);background:var(--bg-elevated);border-radius:4px;margin-bottom:6px;padding:6px}.hand-player-section:last-child{margin-bottom:0}.hand-player-section.hand-player-killer{border-color:var(--danger);background:#dc354514}.hand-player-name{color:var(--text);align-items:center;gap:4px;margin-bottom:4px;font-size:11px;display:flex}.hand-player-name.killer-label{color:var(--danger)}.killer-badge{background:var(--danger);color:#fff;text-transform:uppercase;border-radius:2px;padding:1px 4px;font-size:8px;font-weight:700}.hand-players-items .hand-section{margin-bottom:3px}.hand-players-items .hand-section:last-child{margin-bottom:0}.hand-type-label{color:var(--text-dim);margin-bottom:2px;font-size:9px;display:block}.hand-item.killer-card{border-color:var(--danger);color:var(--danger);background:#dc35451a}.killer-select{text-align:center}.killer-select h2{color:var(--accent);margin-bottom:12px;font-size:16px}.selection-panels{gap:12px;margin-bottom:12px;display:flex}.selection-panel{flex:1}.selection-panel h3{color:var(--accent);margin-bottom:6px;font-size:13px}.selection-grid{flex-direction:column;gap:4px;display:flex}.selection-card{background:var(--bg-elevated);border:2px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;padding:8px 12px;font-size:12px;transition:all .2s}.selection-card:hover{border-color:var(--accent)}.selection-card.selected{border-color:var(--danger);background:#8b000033}.selection-summary{margin-bottom:10px;font-size:13px}.selection-summary p{margin-bottom:2px}.clue-board h2{color:var(--accent);margin-bottom:8px;font-size:16px}.clue-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;display:grid}.clue-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:8px;transition:all .3s}.clue-card.revealed{border-color:var(--accent);box-shadow:0 0 8px #c9a84c1f}.clue-card.hidden{opacity:.7}.clue-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.clue-header h3{color:var(--accent);font-size:12px}.clue-timer-badge{background:var(--bg-elevated);color:var(--text-dim);border-radius:3px;padding:1px 6px;font-size:10px}.clue-options{flex-direction:column;gap:2px;display:flex}.clue-option{border-radius:3px;justify-content:space-between;align-items:center;padding:3px 8px;font-size:11px;transition:all .3s;display:flex}.clue-option.correct{border:1px solid var(--success);color:var(--success);background:#2ecc7126;font-weight:600}.clue-option.dimmed{opacity:.4}.check-mark{font-size:14px}.waiting-screen{text-align:center;padding:40px 20px}.waiting-screen p{color:var(--text-dim);font-size:15px}.discussion-area{text-align:center;padding:12px}.discussion-area p{margin-bottom:12px;font-size:13px}.guess-form{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;max-width:420px;margin-bottom:10px;padding:12px}.guess-form h2{color:var(--accent);margin-bottom:10px;font-size:15px}.guess-fields{flex-direction:column;gap:8px;margin-bottom:10px;display:flex}.guess-field label{color:var(--text-dim);margin-bottom:2px;font-size:11px;display:block}.guess-field select{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:4px;padding:6px 10px;font-size:12px}.guess-field select:focus{border-color:var(--accent);outline:none}.guess-results{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;max-width:600px;padding:12px}.guess-results h3{color:var(--accent);margin-bottom:8px;font-size:14px}.results-list{flex-direction:column;gap:4px;display:flex}.result-item{border-radius:4px;flex-wrap:wrap;align-items:center;gap:8px;padding:6px 10px;font-size:11px;display:flex}.result-item.correct{border:1px solid var(--success);background:#2ecc711a}.result-item.wrong{border:1px solid var(--danger);background:#dc35451a}.result-badge{border-radius:3px;padding:1px 6px;font-size:10px;font-weight:700}.result-badge.correct{background:var(--success);color:#fff}.result-badge.wrong{background:var(--danger);color:#fff}.witness-hunt{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;max-width:420px;margin:0;padding:16px}.witness-hunt h2{color:var(--danger);margin-bottom:8px;font-size:15px}.witness-hunt .hint{margin-bottom:12px;font-size:12px}.witness-hunt .guess-field{margin-bottom:12px}.voice-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:8px}.voice-btn{text-align:center;width:100%;padding:6px;font-size:11px}.voice-btn.muted{background:var(--danger)}.voice-btn.active{background:var(--success)}.game-over{text-align:center;padding:24px 16px}.game-over h2{margin-bottom:12px;font-size:24px}.reveal-info{margin-top:12px}.reveal-info p{margin-bottom:4px;font-size:13px}.error-toast{background:var(--danger);color:#fff;z-index:200;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;position:fixed;top:12px;left:50%;transform:translate(-50%)}@media (width<=768px){.game-board{min-height:100dvh}.game-layout{gap:8px;padding:6px 8px}.landing-card{padding:24px 16px}.lobby-card{padding:16px 12px}.title{font-size:24px}.mode-buttons{flex-direction:column;gap:6px}.room-code-display .code{font-size:18px}.invite-qr svg{width:120px!important;height:120px!important}.invite-section .btn-secondary{width:100%}.game-layout{flex-direction:column}.game-sidebar{width:100%}.game-layout-mobile{flex:1;padding-bottom:0}.clue-grid{grid-template-columns:1fr}.selection-panels{flex-direction:column;gap:8px}.role-card{padding:16px 12px}.guess-form,.guess-results,.witness-hunt{max-width:100%;padding:10px}.result-item{flex-direction:column;align-items:flex-start;gap:4px}.game-over{padding:20px 12px}.game-over h2{font-size:20px}.modal-content{padding:16px 12px}.discussion-area{padding:10px 8px}.waiting-screen{padding:20px 12px}.waiting-screen p{font-size:14px}.btn{min-height:44px;padding:12px 20px;font-size:14px}.btn-large{width:100%;min-height:48px;padding:14px 24px;font-size:15px}.btn-small{min-height:44px;padding:10px 14px;font-size:12px}.name-input input,.code-input input,.guess-field select,.investigation-field select{min-height:44px;padding:12px 14px;font-size:16px}.selection-card{min-height:48px;padding:12px 16px;font-size:14px}.clue-option{min-height:36px;padding:8px 12px;font-size:13px}.hand-item{min-height:44px;padding:6px 10px;font-size:12px}.phase-banner{padding:4px 12px;font-size:12px}.game-tab-bar{background:var(--bg-card);border-top:1px solid var(--border);z-index:50;height:52px;display:flex;position:fixed;bottom:0;left:0;right:0}.game-tab-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:44px;padding:4px;font-size:11px;font-weight:600;transition:color .2s;display:flex}.game-tab-btn.active{color:var(--accent);border-top:2px solid var(--accent)}.game-tab-btn .tab-icon{font-size:18px;line-height:1}.game-board{padding-bottom:52px}.game-sidebar{display:none}.tab-content{padding:8px 12px}.tab-content-full{flex:1;padding:8px 12px;overflow-y:auto}.game-action-bar{background:var(--bg-card);border-top:1px solid var(--border);z-index:49;gap:8px;padding:8px 12px;display:flex;position:sticky;bottom:52px}.game-action-bar .btn{flex:1}.clue-carousel{margin:0 -12px}.clue-carousel-track{scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:12px;padding:8px 16px;display:flex;overflow-x:auto}.clue-carousel-track::-webkit-scrollbar{display:none}.clue-carousel-track>*{scroll-snap-align:center;flex:0 0 85vw}.clue-carousel-dots{justify-content:center;gap:6px;padding:6px 0;display:flex}.clue-carousel-dot{background:var(--border);cursor:pointer;border:none;border-radius:50%;width:8px;height:8px;padding:0}.clue-carousel-dot.active{background:var(--accent)}.clue-carousel-track .clue-card{width:100%}.hand-accordion-header{background:var(--bg-elevated);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;border-radius:6px;align-items:center;gap:8px;min-height:44px;padding:10px 12px;font-size:13px;font-weight:600;transition:border-color .2s;display:flex}.hand-accordion-header:hover{border-color:var(--accent)}.hand-accordion-header .hand-count{color:var(--text-dim);margin-left:auto;font-size:11px;font-weight:400}.hand-accordion-chevron{font-size:10px;transition:transform .2s}.hand-accordion-chevron.expanded{transform:rotate(90deg)}.hand-accordion-body{max-height:0;transition:max-height .3s;overflow:hidden}.hand-accordion-body.expanded{max-height:600px}.hand-accordion-body-inner{padding:8px 12px}.voice-float-btn{cursor:pointer;z-index:45;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;transition:all .2s;display:flex;position:fixed;bottom:120px;right:16px;box-shadow:0 2px 8px #0006}.voice-float-btn.muted{background:var(--danger);color:#fff}.voice-float-btn.active{background:var(--success);color:#fff}.voice-float-btn .peer-badge{background:var(--accent);color:var(--bg);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.lobby-card .btn-large{margin-top:8px}.player-item{min-height:44px;padding:10px 12px}.lobby-info{padding:8px 0 0;position:sticky;bottom:0}}.investigation-report{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;margin-top:8px;padding:8px}.investigation-toggle{width:100%;padding:4px 8px;font-size:10px}.investigation-form{flex-direction:column;gap:4px;margin-top:6px;display:flex}.investigation-field label{color:var(--text-dim);margin-bottom:2px;font-size:9px;display:block}.investigation-field select{border:1px solid var(--border);background:var(--bg-color);width:100%;color:var(--text-color);border-radius:3px;padding:4px 6px;font-size:10px}.investigation-list{margin-top:6px}.investigation-list h5{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:9px}.investigation-entry{padding:2px 0;font-size:10px;line-height:1.4}.investigation-author{color:var(--accent);font-weight:600}.investigation-target{color:var(--danger);font-weight:600}.investigation-item{color:var(--warning);font-weight:600}.investigation-verdict{text-align:center;width:14px;font-size:11px;font-weight:700;display:inline-block}.verdict-correct{color:var(--success)}.verdict-wrong{color:var(--danger)}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:10px;width:90%;max-width:380px;padding:20px}.modal-content h2{color:var(--danger);margin:0 0 8px;font-size:18px}.caught-detail{margin-bottom:10px;font-size:12px}.caught-reveal{background:var(--bg-elevated);text-align:left;border-radius:6px;margin-bottom:12px;padding:10px}.caught-reveal p{margin:4px 0;font-size:11px}.caught-label{width:60px;color:var(--text-dim);font-weight:600;display:inline-block}
