*{box-sizing:border-box;margin:0;padding:0}body{color:#fff;background:#0a0a0a;flex-direction:column;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}#app{flex-direction:column;flex:1;min-height:0;display:flex}header{background:#111;border-bottom:1px solid #222;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}header h1{cursor:pointer;font-size:16px;font-weight:600}header h1:hover{color:#aaa}.status{align-items:center;gap:6px;font-size:12px;display:flex}.status-dot{background:#555;border-radius:50%;width:8px;height:8px}.status-dot.connected{background:#22c55e}.status-dot.error{background:#ef4444}.main-layout{flex:1;min-height:0;display:flex}.app-sidebar{background:#0d0d0d;border-right:1px solid #222;flex-shrink:0;width:200px;padding:16px 0}.app-sidebar nav{flex-direction:column;gap:2px;display:flex}.app-sidebar-backdrop{display:none}.nav-toggle{cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:6px;flex-direction:column;justify-content:space-between;align-items:stretch;width:32px;height:32px;margin-right:10px;padding:6px;display:none}.nav-toggle span{background:#ddd;border-radius:1px;height:2px;display:block}.nav-toggle:hover span{background:#fff}.nav-btn{color:#bbb;text-align:left;cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;padding:10px 20px;font-size:14px;transition:background .15s,color .15s,border-color .15s}.nav-btn:hover{color:#fff;background:#161616}.nav-btn.active{color:#fff;background:#161616;border-left-color:#22c55e}.view-area{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.view-placeholder{flex:1;min-height:0;padding:24px;overflow-y:auto}.view-placeholder h2{margin-bottom:16px;font-size:18px}.view-placeholder p{color:#999;font-size:14px}.home-stats{gap:16px;margin-bottom:24px;display:flex}.home-stats .stat{background:#111;border:1px solid #222;border-radius:10px;flex-direction:column;gap:4px;min-width:120px;padding:16px 24px;display:flex}.home-stats .num{font-size:28px;font-weight:700}.home-stats .lbl{color:#999;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.dashboard-grid{flex:1;grid-template-columns:1fr 260px;gap:16px;min-height:0;padding:16px;display:grid}.slots{align-content:start;gap:12px;min-height:0;display:grid}.slots.layout-2x2{grid-template-columns:repeat(2,1fr)}.slots.layout-3x2,.slots.layout-3x3{grid-template-columns:repeat(3,1fr)}.slot{aspect-ratio:16/9;background:#111;border:1px solid #222;border-radius:10px;transition:border-color .15s,background .15s;position:relative;overflow:hidden}.slot.drag-over{background:#0f1a12;border-color:#22c55e}.slot-empty{color:#666;border:2px dashed #2a2a2a;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;height:100%;font-size:13px;display:flex}.slot-num{color:#555;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.slot-video-wrap{background:#000;width:100%;height:100%;position:relative}.slot-video-wrap video,.slot-video-wrap img{object-fit:cover;width:100%;height:100%;display:block}.slot-overlay{background:linear-gradient(#0000,#000000bf);justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;display:flex;position:absolute;bottom:0;left:0;right:0}.slot-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.slot-actions{gap:6px;display:flex}.slot-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:6px;padding:3px 10px;font-size:11px}.slot-btn:hover{background:#ffffff2e}.slot-btn.danger:hover{background:#ef444459;border-color:#ef444480}.slot-video-wrap .online-badge,.slot-video-wrap .offline-badge{border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;position:absolute;top:6px;right:6px}.slot-video-wrap .online-badge{background:#22c55ed9}.slot-video-wrap .offline-badge{background:#ef4444d9}.picker{background:#0d0d0d;border:1px solid #222;border-radius:10px;flex-direction:column;gap:8px;min-height:0;padding:12px;display:flex}.picker h3{font-size:13px;font-weight:600}.picker-hint{color:#666;font-size:11px}.picker-head{border-bottom:1px solid #1e1e1e;flex-direction:column;gap:6px;margin-bottom:6px;padding-bottom:10px;display:flex}.layout-picker{gap:4px;display:flex}.layout-btn{color:#bbb;cursor:pointer;background:#141414;border:1px solid #222;border-radius:6px;flex:1;padding:6px 0;font-size:12px}.layout-btn:hover{color:#fff;background:#1a1a1a}.layout-btn.active{color:#06170d;background:#22c55e;border-color:#22c55e;font-weight:600}.picker-list{flex-direction:column;gap:4px;min-height:0;display:flex;overflow-y:auto}.picker-item{cursor:grab;background:#141414;border:1px solid #1e1e1e;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:flex}.picker-item:hover{background:#1a1a1a;border-color:#2a2a2a}.picker-item:active{cursor:grabbing}.picker-dot{background:#555;border-radius:50%;flex-shrink:0;width:8px;height:8px}.picker-dot.online{background:#22c55e}.picker-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.picker-empty{color:#666;padding:8px 0;font-size:12px}.dashboard{flex:1;padding:24px;overflow-y:auto}.dashboard h2{margin-bottom:16px;font-size:18px}.users-view{flex:1;grid-template-columns:280px 1fr;gap:16px;min-height:0;padding:16px;display:grid}.users-list{background:#0d0d0d;border:1px solid #222;border-radius:10px;flex-direction:column;gap:4px;min-height:0;padding:10px;display:flex;overflow-y:auto}.users-list-header{border-bottom:1px solid #1e1e1e;justify-content:space-between;align-items:center;margin-bottom:6px;padding:4px 6px 10px;display:flex}.users-list-header h2{font-size:14px;font-weight:600}.refresh-btn{color:#bbb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:6px;padding:3px 10px;font-size:11px}.refresh-btn:hover{color:#fff;background:#161616}.refresh-btn:disabled{opacity:.5;cursor:default}.user-row{text-align:left;color:#ddd;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.user-row:hover{background:#161616}.user-row.active{background:#1a1a1a;border-color:#2a2a2a}.user-row-name{align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.user-row-email{color:#777;font-size:11px}.user-badge{letter-spacing:.5px;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:700}.user-badge.admin{color:#bfdbfe;background:#1e3a8a}.user-badge.org-admin{color:#ddd6fe;background:#4c1d95}.read-only-pill{letter-spacing:.4px;text-transform:uppercase;color:#9ca3af;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.org-row{align-items:flex-end;gap:12px;margin-bottom:12px;display:flex}.org-row .form-field{flex:1;max-width:280px}.org-static{color:#ccc;background:#141414;border:1px solid #222;border-radius:6px;padding:6px 10px;font-size:13px}.orgs-grid{flex-wrap:wrap;gap:6px;display:flex}.orgs-chip{color:#ddd;cursor:pointer;background:#141414;border:1px solid #222;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.orgs-chip input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;width:14px;height:14px}.bitrate-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.bitrate-row input[type=number],.bitrate-row select{color:#ddd;background:#141414;border:1px solid #222;border-radius:6px;min-width:140px;padding:6px 10px;font-size:13px}.bitrate-unit{color:#888;font-size:12px}.bitrate-meta{color:#9ca3af;font-size:12px}.bitrate-error{color:#fca5a5;margin-left:8px}.hidden-video{visibility:hidden}.offline-overlay{background:#000;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.offline-snapshot{object-fit:contain;filter:brightness(.55);width:100%;height:100%;position:absolute;inset:0}.offline-snapshot-placeholder{background:#0a0a0a;position:absolute;inset:0}.stream-loading{pointer-events:none;background:#000;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.stream-loading-text{color:#d4d4d4;letter-spacing:.6px;font-size:16px}.stream-loading-dots:after{content:"";text-align:left;width:1.4em;animation:1.4s step-end infinite stream-loading-dots;display:inline-block}@keyframes stream-loading-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.bitrate-chips{flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px;display:flex}.bitrate-chips-label{color:#777;text-transform:uppercase;letter-spacing:.5px;margin-right:2px;font-size:11px}.bitrate-chip{color:#ddd;cursor:pointer;background:#141414;border:1px solid #222;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12px;display:inline-flex}.bitrate-chip:hover:not(:disabled){background:#1c1c1c;border-color:#333}.bitrate-chip.active{color:#bfdbfe;background:#1e3a8a;border-color:#1e40af}.bitrate-chip:disabled{opacity:.5;cursor:default}.bitrate-chip-name{font-weight:600}.bitrate-chip-value{font-variant-numeric:tabular-nums;color:#aaa}.bitrate-chip.active .bitrate-chip-value{color:#dbeafe}.bitrate-chip.recent{font-variant-numeric:tabular-nums}.float-wrap{position:relative}.float-wrap.floating{width:260px;box-shadow:0 10px 30px #0009}.float-wrap.floating>.panel{border-color:#3b3b3b}.float-wrap.floating>.panel h3{cursor:grab;-webkit-user-select:none;user-select:none}.float-wrap.dragging>.panel h3{cursor:grabbing}.float-toggle{color:#777;cursor:pointer;z-index:1;background:0 0;border:1px solid #0000;border-radius:4px;width:22px;height:22px;font-size:13px;line-height:1;position:absolute;top:4px;right:4px}.float-toggle:hover{color:#ddd;background:#1f1f1f;border-color:#2a2a2a}.users-error{color:#fca5a5;padding:6px 8px;font-size:12px}.users-empty{color:#777;text-align:center;padding:16px 10px;font-size:13px}.users-detail{background:#0d0d0d;border:1px solid #222;border-radius:10px;min-height:0;padding:16px;overflow-y:auto}.detail-header{border-bottom:1px solid #1e1e1e;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;padding-bottom:12px;display:flex}.detail-header h2{font-size:16px;font-weight:600}.detail-sub{color:#888;margin-top:2px;font-size:12px}.detail-actions{align-items:center;gap:10px;display:flex}.admin-toggle{color:#ccc;cursor:pointer;background:#141414;border:1px solid #222;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.admin-toggle input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;width:14px;height:14px}.admin-toggle input[type=checkbox]:disabled{cursor:default}.save-msg{color:#9ca3af;font-size:12px}.save-btn{color:#06170d;cursor:pointer;background:#22c55e;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600}.save-btn:hover:not(:disabled){filter:brightness(1.08)}.save-btn:disabled{color:#666;cursor:default;background:#2a2a2a}.detail-note{color:#cbd5e1;background:#1e293b;border:1px solid #334155;border-radius:6px;margin-bottom:12px;padding:8px 12px;font-size:12px}.perm-table{border-collapse:collapse;width:100%;font-size:13px}.perm-table th,.perm-table td{text-align:left;border-bottom:1px solid #1a1a1a;padding:8px 10px}.perm-table th{color:#888;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.perm-table th:nth-child(2),.perm-table th:nth-child(3),.perm-table td:nth-child(2),.perm-table td:nth-child(3){text-align:center;width:90px}.perm-table input[type=checkbox]{accent-color:#22c55e;cursor:pointer;width:16px;height:16px}.perm-table input[type=checkbox]:disabled{cursor:default;opacity:.4}.cam-cell{align-items:center;gap:10px;display:flex}.cam-dot{background:#555;border-radius:50%;flex-shrink:0;width:8px;height:8px}.cam-dot.online{background:#22c55e}.cam-sub{color:#777;font-size:11px}.cameras-view{flex:1;grid-template-columns:280px 1fr;gap:16px;min-height:0;padding:16px;display:grid}.cameras-list{background:#0d0d0d;border:1px solid #222;border-radius:10px;flex-direction:column;gap:4px;min-height:0;padding:10px;display:flex;overflow-y:auto}.cameras-list-header{border-bottom:1px solid #1e1e1e;justify-content:space-between;align-items:center;margin-bottom:6px;padding:4px 6px 10px;display:flex}.cameras-list-header h2{font-size:14px;font-weight:600}.new-btn{color:#06170d;cursor:pointer;background:#22c55e;border:none;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600}.new-btn:hover{filter:brightness(1.08)}.cam-row{text-align:left;color:#ddd;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;display:flex}.cam-row:hover{background:#161616}.cam-row.active{background:#1a1a1a;border-color:#2a2a2a}.cam-row-main{flex:1;min-width:0}.cam-row-name{align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.cam-row-sub{color:#777;font-size:11px}.cam-tag-inline{letter-spacing:.5px;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:700}.cam-tag-inline.private{color:#e9d5ff;background:#4c1d95}.cameras-empty{color:#777;text-align:center;padding:16px 10px;font-size:13px}.cameras-detail{background:#0d0d0d;border:1px solid #222;border-radius:10px;min-height:0;padding:16px;overflow-y:auto}.secondary-btn{color:#ccc;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:6px;padding:6px 12px;font-size:13px}.secondary-btn:hover{color:#fff;background:#161616}.form-grid{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}.form-field{color:#bbb;flex-direction:column;gap:4px;font-size:12px;display:flex}.form-field.span-2{grid-column:1/-1}.form-field span{color:#888;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.form-field input[type=text]{color:#fff;background:#141414;border:1px solid #222;border-radius:6px;padding:7px 10px;font-size:13px}.form-field input[type=text]:focus{border-color:#3b82f6;outline:none}.form-field input[type=text]:disabled{color:#666;background:#111}.form-field small{color:#666;font-size:11px}.boot-loading,.boot-error{color:#888;flex:1;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.boot-error button{color:#fff;cursor:pointer;background:#222;border:1px solid #333;border-radius:6px;padding:6px 14px}.latlon-map{background:#111;border:1px solid #222;border-radius:6px;width:100%;height:260px;overflow:hidden}.form-field.toggle{background:#141414;border:1px solid #222;border-radius:6px;flex-direction:row;align-items:center;gap:8px;padding:8px 10px}.form-field.toggle span{text-transform:none;letter-spacing:0;color:#ddd;font-size:13px}.form-field.toggle input[type=checkbox]{accent-color:#22c55e;cursor:pointer;width:14px;height:14px}.map-wrap{flex:1;min-height:0;display:flex}.map{border:1px solid #222;border-radius:10px;flex:1;min-height:0;margin:16px;overflow:hidden}.map-marker{cursor:pointer;background:#555;border:2px solid #fff;border-radius:50%;width:14px;height:14px;transition:transform .15s;box-shadow:0 0 0 2px #0009}.map-marker:hover{transform:scale(1.2)}.map-marker.online{background:#22c55e}.map-marker.offline{background:#ef4444}.map-marker.private{outline-offset:2px;outline:2px solid #a855f7}.map-popup{color:#111;min-width:160px}.map-popup-title{margin-bottom:2px;font-size:13px;font-weight:600}.map-popup-loc{color:#555;margin-bottom:6px;font-size:11px}.map-popup-tags{gap:4px;display:flex}.map-popup-badge{color:#fff;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:700}.map-popup-badge.online{background:#22c55e}.map-popup-badge.offline{background:#ef4444}.map-popup-badge.private{background:#a855f7}.cam-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px;display:grid}.cam-card{cursor:pointer;background:#111;border:1px solid #222;border-radius:10px;transition:border-color .2s,transform .15s;overflow:hidden}.cam-card:hover{border-color:#444;transform:translateY(-2px)}.cam-card-preview{aspect-ratio:16/9;background:#000;width:100%;position:relative}.cam-card-preview iframe{pointer-events:none;border:none;width:100%;height:100%}.cam-card-preview.offline img{filter:blur(1px)grayscale(0)brightness()}.cam-card-preview.offline:after{content:"";pointer-events:none;position:absolute;inset:0}.cam-card-preview .offline-badge,.cam-card-preview .online-badge{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;right:8px}.cam-card-preview .offline-badge{background:#ef4444cc}.cam-card-preview .online-badge{background:#22c55ecc}.cam-card-info{padding:12px 14px}.cam-card-info h3{margin-bottom:4px;font-size:14px;font-weight:600}.cam-card-info p{color:#888;font-size:12px}.cam-card-info .cam-tags{gap:6px;margin-top:6px;display:flex}.cam-card-info .cam-tag{color:#aaa;background:#222;border-radius:4px;padding:2px 6px;font-size:10px}.cam-tag.ptz{color:#60a5fa;background:#1e3a5f}.cam-tag.private{color:#c084fc;background:#4a1d5f}.viewer-container{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.viewer-toolbar{background:#111;border-bottom:1px solid #222;flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:0;height:38px;padding:0 16px;display:flex;overflow:hidden}.toolbar-info{color:#aaa;white-space:nowrap;align-items:center;gap:8px;min-width:0;margin-right:16px;font-size:12px;display:flex;overflow:hidden}.toolbar-sep{color:#333}.toolbar-id{color:#666;font-size:11px}.toolbar-tabs{gap:0;height:100%;display:flex}.tab{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;height:100%;padding:0 14px;font-size:12px;transition:color .15s,border-color .15s}.tab:hover{color:#ccc}.tab.active{color:#fff;border-bottom-color:#2563eb}.toolbar-spacer{flex:1}.toolbar-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.toolbar-compass{flex-shrink:0;align-items:center;gap:6px;display:flex}.compass-mini{flex-shrink:0;width:38px;height:38px}.compass-mini svg{width:100%;height:100%}.compass-text{color:#fff;text-align:center;min-width:30px;font-size:14px;font-weight:700}.compass-deg{color:#999;font-size:11px}.viewer-body{flex-direction:column;flex:1;display:flex;overflow:hidden}.tab-content{flex:1;display:flex;overflow:hidden}.tab-placeholder{color:#555;flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.video-wrapper{background:#000;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.video-wrapper video{object-fit:contain;width:100%;max-width:100%;height:100%;max-height:100%;display:block}.sidebar-column{flex-direction:column;flex-shrink:0;gap:10px;width:280px;padding:10px;display:flex;overflow:hidden}.sidebar{background:#111;border:1px solid #222;flex-direction:column;flex:auto;gap:12px;min-height:0;padding:12px;display:flex;overflow:hidden}.sidebar>.sidebar-content{flex-direction:column;flex:auto;gap:12px;min-height:0;display:flex;overflow-y:auto}.mini-map{background:#0a0a0a;border:1px solid #2a2a2a;flex:none;width:100%;height:160px;position:relative;overflow:hidden}.mini-map-img{object-fit:cover;width:100%;height:100%;display:block}.mini-map-empty{color:#777;text-align:center;justify-content:center;align-items:center;padding:12px;font-size:11px;display:flex;position:absolute;inset:0}.mini-map-marker{pointer-events:none;width:0;height:0;position:absolute;top:50%;left:50%}.mini-map-fov{transform-origin:50%;filter:drop-shadow(0 1px 3px #0009);will-change:transform;width:72px;height:72px;margin:-36px 0 0 -36px;transition:transform .45s cubic-bezier(.22,1,.36,1);position:absolute;top:0;left:0}.mini-map-camera{filter:drop-shadow(0 1px 2px #000000b3);width:18px;height:18px;margin:-9px 0 0 -9px;position:absolute;top:0;left:0}.mini-map-meta{letter-spacing:.4px;color:#e5e7eb;font-variant-numeric:tabular-nums;background:#0000008c;border:1px solid #ffffff14;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600;position:absolute;bottom:6px;right:6px}.panel{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:10px}.panel h3{text-transform:uppercase;letter-spacing:.5px;color:#888;margin-bottom:8px;font-size:11px}.ptz-grid{grid-template-columns:repeat(3,1fr);gap:6px;max-width:210px;margin:0 auto;display:grid}.ptz-btn{color:#fff;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation;background:#2a2a2a;border:1px solid #333;border-radius:6px;justify-content:center;align-items:center;padding:14px 10px;font-size:15px;transition:background .15s;display:flex}.ptz-btn:hover{background:#3a3a3a}.ptz-btn:active{background:#4a4a4a}.ptz-btn.diag{color:#999;font-size:13px}.ptz-btn.stop{background:#7f1d1d;border-color:#991b1b}.ptz-btn.stop:hover{background:#991b1b}.zoom-row{justify-content:space-between;align-items:center;gap:8px;margin-top:8px;display:flex}.zoom-label{text-transform:uppercase;letter-spacing:.5px;color:#888;font-size:11px}.zoom-controls{gap:4px;display:flex}.zoom-btn{color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation;background:#2a2a2a;border:1px solid #333;border-radius:6px;padding:10px 24px;font-size:15px;transition:background .15s}.zoom-btn:hover{background:#3a3a3a}.spotlight-toggle{gap:4px;display:flex}.spot-btn{color:#888;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;background:#2a2a2a;border:1px solid #333;border-radius:6px;flex:1;padding:8px;font-size:12px;font-weight:600;transition:background .15s,color .15s}.spot-btn:hover{background:#3a3a3a}.spot-btn.active{color:#000;background:#f59e0b;border-color:#f59e0b}.spot-btn.active:hover{background:#d97706}.plane-toggle{gap:4px;display:flex}.plane-btn{color:#888;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;background:#2a2a2a;border:1px solid #333;border-radius:6px;flex:1;padding:8px;font-size:12px;font-weight:600;transition:background .15s,color .15s}.plane-btn:hover{background:#3a3a3a}.plane-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.plane-btn.active:hover{background:#1d4ed8}.plane-info{color:#aaa;margin-top:10px;font-size:11px}.plane-status{color:#888;margin-bottom:6px}.plane-detail{border-bottom:1px solid #222;justify-content:space-between;padding:3px 0;display:flex}.plane-detail .pl{color:#666}.plane-detail .pv{color:#ccc;font-weight:500}.logs-tab-content{flex-direction:column-reverse;flex:1;padding:16px;display:flex;overflow-y:auto}.logs-list{flex-direction:column;gap:2px;display:flex}.log-entry{border-bottom:1px solid #1a1a1a;align-items:center;gap:12px;padding:8px 12px;font-size:12px;display:flex}.log-time{color:#555;flex-shrink:0;min-width:75px;font-size:11px}.log-user{color:#60a5fa;flex-shrink:0;min-width:100px;font-weight:600}.log-action{color:#aaa}.system-tab-content{flex:1;padding:24px;overflow-y:auto}.system-section{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;max-width:480px;margin-bottom:16px;padding:16px}.system-section h3{text-transform:uppercase;letter-spacing:.5px;color:#888;margin-bottom:12px;font-size:11px}.system-actions{flex-direction:column;gap:8px;display:flex}.system-btn{color:#ccc;cursor:pointer;text-align:left;background:#2a2a2a;border:1px solid #333;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:500;transition:background .15s;display:flex}.system-btn:hover{background:#3a3a3a}.system-btn.danger{border-color:#7f1d1d}.system-btn.danger:hover{color:#fff;background:#7f1d1d}.system-btn .btn-desc{color:#666;font-size:11px}.system-btn:disabled{opacity:.5;cursor:not-allowed}.auth-screen{z-index:1000;background:#050505;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0;overflow:hidden}.auth-bg{pointer-events:none;background:radial-gradient(at 20% 0,#2563eb2e,#0000 55%),radial-gradient(at 80% 100%,#60a5fa1a,#0000 60%),#050505;position:absolute;inset:0}.auth-card{background:#0f0f0f;border:1px solid #1f1f1f;border-radius:14px;width:100%;max-width:380px;padding:32px 28px 28px;position:relative;box-shadow:0 25px 60px #0000008c}.auth-brand{text-align:center;flex-direction:column;align-items:center;margin-bottom:26px;display:flex}.auth-title-row{align-items:center;gap:12px;display:flex}.auth-logo-img{flex-shrink:0;width:40px;height:40px;display:block}.auth-title-row h1{letter-spacing:.2px;color:#f5f5f5;margin:0;font-size:26px;font-weight:700;line-height:1}.auth-tagline{color:#8a8a8a;margin:10px 0 0;font-size:13px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field>span{letter-spacing:.5px;text-transform:uppercase;color:#8a8a8a;font-size:11px;font-weight:600}.auth-field input{color:#fff;background:#060606;border:1px solid #222;border-radius:8px;outline:none;width:100%;padding:11px 12px;font-size:14px;transition:border-color .15s,background .15s}.auth-field input::placeholder{color:#4a4a4a}.auth-field input:hover{border-color:#2c2c2c}.auth-field input:focus{background:#080808;border-color:#2563eb}.auth-submit{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;width:100%;margin-top:6px;padding:11px;font-size:14px;font-weight:600;transition:background .15s}.auth-submit:hover:not(:disabled){background:#1d4ed8}.auth-submit:active:not(:disabled){background:#1e40af}.auth-submit:disabled{opacity:.65;cursor:default}.auth-error{color:#fca5a5;background:#ef444414;border:1px solid #ef44444d;border-radius:8px;padding:10px 12px;font-size:13px}.stream-toggle{background:#0a0a0a;border-radius:6px;gap:4px;padding:3px;display:flex}.stream-toggle button{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;flex:1;padding:6px 10px;font-size:12px}.stream-toggle button.active{color:#fff;background:#2a2a2a}.retry-overlay{background:#0009;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.retry-btn{color:#fff;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:6px;padding:8px 18px;font-size:13px;transition:background .15s}.retry-btn:hover{background:#3a3a3a}.back-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #333;border-radius:6px;margin-right:12px;padding:4px 12px;font-size:12px;transition:background .15s,color .15s}.back-btn:hover{color:#fff;background:#222}.logout-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #333;border-radius:6px;margin-left:8px;padding:4px 10px;font-size:11px;transition:background .15s,color .15s}.logout-btn:hover{color:#fff;background:#7f1d1d;border-color:#991b1b}.mobile-tabs{background:#0a0a0a;border-radius:6px;gap:4px;margin-bottom:10px;padding:3px;display:none}.mobile-tab{color:#888;cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;border-radius:4px;flex:1;padding:8px 10px;font-size:12px;font-weight:600}.mobile-tab.active{color:#fff;background:#2a2a2a}.mobile-panel{padding:4px 0}.hidden{display:none!important}@media (width<=768px),(orientation:landscape) and (height<=500px){header{padding:8px 12px}header h1{font-size:14px}.dashboard{padding:12px}.cam-grid{grid-template-columns:1fr}.nav-toggle{display:flex}.app-sidebar{z-index:40;width:240px;max-width:80vw;padding-top:8px;transition:transform .2s ease-out;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:2px 0 12px #00000080}.app-sidebar.open{transform:translate(0)}.app-sidebar-backdrop{z-index:39;cursor:pointer;background:#00000073;border:none;padding:0;display:block;position:fixed;inset:0}.viewer-toolbar{padding:0 10px}.toolbar-info{gap:4px;margin-right:8px;font-size:11px}.toolbar-tabs{display:none}.toolbar-spacer{flex:1}.mobile-tabs{display:flex}.toolbar-compass{gap:4px}.compass-mini{width:28px;height:28px}.compass-text{font-size:12px}.compass-deg{font-size:10px}.tab{padding:0 10px;font-size:11px}.viewer-body{overflow-y:auto}.tab-content{flex-direction:column;overflow:visible}.video-wrapper{aspect-ratio:16/9;flex:none;width:100%}.video-wrapper video{object-fit:contain;width:100%;height:100%}.sidebar{border-top:1px solid #222;border-left:none;flex-shrink:0;width:100%;padding:10px}.ptz-grid{max-width:180px}.ptz-btn{padding:12px 8px;font-size:14px}.zoom-btn{padding:8px 20px}.auth-box{width:90%;padding:24px}.system-tab-content{padding:12px}.system-section{max-width:100%}.logs-tab-content{padding:10px}.log-entry{gap:8px;padding:6px 8px}.log-user{min-width:70px}}
