: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}.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}.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)}svg.chart{width:100%;height:200px}svg.presence-chart{width:100%;height:120px}svg.chart,svg.presence-chart{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-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.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{position:absolute;top:16px;right:16px;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}svg.presence-chart{height:150px}.chart-container{padding:12px 6px}.chart-legend{gap:6px 12px;font-size:.85em}.chart-header{flex-direction:column;align-items:flex-start;gap:4px}}
