@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-root: #0a0a0f;--bg-surface: #12121a;--bg-elevated: #1a1a26;--bg-hover: #22222e;--bg-input: #16161f;--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .15);--text-primary: #e8e8f0;--text-secondary: #8888a0;--text-muted: #555568;--text-inverse: #0a0a0f;--accent: #00d4ff;--accent-dim: rgba(0, 212, 255, .15);--accent-glow: rgba(0, 212, 255, .3);--status-online: #00e676;--status-offline: #555568;--status-error: #ff3d57;--status-warning: #ffab00;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--font-sans: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--transition: .18s ease;--sidebar-width: 60px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--bg-root);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.app-layout{display:flex;height:100vh;background:var(--bg-root)}.app-main{flex:1;overflow:auto;position:relative}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;position:relative;z-index:10}.sidebar-brand{padding:14px 0;display:flex;align-items:center;justify-content:center}.sidebar-brand-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#0066ff);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text-inverse);box-shadow:0 0 20px var(--accent-glow)}.sidebar-nav{flex:1;padding:0 6px;display:flex;flex-direction:column;gap:2px;align-items:center}.sidebar-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:18px;font-weight:400;transition:all var(--transition);position:relative}.sidebar-link:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-link.active{color:var(--accent);background:var(--accent-dim);font-weight:500}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--accent);border-radius:0 2px 2px 0}.sidebar-link svg{width:18px;height:18px;opacity:.7}.sidebar-link.active svg{opacity:1}.sidebar-link[title]:hover:after{content:attr(title);position:absolute;left:52px;top:50%;transform:translateY(-50%);background:var(--bg-elevated);color:var(--text-primary);padding:4px 10px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:100;border:1px solid var(--border-default);pointer-events:none}.sidebar-footer{padding:10px 0;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;gap:4px;font-size:9px;color:var(--text-muted);font-family:var(--font-mono)}.page{padding:24px 28px;animation:fadeIn .3s ease}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:22px;font-weight:600;letter-spacing:-.5px;color:var(--text-primary)}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;transition:border-color var(--transition)}.card:hover{border-color:var(--border-default)}.stat-grid{display:flex;gap:12px;margin-bottom:28px}.stat-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:20px 28px;text-align:center;min-width:120px;transition:all var(--transition)}.stat-card:hover{border-color:var(--accent);box-shadow:0 0 30px #00d4ff0d}.stat-value{font-size:32px;font-weight:700;color:var(--accent);line-height:1;font-variant-numeric:tabular-nums}.stat-label{font-size:11px;color:var(--text-muted);margin-top:6px;text-transform:uppercase;letter-spacing:1px;font-weight:500}.btn{padding:8px 16px;border:none;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover{filter:brightness(1.15);box-shadow:0 0 20px var(--accent-glow)}.btn-ghost{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-default)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-strong)}.btn-danger{background:transparent;color:var(--status-error);border:1px solid rgba(255,61,87,.3)}.btn-danger:hover{background:#ff3d571a;border-color:var(--status-error)}.btn-sm{padding:5px 10px;font-size:12px}.input{padding:9px 12px;background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;outline:none;transition:all var(--transition)}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input::placeholder{color:var(--text-muted)}.select{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;outline:none;cursor:pointer}.badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.badge-online{background:#00e67626;color:var(--status-online)}.badge-offline{background:#55556833;color:var(--status-offline)}.badge-error{background:#ff3d5726;color:var(--status-error)}.badge-active{background:#00e67626;color:var(--status-online)}.badge-motion{background:#ffab0026;color:var(--status-warning)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:10px 14px;color:var(--text-muted);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border-subtle)}.table td{padding:12px 14px;border-bottom:1px solid var(--border-subtle);font-size:13px}.table tr{transition:background var(--transition)}.table tbody tr:hover{background:var(--bg-hover)}.toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle)}.toolbar-group{display:flex;gap:2px;background:var(--bg-root);border-radius:var(--radius-sm);padding:2px}.toolbar-btn{padding:5px 14px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all var(--transition)}.toolbar-btn:hover{color:var(--text-secondary)}.toolbar-btn.active{background:var(--accent);color:var(--text-inverse);font-weight:500}.camera-grid{display:grid;gap:3px;width:100%;height:100%;background:var(--bg-root);padding:3px}.camera-cell{position:relative;overflow:hidden;background:#000;border-radius:4px;cursor:pointer;transition:all var(--transition)}.camera-cell:hover{outline:2px solid var(--accent);outline-offset:-2px}.camera-cell video{width:100%;height:100%;object-fit:contain;background:#000}.camera-overlay{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:linear-gradient(transparent,#000000d9);display:flex;align-items:center;justify-content:space-between;pointer-events:none}.camera-name{font-size:12px;color:#ffffffe6;font-weight:500}.camera-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.camera-dot.online{background:var(--status-online);box-shadow:0 0 8px var(--status-online)}.camera-dot.offline{background:var(--status-offline)}.camera-dot.error{background:var(--status-error);box-shadow:0 0 8px var(--status-error)}.camera-offline-msg{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px}.live-layout{display:flex;height:100%}.live-sidebar{width:260px;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.live-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-subtle)}.live-sidebar-title{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.live-sidebar-count{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.live-viewer{flex:1;display:flex;align-items:center;justify-content:center;background:#000;position:relative}.live-player-wrap{width:100%;height:100%;position:relative}.live-player-wrap video{width:100%;height:100%;object-fit:contain}.live-placeholder{text-align:center;color:var(--text-muted);font-size:14px}.live-placeholder .empty-icon{font-size:48px;margin-bottom:12px;opacity:.2}.camera-list{flex:1;overflow-y:auto;padding:4px}.camera-list-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-family:var(--font-sans);font-size:13px;cursor:pointer;transition:all var(--transition);text-align:left}.camera-list-item:hover{background:var(--bg-hover);color:var(--text-primary)}.camera-list-item.active{background:var(--accent-dim);color:var(--accent)}.camera-list-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-list-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:12px}.empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-icon{font-size:40px;margin-bottom:12px;opacity:.3}.form-row{display:flex;gap:8px;background:var(--bg-surface);border:1px solid var(--border-subtle);padding:14px;border-radius:var(--radius-md);margin-bottom:20px;animation:slideDown .2s ease}.event-item{background:var(--bg-surface);border:1px solid var(--border-subtle);padding:10px 14px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between;transition:all var(--transition)}.event-item:hover{border-color:var(--border-default);background:var(--bg-elevated)}.worker-card{background:var(--bg-surface);border:1px solid var(--border-subtle);padding:14px;border-radius:var(--radius-md);margin-bottom:8px;transition:all var(--transition)}.worker-card:hover{border-color:var(--border-default)}.timeline-bar{display:flex;gap:1px;flex-wrap:wrap;padding:8px;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.timeline-segment{width:5px;height:28px;background:var(--status-online);border-radius:2px;opacity:.7;transition:all var(--transition)}.timeline-segment:hover{opacity:1;transform:scaleY(1.2)}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-muted);gap:8px}.spinner{width:16px;height:16px;border:2px solid var(--border-default);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.camera-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:10px;padding:16px;animation:fadeIn .3s ease}.camera-card{background:#000;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-subtle);transition:border-color var(--transition)}.camera-card:hover{border-color:var(--border-strong)}.camera-card-preview{position:relative;aspect-ratio:16 / 9;background:#0a0a0f;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:36px;overflow:hidden}.camera-card-preview canvas{width:100%!important;height:100%!important;object-fit:cover}.camera-card-actions{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:12px;background:#00000080;opacity:0;transition:opacity var(--transition)}.camera-card-preview:hover .camera-card-actions{opacity:1}.camera-card-action{width:44px;height:44px;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.camera-card-action:hover{background:var(--accent);color:var(--text-inverse);transform:scale(1.1)}.camera-card-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-surface)}.camera-card-name{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.modal-content{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-default);max-width:960px;width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px #0009}.modal-content.wide{max-width:1100px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.modal-title{font-size:15px;font-weight:600;color:var(--text-primary)}.modal-close{width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;overflow:auto;position:relative}.modal-body video{width:100%;display:block;background:#000}
