:root{--bg: #0a0e13;--bg-elevated: #0d1117;--bg-card: #12161c;--bg-hover: #1b2028;--bg-input: #0d1117;--border: #1b2028;--border-strong: #2a3040;--text: #c9d1d9;--text-bright: #e6edf3;--text-muted: #6e7681;--text-dim: #484f58;--accent: #f47e2c;--accent-hover: #ff8c3a;--accent-soft: rgba(244, 126, 44, .13);--blue: #58a6ff;--blue-soft: rgba(88, 166, 255, .12);--online: #3fb950;--online-soft: rgba(63, 185, 80, .12);--offline: #6e7681;--amber: #d29922;--amber-soft: rgba(210, 153, 34, .12);--danger: #f85149;--danger-soft: rgba(248, 81, 73, .12);--purple: #8957e5;--purple-soft: rgba(137, 87, 229, .12);--radius: 8px;--radius-sm: 6px;--radius-xs: 4px;--shadow: 0 8px 28px rgba(0, 0, 0, .45);--topbar-h: 52px;--font: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Roboto, Helvetica, Arial, sans-serif;--mono: "Consolas", ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em;color:var(--text-bright)}a{color:var(--accent);text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#2a3040;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#353f4d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--bg-hover);color:var(--text);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,opacity .15s}.btn:hover{background:#232c38;border-color:#353f4d}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#1a1206;font-weight:600}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-hover);border-color:transparent}.btn-danger{background:var(--danger-soft);border-color:transparent;color:var(--danger)}.btn-danger:hover{background:#f8514938}.btn-sm{padding:5px 10px;font-size:12px}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:15px}.label{font-size:12px;font-weight:500;color:var(--text-muted)}.input,.select{width:100%;padding:9px 11px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:inherit;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input::placeholder{color:var(--text-dim)}.pw-wrap{position:relative;display:flex;align-items:center}.pw-wrap .pw-input{width:100%;padding-right:40px}.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;cursor:pointer;color:var(--text-dim);border-radius:var(--radius-sm)}.pw-toggle:hover{color:var(--text)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.card-pad{padding:18px}.card-head{padding:11px 16px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.badge-dot{width:6px;height:6px;border-radius:50%}.badge-online{background:var(--online-soft);color:var(--online)}.badge-online .badge-dot{background:var(--online);box-shadow:0 0 6px var(--online)}.badge-offline{background:#6e768124;color:var(--text-muted)}.badge-offline .badge-dot{background:var(--offline)}.pill{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-hover);color:var(--text-muted)}.pill-accent{background:var(--accent-soft);color:var(--accent)}.alert{padding:9px 13px;border-radius:var(--radius-sm);font-size:13px}.alert-error{background:var(--danger-soft);color:#ff9d96;border:1px solid rgba(248,81,73,.3)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.18);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-topbar{height:var(--topbar-h);min-height:var(--topbar-h);flex-shrink:0;background:var(--bg-elevated);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:4px;z-index:50}.topbar-left{display:flex;align-items:center;gap:10px;padding-right:16px;margin-right:6px;border-right:1px solid var(--border);flex-shrink:0}.topbar-logo{height:26px;width:auto}.topbar-brand{font-weight:700;font-size:14px;color:var(--text-bright);letter-spacing:.01em;line-height:1.1;white-space:nowrap}.topbar-brand small{display:block;font-weight:500;font-size:9px;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase}.topbar-nav{display:flex;align-items:stretch;height:100%;flex:1;gap:0;overflow-x:auto;overflow-y:hidden}.topbar-nav::-webkit-scrollbar{height:0}.nav-item{display:flex;align-items:center;gap:7px;height:100%;padding:0 15px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:var(--text-muted);font-size:13px;font-weight:500;font-family:inherit;white-space:nowrap;transition:color .15s,background .15s,border-color .15s;flex-shrink:0}.nav-item svg{width:16px;height:16px;flex-shrink:0}.nav-item:hover{color:var(--text);background:var(--accent-soft)}.nav-item.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-soft)}.nav-sep{width:1px;height:20px;background:var(--border);margin:auto 8px;flex-shrink:0}.topbar-right{display:flex;align-items:center;gap:6px;margin-left:auto;padding-left:12px;border-left:1px solid var(--border);flex-shrink:0}.usermenu{position:relative}.user-btn{display:flex;align-items:center;gap:9px;background:transparent;border:none;cursor:pointer;color:var(--text);padding:5px 8px;border-radius:var(--radius-sm);font-family:inherit}.user-btn:hover{background:var(--bg-hover)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#1a1206;display:grid;place-items:center;font-weight:700;font-size:12px;flex-shrink:0}.user-email{font-size:12px;color:var(--text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-pop{position:absolute;right:0;top:calc(100% + 8px);background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow);min-width:210px;padding:7px;z-index:60}.menu-pop .menu-head{padding:8px 10px;border-bottom:1px solid var(--border);margin-bottom:5px}.menu-pop .menu-head .e{font-size:13px;color:var(--text-bright)}.menu-pop .menu-head .o{font-size:11px;color:var(--text-muted);margin-top:1px}.menu-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:13px;width:100%;background:transparent;border:none;text-align:left;font-family:inherit}.menu-item:hover{background:var(--bg-hover)}.app-content{flex:1;overflow:auto;padding:20px 24px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:16px;flex-wrap:wrap}.page-title{font-size:18px}.page-sub{color:var(--text-muted);font-size:12px;margin-top:2px}.muted{color:var(--text-muted)}.dim{color:var(--text-dim)}.row{display:flex;align-items:center;gap:10px}.between{justify-content:space-between}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:22px 0 11px}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:18px}.metric-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:15px 16px;display:flex;align-items:flex-start;gap:12px;transition:border-color .2s}.metric-card:hover{border-color:var(--border-strong)}.metric-icon{width:38px;height:38px;border-radius:var(--radius);display:grid;place-items:center;flex-shrink:0}.metric-icon svg{width:19px;height:19px}.metric-icon.orange{background:var(--accent-soft);color:var(--accent)}.metric-icon.blue{background:var(--blue-soft);color:var(--blue)}.metric-icon.green{background:var(--online-soft);color:var(--online)}.metric-icon.amber{background:var(--amber-soft);color:var(--amber)}.metric-icon.purple{background:var(--purple-soft);color:var(--purple)}.metric-icon.red{background:var(--danger-soft);color:var(--danger)}.metric-body{flex:1;min-width:0}.metric-value{font-size:23px;font-weight:700;color:var(--text-bright);line-height:1.1}.metric-label{font-size:11px;color:var(--text-muted);margin-top:3px}.metric-sub{font-size:10px;color:var(--text-dim);margin-top:1px}.gauge{margin-bottom:13px}.gauge:last-child{margin-bottom:0}.gauge-head{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}.gauge-head .g-label{color:var(--text-muted)}.gauge-head .g-val{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}.gauge-track{height:7px;background:var(--bg-hover);border-radius:999px;overflow:hidden}.gauge-fill{height:100%;border-radius:999px;background:var(--accent);transition:width .4s ease}.gauge-fill.warn{background:var(--amber)}.gauge-fill.crit{background:var(--danger)}.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.kv:last-child{border-bottom:none}.kv .k{color:var(--text-muted)}.kv .v{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-bright)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:18px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:15px 16px}.stat-card .stat-label{display:flex;align-items:center;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.stat-card .stat-label svg{color:var(--accent)}.stat-card .stat-value{font-size:26px;font-weight:700;color:var(--text-bright);margin-top:8px}.stat-card .stat-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);padding:9px 14px;border-bottom:1px solid var(--border)}.table td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:13px}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-hover)}.live-layout{display:grid;grid-template-columns:260px 1fr;gap:16px;height:100%;min-height:0}.cam-tree{display:flex;flex-direction:column;min-height:0;overflow:hidden}.cam-tree-head{display:flex;align-items:center;gap:6px;padding:9px;border-bottom:1px solid var(--border);flex-shrink:0}.search-box{display:flex;align-items:center;gap:7px;flex:1;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:0 9px;color:var(--text-dim)}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:13px;font-family:inherit;padding:7px 0}.search-input::placeholder{color:var(--text-dim)}.cam-tree-body{flex:1;overflow-y:auto;padding:8px;min-height:0}.tree-device{margin-bottom:8px}.tree-device-head{width:100%;display:flex;align-items:center;gap:7px;padding:6px 7px;background:none;border:none;cursor:pointer;font-family:inherit;border-radius:var(--radius-sm)}.tree-device-head:hover{background:var(--bg-hover)}.tree-device-head .name{font-weight:600;font-size:12px;color:var(--text-bright);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.cam-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 10px;margin-top:3px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:13px;transition:background .12s,color .12s,border-color .12s}.cam-item:hover{background:var(--bg-hover);color:var(--text)}.cam-item.active{background:var(--bg-card);border-color:var(--accent);color:var(--text-bright)}.cam-item:disabled{opacity:.4;cursor:not-allowed}.cam-item .ch{font-size:11px;color:var(--text-dim);font-variant-numeric:tabular-nums}.player-pane{display:flex;flex-direction:column;gap:10px;min-width:0;min-height:0}.video-frame{position:relative;width:100%;height:100%;background:#000;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.video-frame video{width:100%;height:100%;object-fit:contain;display:block;background:#000}.video-overlay{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:8px;padding:4px 9px;border-radius:999px;background:#0000008c;backdrop-filter:blur(6px);font-size:12px;font-weight:500;max-width:calc(100% - 80px);overflow:hidden}.video-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-dim);font-size:13px}.video-placeholder .ph-icon{color:var(--offline)}.video-placeholder .ph-name{font-weight:600;color:var(--text);font-size:13px}.video-placeholder .ph-msg{font-size:12px;color:var(--text-dim)}.empty-state{flex:1;display:grid;place-items:center;color:var(--text-dim);text-align:center;gap:8px;border:1px dashed var(--border-strong);border-radius:var(--radius)}.live-grid{display:grid;gap:10px;flex:1;min-height:0}.grid-slot{min-width:0;min-height:0}.player-block{min-width:0;height:100%}.grid-cell-empty{height:100%;border:1px dashed var(--border-strong);border-radius:var(--radius);display:grid;place-items:center;color:var(--text-dim);font-size:13px}.cam-name-overlay{font-weight:600;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layout-switch{display:inline-flex;gap:4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.layout-btn{display:grid;place-items:center;width:30px;height:26px;background:transparent;border:none;border-radius:5px;color:var(--text-muted);cursor:pointer}.layout-btn:hover{background:var(--bg-hover);color:var(--text)}.layout-btn.active{background:var(--accent-soft);color:var(--accent)}.grid-icon{display:grid;gap:2px;width:15px;height:15px}.grid-icon i{background:currentColor;border-radius:1px}.modal-backdrop{position:fixed;inset:0;background:#0000009e;display:grid;place-items:center;z-index:100;padding:24px}.modal{width:100%;max-width:440px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:12px;box-shadow:var(--shadow);padding:22px}.modal h3{margin-bottom:14px;font-size:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.code-box{font-family:var(--mono);font-size:25px;font-weight:700;letter-spacing:.12em;text-align:center;color:var(--accent);background:var(--bg-input);border:1px dashed var(--border-strong);border-radius:var(--radius);padding:16px;margin:8px 0}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 500px at 50% -10%,rgba(244,126,44,.09),transparent 60%),linear-gradient(135deg,#0a0e13,#12161c)}.login-card{width:100%;max-width:380px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:32px 28px;box-shadow:var(--shadow)}.login-logo{display:block;height:46px;margin:0 auto 10px}.login-title{text-align:center;font-size:19px;margin-bottom:4px}.login-sub{text-align:center;color:var(--text-muted);font-size:12px;margin-bottom:24px}.full-center{display:grid;place-items:center;height:100vh;gap:14px}.pb-page{display:flex;flex-direction:column;height:100%;min-height:0}.pb-layout{display:grid;grid-template-columns:290px 1fr;gap:16px;flex:1;min-height:0}.pb-tree{display:flex;flex-direction:column;overflow:hidden}.pb-main{display:flex;flex-direction:column;min-width:0;min-height:0;gap:12px}.pb-grid{display:grid;gap:10px;flex:1;min-height:0;align-content:start}.pb-tile{position:relative;background:#000;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;aspect-ratio:16 / 9;min-height:0}.pb-tile video{width:100%;height:100%;object-fit:contain;display:block;background:#000}.pb-tile-label{position:absolute;top:8px;left:8px;z-index:2;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;background:#0000008c;backdrop-filter:blur(6px);color:var(--text-bright)}.tile-tools{position:absolute;top:6px;right:6px;z-index:4;display:flex;gap:4px;opacity:0;transition:opacity .15s}.video-frame:hover .tile-tools,.pb-tile:hover .tile-tools,.tile-tools:focus-within{opacity:1}.tile-tool{width:26px;height:26px;display:grid;place-items:center;border:none;border-radius:5px;cursor:pointer;background:#0000008c;color:#fff;backdrop-filter:blur(4px)}.tile-tool:hover{background:#000000d9}.tile-tool.danger:hover{background:var(--danger)}.tile-info{position:absolute;bottom:10px;left:12px;z-index:3;background:#0000009e;backdrop-filter:blur(4px);border-radius:6px;padding:5px 9px;font-size:11px;font-family:var(--mono);color:#fff;line-height:1.55;pointer-events:none}.tile-zoom-badge{position:absolute;bottom:10px;right:12px;z-index:3;background:#0000009e;border-radius:999px;padding:2px 9px;font-size:11px;font-weight:600;color:#fff;pointer-events:none}.pb-tile-state{position:absolute;inset:0;display:grid;place-items:center;font-size:13px;color:var(--text-muted)}.pb-timeline{flex-shrink:0}.pb-hours{position:relative;height:15px}.pb-hour{position:absolute;transform:translate(-50%);font-size:10px;color:var(--text-dim);font-variant-numeric:tabular-nums}.pb-track{position:relative;min-height:46px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:crosshair;touch-action:none}.pb-trackrow{position:absolute;left:0;right:0}.pb-avail{position:absolute;top:0;bottom:0;background:var(--accent-soft);border:1px solid var(--accent);border-radius:2px}.pb-trackname{position:absolute;left:6px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-muted);pointer-events:none;text-shadow:0 0 4px var(--bg);white-space:nowrap}.pb-tick{position:absolute;top:0;bottom:0;width:1px;background:var(--border)}.pb-playhead{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--accent);box-shadow:0 0 6px var(--accent);pointer-events:none;z-index:3}.pb-playhead:before{content:"";position:absolute;top:-1px;left:-4px;width:10px;height:10px;border-radius:50%;background:var(--accent)}.pb-hovertip{position:absolute;top:2px;transform:translate(-50%);padding:1px 6px;font-size:10px;font-family:var(--mono);background:#000000b3;color:#fff;border-radius:4px;pointer-events:none;white-space:nowrap;z-index:4}.pb-track-empty{position:absolute;inset:0;display:grid;place-items:center;font-size:12px;pointer-events:none}.pb-controls{display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}.pb-transport,.pb-jump,.pb-actions{display:flex;align-items:center;gap:6px}.pb-actions{margin-left:auto}.pb-clock{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--text-bright);font-variant-numeric:tabular-nums;min-width:78px}.pb-cal{position:absolute;top:calc(100% + 6px);right:0;z-index:60;width:232px;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow);padding:10px}.pb-cal-head{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text-bright);margin-bottom:8px}.pb-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.pb-cal-dow{text-align:center;font-size:10px;color:var(--text-dim);padding:2px 0}.pb-cal-day{aspect-ratio:1;border:none;background:transparent;color:var(--text);font-size:12px;border-radius:5px;cursor:pointer;position:relative;font-family:inherit}.pb-cal-day:hover{background:var(--bg-hover)}.pb-cal-day.sel{background:var(--accent);color:#1a1206;font-weight:700}.pb-cal-day.has:after{content:"";position:absolute;left:50%;bottom:3px;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--online)}.pb-cal-day.sel.has:after{background:#1a1206}
