:root{--bg-primary:#f5f5f5;--bg-secondary:#fff;--bg-card:#fff;--text-primary:#333;--text-secondary:#666;--text-tertiary:#999;--border-color:#e0e0e0;--shadow:#0000001a;--chart-grid:#e0e0e0;--header-gradient-start:#00bcd4;--header-gradient-mid:#0097a7;--header-gradient-end:#00838f}body.dark-mode{--bg-primary:#121212;--bg-secondary:#1e1e1e;--bg-card:#2a2a2a;--text-primary:#e0e0e0;--text-secondary:#b0b0b0;--text-tertiary:grey;--border-color:#404040;--shadow:#0000004d;--chart-grid:#404040;--header-gradient-start:#00838f;--header-gradient-mid:#006064;--header-gradient-end:#004d40}*{box-sizing:border-box;margin:0;padding:0}body{background:#f5f5f5;background:var(--bg-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{background:#fff;background:var(--bg-secondary);box-shadow:0 0 20px #0000001a;margin:0 auto;max-width:480px;min-height:100vh}.header{background:linear-gradient(135deg,#00bcd4,#0097a7 50%,#00838f);box-shadow:0 2px 8px #00bcd44d;color:#fff;justify-content:space-between;padding:15px 20px;position:relative}.header,.header-left{align-items:center;display:flex}.header-left{flex:1 1;gap:12px}.header-logo{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:45px;object-fit:contain;width:45px}.header-title{display:flex;flex-direction:column;gap:2px}.header-title h1{font-size:20px;font-weight:600;letter-spacing:.5px;margin:0}.header-title .subtitle{font-size:11px;font-weight:400;opacity:.9}.header-icons{display:flex;gap:10px}.header-button{align-items:center;background:#fff3;border:2px solid #ffffff80;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .3s}.header-button:hover{background:#ffffff4d;transform:scale(1.05)}.header-button:active{transform:scale(.95)}.tabs{background:#fff;background:var(--bg-secondary);border-bottom:2px solid #e0e0e0;display:flex}.tab{background:none;border:none;color:#666;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:14px;padding:15px;text-align:center}.tab.active{border-bottom:3px solid #00bcd4;color:#00bcd4}.content{padding:20px}.button-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:30px}.info-button{background:#fff;background:var(--bg-secondary);border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;padding:12px;text-align:center;transition:transform .2s,box-shadow .2s}.info-button:active{transform:scale(.98)}.info-button h3{color:#333;color:var(--text-primary);font-size:13px;margin:8px 0}.info-button .value{color:#00bcd4;font-size:20px;font-weight:700}.info-button .unit{color:#999;color:var(--text-tertiary);font-size:11px;margin-top:3px}.gauges-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin:30px 0}.gauge{background:#fff;background:var(--bg-secondary);border:2px solid #e0e0e0;border-radius:12px;padding:15px;text-align:center}.gauge h4{color:#666;color:var(--text-secondary);font-size:14px;margin-bottom:10px}.gauge-value{color:#333;color:var(--text-primary);font-size:28px;font-weight:700}.gauge-unit{color:#999;color:var(--text-tertiary);font-size:12px;margin-top:5px}.loading{color:#666;color:var(--text-secondary);padding:40px;text-align:center}.error{background:#ffebee;border-radius:8px;color:#c62828;margin:20px;padding:15px}.status-badge{border-radius:20px;display:inline-block;font-size:10px;font-weight:700;margin-top:5px;padding:4px 10px}.status-charging{background:#4caf50;color:#fff}.status-discharging{background:#f44336;color:#fff}.status-idle{background:#9e9e9e;color:#fff}.status-buying{background:#ff9800;color:#fff}.status-selling{background:#4caf50;color:#fff}.back-button{align-items:center;background:#00bcd4;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 24px;transition:background .2s}.back-button:hover{background:#0097a7}.detail-card{background:#fff;background:var(--bg-secondary);border:2px solid #e0e0e0;border-radius:12px;margin-bottom:20px;padding:20px}.detail-card h3{align-items:center;color:#333;color:var(--text-primary);display:flex;font-size:16px;gap:8px;margin-bottom:15px}.detail-row{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#666;color:var(--text-secondary);font-size:14px}.detail-value{color:#333;color:var(--text-primary);font-size:14px;font-weight:600}.battery-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.battery-card{background:#fff;background:var(--bg-secondary);border:2px solid #e0e0e0;border-radius:12px;padding:15px;text-align:center}.battery-card h4{color:#333;color:var(--text-primary);font-size:14px;margin-bottom:10px}.battery-soc{font-size:32px;font-weight:700;margin:10px 0}.battery-info{color:#666;color:var(--text-secondary);font-size:12px;margin:5px 0}.chart-container{padding:20px}.chart-container h3{color:#333;color:var(--text-primary);font-size:16px;margin-bottom:15px}.modal-overlay{animation:fadeIn .2s;background:#000000b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s;border-radius:16px;max-height:80vh;max-width:400px;padding:20px;position:relative;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.modal-header{margin-bottom:20px;padding-bottom:15px}.modal-header h2{align-items:center;color:#333;color:var(--text-primary);display:flex;font-size:20px;gap:10px;margin:0}.modal-close{background:#f5f5f5;background:var(--bg-primary);border-radius:50%;height:32px;transition:background .2s;width:32px}.modal-close:hover{background:#e0e0e0}.battery-info-content{background:#f5f5f5;background:var(--bg-primary);border-radius:8px;color:#333;color:var(--text-primary);font-family:Courier New,monospace;font-size:13px;line-height:1.6;padding:15px;white-space:pre-wrap}.battery-summary-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.summary-item{display:flex;flex-direction:column;gap:4px}.summary-label{color:#666;color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase}.summary-value{color:#333;color:var(--text-primary);font-size:18px;font-weight:700}.chart-section{margin-top:30px}.chart-section h3{color:#333;color:var(--text-primary);margin-bottom:20px}.chart-container{background:#fff;background:var(--bg-secondary);border:2px solid #e0e0e0;border-radius:12px;margin-bottom:30px;padding:15px}.chart-title{color:#666;color:var(--text-secondary);font-size:14px;font-weight:600;margin-bottom:10px;text-transform:uppercase}.battery-button-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:30px}.battery-button{background:#fff;background:var(--bg-secondary);border:3px solid #e0e0e0;border-radius:12px;cursor:pointer;overflow:hidden;padding:0;transition:transform .2s,box-shadow .2s}.battery-button:active{transform:scale(.98)}.battery-button:hover{box-shadow:0 4px 12px #00000026}.battery-button-header{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:700;justify-content:space-between;padding:10px}.battery-button-soc{font-size:16px}.battery-button-content{padding:12px}.battery-button-row{display:flex;font-size:13px;justify-content:space-between;margin-bottom:6px}.battery-button-row:last-child{margin-bottom:0}.battery-button-row span:first-child{color:#666;color:var(--text-secondary)}.battery-button-row span:last-child{color:#333;color:var(--text-primary);font-weight:700}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;background:var(--bg-secondary);border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:440px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#333;color:var(--text-primary);margin:0}.modal-close{align-items:center;background:none;border:none;color:#666;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px}.modal-close:hover{color:#333;color:var(--text-primary)}.modal-body{padding:20px}.modal-row{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.modal-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.modal-label{color:#666;color:var(--text-secondary);font-size:13px;font-weight:600}.modal-value{color:#333;color:var(--text-primary);font-size:14px;font-weight:700}.modal-section{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.modal-section h4{color:#666;color:var(--text-secondary);font-size:14px;margin-bottom:12px;text-transform:uppercase}.solar-summary-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.string-detail-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr}body.dark-mode .header{background:linear-gradient(135deg,#00bcd4,#0097a7 50%,#00838f);background:linear-gradient(135deg,var(--header-gradient-start) 0,var(--header-gradient-mid) 50%,var(--header-gradient-end) 100%);box-shadow:0 2px 8px #00838f80}body.dark-mode .app{box-shadow:0 0 20px #00000080}body.dark-mode .app,body.dark-mode .content{background:#fff;background:var(--bg-secondary)}body.dark-mode .chart-container,body.dark-mode .detail-card,body.dark-mode .info-button{background:#fff;background:var(--bg-card);border-color:#e0e0e0;border-color:var(--border-color);color:#333;color:var(--text-primary)}body.dark-mode .value{color:#333;color:var(--text-primary)}body.dark-mode .label,body.dark-mode .unit{color:#666;color:var(--text-secondary)}body.dark-mode .nav-button{background:#fff;background:var(--bg-card);border-color:#e0e0e0;border-color:var(--border-color)}body.dark-mode .nav-button:hover{background:#383838}body.dark-mode .back-button,body.dark-mode .nav-button-label{color:#333;color:var(--text-primary)}body.dark-mode .back-button{background:#fff;background:var(--bg-card);border-color:#e0e0e0;border-color:var(--border-color)}body.dark-mode .back-button:hover{background:#383838}body.dark-mode .tab{border-bottom-color:#e0e0e0;border-bottom-color:var(--border-color);color:#666;color:var(--text-secondary)}body.dark-mode .tab.active{border-bottom-color:#00bcd4;color:#00bcd4}body.dark-mode h2,body.dark-mode h3{color:#333;color:var(--text-primary)}body.dark-mode .battery-label,body.dark-mode .string-label,body.dark-mode .summary-label{color:#666;color:var(--text-secondary)}body.dark-mode .battery-value,body.dark-mode .string-value,body.dark-mode .summary-value{color:#333;color:var(--text-primary)}body.dark-mode .recharts-cartesian-grid-horizontal line,body.dark-mode .recharts-cartesian-grid-vertical line{stroke:#e0e0e0;stroke:var(--chart-grid)}body.dark-mode .recharts-text{fill:#666;fill:var(--text-secondary)}body.dark-mode .recharts-legend-item-text{color:#333!important;color:var(--text-primary)!important}body.dark-mode .error,body.dark-mode .loading{color:#333;color:var(--text-primary)}body.dark-mode .modal-overlay{background:#000c}body.dark-mode .modal-content{background:#fff;background:var(--bg-card);color:#333;color:var(--text-primary)}body.dark-mode .modal-header{border-bottom-color:#e0e0e0;border-bottom-color:var(--border-color)}body.dark-mode .close-button{color:#666;color:var(--text-secondary)}body.dark-mode .close-button:hover{color:#333;color:var(--text-primary)}body.dark-mode .gauge-label{color:#666;color:var(--text-secondary)}body.dark-mode .gauge-value{color:#333;color:var(--text-primary)}body.dark-mode .header-button:hover{background:#ffffff26}body.dark-mode .weather-info{color:#666;color:var(--text-secondary)}body.dark-mode .string-metrics{border-color:#e0e0e0;border-color:var(--border-color)}body.dark-mode .battery-comparison,body.dark-mode .string-metrics{background:#fff;background:var(--bg-card)}
/*# sourceMappingURL=main.f3ba3fee.css.map*/