@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root,[data-theme=dark]{--bg-base: #000000;--bg-raised: #0a0a0a;--bg-surface: #111111;--bg-surface-hover: #1a1a1a;--bg-muted: #161616;--bg-inset: #0d0d0d;--text-primary: #f0f0f0;--text-secondary: #a0a0a0;--text-tertiary: #666666;--text-inverse: #000000;--green: #22c55e;--green-dim: rgba(34, 197, 94, .12);--green-border: rgba(34, 197, 94, .25);--green-glow: rgba(34, 197, 94, .35);--red: #ef4444;--red-dim: rgba(239, 68, 68, .12);--red-border: rgba(239, 68, 68, .25);--amber: #f59e0b;--amber-dim: rgba(245, 158, 11, .12);--amber-border: rgba(245, 158, 11, .25);--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--border-focus: rgba(255, 255, 255, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-green: 0 0 24px rgba(34, 197, 94, .3);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease}[data-theme=light]{--bg-base: #f5f5f5;--bg-raised: #ffffff;--bg-surface: #eaeaea;--bg-surface-hover: #e0e0e0;--bg-muted: #f0f0f0;--bg-inset: #e8e8e8;--text-primary: #111111;--text-secondary: #555555;--text-tertiary: #888888;--text-inverse: #ffffff;--green: #16a34a;--green-dim: rgba(22, 163, 74, .1);--green-border: rgba(22, 163, 74, .3);--green-glow: rgba(22, 163, 74, .25);--red: #dc2626;--red-dim: rgba(220, 38, 38, .08);--red-border: rgba(220, 38, 38, .25);--amber: #d97706;--amber-dim: rgba(217, 119, 6, .08);--amber-border: rgba(217, 119, 6, .25);--border: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .14);--border-focus: rgba(0, 0, 0, .24);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow-green: 0 0 24px rgba(22, 163, 74, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font);font-size:14px;line-height:1.5;background:var(--bg-base);color:var(--text-primary);display:flex;justify-content:center;padding:0}#mediasoup-demo-app-container{width:100%;max-width:100%;padding:16px}button{font-family:var(--font);font-size:13px;font-weight:500;line-height:1;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);padding:10px 18px;cursor:pointer;transition:all var(--transition-fast);outline:none;white-space:nowrap}button:focus-visible{border-color:var(--border-focus);box-shadow:0 0 0 2px #ffffff14}button:disabled{opacity:.35;cursor:not-allowed}button.primary{background:var(--green);color:var(--text-inverse);border-color:transparent;font-weight:600}button.primary:hover:not(:disabled){background:#16a34a;border-color:transparent}button.on{background:var(--bg-muted);color:var(--text-secondary);border-color:var(--border)}.login-container{display:flex;justify-content:center;align-items:center;width:100%;padding:24px}.login-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:400px}.login-title{font-size:24px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary);margin-bottom:6px}.login-subtitle{font-size:14px;color:var(--text-tertiary);margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.login-field input{font-family:var(--font);font-size:14px;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;outline:none;transition:border-color var(--transition-fast)}.login-field input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-dim)}.login-field input:-ms-input-placeholder{color:var(--text-tertiary)}.login-field input::placeholder{color:var(--text-tertiary)}.login-field input:disabled{opacity:.4;cursor:not-allowed}.login-button{margin-top:8px;padding:14px 24px;font-size:14px;font-weight:600;background:var(--green);color:var(--text-inverse);border:none;border-radius:var(--radius-md);transition:all var(--transition-fast)}.login-button:hover:not(:disabled){background:#16a34a}.login-error{background:var(--red-dim);border:1px solid var(--red-border);border-radius:var(--radius-md);padding:12px 14px;color:var(--red);font-size:13px;font-weight:500}.logout-container{display:flex;justify-content:center;align-items:center;color:var(--text-tertiary)}.tab-navigation{display:flex;flex-direction:column;width:100%}.tab-nav-bar{display:flex;gap:2px;padding:3px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:20px;position:sticky;top:12px;z-index:50;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.tab-nav-button{flex:1;padding:10px 16px;font-size:13px;font-weight:500;background:transparent;color:var(--text-tertiary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.tab-nav-button:hover:not(.active){color:var(--text-secondary);background:#ffffff0a}.tab-nav-button.active{background:var(--text-primary);color:var(--text-inverse);font-weight:600}.tab-content-visible{display:block}.tab-content-hidden{display:none}.room-manager-layout{display:flex;align-items:flex-start;gap:16px;width:80%;margin:auto}.room-manager-main{width:50%}.history-container{width:50%;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;color:var(--text-secondary);display:flex;flex-direction:column;gap:12px;min-height:520px}.history-container h1{font-size:18px;color:var(--text-primary);margin-bottom:8px}.history-container p{font-size:13px;line-height:1.5}.history-header{display:flex;flex-direction:column;gap:2px}.history-title{font-size:16px;font-weight:700;color:var(--text-primary)}.history-subtitle{font-size:12px;color:var(--text-tertiary)}.history-error-banner{background:var(--red-dim);color:var(--red);border:1px solid var(--red-border);border-radius:var(--radius-sm);padding:8px 10px}.history-scrollable{border:1px solid var(--border);background:var(--bg-surface);border-radius:var(--radius-md);padding:12px;overflow:auto;height:560px;display:flex;flex-direction:column-reverse}.history-message-list{list-style:none;display:flex;flex-direction:column;gap:10px}.history-message-row{width:100%;display:flex}.history-message-left{justify-content:flex-start}.history-message-right{justify-content:flex-end}.history-message-card{border-radius:var(--radius-md);padding:10px;border:1px solid var(--border);background:var(--bg-muted);display:flex;flex-direction:column;gap:8px;width:50%}.history-message-right .history-message-card{border-color:var(--green-border);background:var(--green-dim)}.history-message-header{display:flex;justify-content:space-between;gap:10px}.history-message-sender{font-size:12px;font-weight:600;color:var(--text-primary)}.history-message-time{font-size:11px;color:var(--text-tertiary)}.history-message-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--text-secondary)}.history-message-card audio{width:100%;height:34px}.history-message-error{font-size:12px;color:var(--red)}.history-loading,.history-loading-more,.history-placeholder{text-align:center;padding:10px;color:var(--text-tertiary)}.rooms-container{display:flex;flex-direction:column;gap:8px}.room-types-filter{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md)}.room-types-filter-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.room-types-filter-list{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.room-types-filter-option{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-primary);cursor:pointer}.room-types-filter-option input[type=checkbox]{accent-color:var(--green);cursor:pointer}.room-type-indicator{font-size:10px;color:var(--text-tertiary);background:var(--bg-surface);padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--border)}.rooms-loading{display:flex;flex-direction:column;gap:16px;justify-content:center;align-items:center;color:var(--text-tertiary);font-size:14px}.room-wrapper{width:100%}[data-component=Room].room-row{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-base);width:100%}[data-component=Room].room-row:hover{border-color:var(--border-hover)}[data-component=Room].room-row.history-active-room{border-color:var(--green-border);box-shadow:inset 0 0 0 1px var(--green-border)}.room-row-header{display:flex;align-items:center;gap:12px;padding:14px 16px}@media (max-width: 1200px){.room-manager-layout{width:100%;flex-direction:column}.room-manager-main,.history-container{width:100%}.history-scrollable{height:420px}}.room-metadata{flex:1;display:flex;flex-direction:column;gap:4px}.room-name-row{display:flex;align-items:center;gap:8px}.room-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-state-indicator{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-surface)}.room-state-dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary)}.room-state-indicator.connected .room-state-dot{background:var(--green);box-shadow:0 0 6px var(--green-glow)}.room-state-indicator.connecting .room-state-dot{background:var(--amber);animation:blink 1.2s ease-in-out infinite}.room-state-indicator.closed .room-state-dot{background:var(--red)}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.room-state-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.room-peer-count-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.room-peer-count-text{font-size:12px;color:var(--text-tertiary);font-weight:500}.room-peers-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.onoff-room-button{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border);padding:0;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.onoff-room-button:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--border-hover)}.onoff-room-button.connected{background:var(--green-dim);border-color:var(--green-border)}.onoff-room-button.closed{background:var(--red-dim);border-color:var(--red-border)}.onoff-room-button.connecting{background:var(--amber-dim);border-color:var(--amber-border)}.onoff-room-button:disabled{opacity:.35;cursor:not-allowed}.global-speakers-container{display:flex;flex-direction:column;gap:10px;padding:8px 12px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;max-height:10.5rem;overflow:hidden}.global-speakers-container .non-global-speakers{font-size:.8rem;color:var(--text-tertiary);background:var(--bg-surface);padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--border)}.global-speakers-room{display:flex;align-items:center;gap:6px}.global-speakers-room:not(:last-child):after{content:"";display:block;width:1px;height:12px;background:var(--border);margin-left:4px}.global-speakers-room-label{font-size:.75rem;font-weight:1000;color:var(--text-tertiary);letter-spacing:.4px;white-space:nowrap}.current-speaker-container{display:flex;align-items:center;flex-wrap:wrap;gap:4px}.speaker-badge{display:inline-flex;align-items:center;gap:4px;background:var(--green-dim);padding:2px 8px;border-radius:var(--radius-full);border:1px solid var(--green-border)}.speaker-indicator{width:14px;height:14px;border-radius:50%;background:var(--green-dim);display:flex;align-items:center;justify-content:center}.speaker-name{font-size:11px;font-weight:600;color:var(--green)}.speaker-status-pill{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--green);background:#22c55e14;padding:1px 5px;border-radius:var(--radius-full)}.non-priority-speaker .speaker-indicator.secondary{background:#ffffff0f}.non-priority-speaker .speaker-name{color:var(--text-secondary)}.non-priority-speaker{background:#ffffff0a;border-color:var(--border)}.speaker-status-pill.buffered{color:var(--text-tertiary);background:#ffffff0a}.speaker-more-badge{background:var(--green-dim);padding:2px 8px;border-radius:var(--radius-full);border:1px solid var(--green-border)}.speaker-more-text{font-size:11px;font-weight:600;color:var(--green)}.ptt-compact-wrapper{display:flex;align-items:center;flex-shrink:0}.ptt-compact-button-container{position:relative}.ptt-compact-wave-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.ptt-compact-wave{width:56px;height:56px;border-radius:50%;border:2px solid var(--green-border);animation:ptt-pulse 1.4s ease-out infinite}@keyframes ptt-pulse{0%{transform:scale(1);opacity:.5}to{transform:scale(1.6);opacity:0}}.ptt-compact-button{position:relative;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:2px solid var(--border);padding:0;cursor:pointer;transition:all var(--transition-fast)}.ptt-compact-button:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--border-hover)}.ptt-compact-button.ptt-compact-pressed,.ptt-compact-button.ptt-compact-pressed:hover:not(:disabled){background:var(--green);border-color:var(--green);transform:scale(.92);box-shadow:var(--shadow-glow-green)}.ptt-compact-button.ptt-compact-disabled{background:var(--bg-surface);border-color:var(--border);opacity:.3;cursor:not-allowed}[data-component=Room]:not(.room-row){background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;display:grid;grid-template-columns:minmax(0,1fr);gap:24px}.room-header{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid var(--border)}.state-indicator{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-full);background:var(--bg-surface);font-size:13px;font-weight:500;text-transform:capitalize}.state-indicator .dot{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary)}.state-indicator.connected .dot{background:var(--green);box-shadow:0 0 6px var(--green-glow)}.state-indicator.connecting .dot{background:var(--amber)}.state-indicator.closed .dot{background:var(--red)}.versions{display:flex;gap:16px;font-size:12px;text-transform:uppercase;letter-spacing:.3px;color:var(--text-tertiary)}.versions .label{display:block;font-size:10px;opacity:.6}.room-link button{border-radius:var(--radius-md)}.peers-section,.me-section,.room-actions{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.peers-section h2,.me-section h2{margin:0 0 14px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.me-section.speaking,.peer-container.speaking{background:var(--green-dim)}.me-card,.peer-card{background:var(--bg-muted);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.me-header,.peer-card-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.display-name{font-size:15px;font-weight:600;color:var(--text-primary)}.device-info{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary)}.device-flag{width:10px;height:10px;border-radius:50%;background:#ffffff26}.me-actions,.peer-card-body{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.peer-container{background:var(--bg-muted);border-radius:var(--radius-md);padding:14px;border:1px solid var(--border);transition:all var(--transition-base)}.peer-container.priority-speaker{border-color:var(--green-border);background:var(--green-dim)}.peer-card-header button{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border)}.peer-card-body audio{width:100%;margin:4px 0;border-radius:var(--radius-sm);background:var(--bg-surface)}.peer-name{font-size:13px;font-weight:500;color:var(--text-secondary);margin:0}.peer-audio-state{font-size:12px;font-weight:500;color:var(--green)}.peer-audio-state.muted{color:var(--text-tertiary)}.peer-empty-state{padding:32px;text-align:center;color:var(--text-tertiary);border:1px dashed var(--border);border-radius:var(--radius-md);font-size:13px}.room-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-start}[data-component=Notifications]{position:fixed;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:100;max-width:360px}.notification{padding:12px 16px;border-radius:var(--radius-md);background:var(--bg-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;cursor:pointer;box-shadow:var(--shadow-lg);transition:opacity var(--transition-base);animation:notif-in .2s ease-out}@keyframes notif-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.notification:hover{border-color:var(--border-hover)}.notification .icon{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.notification.info .icon{background:var(--green);box-shadow:0 0 6px var(--green-glow)}.notification.error .icon{background:var(--red)}.notification .title{margin:0;font-size:13px;font-weight:600;color:var(--text-primary)}.notification .text{margin:2px 0 0;font-size:13px;color:var(--text-secondary);line-height:1.4}.participants-tab{padding:0}.participants-tab-title{font-size:20px;font-weight:700;letter-spacing:-.3px;color:var(--text-primary);margin-bottom:4px}.participants-tab-subtitle{color:var(--text-tertiary);font-size:13px;margin-bottom:20px}.participants-empty{text-align:center;padding:48px 24px;color:var(--text-tertiary);font-size:13px}.participants-rooms-list{display:flex;flex-direction:column;gap:16px}.room-participants-section{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.room-participants-section.collapsed{padding-bottom:20px}.room-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}.room-section-toggle{width:100%;background:none;border:none;cursor:pointer;padding:0 0 12px;transition:none}.room-participants-section.collapsed .room-section-toggle{margin-bottom:0;padding-bottom:0;border-bottom:none}.room-section-toggle-left{display:flex;align-items:center;gap:6px}.room-section-chevron{color:var(--text-tertiary);flex-shrink:0}.room-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.room-section-title-group{display:flex;flex-direction:column;gap:2px;text-align:left}.room-section-description{font-size:11px;color:var(--text-tertiary);margin:0;font-weight:400}.room-section-count{font-size:11px;font-weight:600;color:var(--text-tertiary);background:var(--bg-surface);padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--border)}.room-section-empty{color:var(--text-tertiary);font-size:13px;padding:12px 0}.participants-list{display:flex;flex-direction:column;gap:6px}.participant-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--transition-fast)}.participant-card:hover{background:var(--bg-surface)}.participant-card.speaking{border-color:var(--green-border);background:var(--green-dim)}.participant-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.participant-card.speaking .participant-avatar{background:var(--green-dim);border-color:var(--green-border)}.participant-initials{font-size:13px;font-weight:700;color:var(--text-secondary)}.participant-card.speaking .participant-initials{color:var(--green)}.participant-info{display:flex;flex-direction:column;gap:1px}.participant-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.participant-device{font-size:11px;color:var(--text-tertiary)}.participant-speaking-indicator{width:8px;height:8px;border-radius:50%;background:var(--green);margin-left:auto;box-shadow:0 0 8px var(--green-glow);animation:pulse-dot 1.2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.me-tab{display:flex;flex-direction:column;gap:16px}.me-tab-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.me-tab-card-title{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.me-tab-card-subtitle{font-size:12px;color:var(--text-tertiary);margin-bottom:16px}.me-tab-info-list{display:flex;flex-direction:column}.info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.info-row:last-child{border-bottom:none}.info-label{font-size:13px;color:var(--text-tertiary)}.info-value{font-size:13px;font-weight:500;color:var(--text-primary)}.static-rooms-list{display:flex;flex-direction:column;gap:6px}.static-room-card{display:flex;flex-direction:column;gap:2px;padding:12px 14px;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border)}.static-room-name{font-size:13px;font-weight:600;color:var(--text-primary)}.static-room-description{font-size:12px;color:var(--text-tertiary)}.me-tab-placeholder{color:var(--text-tertiary);font-size:13px}.me-tab-actions{margin-top:4px}.logout-button{background:var(--red-dim);border:1px solid var(--red-border);color:var(--red);font-weight:600}.logout-button:hover:not(:disabled){background:#ef444433;border-color:#ef444459}.calls-tab{display:flex;flex-direction:column;gap:20px}.calls-tab.empty{padding:36px 20px;text-align:center}.calls-tab.empty h2{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.calls-tab.empty p{color:var(--text-tertiary);font-size:13px}.calls-tab-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.calls-tab-header h2{font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--text-primary);margin:0}.calls-tab-header .ghost-button{background:var(--red-dim);border:1px solid var(--red-border);color:var(--red);font-weight:600;padding:8px 14px;font-size:12px}.calls-tab-header .ghost-button:hover:not(:disabled){background:#ef444433}.calls-live-section{display:flex;flex-direction:column;gap:12px}.calls-tab-content{display:flex;flex-direction:column;gap:16px}.calls-room-group{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:14px}.calls-room-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid var(--border)}.calls-room-toggle{width:100%;background:none;border:none;cursor:pointer;padding:0 0 10px;transition:none}.calls-room-group.collapsed .calls-room-toggle{padding-bottom:0;border-bottom:none}.calls-room-group.collapsed .calls-peers-container{display:none}.calls-room-toggle-left{display:flex;align-items:center;gap:6px}.calls-room-chevron{color:var(--text-tertiary);flex-shrink:0}.calls-room-name{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.calls-room-count{font-size:11px;font-weight:600;color:var(--text-tertiary);background:var(--bg-surface);padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--border)}.calls-peers-container{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-start}.calls-peer-group{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);flex:1 1 260px}.calls-peer-header{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.calls-peer-info{display:flex;align-items:center;gap:6px;flex:1}.calls-peer-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:normal;overflow:visible;text-overflow:unset;word-break:break-word}.calls-role-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;flex-shrink:0;background:var(--green-dim);color:var(--green);border:1px solid var(--green-border)}.calls-role-icon.dispatcher,.calls-role-icon.driver{background:var(--green-dim);color:var(--green);border-color:var(--green-border)}.calls-role-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:var(--radius-full);flex-shrink:0}.calls-role-badge.dispatcher{background:#60a5fa1f;color:#60a5fa;border:1px solid rgba(96,165,250,.25)}.calls-role-badge.driver{background:var(--green-dim);color:var(--green);border:1px solid var(--green-border)}.calls-peer-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.calls-answer-button{display:flex;align-items:center;gap:5px;padding:6px 14px;background:var(--green);color:#000;border:none;border-radius:var(--radius-full);font-size:12px;font-weight:700;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.calls-answer-button:hover:not(:disabled){background:#16a34a;box-shadow:0 0 12px var(--green-glow)}.calls-answer-button:disabled{opacity:.5;cursor:not-allowed}.calls-peer-count{font-size:11px;color:var(--text-tertiary);background:var(--bg-muted);padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0;font-weight:600}.calls-clip-list{display:flex;flex-direction:column;gap:6px}.calls-clip-item{display:flex;flex-direction:column;gap:6px;padding:8px;background:var(--bg-muted);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color var(--transition-fast)}.calls-clip-item:hover{border-color:var(--border-hover)}.calls-clip-meta{display:flex;justify-content:space-between;align-items:center;gap:8px}.calls-clip-time{font-size:11px;color:var(--text-tertiary);font-weight:500}.calls-clip-remove{background:var(--red-dim);border:1px solid var(--red-border);color:var(--red);padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.calls-clip-remove:hover:not(:disabled){background:#ef444433}.calls-clip-audio{width:100%;height:32px;border-radius:var(--radius-sm);background:#ffffff0f;outline:none}.calls-clip-audio::-webkit-media-controls-panel{background:#ffffff14;border-radius:var(--radius-sm)}.mute-button{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border);padding:0;cursor:pointer;transition:all var(--transition-fast)}.mute-button:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--border-hover)}.mute-button.muted{background:var(--red-dim);border-color:var(--red-border)}.mute-icon{width:18px;height:18px;color:var(--text-secondary)}.mute-button.muted .mute-icon{color:var(--red)}[data-component=Me] .card button,.peer-card button,.room-actions button{flex:1 1 auto}@media (max-width: 640px){#mediasoup-demo-app-container{padding:8px}.login-card{padding:32px 24px}.login-title{font-size:20px}.tab-nav-bar{gap:1px;padding:2px}.tab-nav-button{padding:8px 10px;font-size:12px}.room-manager-layout{flex-direction:column;gap:12px}.history-container{flex-basis:auto;width:100%}.room-row-header{padding:10px 12px;gap:8px}.room-name{font-size:13px}.room-state-indicator{padding:2px 6px}.room-state-label{font-size:9px}.onoff-room-button{width:34px;height:34px}.ptt-compact-button{width:40px;height:40px}.speaker-name{max-width:60px}.room-participants-section,.me-tab-card{padding:14px}.me-actions,.peer-card-body,.room-actions{flex-direction:column}.calls-room-group{padding:12px}.calls-tab-header{flex-direction:column;align-items:flex-start}.calls-tab-header .ghost-button{width:100%}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0000001f}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000038}::selection{background:#22c55e4d;color:var(--text-primary)}[data-theme=light] .tab-nav-button:hover:not(.active){background:#0000000d}[data-theme=light] .tab-nav-button.active{background:var(--text-primary);color:var(--text-inverse)}[data-theme=light] .non-priority-speaker{background:#00000008}[data-theme=light] .speaker-status-pill.buffered{background:#0000000a}[data-theme=light] .calls-clip-audio::-webkit-media-controls-panel{background:#0000000f}.theme-selector{display:flex;gap:6px}.theme-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg-surface);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);font-size:11px;font-weight:600}.theme-option:hover{border-color:var(--border-hover);background:var(--bg-surface-hover)}.theme-option.active{border-color:var(--green);background:var(--green-dim);color:var(--green)}.theme-option-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.admin-panel-fab-container{position:fixed;bottom:24px;left:0;right:0;display:flex;justify-content:center;z-index:200;pointer-events:none}.admin-panel-fab{pointer-events:all;padding:6px 16px;font-size:11px;font-weight:500;font-family:var(--font);background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-hover);border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--shadow-lg);transition:background var(--transition-fast),border-color var(--transition-fast)}.admin-panel-fab:hover{background:var(--bg-surface-hover);border-color:var(--border-focus)}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:300}.admin-modal{background:var(--bg-surface);border:1px solid var(--border-hover);border-radius:var(--radius-lg);padding:32px 40px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:20px}.admin-modal-text{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.admin-modal-close{padding:8px 24px;font-size:13px;font-weight:600;font-family:var(--font);background:var(--bg-raised);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.admin-modal-close:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--border-hover)}.admin-panel-container{background:var(--bg-raised);border:1px solid var(--border-hover);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:94vw;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.admin-panel-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;display:inline-flex;align-items:center;gap:8px}.admin-panel-tabs{display:flex;gap:2px;padding:8px 12px 0;border-bottom:1px solid var(--border)}.admin-panel-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;transition:all var(--transition-fast);margin-bottom:-1px}.admin-panel-tab:hover{color:var(--text-primary);background:transparent}.admin-panel-tab.active{color:var(--green);border-bottom-color:var(--green);background:transparent}.admin-panel-body{flex:1;overflow-y:auto;padding:12px}.admin-tab-content{display:flex;flex-direction:column;gap:8px}.admin-tab-header{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 8px}.admin-tab-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:8px}.admin-tab-count{font-size:11px;font-weight:500;color:var(--text-tertiary);background:var(--bg-surface);padding:1px 8px;border-radius:var(--radius-full);border:1px solid var(--border)}.admin-btn-icon{display:flex;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:500;background:var(--green);color:var(--text-inverse);border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast)}.admin-btn-icon:hover{background:#16a34a}.admin-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.admin-list-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast)}.admin-list-item:hover{border-color:var(--border-hover)}.admin-list-item-info{display:flex;flex-direction:column;gap:2px;flex:1}.admin-list-item-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-list-item-detail{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-list-item-meta{font-size:10px;color:var(--text-tertiary);font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-list-item-actions{display:flex;gap:4px;flex-shrink:0;align-items:center}.admin-btn-sm{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.admin-btn-sm:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--border-hover)}.admin-btn-sm-danger:hover{background:var(--red-dim);color:var(--red);border-color:var(--red-border)}.admin-list-item-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.admin-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:10px;font-weight:500;background:var(--green-dim);color:var(--green);border:1px solid var(--green-border);border-radius:var(--radius-full)}.admin-tag-remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;padding:0;font-size:12px;line-height:1;background:transparent;border:none;border-radius:50%;color:var(--green);cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}.admin-tag-remove:hover{opacity:1}.admin-crud-modal{background:var(--bg-raised);border:1px solid var(--border-hover);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:92vw;max-width:440px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.admin-crud-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.admin-crud-modal-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0}.admin-crud-modal-close-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.admin-crud-modal-close-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--border)}.admin-crud-modal-body{padding:18px;overflow-y:auto}.admin-form{display:flex;flex-direction:column;gap:14px}.admin-form-row{display:flex;gap:10px}.admin-form-row>.admin-form-field{flex:1}.admin-form-field{display:flex;flex-direction:column;gap:4px}.admin-form-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.admin-input{width:100%;padding:8px 10px;font-size:13px;font-family:var(--font);background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.admin-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 2px #ffffff0f}.admin-textarea{resize:vertical}select.admin-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a0a0a0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}select.admin-input option{background:var(--bg-surface);color:var(--text-primary)}.admin-form-error{font-size:11px;color:var(--red)}.admin-form-submit-error{font-size:12px;color:var(--red);margin:0;padding:6px 10px;background:var(--red-dim);border:1px solid var(--red-border);border-radius:var(--radius-sm)}.admin-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.admin-btn-danger{background:var(--red);color:#fff;border-color:transparent;font-weight:600}.admin-btn-danger:hover{background:#dc2626}.admin-confirm-message{font-size:13px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.admin-empty-state,.admin-loading-state,.admin-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 16px;color:var(--text-tertiary);font-size:13px}.admin-error-state{color:var(--red)}.admin-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:admin-spin .6s linear infinite}@keyframes admin-spin{to{transform:rotate(360deg)}}.admin-toast{position:fixed;bottom:72px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:500;background:var(--bg-surface);border:1px solid var(--border-hover);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:400;animation:admin-toast-in .2s ease}.admin-toast-success{color:var(--green);border-color:var(--green-border)}.admin-toast-error{color:var(--red);border-color:var(--red-border)}.admin-toast-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:transparent;border:none;border-radius:50%;color:inherit;cursor:pointer;opacity:.5}.admin-toast-close:hover{opacity:1}@keyframes admin-toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
