:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#eef4f8;background:#06070a;font-synthesis:none;text-rendering:optimizeLegibility;--bg: #06070a;--panel: rgba(16, 20, 26, .76);--panel-strong: rgba(20, 25, 32, .92);--line: rgba(190, 213, 220, .16);--line-strong: rgba(190, 213, 220, .28);--text: #eef4f8;--muted: #8d9ba8;--green: #34f08a;--green-soft: rgba(52, 240, 138, .18);--yellow: #ffd84d;--yellow-soft: rgba(255, 216, 77, .18);--blue: #4ec7ff;--blue-soft: rgba(78, 199, 255, .18);--red: #ff5f68;--red-soft: rgba(255, 95, 104, .18);--neutral-soft: rgba(148, 163, 184, .16);--radius: 8px;--shadow: 0 18px 60px rgba(0, 0, 0, .38)}*{box-sizing:border-box}html{background:var(--bg)}body{min-width:320px;min-height:100vh;margin:0;background:linear-gradient(135deg,rgba(30,40,45,.16),transparent 42%),linear-gradient(225deg,rgba(60,39,26,.12),transparent 46%),var(--bg)}button,input{font:inherit}button{color:inherit}button:focus-visible,input:focus-visible{outline:2px solid var(--blue);outline-offset:2px}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:clamp(1.35rem,2vw,2rem);line-height:1.05}h2{margin-bottom:0;font-size:1rem;line-height:1.2}svg{display:block}.eyebrow{margin-bottom:6px;color:var(--muted);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.auth-shell{display:grid;min-height:100vh;padding:20px;place-items:center}.login-panel{width:min(420px,100%);padding:26px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-strong);box-shadow:var(--shadow)}.login-panel h1{margin-bottom:20px}.login-panel p:last-child{margin-bottom:0;color:var(--muted)}.login-panel label{display:flex;flex-direction:column;gap:7px;color:var(--muted);font-size:.88rem}.login-panel input,.deadline-editor input{min-height:42px;padding:9px 11px;border:1px solid var(--line-strong);border-radius:6px;color:var(--text);background:#06070ab8}.login-panel button{width:100%;min-height:42px;margin-top:16px;border:1px solid rgba(52,240,138,.58);border-radius:6px;color:#03140b;background:var(--green);cursor:pointer;font-weight:800}.login-panel button:disabled{cursor:wait;opacity:.62}.notice{padding:13px 15px;border:1px solid rgba(255,216,77,.35);border-radius:var(--radius);color:#ffefad;background:#ffd84d1a}.dashboard-shell{min-height:100vh;padding:18px clamp(14px,2vw,30px) 24px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:64px;padding-bottom:14px}.brand-block,.header-status,.panel-head{display:flex;align-items:center}.brand-block{gap:12px;min-width:0}.app-mark{width:36px;height:36px;flex:0 0 auto;border:1px solid rgba(52,240,138,.45);border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(52,240,138,.95) 0 18%,transparent 19%),conic-gradient(from 220deg,var(--green),var(--yellow),var(--blue),var(--green));box-shadow:0 0 22px #34f08a3d}.header-status{justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}.last-poll{color:var(--muted);font-size:.82rem;white-space:nowrap}.logout-button,.icon-button,.secondary-action,.panel-action{min-height:34px;border-radius:6px;cursor:pointer;font-weight:800}.logout-button,.icon-button,.secondary-action{border:1px solid var(--line-strong);color:var(--text);background:#ffffff0a}.logout-button{padding:6px 12px}.logout-button:hover,.icon-button:hover,.secondary-action:hover{background:#ffffff14}.dashboard-notice{width:min(720px,100%);margin:0 auto 12px}.dashboard-stage{position:relative;display:grid;min-height:calc(100vh - 112px);place-items:center;padding:48px 0 170px}.mode-toggle-slot{position:absolute;z-index:4;top:12px;right:0}.value-mode-toggle{display:inline-grid;grid-template-columns:repeat(2,minmax(86px,1fr));gap:4px;padding:4px;border:1px solid var(--line);border-radius:999px;background:#10141ac7;box-shadow:0 10px 34px #0003}.value-mode-toggle button{min-height:30px;padding:4px 12px;border:0;border-radius:999px;color:var(--muted);background:transparent;cursor:pointer;font-size:.76rem;font-weight:800;white-space:nowrap}.value-mode-toggle button.active{color:#04100b;background:var(--green);box-shadow:0 0 18px #34f08a47}.metric-ring-dial{position:relative;z-index:1;display:grid;width:clamp(340px,45vw,610px);aspect-ratio:1;place-items:center}.stage-glow{position:absolute;z-index:0;top:50%;left:50%;width:min(640px,90vw);height:min(640px,90vw);transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(33,112,228,.22) 0%,transparent 68%);border-radius:50%;pointer-events:none;filter:blur(50px)}.ring-svg{width:100%;height:100%;overflow:visible}.ring-track,.meter-ring,.target-guide,.target-marker{fill:none;transform:rotate(-90deg);transform-origin:130px 130px}.ring-track{stroke:#ffffff14;stroke-width:9}.ring-track--inner{stroke:#34f08a1f}.ring-track.ring-thin,.meter-ring.ring-thin{stroke-width:3}.ring-track.ring-medium,.meter-ring.ring-medium{stroke-width:7}.ring-track.ring-thick,.meter-ring.ring-thick{stroke-width:12}.meter-ring{stroke-linecap:round;stroke-width:9;transition:stroke-dashoffset .9s cubic-bezier(.22,1,.36,1),stroke .48s ease,opacity .48s ease,filter .48s ease;animation:ringGlow 4s ease-in-out infinite;filter:url(#softGlow)}.target-guide{stroke:#34f08a33;stroke-dasharray:4 8;stroke-width:2}.target-marker{stroke:var(--green);stroke-linecap:round;stroke-width:6;transition:stroke-dashoffset .9s cubic-bezier(.22,1,.36,1);filter:drop-shadow(0 0 8px rgba(52,240,138,.5))}.soc-target-tick{fill:none;transform:rotate(-90deg);transform-origin:130px 130px;stroke:#fffffff2;stroke-width:16;stroke-linecap:butt;transition:stroke-dashoffset .9s cubic-bezier(.22,1,.36,1);filter:drop-shadow(0 0 5px rgba(255,255,255,.7))}.soc-req-label{display:block;margin-top:2px;color:#ffffff8c;font-size:.68rem;font-weight:700;letter-spacing:.03em}.soc-value-row{display:flex;align-items:baseline;gap:4px}.soc-trend{font-size:.62rem;font-weight:900;line-height:1;transition:color .36s ease}.soc-trend--up{color:var(--green)!important;text-shadow:0 0 8px rgba(52,240,138,.7)}.soc-trend--down{color:var(--red)!important;text-shadow:0 0 8px rgba(248,113,113,.7)}.tone-green{stroke:var(--green);color:var(--green)}.tone-yellow{stroke:var(--yellow);color:var(--yellow)}.tone-blue{stroke:var(--blue);color:var(--blue)}.tone-red{stroke:var(--red);color:var(--red)}.tone-neutral{color:var(--muted)}.dial-center{position:absolute;z-index:2;display:grid;width:42%;min-width:144px;aspect-ratio:1;place-items:center;align-content:center;gap:12px;border:1px solid rgba(255,255,255,.08);border-radius:50%;background:radial-gradient(circle,#141920fa,#080a0df0);box-shadow:inset 0 0 34px #ffffff0a,0 0 40px #00000047}.dial-state{font-size:clamp(1.05rem,2.5vw,1.8rem);font-weight:900;line-height:1;text-align:center}.dial-state.tone-active{color:#fff;text-shadow:0 0 18px rgba(255,255,255,.26)}.dial-state.tone-muted{color:var(--muted)}.charge-rate{display:inline-flex;align-items:center;justify-content:center;gap:7px;color:var(--muted);font-size:clamp(.74rem,1.4vw,.9rem);font-weight:800;text-align:center}.charge-rate i{width:10px;height:10px;flex:0 0 auto;border-radius:50%;background:#94a3b88c}.charge-rate i.active{background:var(--green);box-shadow:0 0 16px #34f08aad;animation:ledPulse 1.6s ease-in-out infinite}.ring-label{position:absolute;z-index:3;pointer-events:none}.ring-label--grid{top:0;left:0}.ring-label--pv{top:0;right:0}.ring-label--battery{bottom:0;left:0}.ring-label--load{bottom:0;right:0}.ring-metric-label{min-width:clamp(104px,14vw,150px);max-width:168px;padding:9px 11px;border:1px solid rgba(148,163,184,.12);border-left:3px solid currentColor;border-radius:var(--radius);background:#080a0dd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 10px 34px #00000047;transition:color .42s ease,border-color .42s ease,box-shadow .42s ease}.ring-metric-label span{display:block;color:var(--muted);font-size:clamp(.62rem,1.4vw,.74rem);font-weight:800;letter-spacing:.04em;text-transform:uppercase}.ring-metric-label strong{display:block;margin-top:3px;color:currentColor;font-size:clamp(.98rem,2vw,1.35rem);line-height:1.1;text-shadow:0 0 10px currentColor}.value-pulse{animation:valuePulse .62s ease}.dashboard-panels{position:absolute;right:0;bottom:10px;left:0;display:grid;grid-template-columns:minmax(300px,430px) minmax(300px,430px);gap:22px;justify-content:space-between;align-items:end}.glass-panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.predictions-panel,.charge-control-panel{min-width:0;padding:18px}.panel-head{justify-content:space-between;gap:14px;margin-bottom:16px}.panel-head .eyebrow{margin-bottom:4px}.status-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 9px;border:1px solid currentColor;border-radius:999px;background:#ffffff0a;font-size:.72rem;font-weight:900;white-space:nowrap;transition:color .36s ease,background-color .36s ease,border-color .36s ease}.status-badge.tone-green{background:var(--green-soft)}.status-badge.tone-yellow{background:var(--yellow-soft)}.status-badge.tone-red{background:var(--red-soft)}.status-badge.tone-neutral{border-color:#94a3b857;background:var(--neutral-soft)}.control-facts{display:grid;gap:10px}.prediction-list{display:flex;flex-direction:column}.prediction-list div,.control-facts div{min-width:0;padding:10px;border:1px solid rgba(255,255,255,.07);border-radius:6px;background:#ffffff09}.prediction-list div{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:11px 0;border:none;border-bottom:1px solid var(--line);border-radius:0;background:transparent}.prediction-list div:last-child{border-bottom:none;padding-bottom:0}.prediction-list span,.control-facts span,.deadline-editor label span{display:block;margin-bottom:5px;color:var(--muted);font-size:.73rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase}.prediction-list span{margin-bottom:0;font-size:.82rem;font-weight:400;letter-spacing:normal;text-transform:none}.prediction-list strong,.control-facts strong{display:block;min-width:0;color:var(--text);font-size:1.06rem;overflow-wrap:anywhere}.prediction-list strong{flex-shrink:0;font-size:.88rem;font-family:JetBrains Mono,monospace}.prediction-list .positive strong{color:var(--green)}.prediction-list .negative strong{color:var(--red)}.automation-reason{margin:13px 0 0;color:var(--muted);font-size:.82rem;line-height:1.35}.prediction-unavailable{margin:8px 0 0;color:var(--muted);font-size:.82rem;font-style:italic}.control-segmented{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:5px;padding:5px;border:1px solid var(--line);border-radius:var(--radius);background:#06070a6b}.control-segmented button{min-height:36px;border:0;border-radius:6px;color:var(--muted);background:transparent;cursor:pointer;font-weight:900}.control-segmented button.active{color:#05110b;background:var(--green);box-shadow:0 0 18px #34f08a33}.control-segmented button:disabled{cursor:wait;opacity:.65}.control-facts{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}.panel-action{width:100%;margin-top:14px;padding:7px 12px;border:1px solid rgba(78,199,255,.6);color:#06131a;background:var(--blue)}.panel-action:disabled,.secondary-action:disabled{cursor:wait;opacity:.6}.modal-backdrop{position:fixed;z-index:20;top:0;right:0;bottom:0;left:0;display:grid;padding:20px;background:#00000094;place-items:center}.modal-close-layer{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:transparent;cursor:default}.deadline-editor{position:relative;z-index:1;width:min(440px,100%);margin:0;padding:18px;color:var(--text)}.icon-button{width:34px;padding:0}.deadline-editor-form{display:grid;gap:12px}.deadline-editor label{display:grid;gap:4px}.deadline-editor-actions{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.deadline-editor-actions .panel-action{margin-top:0}.secondary-action{padding:7px 13px}@keyframes ringGlow{0%,to{opacity:.88}50%{opacity:1}}@keyframes ledPulse{0%,to{transform:scale(1);box-shadow:0 0 12px #34f08a75}50%{transform:scale(1.22);box-shadow:0 0 22px #34f08ad1}}@keyframes valuePulse{0%{opacity:.72;text-shadow:0 0 0 transparent}45%{opacity:1;text-shadow:0 0 18px currentColor}to{opacity:1;text-shadow:0 0 0 transparent}}.energy-flow-slot{position:absolute;z-index:4;top:10px;left:0;max-width:500px;width:max-content}.energy-flow-panel{min-width:0;padding:18px;white-space:nowrap}.energy-flow-panel .panel-head{white-space:normal}.energy-rings{display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:center;margin-top:4px}.ef-divider{width:1px;height:80px;margin:0 12px;background:var(--line)}.energy-ring-item{display:grid;grid-template-columns:90px 1fr;gap:10px;align-items:center}.energy-ring-svg{width:90px;height:90px;overflow:visible}.ef-track{fill:none;stroke:#ffffff0f;stroke-width:9}.ef-arc{fill:none;stroke-width:9;stroke-linecap:butt;transform:rotate(-90deg);transform-origin:50px 50px;transition:stroke-dashoffset .9s cubic-bezier(.22,1,.36,1)}.ef-arc--import{stroke:#fb923c59}.ef-arc--autarkie{stroke:var(--green);filter:drop-shadow(0 0 4px rgba(52,240,138,.5))}.ef-arc--export{stroke:#38bdf859}.ef-arc--eigenverbrauch{stroke:var(--green);filter:drop-shadow(0 0 4px rgba(52,240,138,.5))}.ef-center-value{fill:var(--text);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;text-anchor:middle;dominant-baseline:auto}.ef-center-unit{fill:var(--muted);font-size:8px;font-weight:600;text-anchor:middle;dominant-baseline:auto}.ef-label-block{display:flex;flex-direction:column;gap:2px;min-width:0}.ef-title{color:var(--muted);font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.ef-pct{color:var(--green);font-family:JetBrains Mono,monospace;font-size:1.32rem;font-weight:700;text-shadow:0 0 10px rgba(52,240,138,.5);line-height:1.1}.ef-sub{color:var(--muted);font-size:.7rem;line-height:1.3}.ef-sub--green{color:#34f08ab3}@media(max-width:1120px){.dashboard-stage{display:flex;min-height:auto;flex-direction:column;gap:18px;padding:58px 0 24px}.mode-toggle-slot{right:50%;transform:translate(50%)}.energy-flow-slot{position:static;width:100%;max-width:100%}.energy-flow-panel{width:100%}.dashboard-panels{position:static;width:100%;grid-template-columns:repeat(2,minmax(0,1fr))}.metric-ring-dial{width:min(610px,92vw)}}@media(max-width:760px){.dashboard-shell{padding:12px 10px 18px}.dashboard-header{align-items:flex-start;flex-direction:column}.header-status{justify-content:flex-start}.last-poll{white-space:normal}.dashboard-panels,.control-facts,.energy-rings{grid-template-columns:1fr}.ef-divider{display:none}.metric-ring-dial{width:min(100%,430px)}.ring-metric-label{min-width:96px;padding:7px 8px}.ring-label--pv{top:0;right:0;left:auto}.ring-label--load{bottom:0;top:auto;right:0}.ring-label--grid{top:0;bottom:auto;left:0}.dashboard-stage{padding-top:54px}}@media(max-width:420px){.value-mode-toggle{grid-template-columns:1fr 1fr;width:calc(100vw - 20px)}.value-mode-toggle button{padding-inline:6px;font-size:.7rem}.dial-center{min-width:118px}.ring-label--battery{bottom:0;top:auto;left:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:80ms!important}}
