:root{--bg: #0b0e14;--bg-elev: #121723;--bg-elev-2: #19202e;--border: #232c3d;--border-soft: #1b2230;--text: #e6ebf2;--text-dim: #9aa6b8;--text-faint: #62708a;--accent: #3b82f6;--accent-hover: #2f6fe0;--accent-soft: rgba(59, 130, 246, .15);--live: #22c55e;--danger: #ef4444;--danger-hover: #dc2626;--warn: #f59e0b;--radius: 12px;--radius-sm: 8px;--shadow: 0 8px 28px rgba(0, 0, 0, .45);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85em;color:var(--text-dim);background:var(--bg-elev-2);padding:2px 6px;border-radius:6px}.brand-mark{color:var(--accent);font-size:1.1em;line-height:1}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;border-radius:var(--radius-sm);padding:10px 16px;font-size:.92rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease;color:var(--text)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:not(:disabled):hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn.ghost{background:transparent;border-color:var(--border);color:var(--text-dim)}.btn.ghost:hover{border-color:var(--accent);color:var(--text)}.btn.danger{background:transparent;border-color:#ef444473;color:#f4a3a3}.btn.danger:not(:disabled):hover{background:var(--danger);border-color:var(--danger);color:#fff}.btn.small{padding:6px 12px;font-size:.82rem}.alert{border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;line-height:1.4}.alert.error{background:#ef44441f;border:1px solid rgba(239,68,68,.4);color:#fca5a5}.field{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--text-dim)}.field input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;color:var(--text);font-size:.95rem;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field input::placeholder{color:var(--text-faint)}.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .8s linear infinite}.spinner.small{width:22px;height:22px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.centered-screen{min-height:100vh;display:grid;place-items:center}.centered-block{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 0;color:var(--text-dim)}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,rgba(59,130,246,.12),transparent 70%),var(--bg)}.login-card{width:100%;max-width:380px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px 30px;display:flex;flex-direction:column;gap:16px}.login-card .brand{display:flex;align-items:center;gap:10px}.login-card .brand h1{margin:0;font-size:1.5rem;letter-spacing:.5px}.login-card .brand-mark{font-size:1.6rem}.login-sub{margin:-8px 0 8px;color:var(--text-faint);font-size:.9rem}.login-card .btn.primary{margin-top:4px;padding:12px}:root{--sidebar-w: 232px;--sidebar-w-collapsed: 68px;--topbar-h: 60px}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .2s ease;z-index:30;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-head{display:flex;align-items:center;gap:10px;height:var(--topbar-h);padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0}.hamburger{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;cursor:pointer;width:34px;height:34px;border-radius:var(--radius-sm);display:inline-flex;flex-direction:column;justify-content:center;gap:4px;padding:8px;flex-shrink:0;transition:background .15s ease}.hamburger:hover{background:var(--bg-elev-2)}.hamburger span{display:block;height:2px;width:100%;background:var(--text-dim);border-radius:2px}.sidebar-brand{display:flex;align-items:center;gap:8px;font-weight:700;letter-spacing:.5px;white-space:nowrap}.sidebar-brand .brand-mark{font-size:1.15rem}.sidebar.collapsed .sidebar-brand-text{display:none}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.side-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-dim);font-size:.92rem;font-weight:500;white-space:nowrap;transition:background .15s ease,color .15s ease}.side-link:hover{background:var(--bg-elev-2);color:var(--text)}.side-link.active{background:var(--accent-soft);color:#fff}.side-link.active .side-icon{filter:none}.side-icon{font-size:1.15rem;width:24px;text-align:center;flex-shrink:0}.sidebar.collapsed .side-label{display:none}.sidebar.collapsed .side-link{justify-content:center;gap:0}.sidebar-foot{padding:14px 16px;border-top:1px solid var(--border);flex-shrink:0}.side-foot-text{font-size:.72rem;color:var(--text-faint);white-space:nowrap}.sidebar.collapsed .side-foot-text{display:none}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:25}.layout-main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:16px;padding:0 24px;height:var(--topbar-h);background:var(--bg-elev);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.topbar-spacer{flex:1}.topbar-burger{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;cursor:pointer;width:38px;height:38px;border-radius:var(--radius-sm);display:none;flex-direction:column;justify-content:center;gap:4px;padding:9px}.topbar-burger span{display:block;height:2px;background:var(--text-dim);border-radius:2px}.topbar-burger:hover{background:var(--bg-elev-2)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}.user-chip{display:flex;align-items:center;gap:9px}.user-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--accent-soft);color:#cfe0ff;font-weight:700;font-size:.95rem}.user-meta{display:flex;flex-direction:column;line-height:1.15}.user-name{font-size:.9rem;font-weight:600}.user-role{font-size:.72rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}.content{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:28px 28px 56px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{margin:0;font-size:1.5rem;letter-spacing:.2px}.page-sub{margin:4px 0 0;color:var(--text-faint);font-size:.9rem}.mini-stats{display:flex;gap:10px;align-items:center}.mini-stat{background:var(--bg-elev);border:1px solid var(--border);border-radius:999px;padding:6px 14px;font-size:.82rem;color:var(--text-dim)}.mini-stat strong{color:var(--text)}.mini-stat.dim{color:var(--text-faint)}.camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px}.camera-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s ease,transform .15s ease}.camera-card:hover{border-color:#2c3850;transform:translateY(-2px)}.tile-video{position:relative;width:100%;aspect-ratio:16 / 9;background:#000}.tile-video video{width:100%;height:100%;object-fit:cover;display:block;background:#000}.tile-video video.is-hidden{visibility:hidden}.tile-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text-faint);font-size:.88rem;background:repeating-linear-gradient(45deg,#0c0f16,#0c0f16 12px,#0e121b 12px,#0e121b 24px)}.tile-placeholder.error{color:#d28a8a}.no-signal-icon{font-size:1.8rem;color:var(--warn)}.live-badge{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.6px;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff}.live-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--text-faint)}.live-badge[data-state=live] .dot{background:var(--live);box-shadow:0 0 #22c55eb3;animation:pulse 1.6s infinite}.live-badge[data-state=error] .dot{background:var(--danger)}@keyframes pulse{0%{box-shadow:0 0 #22c55e99}70%{box-shadow:0 0 0 7px #22c55e00}to{box-shadow:0 0 #22c55e00}}.camera-meta{padding:13px 16px 15px}.camera-name{margin:0;font-size:1rem;font-weight:600}.camera-location{margin:5px 0 0;font-size:.84rem;color:var(--text-dim);display:flex;align-items:center;gap:5px}.empty-state{text-align:center;padding:70px 20px;color:var(--text-dim);display:flex;flex-direction:column;align-items:center;gap:10px}.empty-icon{font-size:2.6rem}.empty-state h2{margin:4px 0 0;color:var(--text);font-size:1.2rem}.empty-state p{margin:0 0 8px;max-width:380px}.panel{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:22px 22px 24px;margin-bottom:22px}.panel-title{margin:0 0 18px;font-size:1.05rem;display:flex;align-items:center;gap:10px}.count-pill{font-size:.74rem;font-weight:700;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text-dim);padding:2px 9px;border-radius:999px}.camera-form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;justify-content:flex-end}.muted{color:var(--text-faint);font-size:.9rem}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th{text-align:left;font-size:.74rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text-faint);font-weight:600;padding:8px 12px;border-bottom:1px solid var(--border)}.data-table td{padding:12px;border-bottom:1px solid var(--border-soft);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.col-actions{text-align:right;width:1%;white-space:nowrap}.status-pill{display:inline-block;font-size:.74rem;font-weight:600;padding:3px 10px;border-radius:999px}.status-pill.on{background:#22c55e24;color:#6ee7a0}.status-pill.off{background:#94a3b824;color:var(--text-dim)}.bool-flag{color:var(--text-dim);font-weight:600}.self-tag{margin-left:8px;font-size:.68rem;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);background:var(--accent-soft);padding:2px 7px;border-radius:999px}.role-pill{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:3px 10px;border-radius:999px}.role-pill.admin{background:#3b82f629;color:#93c0ff}.role-pill.viewer{background:#94a3b824;color:var(--text-dim)}.row-actions{display:inline-flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.btn.danger-solid{background:var(--danger);border-color:var(--danger);color:#fff}.btn.danger-solid:not(:disabled):hover{background:var(--danger-hover);border-color:var(--danger-hover)}.select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;color:var(--text);font-size:.95rem;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field-hint{color:var(--text-faint);font-size:.78rem}.check-row{display:flex;flex-direction:column;gap:12px}.check{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--text);cursor:pointer}.check em{color:var(--text-faint);font-style:normal}.check input[type=checkbox],.check-item input[type=checkbox]{width:18px;height:18px;margin-top:1px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.inline-form{display:flex;gap:12px;flex-wrap:wrap}.inline-input{flex:1;min-width:220px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;color:var(--text);font-size:.95rem;font-family:inherit}.inline-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.check-list{display:flex;flex-direction:column;gap:2px;max-height:340px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px;background:var(--bg)}.check-item{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:6px;cursor:pointer;transition:background .12s ease}.check-item:hover{background:var(--bg-elev-2)}.check-item-main{display:flex;flex-direction:column;line-height:1.25}.check-item-name{font-size:.9rem;color:var(--text)}.check-item-sub{font-size:.76rem;color:var(--text-faint)}.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.perm-title{margin:0 0 10px;font-size:.95rem}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}.info-list{margin:0;display:flex;flex-direction:column}.info-row{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--border-soft)}.info-row:last-child{border-bottom:none}.info-row dt{color:var(--text-dim);font-size:.88rem}.info-row dd{margin:0;font-size:.9rem;font-weight:600}.alert.info{background:#3b82f61a;border:1px solid rgba(59,130,246,.35);color:#bcd6ff}.alert.warn{background:#f59e0b1f;border:1px solid rgba(245,158,11,.4);color:#fcd49a}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060bb3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:24px;z-index:50;animation:fade-in .15s ease}.modal-card{width:100%;max-width:540px;max-height:88vh;display:flex;flex-direction:column;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);animation:pop-in .16s ease}.modal-card.sm{max-width:420px}.modal-card.lg{max-width:760px}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1.05rem}.modal-x{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;color:var(--text-dim);font-size:1.5rem;line-height:1;cursor:pointer;width:32px;height:32px;border-radius:var(--radius-sm)}.modal-x:hover{background:var(--bg-elev-2);color:var(--text)}.modal-body{padding:20px;overflow-y:auto}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border)}.confirm-message{margin:0;color:var(--text-dim);line-height:1.5;font-size:.92rem}@keyframes fade-in{0%{opacity:0}}@keyframes pop-in{0%{opacity:0;transform:translateY(8px) scale(.98)}}.toast-stack{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:60;max-width:360px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);background:var(--bg-elev-2);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--text);font-size:.9rem;cursor:pointer;animation:toast-in .2s ease}.toast-icon{font-weight:700}.toast.success{border-color:#22c55e80}.toast.success .toast-icon{color:var(--live)}.toast.error{border-color:#ef444480}.toast.error .toast-icon{color:var(--danger)}.toast.info .toast-icon{color:var(--accent)}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}}@media (max-width: 900px){.sidebar{position:fixed;left:0;top:0;height:100vh;width:var(--sidebar-w);transform:translate(-100%);transition:transform .2s ease}.sidebar.collapsed{width:var(--sidebar-w)}.sidebar.collapsed .side-label,.sidebar.collapsed .sidebar-brand-text,.sidebar.collapsed .side-foot-text{display:inline}.sidebar.collapsed .side-link{justify-content:flex-start;gap:12px}.sidebar.mobile-open{transform:translate(0)}.topbar-burger{display:inline-flex}}@media (max-width: 720px){.topbar{gap:10px;padding:0 14px}.user-meta{display:none}.form-row{grid-template-columns:1fr}.content{padding:20px 14px 40px}.perm-grid,.config-grid{grid-template-columns:1fr}.data-table,.data-table thead,.data-table tbody,.data-table th,.data-table td,.data-table tr{display:block}.data-table thead{display:none}.data-table tr{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;padding:6px 4px}.data-table td{border:none;display:flex;justify-content:space-between;gap:12px;padding:8px 12px}.data-table td:before{content:attr(data-label);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);font-weight:600}.col-actions{justify-content:flex-end}.col-actions:before{display:none}.row-actions{justify-content:flex-end}}.login-logo{width:240px;max-width:78%;height:auto;display:block;margin:0 auto 4px}.sidebar-brand{display:flex;align-items:center;overflow:hidden}.sidebar-logo-full{height:38px;width:auto;max-width:150px;object-fit:contain}.sidebar-logo-icon{display:none;height:34px;width:34px;object-fit:contain}.sidebar.collapsed .sidebar-logo-full{display:none}.sidebar.collapsed .sidebar-logo-icon{display:block}.dvr-cams{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 16px}.chip{padding:8px 16px;border-radius:999px;border:1px solid #1f2740;background:#141a2b;color:#c7cfde;font-size:13px;cursor:pointer;transition:all .15s}.chip:hover{border-color:#2f6bff;color:#fff}.chip.active{background:#2f6bff;border-color:#2f6bff;color:#fff}.dvr-wrap{display:flex;flex-direction:column;gap:14px}.dvr-player{background:#000;border-radius:16px;overflow:hidden;border:1px solid #1f2740;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center}.dvr-video{width:100%;height:100%;object-fit:contain;background:#000}.dvr-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.dvr-clock{font-variant-numeric:tabular-nums;font-weight:600;color:#f5f7fb;background:#141a2b;border:1px solid #1f2740;padding:8px 14px;border-radius:12px}.dvr-quick{display:flex;flex-wrap:wrap;gap:6px}.btn.sm{padding:6px 12px;font-size:12.5px;border-radius:10px}.dvr-timeline{position:relative;height:46px;background:#0e1320;border:1px solid #1f2740;border-radius:12px;cursor:pointer;overflow:hidden;touch-action:none}.dvr-seg{position:absolute;top:8px;bottom:8px;background:linear-gradient(180deg,#2f6bff,#2456d6);opacity:.55;border-radius:4px;min-width:2px}.dvr-playhead{position:absolute;top:-2px;bottom:-2px;width:3px;background:#ff4d4f;box-shadow:0 0 8px #ff4d4fcc;border-radius:2px;pointer-events:none}.dvr-range-labels{display:flex;justify-content:space-between;font-size:12px;color:#8a93a8;font-variant-numeric:tabular-nums}
