:root{--accent: #2185a1;--accent-deep: #176b87;--accent-soft: rgba(33, 133, 161, .12);--solar: #d9a833;--grid: #707d8f;--battery: #42a98c;--consumption: #388ab3;--light: #d1a333;--climate: #cc764d;--sensor: #3d9490;--red: #d64545;--orange: #d98e32;--green: #3fa15c;--blue: #3f7fd9;--text: #1b2430;--text-secondary: rgba(27, 36, 48, .58);--text-tertiary: rgba(27, 36, 48, .36);--surface-glass: rgba(255, 255, 255, .52);--subcard-fill: rgba(255, 255, 255, .55);--border-glass: rgba(255, 255, 255, .55);--hairline: rgba(0, 0, 0, .05);--radius-card: 24px;--radius-chip: 16px;--screen-pad: 20px;--section-gap: 22px}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea,select{-webkit-user-select:text;user-select:text}body{background:linear-gradient(180deg,#fbfdfe,#edf5f7 45%,#dbeaef) fixed;min-height:100vh;overscroll-behavior-y:none}#root{max-width:560px;margin:0 auto;padding:calc(env(safe-area-inset-top) + 12px) var(--screen-pad) calc(env(safe-area-inset-bottom) + 96px);display:flex;flex-direction:column;gap:var(--section-gap)}h1.app-title{font-family:-apple-system,BlinkMacSystemFont,SF Pro Rounded,SF Pro Display,sans-serif;font-size:34px;font-weight:650;letter-spacing:-.4px;margin:8px 0 0}.status-line{color:var(--text-secondary);font-size:15px;margin-top:4px}.section-title{font-size:20px;font-weight:650;letter-spacing:-.2px;margin:0 0 2px}.card{background:#ffffff9e;border:1px solid var(--border-glass);border-radius:var(--radius-card);box-shadow:0 8px 24px #0f283212;padding:18px}.card.tinted-red{background:#d645451a;border-color:#d6454538}.subcard{background:var(--subcard-fill);border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-chip);padding:14px}a{color:inherit;text-decoration:none;touch-action:manipulation}a.block{display:block}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}button:disabled{opacity:.5;cursor:default}button,a.block,.alert-pill,.tab-bar a{transition:transform .34s cubic-bezier(.34,1.3,.5,1),background-color .2s ease,color .2s ease,opacity .16s ease}button:active:not(:disabled),a.block:active,.alert-pill:active{transform:scale(.965);transition-duration:.06s;transition-timing-function:ease-out}.stepper button:active,.page-header .back:active{transform:scale(.84)}@keyframes value-swap{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.value-swap{display:inline-block;animation:value-swap .28s cubic-bezier(.2,.8,.2,1)}.reveal{display:grid;transition:grid-template-rows .32s cubic-bezier(.32,.72,.35,1)}.reveal>*{overflow:hidden;min-height:0}.row{display:flex;align-items:center;gap:10px}.row.spread{justify-content:space-between}.col{display:flex;flex-direction:column;gap:4px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stack{display:flex;flex-direction:column;gap:10px}.muted{color:var(--text-secondary)}.faint{color:var(--text-tertiary)}.small{font-size:13px}.tiny{font-size:11px}.semibold{font-weight:600}.mono{font-variant-numeric:tabular-nums}.icon-circle{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:600}.alert-row{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;margin:0 calc(-1 * var(--screen-pad));padding:2px var(--screen-pad)}.alert-row::-webkit-scrollbar{display:none}.alert-pill{display:flex;align-items:center;gap:10px;background:var(--subcard-fill);border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-chip);padding:12px;white-space:nowrap;flex-shrink:0}.alert-pill .title{font-size:13px;font-weight:600}.alert-pill .detail{font-size:11px;color:var(--text-secondary)}.tile{display:flex;flex-direction:column;min-height:122px;text-align:left;width:100%}.tile .value{font-size:20px;font-weight:650;letter-spacing:-.2px}.tile .label{font-size:12px;font-weight:550;color:var(--text-secondary);margin-top:2px}.tile .detail{font-size:11px;color:var(--text-tertiary);margin-top:1px;min-height:13px}.switch{position:relative;width:51px;height:31px;border-radius:999px;background:#0000001f;transition:background .2s ease;flex-shrink:0}.switch.on{background:var(--accent)}.switch .knob{position:absolute;top:2px;left:2px;width:27px;height:27px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0003;transition:transform .2s ease}.switch.on .knob{transform:translate(20px)}.stepper{display:inline-flex;align-items:center;background:var(--subcard-fill);border-radius:999px;padding:4px 0}.stepper button{width:36px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:17px;font-weight:600}.stepper .value{min-width:62px;text-align:center;font-size:18px;font-weight:650;font-variant-numeric:tabular-nums}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:8px;background:var(--accent-soft);outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 3px 8px #00000026}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-chip);padding:12px 16px;font-size:15px;font-weight:600}.btn.primary{background:var(--accent);color:#fff}.btn.danger{background:var(--red);color:#fff}.btn.soft{background:var(--subcard-fill);border:1px solid var(--hairline)}.btn.block{width:100%}.alarm-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 6px;border-radius:var(--radius-chip);background:var(--subcard-fill);border:1px solid var(--hairline);font-size:12px;font-weight:600}.alarm-btn.active-accent{background:var(--accent-soft);border-color:#2185a147;color:var(--accent)}.alarm-btn.active-orange{background:#d98e321f;border-color:#d98e3247;color:var(--orange)}.tab-bar{position:fixed;bottom:calc(env(safe-area-inset-bottom) + 14px);left:50%;transform:translate(-50%);display:flex;gap:6px;background:#fff9;-webkit-backdrop-filter:blur(20px) saturate(1.6);backdrop-filter:blur(20px) saturate(1.6);border:1px solid rgba(255,255,255,.6);border-radius:999px;padding:6px;box-shadow:0 10px 30px #0f28321f;z-index:50}.tab-bar a{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 18px;border-radius:999px;font-size:11px;font-weight:600;color:var(--text-secondary);position:relative;z-index:1}.tab-bar a.active{color:var(--accent)}.tab-indicator{position:absolute;top:6px;bottom:6px;left:0;border-radius:999px;background:var(--accent-soft);transition:transform .34s cubic-bezier(.3,1.15,.4,1),width .34s cubic-bezier(.3,1.15,.4,1);z-index:0}.page-header{display:flex;align-items:center;gap:8px;margin-top:4px}.page-header .back{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--subcard-fill);border:1px solid var(--hairline)}.page-header h2{font-size:22px;font-weight:650;margin:0}@keyframes pulse{0%,to{transform:scale(.7);opacity:.5}50%{transform:scale(1);opacity:1}}.pulse-dot{width:7px;height:7px;border-radius:50%;animation:pulse 1.6s ease-in-out infinite}.energy-node{fill:#ffffffd9;stroke:#0000000d}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:16px;height:16px;border-radius:50%;border:2px solid var(--accent-soft);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1e2852;z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:backdrop-in .24s ease;transition:opacity .22s ease}.sheet-backdrop.closing{opacity:0}.sheet{width:100%;max-width:560px;max-height:86vh;overflow-y:auto;background:#fcfefff0;-webkit-backdrop-filter:blur(24px) saturate(1.5);backdrop-filter:blur(24px) saturate(1.5);border-radius:24px 24px 0 0;padding:10px 18px calc(env(safe-area-inset-bottom) + 20px);animation:sheet-up .32s cubic-bezier(.32,.72,.35,1);transition:transform .26s cubic-bezier(.32,.72,.35,1)}.sheet.closing{transform:translateY(110%)}.sheet-handle{touch-action:none;cursor:grab;margin:0 -18px;padding:0 18px}.sheet-handle:active{cursor:grabbing}.sheet-grabber{width:38px;height:5px;border-radius:999px;background:#00000026;margin:2px auto 12px}.sheet-done{font-size:15px;font-weight:600;color:var(--accent);padding:6px 4px}@keyframes page-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page{display:flex;flex-direction:column;gap:var(--section-gap)}html:not(.vt) .page{animation:page-in .24s ease}.tab-bar{view-transition-name:tabbar}@keyframes vt-slide-from-right{0%{transform:translate(100%)}}@keyframes vt-slide-to-left{to{transform:translate(-26%);opacity:.6}}@keyframes vt-slide-from-left{0%{transform:translate(-26%);opacity:.6}}@keyframes vt-slide-to-right{to{transform:translate(100%)}}@keyframes vt-fade-in{0%{opacity:0}}@keyframes vt-fade-out{to{opacity:0}}html[data-nav=push]::view-transition-old(root){animation:vt-slide-to-left .32s cubic-bezier(.32,.72,.35,1) both}html[data-nav=push]::view-transition-new(root){animation:vt-slide-from-right .32s cubic-bezier(.32,.72,.35,1) both}html[data-nav=pop]::view-transition-old(root){animation:vt-slide-to-right .3s cubic-bezier(.32,.72,.35,1) both}html[data-nav=pop]::view-transition-new(root){animation:vt-slide-from-left .3s cubic-bezier(.32,.72,.35,1) both}html[data-nav=tab]::view-transition-old(root){animation:vt-fade-out .16s ease both}html[data-nav=tab]::view-transition-new(root){animation:vt-fade-in .16s ease both}@media(prefers-reduced-motion:reduce){*,*:before,*:after,::view-transition-old(root),::view-transition-new(root),::view-transition-old(tabbar),::view-transition-new(tabbar){animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.login-wrap{display:flex;flex-direction:column;gap:24px;padding-top:48px}.field label{font-size:12px;font-weight:550;color:var(--text-secondary);display:block;margin-bottom:7px}.field input{width:100%;font:inherit;font-size:15px;color:var(--text);background:var(--subcard-fill);border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-chip);padding:14px;outline:none}.field input:focus{border-color:#2185a166}
