@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-base:#0a0c10;--bg-surface:#111318;--bg-elevated:#1a1d26;--bg-hover:#22263a;--border:#ffffff12;--border-active:#6366f180;--accent:#6366f1;--accent-light:#818cf8;--accent-dark:#4f46e5;--accent-glow:#6366f140;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#38bdf8;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--radius-sm:6px;--radius:10px;--radius-lg:16px;--radius-xl:24px;--shadow-lg:0 20px 60px #00000080;--shadow-glow:0 0 30px #6366f133;--sidebar-accent:#27b3ff;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;font-size:14px;line-height:1.6}#root{min-height:100%}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.btn{border-radius:var(--radius);transition:all var(--transition);white-space:nowrap;align-items:center;gap:8px;padding:9px 18px;font-size:14px;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.btn-primary:hover{background:var(--accent-light);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent-light)}.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover{background:#ef444440}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-active);background:var(--bg-elevated)}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{border-radius:var(--radius-sm);padding:8px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-body{padding:24px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:500}.form-input,.form-select,.form-textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);width:100%;transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.badge{text-transform:uppercase;letter-spacing:.06em;border-radius:9999px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{color:var(--success);background:#22c55e26}.badge-warning{color:var(--warning);background:#f59e0b26}.badge-danger{color:var(--danger);background:#ef444426}.badge-neutral{background:var(--bg-elevated);color:var(--text-secondary)}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:600}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--bg-elevated)}tbody td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:14px 16px}tbody tr:last-child td{border-bottom:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:flex-start;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:90%;max-width:520px;box-shadow:var(--shadow-lg);margin:28px 0;animation:.2s slideUp}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:24px;display:flex}.modal-body{flex-direction:column;gap:18px;padding:24px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:20px 24px;display:flex}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), transform var(--transition);align-items:center;gap:18px;padding:24px;display:flex}.stat-card:hover{border-color:var(--border-active);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-content{flex:1}.stat-value{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.app-shell{min-height:100vh;display:flex;overflow:hidden}.app-sidebar{background:radial-gradient(circle at 0 0,#27b3ff29,#0000 26%),linear-gradient(#12131b 0%,#0d0f16 55%,#090b10 100%);border-right:1px solid #ffffff14;flex-direction:column;flex-shrink:0;width:268px;display:flex;box-shadow:inset -1px 0 #ffffff08}.app-logo{border-bottom:1px solid #ffffff0f;align-items:center;gap:14px;padding:26px 22px;display:flex}.app-logo-mark{background:linear-gradient(#27b3ff29,#27b3ff0d);border:1px solid #27b3ff47;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 0 24px #27b3ff1a}.app-logo-copy{flex:1;min-width:0}.app-logo-collapse{color:#e2e8f0b8;align-items:center;display:flex}.app-nav{flex-direction:column;flex:1;gap:8px;padding:16px 12px;display:flex;overflow:auto}.app-logout{border-top:1px solid #ffffff0f;padding:14px 12px 18px}.app-main{background:var(--bg-base);flex:1;overflow:auto}.page-shell{width:100%;max-width:none;padding:32px 36px 48px}.page-shell-wide{padding-bottom:56px}.page-header-responsive{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.dashboard-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:32px;display:grid}.dashboard-panels{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;display:grid}.dashboard-panel-card{min-width:0}.dashboard-map-card{margin-top:24px}.dashboard-map-layout{min-height:540px;display:block}.dashboard-map-summary{text-align:center}.dashboard-map-summary__stats{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:12px;display:flex}.dashboard-map-summary__stat{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;justify-content:center;align-items:center;padding:6px 10px;font-size:11px;font-weight:700;display:inline-flex}.dashboard-map-summary__stat.is-online{color:#86efac;background:#22c55e1f;border:1px solid #22c55e3d}.dashboard-map-summary__stat.is-offline{color:#cbd5e1;background:#94a3b81f;border:1px solid #94a3b82e}.dashboard-map-summary__value{color:var(--text-primary);font-size:42px;font-weight:800;line-height:1}.dashboard-map-summary__label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-top:8px;font-size:13px}.dashboard-map-search{border:1px solid var(--border);background:var(--bg-elevated);border-radius:14px;align-items:stretch;display:flex;overflow:hidden}.dashboard-map-search__icon{width:54px;color:var(--accent-light);border-right:1px solid var(--border);background:#6366f124;justify-content:center;align-items:center;display:flex}.dashboard-map-search__input{background:0 0;border:none;border-radius:0;box-shadow:none!important}.dashboard-map-list{border:1px solid var(--border);background:#ffffff05;border-radius:16px;flex-direction:column;display:flex;overflow:auto}.dashboard-map-list__empty{color:var(--text-muted);text-align:center;padding:20px}.dashboard-map-list__item{width:100%;color:var(--text-secondary);border-bottom:1px solid var(--border);text-align:left;transition:background var(--transition), color var(--transition);align-items:flex-start;gap:12px;padding:16px 18px;display:flex}.dashboard-map-list__item:last-child{border-bottom:none}.dashboard-map-list__item.is-selected,.dashboard-map-list__item:hover{color:var(--text-primary);background:#6366f11f}.dashboard-map-list__title{color:inherit;font-weight:700}.dashboard-map-list__meta{color:var(--text-muted);margin-top:4px;font-size:12px}.dashboard-map-panel{min-width:0;position:relative}.dashboard-map-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:500;background:linear-gradient(#0e121cf0,#0b0e16e0);border:1px solid #ffffff14;border-radius:22px;flex-direction:column;gap:16px;width:min(360px,100% - 32px);max-height:calc(100% - 56px);padding:18px;display:flex;position:absolute;top:28px;left:28px;box-shadow:0 18px 42px #00000052}.dashboard-map-overlay.is-minimized{width:min(360px,100% - 32px);max-height:none}.dashboard-map-overlay__topbar{justify-content:space-between;align-items:center;gap:10px;display:flex}.dashboard-map-overlay__drag{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;cursor:grab;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:999px;align-self:flex-start;align-items:center;gap:8px;padding:8px 12px;font-size:11px;font-weight:700;display:inline-flex}.dashboard-map-overlay__drag:active{cursor:grabbing}.dashboard-map-overlay__toggle{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:11px;font-weight:700;display:inline-flex}.dashboard-map-canvas{background:#ffffff05;width:100%;height:100%;min-height:540px}.dashboard-map-empty{height:100%;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.dashboard-map-marker{justify-content:center;align-items:center;width:30px;height:38px;display:flex;transform:translateZ(0)}.dashboard-map-marker__inner{color:#2563eb;filter:drop-shadow(0 8px 12px #0003);width:30px;height:38px}.dashboard-map-marker.is-active .dashboard-map-marker__inner{color:#2563eb}.dashboard-map-marker.is-inactive .dashboard-map-marker__inner{color:#94a3b8;opacity:.88}.dashboard-map-marker.is-selected .dashboard-map-marker__inner{color:#f97316;opacity:1}.dashboard-map-marker svg{fill:currentColor;width:100%;height:100%}.dashboard-map-popup{min-width:180px}.dashboard-map-popup__title{color:#111827;font-size:14px;font-weight:700}.dashboard-map-popup__meta{color:#475569;margin-top:4px;margin-bottom:10px;font-size:12px}.dashboard-map-popup__button{color:#fff;text-transform:uppercase;letter-spacing:.04em;background:linear-gradient(#0f172a,#1e3a8a);border:1px solid #1e40af52;border-radius:12px;justify-content:center;align-items:center;padding:10px 14px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 10px 24px #1e40af38}.live-layout{grid-template-columns:minmax(0,1fr) 260px;align-items:start;gap:20px;display:grid}.live-monitor-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.live-monitor-title{font-size:24px;font-weight:700}.live-monitor-select{width:304px;max-width:100%}.live-monitor-grid{grid-template-columns:minmax(0,1fr) minmax(320px,33%);align-items:start;gap:20px;display:grid}.live-monitor-side{flex-direction:column;gap:20px;display:flex}.live-monitor-player{border:1px solid var(--border);border-radius:var(--radius-lg);aspect-ratio:16/9;background:#050608;position:relative;overflow:hidden}.live-monitor-player__video{object-fit:contain;width:100%;height:100%;display:block}.live-monitor-player__overlay{color:var(--text-secondary);background:#000000b8;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.live-monitor-player__badge{color:#b7ffcc;background:#0a2a16d1;border:1px solid #22c55e59;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;display:flex;position:absolute;top:12px;left:12px}.live-monitor-player__badge-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite liveBadgePulse;box-shadow:0 0 #ef4444a6}.live-monitor-details{flex-direction:column;gap:18px;display:flex}.live-monitor-details__row{color:var(--text-secondary);justify-content:space-between;gap:12px;display:flex}.live-monitor-details__row span:last-child{color:var(--text-primary)}.live-monitor-recordings{flex-direction:column;display:flex}.live-monitor-recordings__item{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.live-monitor-recordings__item:first-child{border-top:none}.live-monitor-recordings__content{min-width:0}.live-monitor-recordings__title{color:var(--text-primary);word-break:break-word;font-weight:700}.live-monitor-recordings__meta{color:var(--text-muted);margin-top:6px;font-size:12px}.live-monitor-bottom{margin-top:20px}.recordings-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.pagination-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;display:flex}.pagination-meta{color:var(--text-muted);font-size:12px}.pagination-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pagination-page{text-align:center;min-width:92px;color:var(--text-secondary);font-size:12px;font-weight:600}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;display:grid}.mail-test-layout{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:12px;display:grid}.camera-connection-options{flex-wrap:wrap;gap:24px;display:flex}.camera-map-picker{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elevated);overflow:hidden}.camera-map-helper{border-bottom:1px solid var(--border);color:var(--text-muted);padding:10px 12px;font-size:12px}.camera-map-canvas{background:#ffffff05;width:100%;height:220px}.analytics-grid{gap:20px;margin-bottom:20px;display:grid}.analytics-grid--stats{grid-template-columns:repeat(4,minmax(0,1fr))}.analytics-grid--charts{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-stat-card{border:1px solid var(--border);background:linear-gradient(#121622f0,#0b0f18eb);border-radius:20px;align-items:center;gap:16px;min-width:0;padding:22px;display:flex;box-shadow:0 18px 32px #0000002e}.analytics-stat-card__icon{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.analytics-stat-card__value{color:var(--text-primary);font-size:28px;font-weight:800}.analytics-stat-card__label{color:var(--text-muted);margin-top:4px;font-size:13px}.analytics-chart-card{border:1px solid var(--border);background:linear-gradient(#121622f0,#0b0f18eb);border-radius:22px;min-width:0;padding:22px;box-shadow:0 18px 32px #0000002e}.analytics-chart-card__head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.analytics-chart-card__kicker{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:700}.analytics-chart-card__title{color:var(--text-primary);margin-top:6px;font-size:18px;font-weight:700}.analytics-distribution-list,.analytics-matrix-list,.analytics-summary-list{flex-direction:column;gap:14px;display:flex}.analytics-distribution-row{grid-template-columns:minmax(120px,160px) minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.analytics-distribution-label{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.analytics-distribution-dot{border-radius:999px;width:10px;height:10px}.analytics-distribution-track{background:#ffffff0f;border-radius:999px;height:10px;overflow:hidden}.analytics-distribution-fill{border-radius:inherit;height:100%}.analytics-distribution-value{color:var(--text-primary);font-size:13px}.analytics-hourly-chart{grid-template-columns:repeat(6,minmax(0,1fr));align-items:end;gap:12px;min-height:220px;display:grid}.analytics-hourly-group{flex-direction:column;align-items:center;gap:10px;display:flex}.analytics-hourly-rail{background:#ffffff0d;border-radius:18px;align-items:flex-end;width:100%;height:170px;padding:10px;display:flex}.analytics-hourly-fill{background:linear-gradient(#38bdf8,#2563eb);border-radius:12px;width:100%;box-shadow:0 12px 18px #2563eb38}.analytics-hourly-label{color:var(--text-muted);font-size:12px}.analytics-matrix-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:14px 0;display:flex}.analytics-matrix-row:first-child{border-top:none;padding-top:0}.analytics-matrix-event{color:var(--text-primary);font-weight:700}.analytics-matrix-subtext{color:var(--text-muted);margin-top:4px;font-size:12px;display:inline-block}.analytics-matrix-metrics{color:var(--text-secondary);flex-direction:column;align-items:flex-end;gap:4px;font-size:12px;display:flex}.analytics-matrix-metrics strong{color:var(--text-primary);font-size:14px}.analytics-summary-item{align-items:flex-start;gap:12px;display:flex}.analytics-summary-item strong{color:var(--text-primary)}.analytics-summary-item p{color:var(--text-muted);margin-top:4px;font-size:12px}.analytics-summary-swatch{border-radius:999px;width:12px;height:12px;margin-top:4px}.analytics-summary-note{border-top:1px solid var(--border);color:var(--text-muted);margin-top:6px;padding-top:14px;font-size:12px}@media (width<=1024px){.page-shell{padding:24px 24px 40px}.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-panels,.live-layout,.live-monitor-grid{grid-template-columns:1fr}.dashboard-map-overlay{width:auto;max-height:none;margin:16px;position:relative;top:auto!important;left:auto!important}.dashboard-map-canvas{min-height:420px}.analytics-grid--stats,.analytics-grid--charts,.analytics-distribution-row{grid-template-columns:1fr}.analytics-hourly-chart{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=820px){.app-shell{flex-direction:column;overflow:auto}.app-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%}.app-logo{padding:18px 16px}.app-nav{flex-direction:row;gap:10px;padding:10px 12px;overflow:auto}.app-nav a{min-width:max-content}.app-logout{border-top:none;padding:10px 12px 14px}.app-main{overflow:visible}.page-header-responsive,.live-monitor-header{flex-direction:column;align-items:stretch}}@media (width<=640px){.page-shell{padding:18px 14px 28px}.dashboard-stats{grid-template-columns:1fr}.card-header,.card-body,.modal-header,.modal-body,.modal-footer{padding-left:16px;padding-right:16px}.modal{border-radius:18px;width:calc(100% - 20px);max-width:none;margin:10px 0}.mail-test-layout{grid-template-columns:1fr}.recordings-toolbar>*{width:100%;max-width:none!important}.recordings-toolbar .btn{justify-content:center}.camera-connection-options{flex-direction:column;gap:12px}.camera-map-canvas{height:180px}.dashboard-map-overlay{margin:12px;padding:16px}.dashboard-map-search__icon{width:48px}.dashboard-map-canvas{min-height:320px}.live-monitor-player,.live-monitor-player__video{min-height:auto}thead th,tbody td{padding-left:10px;padding-right:10px}.btn{padding:9px 14px}.btn-sm{padding:6px 10px}}.empty-state svg{opacity:.3}.empty-state h3{color:var(--text-secondary);font-size:16px}.alert{border-radius:var(--radius);align-items:center;gap:10px;padding:14px 18px;font-size:13px;display:flex}.alert-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d}.alert-success{color:#86efac;background:#22c55e1a;border:1px solid #22c55e4d}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes liveBadgePulse{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 #ef44448c}50%{opacity:.55;transform:scale(.82);box-shadow:0 0 0 6px #ef444400}}.live-dot{background:var(--success);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite pulse;display:inline-block}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-light)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.fw-600{font-weight:600}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.w-full{width:100%}
