.lang-switcher[data-v-5b120ce9]{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:28px;padding:0 8px;border:1px solid var(--border);border-radius:var(--r-sm);background:transparent;color:var(--fg-2);font-size:var(--fs-xs);font-weight:600;cursor:pointer;transition:border-color var(--t-fast),color var(--t-fast)}.lang-switcher[data-v-5b120ce9]:hover{border-color:var(--border-strong);color:var(--fg-0)}.alerts-wrap[data-v-d4a99b14]{position:relative}.icon-btn.badge-info[data-badge][data-v-d4a99b14]:after{background:var(--accent)}.icon-btn.badge-warning[data-badge][data-v-d4a99b14]:after{background:var(--warn)}.icon-btn.badge-critical[data-badge][data-v-d4a99b14]:after{background:var(--err)}.alerts-menu[data-v-d4a99b14]{position:absolute;right:0;top:calc(100% + 6px);width:360px;max-height:460px;display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);overflow:hidden;z-index:30}.alerts-menu-head[data-v-d4a99b14]{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-soft)}.alerts-menu-title[data-v-d4a99b14]{font-size:var(--fs-sm);font-weight:500;color:var(--fg-0)}.alerts-menu-count[data-v-d4a99b14]{font-size:var(--fs-xs);color:var(--fg-3)}.alerts-menu-empty[data-v-d4a99b14]{padding:var(--sp-5);text-align:center;color:var(--fg-3);font-size:var(--fs-sm)}.alerts-menu-list[data-v-d4a99b14]{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.alerts-menu-item[data-v-d4a99b14]{display:flex;align-items:flex-start;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-soft)}.alerts-menu-item[data-v-d4a99b14]:last-child{border-bottom:none}.alerts-menu-item .dot[data-v-d4a99b14]{margin-top:6px;flex-shrink:0}.alerts-menu-body[data-v-d4a99b14]{flex:1;min-width:0}.alerts-menu-msg[data-v-d4a99b14]{font-size:var(--fs-sm);color:var(--fg-1);word-break:break-word}.alerts-menu-meta[data-v-d4a99b14]{font-size:var(--fs-xs);color:var(--fg-3);margin-top:2px}.alerts-menu-acked[data-v-d4a99b14]{color:var(--ok);margin-left:4px}.alerts-menu-ack[data-v-d4a99b14]{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:transparent;border:1px solid var(--border);color:var(--fg-3);display:grid;place-items:center;cursor:pointer;transition:background var(--t-fast),color var(--t-fast)}.alerts-menu-ack[data-v-d4a99b14]:hover{background:var(--bg-hover);color:var(--fg-0)}.alerts-menu-footer[data-v-d4a99b14]{padding:var(--sp-3) var(--sp-4);text-align:center;font-size:var(--fs-sm);color:var(--accent);background:transparent;border:none;border-top:1px solid var(--border-soft);cursor:pointer}.alerts-menu-footer[data-v-d4a99b14]:hover{background:var(--bg-hover)}.user-pill-wrap[data-v-d4a99b14]{position:relative}.user-menu[data-v-d4a99b14]{position:absolute;right:0;top:calc(100% + 6px);min-width:180px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);overflow:hidden;z-index:20}.user-menu-head[data-v-d4a99b14]{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-soft)}.user-menu-name[data-v-d4a99b14]{font-size:var(--fs-sm);font-weight:500;color:var(--fg-0)}.user-menu-role[data-v-d4a99b14]{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-3);text-transform:lowercase}.user-menu-item[data-v-d4a99b14]{width:100%;text-align:left;padding:8px var(--sp-4);font-size:var(--fs-sm);color:var(--fg-1);transition:background var(--t-fast),color var(--t-fast)}.user-menu-item[data-v-d4a99b14]:hover{background:var(--bg-hover);color:var(--fg-0)}.is-group[data-v-20c0eaf9]{position:relative}.group-chevron[data-v-20c0eaf9]{margin-left:auto;display:inline-flex;align-items:center;transition:transform .15s ease;opacity:.6}.group-chevron.open[data-v-20c0eaf9]{transform:rotate(90deg);opacity:1}.nav-item.group-active[data-v-20c0eaf9]{color:var(--fg-0)}.nav-sub[data-v-20c0eaf9]{display:flex;flex-direction:column;margin:2px 0 4px}.nav-sub-item[data-v-20c0eaf9]{display:flex;align-items:center;padding:6px 12px 6px 38px;font-size:var(--fs-sm);color:var(--fg-2);cursor:pointer;border-left:2px solid transparent;transition:background var(--t-fast)}.nav-sub-item[data-v-20c0eaf9]:hover{background:var(--bg-hover);color:var(--fg-1)}.nav-sub-item.active[data-v-20c0eaf9]{background:var(--bg-2);border-left-color:var(--accent);color:var(--fg-0);font-weight:500}.pwa-toast[data-v-398b9e4d]{position:fixed;left:50%;bottom:16px;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-2);border:1px solid var(--accent);border-radius:var(--r-md);box-shadow:var(--shadow-md);max-width:calc(100vw - 32px);font-size:var(--fs-sm);animation:pwa-slide-398b9e4d .2s ease-out}.pwa-toast.ready[data-v-398b9e4d]{border-color:var(--ok)}.pwa-msg[data-v-398b9e4d]{color:var(--fg-1)}.pwa-btn[data-v-398b9e4d]{border:none;background:transparent;color:var(--fg-2);cursor:pointer;padding:4px 8px;border-radius:var(--r-sm);font-size:var(--fs-sm)}.pwa-btn.primary[data-v-398b9e4d]{background:var(--accent);color:var(--accent-fg);padding:6px 14px;font-weight:500}.pwa-btn.primary[data-v-398b9e4d]:hover{filter:brightness(1.1)}@keyframes pwa-slide-398b9e4d{0%{transform:translate(-50%,30px);opacity:0}to{transform:translate(-50%);opacity:1}}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--font-display: "Inter", sans-serif;--fs-xs: 11px;--fs-sm: 12px;--fs-md: 13px;--fs-lg: 15px;--fs-xl: 18px;--fs-2xl: 22px;--fs-3xl: 28px;--fs-4xl: 40px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--bp-mobile: 480px;--bp-tablet: 768px;--bp-desktop: 1024px;--r-xs: 3px;--r-sm: 5px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--accent: oklch(78% .16 72);--accent-strong: oklch(72% .18 68);--accent-soft: oklch(78% .16 72 / .12);--accent-border: oklch(78% .16 72 / .28);--accent-fg: #1a1206;--ok: oklch(72% .14 155);--warn: oklch(80% .16 85);--err: oklch(68% .19 25);--rec: oklch(64% .22 28);--info: oklch(72% .1 230);--t-fast: .12s cubic-bezier(.2,.8,.2,1);--t-med: .22s cubic-bezier(.2,.8,.2,1)}:root,[data-theme=dark]{--bg-0: #0a0b0d;--bg-1: #0f1114;--bg-2: #14171b;--bg-3: #1a1d22;--bg-4: #22262d;--bg-hover: #1e2228;--bg-active: #262b33;--border: #23272e;--border-strong: #2d333c;--border-soft: #1b1e23;--fg-0: #e8ebef;--fg-1: #b6bcc5;--fg-2: #7c8490;--fg-3: #545b66;--fg-4: #3a3f48;--video-bg: #06070a;--video-overlay: rgba(0,0,0,.55);--scrim: rgba(6, 7, 10, .72);--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 8px 24px rgba(0,0,0,.5);--shadow-lg: 0 24px 64px rgba(0,0,0,.6);color-scheme:dark}[data-theme=light]{--bg-0: #e9ebef;--bg-1: #f4f5f7;--bg-2: #ffffff;--bg-3: #fafbfc;--bg-4: #ffffff;--bg-hover: #f0f1f4;--bg-active: #e6e8ec;--border: #e1e3e8;--border-strong: #cbcfd6;--border-soft: #eceef2;--fg-0: #14171b;--fg-1: #3a3f48;--fg-2: #5e6570;--fg-3: #8a909b;--fg-4: #b6bcc5;--video-bg: #1a1d22;--video-overlay: rgba(0,0,0,.45);--scrim: rgba(255,255,255,.75);--accent-fg: #ffffff;--accent: oklch(62% .16 58);--accent-strong: oklch(56% .17 55);--accent-soft: oklch(62% .16 58 / .1);--accent-border: oklch(62% .16 58 / .26);--shadow-sm: 0 1px 2px rgba(30,35,45,.06);--shadow-md: 0 8px 24px rgba(30,35,45,.1);--shadow-lg: 0 24px 64px rgba(30,35,45,.14);color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);font-size:var(--fs-md);background:var(--bg-1);color:var(--fg-0);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"cv11","ss01","ss03"}button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}input,select,textarea{font:inherit;color:inherit}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--fg-3);background-clip:padding-box;border:2px solid transparent}::selection{background:var(--accent-soft);color:var(--fg-0)}.mono{font-family:var(--font-mono);font-feature-settings:"zero","ss01"}.dot{width:6px;height:6px;border-radius:50%;display:inline-block;vertical-align:middle;background:var(--fg-3)}.dot.ok{background:var(--ok)}.dot.warn{background:var(--warn)}.dot.err{background:var(--err)}.dot.rec{background:var(--rec);animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app{--sidebar-w: 232px;display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:calc(48px + env(safe-area-inset-top)/.4) 1fr;grid-template-areas:"topbar topbar" "sidebar main";height:100vh;background:var(--bg-1)}.app.sidebar-collapsed:not(.sidebar-narrow){--sidebar-w: 56px}.app.sidebar-narrow{--sidebar-w: 0}.app.sidebar-narrow .sidebar{position:fixed;top:48px;left:0;bottom:0;width:240px;z-index:30;transform:translate(-100%);transition:transform .18s ease;border-right:1px solid var(--border)}.app.sidebar-narrow.sidebar-overlay-open .sidebar{transform:translate(0)}.sidebar-backdrop{position:fixed;inset:48px 0 0;background:#00000080;z-index:25;cursor:pointer}.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .nav-item span:not(.count),.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .nav-sub,.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .cam-tree,.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .sidebar-footer .footer-text,.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .group-chevron{display:none!important}.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .nav-item{justify-content:center;padding:7px 4px}.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .nav-item .count{position:absolute;top:2px;right:4px;font-size:9px}.app.sidebar-collapsed:not(.sidebar-narrow) .sidebar .nav-item{position:relative}.topbar-burger{background:transparent;border:1px solid var(--border);color:var(--fg-1);width:32px;height:32px;border-radius:var(--r-sm);margin:0 var(--sp-2) 0 var(--sp-3);display:grid;place-items:center;cursor:pointer;transition:background .1s ease}.topbar-burger:hover{background:var(--bg-3);color:var(--fg-0)}.topbar{grid-area:topbar;display:flex;align-items:center;gap:var(--sp-4);padding:calc(env(safe-area-inset-top)/.4) var(--sp-4) 0;background:var(--bg-2);border-bottom:1px solid var(--border);z-index:10}.brand{display:flex;align-items:center;gap:var(--sp-2);font-weight:600;font-size:var(--fs-md);letter-spacing:-.01em;padding-right:var(--sp-4);border-right:1px solid var(--border);height:100%;min-width:220px}.brand-mark{width:22px;height:22px;display:grid;place-items:center;background:var(--accent);color:var(--accent-fg);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:-.04em}.brand-suffix{color:var(--fg-3);font-weight:400;font-family:var(--font-mono);font-size:var(--fs-xs);margin-left:auto}.topbar-status{display:flex;align-items:center;gap:var(--sp-4);font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-2)}.topbar-status .kv{display:flex;gap:6px;align-items:center}.topbar-status .kv b{color:var(--fg-0);font-weight:500}.topbar-spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:var(--sp-2)}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:var(--r-sm);color:var(--fg-1);transition:background var(--t-fast),color var(--t-fast);position:relative}.icon-btn:hover{background:var(--bg-hover);color:var(--fg-0)}.icon-btn[data-badge]:after{content:attr(data-badge);position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 3px;background:var(--accent);color:var(--accent-fg);border-radius:8px;font-size:9px;font-weight:700;display:grid;place-items:center;font-family:var(--font-mono)}.clock{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-1);padding:0 var(--sp-3);border-left:1px solid var(--border);height:100%;display:flex;align-items:center;gap:var(--sp-2)}.clock b{color:var(--fg-0);font-weight:500}.user-pill{display:flex;align-items:center;gap:var(--sp-2);padding:4px 10px 4px 4px;border-radius:20px;background:var(--bg-3);border:1px solid var(--border);font-size:var(--fs-sm);transition:background var(--t-fast)}.user-pill:hover{background:var(--bg-hover)}.user-pill .avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:var(--accent-fg);display:grid;place-items:center;font-size:10px;font-weight:700}.sidebar{grid-area:sidebar;background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.nav{display:flex;flex-direction:column;padding:var(--sp-3) var(--sp-2);gap:1px}.nav-section{font-size:var(--fs-xs);color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em;padding:var(--sp-3) var(--sp-3) var(--sp-2);font-weight:500}.nav-item{display:flex;align-items:center;gap:var(--sp-3);padding:7px 10px;border-radius:var(--r-sm);color:var(--fg-1);font-size:var(--fs-md);cursor:pointer;transition:background var(--t-fast),color var(--t-fast);position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--fg-0)}.nav-item.active{background:var(--accent-soft);color:var(--fg-0)}.nav-item.active:before{content:"";position:absolute;left:-2px;top:8px;bottom:8px;width:2px;background:var(--accent);border-radius:2px}.nav-item .count{margin-left:auto;font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-3);background:var(--bg-3);padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.nav-item.active .count{color:var(--accent);background:transparent}.cam-tree{flex:1;overflow-y:auto;padding:var(--sp-2) var(--sp-2) var(--sp-4);border-top:1px solid var(--border)}.cam-tree-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-3) var(--sp-2);font-size:var(--fs-xs);color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.cam-tree-search{margin:0 var(--sp-2) var(--sp-2);position:relative}.cam-tree-search input{width:100%;padding:6px 10px 6px 28px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--fg-0);font-size:var(--fs-sm);outline:none}.cam-tree-search input:focus{border-color:var(--accent-border)}.cam-tree-search svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--fg-3)}.cam-row{display:flex;align-items:center;gap:var(--sp-2);padding:5px 10px;border-radius:var(--r-xs);cursor:grab;font-size:var(--fs-sm);color:var(--fg-1);transition:background var(--t-fast);-webkit-user-select:none;user-select:none}.cam-row:hover{background:var(--bg-hover);color:var(--fg-0)}.cam-row:active{cursor:grabbing}.cam-row.dragging{opacity:.35}.cam-row .label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cam-row .meta{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-3)}.sidebar-footer{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--border);font-family:var(--font-mono);font-size:10px;color:var(--fg-3);display:flex;justify-content:space-between}.main{grid-area:main;overflow:hidden;position:relative;display:flex;flex-direction:column}.page-header{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--border);background:var(--bg-2);min-height:56px}.page-title{font-size:var(--fs-xl);font-weight:600;letter-spacing:-.01em}.page-sub{color:var(--fg-2);font-size:var(--fs-sm);font-family:var(--font-mono)}.page-actions{display:flex;gap:var(--sp-2);margin-left:auto}.page-body{flex:1;overflow:auto;position:relative}.btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:6px 12px;border-radius:var(--r-sm);font-size:var(--fs-sm);font-weight:500;border:1px solid var(--border);background:var(--bg-3);color:var(--fg-0);transition:background var(--t-fast),border-color var(--t-fast);height:30px;white-space:nowrap}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-primary{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-hover)}.btn-danger{color:var(--err)}.btn-danger:hover{background:color-mix(in oklab,var(--err) 10%,transparent)}.btn-sm{height:26px;padding:4px 10px;font-size:var(--fs-xs)}.btn-icon{width:30px;padding:0;justify-content:center}.seg{display:inline-flex;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-sm);padding:2px;gap:1px}.seg button{padding:4px 10px;font-size:var(--fs-sm);color:var(--fg-1);border-radius:3px;height:24px;display:inline-flex;align-items:center;gap:6px;transition:background var(--t-fast),color var(--t-fast)}.seg button:hover{color:var(--fg-0)}.seg button.active{background:var(--bg-1);color:var(--fg-0);box-shadow:var(--shadow-sm)}.input{height:30px;padding:0 10px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--fg-0);font-size:var(--fs-sm);outline:none;transition:border-color var(--t-fast)}.input:focus{border-color:var(--accent-border)}.kbd{font-family:var(--font-mono);font-size:10px;padding:1px 5px;border-radius:3px;background:var(--bg-3);border:1px solid var(--border);color:var(--fg-2)}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:var(--fs-xs);font-family:var(--font-mono);background:var(--bg-3);color:var(--fg-1);border:1px solid var(--border);line-height:1.4}.tag.ok{color:var(--ok);border-color:color-mix(in oklab,var(--ok) 30%,var(--border))}.tag.err{color:var(--err);border-color:color-mix(in oklab,var(--err) 30%,var(--border))}.tag.rec{color:var(--rec);border-color:color-mix(in oklab,var(--rec) 30%,var(--border))}.tag.warn{color:var(--warn);border-color:color-mix(in oklab,var(--warn) 30%,var(--border))}.tag.accent{color:var(--accent);border-color:var(--accent-border);background:var(--accent-soft)}.modal-scrim{position:fixed;inset:0;background:var(--scrim);z-index:100;display:grid;place-items:center;padding:var(--sp-4);animation:fadeIn .16s ease}.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:min(720px,100%);max-height:86vh;display:flex;flex-direction:column;animation:slideIn .18s ease}.modal-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);display:flex;align-items:center}.modal-header h3{margin:0;font-size:var(--fs-lg);font-weight:600}.modal-header .close{margin-left:auto}.modal-body{padding:var(--sp-5);overflow:auto;flex:1}.modal-footer{padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--border);display:flex;gap:var(--sp-2);justify-content:flex-end}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.card-head{padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;gap:var(--sp-2);border-bottom:1px solid var(--border);font-size:var(--fs-sm);font-weight:500;color:var(--fg-1)}.card-head .title{color:var(--fg-0)}.card-head .sub{color:var(--fg-3);font-family:var(--font-mono);font-size:var(--fs-xs)}.card-body{padding:var(--sp-4)}.toast-stack{position:fixed;right:var(--sp-5);bottom:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2);z-index:200}.toast{background:var(--bg-3);border:1px solid var(--border-strong);border-left:3px solid var(--accent);border-radius:var(--r-sm);padding:10px 14px;font-size:var(--fs-sm);box-shadow:var(--shadow-md);min-width:280px;animation:slideIn .2s ease}@media(max-width:768px){.topbar{gap:var(--sp-2);padding:0 var(--sp-2)}.topbar-status,.brand-suffix{display:none}.brand{min-width:auto;border-right:none;padding-right:var(--sp-2)}.clock{padding:0 var(--sp-2);border-left:none}.clock span:not(.mono):not(:first-child){display:none}}@media(max-width:480px){.brand span:not(.brand-suffix){display:none}.user-pill{padding:4px;border-radius:50%}.user-pill>span:not(.avatar){display:none}.user-pill>svg{display:none}.topbar-actions{gap:2px}}.video-tile{position:relative;background:var(--video-bg);border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--border);transition:border-color var(--t-fast),transform var(--t-fast);min-height:0;cursor:pointer}.video-tile:hover{border-color:var(--border-strong)}.video-tile.selected{border-color:var(--accent)}.video-tile.drop-target{border-color:var(--accent);background:var(--accent-soft)}.video-tile .frame{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(.92)}.video-tile .frame.empty{display:grid;place-items:center;color:var(--fg-3);font-family:var(--font-mono);font-size:var(--fs-xs);background:repeating-linear-gradient(45deg,transparent 0 12px,color-mix(in oklab,var(--fg-3) 8%,transparent) 12px 13px)}.video-tile .overlay-top{position:absolute;left:0;right:0;top:0;padding:8px 10px;display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:var(--fs-xs);color:#f0f0f0;background:linear-gradient(to bottom,#0009,#0000);pointer-events:none}.video-tile .overlay-top .name{font-weight:600;letter-spacing:-.01em}.video-tile .overlay-top .spacer{flex:1}.video-tile .overlay-bot{position:absolute;left:0;right:0;bottom:0;padding:6px 10px;display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;color:#f0f0f0d9;background:linear-gradient(to top,#0000008c,#0000);pointer-events:none}.video-tile .rec-dot{width:6px;height:6px;border-radius:50%;background:var(--rec);box-shadow:0 0 6px var(--rec);animation:pulse 1.6s ease-in-out infinite}.video-tile .hover-actions{position:absolute;right:8px;top:8px;display:flex;gap:4px;opacity:0;transition:opacity var(--t-fast)}.video-tile:hover .hover-actions{opacity:1}.video-tile .hover-actions button{width:26px;height:26px;background:#14171bc7;border:1px solid rgba(255,255,255,.08);border-radius:4px;color:#e8ebef;display:grid;place-items:center}.video-tile .hover-actions button:hover{background:#22262df2}.bbox{position:absolute;border:1.5px solid var(--accent);background:color-mix(in oklab,var(--accent) 12%,transparent);border-radius:2px;transition:all .12s linear}.bbox-label{position:absolute;left:-1px;top:-18px;font-family:var(--font-mono);font-size:10px;padding:1px 5px;background:var(--accent);color:var(--accent-fg);border-radius:2px;white-space:nowrap}.live-wrap{display:flex;flex-direction:column;height:100%;background:var(--bg-0)}.live-toolbar{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);background:var(--bg-2)}.live-grid{flex:1;padding:var(--sp-3);display:grid;gap:var(--sp-3);overflow:hidden;min-height:0}.live-grid.l-1{grid-template-columns:1fr;grid-template-rows:1fr}.live-grid.l-4{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.live-grid.l-9{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}.live-grid.l-16{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr)}@media(max-width:768px){.live-grid.l-1{grid-template-rows:auto;align-content:start;overflow-y:auto}.live-grid.l-1 .video-tile{aspect-ratio:16 / 9;height:auto}}.archive-wrap{display:grid;grid-template-columns:1fr 320px;grid-template-rows:1fr auto;grid-template-areas:"video sidebar" "timeline sidebar";height:100%;background:var(--bg-0)}.archive-video{grid-area:video;background:var(--video-bg);position:relative;overflow:hidden;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;place-items:center}.archive-video .frame{position:absolute;inset:0;background-size:cover;background-position:center}.archive-video .player-bar{position:absolute;left:0;right:0;bottom:0;padding:10px 14px;background:linear-gradient(to top,rgba(0,0,0,.65),transparent);display:flex;align-items:center;gap:var(--sp-3);color:#e8ebef;font-family:var(--font-mono);font-size:var(--fs-xs)}.archive-video .title-chip{position:absolute;top:12px;left:14px;padding:4px 10px;background:#14171bb8;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:var(--fs-xs);color:#e8ebef;display:flex;align-items:center;gap:8px}.archive-sidebar{grid-area:sidebar;background:var(--bg-2);display:flex;flex-direction:column;overflow:hidden;border-bottom:1px solid var(--border)}.archive-sidebar-head{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:500}.archive-sidebar-head .count{margin-left:auto;font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-3)}.event-list{flex:1;overflow-y:auto;padding:var(--sp-2)}.event-item{padding:10px 12px;border-radius:var(--r-sm);border:1px solid transparent;margin-bottom:2px;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}.event-item:hover{background:var(--bg-hover)}.event-item.active{background:var(--accent-soft);border-color:var(--accent-border)}.event-item .row1{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:500}.event-item .row1 .spacer{flex:1}.event-item .row1 .ts{font-family:var(--font-mono);font-size:10px;color:var(--fg-3)}.event-item .row2{font-size:var(--fs-xs);color:var(--fg-2);margin-top:3px;display:flex;gap:8px}.timeline{grid-area:timeline;background:var(--bg-2);padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border)}.timeline-head{display:flex;align-items:center;gap:var(--sp-3);font-size:var(--fs-sm)}.timeline-head .date{font-family:var(--font-mono);color:var(--fg-0);font-weight:500}.timeline-head .zoom{margin-left:auto;display:flex;gap:2px}.tl-ruler{position:relative;height:24px;font-family:var(--font-mono);font-size:10px;color:var(--fg-3);border-bottom:1px solid var(--border);overflow:hidden}.tl-ruler .tick{position:absolute;top:0;bottom:0;border-left:1px solid var(--border);padding:4px 4px 0;white-space:nowrap}.tl-ruler .tick.major{border-left-color:var(--border-strong);color:var(--fg-1)}.tl-track{position:relative;height:40px;background:var(--bg-1);border-radius:var(--r-sm);overflow:hidden;cursor:crosshair;border:1px solid var(--border)}.tl-track.thin{height:20px}.tl-rec{position:absolute;top:0;bottom:0;background:color-mix(in oklab,var(--info) 35%,var(--bg-1));border-left:1px solid color-mix(in oklab,var(--info) 60%,transparent)}.tl-event{position:absolute;top:4px;bottom:4px;min-width:3px;background:var(--accent);border-radius:1px;cursor:pointer;transition:transform var(--t-fast)}.tl-event.motion{background:var(--info)}.tl-event.person{background:var(--accent)}.tl-event.vehicle{background:var(--warn)}.tl-event.alarm{background:var(--err)}.tl-event:hover{transform:scaleX(1.6);z-index:2}.tl-event.active{box-shadow:0 0 0 2px var(--bg-2),0 0 0 3px var(--accent);z-index:3}.tl-playhead{position:absolute;top:-4px;bottom:-4px;width:2px;background:var(--accent);pointer-events:none;z-index:4}.tl-playhead:before{content:"";position:absolute;top:-2px;left:-5px;width:12px;height:12px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px var(--bg-2)}.tl-legend{display:flex;gap:var(--sp-4);font-family:var(--font-mono);font-size:10px;color:var(--fg-2);padding-top:2px}.tl-legend .li{display:inline-flex;align-items:center;gap:5px}.tl-legend .swatch{width:10px;height:4px;border-radius:2px}.dash{padding:var(--sp-5);display:grid;gap:var(--sp-4);grid-template-columns:repeat(12,1fr)}.dash>.span-3{grid-column:span 3}.dash>.span-4{grid-column:span 4}.dash>.span-5{grid-column:span 5}.dash>.span-6{grid-column:span 6}.dash>.span-7{grid-column:span 7}.dash>.span-8{grid-column:span 8}.dash>.span-9{grid-column:span 9}.dash>.span-12{grid-column:span 12}.kpi{padding:var(--sp-4);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.kpi-label{font-size:var(--fs-xs);color:var(--fg-2);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.kpi-value{font-size:var(--fs-3xl);font-weight:500;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-sub{font-size:var(--fs-xs);color:var(--fg-3);font-family:var(--font-mono)}.kpi-delta{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs)}.kpi-delta.up{color:var(--ok)}.kpi-delta.down{color:var(--err)}.sparkline{position:absolute;right:10px;bottom:10px;opacity:.7}.tbl{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.tbl th{text-align:left;font-weight:500;color:var(--fg-3);padding:8px 14px;border-bottom:1px solid var(--border);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.06em}.tbl td{padding:10px 14px;border-bottom:1px solid var(--border-soft);color:var(--fg-1);vertical-align:middle}.tbl tr:hover td{background:var(--bg-hover)}.tbl tr.active td{background:var(--accent-soft)}.tbl td.mono{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-1)}.tbl .row-actions{display:flex;gap:4px;opacity:0}.tbl tr:hover .row-actions{opacity:1}.events-page{display:grid;grid-template-columns:280px 1fr;height:100%}.events-filters{background:var(--bg-2);border-right:1px solid var(--border);padding:var(--sp-4);overflow-y:auto}.filter-group{margin-bottom:var(--sp-5)}.filter-group h4{font-size:var(--fs-xs);color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em;font-weight:500;margin:0 0 var(--sp-2)}.filter-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:var(--fs-sm);color:var(--fg-1);cursor:pointer}.filter-row:hover{color:var(--fg-0)}.filter-row input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent)}.filter-row .count{margin-left:auto;font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-3)}.events-content{overflow:auto}.settings-layout{display:grid;grid-template-columns:220px 1fr;height:100%}.settings-nav{background:var(--bg-2);border-right:1px solid var(--border);padding:var(--sp-3) var(--sp-2)}.settings-nav .nav-item{font-size:var(--fs-sm)}.settings-panel{padding:var(--sp-6);overflow-y:auto;max-width:860px}.settings-section{margin-bottom:var(--sp-8)}.settings-section h3{font-size:var(--fs-lg);margin:0 0 6px;font-weight:600;letter-spacing:-.01em}.settings-section .desc{color:var(--fg-2);font-size:var(--fs-sm);margin-bottom:var(--sp-4)}.field-row{display:grid;grid-template-columns:220px 1fr;gap:var(--sp-4);padding:var(--sp-4) 0;border-top:1px solid var(--border-soft);align-items:start}.field-row:first-of-type{border-top:0}.field-row label{font-size:var(--fs-sm);font-weight:500;color:var(--fg-0)}.field-row label .help{display:block;font-weight:400;color:var(--fg-2);margin-top:3px;font-size:var(--fs-xs)}.field-row .ctrl{min-width:0}.tweaks{position:fixed;right:var(--sp-5);bottom:var(--sp-5);background:var(--bg-2);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:260px;padding:var(--sp-3) var(--sp-4);font-size:var(--fs-sm);z-index:50;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.tweaks h4{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);margin:0 0 var(--sp-2);font-weight:500;display:flex;align-items:center;justify-content:space-between}.tweak-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-top:1px solid var(--border-soft)}.tweak-row:first-of-type{border-top:0}.swatches{display:flex;gap:6px}.swatch-btn{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer}.swatch-btn.active{border-color:var(--fg-0)}
