*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1e40af;--primary-dark: #1e3a8a;--primary-light: #3b82f6;--secondary: #0ea5e9;--accent: #f59e0b;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--dark: #1e293b;--gray-900: #0f172a;--gray-800: #1e293b;--gray-700: #334155;--gray-600: #475569;--gray-500: #64748b;--gray-400: #94a3b8;--gray-300: #cbd5e1;--gray-200: #e2e8f0;--gray-100: #f1f5f9;--gray-50: #f8fafc;--white: #ffffff;--sidebar-width: 260px;--header-height: 64px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-100);color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--white);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;z-index:100;box-shadow:4px 0 20px #00000026}.sidebar-logo{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo h1{font-size:18px;font-weight:700;letter-spacing:-.5px}.sidebar-logo span{display:block;font-size:11px;font-weight:400;opacity:.7;margin-top:4px}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;color:#fffc;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease;margin-bottom:4px}.nav-item:hover{background:#ffffff1a;color:var(--white)}.nav-item.active{background:#fff3;color:var(--white);box-shadow:0 2px 8px #0003}.nav-item svg{width:20px;height:20px;flex-shrink:0}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.page-header{background:var(--white);padding:20px 32px;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50}.page-header-left h2{font-size:24px;font-weight:600;color:var(--gray-900)}.page-header-left p{font-size:14px;color:var(--gray-500);margin-top:4px}.page-content{padding:24px 32px}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.dashboard-card{background:var(--white);border-radius:12px;padding:24px;cursor:pointer;transition:all .3s ease;border:1px solid var(--gray-200);box-shadow:0 1px 3px #0000000d}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--primary-light)}.dashboard-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.dashboard-card-icon.blue{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.dashboard-card-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.dashboard-card-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.dashboard-card-icon.red{background:linear-gradient(135deg,#ef4444,#dc2626)}.dashboard-card-icon.purple{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.dashboard-card-icon.cyan{background:linear-gradient(135deg,#06b6d4,#0891b2)}.dashboard-card-icon svg{width:24px;height:24px;color:var(--white)}.dashboard-card h3{font-size:18px;font-weight:600;color:var(--gray-900);margin-bottom:8px}.dashboard-card p{font-size:14px;color:var(--gray-500);line-height:1.5}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:24px}.metric-card{background:var(--white);border-radius:12px;padding:20px;border:1px solid var(--gray-200);box-shadow:0 1px 3px #0000000d}.metric-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.metric-card-title{font-size:14px;font-weight:500;color:var(--gray-500)}.metric-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--gray-100)}.metric-card-icon svg{width:18px;height:18px}.metric-card-value{font-size:28px;font-weight:700;color:var(--gray-900)}.metric-card-subtitle{font-size:12px;color:var(--gray-500);margin-top:4px}.data-table{width:100%;background:var(--white);border-radius:12px;overflow:hidden;border:1px solid var(--gray-200)}.data-table table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:16px;background:var(--gray-50);font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray-200)}.data-table td{padding:16px;font-size:14px;color:var(--gray-700);border-bottom:1px solid var(--gray-100)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gray-50)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.active{background:#10b9811a;color:var(--success)}.status-badge.inactive{background:#ef44441a;color:var(--danger)}.status-badge.warning{background:#f59e0b1a;color:var(--warning)}.status-badge.high{background:#ef44441a;color:var(--danger)}.status-badge.medium{background:#f59e0b1a;color:var(--warning)}.status-badge.low{background:#10b9811a;color:var(--success)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none}.btn-primary{background:var(--primary);color:var(--white)}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-200)}.btn-icon{width:36px;height:36px;padding:0;border-radius:8px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--gray-700);margin-bottom:8px}.form-input,.form-select{width:100%;padding:10px 14px;border:1px solid var(--gray-300);border-radius:8px;font-size:14px;color:var(--gray-800);background:var(--white);transition:all .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1e40af1a}.card{background:var(--white);border-radius:12px;border:1px solid var(--gray-200);box-shadow:0 1px 3px #0000000d}.card-header{padding:20px;border-bottom:1px solid var(--gray-200)}.card-header h3{font-size:16px;font-weight:600;color:var(--gray-900)}.card-body{padding:20px}.video-player-container{background:var(--gray-900);border-radius:12px;overflow:hidden;position:relative}.video-player{width:100%;aspect-ratio:16/9;background:var(--gray-900);display:flex;align-items:center;justify-content:center}.video-placeholder{text-align:center;color:var(--gray-400)}.video-placeholder svg{width:64px;height:64px;margin-bottom:16px}.video-controls{display:flex;align-items:center;gap:12px;padding:16px;background:var(--gray-800)}.video-progress{flex:1;height:4px;background:var(--gray-600);border-radius:2px;cursor:pointer}.filters-bar{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;background:var(--white);padding:16px 20px;border-radius:12px;border:1px solid var(--gray-200)}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:12px;font-weight:500;color:var(--gray-500);text-transform:uppercase}.filter-select{padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:14px;min-width:150px}.timeline{background:var(--white);border-radius:12px;padding:20px;border:1px solid var(--gray-200)}.timeline-bar{height:40px;background:var(--gray-100);border-radius:8px;position:relative;margin:16px 0}.timeline-marker{position:absolute;width:12px;height:12px;border-radius:50%;top:50%;transform:translate(-50%,-50%);cursor:pointer;transition:all .2s ease}.timeline-marker:hover{transform:translate(-50%,-50%) scale(1.3)}.timeline-marker.motion{background:var(--primary)}.timeline-marker.theft{background:var(--danger)}.timeline-marker.vehicle{background:var(--success)}.timeline-marker.human{background:var(--warning)}.chart-container{background:var(--white);border-radius:12px;padding:20px;border:1px solid var(--gray-200);height:300px}.map-container{background:var(--gray-100);border-radius:12px;height:400px;display:flex;align-items:center;justify-content:center;border:1px solid var(--gray-200)}.map-placeholder{text-align:center;color:var(--gray-500)}.map-placeholder svg{width:48px;height:48px;margin-bottom:12px}.alert-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.alert-summary-card{background:var(--white);border-radius:12px;padding:20px;text-align:center;border:1px solid var(--gray-200)}.alert-summary-card.highlight{border-color:var(--danger);background:#ef444405}.alert-summary-value{font-size:32px;font-weight:700;color:var(--gray-900)}.alert-summary-label{font-size:14px;color:var(--gray-500);margin-top:4px}.search-bar{display:flex;align-items:center;gap:12px;background:var(--white);padding:12px 16px;border-radius:8px;border:1px solid var(--gray-300);margin-bottom:24px}.search-bar svg{width:20px;height:20px;color:var(--gray-400)}.search-bar input{flex:1;border:none;outline:none;font-size:14px}.settings-tabs{display:flex;gap:4px;background:var(--gray-100);padding:4px;border-radius:8px;margin-bottom:24px}.settings-tab{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;color:var(--gray-600);cursor:pointer;border:none;background:transparent;transition:all .2s ease}.settings-tab.active{background:var(--white);color:var(--gray-900);box-shadow:0 1px 3px #0000001a}.settings-content{background:var(--white);border-radius:12px;padding:24px;border:1px solid var(--gray-200)}.settings-section{margin-bottom:32px}.settings-section:last-child{margin-bottom:0}.settings-section h3{font-size:16px;font-weight:600;color:var(--gray-900);margin-bottom:16px}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--gray-100)}.settings-row:last-child{border-bottom:none}.settings-label{font-size:14px;color:var(--gray-700)}.settings-value{font-size:14px;color:var(--gray-500)}.toggle-switch{position:relative;width:44px;height:24px;background:var(--gray-300);border-radius:12px;cursor:pointer;transition:all .2s ease}.toggle-switch.active{background:var(--primary)}.toggle-switch:after{content:"";position:absolute;width:20px;height:20px;background:var(--white);border-radius:50%;top:2px;left:2px;transition:all .2s ease;box-shadow:0 1px 3px #0003}.toggle-switch.active:after{left:22px}.progress-bar{height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-fill.blue{background:var(--primary)}.progress-fill.green{background:var(--success)}.progress-fill.orange{background:var(--warning)}.progress-fill.red{background:var(--danger)}.spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.dashboard-grid,.metrics-grid{grid-template-columns:1fr}.filters-bar{flex-direction:column}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease forwards}.fade-in:nth-child(1){animation-delay:0s}.fade-in:nth-child(2){animation-delay:.05s}.fade-in:nth-child(3){animation-delay:.1s}.fade-in:nth-child(4){animation-delay:.15s}.fade-in:nth-child(5){animation-delay:.2s}.fade-in:nth-child(6){animation-delay:.25s}.leaflet-container{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 4px 12px #00000026}.leaflet-popup-content{margin:12px;font-size:13px}.vehicle-marker,.site-marker{background:transparent!important;border:none!important}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 1.5s ease-in-out infinite}
