:root,[data-theme=default]{color:#192231;background:#f3f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--surface: #fff;--surface-soft: #f8fafc;--border: #dce4ed;--border-strong: #c4d0dc;--muted: #667488;--accent: #17657a;--accent-soft: #eaf6f9;--ok: #197a4d;--ok-soft: #e9f7ef;--warn: #9a6200;--warn-soft: #fff6e5;--danger: #b12f2f;--danger-soft: #fff1f1;--surface-glow: #f8fbff;--ink-strong: #101926;--shadow: 0 10px 28px rgb(21 34 50 / .08);--shadow-soft: 0 1px 2px rgb(21 34 50 / .05)}[data-theme=cold-storage]{background:#eef4fb;--accent: #1558a8;--accent-soft: #e2edf9;--ok: #0f6b8e;--ok-soft: #e0f2f8}[data-theme=cold-storage] body{background:#eef4fb}[data-theme=cold-storage] .login-page{background:linear-gradient(180deg,#d8e9f7,#eef4fb 44%,#f3f8fc)}[data-theme=cold-storage] .sidebar button:hover,[data-theme=cold-storage] .sidebar button.active{border-color:#b0cce8;background:var(--accent-soft);color:var(--accent)}[data-theme=food-service]{background:#faf4ef;--accent: #b85a00;--accent-soft: #fef3e8;--ok: #1a6b3a;--ok-soft: #e8f7ee}[data-theme=food-service] body{background:#faf4ef}[data-theme=food-service] .login-page{background:linear-gradient(180deg,#f5e8d8,#faf4ef 44%,#fdf8f3)}[data-theme=food-service] .sidebar button:hover,[data-theme=food-service] .sidebar button.active{border-color:#e8c8a0;background:var(--accent-soft);color:var(--accent)}[data-theme=outdoor]{background:#f0f7f0;--accent: #2a6e3a;--accent-soft: #e6f4e8;--ok: #1a6b3a;--ok-soft: #e8f7ee}[data-theme=outdoor] body{background:#f0f7f0}[data-theme=outdoor] .login-page{background:linear-gradient(180deg,#d6ecda,#f0f7f0 44%,#f5faf5)}[data-theme=outdoor] .sidebar button:hover,[data-theme=outdoor] .sidebar button.active{border-color:#b0d8b8;background:var(--accent-soft);color:var(--accent)}[data-theme=residential]{background:#f5f2f9;--accent: #6644a8;--accent-soft: #f0ecfb;--ok: #2a7a4e;--ok-soft: #e6f5ec}[data-theme=residential] body{background:#f5f2f9}[data-theme=residential] .login-page{background:linear-gradient(180deg,#e8e0f5,#f5f2f9 44%,#faf8fc)}[data-theme=residential] .sidebar button:hover,[data-theme=residential] .sidebar button.active{border-color:#c8b8e8;background:var(--accent-soft);color:var(--accent)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,color-mix(in srgb,var(--accent) 13%,transparent),transparent 32rem),linear-gradient(180deg,color-mix(in srgb,var(--surface-glow) 82%,var(--accent-soft)),#eef3f7 44rem)}button,input,select{font:inherit;touch-action:manipulation}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 22%,transparent);outline-offset:2px}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(145deg,#0a3040,#17657a 55%,#1b8099)}.marketing-page{min-height:100vh;background:#f3f6f8;color:#172231}.marketing-hero{position:relative;display:grid;align-items:center;min-height:92vh;padding:88px clamp(18px,5vw,72px) 96px;overflow:hidden;background:#0b1520;color:#fff}.marketing-hero-img,.marketing-hero-shade{position:absolute;top:0;right:0;bottom:0;left:0}.marketing-hero-img{width:100%;height:100%;object-fit:cover}.marketing-hero-shade{background:linear-gradient(90deg,#060d14eb,#08121bbd 42%,#08121b33),linear-gradient(180deg,#060d1438,#060d14e0)}.marketing-nav{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px clamp(18px,5vw,72px)}.marketing-brand,.marketing-nav nav{display:inline-flex;align-items:center;gap:10px}.marketing-brand{color:#fff;font-weight:900;text-decoration:none}.marketing-brand img{width:38px;height:38px;padding:7px;border-radius:10px;background:#ffffff1f}.marketing-nav nav{gap:8px}.marketing-nav a:not(.marketing-brand){padding:8px 10px;border:1px solid rgb(255 255 255 / .18);border-radius:999px;color:#ffffffd6;font-size:.86rem;font-weight:750;text-decoration:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.marketing-hero-content{position:relative;z-index:1;display:grid;gap:18px;max-width:760px}.marketing-hero .eyebrow{color:#76d2e7}.marketing-hero h1{margin:0;max-width:820px;color:#fff;font-size:clamp(2.55rem,7vw,5.75rem);line-height:.95}.marketing-lede{max-width:650px;margin:0;color:#f0f7fad6;font-size:1.08rem;line-height:1.6}.marketing-actions,.marketing-proof{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.marketing-cta{min-height:46px;text-decoration:none}.marketing-proof{padding-top:8px}.marketing-proof span{display:inline-flex;align-items:center;gap:7px;min-height:34px;padding:6px 10px;border:1px solid rgb(255 255 255 / .16);border-radius:999px;background:#ffffff14;color:#ffffffd6;font-size:.86rem;font-weight:750}.marketing-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;margin-top:-48px;padding:0 clamp(18px,5vw,72px);position:relative;z-index:3}.marketing-strip article{display:grid;gap:8px;min-height:124px;padding:22px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow)}.marketing-strip article:first-child{border-radius:12px 0 0 12px}.marketing-strip article:last-child{border-radius:0 12px 12px 0}.marketing-strip strong{color:var(--ink-strong);font-size:1.18rem}.marketing-strip span{color:var(--muted);line-height:1.45}.marketing-section,.login-section{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:clamp(24px,5vw,64px);align-items:center;padding:clamp(56px,8vw,96px) clamp(18px,5vw,72px)}.service-section{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);background:#101926;color:#eaf2f6}.section-copy h2,.login-copy-block h2{margin:0;color:var(--ink-strong);font-size:clamp(2rem,4vw,3.8rem);line-height:1}.service-section .section-copy h2{color:#fff}.section-copy p:not(.eyebrow),.login-copy-block p:not(.eyebrow){margin:18px 0 0;color:var(--muted);font-size:1rem;line-height:1.65}.service-section .section-copy p:not(.eyebrow){color:#eaf2f6bd}.marketing-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.marketing-card{display:grid;align-content:start;gap:12px;min-height:230px;padding:22px;border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:var(--shadow)}.service-section .marketing-card{border-color:#ffffff1f;background:#ffffff12;box-shadow:none}.marketing-card>span{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent)}.marketing-card h3,.marketing-card p{margin:0}.marketing-card h3{color:var(--ink-strong);font-size:1.08rem}.service-section .marketing-card h3{color:#fff}.marketing-card p{color:var(--muted);line-height:1.55}.service-section .marketing-card p{color:#eaf2f6b8}.login-section{align-items:start;background:radial-gradient(circle at 80% 20%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 28rem),#eef3f7}.login-panel{display:grid;width:min(400px,100%);gap:20px;padding:36px;border:none;border-radius:16px;background:#fff;box-shadow:0 32px 80px #0000004d,0 4px 16px #0000001a}.login-section .login-panel{justify-self:end;width:min(430px,100%)}.login-brand{display:flex;align-items:center;gap:16px}.login-logo{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--accent-soft);border-radius:12px}.login-logo img{width:30px;height:30px}.login-brand .eyebrow{margin:0 0 3px}.login-brand h1{margin:0;font-size:1.35rem;line-height:1.2}.login-copy{color:var(--muted);font-size:.925rem;line-height:1.5;margin:0}.login-actions{display:flex;flex-direction:column;align-items:center;gap:10px}.muted{color:var(--muted);line-height:1.45}.eyebrow{color:var(--accent);font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.console-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:18px;border-right:1px solid var(--border);background:#fff}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:6px 4px 22px}.sidebar-brand img{width:44px;height:44px}.sidebar-brand strong,.sidebar-brand span{display:block}.sidebar-brand span{margin-top:2px;color:var(--muted);font-size:.85rem}.sidebar nav{display:grid;gap:6px}.sidebar button,.secondary-action,.primary-action,.danger-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:8px;font-weight:750;cursor:pointer}.sidebar button{justify-content:flex-start;width:100%;padding:8px 10px;border:1px solid transparent;background:transparent;color:#334255}.sidebar button:hover,.sidebar button.active{border-color:#cfdee6;background:var(--accent-soft);color:var(--accent)}.workspace{min-width:0;padding:24px}.console-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;padding:16px;border:1px solid color-mix(in srgb,var(--border) 86%,transparent);border-radius:14px;background:color-mix(in srgb,var(--surface) 86%,transparent);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.console-topbar h1,.console-topbar p,.console-topbar span,.panel-header h2{margin:0}.console-topbar h1{margin-top:4px;font-size:1.55rem;color:var(--ink-strong)}.console-topbar span,.panel-header span{display:block;margin-top:4px;color:var(--muted);font-size:.9rem}.topbar-tools{display:flex;align-items:center;gap:8px}select,input{min-height:38px;width:100%;padding:7px 34px 7px 10px;border:1px solid var(--border-strong);border-radius:8px;background:#fff;color:#223044}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;cursor:pointer}.topbar-tools select{min-width:190px}.select-shell{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 10px;border:1px solid var(--border-strong);border-radius:10px;background:linear-gradient(180deg,#fff,#f7fafc);color:var(--accent);box-shadow:0 8px 20px #15223214}.select-shell select{min-height:40px;padding:0 24px 0 0;border:0;background-color:transparent;background-image:none;color:#223044;font-weight:750;outline:0}.select-shell>svg:last-child{flex:0 0 auto;color:var(--muted);pointer-events:none}.location-select{width:min(260px,36vw)}.icon-button{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--border-strong);border-radius:10px;background:linear-gradient(180deg,#fff,#f8fafc);color:#2d3b4e;cursor:pointer;box-shadow:0 8px 18px #15223212}.icon-button:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.icon-button.danger{color:var(--danger)}.user-badge{display:flex;align-items:center;gap:8px;padding-left:6px}.avatar{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:8px;background:var(--accent-soft);color:var(--accent);font-weight:800;object-fit:cover}.notice{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;line-height:1.4}.notice.error{border-color:#efb3b3;background:var(--danger-soft);color:var(--danger)}.notice.warn{border-color:#f1bf7c;background:var(--warn-soft);color:var(--warn)}.notice.info{border-color:#bad8e1;background:#eef8fb;color:#244050}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.metric,.panel{border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,var(--surface),color-mix(in srgb,var(--surface-soft) 58%,var(--surface)));box-shadow:var(--shadow)}.metric{display:flex;gap:12px;min-width:0;padding:16px;position:relative;overflow:hidden}.metric:after{content:"";position:absolute;inset:auto 12px 0 12px;height:3px;border-radius:999px 999px 0 0;background:color-mix(in srgb,var(--accent) 55%,transparent);opacity:.45}.metric>span{display:inline-grid;place-items:center;flex:0 0 auto;width:36px;height:36px;border-radius:10px;background:var(--accent-soft);color:var(--accent)}.metric.ok>span{background:var(--ok-soft);color:var(--ok)}.metric.warn>span{background:var(--warn-soft);color:var(--warn)}.metric p,.metric strong,.metric small{display:block}.metric p{margin:0 0 8px;color:var(--muted);font-size:.76rem;font-weight:800;text-transform:uppercase}.metric strong{font-size:1.45rem;line-height:1.1}.metric small{margin-top:7px;color:var(--muted)}.panel{min-width:0;margin-bottom:14px;overflow:hidden}.panel.wide,.wide{grid-column:1 / -1}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:1px solid #e8edf2}.panel-header h2{font-size:1.05rem}.two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.segmented{display:flex;gap:4px;padding:3px;border:1px solid color-mix(in srgb,var(--border-strong) 82%,transparent);border-radius:10px;background:color-mix(in srgb,var(--surface-soft) 88%,#fff)}.segmented button{min-height:32px;padding:5px 12px;border:1px solid transparent;border-radius:8px;background:transparent;color:#4d5d70;cursor:pointer;font-weight:700}.segmented button.active{border-color:color-mix(in srgb,var(--accent) 28%,#fff);background:#fff;color:var(--accent);box-shadow:0 8px 16px #15223214}.chart-actions{display:flex;align-items:center;gap:8px}.chart-wrap{padding:16px 18px 18px;overflow-x:auto}.chart-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}.chart-stats .summary-item{background:color-mix(in srgb,var(--accent-soft) 38%,#fff)}.chart-wrap svg{display:block;width:100%;min-width:720px;height:auto}.chart-bg{fill:color-mix(in srgb,var(--surface-soft) 82%,#fff);rx:12px}.grid-line{stroke:#e0e7ef}.grid-line.vertical{stroke-dasharray:3 8;opacity:.72}.chart-axis{stroke:var(--border-strong);stroke-width:1.5}.axis-label{fill:#6a7787;font-size:13px}.axis-label.end{text-anchor:end}.axis-label.time{text-anchor:middle}.legend-label{font-size:12px}.threshold-line{stroke:#b12f2f;stroke-width:2;stroke-dasharray:7 6;opacity:.55}.threshold-label-chart{fill:var(--danger);font-size:11px;font-weight:800;text-anchor:end}.trend-line{fill:none;stroke-width:3.5;stroke-linejoin:round;stroke-linecap:round;filter:drop-shadow(0 4px 8px rgb(21 34 50 / .14))}.trend-area{opacity:.8}.trend-line.c0{stroke:#197a4d}.trend-line.c1{stroke:#2474a6}.trend-line.c2{stroke:#b05a20}.trend-line.c3{stroke:#7a4d9d}.chart-fill-stop.c0{stop-color:#197a4d}.chart-fill-stop.c1{stop-color:#2474a6}.chart-fill-stop.c2{stop-color:#b05a20}.chart-fill-stop.c3{stop-color:#7a4d9d}.latest-point,.legend-dot{stroke:#fff;stroke-width:2}.latest-point.c0,.legend-dot.c0{fill:#197a4d}.latest-point.c1,.legend-dot.c1{fill:#2474a6}.latest-point.c2,.legend-dot.c2{fill:#b05a20}.latest-point.c3,.legend-dot.c3{fill:#7a4d9d}.alert-point{fill:var(--danger);stroke:#fff;stroke-width:2}.status-list,.event-list,.user-list,.location-list,.device-list,.sensor-grid,.recipient-list{display:grid;gap:10px;padding:14px}.status-list article,.user-list article,.location-list article,.device-list article{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px 12px;border:1px solid #e6ebf2;border-radius:8px;background:#fff}.status-list article.alert{border-color:#e49a9a;background:var(--danger-soft)}.status-list article.warn{border-color:#e2b650;background:var(--warn-soft)}.status-list strong,.status-list span,.user-list strong,.user-list span,.location-list strong,.location-list span,.device-list strong,.device-list span{display:block;min-width:0}.status-list span,.user-list span,.location-list span{color:var(--muted);font-size:.87rem}.device-list article{grid-template-columns:auto minmax(0,1fr) minmax(180px,.5fr) auto}.device-list select{min-width:0}.pill{display:inline-flex;align-items:center;min-height:26px;padding:3px 8px;border:1px solid #dbe5ed;border-radius:999px;background:#f8fafc;color:#36465a;font-size:.82rem;font-weight:800}.table-wrap{width:100%;overflow-x:auto}table{width:100%;min-width:620px;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid #edf1f5;text-align:left;white-space:nowrap}th{background:#fbfcfd;color:var(--muted);font-size:.78rem;text-transform:uppercase}.danger-text{color:var(--danger);font-weight:800}.settings-summary,.analytics-list{display:grid;gap:10px;padding:14px}.settings-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.settings-summary.roomy{padding-top:0}.summary-item{min-width:0;padding:12px;border:1px solid #e6ebf2;border-radius:8px;background:#fbfcfd}.summary-item span,fieldset label>span{display:block;color:var(--muted);font-size:.74rem;font-weight:800;text-transform:uppercase}.summary-item strong{display:block;margin-top:6px;overflow-wrap:anywhere}.event-list article{display:grid;grid-template-columns:90px minmax(0,1fr);gap:4px 10px;padding:10px 12px;border:1px solid #e6ebf2;border-radius:8px;background:#fff}.event-list small{grid-column:2;color:var(--danger);overflow-wrap:anywhere}.sensor-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.sensor-card{display:grid;gap:8px;padding:14px;border:1px solid #e6ebf2;border-radius:8px;background:#fff}.sensor-card div{display:flex;align-items:center;gap:8px}.sensor-card span{color:var(--muted)}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:14px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px}.form-grid label{display:grid;gap:5px;min-width:0}.form-grid label>span{display:block;color:var(--muted);font-size:.74rem;font-weight:800;text-transform:uppercase}.device-form{grid-template-columns:minmax(150px,1fr) minmax(180px,1fr) minmax(160px,1fr) minmax(160px,1fr) auto}.permission-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:14px}.permission-table{display:grid;gap:10px;padding:14px}.permission-table article{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,.35fr);align-items:center;gap:12px;padding:11px 12px;border:1px solid #e6ebf2;border-radius:8px;background:#fff}.permission-table strong,.permission-table span{display:block;min-width:0}.permission-table span{margin-top:3px;color:var(--muted);font-size:.87rem}.panel-footer{display:flex;justify-content:flex-end;padding:0 14px 14px}fieldset{display:grid;gap:10px;min-width:0;margin:0;padding:14px;border:1px solid #e6ebf2;border-radius:8px;background:#fff}fieldset:disabled{opacity:.72}legend{display:inline-flex;align-items:center;gap:8px;padding:0 6px;color:#28374a;font-weight:800}fieldset label{display:grid;gap:5px;min-width:0}.switch-field{display:flex;align-items:center;gap:8px;min-height:36px;padding:8px 10px;border:1px solid #dde5ee;border-radius:8px;background:#f8fafc}.switch-field input{width:16px;height:16px;min-height:0;padding:0;accent-color:var(--accent)}.switch-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.recipient-row{display:grid;grid-template-columns:minmax(110px,.5fr) minmax(160px,1fr) minmax(180px,1fr);gap:10px}.primary-action{border:1px solid var(--accent);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 92%,#fff),var(--accent));color:#fff;padding:7px 13px;box-shadow:0 12px 22px color-mix(in srgb,var(--accent) 22%,transparent)}.secondary-action{border:1px solid color-mix(in srgb,var(--accent) 24%,#d7e1eb);background:linear-gradient(180deg,#fff,#f7fafc);color:var(--accent);padding:7px 13px;box-shadow:0 8px 18px #15223212}.danger-action{border:1px solid #c94343;background:linear-gradient(180deg,#d95757,#c94343);color:#fff;padding:7px 13px;box-shadow:0 12px 22px #c943432e}.primary-action:disabled,.secondary-action:disabled,.danger-action:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.55}.danger-zone{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border:1px solid #efb3b3;border-radius:8px;background:var(--danger-soft);color:var(--danger)}.empty-state{padding:34px 16px;color:var(--muted);text-align:center}.sensor-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:14px}.sensor-card{display:flex;flex-direction:column;gap:10px;padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:var(--shadow)}.sensor-card.alert{border-color:#e49a9a;background:var(--danger-soft)}.sensor-card.offline{border-color:var(--border);opacity:.72}.sensor-card-header{display:flex;align-items:flex-start;gap:10px}.sensor-card-icon{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:8px;background:var(--accent-soft);color:var(--accent);flex:0 0 auto}.sensor-card.alert .sensor-card-icon{background:var(--danger-soft);color:var(--danger)}.sensor-card-header>div{flex:1;min-width:0}.sensor-card-header strong{display:block;font-size:1rem}.sensor-location{display:block;color:var(--muted);font-size:.82rem;margin-top:2px}.sensor-badge{flex:0 0 auto;display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;font-size:.72rem;font-weight:800;text-transform:uppercase}.sensor-badge.ok{background:var(--ok-soft);color:var(--ok)}.sensor-badge.alert{background:var(--danger-soft);color:var(--danger)}.sensor-badge.offline{background:var(--warn-soft);color:var(--warn)}.sensor-temp-row{display:flex;align-items:baseline;gap:8px}.sensor-temp{font-size:2rem;line-height:1}.sensor-limit{color:var(--muted);font-size:.85rem}.temp-bar-wrap{height:6px;border-radius:999px;background:#e8edf3;overflow:hidden}.temp-bar{height:100%;border-radius:999px;background:var(--ok);transition:width .4s ease}.temp-bar.over{background:var(--danger)}.sensor-card-footer{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:.8rem}.settings-page{display:flex;flex-direction:column;gap:14px}.settings-readonly-notice{margin-bottom:0}.settings-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}.settings-col{display:flex;flex-direction:column;gap:14px}.settings-fields{padding:14px}.settings-fields fieldset{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.settings-empty{margin:0;padding:12px 14px;color:var(--muted);font-size:.9rem}.threshold-field{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.threshold-field:last-child{border-bottom:none}.threshold-label{color:#2d3b4e;font-weight:600}.threshold-input-wrap{display:flex;align-items:center;gap:6px}.threshold-input-wrap input{width:80px;text-align:right;min-height:36px}.threshold-unit{color:var(--muted);font-size:.85rem;width:28px}.settings-label{display:grid;gap:5px;min-width:0}.settings-label>span{display:block;color:var(--muted);font-size:.74rem;font-weight:800;text-transform:uppercase}.settings-label>small{color:var(--muted);font-size:.78rem}.settings-label code{background:#eef2f6;padding:1px 4px;border-radius:3px;font-size:.82em}.recipient-list{display:flex;flex-direction:column;gap:0}.recipient-card{display:flex;flex-direction:column;gap:8px;padding:14px;border-bottom:1px solid var(--border)}.recipient-card-row{display:flex;align-items:center;justify-content:space-between}.recipient-add{padding:12px 14px}.settings-footer{display:flex;align-items:center;gap:10px;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.save-success{border-color:var(--ok)!important;background:var(--ok)!important}.location-icon{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:8px;background:var(--accent-soft);color:var(--accent);flex:0 0 auto}.pill-admin{background:#e8f3fb;color:#1a5a8a;border-color:#b8d6ef}.pill-manager{background:#eef8f4;color:var(--ok);border-color:#b3dece}.pill-viewer{background:#f8fafc;color:var(--muted);border-color:var(--border)}.inline-form{border-bottom:1px solid var(--border);background:var(--surface-soft)}.inline-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:14px}.inline-form-actions{display:flex;gap:8px;padding:0 14px 14px}.device-table{display:grid;gap:0}.device-table-header{display:grid;grid-template-columns:minmax(130px,1fr) minmax(130px,1fr) minmax(130px,1fr) minmax(160px,1fr) auto;gap:10px;padding:8px 14px;background:#fbfcfd;border-bottom:1px solid var(--border);color:var(--muted);font-size:.74rem;font-weight:800;text-transform:uppercase}.device-table-row{display:grid;grid-template-columns:minmax(130px,1fr) minmax(130px,1fr) minmax(130px,1fr) minmax(160px,1fr) auto;gap:10px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border)}.device-table-row.inactive{opacity:.6}.device-table-row:last-child{border-bottom:none}.device-sensor-name{display:inline-flex;align-items:center;gap:6px;font-weight:700}.device-inactive{padding:10px 14px;color:var(--muted);font-size:.88rem}.device-inactive summary{cursor:pointer;padding:4px 0}.pending-panel{margin-bottom:14px}.pending-role-row{display:flex;align-items:center;gap:8px}.muted-label{color:var(--muted);font-size:.85rem}.pending-list{display:flex;flex-direction:column;gap:0}.pending-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.pending-row:last-child{border-bottom:none}.pending-info{flex:1;min-width:0}.pending-info strong,.pending-info span{display:block;min-width:0}.pending-info span{color:var(--muted);font-size:.85rem;margin-top:1px}.pending-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.users-layout{display:grid;grid-template-columns:minmax(280px,.6fr) minmax(0,1fr);gap:14px;align-items:start}.users-list-panel,.users-perms-panel{position:sticky;top:70px}.users-list{display:flex;flex-direction:column}.user-row{display:flex;align-items:center;gap:10px;width:100%;padding:11px 14px;border:none;border-bottom:1px solid var(--border);background:transparent;text-align:left;cursor:pointer}.user-row:last-child{border-bottom:none}.user-row:hover{background:var(--surface-soft)}.user-row.selected{background:var(--accent-soft)}.user-row-info{flex:1;min-width:0}.user-row-info strong,.user-row-info span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-row-info span{color:var(--muted);font-size:.82rem;margin-top:1px}.role-badge{flex:0 0 auto;display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;font-size:.7rem;font-weight:800;text-transform:uppercase}.role-badge.role-platform_superadmin{background:#f0e8ff;color:#6b21b8}.role-badge.role-business_admin{background:#e8f3fb;color:#1a5a8a}.role-badge.role-location_manager{background:var(--ok-soft);color:var(--ok)}.role-badge.role-viewer,.role-badge.role-user{background:#f1f4f8;color:var(--muted)}.perms-body{padding:16px;display:flex;flex-direction:column;gap:20px}.perms-role-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.perms-section-label{display:block;font-size:.88rem;font-weight:800;color:#2d3b4e;margin-bottom:4px}.perms-hint{margin:0;color:var(--muted);font-size:.82rem;line-height:1.4}.perms-locations{display:flex;flex-direction:column;gap:8px}.perm-location-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-soft)}.perm-location-row>div strong{display:block;font-size:.92rem}.perm-location-row>div span{display:block;color:var(--muted);font-size:.8rem;margin-top:2px}.perm-toggle{display:flex;gap:3px;padding:3px;border:1px solid var(--border);border-radius:8px;background:#f7f9fb;flex:0 0 auto}.perm-toggle button{min-height:28px;padding:4px 10px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--muted);font-size:.78rem;font-weight:700;cursor:pointer}.perm-toggle button.active{border-color:var(--border-strong);background:#fff;color:var(--accent)}.perm-toggle button:disabled{cursor:not-allowed;opacity:.55}.perms-footer{display:flex;justify-content:flex-end}.perms-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:var(--muted);text-align:center}.perms-empty p{margin:0;max-width:240px;line-height:1.5}.location-list article{grid-template-columns:auto minmax(0,1fr) auto}@media (max-width: 1080px){.console-shell{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:100;height:auto;padding:10px 14px;border-right:0;border-bottom:1px solid var(--border);background:#fff}.sidebar-brand{padding:4px 2px 10px}.sidebar-brand img{width:36px;height:36px}.sidebar nav{grid-template-columns:repeat(6,minmax(0,1fr));gap:4px}.sidebar button{flex-direction:column;justify-content:center;gap:4px;padding:8px 6px;min-height:52px;font-size:.72rem;text-align:center}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.marketing-hero{min-height:88vh;padding:84px 18px 78px}.marketing-hero-shade{background:linear-gradient(180deg,#060d14c2,#060d14e0),linear-gradient(90deg,rgb(6 13 20 / .7),transparent)}.marketing-nav{padding:14px 18px}.marketing-nav nav{display:none}.marketing-hero h1{font-size:clamp(2.35rem,13vw,4rem);line-height:.98}.marketing-lede{font-size:.98rem}.marketing-actions{align-items:stretch;flex-direction:column;width:min(100%,340px)}.marketing-actions .primary-action,.marketing-actions .secondary-action{width:100%}.marketing-proof{gap:7px}.marketing-strip{grid-template-columns:1fr;gap:10px;margin-top:-34px;padding:0 14px}.marketing-strip article,.marketing-strip article:first-child,.marketing-strip article:last-child{min-height:auto;border-radius:12px}.marketing-section,.service-section,.login-section{grid-template-columns:1fr;padding:52px 18px}.service-section .section-copy{order:-1}.marketing-card-grid{grid-template-columns:1fr}.marketing-card{min-height:auto}.login-section .login-panel{justify-self:stretch}.workspace{padding:14px}.console-topbar{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:14px}.console-topbar h1{font-size:1.3rem}.topbar-tools{display:flex;flex-wrap:wrap;gap:8px}.topbar-tools select{flex:1;min-width:140px}.location-select{flex:1 1 100%;width:100%}.user-badge>span{display:none}.panel-header{flex-wrap:wrap;gap:10px;padding:14px}.panel-header>div,.panel-header>.chart-actions{width:100%}.chart-actions{align-items:stretch;flex-direction:column}.chart-actions .segmented{width:100%}.chart-actions .segmented button{flex:1}.two-column,.settings-grid,.settings-summary{grid-template-columns:1fr}.sensor-grid,.switch-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.recipient-row,.form-grid,.device-form,.permission-grid{grid-template-columns:1fr}.permission-table article{grid-template-columns:minmax(0,1fr) 160px}.device-list article{grid-template-columns:auto minmax(0,1fr) auto}.device-list article>select{grid-column:1 / -1}.settings-columns,.users-layout{grid-template-columns:1fr}.users-list-panel,.users-perms-panel{position:static}.device-table-header{display:none}.device-table-row{grid-template-columns:1fr auto;grid-template-rows:auto auto auto}.device-table-row>span:nth-child(2),.device-table-row>span:nth-child(3){color:var(--muted);font-size:.85rem}.device-table-row>select{grid-column:1 / -1}.inline-form-grid{grid-template-columns:1fr}.perm-toggle button{padding:4px 8px;font-size:.72rem}button,input,select{min-height:44px}.segmented button{min-height:34px}}@media (max-width: 540px){.sidebar{position:fixed;top:auto;bottom:0;left:0;right:0;padding:0;border-bottom:none;border-top:1px solid var(--border);box-shadow:0 -2px 16px #15223214;z-index:200}.sidebar-brand{display:none}.sidebar nav{grid-template-columns:repeat(6,1fr);gap:0}.sidebar button{border-radius:0;border-color:transparent;padding:8px 4px;min-height:58px;font-size:.65rem;gap:3px}.sidebar button.active{border-color:transparent;color:var(--accent);background:var(--accent-soft)}.workspace{padding:12px 12px 74px}.console-topbar{gap:8px;margin:-2px -2px 12px;padding:14px;border-radius:0 0 16px 16px;border-top:0}.console-topbar h1{font-size:1.22rem;line-height:1.15}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.metric{display:grid;grid-template-columns:auto minmax(0,1fr);padding:12px 10px;gap:9px}.metric>span{width:30px;height:30px}.metric strong{font-size:1.15rem}.sensor-grid{grid-template-columns:1fr}.chart-wrap{padding:12px}.chart-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.chart-wrap svg{min-width:640px}.segmented{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;-webkit-overflow-scrolling:touch}.segmented::-webkit-scrollbar{display:none}.device-list article{grid-template-columns:auto minmax(0,1fr)}.device-list article>select,.device-list article>button{grid-column:1 / -1}.panel-header{padding:12px 14px}.panel-footer{padding:0 12px 12px}.settings-summary,.settings-grid,.form-grid,.status-list,.user-list,.location-list,.device-list,.sensor-grid,.recipient-list,.event-list,.analytics-list{padding:10px}.switch-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.sensor-override-list{display:flex;flex-direction:column;gap:0;margin-bottom:12px;border:1px solid var(--border);border-radius:8px;overflow:hidden}.sensor-override-row{display:grid;grid-template-columns:140px 1fr auto auto;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border);background:#fff}.sensor-override-row:last-child{border-bottom:none}.sensor-override-name{display:flex;align-items:center;gap:6px;font-weight:700;color:#2d3b4e;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sensor-override-presets{display:flex;flex-wrap:wrap;gap:5px}.preset-chip{display:inline-flex;align-items:center;height:26px;padding:0 10px;border:1px solid var(--border-strong);border-radius:999px;background:#f8fafc;color:#36465a;font-size:.76rem;font-weight:700;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.preset-chip.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.preset-chip:disabled{cursor:not-allowed;opacity:.55}.sensor-override-inputs{display:flex;align-items:center;gap:8px}.threshold-unit-label{color:var(--muted);font-size:.74rem;font-weight:800;text-transform:uppercase;white-space:nowrap}.sensor-override-inputs .threshold-input-wrap{display:flex;align-items:center;gap:4px}.sensor-override-inputs input{width:68px;text-align:right;min-height:32px;font-size:.9rem}.override-suggestions{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}.override-suggestions-label{color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase}.override-suggestion-chips{display:flex;flex-wrap:wrap;gap:6px}.suggestion-chip{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 10px;border:1px dashed var(--accent);border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:.78rem;font-weight:700;cursor:pointer}.suggestion-chip:disabled{opacity:.5;cursor:not-allowed}.override-add-row{display:flex;gap:8px;align-items:center;padding-top:4px}.override-add-row input{flex:1;min-height:36px}.theme-selector-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.theme-swatches{display:flex;flex-wrap:wrap;gap:6px}.theme-swatch{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 10px;border:1.5px solid var(--border-strong);border-radius:999px;background:#fff;color:#334255;font-size:.77rem;font-weight:700;cursor:pointer;transition:border-color .15s,box-shadow .15s}.theme-swatch.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.theme-swatch:disabled{cursor:not-allowed;opacity:.55}.theme-swatch-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex:0 0 auto}.theme-swatch-default .theme-swatch-dot{background:#17657a}.theme-swatch-cold-storage .theme-swatch-dot{background:#1558a8}.theme-swatch-food-service .theme-swatch-dot{background:#b85a00}.theme-swatch-outdoor .theme-swatch-dot{background:#2a6e3a}.theme-swatch-residential .theme-swatch-dot{background:#6644a8}@media (max-width: 768px){.sensor-override-row{grid-template-columns:1fr auto;grid-template-rows:auto auto auto}.sensor-override-name{grid-column:1}.sensor-override-row>.icon-button{grid-row:1;grid-column:2}.sensor-override-presets{grid-column:1 / -1}.sensor-override-inputs{grid-column:1 / -1;flex-wrap:wrap}.theme-selector-row{flex-direction:column;align-items:flex-start}}.live-indicator{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);font-size:.78rem;font-weight:700}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--ok);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.sensor-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px}.sensor-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px #0003;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;padding:24px}.sensor-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;font-size:1.1rem}.sensor-modal-analytics{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;padding:12px 16px;background:var(--surface-soft);border:1px solid var(--border);border-radius:8px;font-size:.88rem;color:var(--muted)}.sensor-modal-analytics strong{color:inherit;color:#192231}.sensor-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-1px);transition:box-shadow .15s,transform .15s}[data-color-scheme=dark]{background:#0d1520;color:#dde4ed;--surface: #141e2e;--surface-soft: #192538;--surface-glow: #101a28;--border: #253347;--border-strong: #2f4055;--muted: #7a8fa8;--ink-strong: #f2f6fb;--accent-soft: #0a2535;--ok-soft: #0a2018;--warn-soft: #231500;--danger-soft: #210a0a;--shadow: 0 1px 3px rgb(0 0 0 / .35)}[data-color-scheme=dark] body{background:#0d1520}[data-color-scheme=dark] .sidebar{background:#141e2e;border-color:#253347}[data-color-scheme=dark] .login-page{background:linear-gradient(180deg,#0a1520,#0d1520 44%,#111a28)}[data-color-scheme=dark] select,[data-color-scheme=dark] input{background:#192538;color:#dde4ed;border-color:#2f4055}[data-color-scheme=dark] .select-shell{background:linear-gradient(180deg,#192538,#141e2e);border-color:#2f4055}[data-color-scheme=dark] .select-shell select{background:transparent;color:#dde4ed}[data-color-scheme=dark] .icon-button{background:#141e2e;color:#a8b8cc;border-color:#253347}[data-color-scheme=dark] fieldset,[data-color-scheme=dark] .switch-field{background:#192538;border-color:#253347}[data-color-scheme=dark] th{background:#192538}[data-color-scheme=dark] .sensor-card{background:#141e2e;border-color:#253347}[data-color-scheme=dark] .summary-item{background:#192538;border-color:#253347}[data-color-scheme=dark] .panel,[data-color-scheme=dark] .metric{background:#141e2e}[data-color-scheme=dark] .user-row:hover{background:#192538}[data-color-scheme=dark] .user-row.selected{background:var(--accent-soft)}[data-color-scheme=dark] .chart-bg{fill:#192538}[data-color-scheme=dark] .grid-line{stroke:#253347}[data-color-scheme=dark] .chart-axis{stroke:#2f4055}[data-color-scheme=dark] .axis-label{fill:#7a8fa8}[data-color-scheme=dark] .segmented{background:#192538;border-color:#253347}[data-color-scheme=dark] .segmented button{color:#7a8fa8}[data-color-scheme=dark] .segmented button.active{background:#141e2e;color:var(--accent)}[data-color-scheme=dark] .sidebar button{color:#a8b8cc}[data-color-scheme=dark] .inline-form{background:#141e2e}[data-color-scheme=dark] .sensor-modal{background:#141e2e;border-color:#253347}[data-color-scheme=dark] .sensor-modal-analytics{background:#192538;border-color:#253347}[data-color-scheme=dark] .sensor-modal-analytics strong{color:#dde4ed}
