:root{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;--shadow: 0 1px 2px rgb(21 34 50 / .05)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f3f6f8}button,input,select{font:inherit;touch-action:manipulation}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid rgb(23 101 122 / .22);outline-offset:2px}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(180deg,#eef4f7,#f8fafb 44%,#f3f6f8)}.login-panel{display:grid;width:min(440px,100%);gap:18px;padding:28px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:0 20px 48px #1522321a}.login-panel img{width:64px;height:64px}.login-panel h1,.login-panel p{margin:0}.login-panel h1{font-size:1.7rem;line-height:1.1}.login-copy,.muted{color:var(--muted);line-height:1.45}.eyebrow{color:var(--accent);font-size:.75rem;font-weight:800;letter-spacing:0;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}.console-topbar h1,.console-topbar p,.console-topbar span,.panel-header h2{margin:0}.console-topbar h1{margin-top:4px;font-size:1.55rem}.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 10px;border:1px solid var(--border-strong);border-radius:8px;background:#fff;color:#223044}.topbar-tools select{min-width:190px}.icon-button{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--border-strong);border-radius:8px;background:#fff;color:#2d3b4e;cursor:pointer}.icon-button:hover{border-color:var(--accent);color:var(--accent)}.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:8px;background:var(--surface);box-shadow:var(--shadow)}.metric{display:flex;gap:12px;min-width:0;padding:16px}.metric>span{display:inline-grid;place-items:center;flex:0 0 auto;width:36px;height:36px;border-radius:8px;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 #dce5ee;border-radius:8px;background:#f7f9fb}.segmented button{min-height:30px;padding:5px 10px;border:1px solid transparent;border-radius:6px;background:transparent;color:#4d5d70;cursor:pointer;font-weight:700}.segmented button.active{border-color:#cfe0e7;background:#fff;color:var(--accent)}.chart-wrap{padding:16px 18px 18px;overflow-x:auto}.chart-wrap svg{display:block;width:100%;min-width:680px;height:auto}.chart-bg{fill:var(--surface-soft)}.grid-line{stroke:#e0e7ef}.axis-label{fill:#6a7787;font-size:13px}.axis-label.end{text-anchor:end}.threshold-line{stroke:#b12f2f;stroke-width:2;stroke-dasharray:7 6;opacity:.55}.trend-line{fill:none;stroke-width:3;stroke-linejoin:round;stroke-linecap:round}.trend-line.c0{stroke:#197a4d}.trend-line.c1{stroke:#2474a6}.trend-line.c2{stroke:#b05a20}.trend-line.c3{stroke:#7a4d9d}.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:var(--accent);color:#fff;padding:7px 13px}.secondary-action{border:1px solid #d7e1eb;background:#fff;color:var(--accent);padding:7px 13px}.danger-action{border:1px solid #c94343;background:#c94343;color:#fff;padding:7px 13px}.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){.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}.user-badge>span{display:none}.panel-header{flex-wrap:wrap;gap:10px;padding:14px}.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-bottom:12px}.console-topbar h1{font-size:1.15rem}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metric{padding:12px;gap:10px}.metric>span{width:30px;height:30px}.metric strong{font-size:1.2rem}.sensor-grid{grid-template-columns:1fr}.chart-wrap svg{min-width:480px}.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))}}
