:root{--bg: #0a0e14;--bg2: #0d121a;--panel: #141a24;--panel2: #1a2230;--border: #232c3a;--border2: #2e3a4d;--txt: #e8eef6;--dim: #8a97a8;--dim2: #66738a;--accent: #3b82f6;--accent2: #60a5fa;--accent-soft: rgba(59,130,246,.12);--ok: #22c55e;--warn: #eab308;--danger: #ef4444;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 16px rgba(0,0,0,.35);--shadow-lg: 0 16px 48px rgba(0,0,0,.5);--tr: .18s cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg);color:var(--txt);font-family:system-ui,Segoe UI,Roboto,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background-image:radial-gradient(1200px 600px at 80% -10%,rgba(59,130,246,.06),transparent 60%)}button{font-family:inherit;cursor:pointer;transition:var(--tr)}a{color:var(--accent2);text-decoration:none}a:hover{text-decoration:underline}::selection{background:var(--accent-soft)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#283142;border-radius:6px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#34405580}h1,h2,h3{letter-spacing:-.01em}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(700px 400px at 50% -5%,rgba(59,130,246,.16),transparent 60%),radial-gradient(600px 400px at 90% 110%,rgba(137,87,229,.12),transparent 60%)}.login-card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--border2);border-radius:16px;padding:36px 34px;width:380px;box-shadow:var(--shadow-lg);animation:pop .22s cubic-bezier(.4,0,.2,1)}.brand{display:flex;align-items:center;gap:11px;margin-bottom:8px}.brand .logo{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#8957e5);display:grid;place-items:center;font-weight:800;color:#fff;box-shadow:0 6px 18px #3b82f666}.brand h1{font-size:20px;margin:0;font-weight:700}.muted{color:var(--dim);font-size:13px}.field{margin-top:14px}.field label{display:block;font-size:12px;color:var(--dim);margin-bottom:5px}.field input{width:100%;padding:11px 12px;background:var(--bg);color:var(--txt);border:1px solid var(--border);border-radius:8px;font-size:14px}.btn{width:100%;margin-top:18px;padding:11px;background:var(--accent);color:#fff;border:0;border-radius:8px;font-size:14px;font-weight:600}.btn:hover{background:var(--accent2)}.btn:disabled{opacity:.6;cursor:default}.err{color:var(--danger);font-size:13px;margin-top:12px}.shell{display:grid;grid-template-columns:232px 1fr;grid-template-rows:58px 1fr;grid-template-areas:"top top" "side main";height:100vh;transition:grid-template-columns var(--tr)}.shell.collapsed{grid-template-columns:64px 1fr}.topbar{grid-area:top;display:flex;align-items:center;gap:14px;padding:0 18px;background:linear-gradient(180deg,var(--panel),var(--bg2));border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hamburger{background:transparent;border:0;color:var(--dim);font-size:18px;width:34px;height:34px;border-radius:8px;display:grid;place-items:center}.hamburger:hover{background:var(--panel2);color:var(--txt)}.topbar .spacer{flex:1}.topbar .org{font-size:13px;color:var(--dim)}.topbar .org b{color:var(--txt)}.org-user{opacity:.8}.logout{background:transparent;color:var(--dim);border:1px solid var(--border);padding:7px 14px;border-radius:8px;font-size:13px}.logout:hover{color:var(--txt);border-color:var(--dim2);background:var(--panel2)}.sidebar{grid-area:side;background:var(--panel);border-right:1px solid var(--border);padding:14px 10px;overflow:hidden}.nav{display:flex;flex-direction:column;gap:3px}.nav button{position:relative;display:flex;align-items:center;gap:12px;text-align:left;background:transparent;border:0;color:var(--dim);padding:11px 12px;border-radius:9px;font-size:14px;font-weight:500;white-space:nowrap}.nav button:hover{background:var(--panel2);color:var(--txt)}.nav button.active{background:var(--accent-soft);color:var(--accent2);font-weight:600}.nav button.active:before{content:"";position:absolute;left:-10px;top:9px;bottom:9px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.nav-ico{width:20px;text-align:center;flex:none;font-size:15px}.shell.collapsed .nav-lbl{display:none}.shell.collapsed .nav button{justify-content:center;padding:11px 0}.shell.collapsed .nav button.active:before{left:-10px}.main{grid-area:main;padding:22px 26px;overflow:auto}.main h2{margin:2px 0 18px;font-size:21px;font-weight:650}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:22px}.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:var(--tr)}.card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:var(--shadow)}.card .k{color:var(--dim);font-size:12.5px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.card .v{font-size:32px;font-weight:750;margin-top:8px;letter-spacing:-.02em}.card .v.warn{color:var(--warn)}.card .v.danger{color:var(--danger)}.card .v.ok{color:var(--ok)}.card-sub{margin-top:8px;font-size:12px;color:var(--dim2);display:flex;align-items:center;gap:6px}.card-sub .dot{width:7px;height:7px;border-radius:50%;display:inline-block}.card-sub .dot.on{background:var(--ok);box-shadow:0 0 6px var(--ok)}.card-sub .dot.off{background:var(--dim2)}.info-box{background:var(--accent-soft);border:1px solid var(--border2);border-left:3px solid var(--accent);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px;font-size:13.5px;color:var(--dim);line-height:1.5}.info-box b{color:var(--txt)}.info-box .cmd{display:flex;align-items:center;gap:10px;margin:10px 0 8px;flex-wrap:wrap}.info-box code{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 9px;font-family:ui-monospace,monospace;font-size:12.5px;color:var(--accent2)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:4px 0;margin-bottom:20px;box-shadow:var(--shadow)}.panel h3{margin:15px 18px;font-size:14.5px;font-weight:650}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:11px 18px;font-size:13.5px;border-top:1px solid var(--border)}th{color:var(--dim);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}tbody tr{transition:background var(--tr)}tbody tr:hover{background:#ffffff06}.badge{font-size:11px;padding:3px 10px;border-radius:20px;border:1px solid;font-weight:600;display:inline-flex;align-items:center}.badge.pend{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 50%,transparent);background:color-mix(in srgb,var(--warn) 10%,transparent)}.badge.ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 50%,transparent);background:color-mix(in srgb,var(--ok) 10%,transparent)}.badge.face{color:var(--accent2);border-color:color-mix(in srgb,var(--accent2) 50%,transparent);background:var(--accent-soft)}.badge.lpr{color:#c08cff;border-color:#c08cff66;background:#c08cff14}.badge.danger-b{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 50%,transparent);background:color-mix(in srgb,var(--danger) 10%,transparent)}.empty{color:var(--dim);padding:22px 18px;font-size:14px;text-align:center}.placeholder{color:var(--dim);border:1px dashed var(--border);border-radius:var(--radius);padding:44px;text-align:center}input,select,textarea{transition:border-color var(--tr),box-shadow var(--tr),background var(--tr)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)!important;box-shadow:0 0 0 3px var(--accent-soft)}input:hover,select:hover{border-color:var(--dim2)}.btn:active,.btn-sm:active,.logout:active,.chip:active{transform:translateY(1px)}.btn{transition:background var(--tr),transform .08s}.btn:hover{box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 35%,transparent)}.btn-sm{transition:background var(--tr),transform .08s,box-shadow var(--tr)}.btn-sm:hover{box-shadow:0 3px 12px color-mix(in srgb,var(--accent) 30%,transparent)}.modal{animation:pop .16s cubic-bezier(.4,0,.2,1)}.modal-backdrop{animation:fade .16s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}@keyframes fade{0%{opacity:0}to{opacity:1}}.link-edit,.link-del{transition:var(--tr)}.trj-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px}.trj-bar input{padding:9px 12px;background:var(--bg);color:var(--txt);border:1px solid var(--border);border-radius:8px;font-size:14px;width:220px}.btn-sm{padding:9px 16px;background:var(--accent);color:#fff;border:0;border-radius:8px;font-weight:600}.btn-sm:hover{background:var(--accent2)}.trj-grid{display:grid;grid-template-columns:1fr 300px;gap:16px}.trj-map{height:520px;border-radius:12px;border:1px solid var(--border);overflow:hidden}.trj-list{max-height:520px;overflow:auto}.trj-list td{vertical-align:top}.pin{background:var(--accent);color:#fff;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;border:2px solid #fff;box-shadow:0 1px 4px #00000080}.pin.sm{width:22px;height:22px;font-size:12px;border-width:1px}.leaflet-popup-content{color:#111}.main.main-full{padding:14px 16px;overflow:hidden}.vw-root{display:flex;flex-direction:column;height:calc(100vh - 84px)}.vw-toolbar{display:flex;align-items:center;gap:10px;padding-bottom:10px;flex-wrap:wrap}.vw-toolbar select{background:var(--bg);color:var(--txt);border:1px solid var(--border);border-radius:7px;padding:6px 9px;font-size:13px}.vw-layouts{display:flex;gap:5px}.vw-lbtn{width:34px;height:30px;padding:0;display:grid;place-items:center;background:var(--bg);border:1px solid var(--border);color:var(--dim2);border-radius:7px;cursor:pointer}.vw-lbtn:hover{color:var(--dim);border-color:var(--dim2);background:var(--panel2)}.vw-lbtn.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent2)}.vw-stage{flex:1;min-height:0;background:#000;border:1px solid var(--border);border-radius:12px;overflow:hidden;padding:4px}.vw-stage:fullscreen{border-radius:0;padding:2px;border:0}.vw-grid2{display:grid;gap:4px;width:100%;height:100%}.vw-grid2>div{min-width:0;min-height:0}.vw-cell{position:relative;width:100%;height:100%;background:#0a0d12;border-radius:7px;overflow:hidden}.vw-cell video{width:100%;height:100%;object-fit:cover;background:#000;display:block}.vw-live2{position:absolute;right:6px;top:6px;font-size:10px;font-weight:700;color:#fff;background:var(--ok);padding:1px 7px;border-radius:9px}.vw-label2{position:absolute;left:6px;bottom:6px;background:#000000a6;padding:2px 8px;border-radius:5px;font-size:11px;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vw-empty{width:100%;height:100%;display:grid;place-items:center;color:#2a3240;font-size:15px;border:1px dashed var(--border);border-radius:7px;transition:var(--tr)}.vw-cell{cursor:pointer}.vw-cell:hover .vw-empty{color:var(--dim);border-color:var(--dim2)}.vw-cell.picking{outline:2px solid var(--accent);outline-offset:-2px}.vw-cell.sel{outline:2.5px solid var(--accent);outline-offset:-2px;box-shadow:inset 0 0 0 1px var(--accent),0 0 0 3px var(--accent-soft)}.vw-cell.drag{opacity:.45}.vw-cell-tools{position:absolute;top:6px;left:6px;display:flex;gap:4px;opacity:0;z-index:4;transition:var(--tr)}.vw-cell:hover .vw-cell-tools,.vw-cell.sel .vw-cell-tools{opacity:1}.vw-cell-tools button{width:27px;height:27px;border:0;border-radius:7px;background:#0000009e;color:#fff;cursor:pointer;font-size:13px;display:grid;place-items:center;transition:var(--tr)}.vw-cell-tools button:hover{background:var(--accent)}.vw-solo-exit{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:6;background:#000000b3;color:#fff;border:1px solid var(--border2);border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:var(--tr)}.vw-solo-exit:hover{background:var(--accent);border-color:var(--accent)}.vw-sep{width:1px;height:22px;background:var(--border2);margin:0 2px}.btn-sm.ghost{background:transparent;color:var(--dim);border:1px solid var(--border2)}.btn-sm.ghost:hover{color:var(--txt);border-color:var(--dim2);background:var(--panel2)}.vw-pick-list{display:flex;flex-direction:column;gap:4px;max-height:50vh;overflow:auto;margin:4px 0}.vw-pick-item{text-align:left;background:var(--bg);border:1px solid var(--border);color:var(--txt);padding:9px 12px;border-radius:8px;font-size:14px;cursor:pointer;transition:var(--tr)}.vw-pick-item:hover{border-color:var(--dim2);background:var(--panel2)}.vw-pick-item.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent2)}.vw-recon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:9px;background:#080c128c;color:#fff;font-size:12.5px;font-weight:600;z-index:3;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px)}.vw-spin{width:15px;height:15px;border:2px solid rgba(255,255,255,.28);border-top-color:#fff;border-radius:50%;animation:vw-spin .8s linear infinite}@keyframes vw-spin{to{transform:rotate(360deg)}}.cam-actions{margin-bottom:12px}.link-del{background:transparent;border:0;color:var(--danger);font-size:13px;cursor:pointer}.link-del:hover{text-decoration:underline}.link-edit{background:transparent;border:0;color:var(--accent2);font-size:13px;cursor:pointer;margin-right:10px}.link-edit:hover{text-decoration:underline}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:50}.modal{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:22px;width:480px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #00000080}.modal h3{margin:0 0 14px;font-size:17px}.modal .field{margin-top:12px}.modal .field label{display:block;font-size:12px;color:var(--dim);margin-bottom:5px}.modal .field input,.modal .field select{width:100%;padding:10px 11px;background:var(--bg);color:var(--txt);border:1px solid var(--border);border-radius:8px;font-size:14px}.modal .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.chips{display:flex;gap:8px}.chip{background:var(--bg);border:1px solid var(--border);color:var(--dim);padding:7px 14px;border-radius:20px;font-size:13px;cursor:pointer}.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.rec-player{background:#000;border:1px solid var(--border);border-radius:12px;min-height:300px;display:grid;place-items:center;overflow:hidden}.rec-player video{width:100%;height:100%;max-height:520px;background:#000}
