*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{min-height:100vh}*{box-sizing:border-box}body{color:#1e293b;background:#f8fafc;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}header{background:#fff;border-bottom:1px solid #e2e8f0;padding:20px 32px}header h1{color:#1e293b;margin:0;font-size:1.5rem;font-weight:700}header .subtitle{color:#64748b;margin:4px 0 0;font-size:.875rem}.layout{flex:1;gap:0;display:flex}.controls{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;gap:28px;width:280px;padding:24px 20px;display:flex;overflow-y:auto}.controls section{flex-direction:column;gap:14px;display:flex}.controls h2{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin:0 0 4px;font-size:.7rem;font-weight:600}.input-group{flex-direction:column;gap:5px;display:flex}.input-group label{color:#475569;font-size:.8rem;font-weight:500}.input-row{background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.input-row:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.input-adornment{color:#94a3b8;background:#f8fafc;border-right:1px solid #e2e8f0;align-items:center;height:36px;padding:0 8px;font-size:.85rem;display:flex}.input-adornment:last-child{border-left:1px solid #e2e8f0;border-right:none}.input-group input{color:#1e293b;background:0 0;border:none;outline:none;flex:1;min-width:0;height:36px;padding:0 10px;font-size:.875rem}.results{flex-direction:column;flex:1;gap:24px;padding:24px 28px;display:flex;overflow-y:auto}.summary-cards{flex-wrap:wrap;gap:14px;display:flex}.card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex:160px;padding:16px 18px}.card-good{background:#f0fdf4;border-color:#6ee7b7}.card-warn{background:#fff5f5;border-color:#fca5a5}.card-label{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:6px;font-size:.72rem;font-weight:600}.card-warn .card-label{color:#ef4444}.card-good .card-label{color:#059669}.card-value{color:#1e293b;font-size:1.6rem;font-weight:700;line-height:1.2}.card-sub{color:#94a3b8;margin-top:4px;font-size:.75rem}.chart-container{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:20px 20px 12px}.chart-container h3{color:#475569;margin:0 0 16px;font-size:.875rem;font-weight:600}.tooltip{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 14px;font-size:.8rem;line-height:1.7;box-shadow:0 4px 16px #00000014}.tooltip p{margin:0}.tooltip-title{color:#1e293b;border-bottom:1px solid #f1f5f9;padding-bottom:4px;font-weight:600;margin-bottom:4px!important}.sidebar-tabs{border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;gap:0;display:flex;overflow:hidden}.tab-btn{color:#64748b;cursor:pointer;background:#f8fafc;border:none;flex:1;padding:8px 0;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.tab-btn:hover{color:#1e293b;background:#f1f5f9}.tab-btn.active{color:#fff;background:#6366f1}.forecast-compare{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:6px;padding:10px 12px;font-size:.78rem;display:flex}.compare-row{flex-direction:column;gap:1px;display:flex}.compare-label{text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-size:.68rem;font-weight:600}.compare-desc{color:#475569}.delta-badge{text-align:center;border-radius:20px;margin-top:4px;padding:4px 10px;font-size:.78rem;font-weight:700}.delta-good{color:#15803d;background:#dcfce7}.delta-bad{color:#b91c1c;background:#fee2e2}.location-row{align-items:center;gap:8px;display:flex}.location-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.location-fields{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.location-name-input{color:#1e293b;background:#fff;border:1px solid #cbd5e1;border-radius:6px;outline:none;width:100%;height:30px;padding:0 10px;font-size:.8rem;transition:border-color .15s}.location-name-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.remove-btn{color:#94a3b8;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex-shrink:0;padding:4px 7px;font-size:.75rem;transition:background .15s,color .15s}.remove-btn:hover{color:#ef4444;background:#fee2e2;border-color:#fca5a5}.add-location-btn{color:#6366f1;cursor:pointer;background:0 0;border:1px dashed #cbd5e1;border-radius:6px;width:100%;padding:7px;font-size:.8rem;font-weight:600;transition:background .15s}.add-location-btn:hover{background:#f5f3ff}.location-summary{border-top:1px solid #f1f5f9;flex-direction:column;gap:8px;margin-top:14px;padding-top:14px;display:flex}.location-summary-row{flex-wrap:wrap;align-items:center;gap:8px;font-size:.8rem;display:flex}.location-summary-row strong{color:#1e293b}.location-summary-row span:not(.location-dot):not(.delta-pill){color:#64748b}.delta-pill{border-radius:20px;padding:2px 8px;font-size:.72rem;font-weight:700}.tooltip-divider{border:none;border-top:1px solid #f1f5f9;margin:5px 0}@media (width<=768px){.layout{flex-direction:column}.controls{border-bottom:1px solid #e2e8f0;border-right:none;width:100%}.results{padding:16px}}
