:root{--color-bg:#f5f6f1;--color-surface:#fff;--color-surface-muted:#f2f5f2;--color-surface-subtle:#f7f9f7;--color-border:#d9dfd9;--color-border-soft:#edf0ed;--color-text:#182321;--color-text-strong:#12312f;--color-text-muted:#66716e;--color-text-soft:#56625f;--color-primary:#d94f30;--color-primary-strong:#a83f27;--color-secondary:#163f3b;--color-secondary-soft:#e8eeea;--color-success-bg:#e8f4ee;--color-success-text:#276348;--color-warning-bg:#fff0d9;--color-warning-text:#855611;--color-danger-bg:#fde5df;--color-danger-text:#9c341f;--color-danger-action:#b83a26;--color-info-bg:#e7edf5;--color-info-text:#2b506f;--color-neutral-bg:#eceff1;--color-neutral-text:#5f6966;--color-sidebar:#12312f;--color-sidebar-hover:#1f4b46;--color-sidebar-panel:#1a403c;--color-sidebar-border:#2c5b55;--shadow-popover:0 16px 48px #12312f29;color:var(--color-text);background:var(--color-bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}[data-theme=dark]{--color-bg:#111817;--color-surface:#182321;--color-surface-muted:#22302d;--color-surface-subtle:#1d2927;--color-border:#33413e;--color-border-soft:#2a3633;--color-text:#e9f0ed;--color-text-strong:#f7fbf9;--color-text-muted:#a9b7b3;--color-text-soft:#c0ccc8;--color-primary:#f06b4a;--color-primary-strong:#ff8a6d;--color-secondary:#8fcac0;--color-secondary-soft:#263936;--color-success-bg:#203a31;--color-success-text:#9bd7b9;--color-warning-bg:#3a2d19;--color-warning-text:#f2c078;--color-danger-bg:#3f231e;--color-danger-text:#ffac9a;--color-danger-action:#f06b4a;--color-info-bg:#234;--color-info-text:#a9c8eb;--color-neutral-bg:#28302e;--color-neutral-text:#c1cbc7;--color-sidebar:#0d1413;--color-sidebar-hover:#1f3733;--color-sidebar-panel:#172523;--color-sidebar-border:#304541;--shadow-popover:0 18px 54px #00000057}*{box-sizing:border-box}body{background:var(--color-bg);color:var(--color-text);margin:0}button{cursor:pointer;font:inherit;border:0;border-radius:8px}button:disabled{cursor:not-allowed;opacity:.55}button:focus-visible,select:focus-visible,input:focus-visible,a:focus-visible{outline:3px solid color-mix(in srgb, var(--color-primary) 70%, transparent);outline-offset:2px}select,input,textarea{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);font:inherit;border-radius:8px;min-height:40px;padding:0 10px}textarea{resize:vertical;min-height:96px;padding:10px}.access-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.access-panel{background:#fff;border:1px solid #d9dfd9;border-radius:8px;align-items:center;gap:16px;width:100%;max-width:520px;padding:22px;display:flex}.access-panel svg{color:#d94f30}.access-panel h1,.access-panel p{margin:0}.login-panel{background:#fff;border:1px solid #d9dfd9;border-radius:8px;gap:22px;width:100%;max-width:460px;padding:24px;display:grid;box-shadow:0 20px 70px #12312f1f}.login-brand{align-items:center;gap:14px;display:flex}.login-brand h1,.login-brand p{margin:0}.auth-form{gap:14px;display:grid}.auth-form label{color:#44504d;gap:7px;font-size:14px;font-weight:650;display:grid}.auth-form label>span{border:1px solid #cbd6d1;border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:8px;padding:0 12px;display:grid}.auth-form label>span svg{color:#66716e}.auth-form input{border:0;outline:0;min-height:44px;padding:0}.primary-button{color:#fff;background:#d94f30;justify-content:center;align-items:center;gap:8px;min-height:46px;padding:0 16px;font-weight:750;display:inline-flex}.text-button{color:#163f3b;background:0 0;min-height:38px;font-weight:650}.auth-message{background:var(--color-warning-bg);color:var(--color-warning-text);border-radius:8px;margin:0;padding:10px 12px;font-size:14px}.demo-users{border-top:1px solid #edf0ed;gap:8px;padding-top:16px;display:grid}.demo-users span{color:#66716e;font-size:13px;font-weight:650}.demo-users button{color:var(--color-text);text-align:left;background:#f2f5f2;min-height:36px;padding:8px 10px}.portal-layout{grid-template-columns:260px minmax(0,1fr);min-height:100vh;display:grid}.portal-layout.sidebar-collapsed{grid-template-columns:82px minmax(0,1fr)}.sidebar{color:#fff;background:#12312f;grid-template-rows:auto 1fr auto;align-content:start;gap:12px;min-height:100vh;padding:12px;transition:width .16s;display:grid;position:sticky;top:0}.sidebar-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.brand-block{align-items:center;gap:9px;min-width:0;display:flex}.brand-mark{background:#d94f30;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:17px;font-weight:750;display:inline-flex}.brand-block div:last-child,.sidebar-footer div{gap:2px;min-width:0;display:grid}.brand-block span,.sidebar-footer span{color:#b8c7c2;font-size:12px}.sidebar-collapse-button{color:#fff;background:#1a403c;border:1px solid #2c5b55;flex:none;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.side-nav{align-content:start;gap:2px;display:grid}.side-nav a{color:#dce6e2;text-align:left;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:8px;height:28px;padding:5px 8px;font-size:14px;line-height:1;text-decoration:none;display:flex}.portal-layout.sidebar-collapsed .brand-block div:last-child,.portal-layout.sidebar-collapsed .side-nav span,.portal-layout.sidebar-collapsed .sidebar-footer div{display:none}.portal-layout.sidebar-collapsed .sidebar-header{justify-items:center;gap:8px;display:grid}.portal-layout.sidebar-collapsed .brand-block,.portal-layout.sidebar-collapsed .side-nav a,.portal-layout.sidebar-collapsed .sidebar-footer{justify-content:center}.portal-layout.sidebar-collapsed .side-nav a,.portal-layout.sidebar-collapsed .sidebar-footer{width:34px;padding-left:0;padding-right:0}.portal-layout.sidebar-collapsed .side-nav{justify-items:center}.side-nav a:hover,.side-nav a.active{color:#fff;background:#1f4b46}.side-nav a[aria-disabled=true]{color:#7e928d;cursor:not-allowed;opacity:1}.sidebar-footer{background:#1a403c;border:1px solid #2c5b55;border-radius:8px;align-items:center;gap:8px;padding:7px 8px;display:flex}.portal-content{grid-auto-rows:max-content;gap:24px;min-width:0;padding:28px;display:grid}.portal-topbar{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;min-height:76px;display:grid}.portal-topbar h1{color:#12312f;margin:0;font-size:32px;line-height:1.1}.portal-topbar p{color:#56625f;margin:8px 0 0}.eyebrow{color:#a83f27;letter-spacing:0;text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:700}.icon-button{color:#fff;background:#d94f30;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex}.icon-button.secondary{color:#163f3b;background:#e8eeea}.user-menu{position:relative}.user-menu-trigger{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);align-items:center;gap:12px;min-height:52px;padding:8px 10px;display:flex}.avatar{color:#fff;background:#d94f30;border-radius:999px;justify-content:center;align-items:center;width:34px;height:34px;font-weight:700;display:inline-flex}.user-menu-trigger span:last-child{text-align:left;gap:2px;display:grid}.user-menu-trigger small{color:#66716e;font-size:13px}.user-dropdown{z-index:20;background:#fff;border:1px solid #d9dfd9;border-radius:8px;gap:8px;min-width:280px;padding:10px;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 16px 48px #12312f29}.user-dropdown-header{border-bottom:1px solid #edf0ed;gap:4px;padding:8px 8px 12px;display:grid}.user-dropdown-header span,.user-dropdown label{color:#66716e;font-size:13px}.user-dropdown label{gap:6px;padding:4px 8px;display:grid}.theme-switch-row{color:var(--color-text-muted);justify-content:space-between;align-items:center;padding:4px 8px;font-size:13px;display:flex}.theme-switch{background:var(--color-border);border-radius:999px;align-items:center;width:44px;height:24px;padding:2px;display:inline-flex}.theme-switch span{background:var(--color-surface);border-radius:999px;width:20px;height:20px;transition:transform .16s;display:block;transform:translate(0);box-shadow:0 1px 4px #0000002e}.theme-switch[aria-checked=true]{background:var(--color-primary)}.theme-switch[aria-checked=true] span{transform:translate(20px)}.user-dropdown button{color:var(--color-text);text-align:left;background:0 0;align-items:center;gap:8px;min-height:38px;padding:8px;display:flex}.user-dropdown button:hover{background:#f2f5f2}.user-dropdown .theme-switch{background:var(--color-border);border-radius:999px;align-items:center;gap:0;width:44px;height:24px;min-height:24px;padding:2px;display:inline-flex}.user-dropdown .theme-switch:hover{background:var(--color-border)}.user-dropdown .theme-switch[aria-checked=true],.user-dropdown .theme-switch[aria-checked=true]:hover{background:var(--color-primary)}.user-dropdown .theme-switch span{background:var(--color-surface);border-radius:999px;width:20px;height:20px;transition:transform .16s;display:block;transform:translate(0);box-shadow:0 1px 4px #0000002e}.user-dropdown .theme-switch[aria-checked=true] span{transform:translate(20px)}.module-strip{background:#fff;border:1px solid #d9dfd9;border-radius:8px;justify-content:space-between;align-items:center;min-height:48px;padding:10px 14px;display:flex}.module-strip span{color:#163f3b;font-weight:650}.module-strip strong{color:#66716e;font-size:14px}.metrics{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.metrics article{background:#fff;border:1px solid #d9dfd9;border-radius:8px;align-items:center;gap:6px;min-height:118px;padding:18px;display:grid}.metrics svg{color:#d94f30}.metrics strong{color:#132d2a;font-size:28px;font-weight:650}.metrics span{color:#56625f}.panel{background:#fff;border:1px solid #d9dfd9;border-radius:8px;overflow:hidden}.panel-header{border-bottom:1px solid #d9dfd9;justify-content:space-between;align-items:center;gap:14px;min-height:82px;padding:18px;display:flex}.panel-header.compact{align-items:center}.panel-header h2{margin:0;font-size:18px;font-weight:650}.panel-header p{color:#66716e;margin:6px 0 0}.workspace{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:18px;display:grid}.single-column{gap:18px;display:grid}.secondary-workspace{grid-template-columns:360px minmax(0,1fr);align-items:stretch}.events-workspace{grid-template-columns:minmax(0,1fr) 420px;align-items:start;gap:18px;display:grid}.reports-panel,.device-panel{min-width:0}.segmented-control{background:#eef2ee;border:1px solid #d9dfd9;border-radius:8px;gap:4px;padding:4px;display:flex}.segmented-control button{color:#44504d;white-space:nowrap;background:0 0;min-height:36px;padding:8px 10px;font-size:14px;font-weight:600}.segmented-control button.active{color:#fff;background:#163f3b}.report-list{display:grid}.report-row{border-bottom:1px solid #edf0ed;grid-template-columns:1fr .8fr .7fr 1.3fr auto;align-items:start;gap:14px;padding:16px 18px;display:grid}.report-row:last-child{border-bottom:0}.report-row div{gap:4px;display:grid}.report-row strong,.device-row strong,.user-row strong,.settings-list strong,.detail-grid strong,.module-strip span{font-weight:650}.report-row span{color:#66716e}.source-badge{border-radius:999px;width:fit-content;padding:7px 9px;font-size:12px;font-weight:800;line-height:1;display:inline-flex}.android-source{color:#087443;background:#ecfdf3}.status-badge,.priority,.device-status{border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:7px 9px;font-size:13px;font-weight:650;line-height:1;display:inline-flex}.status-safe{background:var(--color-success-bg);color:var(--color-success-text)}.status-injured{background:var(--color-warning-bg);color:var(--color-warning-text)}.status-trapped,.status-urgent{background:var(--color-danger-bg);color:var(--color-danger-text)}.priority-low,.priority-medium{background:var(--color-info-bg);color:var(--color-info-text)}.priority-high{background:var(--color-warning-bg);color:var(--color-warning-text)}.priority-critical{background:var(--color-danger-bg);color:var(--color-danger-text)}.device-list{display:grid}.device-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding:18px;display:grid}.device-grid .device-row{border:1px solid #edf0ed;border-radius:8px}.device-row{border-bottom:1px solid #edf0ed;gap:12px;padding:16px 18px;display:grid}.device-row:last-child{border-bottom:0}.device-row div:first-child{gap:4px;display:grid}.device-row span{color:#66716e}.device-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.device-online{background:var(--color-success-bg);color:var(--color-success-text)}.device-degraded{background:var(--color-warning-bg);color:var(--color-warning-text)}.device-offline{background:var(--color-neutral-bg);color:var(--color-neutral-text)}.battery-line{grid-template-columns:1fr auto;align-items:center;gap:10px;display:grid}.battery-line>div{background:#e5ebe7;border-radius:999px;height:10px;overflow:hidden}.battery-line>div>span{background:#d94f30;height:100%;display:block}.permission-list{flex-wrap:wrap;gap:8px;padding:18px;display:flex}.permission-list span,.role-badge{background:var(--color-success-bg);color:var(--color-success-text);border-radius:999px;width:fit-content;padding:8px 10px;font-size:13px;font-weight:650}.role-admin{background:var(--color-danger-bg);color:var(--color-danger-text)}.role-operator{background:var(--color-warning-bg);color:var(--color-warning-text)}.role-viewer{background:var(--color-info-bg);color:var(--color-info-text)}.role-family{background:var(--color-neutral-bg);color:var(--color-neutral-text)}.user-list{display:grid}.user-row{border-bottom:1px solid #edf0ed;grid-template-columns:1fr 1fr .7fr auto;align-items:center;gap:14px;padding:16px 18px;display:grid}.user-row:last-child{border-bottom:0}.user-row div{gap:5px;display:grid}.user-row span{color:#66716e}.empty-state{color:#66716e;text-align:center;place-items:center;gap:8px;padding:34px 18px;display:grid}.empty-state svg{color:#d94f30}.empty-state-danger svg{color:var(--color-danger-action)}.loading-state svg{animation:.9s linear infinite spin}.report-list>.empty-state,.device-grid>.empty-state,.device-list>.empty-state,.user-list>.empty-state{grid-column:1/-1}.row-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.row-actions button,.row-actions a,.panel-footer button{color:#fff;white-space:nowrap;background:#163f3b;justify-content:center;align-items:center;gap:6px;min-height:36px;padding:0 12px;font-weight:650;text-decoration:none;display:inline-flex}.row-action-note{background:var(--color-neutral-bg);color:var(--color-neutral-text);border-radius:999px;padding:8px 10px;font-size:13px;font-weight:650}.row-actions select{min-width:112px;min-height:36px}.row-actions input{width:76px;min-height:36px}.detail-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:18px;display:grid}.detail-grid article{background:#f7f9f7;border:1px solid #edf0ed;border-radius:8px;gap:6px;padding:12px;display:grid}.detail-grid span{color:#66716e;font-size:13px;font-weight:600}.detail-grid ul{color:var(--color-text);margin:0;padding-left:18px}.detail-grid li+li{margin-top:6px}.detail-wide{grid-column:1/-1}.detail-action-row a{background:var(--color-secondary);color:#fff;border-radius:8px;align-items:center;gap:7px;width:fit-content;min-height:38px;padding:0 12px;text-decoration:none;display:inline-flex}.map-workspace{grid-template-columns:minmax(0,1fr) 380px;align-items:start;gap:18px;display:grid}.map-panel{min-width:0}.map-summary{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.map-toolbar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.map-toolbar select{min-width:220px}.map-summary span,.location-type{border-radius:999px;padding:8px 10px;font-size:13px;font-weight:650}.map-summary span:first-child,.location-active{background:var(--color-success-bg);color:var(--color-success-text)}.map-summary span:last-child,.location-warehouse,.location-report{background:var(--color-info-bg);color:var(--color-info-text)}.location-device{background:var(--color-success-bg);color:var(--color-success-text)}.location-map{aspect-ratio:16/9;background:linear-gradient(135deg, #163f3b1a, transparent 46%), linear-gradient(45deg, #d94f301c, transparent 42%), var(--color-surface-subtle);border:1px solid var(--color-border-soft);border-radius:8px;min-height:430px;margin:18px;position:relative;overflow:hidden}.google-map-shell{background:var(--color-surface-subtle);border:1px solid var(--color-border-soft);border-radius:8px;min-height:460px;margin:18px 18px 0;position:relative;overflow:hidden}.google-map-shell iframe{border:0;width:100%;height:100%;min-height:460px;display:block;position:absolute;inset:0}.map-focus-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-popover);z-index:1;border-radius:8px;gap:7px;max-width:min(320px,100% - 36px);padding:12px;display:grid;position:absolute;top:18px;left:18px}.map-focus-card strong{color:var(--color-text-strong);font-size:20px}.map-focus-card small{color:var(--color-text-muted);font-size:13px}.map-focus-card a{background:var(--color-secondary);color:var(--color-surface);border-radius:8px;align-items:center;gap:7px;width:fit-content;min-height:34px;padding:0 10px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex}.map-legend-bar{flex-wrap:wrap;align-items:center;gap:10px;padding:14px 18px 18px;display:flex}.map-legend-bar span{background:var(--color-surface-muted);border:1px solid var(--color-border-soft);color:var(--color-text-muted);border-radius:999px;align-items:center;gap:7px;padding:8px 10px;font-size:13px;font-weight:650;display:inline-flex}.legend-dot{border-radius:999px;width:10px;height:10px;display:inline-block}.legend-online{background:#257d55}.legend-degraded{background:#c17a1e}.legend-warehouse{background:#2b506f}.legend-report{background:#d94f30}.map-grid{background-image:linear-gradient(var(--color-border-soft) 1px, transparent 1px), linear-gradient(90deg, var(--color-border-soft) 1px, transparent 1px);opacity:.72;background-size:54px 54px;position:absolute;inset:0}.map-route{transform-origin:0;background:#163f3b29;border-radius:999px;height:18px;position:absolute}.map-route-a{width:62%;top:31%;left:13%;transform:rotate(22deg)}.map-route-b{width:48%;top:70%;left:23%;transform:rotate(-28deg)}.map-place{background:var(--color-surface);border:1px solid var(--color-border-soft);color:var(--color-text-muted);border-radius:999px;padding:6px 9px;font-size:12px;font-weight:700;position:absolute}.place-coast{top:18%;left:8%}.place-city{top:72%;right:10%}.place-rural{top:54%;left:42%}.map-marker{color:#fff;z-index:2;border:3px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:48px;height:48px;padding:0;display:inline-flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 14px 28px #12312f38}.map-marker span{font-size:13px;font-weight:800}.marker-online{background:#257d55}.marker-degraded{background:#c17a1e}.marker-offline{background:#69736f}.marker-warehouse{border-color:#2b506f;outline:4px solid #2b506f29}.map-side-panel{min-width:0}.map-device-list{display:grid}.map-device-card{border-bottom:1px solid var(--color-border-soft);gap:12px;padding:16px 18px;display:grid}.map-device-card.active{background:var(--color-surface-subtle);box-shadow:inset 3px 0 0 var(--color-primary)}.map-device-card:last-child{border-bottom:0}.map-device-card>div:first-child,.map-device-card dl{gap:5px;display:grid}.map-device-main{color:var(--color-text);text-align:left;background:0 0;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;padding:0;display:grid}.map-device-main svg{color:var(--color-primary-strong)}.report-map-card .map-device-main svg{color:var(--color-danger-action)}.map-device-main span{gap:3px;display:grid}.map-device-main strong{color:var(--color-text-strong)}.map-device-main small{color:var(--color-text-muted);font-size:13px}.map-device-card span,.map-device-card dt{color:var(--color-text-muted)}.map-card-badges{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.map-device-card dl{margin:0}.map-device-card dl div{grid-template-columns:100px minmax(0,1fr);gap:8px;display:grid}.map-device-card dt{font-size:13px;font-weight:650}.map-device-card dd{color:var(--color-text);margin:0}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:80;background:#101b196b;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-panel{box-shadow:var(--shadow-popover);width:min(920px,100%);max-height:calc(100vh - 48px);overflow:auto}.modal-header{z-index:1;position:sticky;top:0}.panel-footer{border-top:1px solid #edf0ed;justify-content:flex-end;gap:8px;padding:14px 18px;display:flex}.confirm-body{align-items:center;gap:12px;padding:18px;display:flex}.confirm-body svg{color:var(--color-danger-action);flex:none}.confirm-body p{margin:0}.modal-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:18px;display:grid}.modal-form label{color:var(--color-text-soft);gap:7px;font-size:14px;font-weight:650;display:grid}.modal-form label:nth-child(3){grid-column:1/-1}.settings-list{display:grid}.settings-list article{border-bottom:1px solid #edf0ed;grid-template-columns:220px minmax(0,1fr);align-items:center;gap:8px;padding:16px 18px;display:grid}.settings-list article:last-child{border-bottom:0}.settings-list span{color:#66716e}.event-list{display:grid}.event-row{border-bottom:1px solid var(--color-border-soft);grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:14px;padding:16px 18px;display:grid}.event-row:last-child{border-bottom:0}.event-row.active{background:var(--color-surface-subtle);box-shadow:inset 3px 0 0 var(--color-primary)}.event-row>button{color:var(--color-text);text-align:left;background:0 0;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:0;display:grid}.event-row>button svg{color:var(--color-primary-strong)}.event-row>button span,.event-detail-body,.event-detail-body dl,.event-detail-body article{gap:6px;display:grid}.event-row small{color:var(--color-text-muted);font-size:13px}.event-row-meta{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.event-row-meta>span:not(.event-status){background:var(--color-surface-muted);color:var(--color-text-muted);border-radius:999px;padding:8px 10px;font-size:13px;font-weight:650}.event-status{border-radius:999px;width:fit-content;padding:8px 10px;font-size:13px;font-weight:650}.event-planned{background:var(--color-info-bg);color:var(--color-info-text)}.event-active{background:var(--color-success-bg);color:var(--color-success-text)}.event-monitoring{background:var(--color-warning-bg);color:var(--color-warning-text)}.event-closed{background:var(--color-neutral-bg);color:var(--color-neutral-text)}.event-detail-body{padding:18px}.event-detail-body dl{margin:0}.event-detail-body dl div{border-bottom:1px solid var(--color-border-soft);grid-template-columns:120px minmax(0,1fr);gap:6px;padding:10px 0;display:grid}.event-detail-body dl div:first-child{padding-top:0}.event-detail-body dt{color:var(--color-text-muted);font-size:13px;font-weight:650}.event-detail-body dd{margin:0}.event-detail-body article{background:var(--color-surface-subtle);border:1px solid var(--color-border-soft);border-radius:8px;padding:12px}.event-detail-body p{color:var(--color-text-muted);margin:0}.event-history{color:var(--color-text-muted);margin:0;padding-left:18px}.event-history li+li{margin-top:6px}.event-close-form{gap:14px;display:grid}.event-close-summary{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.event-close-summary article{background:var(--color-surface-subtle);border:1px solid var(--color-border-soft);border-radius:8px;gap:10px;padding:12px;display:grid}.close-summary-list,.close-device-list{gap:8px;display:grid}.close-summary-list>div,.close-device-list>div{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;display:flex}.close-device-list span{gap:2px;display:grid}.close-device-list small{color:var(--color-text-muted)}.event-device-stack{gap:8px;display:grid}.event-device-stack>div{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex}.event-device-stack span:first-child{gap:3px;display:grid}.event-device-stack small{color:var(--color-text-muted)}.event-form fieldset{border:1px solid var(--color-border);border-radius:8px;grid-column:1/-1;gap:10px;margin:0;padding:12px;display:grid}.event-form legend{color:var(--color-text-soft);padding:0 6px;font-size:14px;font-weight:650}.checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.checkbox-grid label{background:var(--color-surface-muted);border:1px solid var(--color-border-soft);border-radius:8px;align-items:center;gap:8px;padding:10px;display:flex}.checkbox-grid input{width:16px;min-height:16px}.form-wide{grid-column:1/-1}.login-panel,.access-panel,.metrics article,.panel,.modal-header,.module-strip,.user-menu-trigger,.user-dropdown,.map-place{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.login-panel{box-shadow:var(--shadow-popover)}.sidebar{background:var(--color-sidebar)}.sidebar-collapse-button,.sidebar-footer{background:var(--color-sidebar-panel);border-color:var(--color-sidebar-border)}.side-nav a:hover,.side-nav a.active{background:var(--color-sidebar-hover)}.brand-mark,.avatar,.primary-button,.icon-button,.battery-line>div>span{background:var(--color-primary)}.eyebrow,.metrics svg,.access-panel svg,.auth-form label>span svg,.empty-state svg{color:var(--color-primary-strong)}.portal-topbar h1,.metrics strong,.module-strip span,.topbar h1{color:var(--color-text-strong)}.portal-topbar p,.metrics span,.panel-header p,.report-row span,.device-row span,.user-row span,.settings-list span,.user-menu-trigger small,.user-dropdown-header span,.user-dropdown label,.module-strip strong,.detail-grid span,.empty-state,.map-device-card span,.map-device-card dt,.map-place{color:var(--color-text-muted)}.auth-form label,.segmented-control button,.demo-users span{color:var(--color-text-soft)}.auth-form label>span,.panel-header,.report-row,.device-row,.user-row,.settings-list article,.panel-footer,.user-dropdown-header,.demo-users,.map-device-card{border-color:var(--color-border-soft)}.auth-form label>span,.segmented-control,.demo-users button,.user-dropdown button:hover,.detail-grid article,.battery-line>div{background:var(--color-surface-muted);border-color:var(--color-border)}.detail-grid article{background:var(--color-surface-subtle)}.segmented-control button.active,.row-actions button,.row-actions a,.panel-footer button{background:var(--color-secondary);color:var(--color-surface)}.panel-footer .secondary-action{background:var(--color-surface-muted);color:var(--color-text)}.panel-footer .danger-action{background:var(--color-danger-action);color:#fff}.text-button{color:var(--color-secondary)}.icon-button.secondary{background:var(--color-secondary-soft);color:var(--color-secondary)}.user-dropdown{box-shadow:var(--shadow-popover)}.portal-error-screen{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted);text-align:center;border-radius:8px;place-items:center;gap:8px;min-height:280px;padding:34px 18px;display:grid}.portal-error-screen svg{color:var(--color-primary-strong)}.portal-error-screen h2,.portal-error-screen p{margin:0}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1180px){.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.workspace,.secondary-workspace,.events-workspace,.map-workspace{grid-template-columns:1fr}.device-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.event-close-summary{grid-template-columns:1fr}.map-side-panel{order:-1}.report-row,.event-row,.user-row{grid-template-columns:minmax(0,1fr)}.row-actions{justify-content:flex-start}}@media (width<=720px){.portal-layout,.portal-layout.sidebar-collapsed{grid-template-columns:1fr}.portal-content{padding:20px}.sidebar{width:auto;min-height:100vh;position:static}.portal-layout.sidebar-collapsed .brand-block div:last-child,.portal-layout.sidebar-collapsed .side-nav span,.portal-layout.sidebar-collapsed .sidebar-footer div{display:grid}.portal-layout.sidebar-collapsed .brand-block,.portal-layout.sidebar-collapsed .side-nav a,.portal-layout.sidebar-collapsed .sidebar-footer{justify-content:initial}.portal-topbar{grid-template-columns:minmax(0,1fr) auto;align-items:flex-start}.portal-topbar h1{font-size:26px}.user-menu{grid-column:auto;width:auto}.user-dropdown{width:100%;min-width:min(280px,100vw - 40px)}.metrics,.workspace,.secondary-workspace,.events-workspace,.map-workspace,.device-grid,.settings-list article,.report-row{grid-template-columns:1fr}.location-map{aspect-ratio:4/5;min-height:520px}.detail-grid,.modal-form{grid-template-columns:1fr}.modal-backdrop{align-items:stretch;padding:14px}.panel-header{flex-direction:column;align-items:stretch}.modal-header{flex-direction:row;align-items:center}.segmented-control{overflow-x:auto}.user-row{grid-template-columns:1fr}.event-row-meta{justify-content:flex-start}.event-detail-body dl div,.checkbox-grid{grid-template-columns:1fr}.row-actions{justify-content:flex-start}.row-actions select,.row-actions input,.row-actions button,.row-actions a{flex:150px}.map-summary{justify-content:flex-start}.map-toolbar{justify-content:stretch}.map-toolbar select{width:100%}.map-device-card dl div{grid-template-columns:1fr}}
