*{box-sizing:border-box}html,body{overflow-x:hidden;max-width:100vw}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn{display:inline-block;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.btn-warning{background:linear-gradient(135deg,#f57c00,#e65100);color:#fff}.btn-warning:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #f57c0066}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.home-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px}.home-content{max-width:600px;width:100%;text-align:center}.game-title{font-size:3.5rem;margin:0;background:linear-gradient(135deg,#c62828,#1565c0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.game-subtitle{color:#aaa;font-size:1.1rem;margin-bottom:32px}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:16px}.game-options{display:flex;flex-direction:column;gap:16px}.option-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 12px #0003}.option-card h2{margin:0 0 16px;color:#333;font-size:1.25rem}.language-select{display:flex;align-items:center;gap:12px;margin-bottom:16px;justify-content:center}.language-select label{color:#666}.language-select select{padding:8px 12px;border:2px solid #ddd;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer}.difficulty-select{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:16px}.difficulty-select label{color:#666}.difficulty-select select{padding:8px 12px;border:2px solid #ddd;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;min-width:140px}.difficulty-hint{font-size:.75rem;color:#999;font-style:italic}.game-code-input{width:100%;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:1.25rem;text-align:center;text-transform:uppercase;letter-spacing:2px;margin-bottom:16px;box-sizing:border-box}.game-code-input:focus{border-color:#1976d2;outline:none}.btn{width:100%;padding:14px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#c62828,#ad1457);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #c6282866}.btn-secondary{background:linear-gradient(135deg,#1565c0,#0d47a1);color:#fff}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1565c066}.btn:disabled{opacity:.5;cursor:not-allowed}.divider{color:#666;font-weight:600;position:relative}.rules-summary{margin-top:32px;background:#ffffff1a;padding:24px;border-radius:16px;text-align:left}.rules-summary h3{margin:0 0 16px;color:#fff}.rules-summary ul{margin:0;padding-left:20px;color:#ccc}.rules-summary li{margin-bottom:8px}.debug-mode-toggle{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:16px}.debug-mode-toggle label{display:flex;align-items:center;gap:8px;color:#666;cursor:pointer;font-weight:500}.debug-mode-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#9c27b0;cursor:pointer}.debug-hint{font-size:.75rem;color:#999;font-style:italic}.card{width:100%;aspect-ratio:1.5;border:2px solid #333;border-radius:8px;background:#f5f0e1;color:#1a1a1a;cursor:pointer;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:4px;box-shadow:0 2px 4px #0000001a;text-shadow:0 1px 0 rgba(255,255,255,.5);position:relative}.card:hover:not(.disabled):not(.revealed){transform:translateY(-2px);box-shadow:0 4px 8px #0003}.card.disabled{cursor:not-allowed}.card.disabled:not(.revealed){filter:grayscale(30%)}.card.disabled.revealed{filter:brightness(.85) saturate(.7)}.card.revealed{cursor:default}.card.card-red:not(.revealed){background:linear-gradient(135deg,#ffcdd2,#ef9a9a);border-color:#c62828;color:#991b1b;text-shadow:none}.card.card-blue:not(.revealed){background:linear-gradient(135deg,#bbdefb,#90caf9);border-color:#1565c0;color:#1e40af;text-shadow:none}.card.card-neutral:not(.revealed){background:linear-gradient(135deg,#fff9c4,#fff59d);border-color:#f9a825;color:#713f12;text-shadow:none}.card.card-assassin:not(.revealed){background:linear-gradient(135deg,#424242,#212121);border-color:#000;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8)}.card.card-red.revealed{background:#c62828;color:#fff;border-color:#b71c1c;text-shadow:0 1px 2px rgba(0,0,0,.4)}.card.card-blue.revealed{background:#1565c0;color:#fff;border-color:#0d47a1;text-shadow:0 1px 2px rgba(0,0,0,.4)}.card.card-neutral.revealed{background:#ffc107;color:#1a1a1a;border-color:#ff8f00;text-shadow:0 1px 0 rgba(255,255,255,.4)}.card.card-assassin.revealed{background:#000;color:#fff;border-color:#000;text-shadow:none}.card-word{text-align:center;word-break:break-word;line-height:1.2;unicode-bidi:plaintext}.card.my-preguess{box-shadow:0 0 0 3px #4caf50,0 2px 4px #0000001a}.card.my-preguess:not(.disabled):not(.revealed):hover{box-shadow:0 0 0 3px #4caf50,0 4px 8px #0003}.card.has-votes:not(.my-preguess){box-shadow:0 0 0 2px #ff9800,0 2px 4px #0000001a}.card.ai-suggested:not(.has-votes):not(.my-preguess){box-shadow:0 0 0 2px #9c27b0,0 2px 4px #0000001a}.preguess-voters{position:absolute;bottom:4px;left:4px;display:flex;gap:2px}.voter-badge{width:20px;height:20px;border-radius:50%;background:#4caf50;color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 1px 2px #0003}.ai-suggest-badge{position:absolute;top:4px;right:4px;background:#9c27b0;color:#fff;font-size:.6rem;font-weight:700;padding:2px 4px;border-radius:3px;box-shadow:0 1px 2px #0003}.card.has-consensus{box-shadow:0 0 0 3px #4caf50,0 0 12px #4caf5080;animation:consensus-pulse .5s ease-in-out infinite alternate}@keyframes consensus-pulse{0%{box-shadow:0 0 0 3px #4caf50,0 0 8px #4caf5066}to{box-shadow:0 0 0 4px #4caf50,0 0 16px #4caf5099}}.consensus-countdown-circle{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:conic-gradient(transparent 0deg,transparent calc(var(--progress) * 3.6deg),#4caf50 calc(var(--progress) * 3.6deg),#4caf50 360deg);box-shadow:0 2px 4px #0000004d;animation:countdown-pulse .5s ease-in-out infinite alternate}.consensus-countdown-circle:after{content:"";position:absolute;top:4px;left:4px;width:16px;height:16px;border-radius:50%;background:#fff}@keyframes countdown-pulse{0%{box-shadow:0 2px 4px #0000004d}to{box-shadow:0 2px 8px #4caf5099}}.card.sending{opacity:.7;cursor:wait}.sending-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;border:3px solid rgba(0,0,0,.1);border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite;z-index:10}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.board{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:800px;width:100%;margin:0 auto;padding:16px;background:#2c2c2c;border-radius:12px;box-shadow:0 4px 12px #0000004d}@media(max-width:600px){.board{gap:4px;padding:8px}.card{font-size:.7rem}}.team-panel{background:#fff;border-radius:12px;padding:12px;min-width:0;box-shadow:0 2px 8px #0000001a;border:3px solid transparent}@media(min-width:480px){.team-panel{padding:16px;min-width:180px}}.team-panel.active{border-color:currentColor;box-shadow:0 0 20px #0003}.team-panel.team-red{color:#c62828}.team-panel.team-blue{color:#1565c0}.team-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid currentColor}.team-header h3{margin:0;font-size:1.25rem}.cards-remaining{font-size:1.5rem;font-weight:700;background:currentColor;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.team-section{margin-bottom:12px}.team-section h4{margin:0 0 8px;font-size:.85rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.player{padding:6px 10px;background:#f5f5f5;border-radius:6px;margin-bottom:4px;font-size:.9rem;display:flex;align-items:center;gap:4px}.team-red .player.current{background:#c62828;color:#fff}.team-blue .player.current{background:#1565c0;color:#fff}.player .disconnected{font-size:.75rem;opacity:.7;margin-left:4px}.empty{color:#999;font-style:italic;font-size:.9rem}.join-btn{width:100%;padding:8px 12px;border:2px dashed currentColor;background:transparent;color:currentColor;border-radius:6px;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s}.team-red .join-btn:hover{background:#c62828;border-color:#c62828;color:#fff}.team-blue .join-btn:hover{background:#1565c0;border-color:#1565c0;color:#fff}.join-btn.small{padding:4px 8px;font-size:.75rem;margin-top:4px}.join-options{display:flex;flex-direction:column;gap:6px}.join-btn.ai-btn{border-style:solid;background:#9c27b0;color:#fff;border-color:#9c27b0}.join-btn.ai-btn:hover{background:#7b1fa2;border-color:#7b1fa2}.player.ai-player{background:#f3e5f5;border:1px solid #9c27b0}.team-red .player.ai-player.current,.team-blue .player.ai-player.current{background:#9c27b0}.ai-badge{display:inline-block;background:#9c27b0;color:#fff;font-size:.65rem;padding:1px 4px;border-radius:3px;margin-right:6px;font-weight:700}.player.thinking{animation:thinking-glow 1.5s ease-in-out infinite}@keyframes thinking-glow{0%,to{box-shadow:0 0 4px #9c27b066}50%{box-shadow:0 0 12px #9c27b0cc}}.thinking-indicator{display:inline-block;width:12px;height:12px;min-width:12px;min-height:12px;border:2px solid rgba(156,39,176,.3);border-top-color:#9c27b0;border-radius:50%;animation:spin 1s linear infinite;margin-left:8px;vertical-align:middle;flex-shrink:0;aspect-ratio:1}.remove-ai-btn{margin-left:auto;background:none;border:none;color:#999;font-size:1.1rem;line-height:1;cursor:pointer;padding:0 4px;border-radius:4px;transition:all .2s}.remove-ai-btn:hover{color:#c62828;background:#c628281a}.show-thoughts-btn{width:100%;padding:6px 10px;margin-top:4px;border:1px solid #9c27b0;background:transparent;color:#9c27b0;border-radius:6px;cursor:pointer;font-weight:600;font-size:.8rem;transition:all .2s}.show-thoughts-btn:hover{background:#9c27b0;color:#fff}.hint-input{background:#fff;padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:100%;box-sizing:border-box}.hint-fields{display:flex;gap:8px;flex-wrap:wrap}.hint-word{flex:1;min-width:120px;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:1rem;text-transform:uppercase;box-sizing:border-box}.hint-word:focus{border-color:#1976d2;outline:none}.hint-number-select{width:65px;padding:12px 24px 12px 8px;border:2px solid #ddd;border-radius:8px;font-size:1rem;text-align:center;background:#fff;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 6px center;background-size:14px;box-sizing:border-box;flex-shrink:0}.hint-number-select:focus{border-color:#1976d2;outline:none}.hint-number-select:disabled{background-color:#f5f5f5;cursor:not-allowed}.hint-submit{padding:12px 16px;background:#1976d2;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;box-sizing:border-box}.hint-submit:hover:not(:disabled){background:#1565c0}.hint-submit:disabled{background:#ccc;cursor:not-allowed}.hint-help{margin-top:8px;font-size:.8rem;color:#666}.game-status{text-align:center;padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.turn-indicator{font-size:1.25rem;font-weight:700;padding:8px 16px;border-radius:8px;display:inline-block;margin-bottom:12px}.turn-indicator.team-red{background:#ffcdd2;color:#c62828}.turn-indicator.team-blue{background:#bbdefb;color:#1565c0}.your-turn{color:#2e7d32;font-weight:600;font-size:1.1rem}.current-hint{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px;padding:12px;background:#f5f5f5;border-radius:8px}.current-hint .hint-word{font-size:1.5rem;font-weight:700;text-transform:uppercase;color:#333}.current-hint .hint-number{font-size:1.25rem;font-weight:700;background:#333;color:#fff;width:32px;height:32px;min-width:32px;max-width:32px;min-height:32px;max-height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex:0 0 32px;box-sizing:border-box;line-height:1}.current-hint .guesses-left{font-size:.9rem;color:#666}.game-over{padding:20px;border-radius:12px;margin:12px 0}.game-over.team-red{background:#ffcdd2;color:#c62828}.game-over.team-blue{background:#bbdefb;color:#1565c0}.game-over h2{margin:0 0 8px}.game-over p{margin:0;opacity:.8}.end-turn-btn{margin-top:12px;padding:10px 24px;background:#ff9800;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.end-turn-btn:hover{background:#f57c00}.end-turn-btn.voted{background:#4caf50}.end-turn-btn.voted:hover{background:#388e3c}.end-turn-voting{display:flex;flex-direction:column;gap:8px;margin-top:12px}.vote-status{display:flex;flex-direction:column;gap:4px;font-size:.85rem}.vote-count{font-weight:600;color:#666}.voters{font-size:.75rem;color:#999}.consensus-countdown{margin-top:8px;padding:8px;background:#fff3cd;border-radius:8px}.countdown-bar-container{height:4px;background:#ffc107;border-radius:2px;overflow:hidden;margin-bottom:4px}.countdown-bar{height:100%;background:#ff6f00;transition:width .05s linear}.countdown-text{font-size:.8rem;font-weight:600;color:#ff6f00}.score-progress{display:flex;gap:16px;margin-bottom:12px;padding:8px 12px;background:#f5f5f5;border-radius:8px}.score-team{flex:1;display:flex;align-items:center;gap:8px}.score-team .score-label{font-size:.75rem;font-weight:600;text-transform:uppercase;min-width:65px;flex-shrink:0}.score-team.team-red .score-label{color:#c62828}.score-team.team-blue .score-label{color:#1565c0}.score-bar-container{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.score-bar{height:100%;border-radius:4px;transition:width .3s ease}.score-team.team-red .score-bar{background:linear-gradient(90deg,#ef5350,#c62828)}.score-team.team-blue .score-bar{background:linear-gradient(90deg,#42a5f5,#1565c0)}.score-value{font-size:.85rem;font-weight:700;width:35px;text-align:right;flex-shrink:0}.score-team.team-red .score-value{color:#c62828}.score-team.team-blue .score-value{color:#1565c0}.hint-history{background:#fff;padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.hint-history h4{margin:0 0 12px;color:#333;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.hints-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.hint-item{display:flex;flex-direction:column;gap:6px;padding:8px 10px;border-radius:6px;font-size:.85rem}.hint-header{display:flex;align-items:center;gap:8px}.hint-item.team-red{background:#ffebee}.hint-item.team-blue{background:#e3f2fd}.hint-team{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:4px}.hint-item.team-red .hint-team{background:#c62828;color:#fff}.hint-item.team-blue .hint-team{background:#1565c0;color:#fff}.hint-item .hint-word{flex:1;font-weight:600;text-transform:uppercase}.hint-item .hint-number{font-weight:700;background:#333;color:#fff;width:24px;height:24px;min-width:24px;max-width:24px;min-height:24px;max-height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;flex:0 0 24px;box-sizing:border-box;line-height:1}.hint-guesses{display:flex;flex-wrap:wrap;gap:4px;margin-left:4px}.guess-card{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;border:1px solid transparent}.guess-card.red{background:#ffcdd2;color:#c62828;border-color:#ef9a9a}.guess-card.blue{background:#bbdefb;color:#1565c0;border-color:#90caf9}.guess-card.neutral{background:beige;color:#8d6e63;border-color:#d7ccc8}.guess-card.assassin{background:#424242;color:#fff;border-color:#212121}.guess-card.correct{box-shadow:0 0 0 1px #4caf50}.guess-card.wrong{box-shadow:0 0 0 1px #f44336}.debug-panel{position:fixed;bottom:8px;right:8px;left:8px;max-height:80vh;background:#1a1a2e;border:2px solid #9c27b0;border-radius:12px;box-shadow:0 4px 20px #9c27b04d;overflow:hidden;z-index:1000;display:flex;flex-direction:column}@media(min-width:480px){.debug-panel{left:auto;right:16px;bottom:16px;width:320px}}.debug-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none}.debug-header:hover{background:linear-gradient(135deg,#ab47bc,#8e24aa)}.debug-toggle{margin-left:auto;font-size:.8rem;opacity:.8}.debug-panel.collapsed{max-height:none}.debug-badge{background:#fff3;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:1px}.debug-title{font-weight:600;font-size:.95rem}.debug-board-summary{padding:12px;overflow-y:auto;flex:1;min-height:0}.card-type-group{margin-bottom:12px}.card-type-group:last-child{margin-bottom:0}.type-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.type-red .type-label{color:#ef5350}.type-blue .type-label{color:#42a5f5}.type-neutral .type-label{color:#bdbdbd}.type-assassin .type-label{color:#f44336;background:#2d2d2d;padding:2px 8px;border-radius:4px;display:inline-block}.word-list{display:flex;flex-wrap:wrap;gap:6px}.word{font-size:.8rem;padding:3px 8px;border-radius:4px;background:#ffffff1a;color:#ddd}.type-red .word{background:#ef535033;color:#ef5350}.type-blue .word{background:#42a5f533;color:#42a5f5}.type-neutral .word{background:#bdbdbd26;color:#9e9e9e}.type-assassin .word{background:#f443364d;color:#f44336;font-weight:600}.word.revealed{opacity:.4;text-decoration:line-through}.debug-ai-section{border-top:1px solid rgba(156,39,176,.3);padding:12px;background:#9c27b01a;max-height:200px;overflow-y:auto;flex-shrink:0}.ai-thinking-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#ddd;font-size:.85rem}.ai-badge{background:#9c27b0;color:#fff;font-size:.65rem;padding:2px 6px;border-radius:4px;font-weight:700}.ai-thinking-content{font-size:.8rem;color:#ccc}.ai-word{margin-bottom:6px}.ai-word strong{color:#ce93d8}.ai-reasoning{color:#aaa;font-style:italic;line-height:1.4}.connection-debug{position:fixed;bottom:10px;left:10px;background:#000000e6;border:1px solid #444;border-radius:8px;color:#fff;font-family:Monaco,Menlo,monospace;font-size:11px;z-index:10000;max-width:280px;box-shadow:0 4px 12px #00000080}.connection-debug.collapsed{max-width:120px}.connection-debug-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;cursor:pointer;background:#323232cc;border-radius:8px 8px 0 0;-webkit-user-select:none;user-select:none}.connection-debug.collapsed .connection-debug-header{border-radius:8px}.connection-debug-title{font-weight:700;color:#aaa}.connection-status-indicator{font-size:14px}.connection-status-indicator.connected{color:#4caf50}.connection-status-indicator.connecting{color:#ff9800;animation:pulse 1s infinite}.connection-status-indicator.disconnected{color:#f44336}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.connection-debug-content{padding:10px}.connection-state{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #333}.state-row{display:flex;justify-content:space-between;margin-bottom:4px}.state-label{color:#888}.state-value{font-weight:700}.state-value.yes{color:#4caf50}.state-value.no{color:#888}.state-value.error{color:#f44336;font-size:10px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-row{margin-top:6px;padding-top:6px;border-top:1px dashed #333}.connection-logs{max-height:150px;overflow-y:auto}.logs-header{color:#888;margin-bottom:6px;font-size:10px;text-transform:uppercase}.logs-list{display:flex;flex-direction:column;gap:2px}.log-entry{display:flex;gap:6px;padding:2px 4px;background:#ffffff0d;border-radius:3px;font-size:10px}.log-time{color:#666;min-width:75px}.log-event{font-weight:700;min-width:80px}.log-details{color:#aaa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-entry.connected .log-event,.log-entry.connect_end .log-event{color:#4caf50}.log-entry.connecting .log-event,.log-entry.attempt .log-event{color:#ff9800}.log-entry.disconnected .log-event,.log-entry.error .log-event{color:#f44336}.log-entry.reconnecting .log-event,.log-entry.reconnect_end .log-event{color:#2196f3}.log-entry.init .log-event{color:#9c27b0}.connection-overlay{position:fixed;inset:0;background:#000000d9;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.connection-overlay-content{background:#fff;padding:32px 48px;border-radius:16px;text-align:center;max-width:400px;box-shadow:0 4px 24px #0006;animation:overlay-appear .3s ease-out}@keyframes overlay-appear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.connection-status-icon{font-size:48px;margin-bottom:16px}.connection-icon-disconnected{color:#f57c00}.connection-spinner{display:inline-block;width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:overlay-spin 1s linear infinite}@keyframes overlay-spin{to{transform:rotate(360deg)}}.connection-overlay-content h2{margin:0 0 8px;color:#333;font-size:1.5rem}.connection-overlay-content p{color:#666;margin:0 0 24px;font-size:1rem}.connection-overlay-content .btn{padding:12px 32px;font-size:1rem}.connection-debug-info{background:#f5f5f5;border-radius:8px;padding:12px 16px;margin:16px 0;font-family:monospace;font-size:.85rem;text-align:left}.connection-debug-info .debug-row{display:flex;justify-content:space-between;padding:4px 0;color:#555}.connection-debug-info .debug-row span:first-child{color:#888}.connection-debug-info .debug-row span:last-child{font-weight:600;color:#333}.modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;max-width:600px;max-height:80vh;width:90%;box-shadow:0 4px 24px #0006;animation:modal-appear .3s ease-out;display:flex;flex-direction:column}@keyframes modal-appear{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.25rem;color:#333}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:4px 8px;line-height:1;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f0f0f0;color:#333}.modal-body{padding:24px;overflow-y:auto}.ai-thoughts-list{display:flex;flex-direction:column;gap:16px}.ai-thought-item{background:#f8f9fa;border-radius:12px;padding:16px;border-left:4px solid #9c27b0}.ai-thought-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ai-thought-hint{font-weight:700;font-size:1.1rem;color:#333}.ai-thought-number{background:#9c27b0;color:#fff;padding:2px 8px;border-radius:12px;font-size:.85rem;font-weight:600}.ai-thought-reasoning{color:#555;line-height:1.5;font-size:.95rem}.ai-thoughts-empty{text-align:center;color:#666;padding:24px}.chat-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1000;font-family:inherit}.chat-container.collapsed{width:auto;height:auto}.chat-fab{width:56px;height:56px;border-radius:50%;background:#1976d2;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;transition:all .2s ease;position:relative}.chat-fab:hover{background:#1565c0;transform:scale(1.05)}.chat-fab-icon{font-size:1.5rem}.chat-fab .unread-badge{position:absolute;top:-4px;right:-4px;background:#c62828;color:#fff;border-radius:10px;padding:.15rem .45rem;font-size:.7rem;font-weight:600;min-width:18px;text-align:center;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.chat-container.expanded{width:340px;height:420px;display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000040;overflow:hidden}.chat-header{display:flex;align-items:center;padding:.75rem 1rem;background:#1976d2;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none}.chat-header:hover{background:#1565c0}.chat-title{font-weight:600;flex:1}.chat-close{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:.25rem;line-height:1;opacity:.8}.chat-close:hover{opacity:1}.chat-messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;background:#fafafa}.chat-empty{color:#666;text-align:center;padding:2rem 1rem;font-style:italic}.chat-message{padding:.5rem .75rem;border-radius:8px;background:#fff;max-width:85%;box-shadow:0 1px 2px #0000001a}.chat-message.own{align-self:flex-end;background:#e3f2fd}.chat-message.red{border-left:3px solid #c62828}.chat-message.blue{border-left:3px solid #1565c0}.chat-message.own.red{border-left:none;border-right:3px solid #c62828}.chat-message.own.blue{border-left:none;border-right:3px solid #1565c0}.message-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:.75rem}.message-author{font-weight:600}.chat-message.red .message-author{color:#c62828}.chat-message.blue .message-author{color:#1565c0}.message-scope{font-size:.65rem;padding:.1rem .35rem;border-radius:4px;font-weight:500}.message-scope.team{background:#fff3e0;color:#e65100}.message-time{color:#999;font-size:.65rem;margin-left:auto}.message-content{word-wrap:break-word;line-height:1.4;font-size:.9rem}.chat-input-container{padding:.5rem .75rem .75rem;border-top:1px solid #e0e0e0;background:#fff}.scope-toggle{display:flex;gap:.5rem;margin-bottom:.5rem}.scope-btn{flex:1;padding:.35rem .5rem;border:1px solid #e0e0e0;background:#fff;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.scope-btn:hover:not(:disabled){background:#f5f5f5}.scope-btn.active{background:#1976d2;color:#fff;border-color:#1976d2}.scope-btn:disabled{opacity:.5;cursor:not-allowed}.input-row{display:flex;gap:.5rem}.input-row input{flex:1;padding:.5rem .75rem;border:1px solid #e0e0e0;border-radius:4px;font-size:.85rem}.input-row input:focus{outline:none;border-color:#1976d2}.input-row button{padding:.5rem .75rem;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;font-size:.85rem;transition:background .2s ease}.input-row button:hover:not(:disabled){background:#1565c0}.input-row button:disabled{opacity:.5;cursor:not-allowed}[dir=rtl] .chat-container{right:auto;left:1.5rem}[dir=rtl] .chat-message.red{border-left:none;border-right:3px solid #c62828}[dir=rtl] .chat-message.blue{border-left:none;border-right:3px solid #1565c0}[dir=rtl] .chat-message.own.red{border-right:none;border-left:3px solid #c62828}[dir=rtl] .chat-message.own.blue{border-right:none;border-left:3px solid #1565c0}[dir=rtl] .message-time{margin-left:0;margin-right:auto}@media(max-width:480px){.chat-container.expanded{width:calc(100vw - 2rem);height:60vh;bottom:1rem;right:1rem}[dir=rtl] .chat-container.expanded{right:auto;left:1rem}}.game-page{min-height:100vh;max-width:100vw;overflow-x:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;flex-direction:column}.game-page.join-page{display:flex;align-items:center;justify-content:center}.join-container{background:#fff;padding:32px;border-radius:16px;max-width:400px;width:100%;text-align:center;box-shadow:0 4px 20px #0000004d}.join-container h1{margin:0 0 8px;color:#333}.join-container .game-code{color:#666;margin-bottom:24px}.join-container .game-code strong{color:#1976d2;font-size:1.2em;letter-spacing:2px}.name-input{width:100%;padding:14px;border:2px solid #ddd;border-radius:8px;font-size:1rem;margin-bottom:16px;box-sizing:border-box}.name-input:focus{border-color:#1976d2;outline:none}.btn-link{background:none;border:none;color:#666;cursor:pointer;margin-top:16px;font-size:.9rem}.btn-link:hover{color:#333;text-decoration:underline}.game-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0000004d;color:#fff}@media(min-width:768px){.game-header{padding:12px 24px}}.game-header h1{margin:0;font-size:1.2rem;background:linear-gradient(135deg,#c62828,#1565c0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex-shrink:0}@media(min-width:480px){.game-header h1{font-size:1.5rem}}.header-info{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.game-code-badge{background:#fff3;padding:4px 8px;border-radius:6px;font-size:.75rem;letter-spacing:1px}.player-badge{background:#1976d2;padding:4px 8px;border-radius:6px;font-size:.75rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-thinking-badge{background:linear-gradient(135deg,#7b1fa2,#9c27b0);padding:4px 8px;border-radius:6px;font-size:.75rem;color:#fff;display:flex;align-items:center;gap:6px;animation:ai-badge-glow 2s ease-in-out infinite;white-space:nowrap}@keyframes ai-badge-glow{0%,to{box-shadow:0 0 8px #9c27b080}50%{box-shadow:0 0 16px #9c27b0cc}}@media(min-width:480px){.header-info{gap:12px}.game-code-badge,.player-badge,.ai-thinking-badge{padding:6px 12px;font-size:.85rem}.player-badge{max-width:none}}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.error-banner{background:#c62828;color:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:center;gap:12px}.error-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:inherit;opacity:.7;padding:0;flex-shrink:0}.error-close:hover{opacity:1}.thinking-spinner{display:inline-block;width:16px;height:16px;min-width:16px;min-height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px;vertical-align:middle;flex-shrink:0;aspect-ratio:1}@keyframes spin{to{transform:rotate(360deg)}}.consensus-banner{background:linear-gradient(90deg,#2e7d32,#4caf50,#2e7d32);background-size:200% 100%;animation:consensus-pulse 1.5s ease-in-out infinite;color:#fff;padding:12px 16px;text-align:center}@keyframes consensus-pulse{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.consensus-content{font-size:1rem;margin-bottom:8px}.consensus-content strong{font-size:1.2rem;letter-spacing:1px;text-transform:uppercase}.consensus-progress{height:6px;background:#0003;border-radius:3px;overflow:hidden;max-width:400px;margin:0 auto}.consensus-progress-bar{height:100%;background:#fff;border-radius:3px;transition:width .05s linear}.ai-recommendation-card{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;padding:12px;margin-top:12px;border-radius:8px;cursor:pointer;box-shadow:0 2px 8px #0003}.ai-recommendation-card:hover{background:linear-gradient(135deg,#388e3c,#43a047)}.recommendation-header{display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin-bottom:8px;font-size:.8rem}.recommendation-header .ai-badge{background:#fff3;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:700}.recommendation-word{font-size:1.1rem;font-weight:700;margin-bottom:8px;letter-spacing:1px}.recommendation-reasoning{font-size:.8rem;opacity:.9;line-height:1.4}.recommendation-hint{font-size:.7rem;opacity:.6;margin-top:8px;text-align:center}.game-main{flex:1;display:flex;gap:12px;padding:8px;overflow:auto}@media(min-width:768px){.game-main{gap:16px;padding:16px}}.team-sidebar{width:220px;flex-shrink:0}.game-center{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}.lobby-status{background:#fff;border-radius:12px;padding:48px 32px;text-align:center;box-shadow:0 4px 12px #0003;max-width:500px;margin:0 auto}.lobby-status h2{margin:0 0 16px;color:#333;font-size:1.5rem}.lobby-status p{color:#666;margin:0}.btn-lg{padding:16px 32px;font-size:1.1rem}.game-over-banner{padding:16px 24px;text-align:center;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.game-over-banner.team-red{background:linear-gradient(90deg,#c62828,#e53935,#c62828);color:#fff}.game-over-banner.team-blue{background:linear-gradient(90deg,#1565c0,#1976d2,#1565c0);color:#fff}.game-over-banner h2{margin:0;font-size:1.4rem}.game-over-banner .win-reason{opacity:.9;font-size:.9rem}.game-over-banner .game-over-actions{display:flex;gap:12px}.game-over-banner .btn{padding:8px 16px;font-size:.9rem}.game-over-banner .btn-restart{background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff}.game-over-banner .btn-restart:hover{background:#ffffff4d}.game-over-banner .btn-home{background:#fff;border:none}.game-over-banner.team-red .btn-home{color:#c62828}.game-over-banner.team-blue .btn-home{color:#1565c0}@media(max-width:900px){.game-main{flex-direction:column}.team-sidebar{width:100%}.game-main{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr}.game-center{grid-column:1 / -1;order:-1}}
