*{box-sizing:border-box}html,body,#root{margin:0;min-height:100vh;background:#0f172a;color:#f1f5f9;font-family:Heebo,Segoe UI,system-ui,sans-serif}.app{max-width:1200px;margin:0 auto;padding:24px 20px 48px}.header{text-align:center;margin-bottom:32px}.header h1{margin:0 0 8px;font-size:1.75rem}.header p{margin:0;color:#94a3b8}.card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:20px;margin-bottom:20px}.upload-zone{border:2px dashed #334155;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.dragover{border-color:#22c55e;background:#22c55e0d}.upload-zone input{display:none}.upload-zone.upload-compact{padding:16px 24px}.error{background:#ef44441a;border:1px solid #ef4444;color:#fecaca;padding:12px 16px;border-radius:8px;margin-bottom:16px}.archive-notice{background:#f59e0b1f;border:1px solid #f59e0b;color:#fde68a;padding:12px 16px;border-radius:8px;margin-bottom:16px;text-align:right}.quality-warning{background:#f59e0b26;border:1px solid #f59e0b;color:#fef3c7;padding:14px 16px;border-radius:8px;margin-bottom:16px;text-align:right}.quality-warning strong{display:block;margin-bottom:6px;color:#fcd34d}.quality-warning p{margin:0 0 6px;font-size:14px;line-height:1.5}.quality-warning-reasons{font-size:13px;color:#fde68a;opacity:.95}.meta-bar{display:flex;flex-wrap:wrap;gap:16px;color:#94a3b8;font-size:14px;margin-bottom:20px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:20px}.kpi{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:16px}.kpi-label{font-size:13px;color:#94a3b8;margin-bottom:6px}.kpi-value{font-size:1.5rem;font-weight:600;color:#22c55e}.kpi-sub{font-size:12px;color:#64748b;margin-top:4px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px;margin-bottom:20px}.section-header{margin:36px 0 16px;padding-bottom:10px;border-bottom:2px solid #334155}.section-header h2{display:flex;align-items:center;gap:10px;margin:0 0 6px;font-size:1.2rem}.section-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#22c55e;color:#0f172a;font-size:.9rem;font-weight:700;flex-shrink:0}.section-header p{margin:0;font-size:13px;color:#94a3b8;max-width:900px}.chart-card h3{margin:0 0 16px;font-size:1rem}.insights-list{display:flex;flex-direction:column;gap:12px}.insight{padding:14px 16px;border-radius:8px;border-right:4px solid}.insight.warning{background:#eab30814;border-color:#eab308}.insight.success{background:#22c55e14;border-color:#22c55e}.insight.info{background:#3b82f614;border-color:#3b82f6}.insight h4{margin:0 0 6px;font-size:15px}.insight p{margin:0 0 6px;font-size:14px;color:#cbd5e1}.insight .action{font-size:13px;color:#94a3b8}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:10px 12px;text-align:right;border-bottom:1px solid #334155}th{color:#94a3b8;font-weight:500}.btn{background:#22c55e;color:#0f172a;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px}.btn:hover{background:#16a34a}.btn-secondary{background:transparent;color:#94a3b8;border:1px solid #334155;margin-right:8px}.loading{text-align:center;padding:40px;color:#94a3b8}.heatmap-card{padding:24px}.heatmap-scroll{overflow:auto;max-height:min(70vh,900px);border:1px solid #334155;border-radius:8px;padding:12px;background:#0f172a}.heatmap-layout{display:flex;gap:8px;direction:ltr}.heatmap-y-labels{flex-shrink:0;text-align:left}.heatmap-day-label{font-size:10px;color:#94a3b8;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.heatmap-day-label.weekend{color:#60a5fa;font-weight:600}.heatmap-legend{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:12px;color:#94a3b8}.heatmap-legend-bar{width:160px;height:10px;border-radius:5px;background:linear-gradient(to right,#1e293b,#827d32,#e6c814)}.heatmap-legend-avg{margin-right:16px;color:#cbd5e1}.heatmap-x-labels,.heatmap-row{display:flex;gap:1px}.heatmap-hour-label{text-align:center;color:#64748b;flex-shrink:0;font-size:10px}.heatmap-cell{flex-shrink:0;border-radius:2px;cursor:default}.heatmap-temp-col{padding-top:0}.heatmap-temp-cell{font-size:9px;line-height:14px;text-align:center;color:#f8fafc;border-radius:2px;font-weight:600}.rec-section-title{margin:20px 0 12px;font-size:1rem;padding-bottom:6px;border-bottom:1px solid #334155}.rec-section-title.consumption{color:#4ade80}.rec-section-title.cost{color:#fbbf24}.rec-list{display:flex;flex-direction:column;gap:12px}.rec-item{padding:14px 16px;border-radius:8px;background:#0f172a;border:1px solid #334155;border-right:4px solid #64748b}.rec-item.high{border-right-color:#ef4444}.rec-item.medium{border-right-color:#eab308}.rec-item.low{border-right-color:#3b82f6}.rec-item-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}.rec-item h4{margin:0 0 6px;font-size:15px}.rec-item p{margin:0 0 8px;font-size:14px;color:#cbd5e1}.rec-priority{font-size:11px;padding:2px 8px;border-radius:10px;white-space:nowrap}.rec-priority.high{background:#ef444426;color:#fca5a5}.rec-priority.medium{background:#eab30826;color:#fde047}.rec-priority.low{background:#3b82f626;color:#93c5fd}.rec-estimate{font-size:13px;color:#4ade80}.season-peak-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;max-width:520px}.season-peak-grid-header{font-size:13px;font-weight:600;color:#94a3b8;text-align:center;padding:4px}.season-peak-grid-header.peak{color:#eab308}.season-peak-grid-header.offpeak{color:#22c55e}.season-peak-grid-season{display:flex;align-items:center;font-weight:600;padding:12px;border-right:4px solid;color:#f1f5f9}.season-peak-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px;border-radius:10px;border:1px solid #334155;background:#0f172a}.season-peak-cell.peak{border-color:#eab30859}.season-peak-cell.offpeak{border-color:#22c55e59}.season-peak-value{font-size:1.5rem;font-weight:700;color:#f1f5f9}.season-peak-cell.peak .season-peak-value{color:#fde047}.season-peak-cell.offpeak .season-peak-value{color:#4ade80}.season-peak-unit{font-size:12px;color:#64748b;margin-top:4px}.compact-card{padding:16px 20px;max-width:560px}.compact-table{font-size:13px}.compact-table th,.compact-table td{padding:8px 10px}.site-header{background:#1a344d;padding:8px 24px;font-family:Heebo,sans-serif}.site-nav{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.site-logo{display:flex;flex-direction:column;align-items:flex-start;text-decoration:none;color:#fffc;font-size:14px}.site-logo img{height:56px;width:auto}.site-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:4px}.site-nav a{color:#fff;text-decoration:none;padding:8px 12px;font-weight:500}.site-nav a:hover,.site-nav a.active{color:#90d9f9}.site-nav .lang-switch{display:flex;align-items:center;gap:4px;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:2px 4px}.site-nav .lang-btn{border:none;background:transparent;color:#ffffffbf;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}.site-nav .lang-btn-active{background:#90d9f9;color:#1a344d}.options-card h3{color:#f1f5f9}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;align-items:end}.options-grid label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#94a3b8}.options-grid select{padding:10px 12px;border-radius:8px;border:1px solid #334155;background:#0f172a;color:#f1f5f9;font-family:inherit}.tier-badge{display:flex;align-items:center}.badge{padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600}.badge.free{background:#94a3b833;color:#94a3b8}.badge.premium{background:#90d9f926;color:#90d9f9}.options-note,.free-limit-note,.premium-note{font-size:13px;color:#94a3b8;margin-top:12px}.premium-gate{margin:24px 0 48px;padding:32px 24px;border:2px dashed #334155;border-radius:16px;background:linear-gradient(180deg,rgba(144,217,249,.08) 0%,transparent 100%);text-align:center}.premium-gate-inner h3{margin:0 0 12px;color:#90d9f9}.premium-gate-inner p{color:#94a3b8;max-width:520px;margin:0 auto 20px}.btn-premium{background:#90d9f9;color:#1a344d;font-weight:700;padding:14px 28px;font-size:16px}.btn-premium:hover:not(:disabled){background:#e8d93e}.free-preview{opacity:.85}
