:root{--sf-bg: #f8fafc;--sf-bg-gradient: linear-gradient(180deg, #f8fafc 0%, #eef2ff 100%);--sf-text: #0f172a;--sf-text-muted: #64748b;--sf-border: rgba(148, 163, 184, .24);--sf-card-bg: #ffffff;--sf-card-bg-gradient: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);--sf-input-bg: #ffffff;--sf-input-border: #cbd5e1;--sf-primary: #2563eb;--sf-primary-light: #dbeafe;--sf-primary-text: #1d4ed8;--sf-table-header-bg: #f8faff;--sf-table-border: #e2e8f0;--sf-topbar-bg: rgba(255, 255, 255, .85);--sf-sidebar-bg: linear-gradient(180deg, #0f172a 0%, #111827 100%);--sf-sidebar-text: #cbd5e1;--sf-sidebar-active-bg: linear-gradient(135deg, rgba(37, 99, 235, .36) 0%, rgba(59, 130, 246, .28) 100%);--sf-sidebar-active-text: #eff6ff;--sf-sidebar-hover-bg: rgba(148, 163, 184, .16);--sf-sidebar-brand: #e2e8f0;--sf-sidebar-subtitle: #93c5fd;--sf-sidebar-border: rgba(148, 163, 184, .22);--sf-sidebar-role-bg: linear-gradient(180deg, rgba(17, 24, 39, 0) 0%, #111827 35%, #111827 100%);--sf-modal-backdrop: rgba(15, 23, 42, .45);--sf-modal-bg: #ffffff;--sf-hover-row: #f8faff;--sf-selected-row: #eff6ff;--sf-skeleton-from: #e2e8f0;--sf-skeleton-via: #f1f5f9;--sf-success: #166534;--sf-error: #b91c1c;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--sf-text);background:var(--sf-bg);line-height:1.5}[data-theme=dark]{--sf-bg: #0f172a;--sf-bg-gradient: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);--sf-text: #e2e8f0;--sf-text-muted: #94a3b8;--sf-border: rgba(148, 163, 184, .15);--sf-card-bg: #1e293b;--sf-card-bg-gradient: linear-gradient(180deg, #1e293b 0%, #1a2436 100%);--sf-input-bg: #0f172a;--sf-input-border: #334155;--sf-primary: #3b82f6;--sf-primary-light: rgba(59, 130, 246, .18);--sf-primary-text: #93c5fd;--sf-table-header-bg: #1a2436;--sf-table-border: #334155;--sf-topbar-bg: rgba(30, 41, 59, .85);--sf-sidebar-bg: linear-gradient(180deg, #020617 0%, #0f172a 100%);--sf-sidebar-text: #94a3b8;--sf-sidebar-active-bg: linear-gradient(135deg, rgba(59, 130, 246, .3) 0%, rgba(37, 99, 235, .2) 100%);--sf-sidebar-active-text: #dbeafe;--sf-sidebar-hover-bg: rgba(148, 163, 184, .1);--sf-sidebar-brand: #e2e8f0;--sf-sidebar-subtitle: #60a5fa;--sf-sidebar-border: rgba(148, 163, 184, .12);--sf-sidebar-role-bg: linear-gradient(180deg, rgba(2, 6, 23, 0) 0%, #0f172a 35%, #0f172a 100%);--sf-modal-backdrop: rgba(0, 0, 0, .6);--sf-modal-bg: #1e293b;--sf-hover-row: rgba(59, 130, 246, .06);--sf-selected-row: rgba(59, 130, 246, .12);--sf-skeleton-from: #334155;--sf-skeleton-via: #1e293b;--sf-success: #4ade80;--sf-error: #f87171;color-scheme:dark}*{box-sizing:border-box}body{margin:0;color:var(--sf-text);background:var(--sf-bg-gradient)}a{color:inherit;text-decoration:none}.sf-shell{min-height:100vh;display:grid;grid-template-columns:248px 1fr}.sf-sidebar{background:var(--sf-sidebar-bg);border-right:1px solid var(--sf-sidebar-border);padding:1rem;display:flex;flex-direction:column;gap:1.2rem;position:sticky;top:0;height:100vh;overflow-y:auto}.sf-brand-wrap{display:grid;gap:.15rem}.sf-brand-title{color:var(--sf-sidebar-brand);font-weight:700}.sf-brand-subtitle{color:var(--sf-sidebar-subtitle);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.sf-nav{display:grid;gap:.35rem}.sf-nav-link{border-radius:10px;padding:.56rem .7rem;color:var(--sf-sidebar-text);font-size:.9rem}.sf-nav-link:hover{background:var(--sf-sidebar-hover-bg)}.sf-nav-link-active{background:var(--sf-sidebar-active-bg);color:var(--sf-sidebar-active-text)}.sf-main{display:flex;flex-direction:column}.sf-topbar{min-height:72px;border-bottom:1px solid var(--sf-border);background:var(--sf-topbar-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.85rem 1.2rem}.sf-topbar-title{margin:0;font-size:1.15rem;line-height:1.2;color:var(--sf-text)}.sf-topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.sf-role-wrap{display:grid;gap:.3rem;font-size:.8rem}.sf-sidebar-role-wrap{margin-top:auto;padding-top:.7rem;padding-bottom:.15rem;max-width:100%;position:sticky;bottom:0;border-top:1px solid var(--sf-sidebar-border);background:var(--sf-sidebar-role-bg)}.sf-sidebar-role-wrap .sf-muted{color:var(--sf-sidebar-subtitle)}.sf-sidebar-role-wrap .sf-select{width:100%;min-width:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%2364758b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"),linear-gradient(180deg,#fff,#f8fafc)}.sf-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;min-width:190px;min-height:36px;border-radius:10px;border:1px solid var(--sf-input-border);padding:0 2.1rem 0 .7rem;font:inherit;font-size:.82rem;line-height:1.15;color:var(--sf-text);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%2364758b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"),linear-gradient(180deg,var(--sf-input-bg) 0%,var(--sf-bg) 100%);background-position:right .68rem center,0 0;background-size:.9rem .9rem,100% 100%;background-repeat:no-repeat,no-repeat}.sf-select:focus{border-color:var(--sf-primary);outline:2px solid var(--sf-primary-light);outline-offset:0}.sf-content{padding:1.2rem}.sf-auth-shell{min-height:100vh;padding:1.1rem;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 500px at 10% -10%,#2563eb26,#2563eb00 60%),radial-gradient(900px 420px at 100% 0%,#0ea5e929,#0ea5e900 65%),linear-gradient(180deg,#f8fafc,#eef2ff)}.sf-auth-card{width:min(460px,100%);border:1px solid rgba(148,163,184,.28);border-radius:16px;background:#fffffff2;box-shadow:0 18px 44px #0f172a26;padding:1.1rem;display:grid;gap:.7rem}.sf-auth-brand{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#475569;font-weight:600}.sf-auth-title{margin:0;font-size:1.2rem;line-height:1.25;color:#0f172a}.sf-auth-login-btn{min-height:38px}.sf-auth-sidebar-value{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;border:1px solid rgba(147,197,253,.45);border-radius:999px;background:#dbeafe26;color:#dbeafe;padding:.2rem .6rem;font-size:.76rem;font-weight:700}.sf-stack{display:grid;gap:1rem}.sf-panel{border:1px solid var(--sf-border);border-radius:14px;background:var(--sf-card-bg-gradient);padding:1rem;display:grid;gap:.8rem}.sf-panel-head{display:flex;align-items:center;justify-content:space-between;gap:.7rem}.sf-panel h1,.sf-panel h2{margin:0}.sf-objects-filters{display:grid;gap:.65rem;grid-template-columns:repeat(4,minmax(0,1fr))}@media(max-width:1080px){.sf-objects-filters{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.sf-objects-filters{grid-template-columns:1fr}}.sf-muted{color:var(--sf-text-muted);margin:0}.sf-error{margin:0;color:var(--sf-error)}.sf-success{margin:0;color:var(--sf-success)}.sf-grid-stats{display:grid;gap:.7rem;grid-template-columns:repeat(4,minmax(0,1fr))}.sf-license-stats-grid{align-items:stretch}.sf-stat-card{border:1px solid var(--sf-border);border-radius:12px;background:var(--sf-card-bg);padding:.75rem;display:grid;gap:.2rem}.sf-stat-label{font-size:.79rem;color:var(--sf-text-muted)}.sf-stat-value{font-size:1.4rem;color:var(--sf-primary-text)}.sf-license-card-value{color:#0f172a;word-break:break-word}.sf-license-stat-card{background:linear-gradient(180deg,#fff,#f7fbff);border-color:#94a3b84d;gap:.35rem}.sf-license-stat-main{font-size:1.18rem;line-height:1.25}.sf-license-status-active{color:#166534;font-weight:600}.sf-license-status-expired{color:#b91c1c;font-weight:600}.sf-stat-hint{font-size:.8rem;color:#475569}.sf-list{margin:0;padding-left:1.2rem;display:grid;gap:.45rem}.sf-table-wrap{overflow-x:auto}.sf-table{width:100%;border-collapse:collapse;min-width:760px}.sf-table th,.sf-table td{border-bottom:1px solid var(--sf-table-border);text-align:left;padding:.55rem;font-size:.88rem}.sf-row-clickable{cursor:pointer}.sf-row-clickable:hover{background:var(--sf-hover-row)}.sf-row-selected{background:var(--sf-selected-row)}.sf-table th{color:var(--sf-text-muted);background:var(--sf-table-header-bg)}.sf-dt-scroll{position:relative;overflow-x:auto}.sf-dt-progress:before{content:"";position:absolute;left:0;top:0;height:2px;width:40%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#60a5fa);animation:sf-dt-progress-bar 1.2s ease-in-out infinite}@keyframes sf-dt-progress-bar{0%{left:-42%}50%{left:35%}to{left:100%}}.sf-dt-table{width:100%;min-width:680px;border-collapse:collapse;background:var(--sf-card-bg)}.sf-dt-table th,.sf-dt-table td{border-bottom:1px solid var(--sf-table-border);text-align:left;padding:.55rem;font-size:.88rem;vertical-align:top}.sf-dt-table th{color:var(--sf-text-muted);background:var(--sf-table-header-bg)}.sf-dt-col--sortable:hover{background:#f1f5f9}.sf-dt-table--striped tbody tr:nth-child(2n){background:#fcfdff}.sf-dt-empty{color:var(--sf-text-muted);text-align:center;padding:.95rem .55rem}.sf-dt-skel-cell{vertical-align:middle}.sf-dt-skel-bar{height:.7rem;border-radius:999px;background:linear-gradient(90deg,var(--sf-skeleton-from) 0%,var(--sf-skeleton-via) 50%,var(--sf-skeleton-from) 100%);animation:sf-dt-skel-pulse 1.35s ease-in-out infinite}.sf-pagination{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.8rem .1rem 0}.sf-page-list{display:flex;align-items:center;gap:.3rem}.sf-page-btn{min-width:2rem;height:2rem;border-radius:.5rem;border:1px solid #cbd5e1;background:#fff;color:#334155;font-size:.84rem;font-weight:600;cursor:pointer}.sf-page-btn:hover:not(:disabled){background:#f1f5f9}.sf-page-btn:disabled{opacity:.55;cursor:default}.sf-page-btn.is-active{border-color:#2563eb;background:#dbeafe;color:#1d4ed8}.sf-page-sep{color:#94a3b8;padding:0 .1rem}.sf-objects-pagination{margin-top:.2rem}@keyframes sf-dt-skel-pulse{0%{opacity:.64}50%{opacity:1}to{opacity:.64}}.sf-table-text-capitalize{text-transform:capitalize}.sf-pill{display:inline-block;border:1px solid transparent;border-radius:.375rem;padding:.24rem .52rem;font-size:.75rem;font-weight:700;line-height:1;vertical-align:baseline}.sf-pill-active{background:#d1e7dd;border-color:#badbcc;color:#0f5132}.sf-pill-trial{background:#fff3cd;border-color:#ffecb5;color:#664d03}.sf-pill-warning{background:#ffc107;border-color:#ffc107;color:#212529}.sf-pill-suspended{background:#dc3545;border-color:#dc3545;color:#fff}.sf-pill-secondary{background:#e2e3e5;border-color:#d3d6d8;color:#41464b}.sf-pill-role-leader{background:#ffc107;border-color:#ffc107;color:#212529}.sf-pill-role-master{background:#0d6efd;border-color:#0d6efd;color:#fff}.sf-pill-role-worker{background:#6c757d;border-color:#6c757d;color:#fff}.sf-pill-role-recorder{background:#cfe2ff;border-color:#b6d4fe;color:#084298}.sf-pill-role-streamer{background:#cff4fc;border-color:#b6effb;color:#055160}.sf-inline-form{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.sf-input{min-height:36px;min-width:210px;border-radius:10px;border:1px solid #cbd5e1;padding:0 .7rem;font:inherit;color:#0f172a;background:#fff}.sf-input:focus{border-color:#2563eb;outline:2px solid #bfdbfe;outline-offset:0}.sf-check-grid{display:grid;gap:.35rem;grid-template-columns:repeat(2,minmax(0,1fr))}.sf-check-row{display:inline-flex;align-items:center;gap:.5rem;color:#334155;font-size:.82rem}.sf-check-row input[type=checkbox]{width:.95rem;height:.95rem;accent-color:#2563eb}.sf-toggle-segment,.sf-toggle-action-grid{display:flex;flex-wrap:wrap;gap:.4rem}.sf-toggle-chip{border:1px solid #cbd5e1;border-radius:999px;background:#f8fafc;color:#334155;padding:.33rem .72rem;font-size:.8rem;line-height:1.2;cursor:pointer;transition:border-color .15s ease,background-color .15s ease,color .15s ease}.sf-toggle-chip:hover{border-color:#94a3b8;background:#f1f5f9}.sf-toggle-chip:focus-visible{outline:2px solid #bfdbfe;outline-offset:1px}.sf-toggle-chip-active{border-color:#2563eb;background:#dbeafe;color:#1d4ed8;font-weight:600}.sf-toggle-chip-wrap{white-space:normal;text-align:left}.sf-cluster-metrics{display:flex;align-items:center;gap:.4rem;margin-bottom:.7rem;flex-wrap:wrap}.sf-cluster-metrics-header{margin-bottom:0;justify-content:flex-end}.sf-cluster-sections{display:grid;gap:.75rem}.sf-cluster-section{border:1px solid #dbe2ee;border-radius:12px;background:#fff;padding:.75rem;display:grid;gap:.7rem}.sf-cluster-section-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.sf-cluster-section-title{margin:0;font-size:.95rem;color:#0f172a}.sf-action-row{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.sf-view-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.84rem;color:#334155;-webkit-user-select:none;user-select:none}.sf-view-toggle input{width:1rem;height:1rem;flex-shrink:0;accent-color:#2563eb}.sf-switch{display:inline-flex;align-items:center;gap:.45rem;border:0;background:transparent;padding:0;color:#475569;cursor:pointer}.sf-switch:disabled{opacity:.6;cursor:not-allowed}.sf-switch:focus-visible{outline:2px solid #bfdbfe;outline-offset:2px;border-radius:999px}.sf-switch-track{width:2rem;height:1.1rem;border-radius:999px;background:#cbd5e1;position:relative;transition:background-color .2s ease}.sf-switch-thumb{position:absolute;top:2px;left:2px;width:.85rem;height:.85rem;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0f172a4d;transition:transform .2s ease}.sf-switch-on .sf-switch-track{background:#2563eb}.sf-switch-on .sf-switch-thumb{transform:translate(.9rem)}.sf-switch-label{min-width:2.6rem;font-size:.82rem;color:#334155}.sf-switch-text{font-size:.9rem;color:#334155}.sf-node-grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.sf-node-card{border:1px solid #dbe2ee;border-radius:12px;background:#fff;padding:.75rem;display:grid;gap:.6rem}.sf-node-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.6rem}.sf-node-name{font-weight:700;color:#0f172a}.sf-node-addr{font-size:.8rem;color:#64748b}.sf-node-storage{font-size:.84rem;color:#334155}.sf-storage-progress{display:grid;gap:.28rem}.sf-storage-progress-head{display:flex;justify-content:space-between;align-items:center;gap:.6rem;font-size:.8rem;color:#334155}.sf-storage-progress-track{width:100%;height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.sf-storage-progress-fill{height:100%;border-radius:inherit}.sf-storage-progress-fill-low{background:linear-gradient(90deg,#34d399,#16a34a)}.sf-storage-progress-fill-medium{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.sf-storage-progress-fill-high{background:linear-gradient(90deg,#fb923c,#ea580c)}.sf-storage-progress-fill-critical{background:linear-gradient(90deg,#f87171,#dc2626)}.sf-textarea{width:100%;border:1px solid #cbd5e1;border-radius:10px;padding:.65rem .75rem;font:inherit;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;color:#0f172a;background:#fff;resize:vertical}.sf-textarea:focus{border-color:#2563eb;outline:2px solid #bfdbfe;outline-offset:0}.sf-btn{border:1px solid transparent;border-radius:10px;padding:.44rem .7rem;font-size:.84rem;cursor:pointer}.sf-btn:disabled{cursor:wait;opacity:.65}.sf-btn-secondary{border-color:var(--sf-border);background:var(--sf-input-bg);color:var(--sf-text)}.sf-btn-warning{border-color:#d9770673;background:#ffedd5;color:#9a3412}.sf-btn-danger{border-color:#dc262666;background:#fee2e2;color:#991b1b}.sf-modal-backdrop{position:fixed;inset:0;z-index:1000;background:var(--sf-modal-backdrop);display:flex;align-items:center;justify-content:center;padding:1rem}.sf-modal{width:min(460px,100%);border:1px solid var(--sf-border);border-radius:14px;background:var(--sf-modal-bg);box-shadow:0 20px 48px #0f172a3d;display:grid;gap:.75rem;padding:.9rem;max-height:calc(100vh - 2rem);overflow-y:auto}.sf-modal-wide{width:min(560px,100%)}.sf-modal-user{width:min(920px,100%)}.sf-modal-camera{width:min(1100px,100%)}.sf-modal-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.sf-modal-title{margin:0;font-size:1rem;color:#0f172a}.sf-modal-close{min-width:36px;min-height:36px;padding:0;line-height:1}.sf-modal-body{display:grid;gap:.4rem}.sf-modal-label{font-size:.82rem;color:#334155}.sf-modal-select{width:100%;min-width:0}.sf-rs__control{min-height:36px;border:1px solid #cbd5e1;border-radius:10px;box-shadow:none}.sf-rs__control--is-focused{border-color:#2563eb;box-shadow:0 0 0 2px #bfdbfe}.sf-rs__value-container{padding:0 8px}.sf-rs__input-container,.sf-rs__single-value,.sf-rs__placeholder{font-size:.84rem}.sf-rs__menu{z-index:20;border:1px solid rgba(148,163,184,.4);box-shadow:0 12px 24px #0f172a1f}.sf-modal-actions{display:flex;justify-content:flex-end;gap:.5rem}.sf-fleet-provider-row{display:flex;flex-wrap:wrap;gap:.45rem}.sf-list-with-side-filters,.sf-cameras-layout{display:grid;gap:.85rem;grid-template-columns:minmax(0,1fr) 280px}.sf-side-filters{border:1px solid #dbe2ee;border-radius:12px;background:#fff;padding:.75rem;display:grid;gap:.5rem;align-content:start}.sf-side-filters-title{margin:0;font-size:.95rem;color:#0f172a}.sf-side-filters-summary{border-top:1px solid #e2e8f0;padding-top:.45rem;display:grid;gap:.15rem}.sf-fleet-toolbar{justify-content:flex-end}.sf-fleet-filters{display:grid;gap:.75rem;grid-template-columns:repeat(4,minmax(0,1fr))}.sf-fleet-filters-compact{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.sf-fleet-filters-compact .sf-select{min-width:160px;min-height:34px;font-size:.8rem}.sf-fleet-search{min-width:280px;flex:1 1 280px}.sf-fleet-scope-list{display:grid;gap:.8rem}.sf-fleet-scope-card{border:1px solid #dbe2ee;border-radius:12px;background:#fff;padding:.85rem;display:grid;gap:.75rem}.sf-fleet-scope-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.sf-fleet-scope-title{margin:0;font-size:1rem}.sf-fleet-scope-table{min-width:680px}.sf-fleet-node-grid{display:grid;gap:.75rem;grid-template-columns:repeat(3,minmax(0,1fr))}.sf-fleet-table-wrap .sf-dt-table{min-width:680px}.sf-fleet-col-actions{width:118px;white-space:nowrap}.sf-fleet-role-cell{display:grid;gap:.35rem}.sf-fleet-role-line{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.sf-fleet-runtime-badges{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}.sf-fleet-resources{display:grid;gap:.4rem;min-width:240px}.sf-fleet-metric{display:grid;grid-template-columns:74px minmax(0,1fr);align-items:center;gap:.45rem}.sf-fleet-metric-label{font-size:.74rem;color:#334155;white-space:nowrap}.sf-fleet-progress-track{position:relative;width:100%;height:16px;border-radius:999px;background:#e2e8f0;overflow:hidden}.sf-fleet-progress-track .sf-storage-progress-fill{position:absolute;inset:0 auto 0 0}.sf-fleet-progress-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:#0f172a;text-shadow:0 1px 0 rgba(255,255,255,.7)}.sf-fleet-action-buttons{gap:.35rem}.sf-fleet-create-form{display:grid;gap:.35rem}.sf-user-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.sf-user-form-col{display:grid;gap:.4rem;align-content:start;min-width:0}.sf-user-form-grid>.sf-muted{grid-column:1 / -1}.sf-fleet-create-form .sf-input,.sf-fleet-create-form .sf-select{width:100%;min-width:0}.sf-object-coords-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.sf-object-coords-row>div{min-width:0}.sf-camera-discovery-top{display:grid;grid-template-columns:1.2fr 1fr 1fr auto;gap:.65rem;align-items:end}.sf-camera-discovery-action{display:flex;align-items:end}.sf-camera-layout{display:grid;gap:.9rem;grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start}.sf-camera-preview-pane{display:grid;gap:.55rem}.sf-camera-preview-box{min-height:260px;border:1px solid rgba(148,163,184,.4);border-radius:10px;background:#f8fafc;display:flex;align-items:center;justify-content:center;padding:.35rem}.sf-camera-preview-image{width:100%;max-height:320px;object-fit:contain;border-radius:8px}.sf-camera-fields-pane{min-width:0}.sf-camera-form-rows{display:grid;gap:.6rem}.sf-camera-form-row{display:grid;gap:.65rem;align-items:end}.sf-camera-form-row>div{min-width:0}.sf-camera-form-row-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sf-camera-form-row-1{grid-template-columns:minmax(0,1fr)}.sf-camera-form-row-tags{grid-template-columns:minmax(0,1fr) auto auto}.sf-camera-form-row-tags .sf-check-row{margin:0}.sf-fleet-filters-form{display:grid;gap:.35rem}.sf-fleet-filters-form .sf-input,.sf-fleet-filters-form .sf-select{width:100%;min-width:0}.sf-icon-btn{min-width:32px;min-height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:.95rem;font-weight:700}.sf-toasts{position:fixed;bottom:1rem;right:1rem;z-index:1200;display:grid;gap:.55rem;width:min(420px,calc(100vw - 2rem));pointer-events:none}.sf-toast{pointer-events:auto;display:grid;grid-template-columns:1fr auto;align-items:start;gap:.5rem;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#fff;color:#0f172a;box-shadow:0 10px 25px #0f172a26;padding:.6rem .7rem}.sf-toast--info{border-left:4px solid #0284c7}.sf-toast--success{border-left:4px solid #16a34a}.sf-toast--warning{border-left:4px solid #ca8a04}.sf-toast--error{border-left:4px solid #dc2626}.sf-toast__msg{font-size:.92rem;line-height:1.35;word-break:break-word}.sf-toast__close{border:none;background:transparent;color:#334155;cursor:pointer;padding:0;width:24px;height:24px;line-height:24px;font-size:1.1rem}@media(max-width:1040px){.sf-shell{grid-template-columns:1fr}.sf-sidebar{border-right:0;border-bottom:1px solid rgba(148,163,184,.22);position:static;top:auto;height:auto;overflow-y:visible}.sf-sidebar-role-wrap{position:static;bottom:auto;background:transparent}.sf-grid-stats,.sf-fleet-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.sf-list-with-side-filters,.sf-cameras-layout{grid-template-columns:1fr}.sf-fleet-node-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sf-topbar{align-items:flex-start;flex-direction:column}.sf-topbar-actions{width:100%;justify-content:flex-start}.sf-user-form-grid,.sf-camera-discovery-top,.sf-camera-layout,.sf-camera-form-row-2,.sf-camera-form-row-tags,.sf-object-coords-row{grid-template-columns:1fr}.sf-toasts{left:.85rem;right:.85rem;bottom:.85rem;width:auto}}@media(max-width:640px){.sf-content{padding:.85rem}.sf-grid-stats,.sf-fleet-filters,.sf-check-grid{grid-template-columns:1fr}.sf-fleet-filters-compact{flex-direction:column;align-items:stretch}.sf-fleet-filters-compact .sf-select,.sf-fleet-search{width:100%;min-width:0}.sf-fleet-scope-head{flex-direction:column}.sf-fleet-node-grid{grid-template-columns:1fr}.sf-fleet-resources{min-width:180px}.sf-cluster-metrics-header{justify-content:flex-start}}.sf-btn-ghost{border:none;background:transparent;color:var(--sf-text-muted);cursor:pointer;padding:.32rem .52rem;border-radius:8px;font-size:1.1rem;line-height:1}.sf-btn-ghost:hover{background:var(--sf-hover-row)}.sf-branding-form{display:grid;gap:1.2rem}.sf-branding-section h3{margin:0 0 .5rem;font-size:.95rem;color:var(--sf-text)}.sf-branding-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.sf-branding-field{display:grid;gap:.25rem}.sf-branding-label{font-size:.82rem;color:var(--sf-text-muted)}.sf-branding-color-row{display:flex;gap:.5rem;align-items:center}.sf-branding-color-picker{width:36px;height:36px;border:1px solid var(--sf-border);border-radius:8px;padding:2px;cursor:pointer;background:none}.sf-branding-color-hex{flex:1;font-family:monospace}.sf-branding-actions{display:flex;gap:.5rem;justify-content:flex-end}.sf-branding-theme-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.sf-branding-preview-colors{display:flex;gap:.75rem}.sf-branding-swatch{width:72px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;text-shadow:0 1px 2px rgba(0,0,0,.4)}.sf-pill-online{background:#d1e7dd;border-color:#badbcc;color:#0f5132}.sf-pill-offline{background:#dc3545;border-color:#dc3545;color:#fff}.sf-object-grid{display:grid;gap:.64rem;grid-template-columns:repeat(2,minmax(0,1fr))}.sf-object-card{border:1px solid var(--sf-border);border-radius:10px;background:var(--sf-card-bg);padding:.62rem;display:grid;gap:.36rem}.sf-map-page{min-height:calc(100vh - 94px)}.sf-map-only-wrap{position:relative;border:1px solid rgba(148,163,184,.24);border-radius:12px;overflow:hidden;min-height:calc(100vh - 124px);background:#e2e8f0}.sf-map-only-wrap .leaflet-container{width:100%;height:100%;min-height:calc(100vh - 124px)}.sf-map-only-wrap .leaflet-control{z-index:800}.sf-map-only-wrap .leaflet-control-attribution{display:none!important}.sf-map-status{position:absolute;top:.68rem;left:.68rem;z-index:1200;display:flex;align-items:center;gap:.4rem}.sf-map-chip{display:inline-flex;align-items:center;border-radius:999px;padding:.18rem .54rem;background:#0f172ab8;color:#e2e8f0;font-size:.72rem;font-weight:600}.sf-map-chip-error{background:#b91c1cd1;color:#fff}.sf-map-filter-toggle{position:absolute;top:.68rem;right:.68rem;z-index:1200;border:1px solid rgba(148,163,184,.4);border-radius:8px;background:#fffffff0;color:#0f172a;padding:.34rem .52rem;font-size:.78rem;font-weight:600;cursor:pointer}.sf-map-filter{position:absolute;top:2.9rem;right:.68rem;z-index:1200;width:min(300px,calc(100vw - 2rem));border:1px solid rgba(148,163,184,.35);border-radius:10px;background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.58rem;display:grid;gap:.46rem;transform:translateY(-8px);opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease}.sf-map-filter-open{transform:translateY(0);opacity:1;pointer-events:auto}.sf-map-filter-label{display:grid;gap:.3rem;font-size:.8rem}.sf-map-check{display:inline-flex;align-items:center;gap:.34rem;font-size:.8rem}.sf-cluster-icon-wrap,.sf-single-icon-wrap{background:transparent!important;border:0!important;box-shadow:none!important}.sf-map-marker{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;border:2px solid rgba(255,255,255,.97);box-shadow:0 6px 14px #0f172a4d}.sf-map-marker-single{position:relative;width:34px;height:34px;font-size:14px}.sf-map-marker-single i{position:relative;z-index:2;line-height:1}.sf-map-marker-fallback{position:absolute;left:50%;top:50%;transform:translate(-50%,-53%);z-index:1;font-size:17px;line-height:1}.sf-map-marker-cluster{width:42px;height:42px;color:#0f172a;font-size:.75rem;font-weight:700}.sf-map-marker-cluster-muted{opacity:.42;filter:saturate(.6)}.sf-map-popup-btn{margin-top:.45rem;display:inline-flex;align-items:center;gap:.38rem;padding:.42rem .65rem}.sf-cluster-icon{width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.96);color:#0f172a;font-size:.75rem;font-weight:700;box-shadow:0 6px 14px #0f172a40}.sf-cluster-icon>span{line-height:1}.sf-cluster-icon-small,.sf-cluster-icon-medium{color:#0f172a}.sf-cluster-icon-large{color:#fff}.sf-map-card{border:1px solid rgba(148,163,184,.24);border-radius:10px;background:#fff;padding:.62rem;display:grid;gap:.52rem}.sf-city-map{height:280px;border:1px solid rgba(148,163,184,.28);border-radius:8px;overflow:hidden}.sf-city-map .leaflet-container{width:100%;height:100%}.sf-coord-grid{display:grid;gap:.38rem;grid-template-columns:repeat(2,minmax(0,1fr))}.sf-coord-row{border:1px solid rgba(148,163,184,.24);border-radius:8px;padding:.4rem .48rem;background:#f8fafc;display:grid;gap:.14rem;font-size:.79rem}.sf-camera-list{display:grid;gap:.34rem}.sf-camera-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.82rem}.sf-camera-snapshot{display:block;width:168px;height:96px;border-radius:8px;border:1px solid rgba(148,163,184,.24);object-fit:cover;background:#0f172a}.sf-form{display:grid;gap:.55rem}.sf-form label{display:grid;gap:.28rem;font-size:.82rem;font-weight:600}.sf-form input,.sf-form select{width:100%;min-height:36px;border-radius:10px;border:1px solid var(--sf-input-border);padding:0 2.1rem 0 .7rem;font:inherit;font-size:.82rem;color:var(--sf-text);line-height:1.15;background:var(--sf-input-bg)}.sf-form input:focus,.sf-form select:focus{border-color:var(--sf-primary);outline:2px solid var(--sf-primary-light);outline-offset:0}.sf-row-between{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sf-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-section-title{margin:0}.sf-row-active td{background:var(--sf-selected-row)}.sf-pagination-text{font-size:.8rem;color:var(--sf-text-muted)}.sf-wall-grid{display:grid;gap:.56rem;grid-template-columns:repeat(3,minmax(0,1fr))}.sf-stream-card{border:1px solid var(--sf-border);border-radius:10px;background:var(--sf-card-bg);overflow:hidden;display:grid;gap:0}.sf-stream-preview{height:169px;border-radius:8px;margin:.5rem .5rem 0;background:#000;display:grid;place-items:center;overflow:hidden}.sf-stream-video{display:block;width:100%;height:100%;object-fit:cover;background:#020617}.sf-stream-body{padding:.55rem;display:grid;gap:.2rem}.sf-stream-meta{display:inline-flex;align-items:center;gap:.35rem}.sf-stream-badge{display:inline-block;border:1px solid #d3d6d8;border-radius:.375rem;padding:.24rem .52rem;background:#e2e3e5;color:#41464b;font-size:.75rem;font-weight:700;line-height:1}.sf-stream-dot{display:inline-block;width:8px;height:8px;border-radius:999px}.sf-stream-dot-online{background:#16a34a}.sf-stream-dot-warning{background:#d97706}.sf-stream-dot-offline{background:#dc2626}.sf-archive-actions{display:flex;align-items:end;gap:.5rem}.sf-archive-filter{display:grid;gap:.24rem}.sf-archive-select{min-width:220px}.sf-archive-row-actions{display:flex;gap:.32rem}.sf-player-wrap{position:relative;border:1px solid rgba(148,163,184,.26);border-radius:10px;overflow:hidden;background:#0f172a;isolation:isolate}.sf-player-wrap .media-element-wrapper{width:100%;min-height:320px}.sf-player-wrap-archive{width:70%;margin:0 auto}.sf-player-wrap-archive .media-element-wrapper{min-height:224px}.sf-player-wrap .media-element-wrapper video{display:block}.sf-player-wrap .mejs__container,.sf-player-wrap .mejs__mediaelement,.sf-player-wrap .mejs__layers,.sf-player-wrap .mejs__overlay,.sf-player-wrap .mejs__poster{width:100%!important;height:100%!important}.sf-player-wrap .mejs__overlay-button,.sf-player-wrap .mejs__controls{display:none!important}.sf-player-wrap .media-element-wrapper:fullscreen,.sf-player-wrap .media-element-wrapper:-webkit-full-screen{border-radius:0}.sf-player-empty{padding:1rem;color:#e2e8f0;text-align:center}@media(max-width:1120px){.sf-grid-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.sf-object-grid,.sf-coord-grid{grid-template-columns:1fr}.sf-wall-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:680px){.sf-wall-grid{grid-template-columns:1fr}.sf-archive-actions{width:100%;flex-wrap:wrap}.sf-camera-snapshot{width:136px;height:78px}.sf-archive-select{min-width:0;width:100%}.sf-player-wrap .media-element-wrapper{min-height:220px}.sf-player-wrap-archive{width:100%}.sf-player-wrap-archive .media-element-wrapper{min-height:154px}.sf-map-page{min-height:calc(100vh - 120px)}.sf-map-only-wrap,.sf-map-only-wrap .leaflet-container{min-height:calc(100vh - 160px)}.sf-map-status{left:.54rem;right:3.5rem}.sf-map-filter-toggle{right:.54rem}.sf-map-filter{right:.54rem;width:min(300px,calc(100vw - 1.1rem))}}
