:root{--bg: #1a1a2e;--card: #16213e;--card-border: #0f3460;--text: #e0e0e0;--text-dim: #8892a0;--accent: #e94560;--green: #4ecca3;--orange: #f0a500;--blue: #3498db}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;padding:16px}header{text-align:center;padding:8px 0 12px}header h1{font-size:1.4em;font-weight:600;color:var(--text)}header .updated{font-size:.8em;color:var(--text-dim);margin-top:4px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;max-width:900px;margin:0 auto}.card{background:var(--card);border:1px solid var(--card-border);border-radius:12px;padding:16px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.card-title{font-size:.85em;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.card-icon{font-size:1.2em}.big-value{font-size:2.2em;font-weight:700;line-height:1}.sub-value{font-size:.9em;color:var(--text-dim);margin-top:6px}.people-list{display:flex;gap:12px;flex-wrap:wrap}.person{display:flex;align-items:center;gap:6px;font-size:1.1em}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dot.home{background:var(--green)}.dot.away{background:var(--accent)}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75em;font-weight:600;text-transform:uppercase}.badge.heating{background:var(--accent);color:#fff}.badge.idle{background:#333;color:var(--text-dim)}.badge.schedule{background:var(--blue);color:#fff}.badge.manual{background:var(--orange);color:#111}.badge.cleaned{background:var(--green);color:#111}.badge.not-cleaned{background:#333;color:var(--text-dim)}.humidity-bar{width:100%;height:8px;background:#333;border-radius:4px;margin-top:10px;overflow:hidden}.humidity-bar .fill{height:100%;border-radius:4px;transition:width .5s ease}.header-actions{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:8px}.header-actions .logout-btn{position:static}.settings-btn{background:none;border:1px solid var(--card-border);color:var(--text-dim);padding:4px 8px;border-radius:6px;cursor:pointer;display:flex;align-items:center}.settings-btn:hover{border-color:var(--blue);color:var(--blue)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:var(--card);border:1px solid var(--card-border);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;outline:none}.modal-dialog{outline:none}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 16px 0}.modal-title{font-size:1.1em;font-weight:600;color:var(--text)}.modal-close{background:none;border:none;color:var(--text-dim);font-size:1.5em;cursor:pointer;padding:0 4px;line-height:1}.modal-close:hover{color:var(--text)}.modal-header{padding:20px 24px 0}.modal-body{padding:0 24px 24px}.modal-section{padding:28px 0}.modal-section+.modal-section{border-top:1px solid var(--card-border)}.modal-section:last-child{padding-bottom:0}.section-title{font-size:.85em;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:16px}.section-divider{border:none;border-top:1px solid var(--card-border);margin:20px 0 0}.vacation-dates{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:600px){.vacation-dates{grid-template-columns:1fr}}.badge.vacation{background:var(--blue);color:#fff}.control-form{padding:16px}.override-active{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f0a5001a;border:1px solid var(--orange);border-radius:8px;margin-bottom:20px;font-size:.9em;flex-wrap:wrap}.badge.override{background:var(--orange);color:#111}.cancel-btn{margin-left:auto;padding:4px 12px;border-radius:6px;border:1px solid var(--accent);background:none;color:var(--accent);font-size:.8em;cursor:pointer;font-family:inherit}.cancel-btn:hover{background:var(--accent);color:#fff}.override-set{display:flex;flex-direction:column;gap:20px}.slider-row,.duration-row{display:flex;flex-direction:column;gap:4px}.temp-slider,.config-item .react-aria-Slider{width:100%}.slider-header{display:flex;justify-content:space-between;font-size:.85em;color:var(--text-dim);margin-bottom:8px}.slider-track{width:100%;height:6px;background:#333;border-radius:3px;position:relative;cursor:pointer}.slider-track:before{content:"";position:absolute;height:100%;background:var(--blue);border-radius:3px}.slider-thumb{width:20px;height:20px;border-radius:50%;background:var(--blue);border:2px solid #fff;top:50%;cursor:grab}.slider-thumb:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.slider-thumb[data-dragging]{cursor:grabbing;background:#2980b9}.duration-select{display:flex;flex-direction:column;gap:4px}.duration-select [slot=label]{font-size:.85em;color:var(--text-dim)}.select-btn{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg);border:1px solid var(--card-border);border-radius:8px;color:var(--text);font-size:.9em;font-family:inherit;cursor:pointer}.select-btn:hover{border-color:var(--blue)}.chevron{font-size:.7em;color:var(--text-dim)}.select-popover{background:var(--card);border:1px solid var(--card-border);border-radius:8px;overflow:hidden;box-shadow:0 8px 24px #0006}.select-listbox{padding:4px;outline:none}.select-item{padding:8px 12px;border-radius:6px;font-size:.9em;cursor:pointer;outline:none;color:var(--text)}.select-item[data-focused]{background:#3498db26}.select-item[data-selected]{color:var(--blue);font-weight:600}.action-btn{width:100%;padding:10px;border-radius:8px;border:none;background:var(--blue);color:#fff;font-size:.95em;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s}.action-btn:hover{background:#2980b9}.action-btn[data-disabled]{opacity:.5;cursor:default}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.config-item{display:flex;flex-direction:column;gap:4px}.config-label{font-size:.85em;color:var(--text-dim)}.config-input{padding:8px 12px;background:var(--bg);border:1px solid var(--card-border);border-radius:8px;color:var(--text);font-size:.9em;font-family:inherit;outline:none}.config-input:focus{border-color:var(--blue)}.control-feedback{margin-top:12px;padding:8px 12px;background:#4ecca31a;border:1px solid var(--green);border-radius:6px;font-size:.85em;color:var(--green);text-align:center}.control-feedback.error{background:#e945601a;border-color:var(--accent);color:var(--accent)}@media(max-width:600px){.config-grid{grid-template-columns:1fr}}.range-selector{display:flex;justify-content:center;gap:6px;margin:24px auto 14px;max-width:900px}.range-btn{background:var(--card);border:1px solid var(--card-border);color:var(--text-dim);padding:6px 16px;border-radius:8px;cursor:pointer;font-size:.85em;font-family:inherit;transition:all .2s}.range-btn:hover{border-color:var(--blue);color:var(--text)}.range-btn.active,.range-btn[data-selected=true]{background:var(--blue);color:#fff;border-color:var(--blue)}.chart-container{max-width:900px;margin:16px auto 0;background:var(--card);border:1px solid var(--card-border);border-radius:12px;padding:16px;-webkit-user-select:none;user-select:none}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.chart-title{font-size:.85em;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.chart-legend{display:flex;gap:16px;font-size:.8em;color:var(--text-dim);flex-wrap:wrap}.chart-legend span:before{content:"";display:inline-block;width:12px;height:3px;margin-right:4px;vertical-align:middle;border-radius:1px}.chart-legend .temp:before{background:var(--accent)}.chart-legend .hum:before{background:var(--blue)}.chart-legend .sp:before{background:var(--orange)}.chart-legend .temp-ext:before{background:var(--green)}.chart-legend .leg-francesco:before{background:var(--blue)}.chart-legend .leg-carolina:before{background:var(--accent)}.chart-legend.interactive span{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .2s}.chart-legend.interactive span:hover{opacity:.8}.chart-legend.interactive span.legend-hidden{opacity:.3;text-decoration:line-through}.zoom-reset{margin-left:10px;background:var(--card-border);border:none;color:var(--text-dim);font-size:.75em;padding:2px 8px;border-radius:4px;cursor:pointer;vertical-align:middle}.zoom-reset:hover{background:var(--accent);color:#fff}svg.chart{width:100%;height:320px;cursor:crosshair}.pie-row{display:flex;gap:16px;max-width:900px;margin:16px auto 0;flex-wrap:wrap}.pie-card{flex:1 1 0;min-width:150px;background:var(--card);border:1px solid var(--card-border);border-radius:12px;padding:16px;text-align:center}.pie-card .card-title{margin-bottom:8px}.pie-card svg{display:block;margin:0 auto}.pie-card .recharts-wrapper{margin:0 auto}.pie-pct{font-size:1.6em;font-weight:700;margin-top:6px}.pie-detail{font-size:.8em;color:var(--text-dim);margin-top:4px}.savings-pct{font-size:2em;font-weight:700;margin:12px 0 8px}.savings-bar-container{display:flex;flex-direction:column;gap:4px;margin:8px 0}.savings-bar-row{display:flex;align-items:center;gap:8px;font-size:.75em;color:var(--text-dim)}.savings-bar-row .bar-label{width:32px;text-align:right;flex-shrink:0}.savings-bar-row .bar-track{flex:1;height:10px;background:#333;border-radius:5px;overflow:hidden}.savings-bar-row .bar-fill{height:100%;border-radius:5px;transition:width .5s ease}.savings-detail{font-size:.85em;color:var(--text);margin-top:8px}.savings-sub{font-size:.8em;color:var(--text-dim);margin-top:2px}.savings-note{font-size:.75em;color:var(--text-dim);font-style:italic;margin-top:8px}.stale-banner{background:var(--orange);color:#111;text-align:center;padding:6px 12px;font-size:.85em;font-weight:600;border-radius:8px;max-width:900px;margin:0 auto 12px}.chart-tooltip{position:fixed;background:#16213ef2;border:1px solid var(--card-border);border-radius:8px;padding:8px 12px;font-size:.8em;color:var(--text);pointer-events:none;z-index:100;display:none;white-space:nowrap;line-height:1.6}.chart-tooltip .tt-time{color:var(--text-dim);font-size:.9em;margin-bottom:2px}.chart-tooltip .tt-row{display:flex;align-items:center;gap:6px}.chart-tooltip .tt-row-inline{display:flex;align-items:center;gap:12px}.chart-tooltip .tt-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;margin-right:4px}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.login-screen h1{font-size:1.6em}.login-form{display:flex;flex-direction:column;gap:12px;width:280px}.login-form [slot=label]{display:none}.login-form input{padding:10px 14px;border-radius:8px;border:1px solid var(--card-border);background:var(--card);color:var(--text);font-size:1em;outline:none;width:100%}.login-form input:focus{border-color:var(--accent)}.login-btn{padding:10px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:1em;font-weight:600;cursor:pointer}.login-btn[data-disabled=true]{opacity:.5}.login-error{color:var(--accent);font-size:.85em;text-align:center;min-height:1.2em}.logout-btn{background:none;border:1px solid var(--card-border);color:var(--text-dim);padding:4px 12px;border-radius:6px;font-size:.8em;cursor:pointer}.logout-btn:hover{border-color:var(--accent);color:var(--accent)}.recharts-wrapper:focus,.recharts-wrapper *:focus,.recharts-surface:focus{outline:none}.error-msg{color:var(--accent);font-size:.9em;text-align:center;padding:20px}@media(max-width:600px){body{padding:8px}.big-value{font-size:1.8em}.grid{gap:8px}.card{padding:12px}.pie-row{gap:8px}.pie-card{flex:1 1 calc(50% - 4px);min-width:0}.range-btn{padding:6px 10px;font-size:.8em}svg.chart{height:240px}.chart-container{padding:12px 6px}.chart-legend{gap:6px 12px;font-size:.85em}.chart-header{flex-direction:column;align-items:flex-start;gap:4px}}
