@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap";:root{color-scheme:light;--primary: #3566e8;--accent: #ff8a2a;--surface-soft: #f2f5fd;--surface-muted: #edf2ff;--text: #0f1730;--muted: #4a5568;--line: #d7e0fe;--line-strong: #c8d4ff;--good: #159947;--good-soft: #eaf7ef;--warn: #f97316;--warn-soft: #fff3e8;--danger: #dc2626;--danger-soft: #fff0f0}*{box-sizing:border-box}body{min-width:320px;margin:0;background:radial-gradient(circle at top,rgba(53,102,232,.1),transparent 24%),radial-gradient(circle at bottom center,rgba(255,138,42,.08),transparent 22%),linear-gradient(180deg,#f7f8fc,#eff3ff 48%,#f7f8fc);color:var(--text);font-family:Poppins,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}button,input{font:inherit}button{border:0}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin-top:0}h1{margin-bottom:3px;font-size:1.55rem;line-height:1.1}h2{margin-bottom:0;font-size:.94rem;line-height:1.2}svg{display:block;width:100%;height:auto}.app-shell{display:grid;grid-template-columns:210px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:16px;padding:14px 12px;background:linear-gradient(180deg,#121827fa,#0e1630fa);border-right:1px solid rgba(215,224,254,.12);box-shadow:inset -1px 0 #ffffff0a}.brand{display:grid;grid-template-columns:34px minmax(0,1fr);gap:9px;align-items:center;padding:4px 2px 12px;border-bottom:1px solid var(--line)}.brand-mark{display:block;width:34px;height:34px;object-fit:contain;border-radius:7px;background:#fff}.brand strong{color:#edf2ff;font-size:.95rem}.nav-stack{display:grid;gap:4px}.nav-link{display:grid;grid-template-columns:28px minmax(0,1fr);gap:8px;align-items:center;min-height:38px;padding:7px 9px;color:#cbd5e1;background:transparent;border:1px solid transparent;border-radius:12px;text-align:left;transition:background .16s ease,color .16s ease,transform .16s ease}.nav-link span{display:grid;place-items:center;width:24px;height:22px;color:#dbeafe;background:#ffffff14;border:1px solid rgba(215,224,254,.12);border-radius:8px}.nav-link svg{width:15px;height:15px}.nav-link:hover,.nav-link.active{color:#fff;background:linear-gradient(90deg,#3566e82e,#ff8a2a24);border-color:#d7e0fe3d;transform:translate(1px)}.nav-link.active span{color:#fff;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);border-color:transparent}.logout-button{margin-top:auto;padding:10px 12px;color:#edf2ff;background:#ffffff0f;border:1px solid rgba(215,224,254,.18);border-radius:12px;cursor:pointer}.workspace{min-width:0;padding:14px}.topbar{display:block;margin-bottom:12px}.topbar p{margin:4px 0 0;color:var(--muted);font-size:.78rem}@media(max-width:1050px){.app-shell{grid-template-columns:74px minmax(0,1fr)}.brand{grid-template-columns:1fr;justify-items:center}.brand strong,.nav-link{font-size:0}.nav-link{grid-template-columns:1fr;justify-items:center}}@media(max-width:760px){.app-shell{display:block}.sidebar{position:static;height:auto;padding:8px}.brand{display:none}.nav-stack{display:flex;overflow-x:auto;gap:6px}.nav-link{min-width:54px}.workspace{padding:10px}}.kpi-card span,.mini-panel span,.report-card span{display:block;color:var(--muted);font-size:.66rem;font-weight:750;text-transform:uppercase}.kpi-strip{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:10px;margin-bottom:12px}.kpi-card,.panel,.mini-panel,.chart-card,.report-card,.lane-card,.alert-row,.camera-card{background:#ffffffd6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:20px;box-shadow:0 12px 30px #14285014;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),border-color .3s ease}.kpi-card:hover,.mini-panel:hover,.chart-card:hover,.report-card:hover,.lane-card:hover{transform:translateY(-4px);box-shadow:0 22px 42px #14285024;border-color:var(--line-strong)}.kpi-card{min-height:108px;padding:12px}.kpi-card strong,.mini-panel strong,.report-card strong{display:block;margin:6px 0 4px;color:var(--text);font-size:1.75rem;line-height:1}.kpi-card em,.mini-panel em{color:var(--muted);font-size:.75rem;font-style:normal}.kpi-card.good,.mini-panel.good{border-bottom:3px solid var(--good)}.kpi-card.warn,.mini-panel.warn{border-bottom:3px solid var(--warn)}.kpi-card.danger,.mini-panel.danger{border-bottom:3px solid var(--danger)}.mini-panel{min-height:80px;padding:10px}.panel{overflow:hidden}.panel.no-inner-heading .panel-header{display:none}.panel-header{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px 14px;background:linear-gradient(180deg,#ffffffeb,#f7f9ffe0);border-bottom:1px solid var(--line)}.badge,.severity{display:inline-flex;align-items:center;min-height:22px;padding:0 7px;border-radius:999px;font-size:.64rem;font-weight:800;text-transform:uppercase;white-space:nowrap}.badge{color:#3f4750;background:var(--surface-soft);border:1px solid var(--line)}.badge.danger,.severity.danger{color:#9f1239;background:var(--danger-soft);border:1px solid #ffc9c9}.severity.warn,.badge.warn{color:#9a4b00;background:var(--warn-soft);border:1px solid #fed7aa}.severity.good{color:#0f6b34;background:var(--good-soft);border:1px solid #bee8ca}.chart-card{min-height:178px;padding:11px}.chart-card.wide{grid-column:1 / -1}.chart-card.vehicle-lane-card{min-height:240px}.chart-title{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:8px}.chart-title span{color:var(--text);font-size:.78rem;font-weight:850}.chart-title strong{color:var(--muted);font-size:.68rem;text-transform:uppercase}.grid-line{stroke:#e5e7eb;stroke-width:1}.chart-label{fill:#68717a;font-size:11px;font-weight:750}.line-entry{fill:none;stroke:var(--good);stroke-width:3}.line-exit{fill:none;stroke:var(--warn);stroke-width:3}.area-occupancy{fill:#f9731624}.area-line{fill:none;stroke:var(--warn);stroke-width:2}.heatmap{display:grid;grid-template-columns:repeat(6,1fr);gap:5px}.heat-cell{min-height:30px;border-radius:5px;border:1px solid var(--line)}.heat-cell.low{background:#dff7e7}.heat-cell.medium{background:#fed7aa}.heat-cell.high{background:#ffc9c9}.progress-rows{display:grid;gap:11px;padding:12px}.progress-row{display:grid;grid-template-columns:106px minmax(0,1fr) 64px;gap:10px;align-items:center;font-size:.76rem}.progress-row span{color:#3f4750;font-weight:760}.progress-track{height:10px;overflow:hidden;background:var(--surface-muted);border-radius:999px}.progress-track i{display:block;height:100%;background:linear-gradient(90deg,var(--good),var(--warn));border-radius:inherit}.summary-stack,.alert-table,.incident-list,.settings-list{display:grid;gap:8px;padding:10px}.alert-table,.incident-list{grid-template-columns:repeat(2,minmax(0,1fr))}.alert-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;min-height:54px;padding:8px;background:#fff;border:1px solid var(--line);border-radius:7px;transition:transform .2s ease,box-shadow .2s ease}.alert-row:hover{transform:translate(4px);box-shadow:0 8px 16px #1428500d}.alert-row strong,.alert-row span,.alert-row time{display:block}.alert-row strong{font-size:.82rem}.alert-row span,.alert-row time{color:var(--muted);font-size:.72rem}.peak-list{display:grid;gap:8px;padding:2px 2px 0}.peak-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}.peak-row:last-child{border-bottom:none}.peak-row strong,.peak-row span{display:block}.peak-row strong{color:var(--text);font-size:.82rem}.peak-row span{color:var(--muted);font-size:.72rem}.peak-row em,.lane-card em{padding:3px 7px;border-radius:999px;font-size:.64rem;font-style:normal;font-weight:800}.peak-row em.good,.lane-card em.good{color:#0f6b34;background:var(--good-soft)}.peak-row em.warn,.lane-card em.warn{color:#9a4b00;background:var(--warn-soft)}.incident-summary-inline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px 10px 0}.incident-inline-status{margin:0;padding:8px 12px;color:#9f1239;background:linear-gradient(90deg,#fff0f0f2,#fff7edf2);border:1px solid #ffc9c9;border-radius:12px;box-shadow:0 8px 18px #dc262614;font-size:.9rem;font-weight:700;width:max-content}.incident-inline-status strong{color:#7f1d1d;font-size:1rem}.incident-inline-status span{color:#b91c1c}.incident-summary-chip{display:grid;gap:2px;padding:10px;background:#ffffffdb;border:1px solid var(--line);border-radius:14px;box-shadow:0 8px 18px #1428500f}.incident-summary-chip strong{color:var(--text);font-size:1.2rem}.incident-summary-chip span{color:var(--muted);font-size:.72rem}.incident-summary-chip.danger{border-color:#ffc9c9;background:linear-gradient(180deg,#fffffff5,#fff4f4f0)}.incident-summary-chip.good{border-color:#bee8ca;background:linear-gradient(180deg,#fffffff5,#ecfdf5f0)}.incident-list{padding-top:0}.incident-card{display:grid;grid-template-columns:92px minmax(0,1fr);gap:10px;padding:8px;background:#fff;border:1px solid var(--line);border-radius:7px;transition:transform .2s ease,box-shadow .2s ease}.incident-card:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 12px 24px #14285014}.incident-thumb{position:relative;min-height:68px;overflow:hidden;background:#080909;border-radius:6px}.incident-thumb canvas{display:block;width:100%;height:100%}.incident-meta{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:6px}.incident-meta span:last-child{color:var(--muted);font-size:.68rem;font-weight:760}.incident-card h3{margin:0 0 4px;font-size:.84rem}.incident-card p{margin:0;color:var(--muted);font-size:.72rem}.incident-view-button,.incident-viewer-close{margin-top:10px;min-height:34px;padding:0 12px;color:#0f3d67;background:linear-gradient(90deg,#e6f1fff5,#f0f7fff5);border:1px solid #b9d3ef;border-radius:999px;font-size:.72rem;font-weight:800;cursor:pointer}.incident-viewer-backdrop{position:fixed;inset:0;z-index:40;display:flex;align-items:center;justify-content:center;padding:20px;background:#070c14b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.incident-viewer{width:min(920px,100%);max-height:90vh;overflow:auto;background:linear-gradient(180deg,#fafcfffa,#ecf2faf5);border:1px solid rgba(185,211,239,.9);border-radius:24px;box-shadow:0 30px 90px #00000047}.incident-viewer-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:18px 20px 10px}.incident-viewer-header strong,.incident-viewer-header span{display:block}.incident-viewer-header strong{font-size:1rem}.incident-viewer-header span{margin-top:4px;color:var(--muted);font-size:.74rem}.incident-viewer-body{display:grid;gap:16px;padding:0 20px 20px}.incident-viewer-video,.incident-viewer-image{width:100%;border:1px solid rgba(185,211,239,.9);border-radius:18px;background:#000}.lane-grid,.report-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:10px}.lane-card,.report-card{padding:10px;box-shadow:none}.report-grid .report-card:nth-child(1){background:linear-gradient(180deg,#fffffff5,#f2f5fdf5);border-color:var(--line);border-top:4px solid var(--primary)}.report-grid .report-card:nth-child(2){background:linear-gradient(180deg,#fffffff5,#fff3e8f0);border-color:var(--line);border-top:4px solid var(--warn)}.report-grid .report-card:nth-child(3){background:linear-gradient(180deg,#fffffff5,#fff0f0f0);border-color:var(--line);border-top:4px solid var(--danger)}.report-grid .report-card:nth-child(4){background:linear-gradient(180deg,#fffffff5,#eaf7eff0);border-color:var(--line);border-top:4px solid var(--good)}.lane-card strong,.lane-card span,.lane-card em{display:block}.lane-card strong{font-size:.84rem}.lane-card span,.report-card p{margin:5px 0 8px;color:var(--muted);font-size:.72rem}.report-card strong{font-size:1.35rem}.settings-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:9px 10px;background:linear-gradient(90deg,#fffffffa,#f2f5fdf0);border:1px solid var(--line);border-radius:7px}.settings-list .settings-row:nth-child(1){border-left:4px solid var(--primary)}.settings-list .settings-row:nth-child(2){border-left:4px solid var(--good)}.settings-list .settings-row:nth-child(3){border-left:4px solid var(--danger)}.settings-list .settings-row:nth-child(4){border-left:4px solid var(--warn)}.settings-list .settings-row:nth-child(5){border-left:4px solid var(--primary)}.settings-row strong,.settings-row span{display:block}.settings-row strong{font-size:.84rem}.settings-row span{margin-top:2px;color:var(--muted);font-size:.72rem}.settings-row em{padding:4px 8px;color:var(--primary);background:linear-gradient(90deg,#e7edfef2,#f2f5fdf2);border-radius:999px;font-size:.68rem;font-style:normal;font-weight:800;white-space:nowrap}.settings-primary-button,.settings-secondary-button,.settings-danger-button,.settings-chip,.settings-camera-item{border:1px solid var(--line);border-radius:14px;font-weight:800;cursor:pointer}.settings-primary-button,.settings-secondary-button,.settings-danger-button{min-height:40px;padding:0 14px}.settings-primary-button{color:#fff;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);border-color:transparent}.settings-secondary-button{color:var(--text);background:#fff}.settings-danger-button{color:#991b1b;background:#fff5f5;border-color:#fecaca}@media(max-width:1300px){.kpi-strip{grid-template-columns:repeat(4,minmax(120px,1fr))}.lane-grid,.report-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){.kpi-strip,.incident-summary-inline,.lane-grid,.report-grid,.alert-row,.incident-card{grid-template-columns:1fr}}.login-shell{min-height:100vh;display:grid;align-items:center;padding:24px;background:radial-gradient(circle at top left,rgba(53,102,232,.2),transparent 24%),radial-gradient(circle at bottom right,rgba(255,138,42,.16),transparent 28%),linear-gradient(135deg,#edf3ff,#f7f8fc 46%,#eef2ff)}.login-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(340px,.72fr);gap:20px;align-items:stretch;width:min(1320px,100%);margin:0 auto}.login-showcase{display:grid;align-content:start;gap:14px;padding:20px 22px;color:var(--text);background:linear-gradient(145deg,#ffffffe0,#f2f5fdd1),linear-gradient(180deg,#3566e80a,#ff8a2a0d);border:1px solid var(--line);border-radius:28px;box-shadow:0 24px 48px #1428501a}.login-showcase-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.login-wordmark{width:220px;max-width:100%;object-fit:contain}.login-tag{padding:8px 12px;color:var(--primary);background:#e7edfef2;border:1px solid var(--line);border-radius:999px;font-size:.72rem;font-weight:800;text-transform:uppercase}.login-hero-copy h1{max-width:none;margin-bottom:8px;font-size:clamp(1.35rem,2vw,1.85rem);line-height:.98;white-space:nowrap}.login-card{display:grid;align-content:start;padding:28px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:24px;box-shadow:0 18px 40px #12181f1f}.login-card-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}.login-card-head h2{font-size:1.35rem}.login-eyebrow{display:inline-block;margin-bottom:4px;color:var(--primary);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.login-logo{width:72px;height:72px;object-fit:contain;margin-bottom:10px}.login-subtitle{margin:0;color:var(--muted);max-width:48ch;font-size:.88rem;line-height:1.45}.login-form{display:grid;gap:12px}.login-form label{display:grid;gap:6px;color:#334155;font-size:.88rem;font-weight:700}.login-form input{width:100%;padding:10px 12px;color:#0f172a;background:#e7edfe;border:1px solid transparent;border-radius:14px}.login-form input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #3566e826;outline:none}.login-button{margin-top:4px;padding:10px 12px;color:#fff;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);border-radius:14px;font-weight:800;cursor:pointer;box-shadow:0 12px 24px #3566e838;transition:transform .16s ease,box-shadow .16s ease}.login-button:hover{transform:translateY(-1px);box-shadow:0 14px 28px #3566e84d}.login-error{color:#b91c1c;font-size:.86rem;font-weight:700}.login-demo-note{display:grid;gap:4px;margin-top:16px;padding:12px 14px;background:#f2f5fdf2;border:1px solid var(--line);border-radius:16px}.login-demo-note strong{font-size:.84rem}.login-demo-note span{color:var(--muted);font-size:.8rem}.login-kpi-preview{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.login-kpi-tile{min-height:108px;padding:14px;background:#ffffffd1;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 24px #1428500f}.login-kpi-tile span,.login-kpi-tile em{display:block}.login-kpi-tile span{color:var(--muted);font-size:.68rem;font-weight:800;text-transform:uppercase}.login-kpi-tile strong{display:block;margin:8px 0 6px;font-size:1.6rem;line-height:1}.login-kpi-tile em{color:var(--muted);font-size:.76rem;font-style:normal}.login-kpi-tile.good{border-bottom:4px solid var(--good)}.login-kpi-tile.warn{border-bottom:4px solid var(--warn)}.login-kpi-tile.danger{border-bottom:4px solid var(--danger)}.login-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.login-footer-note{margin-top:auto;align-items:baseline;justify-content:center;gap:8px;display:flex;padding-top:8px;border-top:1px solid rgba(215,224,254,.75)}.login-footer-note span{color:var(--muted);font-size:.72rem;font-weight:700;line-height:1;text-transform:uppercase}.login-footer-note strong{color:#f17c01;font-size:1rem;line-height:1}.login-footer-note p{margin:6px 0 0;color:var(--muted);font-size:.72rem;line-height:1.5}.login-feature-box{display:flex;flex-direction:column;padding:10px 11px;background:#ffffffd1;border:1px solid var(--line);border-radius:16px;box-shadow:0 8px 18px #1428500d;min-height:170px}.login-feature-box strong{display:block;margin-bottom:4px;font-size:.88rem}.login-feature-points{margin:0;padding-left:18px;color:var(--muted);font-size:.8rem;line-height:1.45}.login-feature-points li+li{margin-top:4px}.login-feature-points li::marker{color:var(--primary)}.login-feature-meta{display:inline-flex;align-items:center;width:max-content;margin-top:auto;padding:5px 9px;color:var(--primary);background:#e7edfef2;border:1px solid var(--line);border-radius:999px;font-size:.68rem;font-weight:800;text-transform:uppercase}.tab-panel{display:grid;gap:12px}.panel-inline-status{display:inline-flex;align-items:center;width:max-content;padding:7px 11px;color:#1d4ed8;background:#dbeafeeb;border:1px solid rgba(147,197,253,.8);border-radius:999px;font-size:.74rem;font-weight:800}.settings-admin-page{align-content:start}.wizard-steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:14px}.wizard-step{display:flex;align-items:center;gap:10px;padding:12px;background:#f4f7fcf5;border:1px solid var(--line);border-radius:16px;color:var(--muted)}.wizard-step.active{border-color:#3566e859;box-shadow:0 12px 24px #3566e81f;color:var(--text)}.wizard-step.complete{background:#ebf8eff5;border-color:#22c55e4d;color:#14532d}.wizard-step-index{display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:#fff;border:1px solid currentColor;font-size:.8rem;font-weight:800}.wizard-shell{display:grid;grid-template-columns:minmax(0,1.2fr) 280px;gap:14px;align-items:start}.wizard-main,.wizard-summary{display:grid;gap:12px;align-content:start}.wizard-action-row{display:flex;flex-wrap:wrap;gap:8px}.wizard-summary-list{display:grid;gap:10px}.wizard-summary-list div{display:grid;gap:3px}.wizard-summary-list span{color:var(--muted);font-size:.82rem}.wizard-preview-shell{position:relative;min-height:360px;overflow:hidden;background:linear-gradient(135deg,#101828fa,#0b1018fa),repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 12px,transparent 12px 24px);border:1px solid rgba(148,163,184,.18);border-radius:20px}.wizard-preview-media{display:block;width:100%;height:100%;min-height:360px;object-fit:contain;background:#050606}.wizard-preview-empty{min-height:360px;display:grid;place-items:center;padding:24px;text-align:center;color:var(--muted)}.wizard-preview-empty p{margin:0;max-width:28rem}.wizard-preview-meta{display:grid;gap:8px}.wizard-preview-meta p{margin:0;color:var(--muted);font-size:.82rem}.wizard-zone-shell{align-items:start}.wizard-nav{display:flex;justify-content:space-between;gap:12px;margin-top:14px;align-items:center}.settings-admin-grid{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(0,1.15fr);gap:14px;padding:12px}.settings-admin-column{display:grid;gap:12px}.settings-admin-wide{align-content:start}.settings-card-block,.settings-card-subsection{display:grid;gap:10px;padding:12px;background:#ffffffb8;border:1px solid var(--line);border-radius:18px}.settings-card-block h3,.settings-card-subsection h4{margin:0}.settings-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-section-head h3{line-height:1.1}.settings-inline-actions,.settings-chip-row,.settings-form-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:end}.settings-form{display:grid;gap:10px}.settings-form label,.settings-toggle{display:grid;gap:6px;color:var(--text);font-size:.82rem;font-weight:700}.settings-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-form-span-2{grid-column:1 / -1}.settings-form input,.settings-form select,.settings-card-subsection input{width:100%;min-height:40px;padding:0 12px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:12px}.settings-toggle{grid-template-columns:auto 1fr;align-items:center}.settings-toggle input{width:16px;height:16px;min-height:16px;margin:0}.settings-chip{min-height:34px;padding:0 12px;color:var(--muted);background:#fff}.settings-chip.active{color:#fff;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);border-color:transparent}.settings-camera-list,.settings-zone-list{display:grid;gap:8px}.settings-camera-item,.settings-zone-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;color:var(--text);background:#fff;text-align:left}.settings-camera-item strong,.settings-zone-item strong,.settings-camera-item span,.settings-zone-item span{display:block}.settings-camera-item span,.settings-zone-item span,.settings-points-label,.settings-empty-state,.settings-admin-busy,.settings-admin-error{color:var(--muted);font-size:.76rem}.settings-camera-item.active{border-color:var(--primary);box-shadow:0 10px 22px #3566e81f}.settings-camera-item.source-active{border-left:4px solid #15803d;background:linear-gradient(90deg,#16a34a14,#fff 28%)}.settings-camera-item.source-configured{border-left:4px solid #d97706;background:linear-gradient(90deg,#f59e0b14,#fff 28%)}.settings-camera-item.source-discovered{border-left:4px solid #2563eb;background:linear-gradient(90deg,#2563eb14,#fff 28%)}.settings-editor-shell{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:12px}.settings-editor-canvas{position:relative;overflow:hidden;background:#050606;border:1px solid var(--line);border-radius:18px}.settings-editor-canvas img,.settings-editor-overlay{display:block;width:100%}.settings-editor-overlay{position:absolute;inset:0;height:100%;cursor:crosshair;touch-action:none}.settings-editor-polygon{fill:#3566e826;stroke:#3566e8e6;stroke-width:4}.settings-editor-polygon.danger{fill:#dc26262e;stroke:#dc2626f5}.settings-editor-polygon.draft{stroke-dasharray:14 10}.settings-editor-line{stroke:#22c55ef2;stroke-width:5;stroke-linecap:round}.settings-editor-point{fill:#fff;stroke:#3566e8eb;stroke-width:3}.settings-editor-point.line{stroke:#22c55ef2}.settings-line-label{font-size:28px;font-weight:800;text-anchor:middle;paint-order:stroke;stroke:#050606eb;stroke-width:8px}.settings-line-label.positive{fill:#bbf7d0}.settings-line-label.negative{fill:#bfdbfe}.settings-editor-sidebar{display:grid;gap:12px}.settings-side-toggle-group{display:grid;gap:8px}.settings-side-toggle-group>span{color:var(--text);font-size:.78rem;font-weight:800;text-transform:uppercase}.wizard-nav .settings-primary-button,.wizard-nav .settings-secondary-button,.settings-form-actions .settings-primary-button{min-width:136px;justify-content:center}.settings-zone-item{border:1px solid var(--line);border-radius:14px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.7fr);gap:12px}.dashboard-priority-grid{grid-template-columns:1fr}.priority-summary-panel .summary-stack{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.crowd-people-strip{grid-template-columns:repeat(4,minmax(0,1fr))}.three-grid.inside,.four-grid{margin:0;padding:10px}.four-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.history-summary-grid .mini-panel{min-height:92px}.history-controls{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px 12px;margin-top:2px}.history-chip{padding:7px 10px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--line);border-radius:999px;font-size:.72rem;font-weight:800;cursor:pointer}.history-chip.active{color:#fff;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);border-color:transparent}.analytics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.cameras-page-shell{height:calc(100vh - 96px);min-height:0}.camera-monitor-panel{display:flex;flex-direction:column;height:100%;min-height:0}.camera-header-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-bottom:10px}.camera-nav{display:flex;align-items:center;gap:8px}.camera-nav-btn{border:1px solid #2b3540;background:#111827;color:#f8fafc;border-radius:999px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer}.camera-nav-btn:disabled{opacity:.45;cursor:not-allowed}.camera-page-label{color:#cbd5e1;font-size:.82rem;font-weight:700}.camera-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:12px;flex:1 1 auto;min-height:0;width:100%}.camera-card{position:relative;overflow:hidden;width:100%;height:100%;min-height:0;background:#080909;border:1px solid #cfd4da;border-radius:10px}.camera-card.active{border-color:var(--warn)}.feed-frame{width:100%;height:100%}.feed-canvas{display:block;width:100%;height:100%;min-height:0;object-fit:cover}.feed-canvas-contain{object-fit:contain;background:#050606}.camera-feed-fallback{display:grid;place-items:center;color:#ffffffb8;font-weight:700}.feed-top,.feed-bottom,.occupancy-pill,.bbox,.danger-zone{position:absolute;z-index:5}.feed-top{top:7px;left:7px;right:7px;display:flex;justify-content:space-between;gap:8px}.feed-top strong,.feed-top span{display:block}.feed-top strong{color:#fff;font-size:.75rem}.feed-top span{color:#ffffffb8;font-size:.65rem}.feed-bottom{left:7px;bottom:7px;color:#ffffffc2;font-size:.64rem;font-weight:800;text-transform:uppercase}.feed-status-pill{position:absolute;top:10px;right:10px;z-index:6;padding:5px 9px;border-radius:999px;font-size:.64rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.feed-status-pill.live{color:#14532d;background:#bbf7d0f0}.feed-status-pill.snapshot{color:#7c2d12;background:#fed7aaf0}.feed-status-pill.offline{color:#991b1b;background:#fecacaf0}.feed-status-pill.loading{color:#1d4ed8;background:#bfdbfef0}.occupancy-pill{right:7px;bottom:7px;min-width:42px;padding:4px 7px;color:#111827;background:#ffffffdb;border-radius:999px;font-size:.72rem;font-weight:850;text-align:center}.bbox{border:2px solid #22c55e;background:#22c55e0f}.bbox.vehicle{border-color:var(--warn);background:#f9731614}.bbox.critical{border-color:var(--danger);background:#dc26261a}.bbox span{position:absolute;top:-20px;left:-2px;padding:2px 5px;color:#052e16;background:#86efac;font-size:.58rem;font-weight:850;white-space:nowrap}.bbox.vehicle span{color:#431407;background:#fdba74}.bbox.critical span{color:#fff;background:var(--danger)}.danger-zone{left:6%;bottom:11%;width:88%;height:24%;border:1px dashed rgba(220,38,38,.88);background:#dc26261f;transform:skew(-10deg)}.danger-zone span{position:absolute;top:6px;left:8px;padding:3px 6px;color:#fff;background:var(--danger);font-size:.56rem;font-weight:850}.facility-map{position:relative;min-height:430px;margin:10px;overflow:hidden;background:linear-gradient(90deg,#edf0f2 1px,transparent 1px),linear-gradient(180deg,#edf0f2 1px,transparent 1px),#fbfcfd;background-size:28px 28px;border:1px solid var(--line);border-radius:7px}.facility-map.compact{min-height:360px}.map-room,.restricted-zone{position:absolute;display:grid;place-items:center;padding:7px;color:#4b5563;background:#ffffffb8;border:1px solid var(--line-strong);border-radius:6px;font-size:.66rem;font-weight:800;text-align:center;text-transform:uppercase}.room-lobby{left:22%;top:18%;width:34%;height:28%}.room-gate{left:5%;top:15%;width:19%;height:28%}.room-loading{right:6%;top:24%;width:25%;height:26%}.room-parking{left:8%;bottom:12%;width:47%;height:23%}.restricted-zone{color:#991b1b;background:repeating-linear-gradient(135deg,#dc262624 0 8px,#ffffff9e 8px 16px);border-color:#f8a9a9}.restricted-one{right:8%;top:55%;width:28%;height:20%}.restricted-two{right:30%;top:6%;width:20%;height:12%}.camera-pin{position:absolute;z-index:4;min-width:52px;min-height:22px;display:grid;place-items:center;color:#0f6b34;background:var(--good-soft);border:1px solid #9bd9ad;border-radius:999px;font-size:.58rem;font-weight:850}.camera-pin.warning{color:#9a4b00;background:var(--warn-soft);border-color:#fed7aa}.camera-pin.danger{color:#991b1b;background:var(--danger-soft);border-color:#ffc9c9}.density-node,.alert-marker{position:absolute;z-index:3;border-radius:50%;transform:translate(-50%,-50%)}.density-node{width:44px;height:44px;background:#15994726;border:1px solid rgba(21,153,71,.35)}.density-node.medium{width:64px;height:64px;background:#f9731626;border-color:#f9731659}.density-node.high{width:82px;height:82px;background:#dc262624;border-color:#dc262657}.alert-marker{width:14px;height:14px;background:var(--danger);box-shadow:0 0 0 7px #dc262621}@media(max-width:1300px){.camera-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}}@media(max-width:1050px){.wizard-steps,.settings-admin-grid,.wizard-shell,.settings-editor-shell,.login-layout,.dashboard-grid,.analytics-grid{grid-template-columns:1fr}.login-hero-copy h1{white-space:normal}.login-feature-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:760px){.login-shell{padding:14px}.settings-form-grid{grid-template-columns:1fr}.login-layout{gap:14px;min-height:auto}.login-showcase,.login-card{padding:20px}.login-showcase-head{grid-template-columns:1fr;display:grid}.login-feature-grid,.camera-grid,.three-grid,.crowd-people-strip{grid-template-columns:1fr}.facility-map{min-height:320px}}
