@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Sora:wght@500;600;700&display=swap";:root{--volt-50:#e8fbf3;--volt-100:#c7f4e0;--volt-200:#97e9c8;--volt-300:#5fd9ac;--volt-400:#2dd4a7;--volt-500:#0ebe8f;--volt-600:#0b9e78;--volt-700:#0a7e61;--solar-50:#fff6e6;--solar-500:#f5a623;--solar-700:#ae6912;--sky-50:#eaf6fc;--sky-500:#2a8bc6;--sky-700:#195880;--coral-50:#feeceb;--coral-100:#fbcfcc;--coral-500:#f2564e;--coral-700:#b0322b;--ink-950:#080b0e;--ink-900:#0c1116;--ink-850:#131a21;--ink-800:#1b232b;--ink-700:#2a343d;--ink-600:#45525c;--ink-500:#647079;--ink-400:#8a949c;--ink-300:#b4bcc2;--ink-200:#d6dce0;--ink-150:#e4e9ec;--ink-100:#eef2f4;--ink-50:#f6f8f9;--white:#fff;--brand:var(--volt-500);--brand-hover:var(--volt-600);--brand-press:var(--volt-700);--brand-subtle:var(--volt-50);--brand-on:var(--white);--brand-ink:var(--volt-700);--text-strong:var(--ink-900);--text-body:var(--ink-800);--text-muted:var(--ink-500);--text-subtle:var(--ink-400);--text-brand:var(--volt-700);--surface-page:#f4f7f7;--surface-card:var(--white);--surface-sunken:var(--ink-100);--surface-subtle:var(--ink-50);--night-base:#0c1116;--night-raised:#131c24;--night-card:#16212b;--night-border:#243340;--night-text:#eaf1f4;--night-muted:#92a4b1;--border-subtle:var(--ink-150);--border-default:var(--ink-200);--divider:var(--ink-150);--success:var(--volt-600);--success-subtle:var(--volt-50);--success-ink:var(--volt-700);--warning:var(--solar-500);--warning-subtle:var(--solar-50);--warning-ink:var(--solar-700);--danger:var(--coral-500);--danger-subtle:var(--coral-50);--danger-ink:var(--coral-700);--info:var(--sky-500);--info-subtle:var(--sky-50);--info-ink:var(--sky-700);--energy-solar:var(--solar-500);--energy-battery:var(--volt-500);--energy-grid:#708293;--energy-ev:#7c8ff3;--energy-home:var(--sky-500);--price-low:var(--volt-500);--price-mid:var(--solar-500);--price-high:var(--coral-500);--price-spike:var(--coral-700);--font-display:"Sora", system-ui, sans-serif;--font-sans:"Plus Jakarta Sans", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--radius-xs:6px;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--radius-pill:999px;--shadow-xs:0 1px 2px #0c11160d;--shadow-sm:0 1px 3px #0c11160f, 0 1px 2px #0c11160a;--shadow-md:0 4px 12px #0c111612, 0 2px 4px #0c11160a;--shadow-xl:0 24px 48px #0c111624, 0 8px 16px #0c11160f;--shadow-brand:0 6px 20px color-mix(in oklch, var(--volt-500) 32%, transparent);--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-spring:cubic-bezier(.34, 1.4, .64, 1);--dur-fast:.14s;--dur-base:.22s;--nav-height:68px}*,:before,:after{box-sizing:border-box}html{background:var(--surface-page);-webkit-text-size-adjust:100%;min-width:320px}body{min-width:320px;min-height:100vh;color:var(--text-body);background:radial-gradient(circle at 50% -20%, #0ebe8f1a, transparent 38rem), var(--surface-page);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.45;overflow-x:hidden}button,input{font:inherit}button{-webkit-tap-highlight-color:transparent}h1,h2,h3,p{margin:0}h1,h2,h3{font-family:var(--font-display);color:var(--text-strong);letter-spacing:-.02em;line-height:1.1}:focus-visible{outline:3px solid color-mix(in oklch, var(--brand) 38%, transparent);outline-offset:2px}#root{min-height:100vh}.app-shell{background:var(--surface-page);min-height:100vh;transition:grid-template-columns var(--dur-base) var(--ease-out);grid-template-columns:240px minmax(0,1fr);display:grid}.app-shell.is-sidebar-collapsed{grid-template-columns:82px minmax(0,1fr)}.sidebar{z-index:40;border-right:1px solid var(--night-border);height:100vh;color:var(--night-text);background:var(--night-base);flex-direction:column;padding:24px 18px 18px;display:flex;position:sticky;top:0}.sidebar__header{align-items:center;display:flex}.sidebar-collapse{z-index:45;color:#c4d1da;cursor:pointer;width:27px;height:40px;transition:color var(--dur-fast), border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-fast);background:#142536;border:1px solid #31485b;border-radius:14px;place-items:center;padding:0;display:grid;position:absolute;top:78px;right:-13px;box-shadow:0 3px 10px #0000003d}.sidebar-collapse:hover{color:#fff;background:#1a3043;border-color:#46647a;transform:translate(1px)}.app-brand{align-items:center;gap:10px;display:flex}.app-brand__mark{color:#fff;background:var(--brand);width:38px;height:38px;box-shadow:var(--shadow-brand);border-radius:12px;place-items:center;display:grid}.app-brand__name{color:inherit;font-family:var(--font-display);letter-spacing:-.03em;font-size:20px;font-weight:700}.sidebar-nav{flex-direction:column;gap:6px;margin-top:38px;display:flex}.sidebar-nav__item{border-radius:var(--radius-sm);width:100%;min-height:44px;color:var(--night-muted);text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:12px;padding:0 13px;font-weight:600;display:flex}.sidebar-nav__item:hover{color:var(--night-text);background:#ffffff0d}.sidebar-nav__item.is-active{color:#fff;box-shadow:inset 3px 0 var(--brand);background:#0ebe8f21}.is-sidebar-collapsed .sidebar{padding-inline:14px}.is-sidebar-collapsed .sidebar__header{justify-content:center}.is-sidebar-collapsed .app-brand__name,.is-sidebar-collapsed .sidebar-nav__item span,.is-sidebar-collapsed .sidebar-status div,.is-sidebar-collapsed .sidebar-profile__copy,.is-sidebar-collapsed .sidebar-profile>svg{display:none}.is-sidebar-collapsed .sidebar-nav__item,.is-sidebar-collapsed .sidebar-profile{justify-content:center;padding:0}.is-sidebar-collapsed .sidebar-status{justify-content:center;padding:16px 0}.sidebar-status{border:1px solid var(--night-border);border-radius:var(--radius-md);background:#ffffff09;align-items:center;gap:10px;margin-top:auto;padding:13px;display:flex}.sidebar-status__dot{background:var(--volt-400);border-radius:50%;width:9px;height:9px;box-shadow:0 0 0 5px #2dd4a71a}.sidebar-status div,.sidebar-profile__copy{flex-direction:column;flex:1;min-width:0;display:flex}.sidebar-status strong,.sidebar-profile strong{color:var(--night-text);font-size:12px}.sidebar-status span,.sidebar-profile small{color:var(--night-muted);font-size:10.5px}.sidebar-profile{border-radius:var(--radius-md);width:100%;color:var(--night-muted);text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:10px;margin-top:12px;padding:10px;display:flex}.profile-avatar,.topbar-avatar{color:var(--volt-700);background:var(--volt-100);border-radius:50%;place-items:center;font-weight:700;display:grid}.profile-avatar{width:36px;height:36px}.app-workspace{z-index:1;flex-direction:column;min-width:0;min-height:100vh;display:flex;position:relative}.app-topbar{z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);height:68px;transition:color var(--dur-base), border-color var(--dur-base), background var(--dur-base);background:#f4f7f7e0;border-bottom:1px solid #d6dce0d1;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.is-immersive .app-topbar{color:var(--night-text);background:#071019ed;border-bottom-color:#3f5b6d80;box-shadow:0 8px 24px #00000029}.topbar-context{align-items:center;gap:10px;display:flex}.topbar-context__label{color:var(--text-muted);font-size:12px;font-weight:600}.is-immersive .topbar-context__label{color:var(--night-muted)}.property-selector{appearance:none;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-height:38px;color:var(--text-strong);cursor:pointer;transition:color var(--dur-base), border-color var(--dur-base), background var(--dur-base);background:#fff;padding:0 12px;font-weight:700}.is-immersive .property-selector{color:var(--night-text);border-color:var(--night-border);background:#ffffff0e}.is-immersive .property-selector:hover{background:#ffffff16;border-color:#3b5365}.topbar-actions{align-items:center;gap:12px;display:flex}.live-status{color:var(--success-ink);align-items:center;gap:7px;font-size:12px;font-weight:700;display:inline-flex}.live-status span{background:var(--success);border-radius:50%;width:7px;height:7px}.icon-button,.mobile-menu{border:1px solid var(--border-subtle);width:40px;height:40px;color:var(--text-body);cursor:pointer;transition:color var(--dur-base), border-color var(--dur-base), background var(--dur-base);background:#fff;border-radius:50%;place-items:center;display:grid;position:relative}.is-immersive .icon-button{color:var(--night-text);border-color:var(--night-border);background:#ffffff0e}.is-immersive .icon-button:hover{background:#ffffff17}.icon-button i{background:var(--brand);border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:9px;right:10px}.is-immersive .icon-button i{border-color:#101b25}.topbar-avatar{width:38px;height:38px}.is-immersive .topbar-avatar{color:var(--volt-200);background:#0ebe8f29;box-shadow:inset 0 0 0 1px #2dd4a738}.mobile-brand,.mobile-nav{display:none}.app-main{flex:1;min-width:0}.app-content{width:min(100%,1240px);margin:0 auto;padding:30px 32px 48px}.is-immersive .app-main,.is-immersive .app-content{min-height:calc(100vh - 68px)}.is-immersive .app-content{width:100%;max-width:none;padding:0}.screen{flex-direction:column;gap:20px;display:flex}.screen-title{font-size:clamp(26px,2.6vw,36px);font-weight:700}.page-heading{max-width:680px}.page-heading .screen-title{margin-top:6px}.page-subtitle{color:var(--text-muted);margin-top:8px;font-size:14px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{font-size:17px;font-weight:700}.text-action{color:var(--text-brand);cursor:pointer;background:0 0;border:0;padding:4px;font-size:13px;font-weight:700}.screen--dashboard{grid-template-columns:minmax(0,1.65fr) minmax(300px,.85fr);grid-template-areas:"heading heading""savings side""flow side""price side";align-items:start;gap:20px;display:grid}.dashboard-heading{grid-area:heading;justify-content:space-between;align-items:center;display:flex}.dashboard-heading>button{display:none!important}.dashboard-savings{grid-area:savings}.dashboard-flow{grid-area:flow;min-width:0}.dashboard-price{grid-area:price}.dashboard-side{flex-direction:column;grid-area:side;gap:18px;display:flex}.network-map{min-height:calc(100vh - 68px);color:var(--night-text);background:#071019;position:relative;overflow:hidden}.network-map__picture,.network-map__picture img{width:100%;height:100%;position:absolute;inset:0}.network-map__picture img{object-fit:cover;object-position:center;display:block}.network-map__header{z-index:3;pointer-events:none;justify-content:space-between;align-items:flex-start;display:flex;position:absolute;top:24px;left:28px;right:28px}.is-immersive .network-map__header{left:48px}.network-map__header .eyebrow{color:var(--volt-300)}.network-map__header h1{color:#fff;margin-top:4px;font-size:clamp(22px,2.4vw,34px)}.network-map__header p:last-child{color:var(--night-muted);margin-top:7px;font-size:12px}.network-map__live{border-radius:var(--radius-pill);height:30px;color:var(--volt-300);background:#0ebe8f1f;border:1px solid #0ebe8f57;align-items:center;gap:7px;padding:0 12px;font-size:12px;font-weight:700;display:inline-flex}.network-map__live span{background:var(--volt-400);border-radius:50%;width:7px;height:7px;animation:1.6s ease-in-out infinite giq-pulse}.network-map__live.is-offline{color:var(--night-muted);background:#92a4b11a;border-color:#92a4b152}.network-map__live.is-offline span{background:var(--night-muted);animation:none}.network-onboarding{z-index:4;border-radius:var(--radius-lg);max-width:720px;color:var(--night-text);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#071019e0;border:1px solid #2dd4a740;align-items:center;gap:13px;margin:0 auto;padding:14px 16px;display:flex;position:absolute;bottom:28px;left:28px;right:28px;box-shadow:0 18px 48px #00000057}.network-onboarding__icon{width:42px;height:42px;color:var(--volt-300);background:#0ebe8f21;border-radius:13px;flex:none;place-items:center;display:grid}.network-onboarding>div{flex:1;min-width:0}.network-onboarding strong{color:#fff;font-size:13px}.network-onboarding p{color:var(--night-muted);margin-top:2px;font-size:11.5px}.network-onboarding button{border-radius:var(--radius-sm);color:#fff;background:var(--brand);cursor:pointer;border:0;align-items:center;gap:7px;min-height:38px;padding:0 14px;font-size:12px;font-weight:700;display:inline-flex}.network-map__canvas{z-index:2;position:absolute;inset:0}.network-map__overlay{width:100%;height:100%;display:block;position:absolute;inset:0}.network-map__overlay--mobile{display:none}.network-hotspot{cursor:pointer;outline:none}.network-hotspot__target{fill:#fff0;stroke:var(--hotspot-color);stroke-width:1.2px;stroke-opacity:0;transition:fill var(--dur-base), stroke-opacity var(--dur-base)}.network-hotspot__beacon{fill:var(--hotspot-color);stroke:#040c12cc;stroke-width:1.5px}.network-hotspot__beacon-ring{fill:none;stroke:var(--hotspot-color);stroke-width:1px;opacity:.55;transform-box:fill-box;transform-origin:50%;animation:2.4s ease-out infinite giq-hotspot}.network-hotspot__label{opacity:0;pointer-events:none;transition:opacity var(--dur-fast), transform var(--dur-fast);transform:translateY(3px)}.network-hotspot__label rect{fill:#060f17e6;stroke:var(--hotspot-color);stroke-width:.6px}.network-hotspot__label text{fill:#fff;font-family:var(--font-sans);font-size:13px;font-weight:700}.network-hotspot:hover .network-hotspot__target,.network-hotspot:focus .network-hotspot__target{fill:color-mix(in srgb, var(--hotspot-color) 8%, transparent);stroke-opacity:.78}.network-hotspot:hover .network-hotspot__label,.network-hotspot:focus .network-hotspot__label{opacity:1;transform:translateY(0)}.network-hotspot__reading{pointer-events:none}.network-hotspot__reading-leader{stroke:var(--hotspot-color);stroke-width:1.5px;opacity:.65}.network-hotspot__reading-card{fill:#060e16d1;stroke:var(--hotspot-color);stroke-opacity:.5;stroke-width:1px}.network-hotspot__reading-dot{fill:var(--hotspot-color)}.network-hotspot__reading-caption{fill:#ffffffa3;font-family:var(--font-sans);letter-spacing:.03em;text-transform:uppercase;font-size:11px;font-weight:700}.network-hotspot__reading-value{fill:#fff;font-family:var(--font-sans);font-size:17px;font-weight:800}.network-hotspot__reading-unit,.network-hotspot__reading-soc{fill:#ffffffa3;font-size:11.5px;font-weight:700}.network-hotspot__reading-secondary{fill:#ffffffd1;font-family:var(--font-sans);font-size:12.5px;font-weight:700}.network-hotspot--has-reading .network-hotspot__label{display:none}.refresh-ring{margin-left:4px;overflow:visible}.refresh-ring__track{stroke:#fff3;stroke-width:2px}.refresh-ring__progress{stroke:var(--volt-400);stroke-width:2px;stroke-linecap:round;transition:stroke-dashoffset .25s linear}.refresh-ring__progress.is-fetching{animation:1s ease-in-out infinite giq-pulse}.device-detail{grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr);grid-template-areas:"back back""hero hero""metrics metrics""primary automation""primary settings";align-items:start;display:grid}.device-detail__back{width:fit-content;color:var(--text-brand);cursor:pointer;background:0 0;border:0;grid-area:back;align-items:center;gap:8px;padding:6px 0;font-size:13px;font-weight:700;display:inline-flex}.device-detail__hero{grid-area:hero;align-items:center;gap:16px;display:flex}.device-detail__icon{width:58px;height:58px;color:var(--device-color);background:color-mix(in srgb, var(--device-color) 14%, white);border-radius:18px;flex:none;place-items:center;display:grid}.device-detail__heading{flex:1;min-width:0}.device-detail__metrics{grid-area:metrics;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.device-metric{align-items:baseline;gap:6px;margin-top:10px;display:flex}.device-metric strong{color:var(--text-strong);font-size:clamp(26px,3vw,38px);line-height:1}.device-metric span{color:var(--text-muted);font-size:12px;font-weight:600}.device-detail__primary{grid-area:primary}.device-detail__automation{grid-area:automation}.device-detail__settings{grid-area:settings}.device-panel-heading{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.device-panel-heading h2{margin-top:4px;font-size:18px}.grid-price-now{align-items:baseline;gap:8px;margin-bottom:20px;display:flex}.grid-price-now strong{color:var(--volt-700);font-size:42px;line-height:1}.grid-price-now span{color:var(--text-muted);font-size:13px}.device-insight{border-radius:var(--radius-sm);color:var(--info-ink);background:var(--info-subtle);align-items:flex-start;gap:9px;margin-top:18px;padding:12px;font-size:12px;font-weight:600;display:flex}.device-automation-row{align-items:center;gap:12px;padding:4px 0;display:flex}.device-automation-row>div{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.device-automation-row strong{color:var(--text-strong);font-size:13px}.device-automation-row span{color:var(--text-muted);font-size:11px}.device-settings-link{width:100%;color:var(--text-body);cursor:pointer;background:0 0;border:0;justify-content:space-between;align-items:center;padding:17px 18px;font-size:13px;font-weight:700;display:flex}.device-settings-link span{align-items:center;gap:9px;display:flex}.activity-chart{border-bottom:1px solid var(--border-subtle);background:linear-gradient(to bottom, transparent 32%, var(--surface-sunken) 33%, transparent 34%, transparent 65%, var(--surface-sunken) 66%, transparent 67%);align-items:flex-end;gap:6px;height:190px;padding-top:14px;display:flex}.activity-chart>span{background:var(--device-color);opacity:.78;border-radius:5px 5px 1px 1px;flex:1;min-width:4px}.activity-chart__axis{color:var(--text-subtle);font-family:var(--font-mono);justify-content:space-between;margin:7px 0 18px;font-size:9px;display:flex}.screen--devices{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);grid-template-areas:"heading heading""list automations""add automations";align-items:start;display:grid}.screen--devices .page-heading{grid-area:heading}.devices-list{grid-area:list}.devices-add{grid-area:add}.devices-automations{grid-area:automations}.screen--settings{grid-template-columns:minmax(300px,.7fr) minmax(0,1.3fr);grid-template-areas:"heading heading""profile integrations""actions integrations";align-items:start;display:grid}.screen--settings .page-heading{grid-area:heading}.settings-profile{grid-area:profile}.settings-integrations{grid-area:integrations}.settings-account-actions{grid-area:actions}.settings-avatar{object-fit:cover;width:52px;height:52px;color:var(--volt-700);background:var(--volt-100);font-family:var(--font-display);border-radius:50%;flex:none;place-items:center;font-size:20px;font-weight:700;display:grid}.integration-setting{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--surface-subtle);align-items:center;gap:12px;padding:13px;display:flex}.integration-setting__icon{width:42px;height:42px;color:var(--volt-700);background:var(--volt-100);border-radius:12px;place-items:center;display:grid}.integration-setting__icon--foxess{color:var(--success-ink);background:var(--success-subtle)}.integration-setting--spaced{margin-top:10px}.integration-setting>div{flex-direction:column;flex:1;min-width:0;display:flex}.integration-setting strong{color:var(--text-strong);font-size:13px}.integration-setting small{color:var(--text-muted);margin-top:2px;font-size:11px}.settings-security-note{color:var(--text-muted);align-items:center;gap:7px;margin-top:12px;font-size:11px;display:flex}.amber-setting{flex-direction:column;gap:10px;display:flex}.amber-connect-form{border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--surface-raised);gap:9px;padding:14px;display:grid}.amber-connect-form label{color:var(--text-strong);font-size:12px;font-weight:700}.amber-connect-form input,.amber-connect-form select{border:1px solid var(--border-default);border-radius:var(--radius-sm);width:100%;height:42px;color:var(--text-strong);background:var(--surface-default);font:inherit;padding:0 12px}.amber-connect-form input:focus,.amber-connect-form select:focus{border-color:var(--brand);outline:3px solid color-mix(in srgb, var(--brand) 15%, transparent)}.amber-connect-form p{color:var(--text-muted);font-size:11px;line-height:1.5}.form-error{border-radius:var(--radius-sm);color:var(--danger-ink);background:var(--danger-subtle);padding:10px 12px;font-size:12px;font-weight:600}.integration-disconnect{width:fit-content;color:var(--danger-ink);cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:5px 0;font-size:11px;font-weight:700;display:inline-flex}.integration-disconnect:disabled{opacity:.55;cursor:wait}.integration-connect{border-radius:var(--radius-sm);color:#fff;background:var(--brand);cursor:pointer;border:0;width:fit-content;height:38px;margin-top:12px;padding:0 15px;font-weight:700}.integration-setup-copy{color:var(--text-muted);overflow-wrap:anywhere;margin-top:12px;font-size:11px;line-height:1.5}.foxess-device{grid-template-columns:minmax(0,1fr) minmax(340px,.8fr);grid-template-areas:"heading heading""main controls";align-items:start;gap:20px;display:grid}.foxess-device--no-controls{grid-template-areas:"heading heading""main main"}.foxess-device .page-heading{grid-area:heading}.foxess-device__main{grid-area:main;align-content:start;gap:16px;display:grid}.foxess-device__controls{grid-area:controls}.foxess-hero{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:20px;display:grid}.foxess-hero__id{gap:14px;min-width:0;display:flex}.foxess-hero__icon{border-radius:var(--radius-md);width:52px;height:52px;color:var(--device-color);background:color-mix(in oklch, var(--device-color) 14%, white);flex:none;place-items:center;display:grid}.foxess-hero__meta{min-width:0}.foxess-hero__meta h2{margin:2px 0;font-size:19px}.foxess-hero__sn{color:var(--text-muted);font-family:var(--font-mono);font-size:11.5px}.foxess-hero__badges{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.foxess-hero__headline{align-items:center;gap:16px;display:flex}.foxess-hero__stat{flex-direction:column;gap:2px;display:flex}.foxess-hero__state{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.foxess-hero__stat strong{color:var(--text-strong);font-family:var(--font-mono);font-size:26px}.foxess-hero__stat strong small,.foxess-hero__big strong small{font-family:var(--font-sans);color:var(--text-muted);font-size:13px;font-weight:700}.foxess-hero__stored{color:var(--text-muted);font-size:12px}.foxess-hero__big{flex-direction:column;gap:4px;display:flex}.foxess-hero__big strong{color:var(--text-strong);font-family:var(--font-mono);font-size:34px;line-height:1}.foxess-hero__big span{color:var(--text-muted);font-size:12px}.soc-ring{flex:none}.soc-ring__track{stroke:var(--border-default);stroke-width:9px}.soc-ring__fill{stroke:var(--energy-battery);stroke-width:9px;stroke-linecap:round;transition:stroke-dashoffset var(--dur-base) var(--ease-out)}.soc-ring__value{fill:var(--text-strong);font-family:var(--font-mono);font-size:30px;font-weight:600}.soc-ring__pct{fill:var(--text-muted);font-size:14px}.soc-ring__caption{fill:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.foxess-group__head{color:var(--text-strong);align-items:center;gap:8px;margin-bottom:12px;display:flex}.foxess-group__head h3{font-size:14px}.foxess-metric__fault{color:var(--coral-600,#d6453f)}.foxess-metric__ok{color:var(--success)}.foxess-fault-banner{border-radius:var(--radius-sm);color:var(--coral-700,#b23a35);background:var(--coral-50,#fdeceb);align-items:center;gap:8px;margin-top:12px;padding:10px 12px;font-size:12.5px;font-weight:600;display:flex}.foxess-device__updated{color:var(--text-subtle);font-size:11.5px}.device-row-button{text-align:left;cursor:pointer;border-radius:var(--radius-sm);width:100%;transition:background var(--dur-fast);background:0 0;border:0;padding:0;display:block}.device-row-button:hover{background:var(--surface-subtle)}.foxess-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.foxess-metric{border-radius:var(--radius-sm);background:var(--surface-subtle);min-width:0;padding:14px}.foxess-metric span,.foxess-metric small{color:var(--text-muted);font-size:10.5px;display:block}.foxess-metric strong{color:var(--text-strong);font-family:var(--font-mono);margin:7px 4px 2px 0;font-size:20px;display:inline-block}.foxess-controls{gap:14px;display:grid}.control-section{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--surface-subtle);align-items:flex-start;gap:12px;padding:14px;display:flex}.control-section__icon{width:36px;height:36px;color:var(--brand-ink);background:var(--brand-subtle);border-radius:10px;flex:none;place-items:center;display:grid}.control-section__body{flex:1;gap:10px;min-width:0;display:grid}.control-section__body>label{color:var(--text-strong);font-size:12px;font-weight:700}.control-section select,.control-field input,.charge-period input[type=time]{border:1px solid var(--border-default);border-radius:var(--radius-sm);height:38px;color:var(--text-strong);background:var(--surface-default);font:inherit;padding:0 10px}.control-pair{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.control-field{color:var(--text-muted);gap:5px;font-size:10.5px;display:grid}.control-field div{align-items:center;gap:6px;display:flex}.control-field input{width:90px}.charge-period{color:var(--text-muted);grid-template-columns:minmax(85px,1fr) auto auto auto;align-items:center;gap:8px;font-size:11px;display:grid}.charge-period label{color:var(--text-strong);align-items:center;gap:6px;font-weight:600;display:flex}.control-note{color:var(--text-muted);margin-bottom:12px;font-size:11px}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.metric-caption{color:var(--text-subtle);margin-top:8px;font-size:10px;display:block}.forecast-price-labels{gap:5px;margin-top:8px;display:flex;overflow:hidden}.forecast-price-labels span{min-width:0;color:var(--text-subtle);font-family:var(--font-mono);text-align:center;flex:1;font-size:8px}.amber-site-details{gap:10px;display:grid}.amber-site-details>div{border-bottom:1px solid var(--divider);justify-content:space-between;gap:12px;padding-bottom:9px;display:flex}.amber-site-details dt{color:var(--text-muted);font-size:11px}.amber-site-details dd{color:var(--text-strong);font-size:12px;font-weight:700}.amber-readonly-card>p{color:var(--text-muted);margin-top:14px;font-size:11px;line-height:1.5}.settings-row{border:0;border-top:1px solid var(--divider);width:100%;color:var(--text-muted);text-align:left;background:0 0;align-items:center;gap:12px;padding:15px 16px;display:flex}.settings-row:first-child{border-top:0}.settings-row>span{color:var(--text-strong);flex:1;font-size:13px;font-weight:700}.settings-row small{font-size:11px}button.settings-row{cursor:pointer}.settings-row--danger,.settings-row--danger>span{color:var(--danger-ink)}.empty-device-card{text-align:center}.empty-device-card p{max-width:560px;color:var(--text-muted);margin:10px auto 18px}.integration-required{text-align:center;max-width:680px;margin:8vh auto 0}.integration-required__icon{width:58px;height:58px;color:var(--volt-700);background:var(--volt-100);border-radius:18px;place-items:center;margin:0 auto 16px;display:grid}.integration-required .page-subtitle{max-width:520px;margin:10px auto 20px}.integration-required__security{color:var(--text-muted);justify-content:center;align-items:center;gap:6px;margin-top:16px;font-size:11px;display:flex}.route-loader,.auth-error-page{text-align:center;place-content:center;min-height:100vh;display:grid}.login-page{min-height:100vh;color:var(--night-text);background:var(--night-base);grid-template-columns:minmax(430px,.78fr) minmax(560px,1.22fr);display:grid}.login-panel{z-index:2;flex-direction:column;justify-content:center;max-width:650px;padding:clamp(42px,7vw,100px);display:flex;position:relative}.login-brand,.legal-brand{color:#fff;font-family:var(--font-display);align-items:center;gap:10px;font-size:22px;font-weight:700;text-decoration:none;display:inline-flex}.login-brand>span{background:var(--brand);width:42px;height:42px;box-shadow:var(--shadow-brand);border-radius:13px;place-items:center;display:grid}.login-panel .connect-eyebrow{margin-top:42px}.login-panel h1{color:#fff;letter-spacing:-.05em;max-width:620px;font-size:clamp(38px,5vw,68px)}.login-copy{max-width:600px;color:var(--night-muted);margin-top:18px;font-size:16px;line-height:1.65}.login-features{gap:12px;margin-top:30px;display:grid}.login-features>div{color:var(--volt-300);align-items:center;gap:12px;display:flex}.login-features span{flex-direction:column;display:flex}.login-features strong{color:#fff;font-size:13px}.login-features small{color:var(--night-muted);font-size:11px}.google-login-button{border-radius:var(--radius-md);width:fit-content;min-height:50px;color:var(--text-strong);box-shadow:var(--shadow-md);background:#fff;align-items:center;gap:11px;margin-top:32px;padding:0 20px;font-weight:700;text-decoration:none;display:inline-flex}.google-mark{color:#4285f4;font-family:Arial,sans-serif;font-size:20px;font-weight:700}.login-security{color:var(--night-muted);align-items:center;gap:6px;margin-top:13px;font-size:10.5px;display:flex}.login-legal{gap:18px;margin-top:24px;display:flex}.login-legal a{color:var(--night-muted);font-size:11px}.login-visual{position:relative;overflow:hidden}.login-visual:after{content:"";background:linear-gradient(90deg, var(--night-base), transparent 26%);position:absolute;inset:0}.login-visual img{object-fit:cover;width:100%;height:100%;display:block}.legal-page{background:var(--surface-page);min-height:100vh;padding:34px max(24px,50vw - 450px) 80px}.legal-brand{color:var(--text-strong)}.legal-page article{margin-top:70px}.legal-page h1{margin-top:8px;font-size:42px}.legal-intro{max-width:720px;color:var(--text-muted);margin-top:16px;font-size:16px}.legal-page article section{max-width:760px;margin-top:34px}.legal-page article h2{font-size:19px}.legal-page article section p,.legal-review{color:var(--text-muted);margin-top:9px}.legal-review{border-top:1px solid var(--divider);padding-top:28px;font-size:11px}.auth-error-page{color:var(--danger-ink);padding:24px}.auth-error-page h1{margin-top:14px}.auth-error-page p{color:var(--text-muted);margin-top:10px}.auth-error-page a{color:var(--text-brand);margin-top:20px;font-weight:700}.profile-avatar,.topbar-avatar{object-fit:cover}.assistant-page{border:1px solid var(--border-subtle);border-radius:var(--radius-xl);min-height:calc(100vh - 128px);box-shadow:var(--shadow-sm);background:#ffffffb8;grid-template-rows:auto minmax(360px,1fr) auto;display:grid;overflow:hidden}.assistant-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:11px;padding:20px 22px 16px;display:flex}.assistant-messages{scrollbar-width:thin;flex-direction:column;gap:12px;min-height:360px;padding:22px;display:flex;overflow-y:auto}.assistant-composer{border-top:1px solid var(--border-subtle);background:#ffffffd6;padding:12px 18px 18px}.connect-page{min-height:100vh;color:var(--night-text);background:var(--night-base);grid-template-columns:minmax(320px,.82fr) minmax(420px,1.18fr);align-items:center;gap:clamp(40px,7vw,100px);padding:clamp(28px,6vw,80px);display:grid;position:relative;overflow:hidden}.connect-panel{z-index:2;max-width:570px;position:relative}.connect-eyebrow{color:var(--volt-300);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;font-size:11px;font-weight:700}.connect-title{color:#fff;letter-spacing:-.045em;max-width:560px;font-size:clamp(38px,5vw,68px)}.connect-copy{max-width:560px;color:var(--night-muted);margin-top:18px;margin-bottom:34px;font-size:clamp(15px,1.5vw,18px);line-height:1.65}.connect-features{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.connect-feature{border:1px solid var(--night-border);border-radius:var(--radius-md);background:#ffffff09;align-items:center;gap:12px;padding:14px;display:flex}.connect-actions{align-items:center;gap:18px;margin-top:28px;display:flex}.connect-actions p{color:var(--night-muted);font-size:11.5px}.connect-visual{z-index:1;position:relative}.connect-visual__glow{filter:blur(80px);background:#0ebe8f2e;border-radius:50%;position:absolute;inset:16%}.connect-visual img{border:1px solid var(--night-border);border-radius:30px;width:min(100%,720px);display:block;position:relative;box-shadow:0 30px 80px #0006}.eyebrow{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:700}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.price-tag>.mono{display:none}.price-tag__value{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.grid-texture{opacity:.2;pointer-events:none;background-image:linear-gradient(var(--night-border) 1px, transparent 1px), linear-gradient(90deg, var(--night-border) 1px, transparent 1px);background-size:30px 30px;position:absolute;inset:0}@keyframes giq-flow-in{to{stroke-dashoffset:24px}}@keyframes giq-flow-out{to{stroke-dashoffset:-24px}}@keyframes giq-ring{0%{opacity:.55;transform:scale(.85)}to{opacity:0;transform:scale(1.65)}}@keyframes giq-pulse{0%,to{box-shadow:0 0 #2dd4a78c}50%{box-shadow:0 0 0 7px #2dd4a700}}@keyframes giq-hotspot{0%{opacity:.75;transform:scale(.75)}75%,to{opacity:0;transform:scale(1.7)}}@media (width<=1020px){.app-shell{grid-template-columns:204px minmax(0,1fr)}.screen--dashboard{grid-template-columns:minmax(0,1.45fr) minmax(280px,.85fr)}.connect-features{grid-template-columns:1fr}}@media (width<=760px){body{background:var(--surface-page)}.app-shell{display:block}.sidebar{display:none}.app-topbar{height:60px;padding:0 16px}.is-immersive .app-topbar{box-shadow:none;background:#071019f5;border-bottom-color:#3f5b6d7a}.mobile-brand{display:block}.mobile-brand .app-brand__mark{border-radius:10px;width:32px;height:32px}.mobile-brand .app-brand__name{font-size:17px}.topbar-context,.live-status,.topbar-avatar{display:none}.topbar-actions{margin-left:auto}.app-content{width:100%;padding:20px 16px calc(92px + env(safe-area-inset-bottom))}.is-immersive .app-main,.is-immersive .app-content{min-height:calc(100dvh - 128px)}.is-immersive .app-content{padding:0 0 calc(68px + env(safe-area-inset-bottom))}.network-map{min-height:calc(100dvh - 128px)}.network-map__header{top:14px;left:14px;right:14px}.is-immersive .network-map__header{left:14px}.network-map__header h1{font-size:19px}.network-map__header p:last-child{display:none}.network-map__canvas{width:100%;height:100%}.network-map__overlay--desktop{display:none}.network-map__overlay--mobile{display:block}.network-map__overlay--mobile .network-hotspot__label{opacity:1;transform:none}.network-map__overlay--mobile .network-hotspot__label text{font-size:12px}.network-onboarding{flex-wrap:wrap;align-items:flex-start;padding:12px;bottom:16px;left:12px;right:12px}.network-onboarding__icon{width:36px;height:36px}.network-onboarding>div{flex-basis:calc(100% - 49px)}.network-onboarding button{justify-content:center;width:100%}.mobile-nav{z-index:30;min-height:68px;padding:4px 8px max(6px, env(safe-area-inset-bottom));border-top:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transition:border-color var(--dur-base), background var(--dur-base);background:#ffffffeb;display:flex;position:fixed;bottom:0;left:0;right:0}.is-immersive .mobile-nav{background:#071019f2;border-top-color:#3f5b6d8c}.mobile-nav__item{min-width:0;color:var(--text-subtle);cursor:pointer;background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:10px;display:flex}.mobile-nav__item.is-active{color:var(--brand);font-weight:700}.is-immersive .mobile-nav__item{color:var(--night-muted)}.is-immersive .mobile-nav__item.is-active{color:var(--volt-300)}.screen--dashboard,.screen--devices,.screen--settings,.foxess-device{flex-direction:column;display:flex}.control-pair{grid-template-columns:1fr}.foxess-hero{grid-template-columns:1fr;gap:16px}.foxess-hero__headline{justify-content:flex-start}.charge-period{grid-template-columns:1fr auto 1fr}.charge-period label{grid-column:1/-1}.charge-period input[type=time]{width:100%;min-width:0}.device-detail{display:flex}.device-detail__hero{flex-wrap:wrap;align-items:flex-start}.device-detail__heading{flex-basis:calc(100% - 74px)}.device-detail__hero>span{margin-left:74px}.device-detail__metrics{grid-template-columns:1fr;width:100%}.device-metric strong{font-size:30px}.screen-title{font-size:25px}.page-subtitle{font-size:13px}.assistant-page{border-radius:var(--radius-lg);min-height:calc(100dvh - 172px)}.assistant-header{padding:14px 16px}.assistant-messages{padding:14px}.assistant-composer{padding:8px 10px 10px}.connect-page{flex-direction:column;justify-content:center;min-height:100dvh;padding:44px 22px 28px;display:flex}.connect-title{font-size:34px}.connect-copy{margin-bottom:26px;font-size:15px}.connect-feature{padding:10px}.connect-actions{flex-direction:column;align-items:stretch}.connect-actions button{width:100%}.connect-actions p{text-align:center}.connect-visual{display:none}.login-page{display:block}.login-panel{min-height:100dvh;padding:32px 22px}.login-panel .connect-eyebrow{margin-top:38px}.login-panel h1{font-size:36px}.login-copy{font-size:14px}.google-login-button{justify-content:center;width:100%}.login-visual{display:none}.legal-page{padding:24px 20px 60px}.legal-page article{margin-top:54px}.legal-page h1{font-size:34px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important}}
