.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card h1{margin:0 0 10px;color:#333;font-size:2em;text-align:center}.subtitle{text-align:center;color:#666;margin:0 0 30px;font-size:.95em}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:.95em}.form-group input[type=text]{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em;transition:all .3s}.form-group input[type=text]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px}.role-option{cursor:pointer;border:2px solid #e0e0e0;border-radius:12px;padding:16px;transition:all .3s;background:#fff}.role-option:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.role-option.selected{border-color:#667eea;background:#f7f8ff}.role-option input[type=radio]{display:none}.role-content{text-align:center}.role-icon{font-size:2.5em;margin-bottom:8px}.role-label{font-weight:600;color:#333;margin-bottom:4px}.role-description{font-size:.85em;color:#666}.error-message{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9em}.login-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:center}.login-footer p{margin:0;color:#666;font-size:.9em}.director-container{min-height:100vh;background:#f5f7fa}.director-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 0;box-shadow:0 2px 8px #0000001a}.header-content{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.director-header h1{margin:0;font-size:1.8em}.director-content{max-width:1400px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:20px}.streaming-panel{border:2px solid #667eea}.streaming-controls{display:flex;flex-direction:column;gap:16px}.mode-selector{display:flex;gap:12px}.mode-selector label{flex:1;padding:12px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s;text-align:center}.mode-selector label:hover{border-color:#667eea}.mode-selector label.active{border-color:#667eea;background:#f7f8ff}.mode-selector input[type=radio]{display:none}.target-select{padding:10px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em}.stream-button{padding:16px 32px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s}.stream-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px)}.stream-button.streaming{background:#e74c3c}.stream-button.streaming:hover{background:#c0392b}.stream-button:disabled{opacity:.5;cursor:not-allowed}.streaming-indicator{display:flex;align-items:center;gap:10px;padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-weight:600}.pulse{width:12px;height:12px;background:#e74c3c;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.mic-error{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33}.create-group-form{display:flex;gap:8px;margin-bottom:20px}.create-group-form input{flex:1;padding:10px;border:2px solid #e0e0e0;border-radius:6px}.create-group-form button{padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.create-group-form button:hover{background:#5568d3}.groups-list{display:flex;flex-direction:column;gap:12px}.group-item{border:1px solid #e0e0e0;border-radius:8px;padding:12px;background:#fafafa}.group-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.group-name{font-weight:600;color:#333;flex:1}.player-count{color:#666;font-size:.9em}.group-actions{display:flex;gap:4px}.group-actions button{padding:4px 8px;background:transparent;border:none;cursor:pointer;font-size:1.1em}.group-actions button:hover{opacity:.7}.group-edit{display:flex;gap:8px}.group-edit input{flex:1;padding:6px;border:2px solid #667eea;border-radius:4px}.group-edit button{padding:6px 12px;border:none;background:#667eea;color:#fff;border-radius:4px;cursor:pointer}.group-players{display:flex;flex-wrap:wrap;gap:6px}.player-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:#fff;border:1px solid #e0e0e0;border-radius:16px;font-size:.9em}.player-chip button{background:none;border:none;cursor:pointer;padding:0;font-size:1em;color:#999}.player-chip button:hover{color:#e74c3c}.players-section{margin-bottom:20px}.players-section h3{margin:0 0 12px;color:#666;font-size:.95em;text-transform:uppercase;letter-spacing:.5px}.players-list{display:flex;flex-direction:column;gap:8px}.player-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fafafa;border:1px solid #e0e0e0;border-radius:8px}.player-name{font-weight:500;color:#333}.move-select{padding:6px 10px;border:1px solid #e0e0e0;border-radius:6px;font-size:.9em;cursor:pointer}.empty-state{text-align:center;color:#999;padding:40px;font-style:italic}@media (max-width: 1024px){.panels-row{grid-template-columns:1fr}}.player-container{min-height:100vh;background:#f5f7fa}.player-header{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;padding:20px 0;box-shadow:0 2px 8px #0000001a}.header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.player-header h1{margin:0;font-size:1.8em}.user-info{display:flex;align-items:center;gap:15px}.logout-btn{padding:8px 16px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;transition:all .3s}.logout-btn:hover{background:#ffffff4d}.player-content{max-width:1200px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:20px}.panel{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.panel h2{margin:0 0 20px;color:#333;font-size:1.3em}.audio-panel{border:2px solid #11998e}.audio-setup{text-align:center;padding:20px}.info-text{margin-bottom:20px;color:#666;font-size:1em;line-height:1.6}.enable-audio-btn{padding:16px 32px;background:#11998e;color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s}.enable-audio-btn:hover{background:#0d7a70;transform:translateY(-2px);box-shadow:0 4px 12px #11998e4d}.audio-status{display:flex;flex-direction:column;gap:16px}.status-indicator{display:flex;align-items:center;gap:12px;padding:16px;background:#f0f9f7;border-radius:8px}.status-indicator.active{background:#e8f5e9;animation:audioActive .5s ease-in-out}@keyframes audioActive{0%{background:#c8e6c9}to{background:#e8f5e9}}.status-dot{width:12px;height:12px;background:#ccc;border-radius:50%}.status-dot.ready{background:#11998e;animation:pulse 2s ease-in-out infinite}.status-text{font-weight:500;color:#333}.director-info{padding:12px;background:#f7f7f7;border-radius:6px;display:flex;align-items:center;justify-content:space-between}.director-info.offline{background:#fff5f5}.online-badge{color:#4caf50;font-size:.9em}.offline-badge{color:#f44336;font-size:.9em}.panels-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.current-group{display:flex;flex-direction:column;gap:16px}.group-info{display:flex;flex-direction:column;gap:8px}.group-name{font-size:1.2em;color:#11998e;font-weight:600}.no-group{font-size:1.2em;color:#999;font-style:italic}.group-selector{display:flex;flex-direction:column;gap:8px}.group-selector label{font-weight:500;color:#666;font-size:.9em}.group-selector select{padding:10px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em;cursor:pointer}.group-members{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.group-members h3{margin:0 0 12px;color:#666;font-size:.95em}.members-list{display:flex;flex-direction:column;gap:8px}.member-item{padding:10px;background:#f7f7f7;border-radius:6px;display:flex;align-items:center;justify-content:space-between}.you-badge{padding:2px 8px;background:#11998e;color:#fff;border-radius:12px;font-size:.8em;font-weight:600}.overview-content{display:flex;flex-direction:column;gap:24px}.section h3{margin:0 0 12px;color:#666;font-size:1em}.groups-overview{display:flex;flex-direction:column;gap:12px}.group-overview-item{border:1px solid #e0e0e0;border-radius:8px;padding:12px;background:#fafafa}.group-overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.group-overview-name{font-weight:600;color:#333}.group-overview-count{color:#666;font-size:.9em}.group-overview-players{display:flex;flex-wrap:wrap;gap:6px}.player-tag{padding:4px 10px;background:#fff;border:1px solid #e0e0e0;border-radius:16px;font-size:.85em;color:#666}.players-overview{display:flex;flex-direction:column;gap:8px}.player-overview-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fafafa;border:1px solid #e0e0e0;border-radius:6px}.player-overview-name{font-weight:500;color:#333}.player-overview-group{color:#666;font-size:.9em}.info-list{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px}.info-list li{padding:12px;background:#f7f7f7;border-left:3px solid #11998e;border-radius:4px;color:#666}.empty-state{text-align:center;color:#999;padding:20px;font-style:italic}@media (max-width: 768px){.panels-row{grid-template-columns:1fr}}body{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}.connection-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f7fa;padding:20px}.error-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 16px #0000001a;text-align:center;max-width:500px}.error-card h2{color:#e74c3c;margin-bottom:16px}.error-card p{color:#666;margin-bottom:12px;line-height:1.6}.error-card .hint{font-size:.9em;color:#999;margin-bottom:24px}.error-card button{padding:12px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s}.error-card button:hover{background:#5568d3;transform:translateY(-2px)}*{margin:0;padding:0;box-sizing:border-box}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}#root{min-height:100vh}
