:root{--bg-primary: #fafafa;--bg-secondary: #f0f0f0;--bg-card: #ffffff;--text-primary: #1a1a1a;--text-secondary: #666666;--accent-temp: #e74c3c;--accent-humidity: #3498db;--accent-co2: #f39c12;--accent-battery: #27ae60;--border-color: #e0e0e0;--shadow: 0 2px 8px rgba(0, 0, 0, .08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;padding:4rem 2rem 2rem}.dashboard{max-width:1200px;margin:0 auto}header{margin-bottom:2rem}h1{font-size:1.75rem;font-weight:600;color:var(--text-primary)}h1 span{color:var(--text-secondary);font-weight:400}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}@media(max-width:768px){body{padding:1rem .75rem}header{margin-bottom:1rem}h1{font-size:1.3rem}.stats{grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.stat-card{padding:.75rem;border-radius:8px}.stat-label{font-size:.65rem;margin-bottom:.25rem}.stat-value{font-size:1.6rem}.stat-unit{font-size:.75rem}.stat-minmax{flex-direction:column;gap:0;font-size:.8rem;line-height:.2}.stat-minmax span{gap:.2rem}.stat-minmax .label{font-size:.6rem}.time-selector{flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}.time-btn{padding:.35rem .6rem;font-size:.7rem}.charts{gap:.75rem}.chart-container{padding:.75rem;border-radius:8px}.chart-title{font-size:.8rem;margin-bottom:.5rem}.chart-wrapper{height:180px}.last-update{margin-top:.25rem;font-size:.65rem}}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow)}.stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-family:Space Mono,monospace}.stat-value{font-size:2.5rem;font-weight:700;font-family:Space Mono,monospace}.stat-value.temp{color:var(--accent-temp)}.stat-value.humidity{color:var(--accent-humidity)}.stat-value.co2{color:var(--accent-co2)}.stat-value.battery{color:var(--accent-battery)}.stat-unit{font-size:1rem;color:var(--text-secondary);font-weight:400}.stat-minmax{display:flex;gap:1.25rem;margin-top:.75rem;font-family:Space Mono,monospace;font-size:1.1rem;color:var(--text-secondary)}.stat-minmax span{display:flex;align-items:baseline;gap:.3rem}.stat-minmax .label{opacity:.6;font-size:.7rem;text-transform:uppercase}.stat-value-row{display:flex;align-items:baseline;gap:.75rem}.stat-voltage{font-family:Space Mono,monospace;font-size:1rem;color:var(--text-secondary);opacity:.7}.voltage-small{font-size:.75em;opacity:.7;margin-left:.2em}.charts{display:grid;gap:1.5rem}.chart-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow)}.chart-title{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem;font-weight:500}.chart-wrapper{position:relative;height:280px}.time-selector{display:flex;gap:.5rem;margin-bottom:1.5rem}.time-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-family:Space Mono,monospace;font-size:.8rem;transition:all .2s}.time-btn:hover{background:var(--bg-card);border-color:var(--text-secondary)}.time-btn.active{background:var(--text-primary);color:var(--bg-card);border-color:var(--text-primary)}.time-separator{color:var(--text-secondary);display:flex;align-items:center;padding:0 .5rem;opacity:.5}.date-range-picker{display:flex;align-items:center;gap:.5rem}.date-input{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem .75rem;border-radius:8px;font-family:Space Mono,monospace;font-size:.8rem;cursor:pointer}.date-input::-webkit-calendar-picker-indicator{filter:invert(.8);cursor:pointer}.date-range-separator{color:var(--text-secondary);font-size:.9rem}.apply-btn{background:var(--accent-color, #4a9eff);border-color:var(--accent-color, #4a9eff);color:#fff}.apply-btn:hover{opacity:.9}.last-update{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;font-family:Space Mono,monospace}.error-message{background:#fee;border:1px solid #fcc;color:#c00;padding:1rem;border-radius:8px;margin-bottom:1rem;display:none}
