:root{--bg:#f1f5f9;--bg-card:#fff;--bg-nav:#ffffffb8;--bg-header:#f8fafc;--bg-hover:#f1f5ff;--bg-input:#fff;--border:#e2e8f0;--border-light:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#eef2ff;--accent-subtle:#6366f11a;--green:#10b981;--green-light:#ecfdf5;--amber:#f59e0b;--amber-light:#fffbeb;--red:#ef4444;--red-light:#fef2f2;--red-dark:#dc2626;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 20px #00000014;--shadow-lg:0 8px 40px #0000001a;--radius:16px;--radius-sm:10px;--radius-xs:8px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}html,body{max-width:100vw;overflow-x:hidden}body{background:var(--bg);min-height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}::selection{background:var(--accent-subtle);color:var(--accent)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}a{color:inherit;text-decoration:none}.navbar{z-index:50;background:var(--bg-nav);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px)saturate(180%);backdrop-filter:blur(16px)saturate(180%);position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;max-width:1280px;height:56px;margin:0 auto;padding:0 24px;display:flex}.navbar-brand{color:var(--text-primary);letter-spacing:-.03em;align-items:center;gap:10px;font-size:16px;font-weight:700;display:flex}.navbar-brand svg{color:var(--accent)}.navbar-badge{color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:600;display:flex}.navbar-badge:before{content:"";background:var(--green);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.page{max-width:1280px;margin:0 auto;padding:20px 24px 40px}.toolbar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:24px;transition:box-shadow .2s;overflow:hidden}.toolbar:hover{box-shadow:var(--shadow-md)}.toolbar-row{padding:12px 16px}.toolbar-row-forms{border-bottom:1px solid var(--border-light);flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toolbar-form{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.toolbar-form-group{flex:0 auto}.toolbar-form input{border:1px solid var(--border);background:var(--bg-input);min-width:120px;color:var(--text-primary);border-radius:var(--radius-sm);outline:none;flex:1;padding:9px 12px;font-size:13px;transition:border-color .2s,box-shadow .2s}.toolbar-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.toolbar-form input::placeholder{color:var(--text-muted)}.toolbar-btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:5px;padding:9px 16px;font-size:13px;font-weight:600;transition:background .15s,transform .1s;display:flex}.toolbar-btn-primary:hover{background:var(--accent-hover)}.toolbar-btn-primary:active{transform:scale(.97)}.toolbar-btn-primary:disabled{opacity:.5;cursor:default;transform:none}.toolbar-btn-secondary{border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;padding:9px 16px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.toolbar-btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.toolbar-btn-secondary:active{transform:scale(.97)}.toolbar-btn-secondary:disabled{opacity:.5;cursor:default;transform:none}.toolbar-divider{background:var(--border);flex-shrink:0;width:1px;height:28px}.toolbar-row-controls{justify-content:space-between;align-items:center;gap:12px;padding-top:10px;padding-bottom:10px;display:flex}.toolbar-count{color:var(--text-muted);letter-spacing:.01em;font-size:13px;font-weight:500}.toolbar-search{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);max-width:280px;color:var(--text-primary);outline:none;flex:1;padding:6px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.toolbar-search:focus{border-color:var(--accent)}.toolbar-search::placeholder{color:var(--text-muted)}.toolbar-controls{background:var(--bg);border-radius:var(--radius-xs);align-items:center;gap:3px;padding:3px;display:flex}.toolbar-controls button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;min-width:30px;padding:5px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:all .12s}.toolbar-controls button:hover{color:var(--text-secondary);background:var(--bg-hover)}.toolbar-controls button.active{background:var(--accent);color:#fff}.stream-group{margin-bottom:28px;animation:.3s ease-out fade-up}.stream-group-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;transition:box-shadow .2s;display:flex}.stream-group-header:hover{box-shadow:var(--shadow-md)}.stream-group-collapse{width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.stream-group-collapse:hover{background:var(--bg-hover);color:var(--text-secondary)}.stream-group-collapse svg{transition:transform .2s}.stream-group-collapse.is-collapsed svg{transform:rotate(-90deg)}.stream-group-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;flex:1;min-width:0;font-size:15px;font-weight:600;overflow:hidden}.stream-group-rename-input{border:2px solid var(--accent);background:var(--bg-input);max-width:300px;color:var(--text-primary);border-radius:var(--radius-xs);outline:none;flex:1;padding:5px 10px;font-size:14px;font-weight:600}.stream-group-count{color:var(--text-muted);background:var(--bg);border-radius:12px;flex-shrink:0;padding:2px 10px;font-size:12px;font-weight:600;line-height:1.6}.stream-group-actions{opacity:0;flex-shrink:0;gap:4px;transition:opacity .2s;display:flex}.stream-group-header:hover .stream-group-actions{opacity:1}.stream-group-empty{text-align:center;color:var(--text-muted);border:1.5px dashed var(--border);border-radius:var(--radius);background:var(--bg-card);padding:28px;font-size:13px}.stream-grid{gap:20px;animation:.3s ease-out fade-up;display:grid}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stream-grid.grid-1{grid-template-columns:repeat(1,minmax(0,1fr))}.stream-grid.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.stream-grid.grid-9{grid-template-columns:repeat(3,minmax(0,1fr))}.stream-card-wrapper{position:relative}.stream-card-actions{opacity:0;z-index:10;gap:5px;transition:opacity .2s;display:flex;position:absolute;top:8px;right:8px}.stream-card-wrapper:hover .stream-card-actions{opacity:1}.stream-card-actions:has(:focus-visible){opacity:1}.stream-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm);transition:box-shadow .25s,transform .2s;overflow:hidden}.stream-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stream-card-header{background:var(--bg-header);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.stream-card-header h3{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;font-size:13px;font-weight:600;overflow:hidden}.stream-card-meta{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:10px;padding:8px 14px;display:flex}.stream-card-meta small{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:500;overflow:hidden}.stream-card-meta button{border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-xs);cursor:pointer;flex-shrink:0;align-items:center;gap:4px;padding:4px 9px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s;display:flex}.stream-card-meta button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:3px 9px;font-size:10px;font-weight:700;display:inline-flex}.status-badge:before{content:"";border-radius:50%;width:5px;height:5px}.status-badge.running{background:var(--green-light);color:#059669}.status-badge.running:before{background:var(--green);animation:2s ease-in-out infinite pulse-dot}.status-badge.starting{background:var(--amber-light);color:#d97706}.status-badge.starting:before{background:var(--amber);animation:1s ease-in-out infinite pulse-dot}.status-badge.error,.status-badge.stopped{background:var(--red-light);color:#dc2626}.status-badge.error:before,.status-badge.stopped:before{background:var(--red)}.status-badge.idle{color:#64748b;background:#f1f5f9}.status-badge.idle:before{background:#94a3b8}.action-btn{border:1px solid var(--border);background:var(--bg-card);width:28px;height:28px;color:var(--text-secondary);border-radius:var(--radius-xs);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;font-size:12px;transition:all .15s;display:flex}.action-btn:hover{background:var(--bg);transform:scale(1.08)}.edit-btn:hover{border-color:var(--accent);color:var(--accent)}.delete-btn:hover{border-color:var(--red);color:var(--red)}.stream-card-editing{border:2px solid var(--accent);padding:18px;animation:.2s ease-out fade-up}.stream-card-deleting{text-align:center;padding:28px 24px;animation:.2s ease-out fade-up}.delete-confirm p{color:var(--text-primary);margin-bottom:16px;font-size:14px;font-weight:600}.edit-form-fields{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.edit-form-fields input{border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);border-radius:var(--radius-sm);outline:none;padding:10px 12px;font-size:13px;transition:border-color .2s,box-shadow .2s}.edit-form-fields input:focus,.edit-form-fields select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.edit-form-select{border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;appearance:auto;outline:none;padding:10px 12px;font-size:13px;transition:border-color .2s,box-shadow .2s}.edit-form-actions{gap:8px;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-xs);cursor:pointer;border:none;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:default;transform:none}.btn-secondary{border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-xs);cursor:pointer;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.btn-secondary:hover{border-color:var(--text-muted);color:var(--text-primary)}.btn-danger{background:var(--red);color:#fff;border-radius:var(--radius-xs);cursor:pointer;border:none;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.btn-danger:hover{background:var(--red-dark)}.btn-danger:active{transform:scale(.97)}.stream-video-container{aspect-ratio:16/9;background:#080b12;width:100%;position:relative;overflow:hidden}.stream-video{object-fit:cover;will-change:transform;background:#000;width:100%;height:100%;display:block}.stream-video-container-inner{will-change:transform;width:100%;height:100%}.stream-video-container-inner video{object-fit:cover;will-change:transform;background:#000;width:100%;height:100%;display:block}.stream-fullscreen{width:100%;height:100%;position:relative}.stream-fullscreen:fullscreen{background:#000;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.stream-fullscreen:fullscreen .stream-video-container-inner{width:100%;height:100%}.stream-fullscreen:fullscreen .stream-video-container-inner video{object-fit:cover;width:100%;height:100%}.stream-fullscreen-overlay{pointer-events:none;opacity:0;transition:opacity .35s;position:absolute;inset:0}.stream-fullscreen-overlay.is-visible{opacity:1;pointer-events:auto}.stream-fullscreen-top{background:linear-gradient(#000000b3 0%,#0000 100%);justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:absolute;top:0;left:0;right:0}.stream-fullscreen-name{color:#fff;text-shadow:0 1px 6px #00000080;font-size:15px;font-weight:600}.stream-fullscreen-exit{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff26;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .2s;display:flex}.stream-fullscreen-exit:hover{background:#ffffff2e}.stream-fullscreen-bottom{text-align:center;background:linear-gradient(#0000 0%,#000000b3 100%);padding:14px 20px;position:absolute;bottom:0;left:0;right:0}.stream-fullscreen-metrics{color:#ffffffa6;font-size:12px;font-weight:500}.stream-video-placeholder{color:#475569;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.video-placeholder-overlay{background:#080b12;position:absolute;inset:0}.stream-video-placeholder p{color:#64748b;font-size:12px;font-weight:500}.stream-video-placeholder-icon{color:#64748b;background:#141a26;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:all .3s;display:flex}.stream-video-placeholder-icon.starting{color:var(--amber);background:#f59e0b14;animation:1.5s ease-in-out infinite pulse-icon}@keyframes pulse-icon{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.stream-video-error{text-align:center;color:#ef4444;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:100%;padding:24px;display:flex}.stream-video-error p{color:#fca5a5;max-width:90%;font-size:12px;line-height:1.4}.stream-video-error .stream-video-error-hint{color:#94a3b8;font-size:11px}.stream-video-error .stream-video-error-hint code{background:#ffffff14;border-radius:4px;padding:1px 5px;font-size:11px}.stream-video-error>svg{color:#ef4444;opacity:.5;width:32px;height:32px}.stream-url-masked{color:var(--text-muted);word-break:break-all;padding:4px 8px;font-size:12px}.encoding-overrides{margin-top:8px}.encoding-overrides summary{cursor:pointer;color:var(--text-secondary);font-size:13px}.encoding-overrides-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-top:8px;display:grid}.encoding-overrides-grid label{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:12px;display:flex}.delete-confirm-inline{flex:1;align-items:center;gap:8px;display:flex}.empty-state{border:1.5px dashed var(--border);border-radius:var(--radius);background:var(--bg-card);text-align:center;padding:48px 24px;animation:.3s ease-out fade-up}.empty-state-icon{background:var(--accent-light);width:48px;height:48px;color:var(--accent);border-radius:14px;justify-content:center;align-items:center;margin:0 auto 14px;display:flex}.empty-state h2{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:6px;font-size:16px;font-weight:600}.empty-state p{color:var(--text-secondary);font-size:14px}.form-error{color:#dc2626;background:var(--red-light);border-radius:var(--radius-sm);border:1px solid #fecaca;margin-bottom:10px;padding:8px 12px;font-size:12px}@media (max-width:980px){.toolbar-row-forms{flex-direction:column;align-items:stretch}.toolbar-divider{display:none}.toolbar-form{flex:none}.stream-grid.grid-9,.stream-grid.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:760px){.navbar-inner{padding:0 16px}.navbar-badge span{display:none}.page{padding:12px 12px 32px}.toolbar-row{padding:10px 12px}.toolbar-form{flex-direction:column}.toolbar-form input{width:100%;min-width:0}.toolbar-form-group{width:100%}.stream-grid.grid-9,.stream-grid.grid-4,.stream-grid.grid-1{grid-template-columns:repeat(1,minmax(0,1fr))}}.public-grid{max-width:1600px;margin:0 auto;padding:16px}.public-grid .toolbar{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:12px;margin-bottom:20px;padding:10px 16px;display:flex}.search-box{flex:1;align-items:center;gap:8px;display:flex}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:14px}.search-box input::placeholder{color:var(--text-secondary)}.layout-toggles{gap:4px;display:flex}.layout-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-size:13px;transition:all .15s;display:flex}.layout-btn:hover{border-color:var(--accent);color:var(--text-primary)}.layout-btn-active{background:var(--accent);border-color:var(--accent);color:#fff}.group-section{margin-bottom:24px}.group-header{background:var(--bg-card);cursor:pointer;width:100%;color:var(--text-primary);border:none;border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;font-size:15px;font-weight:600;display:flex}.group-header:hover{background:var(--bg-hover)}.group-name{text-align:left;flex:1}.group-count{color:var(--text-secondary);background:var(--bg);border-radius:10px;padding:2px 8px;font-size:12px}.stream-grid{gap:12px;display:grid}.grid-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-9{grid-template-columns:repeat(3,minmax(0,1fr))}.stream-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.stream-card--public{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-sm);flex-direction:column;transition:box-shadow .25s,transform .2s,border-color .25s;display:flex}.stream-card--public:hover{box-shadow:var(--shadow-md);border-color:color-mix(in srgb, var(--accent) 25%, var(--border));transform:translateY(-2px)}.stream-card--public .stream-card-media{position:relative}.stream-video-wrapper--public{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.stream-video-wrapper--public.is-live{box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--green) 40%, transparent)}.stream-video-wrapper--dblclick{cursor:pointer}.stream-status-fps{opacity:.85;text-transform:none;letter-spacing:0;font-size:10px;font-weight:500}.stream-card-topbar{z-index:5;pointer-events:none;background:linear-gradient(#0000008c 0%,#0000 100%);justify-content:space-between;align-items:center;padding:8px 10px;display:flex;position:absolute;top:0;left:0;right:0}.stream-card-controls{opacity:0;pointer-events:none;gap:6px;margin-left:auto;transition:opacity .2s;display:flex}.stream-video-wrapper--public:hover .stream-card-controls{opacity:1;pointer-events:auto}.stream-card-controls:has(:focus-visible){opacity:1;pointer-events:auto}.stream-status-pill{pointer-events:auto;letter-spacing:.02em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;background:#00000073;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.stream-status-pill--running{background:color-mix(in srgb, var(--green) 75%, #0006)}.stream-status-pill--starting,.stream-status-pill--idle{background:color-mix(in srgb, var(--amber) 70%, #0006)}.stream-status-pill--error{background:color-mix(in srgb, var(--red) 75%, #0006)}.stream-status-pill--stopped{background:#64748bb3}.stream-status-dot{background:currentColor;border-radius:50%;width:7px;height:7px}.stream-status-pill--running .stream-status-dot{background:#fff;animation:1.5s ease-in-out infinite live-pulse}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.stream-control-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000073;border:1px solid #fff3;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex}.stream-control-btn:hover{background:#fff3}.stream-card-footer{border-top:1px solid var(--border-light);background:var(--bg-header);justify-content:space-between;align-items:center;gap:12px;min-height:44px;padding:10px 12px;display:flex}.stream-card-title{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.stream-live-dot{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:8px;height:8px}.stream-live-dot.is-active{background:var(--green);box-shadow:0 0 0 3px var(--green-light);animation:1.5s ease-in-out infinite live-pulse}.stream-card--public .stream-name{color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.stream-card-stats{flex-shrink:0;align-items:center;gap:10px;display:flex}.stream-stat{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:4px;font-size:11px;font-weight:500;display:inline-flex}.stream-stat--muted{color:var(--text-muted)}.stream-placeholder-skeleton{background:#0f172a}.skeleton-shimmer{border:3px solid #ffffff14;border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.9s linear infinite spin}.stream-retry-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff59;border-radius:8px;margin-top:8px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s}.stream-retry-btn:hover{background:#ffffff38}.public-grid .stream-grid{gap:16px}@media (hover:none){.stream-card-controls{opacity:1;pointer-events:auto}}@media (max-width:640px){.stream-card-footer{flex-direction:column;align-items:flex-start;gap:6px}.stream-card-stats{flex-wrap:wrap;width:100%}}.fs-overlay{z-index:9999;background:#000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.fs-content{width:100vw;height:100vh;position:relative}.fs-video-wrapper{width:100%;height:100%}.fs-video-wrapper .stream-video-wrapper{aspect-ratio:auto;width:100%;height:100%}.fs-video-wrapper .stream-video{object-fit:cover;width:100%;height:100%}.fs-video-wrapper .stream-placeholder{font-size:18px}.fs-video-wrapper .stream-info{display:none}.fs-close{z-index:10;color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s;display:flex;position:absolute;top:16px;right:16px}.fs-close:hover{background:#ffffff4d}.stream-video-wrapper{aspect-ratio:16/9;background:#000;width:100%;position:relative;overflow:hidden}.stream-video-wrapper:fullscreen{aspect-ratio:auto;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.stream-video-wrapper:fullscreen .stream-video{object-fit:contain;width:100%;height:100%}.stream-video{object-fit:contain;width:100%;height:100%;display:block}.stream-placeholder{color:#fff;background:#000000b3;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex;position:absolute;inset:0}.stream-placeholder-error{background:#b42828d9}.error-icon{color:#b42828;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;font-weight:700;display:flex}.error-text{text-align:center;word-break:break-word;max-width:100%;padding:0 16px;font-size:12px}.spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fullscreen-btn{z-index:10;color:#fff;cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:6px;padding:6px;transition:opacity .2s;position:absolute;bottom:8px;right:8px}.stream-video-wrapper:hover .fullscreen-btn{opacity:1}.stream-info{justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.stream-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.stream-metrics{color:var(--text-secondary);gap:8px;font-size:11px;display:flex}.empty-state{text-align:center;color:var(--text-secondary);padding:60px 20px}.admin-layout{background:var(--bg);min-height:calc(100vh - 57px);display:flex}.admin-loading{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.admin-loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.admin-login-page{background:radial-gradient(ellipse at 20% 0%, var(--accent-subtle) 0%, transparent 50%), var(--bg);justify-content:center;align-items:center;min-height:calc(100vh - 57px);padding:24px;display:flex}.admin-login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow-md);padding:36px 32px}.admin-login-brand{text-align:center;margin-bottom:28px}.admin-login-brand__icon{margin-bottom:14px;display:inline-flex;position:relative}.admin-login-shield{color:var(--accent);background:var(--bg-card);border-radius:50%;padding:2px;position:absolute;bottom:-4px;right:-4px}.admin-login-brand h1{margin:0 0 4px;font-size:22px}.admin-login-brand p{color:var(--text-secondary);margin:0;font-size:14px}.admin-login-card form{flex-direction:column;gap:16px;display:flex}.admin-login-card label{color:var(--text-secondary);text-align:left;flex-direction:column;gap:6px;font-size:13px;font-weight:500;display:flex}.admin-login-error{color:var(--red);text-align:center;margin:0;font-size:13px}.admin-sidebar{background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;padding:20px 12px;display:flex}.admin-sidebar__brand{align-items:center;gap:10px;padding:4px 12px 20px;display:flex}.admin-sidebar__logo{color:var(--accent);letter-spacing:.04em;font-size:18px;font-weight:700;display:block}.admin-sidebar__subtitle{color:var(--text-muted);font-size:12px}.admin-nav{flex-direction:column;flex:1;gap:4px;display:flex}.admin-nav__item{border-radius:var(--radius-xs);width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.admin-nav__item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav__item.is-active{background:var(--accent-light);color:var(--accent)}.admin-nav__badge{background:var(--bg);color:var(--text-muted);border-radius:999px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:600}.admin-nav__item.is-active .admin-nav__badge{background:var(--accent-subtle);color:var(--accent)}.admin-sidebar__footer{border-top:1px solid var(--border-light);flex-direction:column;gap:8px;padding-top:16px;display:flex}.admin-nav__link{color:var(--text-secondary);border-radius:var(--radius-xs);align-items:center;gap:8px;padding:8px 12px;font-size:13px;text-decoration:none;transition:background .15s;display:flex}.admin-nav__link:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-main{flex:1;min-width:0;padding:24px 28px;overflow-y:auto}.admin-topbar{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.admin-topbar h1{margin:0;font-size:24px;font-weight:700}.admin-topbar__sub{color:var(--text-secondary);margin:4px 0 0;font-size:13px}.admin-stats{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-bottom:24px;display:grid}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}.admin-stat-card--green{border-color:color-mix(in srgb, var(--green) 30%, var(--border));background:var(--green-light)}.admin-stat-card--red{border-color:color-mix(in srgb, var(--red) 30%, var(--border));background:var(--red-light)}.admin-stat-card__label{color:var(--text-secondary);margin-bottom:4px;font-size:12px;display:block}.admin-stat-card__value{color:var(--text-primary);font-size:26px;font-weight:700;line-height:1}.admin-stat-card__value--sm{font-size:18px}.admin-stat-card__value.is-ok{color:var(--green)}.admin-stat-card__value.is-bad{color:var(--red)}.admin-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.admin-search{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);flex:1;align-items:center;gap:8px;min-width:200px;padding:8px 12px;display:flex}.admin-search input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:14px}.admin-search svg{color:var(--text-muted);flex-shrink:0}.admin-filters{flex-wrap:wrap;gap:6px;display:flex}.admin-filter-chip{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:999px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.admin-filter-chip:hover{border-color:var(--accent);color:var(--text-primary)}.admin-filter-chip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.admin-camera-list{flex-direction:column;gap:8px;display:flex}.admin-camera-row{border:1px solid var(--border);border-radius:var(--radius-xs);transition:border-color .15s,box-shadow .15s;overflow:hidden}.admin-camera-row:hover{border-color:color-mix(in srgb, var(--accent) 25%, var(--border))}.admin-camera-row.is-expanded{box-shadow:var(--shadow-sm)}.admin-camera-row__main{background:var(--bg);align-items:center;gap:12px;padding:12px 14px;display:flex}.admin-camera-row__expand{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-camera-row__expand:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-camera-row__info{flex:1;min-width:0}.admin-camera-row__title{align-items:center;gap:10px;margin-bottom:4px;display:flex}.admin-camera-row__title h3{white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:15px;font-weight:600;overflow:hidden}.admin-camera-row__meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;display:flex}.admin-camera-row__meta code{background:var(--bg-card);word-break:break-all;border-radius:4px;padding:2px 6px;font-size:11px}.admin-camera-row__actions{flex-shrink:0;gap:4px;display:flex}.admin-camera-row__preview{background:var(--bg-card);border-top:1px solid var(--border-light);max-width:480px;padding:12px 14px 14px}.admin-camera-row__preview .stream-card{box-shadow:none;border:none}.admin-status{white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.admin-status--idle{background:var(--border-light);color:var(--text-secondary)}.admin-status--starting{background:var(--amber-light);color:#92400e}.admin-status--running{background:var(--green-light);color:#065f46}.admin-status--stopped{background:var(--border-light);color:var(--text-muted)}.admin-status--error{background:var(--red-light);color:var(--red-dark)}.admin-tag{background:var(--accent-light);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.admin-group-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:16px;display:grid}.admin-group-card{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);padding:16px}.admin-group-card__head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.admin-group-card__head h3{margin:0;font-size:15px;font-weight:600}.admin-group-card__rename{border:1px solid var(--accent);border-radius:6px;outline:none;flex:1;padding:6px 10px;font-family:inherit;font-size:14px}.admin-group-card__actions{gap:4px;display:flex}.admin-group-card__stats{color:var(--text-secondary);gap:12px;margin-bottom:10px;font-size:12px;display:flex}.admin-group-card__live{color:var(--green);font-weight:500}.admin-group-card__list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.admin-group-card__list li{color:var(--text-primary);align-items:center;gap:8px;font-size:13px;display:flex}.admin-group-card__dot{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:7px;height:7px}.admin-group-card__dot--running{background:var(--green)}.admin-group-card__dot--error{background:var(--red)}.admin-group-card__dot--starting{background:var(--amber)}.admin-inline-form{flex-wrap:wrap;gap:8px;display:flex}.admin-inline-form input{flex:1;min-width:200px}.admin-settings-section{border-bottom:1px solid var(--border-light);margin-bottom:28px;padding-bottom:24px}.admin-settings-section:last-of-type{border-bottom:none;margin-bottom:20px}.admin-settings-section h2{margin:0 0 6px;font-size:16px}.admin-hint{color:var(--text-secondary);margin:0 0 16px;font-size:13px}.admin-form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.admin-form-grid--compact{margin-top:12px}.admin-field{color:var(--text-secondary);flex-direction:column;gap:6px;font-size:13px;font-weight:500;display:flex}.admin-field--full{grid-column:1/-1}.admin-field input,.admin-field select,.admin-inline-form input{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);color:var(--text-primary);outline:none;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.admin-field input:focus,.admin-field select:focus,.admin-inline-form input:focus{border-color:var(--accent)}.admin-details{margin-top:16px}.admin-details summary{cursor:pointer;color:var(--text-secondary);font-size:13px;font-weight:500}.admin-form-error{color:var(--red);margin:8px 0 0;font-size:13px}.admin-btn{border-radius:var(--radius-xs);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:opacity .15s,background .15s;display:inline-flex}.admin-btn--primary{background:var(--accent);color:#fff}.admin-btn--primary:hover{opacity:.9}.admin-btn--primary:disabled{opacity:.5;cursor:not-allowed}.admin-btn--ghost{border:1px solid var(--border);color:var(--text-primary);background:0 0}.admin-btn--ghost:hover{background:var(--bg-hover)}.admin-btn--danger{background:var(--red);color:#fff}.admin-btn--danger:hover{opacity:.9}.admin-btn--block{width:100%}.admin-icon-btn{border-radius:var(--radius-xs);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.admin-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-icon-btn:disabled{opacity:.35;cursor:not-allowed}.admin-icon-btn--danger:hover{background:var(--red-light);color:var(--red)}.admin-modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.admin-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.admin-modal--sm{max-width:400px}.admin-modal__header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.admin-modal__header h2{margin:0;font-size:18px}.admin-modal__body{padding:20px}.admin-modal__footer{border-top:1px solid var(--border-light);justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.admin-empty{text-align:center;color:var(--text-secondary);padding:48px 20px}.admin-empty p{margin:0 0 16px}.stream-meta{color:var(--text-secondary);font-size:11px}.status-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.status-idle{color:#666;background:#f0f0f0}.status-starting{color:#856404;background:#fff3cd}.status-running{color:#155724;background:#d4edda}.status-stopped{color:#383d41;background:#e2e3e5}.status-error{color:#721c24;background:#f8d7da}@media (max-width:900px){.admin-layout{flex-direction:column}.admin-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap;align-items:center;width:100%;padding:12px}.admin-sidebar__brand{padding:0 8px}.admin-nav{flex-flow:wrap;flex:1}.admin-sidebar__footer{border-top:none;flex-direction:row;gap:4px;padding-top:0}.admin-nav__link{display:none}.admin-main{padding:16px}.admin-camera-row__main{flex-wrap:wrap}.admin-camera-row__actions{justify-content:flex-end;width:100%}}.navbar-links{gap:4px;margin-left:auto;display:flex}.nav-link{color:var(--text-secondary);border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:14px;text-decoration:none;transition:all .15s;display:inline-flex}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.navbar-logo{width:auto;height:28px;display:block}.navbar-brand{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:600;text-decoration:none;display:flex}@media (max-width:768px){.grid-4,.grid-9{grid-template-columns:repeat(1,minmax(0,1fr))}.settings-grid{grid-template-columns:1fr}.add-form{flex-direction:column}}
