:root{--bg-0:#f1f4fb;--bg-1:#fff;--bg-2:#f7f8fc;--bg-3:#eef0f8;--bg-elev:#fff;--line:#e3e6f0;--line-strong:#c8cee0;--fg-0:#1a1d2e;--fg-1:#4a5169;--fg-2:#7a82a0;--fg-3:#a4abc0;--accent:#6f5dfd;--accent-strong:#5847e6;--accent-soft:#6f5dfd1a;--rec:#ef4e5e;--warn:#f59e0b;--ok:#22c55e;--info:#3b82f6;--pill:999px;--r-sm:6px;--r:10px;--r-lg:14px;--shadow-1:0 1px 2px #141e5014;--shadow-2:0 12px 32px #323c7826;--kbd-bg:#eef0f8;--grad-purple:linear-gradient(135deg, #7c6dff 0%, #a48cff 100%);--grad-purple-soft:linear-gradient(135deg, #efedff 0%, #f6f2ff 100%);--grad-blue:linear-gradient(135deg, #5b8def 0%, #6f5dfd 100%);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--bg-0:#0b0d12;--bg-1:#11141b;--bg-2:#181c25;--bg-3:#232836;--bg-elev:#1c2030;--line:#2a2f3d;--line-strong:#3a4054;--fg-0:#e8ecf2;--fg-1:#b8bfcc;--fg-2:#7a8294;--fg-3:#555c6e;--accent:#8b75ff;--accent-strong:#6f5dfd;--accent-soft:#8b75ff2e;--kbd-bg:#2a2f3d;--shadow-1:0 1px 2px #0006;--shadow-2:0 8px 24px #00000080;--grad-purple:linear-gradient(135deg, #6f5dfd 0%, #8b75ff 100%);--grad-purple-soft:linear-gradient(135deg, #2a2240 0%, #1f1a30 100%);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body,#root{background:var(--bg-0);color:var(--fg-0);-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;margin:0;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic UI,Noto Sans JP,Segoe UI,Roboto,sans-serif;font-size:14px}html,body{min-height:100%}#root{flex-direction:column;min-height:100vh;display:flex}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;background:0 0;border:0;padding:0}input,select,textarea{color:inherit;font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--line-strong)}.app{flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{background:var(--bg-1);border-bottom:1px solid var(--line);height:60px;box-shadow:var(--shadow-1);z-index:30;flex-shrink:0;align-items:center;gap:14px;padding:0 18px;display:flex;position:sticky;top:0}.brand{letter-spacing:.01em;align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.brand-mark{flex-shrink:0;display:inline-block}.brand-name{white-space:nowrap}.brand-name b{color:var(--accent)}.spacer{flex:1}.tabs{background:var(--bg-2);border-radius:var(--pill);gap:2px;padding:4px;display:inline-flex}.tab{border-radius:var(--pill);color:var(--fg-1);align-items:center;gap:6px;padding:7px 18px;font-size:13px;font-weight:500;display:inline-flex}.tab.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #6f5dfd4d}.tab:hover:not(.active){color:var(--fg-0);background:var(--bg-3)}.user-chip{border-radius:var(--pill);background:var(--bg-2);color:var(--fg-1);align-items:center;gap:8px;padding:5px 10px 5px 5px;font-size:13px;display:flex}.user-avatar{background:var(--grad-purple);color:#fff;border-radius:50%;place-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:grid}.btn-ghost{border-radius:var(--r-sm);color:var(--fg-1);padding:6px 12px;font-size:13px}.btn-ghost:hover{color:var(--fg-0);background:var(--bg-2)}.burger{color:var(--fg-1);padding:8px 12px;font-size:18px;line-height:1}.burger:hover{color:var(--fg-0);background:var(--bg-2);border-radius:var(--r-sm)}.stream-info{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;border-radius:var(--r-sm);pointer-events:none;background:#0000006b;min-width:200px;padding:10px 14px;font-size:12px;line-height:1.6;position:absolute;bottom:14px;left:14px;box-shadow:0 4px 16px #0000004d}.stream-info-h{text-transform:uppercase;letter-spacing:.08em;opacity:.65;margin-bottom:6px;font-size:10px;font-weight:600}.stream-info-row{justify-content:space-between;gap:16px;display:flex}.stream-info-row .muted{color:#ffffffa6}.whep-player{width:100%;height:100%;display:contents;position:relative}.whep-overlay{color:#fff;background:#0000008c;place-items:center;display:grid;position:absolute;inset:0}.whep-spin{opacity:.9;font-size:14px}.whep-err{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.whep-err .icon{font-size:30px}.live-dot{background:var(--rec);width:8px;height:8px;box-shadow:0 0 8px var(--rec);border-radius:50%;margin-right:4px;animation:1.6s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.shell{background:var(--bg-0);flex:1;position:relative}.page{width:100%;max-width:1180px;margin:0 auto;padding:0 16px 32px}.page-header{text-align:center;background:var(--bg-1);border-bottom:1px solid var(--line);padding:18px 16px 14px}.page-header-title{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0 0 12px;font-size:15px;font-weight:600}.page-header-divider{background:var(--accent);border-radius:2px;width:60px;height:2px;margin:0 auto 14px}.page-header-tabs{background:var(--bg-2);border-radius:var(--pill);padding:4px;display:inline-flex}.page-header-tab{border-radius:var(--pill);color:var(--fg-1);align-items:center;gap:6px;padding:7px 22px;font-size:13px;font-weight:500;display:inline-flex}.page-header-tab.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #6f5dfd40}.cam-title-strip{text-align:center;padding:14px 12px 10px}.cam-title-name{color:var(--fg-0);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:8px;padding:4px 14px;font-size:17px;font-weight:600;transition:background .12s;display:inline-flex}.cam-title-name:hover{background:var(--bg-2)}.cam-title-name .chev{color:var(--fg-2);font-size:12px}.cam-title-loc{color:var(--fg-2);margin-top:4px;font-size:12px;display:block}.sb-backdrop{z-index:19;background:#14183273;animation:.16s fadeIn;display:none;position:fixed;inset:60px 0 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar{background:var(--bg-1);border-right:1px solid var(--line);z-index:20;flex-direction:column;width:320px;max-width:88vw;min-height:0;transition:transform .22s;display:flex;position:fixed;top:60px;bottom:0;left:0;transform:translate(-100%);box-shadow:8px 0 32px #141e501a}.sidebar.open{transform:translate(0)}.app.sb-open .sb-backdrop{display:block}.sidebar-header{border-bottom:1px solid var(--line);align-items:center;gap:8px;padding:14px 18px;display:flex}.sidebar-title{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-2);font-size:11px;font-weight:600}.sidebar-search{border-radius:var(--r-sm);border:1px solid var(--line);background:var(--bg-2);margin:12px 14px 4px;padding:8px 12px;font-size:13px}.sidebar-search:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.sidebar-scroll{flex:1;padding:6px 10px 16px;overflow:auto}.cam-card{border-radius:var(--r);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;grid-template-columns:96px 1fr;gap:10px;width:100%;margin-bottom:4px;padding:8px;display:grid}.cam-card:hover{background:var(--bg-2)}.cam-card.active{background:var(--accent-soft);border-color:var(--accent)}.cam-thumb{aspect-ratio:16/9;border-radius:var(--r-sm);background:var(--bg-3);position:relative;overflow:hidden}.cam-thumb img{object-fit:cover;width:100%;height:100%;display:block}.cam-thumb .badge{border-radius:var(--r-sm);color:#fff;background:#0000008c;padding:2px 6px;font-size:10px;position:absolute;top:4px;left:4px}.cam-info{min-width:0}.cam-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.cam-loc{color:var(--fg-2);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.cam-meta{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.tag{border-radius:var(--pill);background:var(--bg-3);color:var(--fg-1);padding:2px 7px;font-size:10px;font-weight:500}.tag.online{color:var(--ok);background:#22c55e26}.tag.offline{color:var(--rec);background:#ef4e5e26}.tag.ptz{color:var(--accent);background:#6f5dfd1f}.tag.lte{color:var(--warn);background:#f59e0b2e}.cam-dropdown{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r);width:min(420px,92vw);max-height:60vh;box-shadow:var(--shadow-2);z-index:30;padding:6px;position:absolute;top:calc(100% + 6px);left:50%;overflow-y:auto;transform:translate(-50%)}.video-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);margin:6px 0 14px;overflow:hidden}.viewer{aspect-ratio:16/9;cursor:pointer;background:#0b0d12;place-items:center;display:grid;position:relative;overflow:hidden}.viewer .viewer-overlay,.viewer .viewer-actions,.viewer .wl-status,.viewer .stream-info{transition:opacity .18s}.viewer.chrome-hidden .viewer-overlay,.viewer.chrome-hidden .viewer-actions,.viewer.chrome-hidden .wl-status,.viewer.chrome-hidden .stream-info{opacity:0;pointer-events:none}.viewer-img{object-fit:contain;background:#000;width:100%;height:100%;display:block}.mjpeg-poster,.mjpeg-live{grid-area:1/1}.mjpeg-live{opacity:0;transition:opacity .2s}.mjpeg-live.loaded{opacity:1}.viewer-overlay{pointer-events:none;position:absolute;inset:0}.viewer-badge-top-left,.viewer-badge-top-right{border-radius:var(--r-sm);color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000061;padding:6px 10px;font-size:13px;position:absolute}.viewer-badge-top-left{font-weight:500;top:14px;left:14px}.viewer-badge-top-right{font-variant-numeric:tabular-nums;top:14px;right:14px}.viewer-actions{pointer-events:auto;gap:8px;display:flex;position:absolute;bottom:12px;right:12px}.viewer-actions .btn{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000005c;border:0}.viewer-actions .btn:hover{background:#0000009e}.btn{border-radius:var(--r-sm);background:var(--bg-1);color:var(--fg-0);border:1px solid var(--line);align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .12s;display:inline-flex}.btn:hover:not(:disabled){background:var(--bg-2);border-color:var(--line-strong)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong);box-shadow:0 4px 12px #6f5dfd4d}.btn.danger{color:var(--rec);background:#ef4e5e1f;border-color:#ef4e5e4d}.btn.icon{aspect-ratio:1;justify-content:center;padding:8px}.btn.sm{padding:5px 10px;font-size:12px}.kbd{background:var(--kbd-bg);border:1px solid var(--line-strong);color:var(--fg-1);border-radius:4px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.ptz-band{border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow-1);margin:16px 0;overflow:hidden}.ptz-band-header{background:var(--grad-purple);color:#fff;text-align:center;letter-spacing:.08em;cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;gap:8px;padding:11px;font-size:13px;font-weight:600;display:flex}.ptz-band-header .chev{opacity:.8;font-size:11px}.ptz-band-body{background:var(--bg-1);grid-template-columns:auto 1fr auto;align-items:center;gap:28px;padding:22px 20px 16px;display:grid}.ptz-band-body .ptz-help{color:var(--fg-2);text-align:center;margin-top:8px;font-size:11px}.ptz-band-zoom{flex-direction:column;gap:10px;display:flex}.ptz-band-zoom-row{grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;display:grid}.ptz-band-zoom input[type=range]{width:100%;accent-color:var(--accent)}.ptz-band.collapsed .ptz-band-body,.ptz-band.collapsed .ptz-band-presets{display:none}.ptz-band-presets{background:var(--bg-1);border-top:1px solid var(--line);padding:14px 20px}.ptz-band-presets-h{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-2);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:11px;font-weight:600;display:flex}.preset-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.preset-cell{aspect-ratio:16/9;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--fg-1);cursor:pointer;text-align:center;place-items:center;padding:4px;font-size:12px;display:grid;position:relative;overflow:hidden}.preset-cell.set{color:var(--fg-0);border-color:var(--line-strong);background:var(--bg-1)}.preset-cell.set:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.preset-cell .num{color:var(--fg-2);font-size:10px;font-weight:600;position:absolute;top:3px;left:6px}.preset-cell .nm{max-height:28px;font-size:12px;line-height:1.2;overflow:hidden}.preset-cell.add{color:var(--fg-2);border-style:dashed}.preset-cell.add:hover{color:var(--accent);border-color:var(--accent)}.preset-cell .del{opacity:0;color:var(--rec);font-size:10px;transition:opacity .12s;position:absolute;top:3px;right:6px}.preset-cell:hover .del{opacity:1}.joystick-wrap{place-items:center;display:grid}.joystick{background:radial-gradient(circle at 50% 50%, var(--bg-2) 0%, var(--bg-3) 70%, var(--bg-2) 100%);border:1px solid var(--line-strong);touch-action:none;cursor:grab;border-radius:50%;width:170px;height:170px;position:relative;box-shadow:inset 0 2px 6px #0000000f}.joystick:active{cursor:grabbing}.joystick-knob{background:var(--grad-purple);border-radius:50%;width:56px;height:56px;transition:transform 80ms;position:absolute;top:calc(50% - 28px);left:calc(50% - 28px);box-shadow:0 4px 16px #6f5dfd66,inset 0 0 0 1px #fff3}.joystick-arrow{color:var(--fg-2);pointer-events:none;font-size:14px;position:absolute}.joystick-arrow.up{top:8px;left:calc(50% - 6px)}.joystick-arrow.down{bottom:8px;left:calc(50% - 6px)}.joystick-arrow.left{top:calc(50% - 8px);left:8px}.joystick-arrow.right{top:calc(50% - 8px);right:8px}.timeline-bar{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);margin:6px 0 14px;padding:14px 18px}.tl-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;display:flex}.tl-date{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--fg-0);padding:6px 10px;font-size:13px}.tl-zoom{background:var(--bg-2);border-radius:var(--pill);gap:2px;padding:3px;display:flex}.tl-zoom button{border-radius:var(--pill);color:var(--fg-2);padding:4px 14px;font-size:12px;font-weight:500}.tl-zoom button.active{background:var(--accent);color:#fff}.tl-legend{color:var(--fg-2);flex-wrap:wrap;gap:12px;margin-left:auto;font-size:11px;display:flex}.tl-legend .sw{vertical-align:-1px;border-radius:2px;width:10px;height:10px;margin-right:4px;display:inline-block}.sw.cont{background:var(--accent)}.sw.motion{background:var(--warn)}.sw.event-person{background:var(--ok)}.sw.event-vehicle{background:var(--info)}.sw.event-intrusion{background:var(--rec)}.tl-wrap{position:relative}.tl{background:var(--bg-2);border-radius:var(--r-sm);cursor:crosshair;-webkit-user-select:none;user-select:none;border:1px solid var(--line);height:78px;position:relative;overflow:hidden}.tl-hour{background:var(--line);width:1px;position:absolute;top:0;bottom:0}.tl-hour-label{color:var(--fg-2);font-variant-numeric:tabular-nums;font-size:10px;position:absolute;top:4px;transform:translate(2px)}.tl-rec{background:var(--accent);opacity:.9;border-radius:3px;height:14px;position:absolute;bottom:8px}.tl-rec.motion{background:var(--warn)}.tl-rec.manual{background:#b478ff}.tl-event{border:1.5px solid var(--bg-2);border-radius:50%;width:9px;height:9px;position:absolute;top:32px;transform:translate(-4px)}.tl-event.person{background:var(--ok)}.tl-event.vehicle{background:var(--info)}.tl-event.motion{background:var(--warn)}.tl-event.intrusion{background:var(--rec);box-shadow:0 0 6px var(--rec)}.tl-event.weather{background:#b478ff}.tl-preview{pointer-events:none;border-radius:var(--r-sm);z-index:5;background:#000000b3;width:240px;position:absolute;bottom:calc(100% + 6px);overflow:hidden;box-shadow:0 6px 18px #00000059}.tl-preview-img{object-fit:cover;background:#000;width:100%;height:135px;display:block}.tl-preview-empty{background:var(--bg-3);width:100%;height:135px;color:var(--fg-3);place-items:center;font-size:22px;display:grid}.tl-preview-time{color:#fff;text-align:center;font-variant-numeric:tabular-nums;padding:4px 8px;font-size:12px}.tl-cursor{background:var(--accent);pointer-events:none;width:2px;box-shadow:0 0 6px var(--accent);position:absolute;top:0;bottom:0}.tl-cursor:before{content:"";background:var(--accent);width:12px;height:12px;box-shadow:0 0 8px var(--accent);border-radius:50%;position:absolute;top:-4px;left:-5px}.tl-now{background:var(--rec);opacity:.9;width:2px;position:absolute;top:0;bottom:0}.tl-selection{background:var(--accent-soft);border-left:1px solid var(--accent);border-right:1px solid var(--accent);position:absolute;top:0;bottom:0}.pb{align-items:center;gap:12px;padding-top:10px;display:flex}.pb-time{font-variant-numeric:tabular-nums;color:var(--fg-1);min-width:220px;font-size:13px}.pb-time strong{color:var(--fg-0);font-size:16px}.pb-spd{background:var(--bg-2);border-radius:var(--pill);gap:2px;padding:3px;display:flex}.pb-spd button{color:var(--fg-2);border-radius:var(--pill);padding:4px 10px;font-size:12px;font-weight:500}.pb-spd button.active{background:var(--accent);color:#fff}.pb-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.info-grid{grid-template-columns:minmax(220px,1fr) minmax(220px,1fr) minmax(280px,2fr);gap:14px;margin:14px 0 24px;display:grid}.info-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-1);padding:14px 16px}.info-h{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-2);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:11px;font-weight:600;display:flex}.info-stats{flex-direction:column;gap:8px;display:flex}.info-stats .row{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:center;padding:4px 0;display:flex}.info-stats .row:last-child{border-bottom:0}.info-stats .row strong{font-size:16px}.events-list{flex-direction:column;gap:6px;max-height:220px;display:flex;overflow:auto}.event-row{border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--line);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;width:100%;padding:8px 10px;font-size:12px;display:flex}.event-row:hover{background:var(--bg-3);border-color:var(--line-strong)}.event-row .left{align-items:center;gap:10px;display:flex}.event-row .tl-event{border:0!important;position:static!important;transform:none!important}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#14183273;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-2);width:min(560px,100%);max-height:80vh;overflow:auto}.modal-h{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-h h3{margin:0;font-size:15px}.modal-b{padding:18px 20px}.modal-f{border-top:1px solid var(--line);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.field{margin-bottom:14px}.field label{color:var(--fg-2);margin-bottom:6px;font-size:12px;display:block}.field input,.field select{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);width:100%;color:var(--fg-0);padding:8px 10px;font-size:13px}.field input:focus,.field select:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.wl-overlay{pointer-events:none;position:absolute;inset:0}.wl-line{border-top-style:dashed;border-top-width:2px;height:0;position:absolute;left:0;right:0;transform:translateY(-1px)}.wl-line-yellow{border-color:#ffd60a;border-top-style:solid;box-shadow:0 0 6px #ffd60a99}.wl-line-red{pointer-events:auto;cursor:ns-resize;border-color:#ff4757;margin-top:-10px;padding:10px 0}.wl-line-blue{pointer-events:auto;cursor:ns-resize;border-color:#4ea1ff;margin-top:-10px;padding:10px 0}.wl-line-red,.wl-line-blue{transform:translateY(-11px)}.wl-handle{color:#fff;border-radius:var(--r-sm);white-space:nowrap;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0000006b;padding:3px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;right:12px}.wl-handle-red{color:#ffb1b9}.wl-handle-blue{color:#b6daff}.wl-tag{color:#ffd60a;border-radius:var(--r-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0000006b;padding:3px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;left:12px}.wl-area{mix-blend-mode:multiply;background:#2ed57352;position:absolute;bottom:0;left:0;right:0}.wl-mask{pointer-events:none;mix-blend-mode:multiply;background:#2ed5738c;position:absolute;inset:0;-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.wl-status{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;border-radius:var(--r);pointer-events:auto;background:#0000006b;width:200px;padding:10px 12px;font-size:12px;position:absolute;top:56px;right:14px;box-shadow:0 4px 16px #0000004d}.wl-status:hover{background:#0009}.wl-status-h{text-transform:uppercase;letter-spacing:.08em;opacity:.65;margin-bottom:8px;font-size:10px;font-weight:700}.wl-status-row{justify-content:space-between;gap:12px;padding:2px 0;display:flex}.wl-status-row .muted{color:#fff9}.wl-status-high strong{color:#ff6b78}.wl-status-normal strong{color:#2ed573}.wl-status-low strong{color:#f5a623}.wl-status-unknown strong{color:var(--fg-2)}.log-panel{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);flex-direction:column;max-height:280px;margin:0 0 14px;display:flex;overflow:hidden}.log-panel-h{background:var(--bg-2);border-bottom:1px solid var(--line);align-items:center;gap:8px;padding:8px 12px;font-size:12px;display:flex}.log-panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-2);font-size:11px;font-weight:600}.log-panel-count{border-radius:var(--pill);background:var(--bg-3);font-variant-numeric:tabular-nums;padding:1px 6px}.log-panel-body{background:var(--bg-1);flex:1;padding:6px 12px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5;overflow:auto}.log-empty{text-align:center;padding:14px 0}.log-line{white-space:pre-wrap;word-break:break-word;grid-template-columns:auto auto 1fr;gap:8px;padding:1px 0;display:grid}.log-time{color:var(--fg-3)}.log-level{text-transform:uppercase;letter-spacing:.06em;border-radius:var(--r-sm);text-align:center;align-self:center;padding:0 6px;font-size:10px;font-weight:600}.log-level.lvl-info{color:var(--info);background:#4ea1ff1f}.log-level.lvl-warn{color:var(--warn);background:#f59e0b1f}.log-level.lvl-err{color:var(--rec);background:#ef4e5e1f}.log-msg{color:var(--fg-0)}.log-line.lvl-err .log-msg{color:var(--rec)}.log-line.lvl-warn .log-msg{color:var(--warn)}.url-preview{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);align-items:center;gap:6px;padding:6px 8px;display:flex}.url-preview code{white-space:nowrap;min-width:0;color:var(--fg-0);-webkit-user-select:text;user-select:text;flex:1;font-size:12px;overflow-x:auto}.url-preview button{flex:none}.radio-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.radio-card{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg-2);cursor:pointer;text-align:left;padding:10px 12px}.radio-card.active{border-color:var(--accent);background:var(--accent-soft)}.radio-card .rt{font-size:13px;font-weight:500}.radio-card .rd{color:var(--fg-2);margin-top:2px;font-size:11px}.lang-switch{position:relative}.lang-btn{border-radius:var(--r-sm);align-items:center;gap:6px;padding:6px 10px;font-size:13px;display:inline-flex}.lang-btn:hover{background:var(--bg-2)}.lang-code{letter-spacing:.04em;color:var(--fg-1);font-size:11px;font-weight:700}.lang-menu{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--r);min-width:160px;box-shadow:var(--shadow-2);z-index:30;padding:4px;position:absolute;top:calc(100% + 6px);right:0}.lang-item{border-radius:var(--r-sm);text-align:left;align-items:center;gap:8px;width:100%;padding:8px 10px;font-size:13px;display:flex}.lang-item:hover{background:var(--bg-2)}.lang-item.active{background:var(--accent-soft);color:var(--fg-0)}.lang-item.active:after{content:"✓";color:var(--accent);margin-left:auto}.theme-toggle{border-radius:var(--r-sm);color:var(--fg-1);padding:6px 10px;font-size:16px;line-height:1}.theme-toggle:hover{background:var(--bg-2);color:var(--fg-0)}.sc-menu{width:280px;padding:12px 14px}.sc-h{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-2);border-bottom:1px solid var(--line);margin-bottom:8px;padding-bottom:8px;font-size:11px;font-weight:600}.sc-group{margin-bottom:10px}.sc-group:last-child{margin-bottom:0}.sc-group-title{color:var(--fg-1);margin-bottom:6px;font-size:11px;font-weight:600}.sc-row{justify-content:space-between;align-items:center;padding:4px 0;font-size:12px;display:flex}.sc-keys{gap:3px;display:inline-flex}.sc-label{color:var(--fg-2);text-align:right;margin-left:12px}.toast{background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:var(--r);box-shadow:var(--shadow-2);z-index:100;padding:10px 16px;font-size:13px;animation:.2s toastIn;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.toast.ok{color:var(--ok);border-color:#22c55e80}.toast.err{color:var(--rec);border-color:#ef4e5e80}.empty{color:var(--fg-2);text-align:center;flex-direction:column;place-items:center;padding:40px 24px;font-size:14px;display:grid}.empty .icon{margin-bottom:12px;font-size:36px}.row{align-items:center;gap:8px;display:flex}.row.between{justify-content:space-between}.col{flex-direction:column;gap:8px;display:flex}.muted{color:var(--fg-2);font-size:12px}.mono{font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.shortcut-hint{color:var(--fg-2);align-items:center;gap:4px;font-size:11px;display:inline-flex}@media (width<=1023px){.info-grid{grid-template-columns:1fr 1fr}.info-grid .info-card:last-child{grid-column:1/-1}.preset-grid{grid-template-columns:repeat(4,1fr)}.ptz-band-body{grid-template-columns:auto 1fr;gap:18px}.ptz-band-body .ptz-band-zoom{grid-column:1/-1}.hide-md{display:none!important}.lang-btn .lang-code{display:none}}@media (width<=767px){.topbar{gap:8px;padding:0 10px}.tabs .tab{padding:6px 12px;font-size:12px}.brand-name{display:none}.hide-sm{display:none!important}.page{padding:0 12px 24px}.page-header{padding:14px 12px 12px}.page-header-title{margin-bottom:8px;font-size:13px}.ptz-band-body{grid-template-columns:1fr;gap:14px;padding:16px 14px}.preset-grid{grid-template-columns:repeat(3,1fr)}.joystick{width:150px;height:150px}.info-grid{grid-template-columns:1fr}.info-grid .info-card:last-child{grid-column:auto}.tl-toolbar{gap:8px}.tl-legend{width:100%;font-size:10px}.tl{height:64px}.pb{flex-wrap:wrap;gap:6px}.pb-time{flex:100%;order:5;min-width:auto;font-size:12px}.pb-actions{flex:100%;order:6}.pb-actions .btn{justify-content:center;width:100%}.pb-spd button,.viewer-badge-top-left,.viewer-badge-top-right{padding:4px 8px;font-size:11px}.viewer-actions .btn{padding:6px 10px;font-size:12px}.modal{max-height:calc(100vh - 32px)}.radio-grid{grid-template-columns:1fr}}@media (width<=419px){.topbar{padding:0 8px}.tabs .tab{padding:5px 10px;font-size:11px}.lang-btn{padding:5px 7px}.pb-spd{display:none}.preset-grid{grid-template-columns:repeat(3,1fr)}}
