.envido-cantos-overlay{position:fixed;pointer-events:none;z-index:100;width:100%;height:100%;top:0;left:0}.envido-canto{position:absolute;background:#ffd700f2;color:#1a1008;padding:8px 16px;border-radius:8px;font-weight:700;font-size:18px;box-shadow:0 4px 8px #0006;border:2px solid rgba(255,180,0,.8);animation:slideIn .3s ease-out,pulse .5s ease-in-out .3s;white-space:nowrap}.envido-canto.position-0{bottom:80px;left:50%;transform:translate(-50%)}.envido-canto.position-1{right:120px;top:50%;transform:translateY(-50%)}.envido-canto.position-2{top:120px;left:50%;transform:translate(-50%)}.envido-canto.position-3{left:120px;top:50%;transform:translateY(-50%)}.envido-canto.is-local{background:#64c8fff2;border-color:#3296ffcc}.envido-canto-text{text-shadow:1px 1px 2px rgba(0,0,0,.3)}@keyframes slideIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.envido-canto.position-0{animation:slideInBottom .3s ease-out,pulseBottom .5s ease-in-out .3s}@keyframes slideInBottom{0%{opacity:0;bottom:60px}to{opacity:1;bottom:80px}}@keyframes pulseBottom{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.1)}}.envido-canto.position-2{animation:slideInTop .3s ease-out,pulseTop .5s ease-in-out .3s}@keyframes slideInTop{0%{opacity:0;top:100px}to{opacity:1;top:120px}}@keyframes pulseTop{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.1)}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#0f0f1a,#16213e)}canvas{display:block}.ui-overlay{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:100;pointer-events:none}.title{font-family:Playfair Display,serif;font-size:2rem;color:#d4af37;text-shadow:0 2px 20px rgba(212,175,55,.4);letter-spacing:.1em;text-transform:uppercase}.instructions{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:100;font-family:Playfair Display,serif;font-size:1rem;color:#fff9;letter-spacing:.05em;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.reset-button{position:fixed;bottom:24px;right:24px;z-index:100;padding:12px 24px;font-family:Playfair Display,serif;font-size:.9rem;color:#d4af37;background:#1e1e28cc;border:1px solid rgba(212,175,55,.3);border-radius:4px;cursor:pointer;transition:all .3s ease;letter-spacing:.05em;text-transform:uppercase}.reset-button:hover{background:#d4af3733;border-color:#d4af37;box-shadow:0 0 20px #d4af374d}.scenario-button{position:fixed;bottom:24px;left:24px;z-index:100;padding:12px 24px;font-family:Playfair Display,serif;font-size:.9rem;color:#d4af37;background:#1e1e28cc;border:1px solid rgba(212,175,55,.3);border-radius:4px;cursor:pointer;transition:all .3s ease;letter-spacing:.05em;text-transform:uppercase;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.scenario-button:hover{background:#d4af3733;border-color:#d4af37;box-shadow:0 0 20px #d4af374d;transform:scale(1.05)}.scoreboard{position:fixed;top:24px;left:24px;z-index:100;padding:12px 16px;min-width:200px;background:#14141ee6;border:1px solid rgba(212,175,55,.35);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#f5d97a;font-family:Playfair Display,serif;pointer-events:none}.scoreboard-title{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;color:#ffffffb3}.scoreboard-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 0;font-size:.95rem}.scoreboard-team{color:#ffffffe6;white-space:nowrap}.scoreboard-points{font-weight:700;color:#d4af37}.action-panel{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:100;display:flex;flex-direction:row;gap:16px;align-items:flex-end}.action-group{display:flex;flex-direction:column;align-items:center;gap:6px}.action-group-title{font-family:Playfair Display,serif;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#ffffffa6}.game-actions{display:flex;gap:12px;padding:10px 14px;background:#14141ee6;border:1px solid rgba(212,175,55,.35);border-radius:10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.game-action-button{padding:8px 16px;font-family:Playfair Display,serif;font-size:.85rem;color:#f5d97a;background:#1e1e28cc;border:1px solid rgba(212,175,55,.3);border-radius:6px;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all .2s ease}.game-action-button:hover:not(:disabled){background:#d4af3733;border-color:#d4af37;box-shadow:0 0 12px #d4af3740}.game-action-button:disabled{opacity:.5;cursor:not-allowed}.mic-button{position:fixed;right:24px;bottom:90px;z-index:100;padding:10px 16px;font-family:Playfair Display,serif;font-size:.8rem;color:#ffffffe6;background:#14141ee6;border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;letter-spacing:.05em;text-transform:uppercase;transition:all .2s ease}.mic-button.is-listening{color:#f5d97a;border-color:#f5d97a99;box-shadow:0 0 12px #f5d97a59}.mic-button:hover{background:#d4af3726;border-color:#d4af3780}.player-labels{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:90}.player-label{position:absolute;padding:6px 10px;background:#14141ed9;border:1px solid rgba(255,255,255,.12);border-radius:6px;font-family:Playfair Display,serif;font-size:.85rem;color:#ffffffe6;text-transform:none;letter-spacing:.02em}.player-label.is-local{border-color:#d4af3799;color:#f5d97a}.player-label.position-0{bottom:110px;left:50%;transform:translate(-50%)}.player-label.position-2{top:90px;left:50%;transform:translate(-50%)}.player-label.position-1{right:40px;top:50%;transform:translateY(-50%)}.player-label.position-3{left:40px;top:50%;transform:translateY(-50%)}.signal-button{position:absolute;padding:4px 8px;background:#14141ed9;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;font-size:1.2rem;transition:all .2s ease;z-index:91;pointer-events:auto;margin-left:8px}.signal-button:hover:not(:disabled){background:#d4af3733;border-color:#d4af37;transform:scale(1.1)}.signal-button:disabled{opacity:.4;cursor:not-allowed}.signal-count{position:absolute;top:-6px;right:-6px;background:#d4af37;color:#1a1a2e;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;font-family:Playfair Display,serif}.signal-display-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:95}.signal-display{position:absolute;display:flex;flex-direction:column;align-items:center;gap:8px;animation:fadeInOut 4s ease-in-out forwards;pointer-events:none}.signal-group{display:flex;flex-direction:row;gap:12px;align-items:center}.animated-signal{display:flex;flex-direction:column;align-items:center;gap:8px}.lottie-container{width:120px;height:120px;display:flex;align-items:center;justify-content:center}.emoji-fallback{font-size:3.5rem;line-height:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.signal-face,.signal-image{filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.signal-image img,.signal-image video{display:block;object-fit:contain;object-position:center;border-radius:8px;max-width:200px}.signal-label{background:#14141ef2;padding:6px 12px;border-radius:4px;font-family:Playfair Display,serif;font-size:.9rem;color:#f5d97a;border:1px solid rgba(212,175,55,.4);white-space:nowrap}@keyframes fadeInOut{0%{opacity:0;transform:scale(.5)}15%{opacity:1;transform:scale(1.05)}30%,85%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}.signal-display.position-1{right:80px;top:50%;transform:translateY(-50%)}.signal-display.position-2{top:120px;left:50%;transform:translate(-50%)}.signal-display.position-3{left:80px;top:50%;transform:translateY(-50%)}.connection-status{position:fixed;top:24px;right:24px;z-index:100;font-family:SF Mono,Fira Code,monospace;font-size:.75rem}.status-indicator{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#14141ee6;border:1px solid rgba(255,255,255,.1);border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-dot{width:8px;height:8px;border-radius:50%;transition:all .3s ease}.status-dot.connected{background:#4ade80;box-shadow:0 0 8px #4ade8099}.status-dot.disconnected{background:#6b7280}.status-text{color:#fffc;letter-spacing:.02em}.leave-button{margin-left:8px;padding:4px 10px;font-family:inherit;font-size:.7rem;color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:4px;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em}.leave-button:hover{background:#f8717133;border-color:#f87171}.message-log{margin-top:8px;background:#14141ee6;border:1px solid rgba(255,255,255,.1);border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;max-width:280px}.message-log-header{padding:6px 12px;font-size:.65rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid rgba(255,255,255,.05)}.message-list{max-height:150px;overflow-y:auto}.message{display:flex;gap:8px;padding:6px 12px;border-bottom:1px solid rgba(255,255,255,.03)}.message:last-child{border-bottom:none}.message-time{color:#ffffff4d;flex-shrink:0}.message-text{color:#ffffffb3;word-break:break-word}.message.system .message-text{color:#60a5fa}.message.sent .message-text{color:#a78bfa}.message.received .message-text{color:#4ade80}.message.error .message-text{color:#f87171}.message.info .message-text{color:#fbbf24}.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:50;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:opacity .5s ease,visibility .5s ease}.menu-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.menu-content{max-width:800px;width:90%;max-height:85vh;overflow-y:auto;padding:32px}.menu-title{font-family:Playfair Display,serif;font-size:2.5rem;color:#d4af37;text-shadow:0 2px 20px rgba(212,175,55,.4);letter-spacing:.1em;text-transform:uppercase;text-align:center;margin-bottom:32px}.name-input-container{display:flex;flex-direction:column;align-items:center;gap:24px}.name-input-subtitle{font-family:Playfair Display,serif;font-size:1.1rem;color:#ffffffb3;text-align:center}.name-input-form{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:320px}.name-input-field{width:100%;padding:14px 20px;font-family:Playfair Display,serif;font-size:1.1rem;color:#fff;background:#1e1e28cc;border:1px solid rgba(212,175,55,.3);border-radius:8px;outline:none;transition:all .3s ease;text-align:center}.name-input-field::placeholder{color:#fff6}.name-input-field:focus{border-color:#d4af37;box-shadow:0 0 20px #d4af3733}.name-input-error{color:#f87171;font-size:.85rem;margin:0}.menu-button{padding:12px 28px;font-family:Playfair Display,serif;font-size:1rem;border-radius:6px;cursor:pointer;transition:all .3s ease;letter-spacing:.05em;text-transform:uppercase;border:1px solid}.menu-button.primary{color:#1a1a2e;background:linear-gradient(135deg,#d4af37,#c9a227);border-color:#d4af37}.menu-button.primary:hover{background:linear-gradient(135deg,#e5c048,#d4af37);box-shadow:0 0 25px #d4af3766;transform:translateY(-2px)}.menu-button.secondary{color:#d4af37;background:#1e1e28cc;border-color:#d4af374d}.menu-button.secondary:hover{background:#d4af3726;border-color:#d4af37}.menu-button.ready-active{color:#1a1a2e;background:linear-gradient(135deg,#4ade80,#22c55e);border-color:#4ade80}.menu-button.ready-active:hover{background:linear-gradient(135deg,#5ce88f,#4ade80)}.menu-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.room-browser{display:flex;flex-direction:column;gap:24px}.room-browser-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.room-browser-title{font-family:Playfair Display,serif;font-size:1.3rem;color:#ffffffe6;margin:0}.room-browser-actions{display:flex;gap:12px}.room-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.no-rooms{grid-column:1 / -1;text-align:center;padding:48px 24px;background:#1e1e2899;border-radius:12px;border:1px dashed rgba(212,175,55,.2)}.no-rooms-text{font-family:Playfair Display,serif;font-size:1.2rem;color:#fff9;margin:0 0 8px}.no-rooms-hint{font-size:.9rem;color:#fff6;margin:0}.room-card{background:#1e1e28e6;border:1px solid rgba(212,175,55,.2);border-radius:12px;padding:20px;transition:all .3s ease}.room-card:hover:not(.full){border-color:#d4af3780;box-shadow:0 0 20px #d4af371a}.room-card.full{opacity:.6}.room-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.room-card-name{font-family:Playfair Display,serif;font-size:1.1rem;color:#d4af37;margin:0}.room-card-type{font-size:.75rem;color:#ffffff80;background:#ffffff1a;padding:4px 8px;border-radius:4px}.room-card-players{margin-bottom:16px}.player-count{font-size:.9rem;color:#ffffffb3}.room-card-teams{display:flex;gap:16px;margin-bottom:16px}.team-section{flex:1;padding:12px;background:#0000004d;border-radius:8px}.team-section.full{opacity:.5}.team-label{display:block;font-size:.75rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.team-players{display:flex;flex-direction:column;gap:4px}.player-name{font-size:.85rem;color:#fffc}.empty-slot{font-size:.85rem;color:#ffffff4d;font-style:italic}.room-card-join{display:flex;flex-direction:column;gap:12px}.team-select{display:flex;gap:8px}.team-select-btn{flex:1;padding:8px 12px;font-family:inherit;font-size:.8rem;color:#ffffffb3;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;transition:all .2s ease}.team-select-btn:hover:not(.disabled){background:#d4af371a;border-color:#d4af374d}.team-select-btn.selected{color:#d4af37;background:#d4af3726;border-color:#d4af37}.team-select-btn.disabled{opacity:.4;cursor:not-allowed}.join-btn{width:100%}.room-card-full{text-align:center;padding:12px;color:#ffffff80;font-style:italic}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#1e1e28fa;border:1px solid rgba(212,175,55,.3);border-radius:16px;padding:28px;width:90%;max-width:420px;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-title{font-family:Playfair Display,serif;font-size:1.4rem;color:#d4af37;margin:0}.modal-close{width:32px;height:32px;font-size:1.5rem;color:#ffffff80;background:transparent;border:none;cursor:pointer;transition:color .2s ease}.modal-close:hover{color:#fff}.create-room-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.85rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em}.form-input{padding:12px 16px;font-family:inherit;font-size:1rem;color:#fff;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;outline:none;transition:all .2s ease}.form-input:focus{border-color:#d4af3780;box-shadow:0 0 10px #d4af371a}.form-input::placeholder{color:#ffffff4d}.game-type-options,.team-options{display:flex;gap:12px}.option-btn{flex:1;padding:16px 12px;font-family:inherit;color:#ffffffb3;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.option-btn:hover{background:#d4af371a;border-color:#d4af374d}.option-btn.selected{color:#d4af37;background:#d4af3726;border-color:#d4af37}.option-title{font-size:1rem}.option-desc{font-size:.75rem;opacity:.6}.form-error{color:#f87171;font-size:.85rem;margin:0}.modal-actions{display:flex;gap:12px;margin-top:8px}.modal-actions .menu-button{flex:1}.waiting-lobby{display:flex;flex-direction:column;gap:28px}.lobby-header{text-align:center}.lobby-room-name{font-family:Playfair Display,serif;font-size:1.5rem;color:#d4af37;margin:0 0 8px}.lobby-game-type{font-size:.9rem;color:#ffffff80}.lobby-teams{display:flex;align-items:stretch;gap:24px}.lobby-team{flex:1;background:#1e1e28cc;border:1px solid rgba(212,175,55,.2);border-radius:12px;padding:20px}.team-header{font-family:Playfair Display,serif;font-size:1.1rem;color:#fffc;text-align:center;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.team-slots{display:flex;flex-direction:column;gap:12px}.player-slot{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0000004d;border-radius:8px;min-height:48px}.player-slot.filled{border:1px solid rgba(255,255,255,.1)}.player-slot.filled.me{border-color:#d4af3766;background:#d4af370d}.player-slot.empty{border:1px dashed rgba(255,255,255,.1)}.player-info{display:flex;align-items:center;gap:8px}.player-slot-name{font-size:.95rem;color:#ffffffe6}.you-badge{font-size:.7rem;color:#d4af37;background:#d4af3733;padding:2px 8px;border-radius:10px}.ready-indicator{font-size:.8rem;padding:4px 10px;border-radius:12px}.ready-indicator.ready{color:#4ade80;background:#4ade8026}.ready-indicator.not-ready{color:#fff6;background:#ffffff0d}.waiting-text{font-size:.85rem;color:#ffffff4d;font-style:italic}.lobby-vs{display:flex;align-items:center;font-family:Playfair Display,serif;font-size:1.5rem;color:#ffffff4d;font-weight:700}.lobby-status{text-align:center}.status-message{font-size:1rem;margin:0;padding:12px 20px;border-radius:8px}.status-message.waiting{color:#fff9;background:#ffffff0d}.status-message.ready-check{color:#fbbf24;background:#fbbf241a}.status-message.starting{color:#4ade80;background:#4ade8026;animation:pulse 1s ease-in-out infinite}.lobby-actions{display:flex;justify-content:center;gap:16px}@media (max-width: 640px){.menu-content{padding:20px}.menu-title{font-size:1.8rem}.room-browser-header{flex-direction:column;align-items:stretch}.room-browser-actions{justify-content:center}.lobby-teams{flex-direction:column}.lobby-vs{justify-content:center;padding:8px 0}.modal-content{padding:20px}.game-type-options,.team-options,.lobby-actions{flex-direction:column}.lobby-actions .menu-button{width:100%}}.new-round-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;font-family:Playfair Display,serif;font-size:3rem;font-weight:700;color:#d4af37;background:#000000e6;padding:32px 60px;border-radius:16px;border:2px solid #d4af37;box-shadow:0 0 40px #d4af3799;letter-spacing:.1em;text-transform:uppercase;text-shadow:0 2px 20px rgba(212,175,55,.8);animation:newRoundFadeIn .5s ease-in-out}@keyframes newRoundFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
