:root{color-scheme:dark;--topbar-h: 50px;--status-h: 30px;--right-width: 300px;--bg: #07090a;--panel: #0d1316;--panel-2: #121b1f;--topbar: #0f161a;--line: #1f2b31;--select: #11313c;--text: #e2eaee;--text-dim: #93a4ad;--text-mute: #61707a;--blue: #2ba3ea;--green: #34d399;--red: #f06a70;--amber: #f0c453;--r-xs: 5px;--r-sm: 7px;--r-md: 10px;--shadow-1: 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 8px 24px rgba(0, 0, 0, .34);--ring: 0 0 0 3px rgba(43, 163, 234, .28);font-family:Inter,ui-sans-serif,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:"tnum" 1;-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#22303a transparent}html,body,#root{height:100%;margin:0}body{overflow:hidden;overscroll-behavior:none}button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}video{display:block}.mono{font-family:ui-monospace,SF Mono,SFMono-Regular,Menlo,monospace;font-variant-numeric:tabular-nums}.app{height:100vh;height:100dvh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);display:flex;flex-direction:column;background:var(--bg)}.topbar{height:var(--topbar-h);flex:none;display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:var(--topbar);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:9px;min-width:0}.brand-logo{height:28px;width:auto;display:block;flex:none}.brand strong{font-size:15px;font-weight:650;letter-spacing:.01em;white-space:nowrap}.brand span{font-size:12px;color:var(--text-dim);white-space:nowrap}.brand-back{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--text);font-size:17px;line-height:1;cursor:pointer;align-self:center}.brand-back:hover{background:#ffffff14;color:#fff}.brand-cam{align-self:center;text-transform:none;letter-spacing:normal;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40vw}.top-actions{display:flex;align-items:center;gap:8px}.top-btn{height:30px;padding:0 10px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel);color:var(--text-dim);font-size:12px;font-weight:550;display:flex;align-items:center;gap:6px;transition:background .12s,color .12s}.top-btn:hover{background:var(--panel-2);color:var(--text)}.top-btn.on{background:var(--select);color:#fff;border-color:#2b6475}.top-btn.icon{width:32px;padding:0;justify-content:center}.status-dot{width:8px;height:8px;border-radius:50%;flex:none;background:var(--green);box-shadow:0 0 0 3px #34d3992e}.status-dot.down{background:var(--red);box-shadow:0 0 0 3px #f06a702e}.status-dot.checking{background:var(--amber);box-shadow:0 0 0 3px #f0c4532e}.status-val{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text);font-variant-numeric:tabular-nums}.main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;position:relative}.seam-toggle{position:absolute;z-index:30;display:grid;place-items:center;padding:0;width:22px;height:46px;border:1px solid #33454e;background:var(--panel-2);color:var(--text);cursor:pointer;box-shadow:0 2px 10px #00000080;transition:color .12s,background .12s,border-color .12s,box-shadow .12s}.seam-toggle:hover{color:#fff;background:var(--select);border-color:var(--blue);box-shadow:0 3px 14px #0009}.seam-toggle:focus-visible{opacity:1;outline:2px solid var(--blue);outline-offset:1px}.seam-toggle svg{display:block}.seam-left{left:0;top:50%;transform:translateY(-50%);border-left:none;border-radius:0 9px 9px 0}.seam-right{right:0;top:50%;transform:translateY(-50%);border-right:none;border-radius:9px 0 0 9px}.seam-bottom{bottom:0;left:50%;transform:translate(-50%);width:46px;height:22px;border-bottom:none;border-radius:9px 9px 0 0}.cameras-grid{flex:1;min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(var(--cv-cols, 3),minmax(0,1fr));grid-auto-rows:minmax(180px,1fr);gap:10px;padding:12px;align-content:stretch}@media(max-width:800px){.cameras-grid{grid-template-columns:1fr}}.grid-empty{grid-column:1 / -1;display:grid;place-items:center;color:var(--text-mute);font-size:13px;padding:60px 0}.workspace{flex:1;min-height:0;display:flex;flex-direction:row}.sidebar{flex:none;width:250px;display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--line);overflow-y:auto}.sidebar.collapsed{width:40px;align-items:center;padding-top:8px}.side-top{display:flex;align-items:center;justify-content:space-between;padding:9px 12px 4px}.side-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute)}.side-rail-toggle{display:grid;place-items:center;width:24px;height:24px;border-radius:6px;color:var(--text-dim);background:none;border:none;cursor:pointer}.side-rail-toggle:hover{color:#fff;background:#ffffff0f}.side-rail-toggle:focus-visible,.side-item:focus-visible,.side-item-main:focus-visible,.side-item-act:focus-visible,.side-add:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.sidebar:not(.collapsed) .side-rail-toggle svg{transform:rotate(180deg)}.side-block{padding:4px 8px}.side-block.cams{flex:1;min-height:0;display:flex;flex-direction:column;padding-bottom:8px}.side-block-head{display:flex;align-items:center;justify-content:space-between;padding:8px 6px 4px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute)}.side-add{width:20px;height:20px;border-radius:6px;font-size:15px;line-height:1;color:var(--text-dim);background:none;border:1px solid var(--line);cursor:pointer}.side-add:hover{color:#fff;border-color:var(--blue)}.side-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 8px;border-radius:7px;background:none;border:none;color:var(--text-dim);font-size:13px;cursor:pointer;text-align:left}.side-item:hover{background:#ffffff0d;color:var(--text)}.side-item.on{background:var(--select);color:#fff}.side-item svg{flex:none;opacity:.85}.side-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-count{font-size:11px;color:var(--text-mute);font-variant-numeric:tabular-nums}.side-item .side-item-main{display:flex;align-items:center;gap:8px;flex:1;min-width:0;background:none;border:none;color:inherit;font:inherit;cursor:pointer;text-align:left;padding:0}.side-item-act{flex:none;width:20px;height:20px;border-radius:5px;background:none;border:none;color:var(--text-mute);font-size:11px;cursor:pointer;opacity:0}.side-item:hover .side-item-act{opacity:1}.side-item-act:hover{color:#fff;background:#ffffff1a}.side-search{margin:2px 6px 6px;padding:6px 9px;border-radius:7px;background:var(--bg);border:1px solid var(--line);color:var(--text);font-size:12.5px}.side-search:focus{outline:none;border-color:var(--blue)}.side-cam-list{flex:1;min-height:0;overflow-y:auto}.side-note{padding:6px 8px;font-size:12px;color:var(--text-mute)}.side-note.err{color:var(--amber)}.side-rename{width:calc(100% - 12px);margin:1px 6px;padding:6px 8px;border-radius:7px;background:var(--bg);border:1px solid var(--blue);color:var(--text);font-size:13px}.side-preview{position:fixed;z-index:60;width:240px;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--panel-2);box-shadow:0 8px 28px #00000080;pointer-events:none}.side-preview img{display:block;width:100%;height:100%;object-fit:cover}.side-preview-ph{display:block;width:100%;height:100%;background:linear-gradient(100deg,transparent 35%,rgba(255,255,255,.07) 50%,transparent 65%) 0 0 / 300% 100%,#ffffff0a;animation:tt-shimmer 1.1s linear infinite}.layout-pane{flex:1;min-height:0;display:flex;flex-direction:column}.layout-pane.maximized{background:var(--bg)}.layout-toolbar{flex:none;display:flex;align-items:center;gap:8px;padding:7px 12px;border-bottom:1px solid var(--line);background:var(--panel)}.lt-name{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:40%}.lt-spacer{flex:1}.lt-status{font-size:12px;color:var(--text-mute);margin-right:4px;font-variant-numeric:tabular-nums}.btn.sm{padding:5px 10px;font-size:12px;border-radius:6px}.btn.sm.icon{padding:4px;display:inline-grid;place-items:center;color:var(--text-dim)}.btn.sm.icon:hover{color:var(--text)}.layout-grid{flex:1;min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(var(--lg-cols),1fr);grid-template-rows:repeat(var(--lg-rows),1fr);gap:8px;padding:10px}.layout-grid.empty{display:grid;place-items:center}.layout-cell{position:relative;min-width:0;min-height:0}.layout-cell .camera-tile{width:100%;height:100%}.layout-grid.editing{position:relative;background:#07090a}.layout-grid.editing:before{content:"";position:absolute;left:10px;top:10px;right:10px;bottom:10px;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(43,163,234,.22) 1px,transparent 1px),linear-gradient(90deg,rgba(43,163,234,.22) 1px,transparent 1px);background-size:calc((100% + 8px) / var(--lg-cols)) calc((100% + 8px) / var(--lg-rows));border:1px solid rgba(43,163,234,.3);border-radius:2px}.layout-grid.editing .layout-cell{z-index:1;outline:1px dashed rgba(255,255,255,.18);outline-offset:-1px;border-radius:var(--r-sm)}.layout-grid.editing .layout-cell .camera-tile,.layout-grid.editing .layout-cell .layout-zoom{pointer-events:none}.rh{position:absolute;display:grid;place-items:center;padding:0;border:0;border-radius:0;background:#0000002e;color:#d9f2ff;font-size:12px;line-height:1;opacity:0;pointer-events:none;touch-action:none;transition:opacity .12s ease,background .12s ease,box-shadow .12s ease,color .12s ease;z-index:6}.rh:after{content:"";position:absolute;background:#d6f1ff8a;box-shadow:0 0 14px #00a3e661;opacity:.72;pointer-events:none}.layout-grid.editing .rh{pointer-events:auto;opacity:.46}.layout-grid.editing .layout-cell:hover .rh,.layout-grid.editing .layout-cell.dragging .rh{opacity:.94}.rh:hover,.layout-cell.dragging .rh{background:#00a3e66b;color:#fff;opacity:1;box-shadow:inset 0 0 0 1px #d6f1ff33}.rh-e{width:52px;right:0;top:0;bottom:0;cursor:ew-resize;background:linear-gradient(90deg,#0000,#00a3e62e)}.rh-e:after{width:3px;height:38px;right:10px;top:50%;transform:translateY(-50%);border-radius:99px}.rh-w{width:52px;left:0;top:0;bottom:0;cursor:ew-resize;background:linear-gradient(270deg,#0000,#00a3e62e)}.rh-w:after{width:3px;height:38px;left:10px;top:50%;transform:translateY(-50%);border-radius:99px}.rh-s{height:52px;left:0;right:0;bottom:0;cursor:ns-resize;background:linear-gradient(180deg,#0000,#00a3e62e)}.rh-s:after{width:42px;height:3px;left:50%;bottom:10px;transform:translate(-50%);border-radius:99px}.rh-n{height:52px;left:0;right:0;top:0;cursor:ns-resize;background:linear-gradient(0deg,#0000,#00a3e62e)}.rh-n:after{width:42px;height:3px;left:50%;top:10px;transform:translate(-50%);border-radius:99px}.rh-se{width:44px;height:44px;right:0;bottom:0;cursor:nwse-resize;border-top-left-radius:4px;background:#0006;z-index:7}.rh-nw,.rh-ne,.rh-sw{width:40px;height:40px;background:#0000004d;z-index:7}.rh-nw{left:0;top:0;cursor:nwse-resize;border-bottom-right-radius:4px}.rh-ne{right:0;top:0;cursor:nesw-resize;border-bottom-left-radius:4px}.rh-sw{left:0;bottom:0;cursor:nesw-resize;border-top-right-radius:4px}.rh-se:after,.rh-nw:after,.rh-ne:after,.rh-sw:after{width:15px;height:15px;background:transparent;box-shadow:none;opacity:1}.rh-se:after{right:9px;bottom:9px;border-right:2px solid rgba(214,241,255,.78);border-bottom:2px solid rgba(214,241,255,.78)}.rh-nw:after{left:9px;top:9px;border-left:2px solid rgba(214,241,255,.7);border-top:2px solid rgba(214,241,255,.7)}.rh-ne:after{right:9px;top:9px;border-right:2px solid rgba(214,241,255,.7);border-top:2px solid rgba(214,241,255,.7)}.rh-sw:after{left:9px;bottom:9px;border-left:2px solid rgba(214,241,255,.7);border-bottom:2px solid rgba(214,241,255,.7)}.cell-size-badge{position:absolute;right:8px;bottom:8px;z-index:9;padding:3px 8px;border-radius:4px;background:#000000b8;color:#d7ecf8;font-size:11px;font-weight:850;letter-spacing:.04em;pointer-events:none;font-variant-numeric:tabular-nums}.cell-edit{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.cell-drag{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:auto;cursor:move;touch-action:none}.cell-remove{position:absolute;top:6px;right:6px;width:24px;height:24px;display:grid;place-items:center;border-radius:999px;background:#080c0eb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:12px;cursor:pointer;pointer-events:auto;touch-action:none;z-index:8}.cell-remove:hover{background:var(--red);border-color:var(--red)}.cell-zoom{position:absolute;top:6px;left:6px;width:24px;height:24px;display:grid;place-items:center;border-radius:999px;background:#080c0eb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);color:#cfd8df;cursor:pointer;pointer-events:auto;z-index:8}.cell-zoom:hover{color:#fff;border-color:var(--blue)}.cell-resize{position:absolute;right:0;bottom:0;width:20px;height:20px;pointer-events:auto;cursor:nwse-resize;touch-action:none;z-index:2;background:linear-gradient(135deg,transparent 0 55%,rgba(255,255,255,.55) 55% 70%,transparent 70% 78%,rgba(255,255,255,.55) 78% 92%,transparent 92%)}.layout-cell.dragging{z-index:10;outline:2px solid var(--green);outline-offset:-2px;background:#33d69f1f;box-shadow:inset 0 0 0 1px #ffffff14,0 0 0 1px #33d69f38,var(--shadow-2)}.wall-body{flex:1;min-height:0;display:flex;flex-direction:row}.wall-body>.layout-grid,.wall-body>.layout-grid.empty{flex:1;min-width:0}.wall-events{flex:none}.wall-events-rail{flex:none;width:30px;display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:12px;background:var(--panel);border-left:1px solid var(--line);color:var(--text-dim);cursor:pointer;border-top:none;border-right:none;border-bottom:none}.wall-events-rail:hover{color:#fff}.wall-rail-label{writing-mode:vertical-rl;text-orientation:mixed;font-size:10px;font-weight:700;letter-spacing:.12em}.wall-events-rail .count{font-size:11px}.layout-cell.focused{outline:2px solid var(--blue);outline-offset:-2px;border-radius:var(--r-sm);z-index:5}.se-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--text)}.wall-timeline{flex:none;height:150px;display:flex;flex-direction:column;background:var(--panel);border-top:1px solid var(--line);position:relative}.wall-timeline .tl-band{flex:1;min-height:0}.wall-timeline.collapsed{height:28px;flex-direction:row;align-items:center;justify-content:center;gap:16px}.wall-tl-collapsed-label{color:var(--text-mute);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.wall-tl-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-dim);font-size:12px;cursor:pointer}.wall-tl-toggle:hover{color:#fff}.wall-tl-toggle.open{position:absolute;top:3px;left:50%;transform:translate(-50%);z-index:3;width:30px;height:16px;justify-content:center;border-radius:4px}.wall-tl-toggle.open svg{transform:rotate(90deg)}.wall-timeline.collapsed .wall-tl-toggle svg{transform:rotate(-90deg)}.wall-tl-label{flex:none;width:196px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:7px;padding:0 12px;border-right:1px solid var(--line)}.wall-tl-name{font-size:12px;font-weight:600;color:var(--text);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wall-tl-live{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);color:var(--text-dim);font-size:11px;font-weight:700;letter-spacing:.05em;cursor:pointer}.wall-tl-live .d{width:6px;height:6px;border-radius:999px;background:currentColor}.wall-tl-live.on{color:var(--red);border-color:#f06a7066}.wall-tl-live:not(.on):hover{color:#fff;border-color:var(--text-dim)}.wall-tl-transport{display:flex;align-items:center;gap:4px}.wall-tl-pp,.wall-tl-speed{display:inline-flex;align-items:center;justify-content:center;height:22px;padding:0 6px;border-radius:6px;background:var(--panel-2);border:1px solid var(--line);color:var(--text-dim);font-size:10px;font-weight:700;cursor:pointer}.wall-tl-pp{min-width:26px;font-size:11px}.wall-tl-pp:hover,.wall-tl-speed:hover{color:#fff;border-color:var(--text-dim)}.wall-tl-speed.on{color:var(--amber);background:#f0c45329;border-color:#f0c45366}.live-pill.playback{background:#f0c45329;color:var(--amber)}.live-pill.playback .d{background:var(--amber)}.live-pill.zoom{background:color-mix(in srgb,var(--zoom-c, var(--blue)) 16%,transparent);color:var(--zoom-c, var(--blue))}.live-pill.zoom .d{background:var(--zoom-c, var(--blue))}.tile-nofootage{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--text-mute);font-size:12px;letter-spacing:.04em;text-transform:uppercase;pointer-events:none}.wall-tl-strip{flex:1;min-width:0;position:relative;display:flex}.wall-tl-strip>*{flex:1;min-width:0}.tile-actions{position:absolute;top:8px;right:8px;z-index:4;display:flex;gap:5px;opacity:0;pointer-events:none;transition:opacity .12s ease}.camera-tile:hover .tile-actions,.camera-tile.focused .tile-actions,.layout-zoom:hover .tile-actions,.layout-zoom.focused .tile-actions{opacity:1;pointer-events:auto}.ta-btn{width:28px;height:28px;display:grid;place-items:center;border-radius:999px;background:#080c0e9e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.14);color:#cfd8df;cursor:pointer;font-size:11px}.ta-btn:hover{background:#080c0ed9;color:#fff;border-color:#ffffff47}.ta-btn.on{background:var(--select);border-color:var(--select);color:#fff}.ta-q{width:auto;padding:0 9px;font-weight:700;letter-spacing:.04em;font-variant-numeric:tabular-nums}.cell-missing{width:100%;height:100%;display:grid;place-items:center;background:#0a0f12;border:1px dashed var(--line);border-radius:var(--r-sm);color:var(--text-mute);font-size:12px}.layout-zoom{position:relative;width:100%;height:100%;overflow:hidden;border-radius:var(--r-sm);background:#000;cursor:pointer}.layout-zoom video{transform:var(--lz-t);transform-origin:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0000008c;display:grid;place-items:center}.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-2);width:min(420px,92vw);max-height:84vh;display:flex;flex-direction:column;padding:16px}.modal-head{font-size:15px;font-weight:650;margin-bottom:12px}.layout-dialog .zone-name-input{width:100%;box-sizing:border-box}.layout-dialog-sub{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-mute);margin:12px 2px 6px}.link-btn{background:none;border:none;color:var(--blue);font-size:12px;cursor:pointer}.layout-dialog-cams{flex:1;min-height:0;overflow-y:auto;border:1px solid var(--line);border-radius:var(--r-sm);padding:4px}.layout-cam-row{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:6px;font-size:13px;color:var(--text);cursor:pointer}.layout-cam-row:hover{background:#ffffff0d}.modal-err{color:var(--red);font-size:12.5px;margin-top:8px}.modal-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.btn{padding:8px 14px;border-radius:7px;background:var(--panel-2);border:1px solid var(--line);color:var(--text);font-size:13px;cursor:pointer}.btn:hover{border-color:var(--text-dim)}.btn.primary{background:var(--blue);border-color:var(--blue);color:#04121b;font-weight:600}.btn.primary:disabled{opacity:.5;cursor:not-allowed}.camera-tile{position:relative;border-radius:var(--r-md);overflow:hidden;background:#0a0d0f;border:1px solid #1b262b;box-shadow:var(--shadow-1);cursor:pointer;min-height:200px;transition:border-color .14s,box-shadow .14s}.camera-tile:hover{border-color:var(--blue)}.maximized{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;width:100vw;height:100vh;height:100dvh;max-width:none;max-height:none;min-height:0;border:none;border-radius:0;background:#000}.tile-poster{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}.camera-tile .media-plane{position:absolute;left:50%;top:50%;width:100%;height:100%;transform:translate(-50%,-50%) rotate(var(--media-rotation, 0deg));transform-origin:center center;transition:transform .16s ease,width .16s ease,height .16s ease}.camera-tile video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:#000;transform:var(--ptz-t, none);transform-origin:center center}.tile-grad{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(0,0,0,.16),transparent 22%,transparent 72%,rgba(0,0,0,.22));pointer-events:none}.tile-label{position:absolute;left:11px;top:10px;display:flex;align-items:center;gap:8px;color:#fff;font-size:12.5px;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.7);pointer-events:none;opacity:0;transition:opacity .12s ease}.camera-tile.names-always .tile-label,.layout-zoom.names-always .tile-label,.camera-tile.names-on-hover:hover .tile-label,.camera-tile.names-on-hover.focused .tile-label,.layout-zoom.names-on-hover:hover .tile-label,.layout-zoom.names-on-hover.focused .tile-label{opacity:1}.time-overlay{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:5;font-size:12px;font-weight:600;color:#eaf3f8;background:#080c0e8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:3px 9px;border-radius:6px;border:1px solid rgba(255,255,255,.08);text-shadow:0 1px 3px rgba(0,0,0,.7);pointer-events:none;white-space:nowrap;opacity:0;transition:opacity .12s ease}.camera-tile.time-always .time-overlay,.camera-tile.time-on-hover:hover .time-overlay,.camera-tile.time-on-hover.focused .time-overlay{opacity:1}.live-pill{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:650;letter-spacing:.08em;color:#ffd2d4}.live-pill .d{width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 0 3px #f06a7038}.live-pill.idle{color:#9fb1b9}.live-pill.idle .d{background:#46535b;box-shadow:none}.tile-badge{position:absolute;left:10px;bottom:10px;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#d9e6ec;background:#080c0e8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:3px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.07);pointer-events:none}.tile-live{position:absolute;right:10px;bottom:10px;z-index:2;background:#080c0e8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:3px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.07);pointer-events:none}.tile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60}.tile-menu{position:fixed;z-index:61;min-width:162px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 18px 44px #0000008c;padding:5px;display:flex;flex-direction:column;gap:2px}.tile-menu-section{padding:6px 9px 3px;color:var(--text-mute);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.tile-menu-item{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;height:30px;padding:0 9px;border:none;background:transparent;color:var(--text);font-size:13px;border-radius:5px;text-align:left;cursor:pointer}.tile-menu-item:hover{background:var(--panel-2);color:#fff}.tile-menu-item.on{color:#fff}.tile-menu-check{color:var(--blue)}.tile-menu-item.has-sub{position:relative}.tile-menu-arrow{color:var(--text-mute);font-size:15px;line-height:1}.tile-submenu{position:absolute;left:calc(100% + 3px);top:-6px;display:none;min-width:124px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 18px 44px #0000008c;padding:5px;flex-direction:column;gap:2px}.tile-menu-item.has-sub:after{content:"";position:absolute;left:100%;top:0;width:6px;height:100%}.tile-menu-item.has-sub:hover .tile-submenu{display:flex}.tile-msg{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#aebcc4;font-size:12px;font-weight:550;background:#06090b73;pointer-events:none}.debug-overlay{position:absolute;left:11px;bottom:38px;max-width:calc(100% - 22px);background:#080c0ec7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:9px 11px;font-family:ui-monospace,Menlo,monospace;font-size:11px;line-height:1.5;color:#cfe0e8;white-space:pre;pointer-events:auto;z-index:5}.debug-overlay .g2g{color:var(--amber);cursor:help}@media(max-width:800px){.debug-overlay{left:8px;bottom:30px;font-size:13px;line-height:1.6;padding:10px 12px;white-space:pre-wrap;word-break:break-word}}.stage{position:absolute;top:0;right:0;bottom:0;left:0;z-index:25;background:#000;display:flex;flex-direction:row}.stage-left{flex:1;min-width:0;display:flex;flex-direction:column}.stage-video{position:relative;flex:1;min-height:0;background:#000;overflow:hidden}.stage-video video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}@media(hover:hover){.stage-actions,.stage-video .sound-ctl{opacity:0;pointer-events:none;transition:opacity .18s ease}.stage-video:hover .stage-actions,.stage-video:hover .sound-ctl{opacity:1;pointer-events:auto}}.stage-mode{position:absolute;left:14px;bottom:14px;display:flex;align-items:center;gap:6px;height:28px;padding:0 11px;border-radius:999px;font-size:10px;font-weight:650;letter-spacing:.08em;color:#ffd2d4;background:#080c0e99;border:1px solid rgba(240,106,112,.4);z-index:6}.stage-mode .d{width:7px;height:7px;border-radius:50%;background:var(--red)}.stage-mode.playback{color:#bfe6fb;border-color:#2ba3ea66}.stage-mode.playback .d{background:var(--blue)}.stage-mode.paused{color:#f8e3b0;border-color:#f0c45373}.stage-mode.paused .d{background:var(--amber)}.stage-msg{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#aebcc4;font-size:13px;font-weight:550;background:#06090b73;pointer-events:none;z-index:4}.timeline{flex:none;border-top:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column}.tl-head{height:38px;flex:none;display:flex;align-items:center;gap:8px;padding:0 12px;border-bottom:1px solid var(--line)}.tl-title{font-size:11px;font-weight:650;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.tl-spacer{flex:1}.tl-presets{display:flex;gap:2px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:2px}.tl-presets button{height:24px;padding:0 9px;border-radius:5px;color:var(--text-dim);font-size:11px;font-weight:600}.tl-presets button:hover{background:var(--panel-2);color:var(--text)}.tl-presets button.on{background:var(--select);color:#fff}.wall-tl-bm{display:grid;place-items:center;width:28px;height:26px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel);color:var(--amber);cursor:pointer}.wall-tl-bm:hover{background:var(--panel-2);color:#fff}.tl-band{display:flex;align-items:stretch;gap:10px;padding:6px 12px 8px}.tl-band>.tl-canvas-wrap{flex:1;min-width:0;padding:0}.tl-controls{flex:none;width:186px;display:flex;flex-direction:column;justify-content:center;gap:6px}.tl-toprow{display:flex;align-items:center;gap:9px}.tp-shuttle{flex:1;min-width:0;height:4px;accent-color:var(--blue);cursor:pointer}.tp-shuttle:disabled{opacity:.4;cursor:default}.tl-zoom-btns{display:flex;flex-direction:column;gap:7px}.tl-transport{display:flex;flex-direction:column;gap:5px;align-items:flex-start}.tp-cluster{display:flex;gap:1px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:2px}.tp-btn{height:26px;min-width:26px;padding:0 5px;border-radius:5px;color:var(--text-dim);font-size:12px;font-weight:600}.tp-btn.zoom{height:18px;min-width:24px;padding:0;line-height:1;font-size:15px;font-weight:700;border:1px solid var(--line);background:var(--bg);border-radius:4px;color:var(--text-dim)}.tp-btn.zoom:hover{background:var(--panel-2);color:var(--text)}.tp-btn:hover:not(:disabled){background:var(--panel-2);color:var(--text)}.tp-btn:disabled{opacity:.35}.tp-btn.tp-play{color:var(--text)}.tp-btn.tp-rev.on{background:var(--select);color:#fff}.tp-btn.tp-live{display:inline-flex;align-items:center;gap:5px;padding:0 8px;font-size:10.5px;font-weight:700;letter-spacing:.06em}.tp-btn.tp-live .tp-live-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.tp-btn.tp-live.on{color:#ffd2d4}.tp-btn.tp-live.on .tp-live-dot{background:var(--red)}.tp-line{display:flex;align-items:center;gap:5px}.tp-rate{height:26px;padding:0 4px;background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:var(--r-sm);font-size:11px;font-weight:600}.tp-time{width:96px;height:20px;padding:0 2px;font-weight:600;font-size:12px;font-variant-numeric:tabular-nums;background:none;color:var(--text-dim);border:1px solid transparent;border-radius:var(--r-sm);cursor:text}.tp-time:hover{color:var(--text);border-color:var(--line)}.tp-time:focus{outline:none;color:var(--text);border-color:var(--select)}.tp-clock{font-size:12px;color:var(--text-dim);font-variant-numeric:tabular-nums;padding-left:2px}.tl-head .tp-date,.wall-tl-label .tp-date{height:26px;padding:0 6px;background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:var(--r-sm);font-size:11px;font-variant-numeric:tabular-nums;color-scheme:dark}.tl-head .tp-date:focus,.wall-tl-label .tp-date:focus{outline:none;border-color:var(--select)}.tl-btn{height:28px;padding:0 10px;border-radius:var(--r-sm);display:flex;align-items:center;gap:6px;color:var(--text-dim);font-size:12px;font-weight:550;border:1px solid var(--line);background:var(--bg);white-space:nowrap}.tl-btn:hover{color:var(--text);background:var(--panel-2)}.tl-btn.live{color:#ffd2d4;border-color:#f06a706b}.tl-btn.live.active{background:#f06a7029;color:#fff}.tl-btn.primary{background:var(--blue);color:#04121b;border-color:transparent;font-weight:650}.tl-btn.primary:hover{background:#4cb2ee;color:#04121b}.tl-btn:disabled{opacity:.45;cursor:not-allowed}.tl-readout{font-size:12px;color:var(--text-dim);white-space:nowrap}.tl-canvas-wrap{position:relative;padding:6px 12px 10px}.tl-canvas-wrap canvas{display:block;width:100%;height:72px;cursor:crosshair;border-radius:var(--r-xs)}.tl-note{padding:0 12px 8px;font-size:11.5px;color:var(--amber)}.tl-filmstrip{position:relative;height:39px;margin-bottom:5px}.tl-thumb{position:absolute;top:0;width:62px;height:35px;padding:0;border:1.5px solid;border-radius:3px;overflow:hidden;background:#0a0f12;cursor:pointer}.tl-thumb img{display:block;width:100%;height:100%;object-fit:cover}.tl-thumb-ph{display:block;width:100%;height:100%;margin:0;border:none;border-radius:0}.tl-thumb:hover{outline:2px solid var(--blue);outline-offset:-1px;z-index:2}.tl-filmstrip-empty{position:absolute;left:0;top:11px;font-size:11px;color:var(--text-dim)}.right-panel{width:var(--right-width);flex:none;background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;min-height:0}.right-head{height:42px;flex:none;display:flex;align-items:center;padding:0 14px;border-bottom:1px solid var(--line);font-size:11px;font-weight:650;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);gap:8px}.right-head .count{margin-left:auto;color:var(--text-mute)}.side-events{flex:1;overflow:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.side-day{position:sticky;top:-10px;z-index:1;margin:2px 0 -2px;padding:4px 2px;font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);background:var(--panel)}.side-day:first-child{margin-top:-4px}.side-more{padding:8px 2px 2px;font-size:11px;color:var(--text-mute);text-align:center}.side-event{border:1px solid var(--line);background:var(--panel-2);border-radius:var(--r-sm);padding:6px 9px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:border-color .12s;text-align:left;width:100%}.side-event:hover{border-color:#2c4a57}.se-thumb{width:48px;height:27px;object-fit:cover;border-radius:4px;border:1px solid var(--line);flex:none;background:#ffffff0a}.se-thumb.ph{display:block;background:linear-gradient(100deg,transparent 35%,rgba(255,255,255,.07) 50%,transparent 65%) 0 0 / 300% 100%,#ffffff0a;animation:tt-shimmer 1.1s linear infinite}.se-tag{display:flex;align-items:center;justify-content:center;padding:4px;border-radius:7px;flex:none;color:var(--text-mute);background:#ffffff0a;border:1px solid var(--line)}.se-tag.person{color:#bfe6fb;background:#2ba3ea24;border-color:#2ba3ea57}.se-tag.vehicle{color:#bff3da;background:#34d3991f;border-color:#34d39952}.se-tag.animal{color:#fcd9a0;background:#f59e0b24;border-color:#f59e0b57}.se-tag.face{color:#e3cbff;background:#c084fc24;border-color:#c084fc57}.se-time{margin-left:auto;font-size:11px;color:var(--text-mute);font-variant-numeric:tabular-nums;white-space:nowrap}.panel-empty{flex:1;display:grid;place-items:center;color:var(--text-mute);font-size:12.5px;text-align:center;padding:30px}.statusbar{height:var(--status-h);flex:none;display:flex;align-items:center;gap:14px;padding:0 14px;background:var(--topbar);border-top:1px solid var(--line);font-size:11.5px;color:var(--text-dim)}.statusbar .clock{font-size:12px;color:var(--text-dim);font-variant-numeric:tabular-nums}@media(max-width:900px){.right-panel{display:none}}.login-wrap{height:100vh;height:100dvh;display:grid;place-items:center;background:var(--bg)}.login-card{width:min(360px,92vw);display:flex;flex-direction:column;gap:14px;padding:28px 26px 26px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-2)}.login-brand{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}.login-brand-row{display:flex;align-items:center;gap:10px}.login-brand strong{font-size:17px;letter-spacing:.02em}.login-brand span{font-size:12px;color:var(--text-dim)}.login-field{display:flex;flex-direction:column;gap:5px}.login-field span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute)}.login-field input{font:inherit;color:var(--text);background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 11px;outline:none}.login-field input:focus{border-color:var(--blue);box-shadow:var(--ring)}.login-field input:disabled{opacity:.6}.login-error{font-size:12.5px;color:var(--red);background:#f06a7014;border:1px solid rgba(240,106,112,.35);border-radius:var(--r-sm);padding:8px 10px}.login-submit{margin-top:4px;padding:10px 12px;font:inherit;font-weight:600;color:#04121b;background:var(--blue);border:none;border-radius:var(--r-sm);cursor:pointer}.login-submit:hover:not(:disabled){filter:brightness(1.1)}.login-submit:disabled{opacity:.6;cursor:default}.tl-filters,.side-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:0 0 8px}.side-filters{padding:0 14px 10px;border-bottom:1px solid var(--line)}.tl-filters .chip,.side-filters .chip{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 9px;border-radius:999px;border:1px solid var(--line);background:#ffffff08;color:var(--text-dim);font-size:11px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.tl-filters .chip:hover,.side-filters .chip:hover{border-color:#2c4a57;color:var(--text)}.tl-filters .chip.on,.side-filters .chip.on{background:var(--select);border-color:var(--select);color:#fff}.tl-filters .chip-count,.side-filters .chip-count{font-size:10px;font-variant-numeric:tabular-nums;padding:0 5px;border-radius:999px;background:#ffffff1a;color:inherit}.stage-quality{position:absolute;right:14px;bottom:50px;height:24px;display:flex;align-items:center;padding:0 10px;border-radius:999px;font-size:10px;font-weight:650;letter-spacing:.06em;font-variant-numeric:tabular-nums;color:#bfe6fb;background:#080c0e99;border:1px solid rgba(43,163,234,.4);z-index:6}.no-rec{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:5;background:repeating-linear-gradient(-45deg,rgba(255,255,255,.03) 0 8px,transparent 8px 16px),#06090bb3}.no-rec-title{font-size:15px;font-weight:700;letter-spacing:.14em;color:#f0a8ac}.no-rec-label{font-size:12.5px;color:#aebcc4}.no-rec-nav{display:flex;gap:10px;margin-top:8px}.no-rec-nav button{height:30px;padding:0 13px;border-radius:999px;background:#080c0eb3;border:1px solid rgba(255,255,255,.14);color:#e6eef2;font-size:12px;font-weight:550}.no-rec-nav button:hover:not(:disabled){background:#172026e6}.no-rec-nav button:disabled{opacity:.35}.tl-tooltip{position:absolute;bottom:calc(100% - 2px);transform:translate(-50%);max-width:360px;padding:6px 9px;border-radius:var(--r-xs);background:#080c0eeb;border:1px solid rgba(255,255,255,.14);pointer-events:none;z-index:8;white-space:nowrap}.tl-tooltip .tt-thumb{display:block;width:160px;height:90px;object-fit:cover;border-radius:4px;border:1px solid rgba(255,255,255,.14);margin-bottom:5px}.tl-tooltip .tt-thumb.ph{background:linear-gradient(100deg,transparent 35%,rgba(255,255,255,.07) 50%,transparent 65%) 0 0 / 300% 100%,#ffffff0a;animation:tt-shimmer 1.1s linear infinite}@keyframes tt-shimmer{0%{background-position:150% 0,0 0}to{background-position:-150% 0,0 0}}.tl-tooltip .tt-head{font-size:11.5px;font-weight:600;color:#f0c9cb}.tl-tooltip .tt-raw{margin-top:2px;font-size:10.5px;font-family:ui-monospace,Menlo,monospace;color:#8fa0aa;max-width:340px;overflow:hidden;text-overflow:ellipsis}.tl-legend{display:flex;gap:14px;align-items:center;padding:5px 2px 0;font-size:10.5px;color:var(--text-dim)}.tl-legend .sw{display:inline-block;width:14px;height:8px;border-radius:2px;margin-right:5px;vertical-align:-1px}.tl-legend .sw.rec{background:#2ba3ea59;border:1px solid rgba(43,163,234,.55)}.tl-legend .sw.hd{background:#2ba3ead9}.tl-legend .sw.none{background:repeating-linear-gradient(-45deg,rgba(120,135,145,.35) 0 2px,transparent 2px 5px),#00000080;border:1px solid rgba(255,255,255,.08)}.tl-legend .sw.outage{background:#f06a7040;border-bottom:2px solid rgba(240,106,112,.85)}.settings-wrap{position:relative}.pop-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.settings-pop{position:absolute;right:0;top:36px;z-index:41;min-width:250px;padding:10px 12px 9px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow-1)}.pop-title{font-size:11px;font-weight:650;letter-spacing:.07em;text-transform:uppercase;color:var(--text-mute);margin-bottom:8px}.pop-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 0}.pop-label{font-size:12.5px;color:var(--text-dim)}.pop-note{margin-top:8px;padding-top:7px;border-top:1px solid var(--line);font-size:11px;line-height:1.45;color:var(--text-mute)}kbd{display:inline-block;padding:1px 5px;border-radius:4px;border:1px solid var(--line);border-bottom-width:2px;background:var(--panel-2);color:var(--text-dim);font-family:ui-monospace,Menlo,monospace;font-size:10px;line-height:1.5}.kbd-hint{font-size:11px;color:var(--text-mute);white-space:nowrap}@media(max-width:980px){.kbd-hint{display:none}}.help-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;background:#00000073}.help-card{min-width:300px;padding:14px 16px 12px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow-1)}.help-row{display:flex;align-items:center;gap:12px;padding:5px 0;font-size:12.5px;color:var(--text-dim)}.help-row kbd{min-width:44px;text-align:center}.bbox-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.bbox-box{position:absolute;border:2px solid;border-radius:2px;box-shadow:0 0 0 1px #0006;transition:left .1s linear,top .1s linear,width .1s linear,height .1s linear}.bbox-label{position:absolute;top:-1.4em;left:-2px;padding:0 5px;font-size:11px;font-weight:600;color:#0b0e11;border-radius:2px;white-space:nowrap}.stage-video video,.stage-video .bbox-layer{transform:var(--ptz-t, none);transform-origin:50% 50%}.ptz-badge{position:absolute;left:50%;top:14px;transform:translate(-50%);height:28px;display:flex;align-items:center;padding:0 12px;border-radius:999px;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;color:#cfe0e8;background:#080c0e99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);z-index:6;pointer-events:none}.stage-actions{position:absolute;right:14px;top:14px;z-index:6;display:flex;gap:6px}.sa-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:999px;background:#080c0e99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:#cfd8df;cursor:pointer}.sa-btn:hover{background:#080c0ed9;color:#fff;border-color:#ffffff40}.sa-btn.on{background:var(--select);border-color:var(--select);color:#fff}.sa-btn.mark{color:#f0c453}.sa-btn.sa-quality{width:auto;min-width:40px;padding:0 11px;font-size:11px;font-weight:700;letter-spacing:.05em;font-variant-numeric:tabular-nums}.sa-btn.mark:hover{color:#f7d57b}.sa-sound{display:flex;align-items:center;height:34px;border-radius:999px;background:#080c0e99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12)}.sa-sound .sa-btn{background:none;border:none;-webkit-backdrop-filter:none;backdrop-filter:none}.sa-sound.on .sa-btn{color:#6fc6f5}.sa-vol{width:0;opacity:0;transition:width .15s ease,opacity .15s ease;accent-color:var(--blue);cursor:pointer}.sa-sound:hover .sa-vol,.sa-sound.on .sa-vol{width:70px;opacity:1;margin:0 8px 0 2px}.zoom-strip{flex:0 0 auto;display:flex;gap:6px;padding:6px 8px;overflow-x:auto;background:#04070a;border-top:1px solid var(--line)}.zoom-tile{position:relative;flex:0 0 auto;width:176px;height:99px;border-radius:6px;overflow:hidden;background:#000;border:1px solid rgba(255,255,255,.1)}.zoom-tile-canvas{display:block;width:100%;height:100%}.zoom-tile-name{position:absolute;left:7px;bottom:5px;font-size:10.5px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9);pointer-events:none;max-width:calc(100% - 34px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zoom-tile-del{position:absolute;top:4px;right:4px;width:20px;height:20px;display:grid;place-items:center;border-radius:999px;background:#080c0ea6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.15);color:#cfd8df;font-size:11px;cursor:pointer;opacity:0;transition:opacity .15s ease}.zoom-tile:hover .zoom-tile-del{opacity:1}.zoom-tile-del:hover{color:#fff;background:#080c0ee6}.zoom-draw-layer .search-rect{border-color:#c084fc;background:#c084fc1f}.zoom-region{position:absolute;border:2px solid var(--green);background:#ffffff0d;border-radius:3px;pointer-events:none}.zoom-region.editable{pointer-events:auto;cursor:move}.zoom-region-label{position:absolute;left:-2px;top:-2px;transform:translateY(-100%);font-size:10px;font-weight:700;color:#08120f;background:var(--green);padding:1px 6px;border-radius:4px 4px 4px 0;white-space:nowrap}.zr-handle{position:absolute;width:12px;height:12px;background:#080c0eb8;border:2px solid var(--green);border-radius:2px}.zr-nw{left:-7px;top:-7px;cursor:nwse-resize}.zr-ne{right:-7px;top:-7px;cursor:nesw-resize}.zr-sw{left:-7px;bottom:-7px;cursor:nesw-resize}.zr-se{right:-7px;bottom:-7px;cursor:nwse-resize}.zw-name{flex:1;min-width:0}.zone-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:center;justify-content:center;z-index:60}.zone-panel{background:#11161b;border:1px solid #273039;border-radius:10px;padding:14px;width:min(1100px,94vw);max-height:92vh;overflow:auto}.zone-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.zone-body{display:flex;gap:14px}.zone-surface{position:relative;flex:1;min-width:0;background:#000;border-radius:6px;overflow:hidden;cursor:crosshair;align-self:flex-start}.zone-surface img{display:block;width:100%;height:auto;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.zone-nofame{aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;color:#5a6873;font-size:13px}.zone-surface svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.zone-side{width:280px;display:flex;flex-direction:column;gap:10px}.zone-form{display:flex;flex-direction:column;gap:8px}.zone-form input{background:#0b0f13;border:1px solid #273039;border-radius:6px;color:#dfe7ec;padding:6px 9px;font-size:13px}.zone-classes{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.zone-classes .chip{background:#0b0f13;border:1px solid #273039;color:#9fb0bc;border-radius:999px;padding:2px 10px;font-size:12px;cursor:pointer}.zone-classes .chip.on{border-color:#2ba3ea;color:#dfe7ec}.zone-hint{color:#748391;font-size:12px}.zone-list{display:flex;flex-direction:column;gap:6px}.zone-row{display:flex;align-items:center;gap:8px;background:#0b0f13;border:1px solid #222b33;border-radius:6px;padding:6px 9px;font-size:13px}.zone-dot{width:9px;height:9px;border-radius:50%;flex:none}.zone-name{font-weight:600}.zone-meta{color:#748391;font-size:11px;flex:1}.zone-del{background:none;border:none;color:#5a6873;cursor:pointer}.zone-del:hover{color:#f87171}.zone-note{font-size:12px;color:#9fb0bc}.zone-note.err{color:#f87171}.zone-save{background:#1c6ea8;border:none;color:#fff;padding:8px;border-radius:6px;cursor:pointer;font-weight:600}.zone-save:disabled{opacity:.5;cursor:default}.search-results{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.search-row{display:flex;align-items:center;gap:9px;background:#0b0f13;border:1px solid #222b33;border-radius:6px;padding:5px;cursor:pointer;color:#cfd8df;text-align:left}.search-row:hover{border-color:#2ba3ea}.search-row img,.search-noimg{width:72px;height:40px;object-fit:cover;border-radius:4px;flex:none}.search-noimg{display:inline-block}.search-meta{display:flex;flex-direction:column;font-size:12px;gap:1px}.search-type{font-weight:600;text-transform:capitalize}.zone-panel.cam-settings{width:min(720px,94vw)}.cs-form{display:flex;flex-direction:column;gap:12px}.cs-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.cs-row .pop-label{width:110px;flex:none}.cs-help{cursor:help;text-decoration:underline dotted rgba(255,255,255,.35);text-underline-offset:3px}.cs-row input[type=text],.cs-row input:not([type]){background:#0b0f13;border:1px solid #273039;border-radius:6px;color:#dfe7ec;padding:6px 9px;font-size:13px;flex:1;min-width:140px}.cs-num{display:inline-flex;align-items:center;gap:5px}.cs-num input{width:74px;background:#0b0f13;border:1px solid #273039;border-radius:6px;color:#dfe7ec;padding:5px 7px;font-size:13px}.zone-panel.cs-dialog{width:min(760px,94vw);height:min(600px,86vh);padding:0;display:flex;flex-direction:column;overflow:hidden}.cs-np-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--panel-2);border:1px solid var(--line);color:var(--text-dim);flex:none}.cs-np-icon svg{width:16px;height:16px}.cs-nameplate{display:flex;align-items:center;gap:11px;padding:13px 14px;background:var(--topbar);border-bottom:1px solid var(--line)}.cs-dot{width:9px;height:9px;border-radius:50%;flex:none}.cs-dot.live{background:var(--green);box-shadow:0 0 0 3px #34d39938}.cs-dot.wait{background:var(--amber);box-shadow:0 0 0 3px #f0c45338}.cs-np-text{display:flex;flex-direction:column;min-width:0;flex:1}.cs-np-name{font-size:16px;font-weight:650;color:var(--text);line-height:1.2}.cs-np-sub{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-np-pill{font-size:10.5px;font-weight:600;letter-spacing:.03em;padding:2px 8px;border-radius:999px;flex:none}.cs-np-pill.live{color:var(--green);background:#34d39924}.cs-np-pill.wait{color:var(--amber);background:#f0c45324}.cs-np-close{flex:none;width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--line);background:transparent;color:var(--text-dim);cursor:pointer;font-size:13px}.cs-np-close:hover{background:var(--panel-2);color:var(--text)}.cs-tabs{display:flex;gap:4px;padding:8px 12px 0;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap}.cs-tab{position:relative;display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:none;background:transparent;color:var(--text-dim);font-size:12.5px;font-weight:550;cursor:pointer;border-radius:var(--r-sm) var(--r-sm) 0 0;border-bottom:2px solid transparent}.cs-tab:hover{color:var(--text)}.cs-tab.on{color:var(--text);background:var(--panel-2);border-bottom-color:var(--blue)}.cs-tab.soon{color:var(--text-mute)}.cs-tab.soon.on{color:var(--text)}.cs-soon-badge{font-size:8.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--amber);border:1px solid rgba(240,196,83,.5);border-radius:999px;padding:1px 5px}.cs-tabbody{flex:1;overflow-y:auto;padding:14px 16px}.cs-section-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);margin:4px 0 8px}.cs-general .cs-section-label:not(:first-child){margin-top:18px}.cs-id{display:flex;flex-direction:column}.cs-kv{display:flex;align-items:center;gap:12px;padding:6px 0;border-bottom:1px solid rgba(31,43,49,.55)}.cs-k{width:116px;flex:none;color:var(--text-dim);font-size:12.5px}.cs-v{flex:1;color:var(--text);font-size:13px;display:inline-flex;align-items:center;gap:8px;min-width:0}.cs-v.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.cs-v.cs-ph,.cs-ph{color:var(--text-mute)}.cs-copy{border:1px solid var(--line);background:transparent;color:var(--text-dim);border-radius:var(--r-xs);width:22px;height:22px;cursor:pointer;font-size:12px;opacity:0;transition:opacity .12s ease}.cs-kv:hover .cs-copy{opacity:1}.cs-copy:hover{color:var(--text);background:var(--panel-2)}.cs-streams{display:flex;flex-wrap:wrap;gap:8px}.cs-stream-badge{display:inline-flex;align-items:center;gap:7px;padding:4px 9px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel-2);color:var(--text-dim);font-size:11.5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.cs-stream-cls{font-family:var(--font, system-ui);font-weight:700;font-size:10px;letter-spacing:.04em;color:var(--blue)}.cs-api-note{margin-top:16px;padding:9px 11px;border-radius:var(--r-sm);border:1px solid rgba(240,196,83,.28);background:#f0c45312;color:var(--text-dim);font-size:11.5px;line-height:1.5}.storage-panel{display:flex;flex-direction:column;gap:12px}.storage-disk{display:flex;flex-direction:column;gap:6px}.storage-disk-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.storage-disk-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute)}.storage-bar{height:8px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);overflow:hidden}.storage-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--green))}.storage-table{display:flex;flex-direction:column}.storage-row{display:grid;grid-template-columns:1.3fr .9fr 1.5fr .9fr;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(31,43,49,.55);font-size:12.5px}.storage-head{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-mute)}.storage-cam{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.storage-used{color:var(--text);font-variant-numeric:tabular-nums}.storage-ret{display:flex;flex-direction:column;gap:4px;color:var(--text-dim)}.storage-mini{height:4px;border-radius:999px;background:var(--panel-2);overflow:hidden}.storage-mini-fill{display:block;height:100%;background:var(--blue)}.storage-days{font-variant-numeric:tabular-nums;color:var(--text)}.storage-days.steady{color:var(--green)}.storage-days.unknown,.storage-ph{color:var(--text-mute)}.storage-days.low{color:var(--amber)}.storage-err{color:var(--red, #f87171)}.storage-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:4px}.storage-note{margin-top:0;flex:1}.storage-refresh{flex:none;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--panel-2);color:var(--text-dim);font-size:12px;cursor:pointer}.storage-refresh:hover:not(:disabled){color:var(--text);border-color:var(--blue)}.storage-refresh:disabled{opacity:.5;cursor:default}.cs-footer{border-top:1px solid var(--line);padding:11px 16px;display:flex;flex-direction:column;gap:8px;background:var(--panel)}.cs-footer-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.cs-footer-note{flex:1}.cs-motion-stage{position:relative}.cs-motion-frame{position:relative;aspect-ratio:16 / 9;width:100%;border-radius:var(--r-sm);overflow:hidden;background:radial-gradient(120% 90% at 50% 30%,#16202610,#07090a);border:1px solid var(--line)}.cs-motion-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(to right,transparent,transparent calc(12.5% - 1px),rgba(226,234,238,.12) calc(12.5% - 1px),rgba(226,234,238,.12) 12.5%),repeating-linear-gradient(to bottom,transparent,transparent calc(20% - 1px),rgba(226,234,238,.12) calc(20% - 1px),rgba(226,234,238,.12) 20%)}.cs-motion-mask{position:absolute;left:25%;top:20%;width:37.5%;height:40%;background:#2ba3ea2e;border:1px solid rgba(43,163,234,.7);border-radius:2px}.cs-sens{display:flex;align-items:center;gap:5px;margin-top:12px}.cs-sens-end{font-size:10.5px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.04em}.cs-sens-tick{flex:1;text-align:center;font-size:11px;color:var(--text-mute);padding:5px 0;border-radius:var(--r-xs);background:var(--panel-2)}.cs-sens-tick.on{color:#07090a;background:var(--blue);font-weight:600}.cs-soon-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#07090a94;border-radius:var(--r-sm)}.cs-soon-blank{display:flex;align-items:center;justify-content:center;min-height:220px}.cs-soon-chip{display:flex;flex-direction:column;gap:7px;max-width:340px;text-align:center;padding:16px 18px;border-radius:var(--r-md);border:1px solid rgba(240,196,83,.45);background:var(--panel-2);box-shadow:var(--shadow-2)}.cs-soon-chip strong{color:var(--text);font-size:14px}.cs-soon-chip span{color:var(--text-dim);font-size:12px;line-height:1.5}.cs-soon-cta{align-self:center;margin-top:4px;padding:6px 14px;border-radius:var(--r-sm);border:1px solid var(--blue);background:transparent;color:var(--blue);font-size:12px;font-weight:600;cursor:pointer}.cs-soon-cta:hover{background:#2ba3ea1f}.tooltip-pop{position:fixed;z-index:9999;pointer-events:none;max-width:min(280px,90vw);padding:5px 9px;border-radius:var(--r-sm);background:#0b1216;border:1px solid var(--line);color:var(--text);font-size:12px;font-weight:500;line-height:1.4;white-space:pre-line;box-shadow:var(--shadow-2);animation:tt-fade .09s ease-out}.tooltip-pop.top{transform:translate(-50%,calc(-100% - 8px))}.tooltip-pop.bottom{transform:translate(-50%,8px)}@keyframes tt-fade{0%{opacity:0}to{opacity:1}}.sound-ctl{position:absolute;right:12px;bottom:12px;z-index:4;display:flex;align-items:center;height:32px;padding:0 4px;border-radius:999px;background:#080c0e99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12)}.stage-video .sound-ctl{right:14px;bottom:14px}.sound-btn{width:26px;height:26px;display:grid;place-items:center;border-radius:999px;color:#cfd8df;cursor:pointer;background:none;border:none}.sound-ctl.on .sound-btn{color:#6fc6f5}.sound-btn:hover{color:#fff}.sound-vol{width:0;opacity:0;transition:width .15s ease,opacity .15s ease;accent-color:var(--blue);cursor:pointer}.sound-ctl:hover .sound-vol,.sound-ctl.on .sound-vol{width:72px;opacity:1;margin:0 6px 0 2px}.dewarp-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:#000;cursor:grab;touch-action:none}.dewarp-canvas:active{cursor:grabbing}.zones-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;cursor:crosshair}.zones-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.zones-layer-hint{position:absolute;left:50%;bottom:18px;transform:translate(-50%);background:#080c0eb8;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:6px 14px;font-size:12px;color:#cfe0e8;pointer-events:none}.zones-panel .zone-name-input{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--text);padding:6px 9px;font-size:13px;width:100%}.zones-foot{margin-top:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line)}.search-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;cursor:crosshair;touch-action:none}.search-rect{position:absolute;border:2px solid var(--blue);background:#2ba3ea21;pointer-events:none}.search-layer-hint{position:absolute;left:50%;bottom:18px;transform:translate(-50%);background:#080c0eb8;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:6px 14px;font-size:12px;color:#cfe0e8;pointer-events:none}.search-panel .search-controls{padding:10px 12px;display:flex;flex-direction:column;gap:9px;border-bottom:1px solid var(--line)}.search-panel .search-results{flex:1;min-height:0;max-height:none;overflow-y:auto;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.layout-tabs{flex:none;display:flex;align-items:stretch;height:38px;background:var(--panel);border-bottom:1px solid var(--line);padding:0 6px;overflow-x:auto;overflow-y:visible}.layout-tab{position:relative;display:flex;align-items:center;gap:7px;height:38px;padding:0 10px;border:none;border-right:1px solid var(--line);background:transparent;color:var(--text-dim);font-size:12.5px;font-weight:550;white-space:nowrap;cursor:pointer;flex:0 0 auto;max-width:220px}.layout-tab:hover{background:var(--panel-2);color:var(--text)}.layout-tab.active{color:#fff;background:var(--panel-2);box-shadow:inset 0 -2px 0 var(--blue)}.layout-tab svg{width:15px;height:15px;flex:none}.layout-tab-name{min-width:0;overflow:hidden;text-overflow:ellipsis}.layout-tab-count{font-size:10.5px;color:var(--text-mute);font-variant-numeric:tabular-nums}.layout-tab-close{width:18px;height:18px;display:grid;place-items:center;border:none;background:transparent;color:var(--text-mute);font-size:12px;border-radius:4px;cursor:pointer}.layout-tab-close:hover{background:#ffffff1a;color:#fff}.layout-tab-add,.layout-tab-dd{flex:none;width:32px;height:38px;display:grid;place-items:center;border:none;border-right:1px solid var(--line);background:transparent;color:var(--text-dim);font-size:16px;cursor:pointer}.layout-tab-add:hover,.layout-tab-dd:hover,.layout-tab-dd.active{background:var(--panel-2);color:#fff}.layout-tab-dd svg{width:14px;height:14px;transform:rotate(-90deg)}.layout-tab-dd-wrap{position:relative;flex:none}.layout-menu{position:absolute;top:38px;left:0;z-index:40;min-width:220px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 20px 48px #0000008c;padding:5px;display:flex;flex-direction:column;gap:2px}.layout-menu-section{padding:6px 8px 3px;color:var(--text-mute);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.layout-menu-empty{padding:4px 8px 8px;color:var(--text-mute);font-size:12px}.layout-menu-item{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;height:32px;padding:0 9px;border:none;background:transparent;color:var(--text);font-size:13px;border-radius:5px;text-align:left;cursor:pointer}.layout-menu-item:hover{background:var(--panel-2)}.layout-menu-item.active{background:var(--select);color:#fff}.layout-menu-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layout-menu-count{font-size:11px;color:var(--text-mute);font-variant-numeric:tabular-nums}.layout-menu-sep{height:1px;background:var(--line);margin:3px 0}.stage-video{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;background:var(--bg)}.stage-video>.camera-tile{flex:1;border-radius:0;min-width:0;min-height:0}.stage-restore{position:absolute;top:12px;left:12px;z-index:30;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#0a0e1099;color:var(--text);cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:.55;transition:opacity .15s ease,background .15s ease,color .15s ease}.stage-video:hover .stage-restore{opacity:1}.stage-restore:hover{background:#141c20eb;color:#fff}.detail-transition-ghost{position:fixed;left:0;top:0;z-index:80;overflow:hidden;pointer-events:none;transform-origin:0 0;will-change:transform,opacity;background:#050608;border:1px solid rgba(43,163,234,.55);box-shadow:0 18px 48px #00000085}.detail-transition-ghost>*{display:block;object-fit:cover}
