:root{font-family:Aptos,Inter,SF Pro Text,Segoe UI Variable,Segoe UI,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;--font-display: "SF Pro Display", "Aptos Display", "Inter", "Segoe UI Variable Display", "Segoe UI", ui-sans-serif, system-ui, sans-serif;--bg-deep: #07121a;--bg-panel: rgba(12, 25, 36, .84);--bg-panel-strong: rgba(16, 34, 48, .92);--line-soft: rgba(91, 142, 170, .34);--line-strong: rgba(129, 212, 250, .42);--text-main: #f6fbff;--text-soft: #98aebb;--cyan: #03a9f4;--cyan-soft: #81d4fa;--mint: #30e6a1;--violet: #8f7cff;--amber: #ffc857;--danger: #ff766d;color:#f7fafc;background:#08131c;font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{position:relative;margin:0;min-width:320px;min-height:100vh;background:linear-gradient(135deg,rgba(3,169,244,.11) 0%,transparent 34%),linear-gradient(315deg,rgba(143,124,255,.09) 0%,transparent 31%),var(--bg-deep)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:linear-gradient(180deg,#000000c7,#0000001f);mask-image:linear-gradient(180deg,#000000c7,#0000001f);opacity:.34}button,input,select{font:inherit}button{cursor:pointer}button,a,input,select{transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease,filter .18s ease}button:hover,a:hover{transform:translateY(-1px)}button:active,a:active{transform:translateY(0) scale(.98)}.login-shell{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,#08131cb8,#08131ce6),radial-gradient(circle at 50% 34%,rgba(129,212,250,.22),transparent 27rem),linear-gradient(145deg,#0b2738,#08131c 58%,#10202d);overflow:hidden}.login-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#ffffff0f,#ffffff03),radial-gradient(circle at 18% 18%,rgba(3,169,244,.18),transparent 24rem);-webkit-backdrop-filter:blur(2px) saturate(1.04);backdrop-filter:blur(2px) saturate(1.04);pointer-events:none}.login-panel{position:relative;z-index:1;width:min(420px,100%);display:grid;gap:20px;border:1px solid rgba(129,212,250,.24);border-radius:8px;padding:28px;background:#09141ed1;box-shadow:0 24px 80px #00000057,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(18px) saturate(1.08);backdrop-filter:blur(18px) saturate(1.08);animation:panelEnter .26s ease-out both}.brand-lockup{display:flex;align-items:center;gap:12px;min-width:0}.iot-logo-mark{width:38px;height:38px;flex:0 0 auto;display:inline-grid;place-items:center;border:1px solid rgba(129,212,250,.54);border-radius:8px;color:#fff;background:linear-gradient(145deg,#0288d1,#03a9f4 58%,#81d4fa);box-shadow:0 10px 24px #03a9f43d;overflow:hidden}.iot-logo-mark.large{width:44px;height:44px}.iot-logo-mark img{width:100%;height:100%;display:block}.brand-lockup strong,.brand-lockup span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-lockup strong{font-family:var(--font-display);font-size:1.04rem;font-weight:880;letter-spacing:0}.brand-lockup span{color:#93a4b0;font-size:.78rem}form{display:grid;gap:12px}label{display:grid;gap:7px;color:#93a4b0;font-size:.84rem;font-weight:760}input,select{min-width:0;height:42px;border:1px solid #22394b;border-radius:8px;padding:0 12px;color:#f7fafc;background:#0f1b25;box-shadow:inset 0 1px 2px #00000038}form button,.top-actions button,.sidebar button,.module-tabs button,.admin-tabs button,.event-row button{border:1px solid #22394b;border-radius:8px;color:#e9f2f6;background:#101d27}form button{height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#04131b;background:linear-gradient(145deg,#81d4fa,#03a9f4);font-weight:900;box-shadow:0 12px 28px #03a9f438}form p{margin:0;color:#29b6f6}.app-shell{min-height:100vh;display:grid;grid-template-columns:248px minmax(0,1fr);background:linear-gradient(125deg,rgba(3,169,244,.12),transparent 34%),linear-gradient(315deg,rgba(143,124,255,.08),transparent 30%),var(--bg-deep);color:#f7fafc}.app-shell.light{background:linear-gradient(135deg,rgba(8,132,166,.08),transparent 36%),#f4f8fa;color:#12212a}.app-shell.collapsed{grid-template-columns:78px minmax(0,1fr)}.app-shell.client-dashboard-shell,.app-shell.client-dashboard-shell.collapsed{grid-template-columns:248px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;display:grid;grid-template-rows:auto 1fr;gap:18px;border-right:1px solid rgba(29,52,70,.92);padding:20px 16px;background:linear-gradient(180deg,#0f2230fa,#07121afa),#0a1721;box-shadow:16px 0 42px #0000002e,inset -1px 0 #ffffff08}.collapsed .sidebar .brand-lockup div,.collapsed .sidebar nav span{display:none}.sidebar-head{min-width:0;display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:10px}.collapsed .sidebar-head{grid-template-columns:42px}.collapsed .sidebar .brand-lockup{display:none}.sidebar nav{display:grid;align-content:start;gap:8px}.sidebar button{min-width:0;height:42px;display:flex;align-items:center;gap:10px;padding:0 11px;color:#a9bdca;text-align:left;font-weight:780;box-shadow:inset 0 1px #ffffff09;position:relative;overflow:hidden}.sidebar button:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(129,212,250,.08),transparent);opacity:0;transform:translate(-34%);transition:opacity .18s ease,transform .22s ease}.sidebar button:hover:after{opacity:1;transform:translate(34%)}.sidebar .icon-button,.icon-button{width:42px;min-width:42px;justify-content:center;padding:0}.sidebar button.active{border-color:#03a9f49e;color:#f5fcff;background:linear-gradient(145deg,#03a9f43d,#0f3448c7),#0a2232;box-shadow:0 12px 28px #03a9f424,inset 0 1px #ffffff0f}.workspace{min-width:0;display:grid;align-content:start;gap:18px;padding:28px}.client-dashboard-shell .workspace{padding:16px}.client-dashboard-shell .topbar{position:sticky;top:0;z-index:20}.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;min-height:54px}.topbar h1{margin:2px 0 0;font-family:var(--font-display);font-size:clamp(1.42rem,2.2vw,2.05rem);font-weight:880;letter-spacing:0;color:var(--text-main);text-shadow:0 10px 34px rgba(3,169,244,.16)}.topbar span,.panel-head span,.hero-status span{color:var(--text-soft);font-size:.78rem;font-weight:820;text-transform:uppercase;letter-spacing:.04em}.top-actions{display:flex;align-items:center;gap:8px}.control-strip{min-height:46px;border:1px solid rgba(39,55,67,.92);border-radius:8px;padding:4px;background:#0d1720bd;box-shadow:0 14px 34px #00000038,inset 0 1px #ffffff0f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.top-actions button{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 10px}.control-button{border-color:transparent;color:#d8ecf7;background:transparent;transition:background .16s ease,color .16s ease,border-color .16s ease}.control-button:hover{border-color:#03a9f461;color:#fff;background:linear-gradient(145deg,#03a9f42e,#81d4fa0f);box-shadow:0 10px 26px #03a9f41a}.top-lock-button{border-color:#14d6763d;color:#dff5ff;background:#14d67614}.top-lock-button.unlocked{border-color:#ffc85785;color:#fff3cf;background:#ffc85724}.control-button.danger:hover{border-color:#ff7c725c;background:#ff7c721f}.theme-switch,.language-switch{position:relative;width:76px;min-width:76px;gap:4px;justify-content:space-between;border-color:#03a9f457;padding:4px;background:linear-gradient(145deg,#07111a,#102331);box-shadow:inset 0 4px 10px #00000052}.language-switch{width:94px;min-width:94px}.theme-switch span,.language-switch span{width:31px;height:31px;display:inline-grid;place-items:center;border-radius:7px;color:#7d93a2;transition:background .16s ease,color .16s ease,box-shadow .16s ease}.language-switch svg{margin-left:4px;color:#81d4fa}.language-switch span{width:28px;font-size:.72rem;font-weight:950}.theme-switch span.active,.language-switch span.active{color:#04131b;background:linear-gradient(145deg,#d8f4ff,#03a9f4);box-shadow:0 8px 18px #03a9f44d}.view-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.view-stack{display:grid;gap:14px}.hero-status,.module-card,.wide-panel,.side-panel{border:1px solid var(--line-soft);border-radius:8px;background:linear-gradient(180deg,var(--bg-panel-strong),rgba(11,23,33,.96)),#0f1c27;box-shadow:0 18px 52px #00000038,inset 0 1px #ffffff0b}.hero-status{grid-column:span 2;min-height:164px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px}.clean-hero{grid-column:span 3}.hero-status h2{margin:4px 0 8px;font-family:var(--font-display);font-size:2rem;font-weight:880}.hero-status p{max-width:580px;margin:0;color:#9babb5}.hero-kpis{min-width:130px;display:grid;place-items:center;border:1px solid rgba(3,169,244,.32);border-radius:8px;padding:16px;background:radial-gradient(circle at 50% 0%,rgba(129,212,250,.16),transparent 80%),#0b2230;box-shadow:inset 0 1px #ffffff0d}.hero-kpis strong{color:#03a9f4;font-size:2.4rem}.module-card{min-height:164px;display:grid;align-content:start;gap:8px;padding:16px;text-align:left;transition:transform .16s ease,border-color .16s ease}.module-card:hover{transform:translateY(-2px);border-color:#03a9f480;box-shadow:0 20px 52px #0000003d,0 0 22px #03a9f414,inset 0 1px #ffffff0d}.module-card span{color:#f7fafc;font-weight:900}.module-card strong{font-size:1.75rem}.module-card small{color:#93a4b0}.dashboard-builder{grid-column:span 1;min-width:0;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:16px;background:linear-gradient(180deg,#142633eb,#0d1923f5),#0f1c27;box-shadow:0 16px 44px #0000002e,inset 0 1px #ffffff0b}.dashboard-widget-page{display:grid;gap:14px}.client-dashboard-shell .dashboard-widget-page{max-width:none}.client-dashboard-shell .dashboard-widget-grid{gap:16px}.client-dashboard-shell .dashboard-widget{border-color:#88b7ab47;background:linear-gradient(145deg,#0c1f23eb,#0a121af0),#0b1720;box-shadow:0 22px 60px #00000042,inset 0 1px #ffffff0f}.client-dashboard-shell .widget-type-siteHero,.client-dashboard-shell .widget-type-environmentContext,.client-dashboard-shell .widget-type-forecast,.client-dashboard-shell .widget-type-camera,.client-dashboard-shell .widget-type-map{overflow:hidden}.client-dashboard-shell .widget-type-siteHero>.widget-head,.client-dashboard-shell .widget-type-environmentContext>.widget-head,.client-dashboard-shell .widget-type-forecast>.widget-head{display:none}.dashboard-titlebar{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px 14px;background:#0f1c27e0}.dashboard-titlebar h2{margin:2px 0;font-size:1.25rem}.dashboard-titlebar span,.dashboard-titlebar small{color:#93a4b0;font-size:.78rem;font-weight:820}.dashboard-tabs-row{min-width:0;display:flex;align-items:flex-end;gap:4px;border-bottom:1px solid rgba(40,74,96,.72)}.dashboard-tabs-row button{min-width:0;height:36px;display:inline-flex;align-items:center;border:1px solid rgba(40,74,96,.72);border-bottom:0;border-radius:8px 8px 0 0;padding:0 14px;color:#9fb4c2;background:linear-gradient(180deg,#122330b8,#09121aa3);font-weight:820;position:relative;overflow:hidden}.dashboard-tabs-row button.active{color:#e8f8ff;background:linear-gradient(180deg,#03a9f433,#03a9f414),#0a1924eb;box-shadow:inset 0 2px #03a9f4,0 -8px 24px #03a9f414}.dashboard-tabs-row input{width:150px;border:0;color:#e8f8ff;background:transparent;font:inherit;font-weight:850;outline:0}.dashboard-tabs-row .new-dashboard-tab{width:36px;justify-content:center;padding:0;color:#dff5ff}.dashboard-tabs-row small{margin-left:auto;padding:0 0 8px 8px;color:#93a4b0;font-size:.78rem;font-weight:820;white-space:nowrap}.dashboard-toolbar,.dashboard-widget{min-width:0;border:1px solid rgba(67,113,140,.54);border-radius:8px;padding:14px;background:linear-gradient(180deg,#152b3be6,#0a1620f5),#0f1c27;box-shadow:0 20px 54px #00000042,0 3px 16px #03a9f412,inset 0 1px #ffffff0f,inset 0 -18px 38px #0000001f}.widget-catalog{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.widget-catalog button{min-height:112px;display:grid;place-items:center;gap:10px;border:1px solid rgba(40,74,96,.26);border-radius:8px;padding:14px;color:#dff5ff;background:#ffffff09;text-align:center}.widget-catalog button strong{color:#f7fafc}.widget-catalog button svg{color:#7e57ff}.create-dashboard-panel{display:grid;gap:12px;margin-top:12px;border:1px solid rgba(3,169,244,.24);border-radius:8px;padding:12px;background:#03a9f40f}.create-dashboard-panel label{display:grid;gap:6px;color:#93a4b0;font-size:.78rem;font-weight:820}.create-dashboard-panel input{height:40px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:0 11px;color:#f7fafc;background:#0c1821}.template-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.template-picker button{min-height:68px;display:grid;align-content:center;gap:3px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;color:#f7fafc;background:#12212cf5;text-align:left}.template-picker button.active{border-color:#7e57ffb8;background:#7e57ff29}.template-picker small{color:#93a4b0}.widget-builder-catalog{min-height:360px;display:grid;grid-template-columns:180px minmax(0,1fr);gap:0;margin-top:12px;border:1px solid rgba(40,74,96,.38);border-radius:8px;overflow:hidden;background:#080f176b}.widget-category-menu{display:grid;align-content:start;border-right:1px solid rgba(40,74,96,.38);background:#ffffff06}.widget-category-menu button{height:50px;border:0;border-left:3px solid transparent;padding:0 18px;color:#a8b4bf;background:transparent;text-align:left;font-weight:820}.widget-category-menu button.active{border-left-color:#7e57ff;color:#d8ccff;background:#7e57ff29}.widget-catalog-content{min-width:0;display:grid;align-content:start;gap:18px;padding:20px}.widget-catalog-content header{display:flex;align-items:center;justify-content:space-between;gap:12px}.widget-catalog-content header span{display:block;color:#f7fafc;font-weight:950}.widget-catalog-content header strong{color:#93a4b0;font-size:.78rem}.lock-dashboard-button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(20,214,118,.35);border-radius:999px;padding:0 14px;color:#dff5ff;background:#14d6761a;font-weight:900}.lock-dashboard-button.unlocked{border-color:#ffc8579e;color:#fff3cf;background:#ffc85724;box-shadow:0 0 0 3px #ffc85714}.dashboard-lock-hint{display:block;margin-top:10px;color:#93a4b0;font-size:.78rem;font-weight:780}.dashboard-widget-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dashboard-widget{position:relative;display:grid;align-content:start;gap:12px;isolation:isolate;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;animation:cardEnter .26s ease-out both}.dashboard-widget:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;z-index:-1;border-radius:7px;background:linear-gradient(135deg,rgba(3,169,244,.14),transparent 38%),linear-gradient(315deg,rgba(143,124,255,.1),transparent 42%);opacity:.74;pointer-events:none}.dashboard-widget:after,.gauge-mini-card:after,.metric-panel-timeline:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.045) 42%,transparent 62%);opacity:0;transform:translate(-45%);pointer-events:none;transition:opacity .18s ease,transform .52s ease}.dashboard-widget:hover:after,.gauge-mini-card:hover:after,.metric-panel-timeline:hover:after{opacity:1;transform:translate(45%)}.dashboard-widget:hover{border-color:#81d4fa80;transform:translateY(-2px);box-shadow:0 26px 68px #0000004f,0 6px 22px #03a9f41c,inset 0 1px #ffffff13,inset 0 -18px 42px #00000021}.dashboard-widget.editing{outline:1px dashed rgba(3,169,244,.45);outline-offset:-5px}.dashboard-widget.unlocked{cursor:grab}.dashboard-widget.dragging{opacity:.48;cursor:grabbing;transform:scale(.985)}.dashboard-widget.drag-over{border-color:#ffc857d1;box-shadow:0 0 0 3px #ffc8571f,0 18px 50px #00000038}.dashboard-widget.resizing{border-color:#03a9f4db;box-shadow:0 0 0 3px #03a9f429,0 18px 48px #03a9f41f;-webkit-user-select:none;user-select:none}.widget-resize-handle{position:absolute;right:8px;bottom:8px;width:34px;min-width:34px;height:34px;display:grid;place-items:center;border:1px solid rgba(3,169,244,.42);border-radius:999px;color:#dff5ff;background:#03a9f42e;box-shadow:0 10px 26px #00000038;cursor:nwse-resize;touch-action:none;z-index:4}.widget-resize-handle:hover{border-color:#03a9f4d1;background:#03a9f447}.widget-small{grid-column:span 1}.widget-wide{grid-column:span 2}.widget-full{grid-column:1 / -1}.category-collapse-button{position:static;flex:0 0 34px;width:34px;height:34px;display:inline-grid;place-items:center;border:1px solid rgba(129,212,250,.42);border-radius:8px;color:#dff5ff;background:linear-gradient(145deg,#03a9f429,#051018db),#071925;box-shadow:0 10px 22px #00000038;order:-1}.category-collapse-button:hover{border-color:#03a9f49e;transform:translateY(-1px)}.widget-category-collapsed{min-height:146px}.category-iconized-card{min-height:80px;display:grid;place-items:center;align-content:center;gap:3px;border:1px solid rgba(129,212,250,.14);border-radius:8px;background:linear-gradient(135deg,rgba(3,169,244,.13),transparent 60%),#0510185c;cursor:pointer}.category-iconized-card strong{font-size:2rem;line-height:1}.category-iconized-card span{color:#f7fafc;font-size:1.28rem;font-weight:950}.category-iconized-card small{color:#93a4b0;font-size:.72rem;font-weight:850;text-transform:uppercase}.widget-snap-settings{display:grid;gap:7px}.widget-snap-settings>span{color:#93a4b0;font-size:.72rem;font-weight:850;text-transform:uppercase}.snap-button-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.snap-button-row button{min-height:34px;border:1px solid rgba(129,212,250,.14);border-radius:8px;color:#9fb3bf;background:#0c182294;font-size:.76rem;font-weight:850}.snap-button-row button.active{border-color:#03a9f49e;color:#f7fafc;background:#03a9f42e;box-shadow:inset 0 0 0 1px #03a9f424}.widget-head,.widget-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.widget-head h2{margin:2px 0 0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:var(--font-display);font-size:1.08rem;font-weight:860;color:#f5fbff}.outdoor-weather-badge{display:inline-flex;align-items:center;min-height:24px;padding:3px 9px;border:1px solid rgba(129,212,250,.22);border-radius:999px;color:#dff5ff;background:#03a9f41f;box-shadow:inset 0 1px #ffffff0d;font-size:.72rem;font-weight:900;line-height:1}.widget-head span{display:inline-flex;align-items:center;gap:6px;color:#93a4b0;font-size:.72rem;font-weight:850;text-transform:uppercase}.widget-actions{flex-shrink:0}.widget-actions .icon-button{width:34px;min-width:34px;height:34px;border:1px solid rgba(129,212,250,.18);border-radius:999px;color:#dff5ff;background:linear-gradient(145deg,#ffffff0e,#03a9f414),#0c1822b8;box-shadow:inset 0 1px #ffffff14,0 8px 18px #00000024;transition:transform .14s ease,border-color .14s ease,background .14s ease}.widget-actions .detail-button{min-width:0;height:34px;border:1px solid rgba(129,212,250,.24);border-radius:999px;padding:0 13px;color:#dff5ff;background:linear-gradient(145deg,#03a9f438,#ffffff0d),#0c1822c7;box-shadow:inset 0 1px #ffffff14,0 8px 18px #00000024;font-size:.74rem;font-weight:900;line-height:1}.widget-actions .detail-button:hover{transform:translateY(-1px);border-color:#81d4fa94;background:linear-gradient(145deg,#81d4fa33,#03a9f424),#0c1822e6}.widget-actions .icon-button:hover{transform:translateY(-1px);border-color:#81d4fa7a;background:linear-gradient(145deg,#81d4fa29,#03a9f41f),#0c1822db}.widget-actions .icon-button.danger{border-color:#ff7c723d;color:#ffd8d5;background:linear-gradient(145deg,#ff7c7214,#0c1822b8),#0c1822b8}.drag-handle{height:34px;display:inline-flex;align-items:center;border:1px solid rgba(255,200,87,.26);border-radius:999px;padding:0 10px;color:#ffe3a3;background:#ffc85714;font-size:.72rem;font-weight:900;text-transform:uppercase;cursor:grab}.widget-config-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;border:1px solid rgba(129,212,250,.24);border-radius:8px;padding:12px;background:linear-gradient(145deg,#81d4fa14,#0a1822ad),#0a1822d1;box-shadow:inset 0 1px #ffffff0d}.timeline-metric-picker.compact,.widget-config-panel .widget-color-row{grid-column:span 2}.widget-config-panel label,.widget-advanced-panel label{display:grid;gap:5px;color:#93a4b0;font-size:.76rem;font-weight:820}.widget-config-panel input,.widget-config-panel select,.widget-advanced-panel select{min-width:0;height:36px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:0 9px;color:#f7fafc;background:#0c1821}.widget-color-row{display:flex;align-items:center;flex-wrap:wrap;gap:7px}.widget-color-row span{display:inline-flex;align-items:center;gap:5px;color:#93a4b0;font-size:.76rem;font-weight:850}.widget-color-row button{width:26px;height:26px;border:2px solid rgba(255,255,255,.18);border-radius:999px}.widget-color-row button.active{border-color:#fff;box-shadow:0 0 0 2px #03a9f45c}.info-widget{min-height:170px;display:grid;place-items:center;align-content:center;gap:8px;color:#dff5ff;text-align:center}.info-widget strong{color:#f7fafc;font-size:2rem}.info-widget span{color:#93a4b0}.site-hero-widget{min-height:250px;display:grid;grid-template-columns:minmax(260px,.95fr) minmax(0,1.35fr);gap:18px;align-items:stretch;padding:6px}.site-hero-widget section{display:grid;align-content:center;gap:12px;border-radius:8px;padding:clamp(18px,3vw,34px);background:linear-gradient(145deg,#081b23e6,#0d2d2bad),radial-gradient(circle at 90% 10%,rgba(48,230,161,.18),transparent 20rem)}.site-kicker{width:fit-content;border:1px solid rgba(48,230,161,.34);border-radius:999px;padding:6px 10px;color:#bff7dd;background:#30e6a11f;font-size:.74rem;font-weight:900;text-transform:uppercase}.site-hero-widget h2{margin:0;color:#f7fafc;font-family:var(--font-display);font-size:clamp(1.75rem,3vw,3rem);line-height:1.02}.site-hero-widget p{max-width:58ch;margin:0;color:#b7c8cf;line-height:1.5}.site-meta-row{display:flex;flex-wrap:wrap;gap:8px}.site-meta-row span{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(129,212,250,.18);border-radius:999px;padding:7px 10px;color:#dff5ff;background:#07121a70;font-size:.8rem;font-weight:850}.site-metric-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.site-metric-strip article{min-width:0;display:grid;align-content:space-between;gap:8px;border:1px solid rgba(129,212,250,.16);border-radius:8px;padding:14px;background:linear-gradient(145deg,#ffffff0e,#03a9f414),#07121a8a}.site-metric-strip i{width:36px;height:36px;display:inline-grid;place-items:center;border-radius:8px;color:#fff;background:linear-gradient(145deg,#0288d1,#30e6a1);font-style:normal}.site-metric-strip span{color:#9fb5bf;font-size:.78rem;font-weight:900}.site-metric-strip strong{color:#f7fafc;font-size:clamp(1.25rem,2vw,1.75rem);line-height:1}.site-metric-strip small{margin-left:4px;color:#9fb5bf;font-size:.74rem}.forecast-widget{min-height:235px;padding:6px}.environment-context-widget{min-height:235px;display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:10px;padding:6px}.context-weather-pane,.context-camera-pane{min-width:0}.context-camera-pane{display:grid;grid-template-rows:minmax(0,1fr) auto;gap:9px}.environment-context-widget .camera-stage,.environment-context-widget .camera-stage img{min-height:172px}.context-camera-pane footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.context-camera-pane footer div{min-width:0;display:grid;gap:2px}.context-camera-pane footer strong,.context-camera-pane footer span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.context-camera-pane footer span{color:#a6a8b4;font-size:.78rem}.ha-weather-card{min-width:0;display:grid;gap:18px;border:1px solid rgba(255,255,255,.055);border-radius:8px;padding:clamp(18px,2.2vw,26px);color:#f4f5fb;background:#24252e;box-shadow:0 22px 54px #00000047,inset 0 1px #ffffff0a}.ha-weather-card header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:18px}.ha-weather-card header>svg{color:#f8d44c;filter:drop-shadow(0 8px 16px rgba(0,0,0,.24))}.ha-weather-card h2{max-width:100%;margin:0;overflow:hidden;color:#f4f5fb;font-size:clamp(1.45rem,2.3vw,2rem);font-weight:520;text-overflow:ellipsis;white-space:nowrap}.ha-weather-card header span,.ha-weather-card footer span,.ha-weather-card aside span{color:#a6a8b4}.ha-weather-card aside{display:grid;justify-items:end;gap:5px}.ha-weather-card aside strong{color:#f4f5fb;font-size:clamp(1.55rem,2.4vw,2rem);font-weight:520;line-height:1}.ha-forecast-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.ha-forecast-row article{min-width:0;display:grid;justify-items:center;gap:8px;color:#f4f5fb;text-align:center}.ha-forecast-row article>span{color:#9da0ac;font-size:.78rem;font-weight:800}.ha-forecast-row svg{color:#f4f5fb;filter:drop-shadow(0 5px 10px rgba(0,0,0,.24))}.ha-forecast-row strong{font-size:1rem;font-weight:520}.ha-forecast-row small{color:#a6a8b4;font-size:.86rem;font-weight:520}.ha-weather-card footer{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px}.ha-weather-card footer span,.ha-weather-card footer button,.ha-weather-card.loading button{display:inline-flex;align-items:center;gap:6px;border:0;color:#a6a8b4;background:transparent;font-size:.82rem;font-weight:760}.ha-weather-card footer button,.ha-weather-card.loading button{margin-left:auto;color:#d6d8e2}.ha-weather-card.loading{min-height:220px;place-items:center;align-content:center;text-align:center}.ha-weather-card.compact-context{height:100%;align-content:space-between;gap:14px;border-color:#ffffff09;border-radius:14px;padding:20px 20px 16px;background:#262832;box-shadow:0 18px 42px #0000003d,inset 0 1px #ffffff06}.ha-weather-card.compact-context header{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px}.ha-weather-card.compact-context header>svg{color:#fff;filter:drop-shadow(8px -7px 0 rgba(255,214,66,.95)) drop-shadow(0 8px 12px rgba(0,0,0,.22))}.weather-art{display:inline-grid;place-items:center;line-height:1;filter:drop-shadow(0 8px 14px rgba(0,0,0,.26))}.weather-art.main{width:58px;min-width:58px;height:58px;font-size:3.05rem}.weather-art.small{width:38px;height:34px;font-size:1.9rem;font-style:normal}.ha-weather-card.compact-context h2{color:#f3f4f8;font-size:clamp(1.34rem,1.55vw,1.78rem);font-weight:520;letter-spacing:0;line-height:1.08}.ha-weather-card.compact-context aside strong{color:#f5f6fb;font-size:clamp(1.42rem,1.8vw,1.95rem);font-weight:520;letter-spacing:0}.ha-weather-card.compact-context aside{grid-column:auto;display:grid;justify-items:end;gap:4px}.ha-weather-card.compact-context header span,.ha-weather-card.compact-context aside span{color:#a5a7b2;font-size:.88rem;font-weight:520}.ha-weather-card.compact-context .ha-forecast-row{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-top:2px}.ha-weather-card.compact-context .ha-forecast-row article{gap:7px}.ha-weather-card.compact-context .ha-forecast-row article:nth-child(n+6){display:none}.ha-weather-card.compact-context .ha-forecast-row article>span{color:#9da0ab;font-size:.76rem;font-weight:760}.ha-weather-card.compact-context .ha-forecast-row svg{color:#f7f8fb;filter:drop-shadow(5px -4px 0 rgba(255,214,66,.92)) drop-shadow(0 5px 9px rgba(0,0,0,.22))}.ha-weather-card.compact-context .ha-forecast-row strong,.ha-weather-card.compact-context .ha-forecast-row small{font-weight:520}.ha-weather-card.compact-context .ha-forecast-row strong{color:#f6f7fb;font-size:1rem}.ha-weather-card.compact-context .ha-forecast-row small{color:#a4a6b1;font-size:.86rem}.ha-weather-card.compact-context footer{margin-top:0;gap:8px 14px}.ha-weather-card.compact-context footer span,.ha-weather-card.compact-context footer button{color:#aaaeba;font-size:.78rem;font-weight:760}.ha-weather-card.compact-context.loading{min-height:160px}.camera-widget{min-height:235px;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:10px;padding:6px}.camera-stage{position:relative;min-height:180px;border-radius:8px;overflow:hidden;background:linear-gradient(145deg,#08121a75,#08121adb),linear-gradient(30deg,rgba(3,169,244,.18),transparent 44%),#11141c}.camera-stage img{width:100%;height:100%;min-height:180px;display:block;object-fit:cover}.camera-swipe-controls{position:absolute;inset:50% 14px auto;display:flex;justify-content:space-between;pointer-events:none;transform:translateY(-50%)}.camera-swipe-controls button{width:44px;height:44px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.24);border-radius:999px;color:#f8fbff;background:#080e1685;box-shadow:0 14px 30px #00000047;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;pointer-events:auto;transition:transform .18s ease,background .18s ease,border-color .18s ease}.camera-swipe-controls button:hover{border-color:#ffffff6b;background:#080e16b8;transform:scale(1.05)}.camera-dots{position:absolute;left:50%;bottom:12px;display:flex;gap:7px;transform:translate(-50%)}.camera-dots button{width:8px;height:8px;border:0;border-radius:999px;background:#ffffff70;cursor:pointer;transition:width .18s ease,background .18s ease}.camera-dots button.active{width:22px;background:#f8fbff}.camera-fake-frame{height:100%;min-height:180px;display:grid;place-items:center;align-content:center;gap:8px;color:#dff5ff;text-align:center}.camera-fake-frame svg{color:#81d4fa}.camera-fake-frame strong{color:#f7fafc;font-size:1.25rem}.camera-fake-frame span{color:#a6a8b4}.camera-live-pill{position:absolute;top:12px;left:12px;border:1px solid rgba(48,230,161,.42);border-radius:999px;padding:6px 9px;color:#c5ffe2;background:#30e6a11f;font-size:.72rem;font-weight:900}.camera-expand-button{position:absolute;top:10px;right:10px;width:34px;height:34px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.22);border-radius:999px;color:#f8fbff;background:#080e168a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer}.camera-live-pill.warning{border-color:#ffc8576b;color:#ffe6a8;background:#ffc85721}.camera-widget footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.camera-widget footer div{min-width:0;display:grid;gap:2px}.camera-widget footer strong,.camera-widget footer span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-widget footer span{color:#a6a8b4;font-size:.78rem}.camera-fullscreen-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:grid;place-items:center;padding:24px;background:#03080dc7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.camera-fullscreen-panel{width:min(1180px,94vw);display:grid;gap:12px;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:12px;background:#0b1118;box-shadow:0 28px 90px #0000007a}.camera-fullscreen-panel header{display:flex;align-items:center;justify-content:space-between;gap:14px}.camera-fullscreen-panel header div{min-width:0;display:grid;gap:2px}.camera-fullscreen-panel header span{color:#8fa4b2;font-size:.76rem;font-weight:820;text-transform:uppercase}.camera-fullscreen-panel header strong{min-width:0;overflow:hidden;color:#f7fafc;font-size:1.15rem;text-overflow:ellipsis;white-space:nowrap}.camera-fullscreen-stage{position:relative;min-height:min(70vh,720px);overflow:hidden;border-radius:8px;background:#05080d}.camera-fullscreen-stage img{width:100%;height:100%;min-height:min(70vh,720px);display:block;object-fit:contain}.google-map-widget{position:relative;min-height:330px;border-radius:8px;overflow:hidden;background:#0b1720}.google-map-widget iframe{width:100%;height:100%;min-height:330px;display:block;border:0;filter:saturate(.95) contrast(1.04)}.google-map-widget>div{position:absolute;left:14px;right:14px;bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:10px 12px;color:#f7fafc;background:#07121ad1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.google-map-widget strong,.google-map-widget span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.google-map-widget span{color:#b7c8cf;font-size:.82rem;font-weight:850}.history-page{display:grid;grid-template-columns:minmax(0,1fr);align-items:start;width:min(1720px,100%);margin:0 auto}.history-chart-panel{min-width:0;border:1px solid rgba(129,212,250,.2);border-radius:8px;padding:16px;background:linear-gradient(145deg,#0c1f23e6,#0a121af0),#0b1720;box-shadow:0 20px 54px #0000003d,inset 0 1px #ffffff0e}.history-actions button{min-width:0;border:1px solid rgba(129,212,250,.16);border-radius:8px;color:#dff5ff;background:#07121a85}.history-actions button.active{border-color:#30e6a17a;color:#f7fafc;background:#30e6a121}.history-chart-panel{position:relative;display:grid;grid-template-rows:auto minmax(520px,1fr) auto;gap:12px;min-height:calc(100vh - 36px)}.history-chart-head{display:grid;grid-template-columns:minmax(220px,1fr) minmax(0,auto);align-items:flex-start;gap:12px}.history-chart-head h2{margin:2px 0 0;color:#f7fafc}.history-chart-head span{color:#93a4b0;font-size:.78rem;font-weight:850}.history-actions{position:relative;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:7px;min-width:0}.history-actions button{min-height:42px;padding:0 14px;font-weight:900}.history-custom-range{margin:0}.history-chart{min-height:min(64vh,720px);height:100%}.history-metric-dock{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:8px;border:1px solid rgba(129,212,250,.16);border-radius:8px;background:#07121a6b}.history-metric-dock button{display:inline-grid;grid-template-columns:auto auto;gap:1px 8px;align-items:center;min-height:38px;border:1px solid rgba(129,212,250,.16);border-radius:8px;padding:6px 10px;color:#dff5ff;background:#07121a85}.history-metric-dock button i{grid-row:span 2;width:10px;height:10px;border-radius:999px}.history-metric-dock button strong,.history-metric-dock button small{line-height:1.05}.history-metric-dock button small{color:#93a4b0;font-size:.7rem}.history-metric-dock button.active{border-color:#30e6a17a;color:#f7fafc;background:#30e6a121}.history-export-menu{position:relative}.history-export-menu>button{min-height:42px;min-width:118px;justify-content:center;border-color:#03a9f485;background:linear-gradient(145deg,#03a9f442,#30e6a11f),#07121ab8;box-shadow:0 10px 24px #03a9f41f}.history-export-menu>div{position:absolute;top:calc(100% + 8px);right:0;z-index:8;display:grid;gap:6px;min-width:132px;border:1px solid rgba(129,212,250,.22);border-radius:8px;padding:8px;background:#07121af5;box-shadow:0 18px 48px #00000057}.history-export-menu>div button{justify-content:flex-start}.history-calendar-popover{position:absolute;top:70px;right:16px;z-index:7;width:min(780px,calc(100% - 32px));border:1px solid rgba(129,212,250,.22);border-radius:8px;padding:10px;background:#07121af7;box-shadow:0 18px 54px #00000061}.history-calendar-popover header{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:10px;margin-bottom:8px}.history-calendar-popover header span{display:block;color:#93a4b0;font-size:.76rem;font-weight:900;text-transform:uppercase}.history-calendar-popover header strong{display:block;margin-top:2px;color:#f7fafc;font-size:.98rem}.history-calendar-popover header button{min-height:30px;border:1px solid rgba(48,230,161,.34);border-radius:8px;padding:0 9px;color:#f4fffb;background:#30e6a121}.booking-calendar-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.booking-calendar-grid section{min-width:0;border:1px solid rgba(129,212,250,.14);border-radius:8px;padding:12px;background:linear-gradient(145deg,rgba(3,169,244,.08),transparent 52%),#0c1822d1}.booking-calendar-grid section>strong{display:block;margin-bottom:10px;color:#f7fafc;text-transform:capitalize}.booking-weekdays,.booking-days{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.booking-weekdays span{color:#7f95a4;font-size:.68rem;font-weight:850;text-align:center;text-transform:uppercase}.booking-days button{aspect-ratio:1;min-width:0;border:1px solid transparent;border-radius:8px;color:#dff5ff;background:#ffffff09;font-weight:850}.booking-days button:not(:disabled):hover{border-color:#7dd3fc6b;background:#7dd3fc1f}.booking-days button.blank{visibility:hidden}.booking-days button.today{border-color:#81d4fa5c}.booking-days button.inRange{border-radius:4px;background:#03a9f42e}.booking-days button.selected,.booking-days button.start,.booking-days button.end{border-color:#30e6a1a3;color:#07131a;background:#65f0b8}.gauge-widget-body{position:relative;display:grid;gap:8px}.gauge-chart{height:222px;margin-top:-4px}.gauge-group-body,.expanded-gauge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.compact-gauge-groups,.gauge-group-body.gauge-snap-focus,.expanded-gauge-grid.gauge-snap-focus{grid-template-columns:repeat(2,minmax(0,1fr))}.gauge-group-body.gauge-snap-max,.expanded-gauge-grid.gauge-snap-max{grid-template-columns:repeat(auto-fit,minmax(145px,1fr))}.expanded-gauge-grid{align-content:start}.gauge-mini-card{--gauge-accent: #3fbf8f;position:relative;min-width:0;display:grid;gap:2px;border:1px solid color-mix(in srgb,var(--gauge-accent) 28%,rgba(40,74,96,.55));border-radius:8px;padding:8px;background:radial-gradient(circle at 50% 18%,color-mix(in srgb,var(--gauge-accent) 16%,transparent),transparent 58%),linear-gradient(145deg,color-mix(in srgb,var(--gauge-accent) 18%,transparent),transparent 58%),#0912193d;box-shadow:0 14px 34px #0000002e,0 3px 18px color-mix(in srgb,var(--gauge-accent) 18%,transparent),inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(8px) saturate(1.12);backdrop-filter:blur(8px) saturate(1.12);overflow:hidden;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,filter .18s ease}.gauge-mini-card:hover{transform:translateY(-2px);filter:saturate(1.14);box-shadow:0 18px 42px #00000038,0 5px 24px color-mix(in srgb,var(--gauge-accent) 24%,transparent),inset 0 1px #ffffff12}.gauge-metric-emoji{position:absolute;top:8px;left:8px;z-index:2;width:28px;height:28px;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--gauge-accent, #3fbf8f) 42%,rgba(147,164,176,.2));border-radius:8px;background:linear-gradient(145deg,color-mix(in srgb,var(--gauge-accent, #3fbf8f) 18%,transparent),transparent 62%),#051018b8;box-shadow:0 8px 20px #0000002e;font-size:.96rem;font-weight:950;letter-spacing:0;line-height:1}.gauge-slot-toggle{position:absolute;top:8px;right:8px;z-index:3;min-width:30px;height:28px;display:inline-grid;place-items:center;border:1px solid color-mix(in srgb,var(--gauge-accent, #3fbf8f) 48%,rgba(147,164,176,.18));border-radius:8px;padding:0 7px;color:#f7fafc;background:linear-gradient(145deg,color-mix(in srgb,var(--gauge-accent, #3fbf8f) 18%,transparent),transparent 62%),#051018c7;font-size:.7rem;font-weight:950;line-height:1;box-shadow:0 8px 18px #0000002e}.gauge-mini-card.ok{border-color:color-mix(in srgb,var(--gauge-accent) 42%,rgba(40,74,96,.55))}.gauge-mini-card.warn{border-color:#d8a23a61}.gauge-mini-card.cold-warn{border-color:#74d3ff75;background:radial-gradient(circle at 50% 18%,rgba(116,211,255,.16),transparent 58%),#74d3ff0a}.gauge-mini-card.cold-alert{border-color:#8b5cf680;background:radial-gradient(circle at 50% 18%,rgba(139,92,246,.18),transparent 58%),#8b5cf60d}.gauge-mini-card.alert{border-color:#d9665b75;background:radial-gradient(circle at 50% 18%,rgba(217,102,91,.16),transparent 58%),#d9665b0b}.gauge-mini-card.fault{border-color:#a3a3b880;background:radial-gradient(circle at 50% 18%,rgba(139,92,246,.14),transparent 58%),#8b5cf609}.gauge-mini-chart{height:142px;min-width:0}.gauge-mini-chart.compact{height:126px}.gauge-snap-focus .gauge-mini-chart{height:188px}.gauge-snap-max .gauge-mini-chart{height:122px}.gauge-mini-chart.large{height:190px}.gauge-mini-chart.large.compact{height:132px}.gauge-mini-caption{min-width:0;display:flex;justify-content:space-between;gap:8px;align-items:center;margin-top:-8px}.gauge-bundle-card{gap:6px;padding:8px 8px 7px}.gauge-bundle-card .gauge-mini-caption{margin-top:-6px}.gauge-bundle-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));gap:5px;margin-top:1px}.gauge-bundle-values button{min-width:0;min-height:38px;display:grid;align-content:center;gap:1px;border:1px solid color-mix(in srgb,var(--gauge-accent) 34%,rgba(129,212,250,.12));border-radius:8px;padding:5px 6px;color:#eaf9ff;background:linear-gradient(145deg,color-mix(in srgb,var(--gauge-accent) 13%,transparent),transparent 68%),#06121b47;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);text-align:left}.gauge-bundle-values span,.gauge-bundle-values strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gauge-bundle-values span{color:#93a4b0;font-size:.56rem;font-weight:850;text-transform:uppercase}.gauge-bundle-values strong{color:#f7fafc;font-size:.74rem;font-weight:950}.wind-bundle{display:grid;grid-template-columns:minmax(74px,.75fr) minmax(0,1.2fr);align-items:center;gap:4px}.wind-compass-card.mini{min-height:108px}.wind-compass-card.mini .wind-compass{width:min(76px,84%)}.gauge-mini-card strong,.gauge-mini-card span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gauge-mini-card strong{color:#f7fafc;font-size:.78rem;font-weight:950}.gauge-mini-card span{color:#93a4b0;font-size:.66rem;font-weight:850}.wind-compass-card{position:relative;min-width:0;min-height:142px;display:grid;place-items:center;align-content:center;gap:4px;color:#eaf8ff}.expanded-gauge-shell{position:relative;min-height:min(58vh,520px)}.expanded-gauge-shell .gauge-metric-emoji,.wind-compass-card.expanded-compass .gauge-metric-emoji{width:38px;height:38px;font-size:1.35rem}.wind-compass-card.large{min-height:190px}.wind-compass-card.expanded-compass{min-height:min(58vh,520px)}.wind-compass-card.expanded-compass .wind-compass{width:min(320px,70vw)}.wind-compass-card.expanded-compass>strong{font-size:2rem}.wind-compass-card.expanded-compass>small{font-size:1rem}.wind-compass-card>strong{color:#f7fbff;font-size:1rem;font-weight:950;line-height:1}.wind-compass-card>small{color:#8fb6c8;font-size:.7rem;font-weight:850}.wind-compass{position:relative;width:min(110px,78%);aspect-ratio:1;border:1px solid color-mix(in srgb,var(--gauge-accent) 42%,rgba(147,164,176,.22));border-radius:50%;background:radial-gradient(circle at center,rgba(247,250,252,.12) 0 8%,transparent 9%),conic-gradient(from 0deg,color-mix(in srgb,var(--gauge-accent) 24%,transparent),transparent 18%,rgba(255,255,255,.06) 25%,transparent 32%,color-mix(in srgb,var(--gauge-accent) 18%,transparent) 50%,transparent 62%,rgba(255,255,255,.05) 75%,transparent 85%),#06121b94;box-shadow:inset 0 0 22px #00000042,0 10px 26px color-mix(in srgb,var(--gauge-accent) 16%,transparent)}.wind-compass span{position:absolute;color:#dff5ff;font-size:.62rem;font-weight:950;line-height:1}.wind-compass .north{top:8px;left:50%;transform:translate(-50%);color:var(--gauge-accent)}.wind-compass .east{right:9px;top:50%;transform:translateY(-50%)}.wind-compass .south{bottom:8px;left:50%;transform:translate(-50%)}.wind-compass .west{left:9px;top:50%;transform:translateY(-50%)}.wind-compass i{position:absolute;left:calc(50% - 2px);bottom:50%;width:4px;height:37%;border-radius:999px 999px 2px 2px;background:linear-gradient(180deg,var(--gauge-accent),#f7fbff);box-shadow:0 0 14px color-mix(in srgb,var(--gauge-accent) 55%,transparent);transform:rotate(var(--compass-deg));transform-origin:50% 100%}.wind-compass b{position:absolute;inset:50% auto auto 50%;width:13px;aspect-ratio:1;border:2px solid var(--gauge-accent);border-radius:50%;background:#071925;box-shadow:0 0 0 4px #f7fafc14;transform:translate(-50%,-50%)}.gauge-threshold-strip{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;margin-top:-12px}.gauge-threshold-strip span{border:1px solid rgba(147,164,176,.18);border-radius:999px;padding:4px 8px;color:#93a4b0;background:#0c161e70;font-size:.68rem;font-weight:850}.gauge-threshold-strip .ok{border-color:#3fbf8f57;color:#a8dec8}.gauge-threshold-strip .warn{border-color:#d8a23a6b;color:#e7c987}.gauge-threshold-strip .cold-warn{border-color:#74d3ff75;color:#b9ecff}.gauge-threshold-strip .cold-alert{border-color:#8b5cf680;color:#ddd6fe}.gauge-status-pill{display:grid;gap:3px;border:1px solid rgba(40,74,96,.55);border-radius:8px;padding:8px 10px;background:#12212c85}.gauge-status-pill strong{font-size:.78rem;font-weight:950}.gauge-status-pill span{color:#93a4b0;font-size:.72rem;line-height:1.25}.gauge-status-pill.ok{border-color:#3fbf8f57;color:#a8dec8}.gauge-status-pill.warn{border-color:#d8a23a6b;color:#e7c987}.gauge-status-pill.cold-warn{border-color:#74d3ff75;color:#b9ecff;background:#74d3ff14}.gauge-status-pill.cold-alert{border-color:#8b5cf680;color:#ddd6fe;background:#8b5cf61f}.gauge-status-pill.alert{border-color:#d9665b7a;color:#e8aaa4;background:#d9665b14}.gauge-status-pill.fault{border-color:#a3a3b87a;color:#d7d7e6;background:#8b5cf614}.widget-live-body,.widget-chart-stack{display:grid;gap:10px}.metric-panel-body{display:grid;gap:7px}.metric-panel-gauges{display:grid;gap:8px}.metric-panel-gauge-row{grid-template-columns:repeat(auto-fit,minmax(136px,1fr))}.metric-panel-gauge-row.meteo-grid{grid-template-columns:repeat(auto-fit,minmax(118px,1fr))}.metric-panel-timeline{position:relative;display:grid;gap:6px;min-width:0;overflow:hidden;border:1px solid rgba(40,74,96,.42);border-radius:8px;padding:7px;background:#06121b61;box-shadow:inset 0 1px #ffffff0a}.metric-panel-timeline .compact-panel-chart{height:185px!important;min-height:185px!important;width:100%;min-width:0}.metric-panel-timeline .timeline-metric-picker.compact{flex-wrap:nowrap;max-height:none;overflow-x:auto;overflow-y:hidden;padding:5px}.metric-panel-timeline .timeline-metric-picker.compact button{flex:0 0 auto;min-height:26px;padding:3px 7px}.expanded-metric-panel{grid-template-rows:auto minmax(300px,1fr);min-height:0}.single-metric-card{min-height:152px;padding:8px}.metric-panel-gauge-row .gauge-mini-chart.compact{height:110px}.metric-panel-gauge-row .wind-compass-card.mini{min-height:110px}.metric-panel-gauge-row .wind-compass-card.mini .wind-compass{width:min(82px,82%)}.single-metric-card .gauge-mini-caption{margin-top:-3px}.single-metric-card .gauge-metric-emoji{width:27px;height:27px;font-size:.94rem}.widget-type-metricPanel{padding:12px}.widget-type-metricPanel .widget-head{align-items:center}.widget-type-metricPanel .widget-head h2{font-size:1.08rem}.timeline-chart{min-height:310px}.timeline-range-presets{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-end}.timeline-range-presets button{min-height:28px;border:1px solid rgba(147,164,176,.16);border-radius:999px;padding:4px 9px;color:#8ea0ad;background:#0c182280;font-size:.7rem;font-weight:900}.timeline-range-presets button.active{border-color:#03a9f494;color:#f7fafc;background:linear-gradient(145deg,#03a9f438,#81d4fa14),#03a9f429;box-shadow:0 8px 22px #03a9f41f}.timeline-custom-range{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;padding:0;overflow:hidden;border:1px solid rgba(3,169,244,.32);border-radius:8px;background:linear-gradient(90deg,rgba(3,169,244,.13),transparent 45%),#09121994}.timeline-custom-range label{display:grid;grid-template-columns:auto minmax(0,1fr);gap:2px 10px;align-items:center;min-width:0;padding:10px 12px;color:#a8b9c4;font-size:.7rem;font-weight:850;text-transform:uppercase}.timeline-custom-range label+label{border-left:1px dashed rgba(148,183,204,.32)}.timeline-custom-range label:before{content:"";grid-row:span 3;width:10px;height:10px;border:2px solid #7dd3fc;border-radius:50%;background:#0b1822;box-shadow:0 0 0 4px #7dd3fc1a}.timeline-custom-range strong{color:#f7fafc;font-size:1.02rem;text-transform:none}.timeline-custom-range input{grid-column:2;min-width:0;height:34px;border:0;border-radius:8px;padding:0 8px;color:#f7fafc;background:#ffffff0f}.timeline-metric-picker{display:flex;flex-wrap:wrap;gap:7px;align-items:center;padding:8px;border:1px solid rgba(40,74,96,.48);border-radius:8px;background:#09121961;box-shadow:inset 0 1px #ffffff0a}.timeline-metric-picker>span{color:#93a4b0;font-size:.74rem;font-weight:850;margin-right:4px}.timeline-metric-picker button{min-height:30px;display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(147,164,176,.18);border-radius:999px;padding:5px 9px;color:#93a4b0;background:linear-gradient(180deg,#1629379e,#0a141d94);font-size:.74rem;font-weight:850}.timeline-metric-picker button.active{border-color:#03a9f48f;color:#f7fafc;background:linear-gradient(145deg,#03a9f438,#81d4fa0f),#03a9f421;box-shadow:0 8px 22px #03a9f41c}.timeline-metric-picker i{width:18px;height:4px;border-radius:999px;box-shadow:0 0 0 1px #ffffff14}.timeline-metric-picker small{color:#6f818d;font-size:.68rem}.timeline-metric-picker.compact{align-items:flex-start;max-height:150px;overflow:auto}.timeline-metric-picker.compact button{min-height:28px;padding:4px 8px;font-size:.7rem}.expanded-timeline-stack{min-width:0;display:grid;gap:10px}.compact-editor{padding:10px}.compact-compare{max-height:86px;overflow:auto}.widget-table,.expanded-widget-table{display:grid;gap:8px}.widget-table button,.expanded-widget-table button{min-width:0;min-height:42px;display:grid;grid-template-columns:auto minmax(0,1.2fr) minmax(0,1fr) auto;align-items:center;gap:8px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:0 10px;color:#f7fafc;background:#12212cf5;text-align:left}.widget-table strong,.widget-table small,.expanded-widget-table strong,.expanded-widget-table small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.widget-table small,.widget-table em,.expanded-widget-table small{color:#93a4b0;font-style:normal}.widget-expanded-backdrop{position:fixed;z-index:1080;top:0;right:0;bottom:0;left:248px;display:grid;justify-items:end;align-items:stretch;padding:0;background:#030a105c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.widget-expanded-backdrop.collapsed{left:78px}.widget-expanded-panel{width:100%;height:100%;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px;border:0;border-left:1px solid rgba(129,212,250,.34);border-radius:0;padding:18px;background:radial-gradient(circle at 82% 0%,rgba(3,169,244,.18),transparent 34rem),linear-gradient(180deg,#0e1f2bfa,#08131cfc),#08131c;box-shadow:-24px 0 56px #00000057;animation:widgetDrawerIn .18s ease-out}@keyframes widgetDrawerIn{0%{transform:translate(28px);opacity:.78}to{transform:translate(0);opacity:1}}.widget-expanded-content{min-height:0;display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.widget-expanded-content.advanced-open{grid-template-columns:minmax(0,1fr) minmax(280px,360px)}.expanded-detail-main{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px}.expanded-detail-tabs,.chart-mode-toolbar{display:flex;flex-wrap:wrap;gap:8px}.expanded-detail-tabs button,.chart-mode-toolbar button{min-height:34px;border:1px solid rgba(129,212,250,.18);border-radius:999px;padding:0 13px;color:#9fb3bf;background:#0c1822a8;font-weight:900}.expanded-detail-tabs button.active,.chart-mode-toolbar button.active{border-color:#03a9f4b3;color:#e8f8ff;background:linear-gradient(145deg,#03a9f438,#81d4fa14),#03a9f42e;box-shadow:0 10px 26px #03a9f41a}.expanded-overview-grid,.expanded-notification-panel{min-height:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;overflow:auto}.expanded-info-card,.expanded-notification-panel article,.expanded-data-table{min-width:0;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;background:linear-gradient(145deg,rgba(3,169,244,.11),transparent 48%),#0a1822b8;box-shadow:0 14px 34px #00000029,inset 0 1px #ffffff0b}.expanded-info-card>span,.expanded-notification-panel article>span,.expanded-data-table header span{display:block;margin-bottom:10px;color:#93a4b0;font-size:.72rem;font-weight:900;text-transform:uppercase}.expanded-metric-grid,.expanded-action-grid,.notification-channel-grid{display:grid;gap:8px}.expanded-metric-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.expanded-metric-grid button,.expanded-action-grid button,.notification-channel-grid label{min-width:0;min-height:58px;display:grid;align-content:center;gap:3px;border:1px solid rgba(129,212,250,.16);border-radius:8px;padding:9px 10px;color:#e8f8ff;background:#09121994;text-align:left}.expanded-metric-grid strong{font-size:1.16rem}.expanded-metric-grid small,.expanded-metric-grid em{color:#93a4b0;font-style:normal;font-weight:850}.expanded-action-grid button,.notification-channel-grid label{display:flex;align-items:center;gap:8px}.notification-channel-grid label{position:relative;border-color:color-mix(in srgb,var(--channel-color, #03a9f4) 24%,rgba(129,212,250,.12));background:linear-gradient(145deg,color-mix(in srgb,var(--channel-color, #03a9f4) 12%,transparent),transparent 54%),#0912199e;overflow:hidden}.notification-channel-grid label:before{content:"";width:5px;align-self:stretch;border-radius:999px;background:var(--channel-color, #03a9f4);box-shadow:0 0 18px color-mix(in srgb,var(--channel-color, #03a9f4) 48%,transparent)}.notification-channel-grid label.enabled{border-color:color-mix(in srgb,var(--channel-color, #03a9f4) 58%,rgba(255,255,255,.12));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--channel-color, #03a9f4) 18%,transparent),0 12px 28px color-mix(in srgb,var(--channel-color, #03a9f4) 12%,transparent)}.notification-channel-grid label.telegram{--channel-color: #2aabee}.notification-channel-grid label.mail{--channel-color: #f0c95a;color:#fff5c8}.notification-channel-grid label.audio{--channel-color: #35d07f}.notification-channel-grid label.popup{--channel-color: #03a9f4}.notification-channel-grid input[type=checkbox]{width:38px;height:22px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid color-mix(in srgb,var(--channel-color, #03a9f4) 44%,rgba(255,255,255,.12));border-radius:999px;background:#01080d94}.notification-channel-grid input[type=checkbox]:after{content:"";display:block;width:16px;height:16px;margin:2px;border-radius:999px;background:#78909c;transition:transform .14s ease,background .14s ease}.notification-channel-grid input[type=checkbox]:checked:after{transform:translate(16px);background:var(--channel-color, #03a9f4)}.notification-channel-grid small{margin-left:auto;color:color-mix(in srgb,var(--channel-color, #03a9f4) 70%,#f7fafc);font-weight:900}.expanded-threshold-card{grid-column:span 2}.widget-threshold-list{display:grid;gap:10px}.widget-threshold-row{display:grid;gap:10px;border:1px solid rgba(129,212,250,.12);border-radius:8px;padding:12px;background:radial-gradient(circle at 92% 8%,rgba(3,169,244,.1),transparent 16rem),#09121994}.widget-threshold-row header{display:flex;align-items:center;justify-content:space-between;gap:10px}.widget-threshold-row header small{display:block;margin-top:3px;color:#93a4b0;font-weight:850}.threshold-save-pill{min-height:34px;display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(3,169,244,.34);border-radius:999px;padding:0 11px;color:#dff5ff;background:#03a9f41f;font-weight:900}.threshold-menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.threshold-menu-card{--threshold-color: #f0c95a;display:grid;gap:8px;border:1px solid color-mix(in srgb,var(--threshold-color) 36%,rgba(129,212,250,.12));border-radius:8px;padding:10px;background:linear-gradient(145deg,color-mix(in srgb,var(--threshold-color) 13%,transparent),transparent 56%),#0a1822a8;box-shadow:inset 0 1px #ffffff0a}.threshold-menu-card.alert{--threshold-color: #ff6b64}.threshold-menu-card>div{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.threshold-menu-card>div strong{color:var(--threshold-color);font-size:.92rem}.threshold-menu-card>div small{color:#93a4b0;font-size:.72rem;font-weight:850}.threshold-menu-card label{display:grid;grid-template-columns:36px auto minmax(0,1fr);align-items:center;gap:7px;min-height:38px;border:1px solid rgba(129,212,250,.12);border-radius:8px;padding:6px 8px;background:#030a105c}.threshold-menu-card label span{color:var(--threshold-color);font-weight:950}.threshold-menu-card input[type=checkbox]{accent-color:var(--threshold-color)}.threshold-menu-card input[type=number]{width:100%;min-height:30px;border:1px solid rgba(129,212,250,.14);border-radius:8px;padding:0 8px;color:#f7fafc;background:#030a107a}.threshold-menu-card input[type=number]:disabled{opacity:.42}.threshold-four-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.threshold-four-grid label{display:grid;grid-template-columns:auto auto;gap:6px;align-items:center;border:1px solid color-mix(in srgb,var(--threshold-color) 34%,rgba(129,212,250,.12));border-radius:8px;padding:8px;background:linear-gradient(145deg,color-mix(in srgb,var(--threshold-color) 12%,transparent),transparent 56%),#0a18229e}.threshold-four-grid label.warn{--threshold-color: #f0c95a}.threshold-four-grid label.alert{--threshold-color: #ff6b64}.threshold-four-grid span{color:var(--threshold-color);font-size:.72rem;font-weight:950;text-transform:uppercase}.threshold-four-grid input[type=checkbox]{justify-self:end;accent-color:var(--threshold-color)}.threshold-four-grid input[type=number]{grid-column:1 / -1;width:100%;min-height:34px;border:1px solid rgba(129,212,250,.16);border-radius:8px;padding:0 8px;color:#f7fafc;background:#030a1070}.threshold-four-grid input[type=number]:disabled{opacity:.42}.service-event-list{display:grid;gap:8px}.service-event-list div{border-left:3px solid #3fbf8f;border-radius:8px;padding:9px 10px;background:#09121994}.service-event-list div.alert{border-left-color:#ff7c72}.service-event-list small{display:block;color:#93a4b0;margin-top:3px}.expanded-chart-mode-panel{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:10px}.smart-chart-panel{overflow:hidden}.smart-chart-grid{min-height:0;display:grid;grid-template-columns:minmax(220px,.34fr) minmax(0,1fr);gap:12px}.smart-gauge-strip{min-height:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(156px,1fr));align-content:start;gap:10px;overflow:auto}.smart-main-chart{min-width:0;min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;gap:10px}.chart-notification-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.chart-notification-bar button{min-width:0;min-height:38px;display:grid;grid-template-columns:auto minmax(0,.7fr) minmax(0,1fr);align-items:center;gap:7px;border:1px solid rgba(240,201,90,.26);border-radius:999px;padding:0 11px;color:#fff5c8;background:linear-gradient(145deg,#f0c95a1f,#ff6b6414),#0912199e;font-weight:900}.chart-notification-bar button span,.chart-notification-bar button strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-notification-bar button span{color:#ffdf86;font-size:.72rem}.compact-presets{justify-content:flex-end}.smart-main-chart .expanded-widget-chart{min-height:360px}.pulse-widget-card{--pulse-color: #03a9f4;position:relative;min-height:238px;display:grid;grid-template-rows:auto minmax(120px,1fr) auto;gap:10px;border:1px solid color-mix(in srgb,var(--pulse-color) 34%,rgba(40,74,96,.72));border-radius:8px;padding:14px;background:radial-gradient(circle at 80% 4%,color-mix(in srgb,var(--pulse-color) 18%,transparent),transparent 26rem),#09121994;overflow:hidden}.pulse-widget-card:after{content:"";position:absolute;inset:auto 18px 12px;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--pulse-color) 52%,transparent),transparent);animation:pulseScanline 2.2s linear infinite}.pulse-widget-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.pulse-widget-head span{display:inline-flex;align-items:center;gap:8px;color:#93a4b0;font-weight:900}.pulse-metric-title i{width:34px;height:34px;display:inline-grid;place-items:center;border:1px solid rgba(255,255,255,.18);border-radius:8px;color:#fff;background:linear-gradient(145deg,#ffffff29,#ffffff0a),color-mix(in srgb,var(--pulse-color) 22%,rgba(8,18,26,.9));box-shadow:0 10px 22px #00000038,inset 0 1px #ffffff2e;font-style:normal}.pulse-widget-head strong{color:#f7fafc;font-size:1.7rem}.pulse-widget-head small{color:#93a4b0;font-size:.82rem}.iot-pulse-svg{width:100%;height:100%;min-height:126px}.iot-pulse-svg polyline{fill:none;stroke:var(--pulse-color);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:100 100;animation:pulseTrace 5s linear infinite;filter:drop-shadow(0 0 8px color-mix(in srgb,var(--pulse-color) 48%,transparent))}.iot-pulse-svg .axis-line{stroke:#93a4b03d;stroke-width:1}.pulse-threshold-line{stroke-width:1.5;stroke-dasharray:5 5}.pulse-threshold-line.warn{stroke:#f0c95a}.pulse-threshold-line.alert{stroke:#ff6b64}.pulse-notification-strip{display:flex;flex-wrap:wrap;gap:7px;padding-right:24px}.pulse-notification-strip span{border:1px solid rgba(129,212,250,.14);border-radius:999px;padding:5px 8px;color:#93a4b0;background:#030a105c;font-size:.72rem;font-weight:900}.pulse-notification-strip span.warn{border-color:#f0c95a66;color:#ffe39b;background:#f0c95a1c}.pulse-notification-strip span.alert{border-color:#ff6b646b;color:#ffd6d3;background:#ff6b641f}@keyframes pulseTrace{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}@keyframes pulseScanline{0%{transform:translate(-45%);opacity:0}35%{opacity:1}to{transform:translate(45%);opacity:0}}.expanded-data-table{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr)}.expanded-data-table header{display:flex;align-items:center;justify-content:space-between;gap:10px}.expanded-table-scroll{min-height:0;overflow:auto}.expanded-table-scroll table{width:100%;border-collapse:collapse;color:#e8f8ff;font-size:.82rem}.expanded-table-scroll th,.expanded-table-scroll td{border-bottom:1px solid rgba(129,212,250,.11);padding:9px 8px;text-align:left;white-space:nowrap}.expanded-table-scroll th{color:#93a4b0;font-size:.72rem;text-transform:uppercase}.expanded-widget-chart{min-height:0;height:100%;border:1px solid rgba(40,74,96,.72);border-radius:8px;background:#0a1822b8}.widget-advanced-panel{min-height:0;display:grid;align-content:start;gap:10px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;background:#0f1b25eb;overflow:auto}.widget-advanced-panel header span{display:block;color:#93a4b0;font-size:.72rem;font-weight:850;text-transform:uppercase}.dashboard-filter-row,.dashboard-actions{display:flex;flex-wrap:wrap;gap:8px}.dashboard-filter-row button,.dashboard-actions button,.soft-action{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:0 11px;color:#dff5ff;background:#03a9f414}.dashboard-filter-row button.active{border-color:#03a9f4ad;color:#04131b;background:#03a9f4;font-weight:900}.dashboard-actions{margin-top:12px}.sensor-board{display:grid;gap:10px}.panel-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.quick-board-editor{display:grid;gap:10px;border:1px solid rgba(3,169,244,.28);border-radius:8px;padding:12px;background:linear-gradient(145deg,rgba(3,169,244,.1),transparent 46%),#0c1923eb}.quick-board-editor header{display:flex;align-items:center;justify-content:space-between;gap:10px}.quick-board-editor header span{display:block;color:#93a4b0;font-size:.72rem;font-weight:850;text-transform:uppercase}.quick-device-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:8px}.quick-device-picker button{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr);gap:3px 8px;align-items:center;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;color:#dff5ff;background:#03a9f40f;text-align:left}.quick-device-picker button.active{border-color:#03a9f4b8;background:#03a9f42e;box-shadow:inset 0 0 0 1px #03a9f433}.quick-device-picker strong,.quick-device-picker small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-device-picker small{grid-column:2;color:#93a4b0}.sensor-tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(180px,22vw,260px),1fr));gap:clamp(10px,1.2vw,16px);align-items:stretch}.live-carousel-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:10px}.live-carousel-toolbar button{min-height:32px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid rgba(129,212,250,.2);border-radius:999px;padding:0 10px;color:#dff5ff;background:#03a9f41a;font-weight:900}.live-carousel-toolbar button:not(.see-all){width:34px;padding:0}.live-carousel-toolbar strong{color:#93a4b0;font-size:.78rem;font-weight:900}.live-carousel-toolbar .see-all{border-color:#03a9f46b;background:#03a9f429}.widget-live-compact .live-carousel-toolbar{margin-top:-2px}.widget-live-compact{padding-bottom:12px}.widget-live-compact .widget-live-body{min-width:0}.widget-live-compact .sensor-tile-grid{grid-auto-flow:row;grid-auto-columns:unset;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:8px;overflow:visible;padding:2px}.widget-live-compact .sensor-tile{min-height:66px;padding:6px;gap:2px}.metric-carousel-grid{grid-template-columns:repeat(auto-fit,minmax(118px,1fr))}.widget-live-compact .metric-carousel-grid{grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:8px}.metric-sensor-tile{min-height:82px;aspect-ratio:1.42 / 1;grid-template-columns:1fr;justify-items:center;align-content:center;gap:4px;padding:8px 7px;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.08),transparent 42%),linear-gradient(145deg,#ffffff09,#03a9f413),#091219a8;text-align:center}.metric-sensor-tile em{grid-column:1;display:inline-flex;align-items:baseline;justify-content:center;gap:3px;color:#f7fafc;font-size:.94rem;font-style:normal;font-weight:950;line-height:1}.metric-sensor-tile em small{color:#9fb2bd;font-size:.56rem;font-weight:850;line-height:1}.metric-white-icon{grid-row:auto;width:34px;height:34px;display:inline-grid;place-items:center;border:1px solid rgba(255,255,255,.14);border-radius:14px;color:#eef7fcd1;background:radial-gradient(circle at 32% 22%,rgba(255,255,255,.2),transparent 30%),linear-gradient(145deg,#ffffff1f,#03a9f412),#ffffff09;box-shadow:0 10px 22px #00000029,inset 0 1px #ffffff1f;opacity:.9}.metric-white-icon.metric-hot,.metric-white-icon.metric-water,.metric-white-icon.metric-dust,.metric-white-icon.metric-gas,.metric-white-icon.metric-wind,.metric-white-icon.metric-sun,.metric-white-icon.metric-energy,.metric-white-icon.metric-default{--metric-tone: rgba(238, 247, 252, .82)}.widget-live-compact .metric-sensor-tile strong{grid-column:1;color:#dff5ff;font-size:.7rem;line-height:1.05;max-width:100%;text-align:center}.widget-live-compact .metric-sensor-tile small,.widget-live-compact .metric-sensor-tile span:last-child{display:none}.widget-live-compact .sensor-tile small{display:none}.widget-live-compact .quick-metric-grid{grid-template-columns:repeat(auto-fit,minmax(44px,1fr));gap:3px;overflow:visible;padding-bottom:0}.widget-live-compact .quick-metric-grid button{min-height:32px;padding:4px}.widget-live-compact .quick-metric-grid span{font-size:.52rem}.widget-live-compact .quick-metric-grid strong{font-size:.68rem}.sensor-tile{position:relative;min-width:0;min-height:168px;display:grid;align-content:start;gap:8px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:clamp(11px,1.2vw,15px);color:#f7fafc;background:linear-gradient(145deg,rgba(3,169,244,.11),transparent 44%),#111d27;text-align:left;cursor:pointer;box-shadow:0 16px 34px #00000038,0 2px 12px #03a9f411,inset 0 1px #ffffff0e}.sensor-tile:hover{border-color:#03a9f480;transform:translateY(-1px);box-shadow:0 20px 44px #00000042,0 5px 18px #03a9f41c,inset 0 1px #ffffff12}.tile-remove-button{position:absolute;top:8px;right:8px;width:30px;height:30px;display:grid;place-items:center;border:1px solid rgba(255,124,114,.38);border-radius:999px;color:#ffd8d5;background:#ff7c721f}.tile-remove-button:hover{border-color:#ff7c72b8;background:#ff7c7233}.quick-empty{grid-column:1 / -1}.sensor-tile strong,.sensor-tile small,.sensor-tile span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sensor-tile small,.sensor-tile span{color:#93a4b0}.sensor-tile em{color:#81d4fa;font-size:1.25rem;font-style:normal;font-weight:950}.quick-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(74px,7vw,110px),1fr));gap:6px;margin-top:2px}.quick-metric-grid button{min-width:0;min-height:48px;display:grid;align-content:center;gap:2px;border:1px solid rgba(3,169,244,.24);border-radius:8px;padding:7px 8px;color:#dff5ff;background:#03a9f414;text-align:left}.quick-metric-grid button:hover{border-color:#03a9f480;background:#03a9f424}.quick-metric-grid span,.quick-metric-grid strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-metric-grid span{color:#93a4b0;font-size:clamp(.58rem,.68vw,.68rem);font-weight:850;text-transform:uppercase}.quick-metric-grid strong{color:#eaf9ff;font-size:clamp(.76rem,.86vw,.94rem);line-height:1.05}.add-tile{place-items:center;text-align:center;border-style:dashed;background:#03a9f40f}.donut-summary{display:grid;place-items:center;gap:7px;min-height:190px}.donut-ring{width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,#0f1c27 0 56%,transparent 57%),conic-gradient(#03a9f4 0 var(--online),rgba(255,124,114,.72) var(--online) 100%);box-shadow:inset 0 0 0 1px #ffffff0a,0 14px 30px #0003}.compact-list{display:grid;gap:8px}.compact-list button{min-width:0;height:36px;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;border:1px solid rgba(255,124,114,.25);border-radius:8px;padding:0 10px;color:#f7fafc;background:#ff7c7214;text-align:left}.compact-list span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.floor-map{min-height:236px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(72px,1fr);gap:8px}.floor-map button{min-width:0;display:grid;align-content:center;gap:4px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;color:#f7fafc;background:#12212cf5;text-align:left}.floor-map button.online{border-color:#03a9f46b;background:linear-gradient(145deg,rgba(3,169,244,.14),transparent 48%),#12212cf5}.floor-map span,.floor-map strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.floor-map span{color:#93a4b0;font-size:.75rem;font-weight:820}.wide-panel{grid-column:span 3;min-width:0;padding:16px}.wide-panel.full{grid-column:1 / -1}.side-panel{padding:16px}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.panel-head h2,.panel-head h3{margin:2px 0 0}.main-chart{height:290px}.large-chart{height:460px}.mini-chart,.widget-h-compact .main-chart{height:230px}.widget-h-tall .main-chart{height:390px}.widget-h-compact .mini-chart{height:190px}.widget-h-tall .mini-chart{height:320px}.widget-h-compact .timeline-chart{min-height:240px}.widget-h-tall .timeline-chart{min-height:420px}.widget-h-compact .gauge-chart{height:190px}.widget-h-tall .gauge-chart{height:280px}.widget-h-compact .gauge-mini-chart{height:116px}.widget-h-tall .gauge-mini-chart{height:180px}.widget-h-tall .gauge-group-body{grid-template-columns:repeat(2,minmax(0,1fr))}.metric-select{width:min(190px,100%);height:36px}.compare-device-picker{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.compare-device-picker button{min-width:150px;min-height:42px;display:grid;grid-template-columns:auto minmax(0,1fr);gap:2px 8px;align-items:center;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:7px 9px;color:#dff5ff;background:#03a9f40f;text-align:left}.compare-device-picker button.active{border-color:#03a9f4b3;background:#03a9f42b;box-shadow:0 10px 24px #03a9f41a}.compare-device-picker strong,.compare-device-picker small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compare-device-picker small{grid-column:2;color:#93a4b0;font-size:.72rem}.gateway-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:4px 9px;align-items:center;border-top:1px solid #22313c;padding:10px 0}.gateway-row strong,.gateway-row small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gateway-row small{grid-column:2 / -1;color:#93a4b0}.ok{color:#03a9f4}.warn{color:#ffc857}.alert{color:#ff7c72}.module-tabs,.admin-tabs{display:flex;flex-wrap:wrap;gap:8px}.module-tabs button,.admin-tabs button{min-height:40px;display:inline-flex;align-items:center;gap:8px;padding:0 12px;color:#9babb5}.module-tabs button.active,.admin-tabs button.active{border-color:#03a9f49e;color:#f7fafc;background:linear-gradient(145deg,#0f3448,#0a2232);box-shadow:0 10px 22px #03a9f41a}.search-row{height:44px;display:flex;align-items:center;gap:9px;border:1px solid #22394b;border-radius:8px;padding:0 12px;background:#0f1b25;box-shadow:inset 0 1px 2px #0003}.search-row input{flex:1;border:0;padding:0;background:transparent}.device-browser{display:grid;gap:12px}.device-tools{display:grid;grid-template-columns:minmax(260px,1fr) auto;align-items:center;gap:10px}.inline-action{margin-top:0}.device-table{display:grid;gap:8px}.device-table-row{min-width:0;min-height:54px;display:grid;grid-template-columns:auto minmax(0,1.1fr) minmax(0,1.2fr) minmax(0,1fr) minmax(0,.9fr) minmax(0,.9fr);align-items:center;gap:10px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;color:#f7fafc;background:#111d27;text-align:left}.device-table-row:hover{border-color:#03a9f480}.device-table-row strong,.device-table-row span,.device-table-row small,.device-table-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-table-row span,.device-table-row small,.device-table-row em{color:#93a4b0;font-style:normal}.device-grid,.package-grid,.application-grid,.notification-grid,.system-grid,.saved-device-list,.account-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:14px}.device-card,.package-grid button,.notification-grid button,.application-grid div,.system-grid a,.saved-device-row,.account-card,.account-panel button{min-width:0;display:grid;gap:7px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;color:#f7fafc;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27;text-align:left;text-decoration:none;box-shadow:0 10px 28px #00000029,inset 0 1px #ffffff0a}.device-form-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}.device-admin-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:14px}.device-admin-toolbar span{color:#93a4b0;font-size:.82rem;font-weight:760}.gateway-live-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;margin-bottom:14px}.gateway-live-card{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:4px 9px;align-items:center;border:1px solid rgba(3,169,244,.36);border-radius:8px;padding:12px;background:linear-gradient(135deg,rgba(3,169,244,.12),transparent 44%),#111d27;box-shadow:0 12px 30px #00000029,inset 0 1px #ffffff0d}.gateway-live-card small{grid-column:2 / -1;min-width:0;color:#93a4b0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gateway-live-card strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.downlink-panel{margin-top:18px;border:1px solid rgba(3,169,244,.28);border-radius:8px;padding:14px;background:linear-gradient(145deg,rgba(3,169,244,.12),transparent 46%),#0a1822e6;box-shadow:0 14px 34px #00000029,inset 0 1px #ffffff0a}.modal-backdrop{position:fixed;z-index:900;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#030a10a3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.wizard-panel{width:min(940px,100%);max-height:min(820px,calc(100vh - 40px));display:grid;grid-template-rows:auto minmax(0,1fr);border:1px solid rgba(129,212,250,.28);border-radius:8px;background:linear-gradient(180deg,#142633f5,#0a1721fa),#0f1c27;box-shadow:0 28px 90px #00000075,inset 0 1px #ffffff0d;overflow:hidden}.wizard-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(40,74,96,.72);padding:16px}.wizard-head h2{margin:2px 0 0}.wizard-head span{color:#93a4b0;font-size:.78rem;font-weight:820;text-transform:uppercase}.wizard-step{min-height:0;display:grid;align-content:start;gap:14px;padding:16px;overflow:auto}.model-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.model-picker button,.selected-model-card{min-width:0;display:grid;gap:6px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;color:#f7fafc;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27;text-align:left}.model-picker button:hover{border-color:#03a9f480;box-shadow:0 14px 34px #03a9f414}.model-picker span,.selected-model-card span{min-width:0;color:#93a4b0;font-size:.75rem;overflow-wrap:anywhere}.selected-model-card{grid-template-columns:auto minmax(0,180px) minmax(0,1fr) auto;align-items:center}.selected-model-card button{min-height:34px;border:1px solid rgba(3,169,244,.38);border-radius:8px;color:#dff5ff;background:#03a9f41f}.device-detail-panel{width:min(1180px,100%)}.sensor-detail-hero,.sensor-analysis-panel,.sensor-info-panel{border:1px solid rgba(3,169,244,.28);border-radius:8px;background:linear-gradient(145deg,rgba(3,169,244,.12),transparent 46%),#0a1822eb;box-shadow:0 14px 34px #00000029,inset 0 1px #ffffff0a}.sensor-detail-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px}.sensor-detail-title{min-width:0;display:grid;gap:7px}.sensor-detail-title span,.sensor-detail-title small{display:block;min-width:0;color:#93a4b0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rename-inline{display:flex;flex-wrap:wrap;gap:8px}.rename-inline input{width:min(440px,100%);height:44px;border-color:#03a9f461;color:#fff;font-size:1.35rem;font-weight:920}.rename-inline button,.segmented-control button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:0 11px;color:#dff5ff;background:#03a9f414;font-weight:850}.sensor-detail-status{display:grid;justify-items:end;gap:7px}.sensor-detail-status em{border-radius:999px;padding:5px 10px;background:#03a9f41f;font-style:normal;font-weight:900}.sensor-detail-status strong{color:#dff5ff;white-space:nowrap}.top-health-indicators{display:flex;align-items:center;justify-content:flex-end;gap:10px}.iphone-signal{height:28px;display:inline-flex;align-items:end;gap:3px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:5px 7px;background:#091620e0}.iphone-signal span{width:5px;border-radius:999px;background:#304653}.iphone-signal span:nth-child(1){height:7px}.iphone-signal span:nth-child(2){height:10px}.iphone-signal span:nth-child(3){height:13px}.iphone-signal span:nth-child(4){height:16px}.iphone-signal span:nth-child(5){height:19px}.iphone-signal span.on{background:linear-gradient(180deg,#9cffd4,#14d676);box-shadow:0 0 8px #14d6767a}.modern-battery{position:relative;width:58px;height:28px;border:2px solid rgba(129,212,250,.72);border-radius:7px;padding:3px;background:#091620e0}.modern-battery:after{content:"";position:absolute;top:8px;right:-6px;width:4px;height:10px;border-radius:0 3px 3px 0;background:#81d4fab8}.modern-battery span{height:100%;display:block;border-radius:4px;background:linear-gradient(90deg,#14d676,#81d4fa);box-shadow:0 0 10px #14d67657}.modern-battery.low{border-color:#ff7c72c7}.modern-battery.low:after,.modern-battery.low span{background:#ff7c72}.wired-power{position:relative;width:58px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(20,214,118,.78);border-radius:7px;color:#04131b;background:linear-gradient(90deg,#14d676f2,#81d4faf2),#14d676;box-shadow:0 0 14px #14d67647}.wired-power:before{content:"";position:absolute;left:-10px;width:10px;height:4px;border-radius:999px 0 0 999px;background:#14d676}.wired-power:after{content:"";position:absolute;right:-7px;width:5px;height:12px;border-radius:0 3px 3px 0;background:#14d676}.wired-power span{position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:4px;background:linear-gradient(90deg,rgba(255,255,255,.22),transparent 40%,rgba(255,255,255,.32));animation:cableCharge 1.4s linear infinite}.wired-power svg{position:relative;z-index:1}@keyframes cableCharge{0%{transform:translate(-18%);opacity:.35}50%{opacity:.85}to{transform:translate(18%);opacity:.35}}.professional-detail-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(280px,.8fr);gap:14px;align-items:start}.sensor-analysis-panel,.sensor-info-panel{min-width:0;padding:14px}.segmented-control{display:inline-flex;gap:6px;padding:3px;border:1px solid rgba(40,74,96,.72);border-radius:8px;background:#08131c9e}.segmented-control button{border-color:transparent;min-height:32px}.segmented-control button.active{color:#04131b;background:#03a9f4}.expand-view-button{width:34px;padding:0}.iot-pulse-chart{position:relative;overflow:hidden;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:13px;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27}.iot-pulse-chart:after{content:"";position:absolute;inset:auto 20px 14px;height:1px;background:linear-gradient(90deg,transparent,rgba(3,169,244,.5),transparent);animation:scanline 2.2s linear infinite}.chart-row-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.chart-row-head span{color:#93a4b0;font-size:.78rem;font-weight:820;text-transform:uppercase}.chart-row-head strong{color:#fff;font-size:1.2rem}.chart-canvas{position:relative;min-height:260px;padding-top:12px}.chart-canvas svg{width:100%;height:250px}.scale-max,.scale-min{position:absolute;left:0;z-index:1;color:#7f93a1;font-size:.72rem;font-weight:820}.scale-max{top:12px}.scale-min{bottom:12px}.grid-line,.axis-line,.threshold-line{stroke-width:1;vector-effect:non-scaling-stroke}.grid-line{stroke:#93a4b02e}.axis-line{stroke:#93a4b052}.threshold-line{stroke:#ff7c72;stroke-dasharray:5 5}.threshold-line.warn{stroke:#ffc857}.threshold-line.alert{stroke:#ff7c72}.iot-line{fill:none;stroke:#03a9f4;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 7px rgba(3,169,244,.52));stroke-dasharray:100 100;animation:traceSolid 5s linear infinite;will-change:stroke-dashoffset}.mini-x-axis{display:flex;justify-content:space-between;color:#7f93a1;font-size:.72rem;font-weight:780}@keyframes traceSolid{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}@keyframes scanline{0%{transform:translate(-45%);opacity:0}35%{opacity:1}to{transform:translate(45%);opacity:0}}.telemetry-table{display:grid;gap:7px;max-height:356px;overflow:auto}.telemetry-table>div{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);align-items:center;gap:10px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:9px 10px;background:#111d27}.telemetry-table .telemetry-table-head{position:sticky;top:0;z-index:1;color:#93a4b0;background:#0f1b25;font-size:.74rem;font-weight:900;text-transform:uppercase}.telemetry-table span,.telemetry-table strong,.telemetry-table small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analysis-fullscreen-backdrop{position:fixed;z-index:1100;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:18px;background:#030a10c7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.analysis-fullscreen-panel{width:min(1500px,100%);height:min(920px,calc(100vh - 36px));min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:14px;border:1px solid rgba(129,212,250,.34);border-radius:8px;padding:18px;background:radial-gradient(circle at 82% 0%,rgba(3,169,244,.18),transparent 34rem),linear-gradient(180deg,#0e1f2bfa,#08131cfc),#08131c;box-shadow:0 30px 100px #00000094,inset 0 1px #ffffff0f}.analysis-fullscreen-head,.analysis-head-actions,.analysis-threshold-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}.analysis-fullscreen-head h2{margin:2px 0 0;font-size:clamp(1.6rem,3vw,2.7rem)}.analysis-fullscreen-head span{color:#93a4b0;font-size:.78rem;font-weight:820;text-transform:uppercase}.analysis-head-actions{flex-wrap:wrap;justify-content:flex-end}.analysis-close-button{min-height:38px;display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(129,212,250,.28);border-radius:999px;padding:0 12px;color:#e8f8ff;background:linear-gradient(145deg,#03a9f429,#0a1822eb),#0f1b25;box-shadow:inset 0 1px #ffffff0f}.analysis-tool-button{min-height:38px;display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(3,169,244,.34);border-radius:999px;padding:0 12px;color:#dff5ff;background:#03a9f41a;font-weight:850}.analysis-tool-button:hover{border-color:#03a9f4ad;background:#03a9f42e}.analysis-tool-button.active{border-color:#ffc85799;color:#fff3cf;background:#ffc85724}.expanded-compare-panel{min-height:0;display:grid;gap:10px;border:1px solid rgba(3,169,244,.3);border-radius:8px;padding:12px;background:#0f1b25d1}.expanded-compare-panel header{display:flex;align-items:center;justify-content:space-between;gap:10px}.expanded-compare-panel header span{display:block;color:#93a4b0;font-size:.72rem;font-weight:820;text-transform:uppercase}.compare-empty-note{color:#93a4b0;font-size:.78rem}.analysis-chart-stack{min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:12px}.analysis-close-button:hover{border-color:#ff7c727a;background:linear-gradient(145deg,#ff7c7229,#0a1822eb),#0f1b25}.analysis-close-button span{color:#93a4b0;font-size:.68rem;font-weight:900}.analysis-threshold-bar{flex-wrap:wrap;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;background:#0f1b25d1}.analysis-threshold-bar label{min-width:210px}.analysis-threshold-bar input[type=number]{height:38px}.threshold-range{flex:1 1 300px;min-width:180px;accent-color:#03a9f4}.analysis-threshold-bar strong{min-width:110px;color:#81d4fa;text-align:right}.fullscreen-chart{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr) auto}.fullscreen-echart-wrap{position:relative;min-height:0}.fullscreen-echart{min-height:0;height:100%;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27}.fullscreen-echart-drag-area{position:absolute;top:10px;right:10px;bottom:10px;left:10px;pointer-events:none}.draggable-threshold-line{position:absolute;left:52px;right:28px;height:30px;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;border-top:2px dashed #ff7c72;padding:0;color:#f7fafc;background:transparent;cursor:grab;pointer-events:auto;transform:translateY(-15px)}.draggable-threshold-line:hover{filter:drop-shadow(0 0 10px rgba(3,169,244,.42))}.draggable-threshold-line.warn{border-top-color:#ffc857}.draggable-threshold-line.dragging{cursor:grabbing;filter:drop-shadow(0 0 12px rgba(3,169,244,.6))}.draggable-threshold-line span,.draggable-threshold-line strong{position:relative;transform:translateY(var(--label-offset, 0));border:1px solid rgba(40,74,96,.72);border-radius:999px;padding:4px 8px;background:#08131ce6;font-size:.74rem;white-space:nowrap}.draggable-threshold-line strong{color:#81d4fa}.fullscreen-analysis-grid{min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:12px}.threshold-touch-panel{min-height:0;display:grid;align-content:start;gap:10px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27;overflow:auto}.threshold-touch-panel header{display:flex;align-items:center;justify-content:space-between;gap:10px}.threshold-touch-panel header span,.threshold-touch-panel small{color:#93a4b0;font-size:.76rem;font-weight:820}.threshold-line-editor{display:grid;grid-template-columns:minmax(0,1fr) 82px;gap:7px 8px;align-items:center;border:1px solid rgba(40,74,96,.72);border-left:4px solid #ff7c72;border-radius:8px;padding:9px;background:#08131c6b}.threshold-line-editor.warn{border-left-color:#ffc857}.threshold-line-editor span{color:#dff5ff;font-size:.82rem;font-weight:850}.field-with-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:24px;line-height:1}.mini-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:38px;height:22px;flex:0 0 auto;display:inline-flex;align-items:center;border:1px solid rgba(147,164,176,.44);border-radius:999px;padding:0;margin:0;background:#26333d;cursor:pointer;box-shadow:inset 0 2px 6px #0000003d;vertical-align:middle}.mini-toggle:before{content:"";width:16px;height:16px;display:block;border-radius:50%;margin-left:2px;background:#93a4b0;transition:transform .16s ease,background .16s ease}.mini-toggle:checked{border-color:#03a9f4b3;background:#03a9f447}.mini-toggle:checked:before{transform:translate(16px);background:#03a9f4}.threshold-line-editor input[type=number]{height:34px;padding:0 8px}.threshold-line-editor input:disabled,.calibration-fields input:disabled{opacity:.42;cursor:not-allowed}.threshold-mini-range{grid-column:1 / -1;width:100%;accent-color:#03a9f4}.threshold-line-editor.compact{grid-template-columns:1fr 1fr;border-left-color:#03a9f4b8}.save-threshold-button{width:100%;margin-top:0}.save-message{justify-self:center;color:#14d676!important}.fullscreen-chart .chart-canvas{min-height:0}.fullscreen-chart .chart-canvas svg{height:100%;min-height:520px}.fullscreen-chart .chart-row-head strong{font-size:1.8rem}.fullscreen-table{max-height:none;min-height:0;align-content:start;overflow:auto}.fullscreen-table>div{min-height:48px;font-size:1rem}.detail-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.detail-metric-grid.compact{grid-template-columns:1fr}.live-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.live-metric-grid button{min-width:0;min-height:118px;display:grid;align-content:start;gap:7px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;color:#f7fafc;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27;text-align:left}.live-metric-grid button.active{border-color:#03a9f4b3;box-shadow:0 14px 34px #03a9f41f}.live-metric-grid button.alert{border-color:#ff7c728f}.live-metric-grid button.warn{border-color:#ffc85794}.live-metric-grid span,.live-metric-grid small{min-width:0;color:#93a4b0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-metric-grid strong{font-size:1.35rem}.advanced-chart-panel{border:1px solid rgba(3,169,244,.28);border-radius:8px;padding:14px;background:linear-gradient(145deg,rgba(3,169,244,.12),transparent 46%),#0a1822e6}.detail-chart{height:300px}.threshold-editor{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.threshold-editor.readonly{align-items:center}.threshold-editor.readonly>span{flex:1 1 260px;color:#93a4b0;font-size:.82rem;font-weight:820}.threshold-editor label{min-width:min(260px,100%)}.threshold-editor button{width:40px;height:40px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(40,74,96,.72);border-radius:999px;padding:0;color:#dff5ff;background:#03a9f414}.threshold-editor button svg{display:block;flex:0 0 auto}.threshold-editor button.enabled{border-color:#03a9f49e;color:#04131b;background:#03a9f4;box-shadow:0 10px 22px #03a9f42e}.threshold-editor .test-notification-button{border-color:#ffc85780;color:#ffc857;background:#ffc85714}.notification-test-message{flex:1 1 100%;color:#93a4b0;font-size:.76rem}.detail-metric-grid div{min-width:0;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27}.detail-metric-grid span,.detail-metric-grid strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-metric-grid span{color:#93a4b0;font-size:.74rem;font-weight:820;text-transform:uppercase}.detail-metric-grid strong{margin-top:6px}.detail-action-row{display:flex;justify-content:flex-start}.primary-action.secondary{color:#dff5ff;background:linear-gradient(145deg,#03a9f42e,#0a2232f5),#0d2b3d}.edit-device-panel{border:1px solid rgba(3,169,244,.28);border-radius:8px;padding:14px;background:linear-gradient(145deg,rgba(3,169,244,.12),transparent 46%),#0a1822e6;box-shadow:0 14px 34px #00000029,inset 0 1px #ffffff0a}.calibration-panel{margin-top:14px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:14px;background:#08131c70}.calibration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px}.calibration-card{min-width:0;display:grid;gap:10px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:12px;background:linear-gradient(180deg,#12212cf5,#0e1923fa),#111d27}.calibration-card.warn{border-color:#ffc8579e}.calibration-card.alert{border-color:#ff7c729e}.calibration-title{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px}.calibration-title strong,.calibration-title span,.calibration-card small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calibration-title svg{color:#81d4fa}.calibration-title span{color:#81d4fa;font-weight:900}.calibration-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.calibration-fields label{gap:5px;font-size:.72rem}.calibration-fields input{height:36px}.calibration-card small{color:#93a4b0;font-size:.76rem}.calibration-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.calibration-actions button{min-height:34px;display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(3,169,244,.44);border-radius:8px;padding:0 10px;color:#04131b;background:#03a9f4;font-weight:900}.downlink-panel.inline{margin-top:0}.downlink-template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin-bottom:12px}.downlink-template-grid button{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr);gap:4px 8px;align-items:center;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;color:#f7fafc;background:linear-gradient(145deg,rgba(3,169,244,.1),transparent 46%),#111d27;text-align:left}.downlink-template-grid button:hover{border-color:#03a9f480}.downlink-template-grid svg{grid-row:span 3;color:#81d4fa}.downlink-template-grid strong,.downlink-template-grid span,.downlink-template-grid small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.downlink-template-grid span{color:#81d4fa;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.78rem}.downlink-template-grid small{color:#93a4b0;font-size:.72rem}.primary-action{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(3,169,244,.68);border-radius:8px;padding:0 14px;margin-top:14px;color:#04131b;background:linear-gradient(145deg,#81d4fa,#03a9f4);font-weight:900;box-shadow:0 12px 28px #03a9f438}.saved-device-list{grid-template-columns:1fr}.saved-device-row{grid-template-columns:auto minmax(0,220px) minmax(0,1fr) minmax(0,160px) auto;align-items:center}.clickable-row{cursor:pointer}.clickable-row:hover{border-color:#03a9f480;transform:translateY(-1px)}.saved-device-row span,.saved-device-row strong,.saved-device-row small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-device-row span,.saved-device-row small,.account-card span,.account-panel button span{color:#93a4b0}.saved-device-row button{width:36px;height:36px;display:inline-grid;place-items:center;border:1px solid #2a4050;border-radius:8px;color:#eaf7ff;background:linear-gradient(145deg,#101d27,#0b141d)}.account-panel{grid-template-columns:minmax(240px,1.5fr) repeat(auto-fit,minmax(170px,1fr));align-items:stretch}.account-card{grid-template-columns:auto minmax(0,1fr);align-items:center}.account-card strong,.account-card span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-panel button{border-color:#263641;color:#f7fafc}.device-card em{color:#03a9f4;font-size:1.4rem;font-style:normal;font-weight:950}.device-card small,.package-grid small,.application-grid small,.application-grid span,.system-grid span{min-width:0;color:#93a4b0;overflow-wrap:anywhere}.device-card div{display:flex;flex-wrap:wrap;gap:6px}.device-card div span,.application-pill,.settings-strip span{border-radius:999px;padding:4px 8px;color:#a9bac4;background:#0d141a;font-size:.72rem;font-weight:820}.status-dot{width:9px;height:9px;border-radius:50%;background:currentColor}.status-dot.ok{color:#03a9f4}.status-dot.warn{color:#ffc857}.status-dot.alert{color:#ff7c72}.event-list{display:grid;gap:8px}.event-row{display:grid;grid-template-columns:auto minmax(0,220px) minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #263641;border-radius:8px;padding:10px;background:#141d24}.event-row span,.event-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-row button{height:34px;padding:0 12px}.empty-state{min-height:120px;display:grid;place-items:center;gap:8px;color:#93a4b0}.admin-layout{display:grid;gap:14px}.package-grid button.enabled,.notification-grid button.enabled{border-color:#03a9f49e;background:linear-gradient(145deg,#03a9f438,#0a2232f5),#0d2b3d}.package-grid button{position:relative;overflow:hidden;transition:border-color .16s ease,background .16s ease,transform .16s ease}.package-grid button:hover{transform:translateY(-1px);border-color:#03a9f466}.package-grid button.enabled:after{content:"Attivo";position:absolute;top:10px;right:10px;border-radius:999px;padding:3px 8px;color:#04131b;background:#81d4fa;font-size:.68rem;font-weight:900}.settings-tile{position:relative;grid-template-columns:auto minmax(0,1fr);align-items:center;border-color:#263641f5;background:linear-gradient(135deg,rgba(3,169,244,.1),transparent 45%),#111d27;box-shadow:0 12px 30px #00000029,inset 0 1px #ffffff0a;transition:border-color .16s ease,background .16s ease,transform .16s ease}.settings-tile svg{grid-row:span 2;color:#4fc3f7}.settings-tile:hover{transform:translateY(-1px);border-color:#03a9f47a;background:linear-gradient(135deg,rgba(3,169,244,.16),transparent 48%),#132433}.settings-tile.danger svg{color:#ff9a91}.help-page .wide-panel{max-width:980px}.help-grid{display:grid;gap:10px;margin-top:14px}.help-grid section,.help-contact-panel{border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:14px;background:linear-gradient(145deg,rgba(3,169,244,.08),transparent 48%),#111d27f5}.help-grid strong,.help-contact-panel strong{color:#f7fafc}.help-grid p{margin:6px 0 0;color:#9fb2bd;line-height:1.55}.help-contact-panel{display:grid;gap:6px;margin-top:12px}.help-contact-panel span{color:#93a4b0;font-size:.76rem;font-weight:850;text-transform:uppercase}.help-contact-panel a{color:#81d4fa;font-weight:850}.support-mail-form{display:grid;gap:10px;margin-top:12px;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:14px;background:linear-gradient(145deg,rgba(48,230,161,.08),transparent 48%),#111d27f5}.support-mail-form>span{color:#93a4b0;font-size:.76rem;font-weight:850;text-transform:uppercase}.support-mail-form label{display:grid;gap:6px;color:#aabdca;font-size:.82rem;font-weight:800}.support-mail-form textarea{min-width:0;resize:vertical;border:1px solid rgba(40,74,96,.72);border-radius:8px;padding:10px;color:#f7fafc;background:#0c1821}.support-mail-form div{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.support-mail-form small{color:#9fb2bd;font-weight:750}.user-admin-panel{grid-column:1 / -1}.user-admin-grid{display:grid;grid-template-columns:minmax(240px,320px) minmax(0,1fr);gap:16px}.user-list-panel,.user-editor-panel,.tenant-preferences-panel,.tenant-device-access,.invite-preview-box{border:1px solid rgba(92,131,158,.28);border-radius:8px;background:#0610196b;padding:14px}.user-list-panel,.user-editor-panel{display:grid;gap:12px;align-content:start}.user-row-button,.tenant-device-grid button{display:grid;grid-template-columns:auto minmax(0,1fr);gap:4px 10px;align-items:center;padding:11px;border:1px solid rgba(73,113,140,.35);border-radius:8px;background:#0b1924ad;color:#eaf4fb;text-align:left;cursor:pointer}.user-row-button svg,.tenant-device-grid button svg{grid-row:span 3;color:#7dd3fc}.user-row-button strong,.user-row-button span,.user-row-button small,.tenant-device-grid strong,.tenant-device-grid span,.tenant-device-grid small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-row-button span,.user-row-button small,.tenant-device-grid span,.tenant-device-grid small{color:#91a6b7;font-size:.76rem}.user-row-button.active{border-color:#03a9f4c2;box-shadow:inset 0 0 0 1px #03a9f440}.user-row-button.disabled{opacity:.58}.tenant-preferences-panel header,.tenant-device-access header,.user-actions-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.tenant-preferences-panel header span,.tenant-device-access header span,.invite-preview-box span{display:block;color:#91a6b7;font-size:.76rem;font-weight:850;text-transform:uppercase}.tenant-device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-top:12px}.tenant-section-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.tenant-section-grid button{display:inline-flex;align-items:center;gap:7px;min-height:34px;border:1px solid rgba(73,113,140,.35);border-radius:8px;padding:0 10px;color:#dcebf2;background:#0b19249e;font-weight:850}.tenant-section-grid button.active{border-color:#03a9f499;color:#f7fbff;background:#03a9f429}.tenant-device-grid button.active{border-color:#22c55ea3;background:#22c55e1f}.tenant-device-grid button.active svg{color:#86efac}.invite-preview-box pre{margin:10px 0 0;white-space:pre-wrap;color:#d8e7f0;font:.86rem/1.5 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px}.settings-strip{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.toast{position:fixed;right:16px;bottom:16px;border:1px solid rgba(3,169,244,.36);border-radius:8px;padding:10px 12px;color:#e7f8ff;background:#0d2b3df0;box-shadow:0 16px 50px #00000052;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.light .sidebar,.light .wide-panel,.light .side-panel,.light .hero-status,.light .module-card,.light .dashboard-builder{border-color:#cfdbe2;background:#fff}.light input,.light select,.light .search-row,.light .device-card,.light .package-grid button,.light .notification-grid button,.light .application-grid div,.light .system-grid a,.light .saved-device-row,.light .account-card,.light .account-panel button,.light .gateway-live-card,.light .downlink-panel,.light .wizard-panel,.light .model-picker button,.light .selected-model-card,.light .detail-metric-grid div,.light .detail-hero,.light .sensor-detail-hero,.light .sensor-analysis-panel,.light .sensor-info-panel,.light .iot-pulse-chart,.light .dashboard-toolbar,.light .dashboard-widget,.light .widget-config-panel,.light .widget-advanced-panel,.light .telemetry-table>div,.light .iphone-signal,.light .modern-battery,.light .wired-power,.light .downlink-template-grid button,.light .calibration-panel,.light .calibration-card,.light .compare-device-picker button,.light .fullscreen-echart,.light .threshold-touch-panel,.light .threshold-line-editor,.light .edit-device-panel,.light .live-metric-grid button,.light .advanced-chart-panel,.light .sensor-tile,.light .floor-map button,.light .compact-list button,.light .device-table-row{border-color:#cfdbe2;color:#12212a;background:#fff}.light .client-dashboard-shell .dashboard-widget,.light.client-dashboard-shell .dashboard-widget,.light .dashboard-widget{color:#12212a;background:linear-gradient(145deg,#fffffffa,#eef7fafa),#fff}.light .topbar h1,.light .dashboard-titlebar h2,.light .widget-head h2,.light .sensor-tile strong,.light .metric-sensor-tile em,.light .gauge-mini-card strong,.light .pulse-widget-card strong,.light .camera-widget footer strong,.light .context-camera-pane footer strong,.light .account-card strong,.light .settings-tile strong{color:#10202a}.light .topbar span,.light .dashboard-titlebar span,.light .dashboard-titlebar small,.light .widget-head span,.light .sensor-tile small,.light .sensor-tile span,.light .quick-device-picker small,.light .live-carousel-toolbar strong,.light .camera-widget footer span,.light .context-camera-pane footer span,.light .ha-weather-card header span,.light .ha-weather-card footer span,.light .ha-weather-card aside span,.light .account-card span,.light .settings-tile span{color:#50646f}.light .ha-weather-card{color:#10202a;background:linear-gradient(145deg,#fff,#edf5f8);box-shadow:0 18px 44px #223a4621,inset 0 1px #ffffffe6}.light .ha-weather-card.compact-context{border-color:#d9e3e8;background:linear-gradient(145deg,#fff,#edf5f8);box-shadow:0 18px 42px #24404c1f,inset 0 1px #fffffff2}.light .ha-weather-card h2,.light .ha-weather-card aside strong,.light .ha-forecast-row article,.light .ha-forecast-row strong{color:#10202a}.light .ha-weather-card.compact-context header span,.light .ha-weather-card.compact-context aside span,.light .ha-weather-card.compact-context footer span,.light .ha-weather-card.compact-context footer button,.light .ha-weather-card.compact-context .ha-forecast-row article>span,.light .ha-weather-card.compact-context .ha-forecast-row small{color:#60717b}.light .ha-forecast-row article>span,.light .ha-forecast-row small{color:#5c707b}.light .metric-sensor-tile,.light .sensor-tile{background:radial-gradient(circle at 50% 0%,rgba(3,169,244,.08),transparent 46%),linear-gradient(145deg,#03a9f40f,#fffffff5),#fff}.light .metric-white-icon{border-color:#0758791f;color:#075879b8;background:radial-gradient(circle at 32% 22%,rgba(255,255,255,.64),transparent 30%),linear-gradient(145deg,#03a9f41f,#ffffffb3)}.light .widget-config-panel input,.light .widget-config-panel select,.light .widget-advanced-panel select,.light .create-dashboard-panel input,.light .dashboard-titlebar,.light .dashboard-tabs-row button,.light .dashboard-tabs-row input,.light .widget-builder-catalog,.light .create-dashboard-panel,.light .template-picker button,.light .widget-catalog button{border-color:#d4dee4;color:#152027;background:#fff}.light .dashboard-tabs-row button.active{color:#152027;background:#eef7fb}.light .dashboard-widget,.light .dashboard-toolbar{box-shadow:0 16px 38px #1520271a,0 2px 10px #03a9f40d,inset 0 1px #ffffffd9}.light .dashboard-widget:before{opacity:.36}.light .dashboard-widget:hover{box-shadow:0 20px 48px #15202721,0 4px 14px #03a9f412,inset 0 1px #ffffffeb}.light .gauge-mini-card,.light .sensor-tile{box-shadow:0 12px 28px #15202717,0 2px 10px #03a9f40b,inset 0 1px #ffffffd1}.light .analysis-fullscreen-panel,.light .analysis-threshold-bar{border-color:#d4dee4;color:#152027;background:#fff}.light .rename-inline input,.light .telemetry-table .telemetry-table-head{color:#152027;background:#fff}.light .donut-ring{background:radial-gradient(circle,#ffffff 0 56%,transparent 57%),conic-gradient(#03a9f4 0 var(--online),rgba(255,124,114,.72) var(--online) 100%)}.light .sidebar{background:#edf3f5}.light .sidebar button,.light .top-actions button,.light .module-tabs button,.light .admin-tabs button{border-color:#d4dee4;color:#43515a;background:#fff}.light .control-strip{border-color:#d4dee4;background:#ffffffd1;box-shadow:0 10px 26px #15202714}.light .control-button{border-color:transparent;background:transparent}.light .theme-switch,.light .language-switch{border-color:#b9dbea;background:linear-gradient(145deg,#fff,#dfeff5);box-shadow:inset 0 2px 8px #1f43521f,0 8px 18px #1520270f}.light .theme-switch span,.light .language-switch span{color:#607780}.light .theme-switch span.active,.light .language-switch span.active{color:#fff;background:linear-gradient(145deg,#0077a6,#03a9f4)}.light .soft-action,.light .widget-actions .detail-button,.light .live-carousel-toolbar button{border-color:#b8d7e4;color:#075879;background:#03a9f41a}.light .settings-tile{background:linear-gradient(135deg,rgba(3,169,244,.12),transparent 45%),#fff}.light .help-grid section,.light .help-contact-panel,.light .support-mail-form,.light .user-list-panel,.light .user-editor-panel,.light .tenant-preferences-panel,.light .tenant-device-access,.light .invite-preview-box{border-color:#d4dee4;background:linear-gradient(145deg,rgba(3,169,244,.08),transparent 48%),#fff}.light .help-grid strong,.light .help-contact-panel strong{color:#10202a}.light .help-grid p,.light .help-contact-panel span,.light .support-mail-form>span,.light .support-mail-form small,.light .user-row-button span,.light .user-row-button small,.light .tenant-device-grid span,.light .tenant-device-grid small,.light .tenant-preferences-panel header span,.light .tenant-device-access header span,.light .invite-preview-box span{color:#50646f}.light .user-row-button,.light .tenant-device-grid button,.light .tenant-section-grid button{border-color:#d4dee4;background:#fff;color:#10202a}.light .support-mail-form textarea{border-color:#c8d6de;color:#10202a;background:#fff}.light .invite-preview-box pre{color:#253541}@keyframes panelEnter{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cardEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@media (max-width: 1060px){.app-shell,.app-shell.collapsed{grid-template-columns:1fr}.sidebar{position:static;height:auto;grid-template-rows:auto auto}.sidebar nav{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.view-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-status,.clean-hero,.dashboard-builder,.wide-panel,.side-panel{grid-column:1 / -1}.dashboard-widget-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.widget-small,.widget-wide,.widget-full{grid-column:span 2}.widget-live-compact .sensor-tile-grid,.widget-live-compact .metric-carousel-grid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}.site-hero-widget{grid-template-columns:1fr}.site-metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.environment-context-widget{grid-template-columns:1fr}.ha-forecast-row{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (max-width: 700px){.workspace{padding:12px}.topbar{align-items:flex-start;flex-direction:column}.top-actions{flex-wrap:wrap}.control-strip{width:100%}.view-grid,.history-page,.history-chart-head{grid-template-columns:1fr}.history-actions{justify-content:flex-start}.user-admin-grid{grid-template-columns:1fr}.hero-status{align-items:stretch;flex-direction:column}.event-row{grid-template-columns:auto minmax(0,1fr)}.event-row span,.event-row button{grid-column:2}.device-tools,.professional-detail-grid{grid-template-columns:1fr}.sensor-detail-hero{align-items:stretch;flex-direction:column}.sensor-detail-status{justify-items:start}.analysis-fullscreen-backdrop{padding:10px}.analysis-fullscreen-panel{height:calc(100vh - 20px);padding:12px}.analysis-fullscreen-head{align-items:flex-start;flex-direction:column}.analysis-head-actions{justify-content:flex-start}.fullscreen-analysis-grid,.dashboard-widget-grid{grid-template-columns:1fr}.widget-small,.widget-wide,.widget-full{grid-column:1}.widget-live-compact .sensor-tile-grid,.widget-live-compact .metric-carousel-grid,.site-metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.environment-context-widget{grid-template-columns:1fr}.ha-weather-card header{grid-template-columns:auto minmax(0,1fr)}.ha-weather-card aside{grid-column:1 / -1;justify-items:start}.ha-forecast-row{grid-template-columns:repeat(2,minmax(0,1fr))}.google-map-widget,.google-map-widget iframe{min-height:280px}.google-map-widget>div{align-items:flex-start;flex-direction:column}.widget-expanded-backdrop,.widget-expanded-backdrop.collapsed{left:0}.widget-expanded-content,.widget-expanded-content.advanced-open{grid-template-columns:1fr}.widget-expanded-panel{height:100vh;padding:12px}.dashboard-tabs-row{align-items:stretch;flex-wrap:wrap}.dashboard-tabs-row small{width:100%;margin-left:0;padding:4px 0 8px}.widget-builder-catalog{grid-template-columns:1fr}.widget-category-menu{grid-template-columns:repeat(2,minmax(0,1fr));border-right:0;border-bottom:1px solid rgba(40,74,96,.38)}.widget-catalog{grid-template-columns:1fr}.fullscreen-chart .chart-canvas svg{min-height:360px}.device-table-row{grid-template-columns:auto minmax(0,1fr)}.device-table-row span,.device-table-row small,.device-table-row em{grid-column:2}.saved-device-row{grid-template-columns:auto minmax(0,1fr) auto}.saved-device-row span,.saved-device-row small{grid-column:2}.selected-model-card{grid-template-columns:auto minmax(0,1fr)}.selected-model-card span,.selected-model-card button{grid-column:2}}
