body{color:#1f2937;background:#f4f5f7;margin:0;font-family:system-ui,Arial,sans-serif}:root[data-theme=light] body{color:#172033;background:#eef2f7}button,select,input{font:inherit}button{cursor:pointer;color:#fff;background:#2563eb;border:none;border-radius:10px;padding:10px 14px}button:disabled{opacity:.55;cursor:not-allowed}button.secondary{color:#111827;background:#e5e7eb}select,input{border:1px solid #d1d5db;border-radius:10px;padding:10px 12px}select{min-width:320px}.center,.login-page{place-items:center;min-height:100vh;display:grid}.login-card{background:#fff;border-radius:18px;width:360px;padding:24px;box-shadow:0 8px 24px #00000014}.login-card h1{margin:0}.login-card label{color:#4b5563;margin-top:14px;margin-bottom:6px;font-size:14px;display:block}.login-card input,.login-card button{box-sizing:border-box;width:100%}.login-card button{margin-top:18px}.app-header{color:#fff;background:#111827;justify-content:space-between;align-items:center;padding:24px;display:flex}.app-header h1{margin:0}:root[data-theme=light] .app-header{color:#172033;background:#fff;border-bottom:1px solid #d8deea}:root[data-theme=light] .app-header .muted{color:#667085}.theme-toggle{color:#111827;background:#e5e7eb;border:1px solid #0000;border-radius:6px;flex:0 0 34px;justify-content:center;align-items:center;width:34px;height:34px;padding:0;line-height:1;display:inline-flex}.theme-toggle:hover{color:#fff;background:#2563eb}.theme-toggle-icon{font-size:1rem;line-height:1}.muted{color:#9ca3af;margin-top:4px;font-size:14px}.panel{background:#fff;border-radius:16px;margin:24px;padding:16px;box-shadow:0 8px 24px #00000014}.room-controls{flex-wrap:wrap;gap:8px;display:flex}.room-status{color:#4b5563;margin-top:12px}.error{color:#b91c1c;margin-top:10px}.section-title{align-items:center;gap:12px;margin:0 24px 12px;display:flex}.section-title h2{margin:0}.badge{color:#374151;background:#e5e7eb;border-radius:999px;padding:4px 10px;font-size:13px}.empty{color:#6b7280;text-align:center;background:#fff;border-radius:16px;margin:0 24px 24px;padding:32px;box-shadow:0 8px 24px #00000014}.grid{grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:16px;margin:0 24px 24px;display:grid}.card{background:#fff;border-radius:16px;min-width:0;padding:12px;box-shadow:0 8px 24px #00000014}.card-header{justify-content:space-between;gap:8px;display:flex}.card h3{margin:0 0 4px;font-size:18px}.tile-actions{align-items:center;gap:8px;display:flex}.card.expanded{order:-1;grid-column:1/-1}.card.expanded .video-container{aspect-ratio:16/10;max-height:90vh}button.sm-button.active{color:#fff;background:#2563eb}.tile-controls{align-items:center;gap:6px;display:flex}.sm-button{padding:6px 10px;font-size:12px;font-weight:600}.video-layer video{background:#000;display:block;object-fit:contain!important;width:100%!important;height:100%!important}.video-layer:fullscreen video{object-fit:contain!important}.video-placeholder{background:#000;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.video-placeholder img{opacity:.7;width:120px}.exit-fullscreen-overlay{z-index:9999;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#1f2937cc;border:1px solid #fff3;border-radius:12px;padding:10px 20px;position:absolute;top:20px;right:20px}.exit-fullscreen-overlay:hover{background:#dc2626}@media (width<=600px){.card.expanded{grid-column:auto}}.status{color:#6b7280;margin-bottom:8px;font-size:14px}.status-dot{background:#9ca3af;border-radius:999px;width:10px;height:10px;margin-top:7px}.status-dot.online{background:#22c55e}.status-dot.streaming{background:#2563eb}.sm-button{border-radius:6px;padding:4px 8px;font-size:16px;line-height:1}.exit-fullscreen-btn{z-index:9999;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border:1px solid #ffffff4d;padding:8px 16px;transition:all .2s;position:absolute;top:20px;right:20px}.exit-fullscreen-btn:hover{background:#dc2626cc}.video-container:fullscreen+.card-header .sm-button{display:none}.log-panel{margin:0 24px 24px}.log{white-space:pre-wrap;background:#fff;border-radius:12px;max-height:220px;margin-top:8px;padding:12px;overflow:auto}.manage-page{--manage-bg:#12141c;--manage-sidebar:#1a1d29;--manage-card:#222738;--manage-border:#2e354f;--manage-accent:#4f46e5;--manage-accent-hover:#6366f1;--manage-text:#f3f4f6;--manage-muted:#9ca3af;background:var(--manage-bg);min-height:calc(100vh - 92px);color:var(--manage-text);margin-bottom:0;padding:24px}:root[data-theme=light] .manage-page{--manage-bg:#eef2f7;--manage-sidebar:#fff;--manage-card:#f7f9fc;--manage-border:#d8deea;--manage-accent:#4f46e5;--manage-accent-hover:#4338ca;--manage-text:#172033;--manage-muted:#667085}.manage-hero{background:var(--manage-sidebar);border:1px solid var(--manage-border);border-radius:8px;justify-content:space-between;align-items:stretch;gap:20px;padding:22px;display:flex}.manage-eyebrow{color:var(--manage-accent-hover);letter-spacing:.5px;text-transform:uppercase;font-size:.78rem;font-weight:700}.manage-hero h1{margin:0;font-size:2rem;line-height:1.15}.manage-heading{align-items:center;gap:12px;min-width:0;margin:8px 0;display:flex}.manage-group-avatar{border:2px solid var(--manage-border);background:var(--manage-accent);color:#fff;border-radius:50%;flex:0 0 48px;place-items:center;width:48px;height:48px;font-size:.95rem;font-weight:800;display:grid}.manage-hero p,.section-subtitle{color:var(--manage-muted);margin:0;font-size:.9rem}.manage-group-card{background:var(--manage-card);border:1px solid var(--manage-border);border-radius:8px;flex-direction:column;justify-content:center;gap:8px;width:min(360px,100%);padding:16px;display:flex}.manage-group-card label{color:var(--manage-muted);letter-spacing:.5px;text-transform:uppercase;font-size:.75rem;font-weight:700}.manage-group-card select{width:100%;min-width:0}.manage-group-stats{flex-wrap:wrap;gap:8px;display:flex}.manage-group-stats span{color:var(--manage-text);background:#ffffff14;border-radius:999px;padding:4px 8px;font-size:.78rem;font-weight:600}.manage-page .panel{background:var(--manage-sidebar);border:1px solid var(--manage-border);box-shadow:none;border-radius:8px;margin:16px 0 0}.manage-tabs-panel{padding:12px}.manage-page .section-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.manage-page .section-header h2{margin:0}.manage-page .error,.manage-error{color:#fca5a5}.manage-page button{background:var(--manage-accent);border-radius:6px}.manage-page button:hover:not(:disabled){background:var(--manage-accent-hover)}.manage-page button.secondary{background:var(--manage-card);color:var(--manage-muted);border:1px solid var(--manage-border)}.manage-page button.secondary:hover:not(:disabled){background:var(--manage-accent);color:#fff;border-color:var(--manage-accent)}.manage-page input,.manage-page select,.manage-page textarea{background:var(--manage-card);border-color:var(--manage-border);color:var(--manage-text);border-radius:6px}.manage-page input::placeholder{color:#6b7280}.manage-page table{background:var(--manage-sidebar)}.manage-page th,.manage-page td{border-bottom-color:var(--manage-border);color:var(--manage-text)}.manage-page th{color:var(--manage-muted)}.manage-page td code{color:var(--manage-text);background:#ffffff14}.manage-page .table-wrap{overflow-x:auto}.manage-page .secret-box{border:1px solid var(--manage-border);background:#0b1020}.manage-page .tabs a{background:var(--manage-card);border:1px solid var(--manage-border);color:var(--manage-muted);border-radius:6px}.manage-page .tabs a.active,.manage-page .tabs a:hover{background:var(--manage-accent);border-color:var(--manage-accent);color:#fff}.manage-page .theme-toggle{background:var(--manage-card);border-color:var(--manage-border);color:var(--manage-muted)}.manage-page .theme-toggle:hover{background:var(--manage-accent);border-color:var(--manage-accent);color:#fff}.form-row{flex-wrap:wrap;gap:8px;margin:16px 0;display:flex}.form-row input,.form-row select{min-width:180px}table{border-collapse:collapse;background:#fff;width:100%}th,td{text-align:left;border-bottom:1px solid #e5e7eb;padding:10px;font-size:14px}th{color:#4b5563;font-weight:600}.secret-box{color:#d1fae5;white-space:pre-wrap;background:#111827;border-radius:12px;margin-top:12px;padding:12px}.table-input{box-sizing:border-box;width:100%;min-width:140px;padding:8px 10px;font-size:14px}.checkbox-label{white-space:nowrap;color:var(--manage-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:14px;display:inline-flex}:root[data-theme=light] .checkbox-label{color:#374151}.actions-cell{flex-wrap:wrap;gap:8px;display:flex}td code{background:#f3f4f6;border-radius:6px;padding:3px 6px;font-size:13px}.participants-counts{color:#374151;align-items:center;gap:10px;display:inline-flex}.participant-count{white-space:nowrap;align-items:center;gap:5px;min-width:42px;font-size:14px;font-weight:600;display:inline-flex}.participant-icon{fill:currentColor;color:#4b5563;flex:0 0 18px;width:18px;height:18px}.main-nav{align-items:center;gap:12px;display:flex}.main-nav a,.tabs a{color:#111827;background:#e5e7eb;border-radius:10px;padding:10px 14px;text-decoration:none}.main-nav a.active,.tabs a.active{color:#fff;background:#2563eb}.tabs{flex-wrap:wrap;gap:8px;display:flex}button.danger{color:#fff;background:#dc2626}button.danger:hover{background:#b91c1c}.selected-row{background:#eff6ff}.compact-empty{box-shadow:none;background:var(--manage-card);color:var(--manage-muted);border:1px dashed var(--manage-muted);margin:12px 0 0}.modal-backdrop{z-index:1000;background:#1118279e;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:18px;flex-direction:column;width:min(900px,100%);max-height:calc(100vh - 48px);display:flex;overflow:hidden;box-shadow:0 24px 80px #00000047}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.modal-header h2{margin:0}.modal-body{padding:20px;overflow:auto}.modal-section{margin-top:16px}.modal-section:first-child{margin-top:0}.sessions-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.sessions-table-wrap{max-height:min(62vh,620px)}.session-status{border-radius:999px;justify-content:center;align-items:center;min-width:64px;padding:3px 8px;font-size:12px;font-weight:700;display:inline-flex}.session-status.active{color:#86efac;background:#22c55e29}.session-status.inactive{color:#4b5563;background:#6b728029}:root[data-theme=light] .session-status.active{color:#15803d;background:#22c55e29}.country-label{white-space:nowrap;align-items:center;gap:7px;display:inline-flex}.country-flag{font-size:1.1rem;line-height:1}.manage-page .modal{background:var(--manage-sidebar);border:1px solid var(--manage-border);color:var(--manage-text);border-radius:8px}.manage-page .modal-header{border-bottom-color:var(--manage-border)}.manage-page .session-status.inactive{color:var(--manage-muted)}.toast-notification{color:#fff;z-index:1000;border-radius:8px;padding:12px 24px;font-weight:500;animation:.3s ease-out slideIn;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #00000026}.toast-notification.success{background-color:#4caf50}.toast-notification.error{background-color:#f44336}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-message{flex-grow:1;margin-right:12px}.toast-notification:hover{filter:brightness(1.05)}.card{background:#fff;border-radius:8px;flex-direction:column;display:flex;position:relative;overflow:hidden}.card-control{box-sizing:border-box;z-index:20;opacity:0;pointer-events:none;background:#fffffffa;border-top:1px solid #e2e8f0;width:100%;padding:16px;transition:transform .25s ease-out,opacity .25s ease-out;position:absolute;bottom:0;left:0;transform:translateY(100%)}.card-control.open{opacity:1;pointer-events:auto;transform:translateY(0)}.card.expanded .card-control{border-left:1px solid #e2e8f0;border-top-left-radius:8px;width:320px;height:auto;left:auto;right:0;box-shadow:-4px 0 15px #00000014}.control-form{flex-direction:column;gap:12px;display:flex}.form-group{justify-content:space-between;align-items:center;gap:16px;display:flex}.form-group label{color:#4a5568;font-size:13px;font-weight:600}.form-group input{border:1px solid #cbd5e1;border-radius:6px;outline:none;width:140px;padding:6px 10px;font-size:14px;transition:border-color .2s}.form-group input:focus{border-color:#3b82f6}.apply-button{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:6px;margin-top:4px;padding:8px;font-weight:500;transition:background-color .2s}.apply-button:hover{background-color:#2563eb}.dashboard-shell{height:100dvh;overflow:hidden}.stream-dashboard{--bg-main:#12141c;--bg-sidebar:#1a1d29;--bg-card:#222738;--accent:#4f46e5;--accent-hover:#6366f1;--text-main:#f3f4f6;--text-muted:#9ca3af;--border:#2e354f;--danger:#ef4444;--profile-bg:#0003;--loader-track:#ffffff1f;--card-control-bg:#1a1d29fa;background:var(--bg-main);color:var(--text-main);height:100dvh;min-height:0;display:flex;overflow:hidden}:root[data-theme=light] .stream-dashboard{--bg-main:#eef2f7;--bg-sidebar:#fff;--bg-card:#f7f9fc;--accent:#4f46e5;--accent-hover:#4338ca;--text-main:#172033;--text-muted:#667085;--border:#d8deea;--danger:#dc2626;--profile-bg:#f7f9fc;--loader-track:#4f46e524;--card-control-bg:#fffffffa}.stream-sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;flex:0 0 320px;width:340px;min-height:0;display:flex}.mobile-sidebar-header,.mobile-sidebar-toggle,.mobile-sidebar-backdrop{display:none}.stream-brand{letter-spacing:1px;border-bottom:1px solid var(--border);color:var(--accent-hover);padding:20px;font-size:1.2rem;font-weight:700}.stream-sidebar-section{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;padding:15px 20px 5px;font-size:.75rem}.room-heading{justify-content:space-between;align-items:center;gap:10px;padding-top:1em;display:flex}.stream-dashboard .workspace-select{appearance:none;background-color:var(--bg-card);border:1px solid var(--border);width:calc(100% - 40px);min-width:0;color:var(--text-main);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:14px;border-radius:6px;outline:none;margin:10px 20px;padding:10px 36px 10px 10px}.stream-dashboard .workspace-select:disabled{opacity:1;color:var(--text-muted)}.stream-dashboard .room-list{flex-grow:1;min-height:0;margin:0;padding:.2rem 20px;list-style:none;overflow-y:auto}.stream-dashboard .room-list li{margin:0 0 10px}.stream-dashboard .room-item{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-main);cursor:pointer;text-align:left;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px;transition:transform .2s,border-color .2s,background .2s;display:flex}.stream-dashboard .room-item:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px)}.stream-dashboard .room-item.active{background:var(--accent);border-color:var(--accent)}:root[data-theme=light] .stream-dashboard .room-item.active{background:var(--accent);border-color:var(--accent);color:#fff}.room-name,.room-description{display:block}.room-name{font-weight:600}.room-description{color:var(--text-muted);margin-top:4px;font-size:.78rem;line-height:1.35}.room-item.active .room-description{color:#ffffffbf}.stream-dashboard .room-badge{color:var(--text-main);text-align:center;background:#ffffff1a;border-radius:12px;min-width:30px;padding:2px 8px;font-size:.8rem}.stream-dashboard .room-counters{flex-shrink:0;align-items:center;gap:6px;display:inline-flex}.stream-dashboard .room-counter{min-width:34px;color:var(--text-main);background:#ffffff1a;border-radius:12px;justify-content:center;align-items:center;gap:4px;padding:2px 7px;font-size:.8rem;font-weight:600;line-height:1.25;display:inline-flex}:root[data-theme=light] .room-counter{border:1px solid var(--border);background:#fff}.room-item.active .room-counter{color:#fff;border:1px solid var(--border);background:#ffffff1a}.stream-dashboard .room-counter-icon{fill:currentColor;opacity:.86;flex:0 0 13px;width:13px;height:13px}.sidebar-empty{color:var(--text-muted);padding:8px 0;font-size:.9rem}.icon-button{background:var(--bg-card);border:1px solid var(--border);width:28px;height:28px;color:var(--text-muted);border-radius:6px;padding:0;line-height:1}.icon-button:hover:not(:disabled){background:var(--accent);color:#fff}.stream-dashboard .user-profile{background:var(--profile-bg);border-top:1px solid var(--border);align-items:center;gap:12px;padding:15px 20px;display:flex}.stream-dashboard .user-avatar{border:2px solid var(--border);background:var(--accent);color:#fff;border-radius:50%;place-items:center;width:44px;height:44px;font-size:.85rem;font-weight:700;display:grid}.stream-dashboard .user-info{flex-direction:column;flex-grow:1;gap:4px;min-width:0;display:flex}.stream-dashboard .user-name,.stream-dashboard .user-role{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.stream-dashboard .user-name{color:var(--text-main);font-size:.95rem;font-weight:600}.stream-dashboard .user-role{color:var(--text-muted);font-size:.75rem}.stream-dashboard .admin-btn,.stream-dashboard .admin-link,.stream-dashboard .dashboard-action{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;padding:8px 10px;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .2s,color .2s,border-color .2s;display:inline-flex}:root[data-theme=light] .stream-dashboard .admin-btn,:root[data-theme=light] .stream-dashboard .admin-link,:root[data-theme=light] .stream-dashboard .dashboard-action,:root[data-theme=light] .profile-icon-btn{color:var(--text)}.stream-dashboard .admin-btn:hover,.stream-dashboard .admin-link:hover,.stream-dashboard .dashboard-action:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.profile-icon-btn{background:var(--bg-card);border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);border-radius:6px;flex:0 0 34px;justify-content:center;align-items:center;padding:0;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.profile-icon-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.stream-dashboard .theme-toggle{background:var(--bg-card);border-color:var(--border);color:var(--text-muted)}.stream-dashboard .theme-toggle:hover{background:var(--accent);border-color:var(--accent);color:#fff}.profile-action-icon{fill:currentColor;width:32px;height:24px}.stream-main{background:var(--bg-main);flex-direction:column;flex-grow:1;min-width:0;min-height:0;display:flex}.stream-top-bar{background:var(--bg-sidebar);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:20px;padding:20px;display:flex}.mobile-sidebar-toggle{background:var(--bg-card);border:1px solid var(--border);width:38px;height:38px;color:var(--text-main);border-radius:6px;flex-direction:column;flex:0 0 38px;justify-content:center;align-items:center;gap:4px;padding:0}.mobile-sidebar-toggle span{background:currentColor;border-radius:999px;width:16px;height:2px}.mobile-sidebar-toggle:hover{background:var(--accent);border-color:var(--accent);color:#fff}.stream-top-bar h1{color:var(--text-main);margin:0;font-size:1.5rem;line-height:1.2}.room-title{align-items:center;gap:10px;display:flex}.room-title-text{align-items:center;line-height:1;display:inline-flex}.room-connection-icon{background:#6b7280;border-radius:999px;flex:0 0 12px;width:12px;height:12px;box-shadow:0 0 0 4px #6b728024}.room-connection-icon.connected{background:#34d399;box-shadow:0 0 0 4px #34d39929,0 0 18px #34d3996b}.room-connection-icon.connecting{background:#fbbf24;animation:1.1s ease-in-out infinite connectionPulse;box-shadow:0 0 0 4px #fbbf2429}@keyframes connectionPulse{0%{opacity:.55;transform:scale(.9)}50%{opacity:1;transform:scale(1.12)}to{opacity:.55;transform:scale(.9)}}.top-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.connection-status{color:var(--text-muted);font-size:.9rem}.dashboard-error{color:#fca5a5;margin-top:6px;font-size:.9rem}.stream-grid{padding:20px 20px calc(20px + env(safe-area-inset-bottom,0px));flex-grow:1;grid-template-columns:repeat(3,minmax(0,1fr));place-content:start;gap:20px;min-height:0;display:grid;overflow-y:auto}.stream-dashboard .empty-state{min-height:320px;color:var(--text-muted);text-align:center;grid-column:1/-1;justify-content:center;align-items:center;display:flex}.stream-loading-state{min-height:320px;color:var(--text-muted);text-align:center;flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;gap:14px;display:flex}.stream-loader{border:3px solid var(--loader-track);border-top-color:var(--accent-hover);border-radius:50%;width:44px;height:44px;animation:.9s linear infinite loaderSpin}@keyframes loaderSpin{to{transform:rotate(360deg)}}.stream-card{background:var(--bg-card);aspect-ratio:16/10;border-radius:12px;flex-direction:column;width:100%;min-width:0;transition:transform .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.stream-card:not(.fullscreen-mode){border:1px solid var(--border)}.stream-card:not(.fullscreen-mode):hover{border-color:#6366f1b3;transform:scale(1.01)}.stream-card.fullscreen-mode{z-index:9999;aspect-ratio:auto;border-radius:0;width:100vw;max-width:none;height:100dvh;position:fixed;inset:0}.stream-card .video-container{background:#000;flex-grow:1;min-height:0;position:relative}.stream-card .video-layer{background:#000;position:absolute;inset:0}.stream-card .video-layer video{background:#000;display:block;object-fit:contain!important;width:100%!important;height:100%!important}.stream-card .video-placeholder{color:var(--text-muted);text-align:center;background:linear-gradient(135deg,#4f46e529,#000 70%);flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex;position:absolute;inset:0}.stream-card .video-placeholder img{opacity:.72;width:120px;max-width:35%}.live-indicator{color:#fff;background:#ef4444e6;border-radius:4px;align-items:center;gap:5px;padding:4px 8px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:12px;left:12px}.live-indicator.idle{background:#22c55ec7}.live-indicator:before{content:"";background:#fff;border-radius:50%;width:6px;height:6px;animation:1.5s infinite blink;display:inline-block}@keyframes blink{0%{opacity:.2}50%{opacity:1}to{opacity:.2}}.video-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex;position:absolute;bottom:12px;right:12px}.fullscreen-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:1px solid #fff3;border-radius:6px;padding:6px 10px;font-size:.8rem;transition:background .2s,border-color .2s}.fullscreen-btn:hover,.fullscreen-btn.active{background:var(--accent);border-color:var(--accent)}.stream-info{background:var(--bg-sidebar);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px;font-size:.9rem;display:flex}.stream-info strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.stream-meta{justify-content:flex-end;align-items:center;gap:8px;min-width:0;display:flex}.stream-quality{color:#34d399;white-space:nowrap}.stream-quality.offline{color:var(--text-muted)}.connection-quality{justify-content:center;align-items:flex-end;gap:2px;width:24px;height:18px;display:inline-flex}.connection-quality-bar{background:#94a3b873;border-radius:2px 2px 1px 1px;width:4px}.connection-quality-bar:first-child{height:6px}.connection-quality-bar:nth-child(2){height:10px}.connection-quality-bar:nth-child(3){height:14px}.connection-quality.excellent .connection-quality-bar{background:#10b981}.connection-quality.good .connection-quality-bar:nth-child(-n+2){background:#3b82f6}.connection-quality.poor .connection-quality-bar:first-child{background:#f59e0b}.connection-quality.lost .connection-quality-bar{background:#ef4444}.connection-quality.unknown .connection-quality-bar{background:#94a3b873}.stream-card .card-control{background:var(--card-control-bg);border-top:1px solid var(--border);color:var(--text-main)}.stream-card.fullscreen-mode .card-control{border-left:1px solid var(--border);width:320px;left:auto;right:0}.stream-card .form-group label{color:var(--text-muted)}.stream-card .form-group input{background:var(--bg-card);border-color:var(--border);color:var(--text-main)}@media (width<=1200px){.stream-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=800px){.manage-page{padding:16px}.manage-hero{flex-direction:column}.manage-heading h1{overflow-wrap:anywhere}.manage-group-card{width:100%}.manage-page .section-header{flex-direction:column}.stream-dashboard{flex-direction:row}.stream-sidebar{z-index:1001;border-right:1px solid var(--border);pointer-events:none;border-bottom:0;flex:none;width:min(86vw,340px);max-height:none;transition:transform .24s;position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:24px 0 60px #00000059}.stream-sidebar.open{pointer-events:auto;transform:translate(0)}.mobile-sidebar-backdrop{z-index:1000;background:#0000007a;border:0;border-radius:0;width:100%;height:100%;padding:0;display:block;position:fixed;inset:0}.stream-brand{display:none}.stream-brand.mobile{border-bottom:0;padding:0;display:block}.mobile-sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.mobile-sidebar-close{flex:0 0 28px}.stream-dashboard .user-profile{border-top:1px solid var(--border);border-bottom:0;padding:12px 16px}.stream-dashboard .room-list{flex:auto;max-height:none}.stream-main{flex:auto;width:100%}.stream-top-bar{flex-direction:row;justify-content:flex-start;align-items:flex-start}.mobile-sidebar-toggle{display:inline-flex}.stream-grid{grid-template-columns:1fr}.room-heading{padding-top:0}}
