@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;justify-content:center;align-items:center;gap:8px;padding:9px 18px;font-size:14px;font-weight:500;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed;filter:saturate(.8)}.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-warning{color:var(--warning);background:#f59e0b29;border:1px solid #f59e0b59}.btn-warning:hover{background:#f59e0b38}.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}.camera-modal{max-width:860px}.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-advanced-card{background:linear-gradient(#101624eb,#0c101afa);border:1px solid #6366f129;border-radius:18px;overflow:hidden}.camera-advanced-card__toggle{text-align:left;justify-content:space-between;align-items:flex-start;gap:18px;width:100%;padding:16px 18px;display:flex}.camera-advanced-card__title{color:var(--text-primary);font-size:14px;font-weight:700}.camera-advanced-card__subtitle{color:var(--text-secondary);margin-top:6px;font-size:12px;line-height:1.5}.camera-advanced-card__state{min-width:160px;color:var(--accent-light);text-transform:uppercase;letter-spacing:.08em;flex-direction:column;align-items:flex-end;gap:2px;font-size:11px;font-weight:700;display:flex}.camera-advanced-card__state strong{color:var(--text-primary);text-transform:none;letter-spacing:normal;font-size:12px}.camera-advanced-card__state small{color:var(--text-muted);text-transform:none;letter-spacing:normal;font-size:11px}.camera-advanced-card__body{padding:0 18px 18px}.camera-advanced-card__field-note{color:var(--text-muted);font-size:11px;line-height:1.5}.camera-advanced-card__preview-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.camera-model-source{gap:10px;display:grid}.camera-model-source__option{cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:14px;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.camera-model-source__option input{accent-color:var(--accent);margin-top:2px}.camera-model-source__option strong{color:var(--text-primary);font-size:13px;display:block}.camera-model-source__option span{color:var(--text-muted);margin-top:4px;font-size:11px;line-height:1.5;display:block}.camera-model-upload{background:#ffffff08;border:1px solid #ffffff0f;border-radius:14px;flex-direction:column;gap:10px;margin-top:10px;padding:12px;display:flex}.camera-model-upload__meta{color:var(--text-secondary);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;font-size:12px;display:flex}.camera-model-upload__meta strong{color:var(--text-primary)}.camera-model-upload__path{color:#dbeafe;word-break:break-all;background:#6366f11a;border:1px solid #818cf829;border-radius:12px;padding:10px 12px;font-size:11px}.camera-model-upload__error{color:#fecaca;font-size:12px}.camera-zone-manager{gap:12px;margin-bottom:18px;display:grid}.camera-zone-manager__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.camera-zone-tabs{flex-wrap:wrap;gap:10px;display:flex}.camera-zone-tab{text-align:left;background:#ffffff08;border:1px solid #ffffff14;border-radius:14px;min-width:140px;padding:10px 12px;transition:all .16s}.camera-zone-tab strong{color:var(--text-primary);font-size:13px;display:block}.camera-zone-tab span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:11px;display:block}.camera-zone-tab.is-active{background:#6366f11f;border-color:#6366f173;box-shadow:inset 0 0 0 1px #6366f12e}.camera-roi-editor{background:#ffffff08;border:1px solid #ffffff0f;border-radius:16px;flex-direction:column;gap:12px;padding:14px;display:flex}.camera-roi-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.camera-roi-status{color:var(--text-secondary);font-size:12px;font-weight:600}.camera-roi-toolbar__actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.camera-roi-helper{color:var(--text-muted);font-size:11px;line-height:1.6}.camera-roi-board{cursor:crosshair;background-color:#0000;background-image:linear-gradient(#818cf814,#818cf814),linear-gradient(90deg,#ffffff0d 1px,#0000 1px),linear-gradient(#ffffff0d 1px,#0000 1px),linear-gradient(#080b12f2,#131927eb);background-position:50%;background-repeat:repeat,repeat,repeat,repeat;background-size:auto,32px 32px,32px 32px,auto;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;border:1px dashed #818cf866;border-radius:16px;width:100%;min-height:280px;position:relative;overflow:hidden}.camera-roi-board__video{object-fit:cover;filter:saturate(.92)brightness(.9);width:100%;height:100%;display:block;position:absolute;inset:0}.camera-roi-board__image{object-fit:contain;background:#080b12d9;width:100%;height:100%;display:block;position:absolute;inset:0}.camera-roi-board__placeholder{text-align:center;color:var(--text-muted);justify-content:center;align-items:center;padding:20px;font-size:12px;line-height:1.6;display:flex;position:absolute;inset:0}.camera-roi-board__overlay{color:var(--text-primary);z-index:2;background:#05070c94;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:12px;display:flex;position:absolute;inset:0}.camera-roi-board__overlay.is-error{color:#fecaca;background:#200a0ab8}.camera-roi-board__svg{z-index:3;width:100%;height:100%;position:absolute;inset:0}.camera-roi-points{color:var(--text-secondary);flex-wrap:wrap;gap:8px;font-size:11px;display:flex}.camera-roi-points code{color:#dbeafe;background:#6366f11f;border:1px solid #818cf829;border-radius:999px;padding:4px 8px}.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-worker-card{border:1px solid var(--border);background:radial-gradient(circle at 0 0,#2563eb24,#0000 30%),linear-gradient(#121622f0,#0b0f18eb);border-radius:24px;margin-bottom:24px;padding:22px;box-shadow:0 18px 32px #0000002e}.analytics-worker-card__head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.analytics-worker-card__status{text-transform:capitalize;background:#ffffff0a;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:700;display:inline-flex}.analytics-worker-grid{grid-template-columns:minmax(300px,.95fr) minmax(360px,1.05fr);gap:18px;display:grid}.analytics-worker-summary,.analytics-worker-cameras{background:#ffffff05;border:1px solid #ffffff0f;border-radius:18px;min-width:0;padding:18px}.analytics-worker-metric{color:var(--text-secondary);align-items:center;gap:12px;padding:12px 0;display:flex}.analytics-worker-metric strong{color:var(--text-primary);display:block}.analytics-worker-metric p{color:var(--text-muted);margin-top:4px;font-size:12px}.analytics-worker-actions{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.analytics-worker-cameras__head{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.analytics-worker-camera-list{gap:10px;max-height:360px;display:grid;overflow-y:auto}.analytics-worker-camera-item{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;padding:12px 14px;display:flex}.analytics-worker-camera-item__select{cursor:pointer;flex:1;align-items:center;gap:12px;min-width:0;display:flex}.analytics-worker-camera-item input{flex:none;width:18px;height:18px}.analytics-worker-camera-item strong{color:var(--text-primary);display:block}.analytics-worker-camera-item p{color:var(--text-muted);margin-top:4px;font-size:12px}.analytics-worker-camera-item__side{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.analytics-worker-camera-item__actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.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-productivity-legend{border:1px solid var(--border);background:#ffffff08;border-radius:18px;flex-wrap:wrap;gap:18px;margin-bottom:18px;padding:14px 16px;display:flex}.analytics-productivity-legend__item{color:var(--text-primary);align-items:center;gap:10px;font-weight:600;display:inline-flex}.analytics-productivity-legend__swatch{border-radius:999px;width:44px;height:14px}.analytics-productivity-heatmap{border:1px solid var(--border);background:#ffffff05;border-radius:24px;grid-template-columns:140px repeat(6,minmax(0,1fr));gap:10px;padding:18px;display:grid}.analytics-productivity-heatmap__corner{min-height:1px}.analytics-productivity-heatmap__hour,.analytics-productivity-heatmap__row-label{min-height:48px;color:var(--text-primary);text-align:center;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.analytics-productivity-heatmap__row-label{color:var(--text-secondary);justify-content:flex-start;padding-left:8px}.analytics-productivity-heatmap__cell{color:#fff;border-radius:14px;justify-content:center;align-items:center;min-height:48px;font-size:12px;font-weight:700;transition:transform .18s,opacity .18s;display:flex}.analytics-productivity-heatmap__cell:hover{transform:translateY(-1px)}.analytics-productivity-line{border:1px solid var(--border);background:#ffffff05;border-radius:24px;padding:10px 0 0;overflow:hidden}.analytics-productivity-line__svg{width:100%;height:auto;display:block}.analytics-productivity-line__grid{stroke:#94a3b824;stroke-width:1px}.analytics-productivity-line__axis{fill:var(--text-muted);font-size:12px}.analytics-productivity-line__area{fill:#22c55e1f}.analytics-productivity-line__stroke{fill:none;stroke:#22c55e;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.analytics-productivity-line__dot{stroke:#0f172ae6;stroke-width:3px}.analytics-productivity-ranking{gap:16px;display:grid}.analytics-productivity-ranking__row{border:1px solid var(--border);background:#ffffff05;border-radius:20px;grid-template-columns:minmax(200px,260px) minmax(0,1fr) 64px;align-items:center;gap:18px;padding:16px 18px;display:grid}.analytics-productivity-ranking__head{align-items:center;gap:14px;min-width:0;display:flex}.analytics-productivity-ranking__head strong{color:var(--text-primary);font-size:14px;display:block}.analytics-productivity-ranking__head p{color:var(--text-muted);margin-top:4px;font-size:12px}.analytics-productivity-ranking__index{width:40px;height:40px;color:var(--text-secondary);background:#ffffff0a;border-radius:14px;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.analytics-productivity-ranking__bar{background:#ffffff0f;border-radius:999px;height:12px;overflow:hidden}.analytics-productivity-ranking__fill{border-radius:inherit;height:100%}.analytics-productivity-ranking__value{color:var(--text-primary);text-align:right;font-size:15px}.analytics-productivity-stack{border:1px solid var(--border);background:linear-gradient(0deg,#94a3b808 1px,#0000 1px) 0 0/100% 25%,#ffffff05;border-radius:24px;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));align-items:end;gap:16px;min-height:360px;padding:26px 18px 10px;display:grid}.analytics-productivity-stack__column{flex-direction:column;align-items:center;gap:10px;min-width:0;display:flex}.analytics-productivity-stack__score{color:var(--text-primary);font-size:14px}.analytics-productivity-stack__bar{background:#ffffff0d;border-radius:20px;flex-direction:column-reverse;justify-content:flex-start;width:min(100%,70px);height:250px;display:flex;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0a}.analytics-productivity-stack__segment{width:100%;min-height:0}.analytics-productivity-stack__label{color:var(--text-primary);text-align:center;word-break:break-word;font-size:13px;font-weight:600;line-height:1.25}.analytics-productivity-stack__meta{color:var(--text-muted);text-align:center;font-size:12px;line-height:1.3}.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}.analytics-comparison{flex-direction:column;gap:16px;display:flex}.analytics-comparison__item{grid-template-columns:minmax(80px,110px) minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.analytics-comparison__label{color:var(--text-secondary);font-size:13px;font-weight:600}.analytics-comparison__bar{background:#ffffff0f;border-radius:999px;height:12px;overflow:hidden}.analytics-comparison__fill{border-radius:inherit;height:100%}.analytics-comparison__fill--positive{background:linear-gradient(90deg,#22c55e,#16a34a);box-shadow:0 10px 18px #22c55e3d}.analytics-comparison__fill--warning{background:linear-gradient(90deg,#f59e0b,#d97706);box-shadow:0 10px 18px #f59e0b3d}.analytics-event-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.analytics-event-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-event-card__head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.analytics-event-card__tag{letter-spacing:.08em;text-transform:uppercase;border:1px solid #ffffff1f;border-radius:999px;align-items:center;padding:7px 12px;font-size:11px;font-weight:700;display:inline-flex}.analytics-event-card__value{color:var(--text-primary);font-size:26px;font-weight:800}.analytics-event-card__title{color:var(--text-primary);font-size:17px;font-weight:700}.analytics-event-card__meta{color:var(--text-muted);flex-wrap:wrap;gap:12px;margin-top:10px;font-size:12px;display:flex}.analytics-event-card__bar{background:#ffffff0f;border-radius:999px;height:12px;margin-top:18px;overflow:hidden}.analytics-event-card__fill{border-radius:inherit;height:100%}.analytics-event-card__foot{color:var(--text-muted);justify-content:space-between;align-items:center;gap:12px;margin-top:12px;font-size:12px;display:flex}.plugin-catalog{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;display:grid}.plugin-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(#ffffff06,#ffffff04);padding:20px}.plugin-card--compact{padding:18px 20px}.plugin-card__head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.plugin-card__title-wrap{align-items:flex-start;gap:12px;display:flex}.plugin-card__dot{border-radius:999px;width:12px;height:12px;margin-top:6px;box-shadow:0 0 18px}.plugin-card__title{color:var(--text-primary);font-size:16px;font-weight:700}.plugin-card__meta{color:var(--text-muted);flex-wrap:wrap;gap:8px 12px;margin-top:6px;font-size:12px;display:flex}.plugin-card__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.plugin-card__description{color:var(--text-secondary);margin-top:14px}.plugin-card__grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:18px;display:grid}.plugin-card__grid div{border-radius:var(--radius);background:#ffffff05;border:1px solid #ffffff0a;padding:12px 14px}.plugin-card__grid span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;display:block}.plugin-card__grid strong{color:var(--text-primary);margin-top:6px;font-size:14px;display:block}.face-gallery-card__thumb{object-fit:cover;background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;width:100%;min-height:180px;max-height:240px;margin-top:14px}.face-gallery-card__placeholder{width:100%;min-height:180px;color:var(--text-muted);background:radial-gradient(circle at top,#26b6ff1f,#0000 55%),linear-gradient(#121827f2,#0a0f18fa);border:1px dashed #ffffff1f;border-radius:16px;justify-content:center;align-items:center;margin-top:14px;display:flex}.portal-avatar{width:54px;height:54px}.plugin-detail-grid{grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);gap:24px;display:grid}.plugin-detail-heading{align-items:flex-start;gap:14px;display:flex}.alerts-layout{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:24px;display:grid}.alert-lanes{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.alert-lane{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;transition:all var(--transition);background:#ffffff05;border-radius:16px;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.alert-lane strong{font-size:24px;font-weight:700}.alert-lane--critical{border-color:#ef444447}.alert-lane--warning{border-color:#f59e0b47}.alert-lane--info{border-color:#3b82f647}.alert-lane.is-active{transform:translateY(-1px);box-shadow:inset 0 0 0 1px #ffffff0f,0 0 0 2px #38bdf82e}.alerts-routing-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;display:grid}.event-evidence-inline{flex-wrap:wrap;gap:6px;display:flex}.event-thumbnail-button,.event-thumbnail-placeholder{background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;width:92px;height:56px;overflow:hidden}.event-thumbnail-button{transition:transform var(--transition), border-color var(--transition);justify-content:center;align-items:center;padding:0;display:inline-flex}.event-thumbnail-button:hover{border-color:#818cf852;transform:translateY(-1px)}.event-thumbnail-image{object-fit:cover;width:100%;height:100%;display:block}.event-thumbnail-placeholder{color:var(--text-muted);justify-content:center;align-items:center;display:inline-flex}.event-evidence-modal{border:1px solid var(--border);background:linear-gradient(#121622fa,#0b0f18f5);border-radius:22px;width:min(1180px,94vw);margin:48px auto;padding:22px;position:relative;box-shadow:0 32px 80px #00000070}.event-evidence-modal__close{border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:#ffffff0a;border-radius:12px;position:absolute;top:18px;right:18px}.event-evidence-modal__header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;padding-right:52px;display:flex}.event-evidence-modal__title{color:var(--text-primary);font-size:22px;font-weight:800}.event-evidence-modal__meta{color:var(--text-muted);flex-wrap:wrap;gap:12px;margin-top:8px;font-size:13px;display:flex}.event-evidence-modal__grid{grid-template-columns:minmax(0,1.35fr) minmax(320px,.9fr);gap:18px;display:grid}.event-evidence-modal__media,.event-evidence-modal__details{flex-direction:column;gap:18px;min-width:0;display:flex}.event-evidence-modal__panel{border:1px solid var(--border);background:#ffffff08;border-radius:18px;padding:16px}.event-evidence-modal__panel-title{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:14px;font-size:14px;font-weight:700;display:flex}.event-evidence-modal__image,.event-evidence-modal__video{background:#000;border-radius:14px;width:100%}.event-evidence-modal__detail-list{gap:12px;display:grid}.event-evidence-modal__detail-list div{border-bottom:1px solid #ffffff0f;justify-content:space-between;gap:16px;padding-bottom:10px;display:flex}.event-evidence-modal__detail-list span{color:var(--text-muted);font-size:13px}.event-evidence-modal__detail-list strong{color:var(--text-primary);text-align:right}.event-evidence-modal__payload{color:#cbd5e1;background:#020617b8;border-radius:14px;max-height:420px;margin:0;padding:14px;font-size:12px;line-height:1.5;overflow:auto}.event-detected-object-list{flex-direction:column;gap:10px;display:flex}.event-detected-object-item{background:#0f172a85;border:1px solid #ffffff0f;border-radius:14px;padding:12px 14px}.event-detected-object-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.event-detected-object-row strong{color:var(--text-primary);font-size:13px}.event-detected-object-meta{color:var(--text-secondary);margin-top:6px;font-size:12px}.system-layout{grid-template-columns:minmax(0,1.45fr) minmax(320px,.9fr);gap:20px;display:grid}.system-service-list{gap:16px;display:grid}.system-service-card{border:1px solid var(--border);background:#ffffff08;border-radius:18px;padding:18px}.system-service-card__head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.system-service-card__title-wrap{align-items:flex-start;gap:12px;min-width:0;display:flex}.system-service-card__icon{color:#93c5fd;background:#3b82f61f;border:1px solid #3b82f62e;border-radius:12px;flex:none;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.system-service-card__title{color:var(--text-primary);font-size:15px;font-weight:700}.system-service-card__subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:12px}.system-service-card__detail{color:var(--text-secondary);margin-top:14px;font-size:13px;line-height:1.55}.system-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.system-meta-grid div{background:#0f172a73;border:1px solid #ffffff0d;border-radius:14px;min-width:0;padding:12px 13px}.system-meta-grid span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px;display:block}.system-meta-grid strong{color:var(--text-primary);word-break:break-word;margin-top:8px;font-size:13px;line-height:1.5;display:block}.system-config-list{gap:12px;display:grid}.system-config-item{border:1px solid var(--border);background:#ffffff08;border-radius:16px;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 16px;display:flex}.system-config-item__label{color:var(--text-primary);font-size:14px;font-weight:600}.system-config-item__meta{color:var(--text-muted);margin-top:4px;font-size:12px}.system-config-item__value{min-width:0;max-width:52%;color:var(--text-secondary);text-align:right;word-break:break-word;font-size:13px}@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-event-grid,.event-evidence-modal__grid,.analytics-worker-grid,.plugin-detail-grid,.system-layout,.alerts-layout,.alert-lanes,.analytics-distribution-row{grid-template-columns:1fr}.analytics-comparison__item,.analytics-event-card__foot{flex-direction:column;grid-template-columns:1fr;align-items:flex-start;display:flex}.analytics-hourly-chart{grid-template-columns:repeat(3,minmax(0,1fr))}.analytics-productivity-heatmap{grid-template-columns:110px repeat(6,minmax(0,1fr));gap:8px;padding:14px}.analytics-productivity-ranking__row{grid-template-columns:1fr;gap:12px}.analytics-productivity-ranking__value{text-align:left}.analytics-productivity-stack{grid-template-columns:repeat(3,minmax(0,1fr));min-height:320px;padding-inline:14px}.camera-modal{max-width:96vw}.camera-advanced-card__toggle{flex-direction:column}.camera-advanced-card__state{align-items:flex-start;min-width:0}}@media (width<=640px){.analytics-productivity-legend{gap:12px}.analytics-productivity-heatmap{grid-template-columns:96px repeat(3,minmax(0,1fr))}.analytics-productivity-heatmap__hour,.analytics-productivity-heatmap__row-label,.analytics-productivity-heatmap__cell{min-height:42px;font-size:11px}.analytics-productivity-stack{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-productivity-stack__bar{width:min(100%,60px);height:220px}}@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{flex-direction:column;align-items:stretch}.system-meta-grid{grid-template-columns:1fr}.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}.system-config-item{flex-direction:column}.system-config-item__value{text-align:left;max-width:100%}.camera-connection-options{flex-direction:column;gap:12px}.camera-roi-board{min-height:220px}.camera-roi-toolbar__actions{width:100%}.camera-roi-toolbar__actions .btn{flex:1}.camera-advanced-card__preview-actions .btn{justify-content:center;width:100%}.camera-model-upload__meta{flex-direction:column;align-items:flex-start}.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}@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}.upload-detail-grid{grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);gap:24px;display:grid}.upload-detail-top-grid{grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);align-items:start;gap:24px;display:grid}.upload-detail-page{padding:40px 44px 64px}.upload-detail-card{padding:26px;overflow:hidden}.upload-detail-card--selectable{overflow:visible}.upload-detail-card__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.upload-detail-card__header .form-select{z-index:4;width:100%;max-width:min(100%,360px);position:relative}.upload-detail-media{object-fit:contain;background:#0a0e18e6;border:1px solid #94a3b824;border-radius:18px;width:100%;max-height:520px}.upload-detail-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.upload-detail-meta-grid--stacked{grid-template-columns:1fr;margin-top:4px}.upload-detail-info-card .upload-detail-meta-grid>div{min-height:70px}.upload-detail-meta-grid>div{background:#ffffff05;border:1px solid #94a3b814;border-radius:14px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.upload-detail-meta-grid span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px}.upload-detail-meta-grid strong{color:var(--text-primary);font-size:15px;line-height:1.4}.upload-detail-results{gap:16px;display:grid}.upload-result-card{background:#ffffff06;border:1px solid #94a3b81a;border-radius:18px;padding:18px}.upload-result-card__title{color:var(--text-primary);margin-bottom:14px;font-size:18px;font-weight:700}.upload-detail-settings .form-group{min-width:0}.upload-evidence-gallery{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.upload-evidence-video-list{grid-template-columns:1fr;gap:12px;display:grid}.upload-evidence-thumb{cursor:pointer;background:0 0;border:0;padding:0;display:block}.upload-evidence-image{object-fit:cover;background:#0b0f18;border:1px solid #94a3b824;border-radius:12px;width:100%;max-height:220px}.upload-evidence-video{background:#0b0f18;border:1px solid #94a3b824;border-radius:12px;width:100%;max-height:360px}.upload-result-evidence-badges{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.upload-evidence-zoom{background:#0b0f18;border:1px solid #94a3b82e;border-radius:18px;width:min(980px,92vw);margin:6vh auto;padding:18px;position:relative;box-shadow:0 32px 80px #00000080}.upload-evidence-zoom img{border-radius:12px;width:100%;height:auto;display:block}@media (width<=1180px){.upload-detail-page{padding:28px 24px 48px}.upload-detail-grid,.upload-detail-top-grid{grid-template-columns:1fr}}@media (width<=720px){.upload-detail-page{padding:20px 16px 36px}.upload-detail-card{padding:18px}.upload-detail-card__header{flex-direction:column;align-items:stretch}.upload-detail-meta-grid{grid-template-columns:1fr}}.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%}.toggle-switch{width:36px;height:20px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--bg-inset);border:1px solid #ffffff1a;border-radius:20px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:var(--text-muted);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;bottom:2px;left:2px}input:checked+.toggle-slider{background-color:var(--accent-color);border-color:var(--accent-color)}input:focus+.toggle-slider{box-shadow:0 0 1px var(--accent-color)}input:checked+.toggle-slider:before{background-color:#fff;transform:translate(16px)}@keyframes toastSlideIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes confirmModalIn{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.split-screen-layout{background:var(--bg-default);width:100vw;min-height:100vh;display:flex;overflow-x:hidden}.table-responsive-wrapper,.table-wrapper{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.mobile-hidden,.tablet-hidden{display:inline-flex}@media (width<=960px){.split-screen-layout{flex-direction:column;height:auto;min-height:auto;overflow-y:auto}.split-screen-layout>div{flex:none!important;width:100%!important}.split-screen-layout__branding{border-bottom:1px solid #ffffff0f;border-right:none!important;padding:40px 24px!important}.split-screen-layout__form{padding:40px 24px!important}}@media (width<=1024px){.tablet-hidden{display:none!important}}@media (width<=768px){.page-header-responsive{flex-direction:column;align-items:flex-start;gap:16px}.page-header-responsive .btn{justify-content:center;width:100%}.mobile-hide,.mobile-hidden{display:none!important}.settings-grid{grid-template-columns:1fr!important}.portal-avatar{width:44px!important;height:44px!important}.portal-avatar svg{width:22px!important;height:22px!important}.card-header{flex-direction:column;align-items:flex-start;gap:12px}}@media (width<=480px){.page-shell{padding:12px 12px 24px}.portal-title{font-size:20px!important}.portal-metadata{gap:4px!important;font-size:12px!important}.portal-actions{width:100%}.portal-actions .btn{flex:1;min-width:44px}}.rbac-page{flex-direction:column;gap:20px;display:flex}.rbac-toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.rbac-toolbar__select{min-width:240px}.rbac-stats-grid{margin-bottom:0}.rbac-layout{grid-template-columns:minmax(0,1.2fr) minmax(340px,1fr);align-items:start}.rbac-stack{gap:12px;display:grid}.rbac-card{background:linear-gradient(#0f172a8f,#0f172a61);border:1px solid #94a3b82e}.rbac-card__header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.rbac-card__title{font-size:15px;font-weight:700}.rbac-card__meta{color:var(--text-secondary);font-size:12px}.rbac-card__description{color:var(--text-primary);margin-top:8px;font-size:13px}.rbac-card__actions{flex-shrink:0;gap:8px;display:flex}.rbac-card__footer{margin-top:12px}.rbac-assignment-select{min-height:140px}.rbac-modal{max-width:1120px}.rbac-modal-grid{align-items:start}.rbac-checklist{border:1px solid var(--border);background:#0f172a4d;border-radius:14px;max-height:360px;padding:12px;overflow:auto}.rbac-checklist__group{margin-bottom:14px}.rbac-checklist__title{text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:700}.rbac-checklist__item{cursor:pointer;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.rbac-checklist__content{font-size:13px}.rbac-checklist__content span{color:var(--text-secondary)}@media (width<=1024px){.rbac-layout{grid-template-columns:1fr}}@media (width<=768px){.rbac-toolbar{width:100%}.rbac-toolbar__select{min-width:100%}.rbac-card__header{flex-direction:column}.rbac-card__actions{width:100%}.rbac-card__actions .btn{flex:1}}
