:root{--bg: #0a0a14;--surface: #12121f;--card-face: #1c1c2e;--border: rgba(255, 255, 255, .08);--text: #e0e0e0;--text-muted: rgba(255, 255, 255, .45);--red: #e84040;--blue: #4080e8;--neutral: #888888;--assassin: #1a0a0a;--green: #40c060;--glow-red: 0 0 20px rgba(232, 64, 64, .5), 0 0 60px rgba(232, 64, 64, .15);--glow-blue: 0 0 20px rgba(64, 128, 232, .5), 0 0 60px rgba(64, 128, 232, .15);--glow-green: 0 0 20px rgba(64, 192, 96, .4);--panel-bg: rgba(12, 12, 24, .85);--panel-border: rgba(255, 255, 255, .06);--radius: 8px;--radius-lg: 12px;--font: "Inter", system-ui, -apple-system, sans-serif}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased}.app{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.app:after{content:"";position:fixed;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);z-index:9999}.panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:28px 32px}.input{width:100%;padding:10px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);color:#fff;font-size:15px;font-family:var(--font);outline:none;transition:border-color .15s}.input:focus{border-color:#ffffff40}.input::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer;transition:filter .15s,transform .1s;color:#fff}.btn:hover{filter:brightness(1.15)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:default;filter:none;transform:none}.btn-primary{background:linear-gradient(135deg,var(--blue),#6050d8)}.btn-secondary{background:#ffffff14}.btn-green{background:linear-gradient(135deg,var(--green),#30a050);box-shadow:var(--glow-green)}.board{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;max-width:600px;width:100%;aspect-ratio:5 / 5}.card{position:relative;display:flex;align-items:center;justify-content:center;background:var(--card-face);border:1px solid var(--border);border-radius:6px;padding:8px 4px;cursor:default;-webkit-user-select:none;user-select:none;transition:background .3s,box-shadow .3s,transform .2s,border-color .3s;aspect-ratio:1.4;overflow:hidden}.card-word{font-size:clamp(10px,1.6vw,15px);font-weight:600;letter-spacing:.04em;text-transform:uppercase;text-align:center;color:var(--text);transition:color .3s;z-index:1}.card.card-red{border-color:#e8404059;background:#e8404014}.card.card-blue{border-color:#4080e859;background:#4080e814}.card.card-neutral{border-color:#ffffff14;background:var(--card-face)}.card.card-assassin{border-color:#ffffff26;background:#0a0a0f}.card.card-assassin:after{content:"☠";position:absolute;top:4px;right:6px;font-size:10px;opacity:.5;line-height:1}.card.card-assassin .card-word{color:#ffffff80}.card.card-mine.card-red{background:#e840402e;border-color:#e84040a6;box-shadow:0 0 0 1px #e8404033,inset 0 0 12px #e8404014}.card.card-mine.card-red .card-word{color:#ffb4b4f2}.card.card-mine.card-blue{background:#4080e82e;border-color:#4080e8a6;box-shadow:0 0 0 1px #4080e833,inset 0 0 12px #4080e814}.card.card-mine.card-blue .card-word{color:#a0c8fff2}.card.revealed{background:#0d0d14;border-color:#ffffff0f;transform:none;opacity:.85}.card.revealed .card-word{color:#ffffff4d;text-decoration:line-through;text-decoration-color:currentColor;text-decoration-thickness:1px}.card.card-red.revealed{box-shadow:inset 3px 0 #e84040b3;border-color:#e8404026}.card.card-red.revealed .card-word{color:#e8646499;text-decoration-color:#e8404066}.card.card-blue.revealed{box-shadow:inset 3px 0 #4080e8b3;border-color:#4080e826}.card.card-blue.revealed .card-word{color:#6496e899;text-decoration-color:#4080e866}.card.card-neutral.revealed{box-shadow:inset 3px 0 #ffffff26}.card.card-neutral.revealed .card-word{color:#fff3}.card.card-assassin.revealed{background:#0a0006;box-shadow:inset 3px 0 #ff1e1ecc,0 0 20px #ff000026;border-color:#ff1e1e33;animation:assassin-pulse 1.2s ease-in-out infinite alternate}.card.card-assassin.revealed .card-word{color:#ff505080;text-decoration-color:#ff1e1e80}@keyframes assassin-pulse{0%{box-shadow:inset 3px 0 #ff1e1e99,0 0 12px #ff00001a}to{box-shadow:inset 3px 0 #ff1e1e,0 0 28px #ff00004d}}.team-panel{flex:1;max-width:320px;min-width:160px;text-align:center}.team-panel-header{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid currentColor}.team-panel-header.red{color:var(--red)}.team-panel-header.blue{color:var(--blue)}.team-player{padding:6px 0;font-size:14px;opacity:.8}.team-player.disconnected{opacity:.35;text-decoration:line-through}.lobby{display:flex;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:700px;padding:24px;transition:max-width .45s ease-in-out}.lobby.lobby-wide{max-width:960px}.lobby-code{font-size:28px;font-weight:700;letter-spacing:.15em;text-shadow:0 0 20px rgba(255,255,255,.15)}.lobby-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 4px}.lobby-welcome{font-size:15px;font-weight:600;color:var(--text);letter-spacing:.01em}.lobby-room-code{font-size:12px;font-weight:700;letter-spacing:.18em;color:var(--text-muted);background:#ffffff0d;border:1px solid var(--border);border-radius:6px;padding:3px 10px;text-transform:uppercase;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,color .15s}.lobby-room-code:hover{background:#ffffff1a;border-color:#ffffff4d;color:var(--text)}.lobby-room-code:active{background:#ffffff26}.lobby-room-code.copied{color:var(--green);border-color:var(--green);background:rgba(var(--green-rgb, 80, 200, 120),.1);letter-spacing:.04em}.join-panel-exit{animation:step-exit .35s ease-in forwards;pointer-events:none}.lobby-teams{display:flex;gap:24px;width:100%}.lobby-main{display:flex;gap:16px;width:100%;align-items:flex-start}.lobby-sidebar{width:190px;flex-shrink:0}.lobby-center{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center}.lobby-sidebar-slide-left{animation:slide-from-center-left .5s ease-out both}.lobby-sidebar-slide-right{animation:slide-from-center-right .5s ease-out both}@keyframes slide-from-center-left{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slide-from-center-right{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.team-roster{padding:14px 16px}.team-roster-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid currentColor}.team-roster-header.red{color:var(--red)}.team-roster-header.blue{color:var(--blue)}.team-roster-red{border-color:#e8404026}.team-roster-blue{border-color:#4080e826}.team-roster-empty{color:var(--text-muted);font-size:12px;padding:6px 0;font-style:italic}.team-roster-player{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-size:13px;opacity:.85}.team-roster-player.disconnected{opacity:.3;text-decoration:line-through}.team-roster-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-roster-you{font-size:11px;color:var(--text-muted)}.team-roster-ready{color:var(--green);font-size:12px;flex-shrink:0;margin-left:6px}.spectator-row{font-size:12px;color:var(--text-muted);text-align:center;padding:4px 0;font-style:italic}.reconnecting-indicator{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:14px}.host-start-section{margin-top:16px;text-align:center}.start-game-btn{font-size:16px;padding:12px 36px}.start-blocker{font-size:12px;color:var(--text-muted);margin-bottom:8px}.start-error{color:var(--red);font-size:12px;margin-top:8px}.reveal-container{display:flex;gap:48px;align-items:flex-start;justify-content:center}.reveal-group{text-align:center}.reveal-name{font-size:32px;font-weight:800;margin-bottom:16px;white-space:nowrap}.reveal-name span{display:inline-block;opacity:0;transform:translateY(12px);animation:letter-in .3s forwards}@keyframes letter-in{to{opacity:1;transform:translateY(0)}}.reveal-answer{font-size:14px;opacity:0;color:var(--text-muted);animation:fade-up .4s forwards;margin-bottom:6px}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:.7;transform:translateY(0)}}.game-view{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:640px;padding:16px}.game-header{display:flex;align-items:center;justify-content:space-between;width:100%;font-size:14px}.turn-indicator{font-weight:700;text-transform:uppercase;letter-spacing:.06em}.turn-indicator.red{color:var(--red);text-shadow:0 0 12px rgba(232,64,64,.4)}.turn-indicator.blue{color:var(--blue);text-shadow:0 0 12px rgba(64,128,232,.4)}.phase-label{font-size:13px;color:var(--text-muted)}.team-panel-locked{animation:lock-pulse .7s ease-out forwards;pointer-events:none}.team-panel-locked.red{--lock-color: var(--red)}.team-panel-locked.blue{--lock-color: var(--blue)}@keyframes lock-pulse{0%{transform:scale(1);box-shadow:0 0 #fff0}35%{transform:scale(1.06);box-shadow:0 0 40px var(--lock-color, rgba(255,255,255,.3)),0 0 80px color-mix(in srgb,var(--lock-color, #fff) 30%,transparent)}to{transform:scale(1);box-shadow:0 0 20px color-mix(in srgb,var(--lock-color, #fff) 25%,transparent)}}.team-panel-dismissed{animation:dismiss-fade .45s ease-in forwards;pointer-events:none}@keyframes dismiss-fade{to{opacity:0;transform:scale(.93) translateY(10px)}}.lobby-step-exit{animation:step-exit .4s ease-in forwards}@keyframes step-exit{to{opacity:0;transform:translateY(-16px)}}.lobby-step-enter{animation:step-enter .45s ease-out both;animation-delay:.05s}@keyframes step-enter{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.waiting-panel{text-align:center;max-width:380px;width:100%}.waiting-panel .icebreaker-question{font-size:15px;font-style:italic;line-height:1.5;margin-bottom:14px;color:var(--text)}.waiting-panel .icebreaker-form{display:flex;gap:8px;margin-bottom:20px}.waiting-panel .icebreaker-form .input{flex:1}.waiting-status{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--text-muted);padding-top:4px}.waiting-status .status-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:dot-pulse 1.4s ease-in-out infinite}@keyframes dot-pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.ready-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 20px;background:#40c0601f;border:1px solid rgba(64,192,96,.3);border-radius:var(--radius);color:var(--green);font-weight:600;font-size:14px;margin-bottom:12px}.unready-btn{font-size:11px!important;padding:3px 10px!important;opacity:.7;transition:opacity .2s}.unready-btn:hover{opacity:1}.score-display{display:flex;align-items:center;gap:6px}.score{font-weight:700;font-size:16px}.score.red{color:var(--red)}.score.blue{color:var(--blue)}.score-divider{color:var(--text-muted);font-size:12px}.gameplay-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:20px 24px;width:100%;max-width:480px;animation:step-enter .35s ease-out both}.waiting-overlay{text-align:center}.waiting-overlay-text{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:var(--text-muted);font-style:italic}.clue-form{text-align:center}.clue-form-title{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;color:var(--text)}.clue-form-fields{display:flex;flex-direction:column;gap:12px}.clue-word-input{text-align:center;font-size:18px!important;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.clue-number-row{display:flex;flex-direction:column;align-items:center;gap:8px}.clue-number-label{font-size:12px;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.clue-number-picker{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.clue-number-chip{width:36px;height:36px;border-radius:6px;border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .12s,border-color .12s,color .12s,transform .1s}.clue-number-chip:hover{background:#ffffff1a;border-color:#ffffff4d;color:var(--text)}.clue-number-chip.selected{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.1)}.clue-submit-btn{margin-top:4px}.clue-error{color:var(--red);font-size:13px;padding:6px 12px;background:#e840401a;border:1px solid rgba(232,64,64,.2);border-radius:var(--radius)}.clue-waiting{text-align:center}.clue-waiting-text{font-size:15px;font-weight:600;margin-bottom:8px;color:var(--text)}.clue-progress{font-size:13px;color:var(--text-muted);margin-top:8px}.voting-panel{text-align:center}.voting-title{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;color:var(--text)}.voting-clues{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:16px}.voting-clue{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius);color:var(--text);font-family:var(--font);cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s,transform .1s}.voting-clue:hover{background:#ffffff14;border-color:#fff3}.voting-clue-selected{background:#4080e81f;border-color:var(--blue);box-shadow:0 0 16px #4080e840;transform:scale(1.04)}.voting-clue-word{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.voting-clue-number{font-size:13px;font-weight:600;color:var(--text-muted);background:#ffffff0f;padding:2px 8px;border-radius:4px}.vote-waiting,.reveal-panel{text-align:center}.reveal-clue{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px}.reveal-clue-word{font-size:22px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.reveal-clue-word.red{color:var(--red);text-shadow:0 0 16px rgba(232,64,64,.4)}.reveal-clue-word.blue{color:var(--blue);text-shadow:0 0 16px rgba(64,128,232,.4)}.reveal-clue-number{font-size:14px;font-weight:600;color:var(--text-muted);background:#ffffff0f;padding:4px 10px;border-radius:4px}.monologue-container{position:relative;background:#0000004d;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px;max-height:220px;overflow-y:auto;text-align:left}.monologue-text{font-size:13px;line-height:1.6;color:#ffffffb3;white-space:pre-wrap;word-break:break-word}.monologue-placeholder{color:var(--text-muted);font-style:italic}.thinking-dots:after{content:"";animation:thinking 1.5s steps(4,end) infinite}@keyframes thinking{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.monologue-cursor{display:inline-block;width:2px;height:1em;background:currentColor;margin-left:1px;vertical-align:text-bottom;animation:cursor-blink .7s step-end infinite}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.newline-pause-dots{display:inline-block;margin-left:2px;color:var(--text-muted);animation:newline-pulse .5s ease-in-out infinite alternate;letter-spacing:.1em}@keyframes newline-pulse{0%{opacity:.3}to{opacity:.9}}.guess-indicator{display:inline-block;margin:10px auto 6px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:5px 16px;font-size:12px;font-weight:600;color:#fff;white-space:nowrap;animation:guess-pulse .8s ease-in-out infinite alternate}@keyframes guess-pulse{0%{box-shadow:0 0 8px #fff3}to{box-shadow:0 0 20px #ffffff80}}.guess-history{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.guess-result{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.guess-correct{background:#40c06026;border:1px solid rgba(64,192,96,.3);color:var(--green)}.guess-wrong{background:#e840401a;border:1px solid rgba(232,64,64,.2);color:var(--red)}.guess-result-word{letter-spacing:.04em}.guess-result-icon{font-size:14px}.alternate-notice{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--text-muted);font-style:italic;margin-top:12px}.card.card-guessing{animation:card-guess-glow .7s ease-in-out infinite alternate;z-index:2}@keyframes card-guess-glow{0%{box-shadow:0 0 12px #ffffff4d;border-color:#ffffff4d;transform:scale(1.02)}to{box-shadow:0 0 28px #fff9,0 0 60px #ffffff26;border-color:#ffffff80;transform:scale(1.06)}}.card.card-just-revealed{animation:card-reveal-flash 1.2s ease-out forwards}@keyframes card-reveal-flash{0%{filter:brightness(2.5);transform:scale(1.12)}40%{filter:brightness(3);transform:scale(1.14)}to{filter:brightness(1);transform:scale(1)}}.turn-end-panel{text-align:center;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:var(--text-muted)}.game-over-panel{text-align:center;padding:20px 32px;animation:step-enter .5s ease-out both;display:flex;flex-direction:column;align-items:center;gap:16px}.game-over-title{font-size:22px;font-weight:700}.game-over-restart{min-width:140px}.game-over-waiting{font-size:13px;color:var(--text-muted);font-style:italic}
