.fin-container{padding:16px;max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.fin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:400px;color:var(--text-muted);font-size:14px}.fin-loading-spinner{width:36px;height:36px;border:3px solid var(--divider);border-top-color:var(--accent-blue);border-radius:50%;animation:finSpin .8s linear infinite}@keyframes finSpin{to{transform:rotate(360deg)}}.fin-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:12px;color:var(--text-muted)}.fin-empty-icon{font-size:48px;opacity:.5}.fin-period-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.fin-mode-selector{display:flex;gap:4px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius, 12px);padding:4px}.fin-period-btn{padding:8px 18px;border:none;border-radius:calc(var(--border-radius, 12px) - 2px);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.fin-period-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.fin-period-btn.active{background:var(--accent-blue);color:#fff;box-shadow:0 2px 8px #3b82f64d}.fin-nav-controls{display:flex;align-items:center;gap:8px}.fin-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--card-border);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-size:18px;font-weight:600;cursor:pointer;transition:all .2s ease;line-height:1}.fin-nav-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--accent-blue);color:var(--accent-blue)}.fin-nav-btn:disabled{opacity:.3;cursor:default}.fin-nav-label{font-size:14px;font-weight:600;color:var(--text-primary);min-width:140px;text-align:center;text-transform:capitalize}.fin-nav-today{padding:6px 12px;border:1px solid var(--accent-blue);border-radius:8px;background:transparent;color:var(--accent-blue);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.fin-nav-today:hover{background:var(--accent-blue);color:#fff}.fin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.fin-stat-card{display:flex;gap:14px;align-items:flex-start;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius, 12px);padding:16px;transition:transform .2s ease,box-shadow .2s ease}.fin-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--card-shadow)}.fin-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.fin-stat-content{flex:1;min-width:0}.fin-stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.fin-stat-value{font-size:20px;font-weight:800;line-height:1.2;white-space:nowrap}.fin-stat-subtitle{font-size:11px;color:var(--text-muted);margin-top:4px}.fin-stat-trend{font-size:11px;font-weight:700;margin-top:4px}.fin-stat-trend.positive{color:var(--accent-green)}.fin-stat-trend.negative{color:var(--accent-red)}.fin-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.fin-chart-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius, 12px);padding:16px;overflow:hidden}.fin-chart-card.fin-chart-wide{grid-column:1 / -1}.fin-chart-title{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 12px;padding:0}.fin-tooltip{background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;padding:10px 14px;box-shadow:0 4px 20px #00000040;font-size:12px}.fin-tooltip-label{font-weight:700;color:var(--text-primary);margin-bottom:6px;font-size:13px}.fin-tooltip-row{display:flex;align-items:center;gap:8px;padding:2px 0}.fin-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.fin-tooltip-name{flex:1;color:var(--text-secondary)}.fin-tooltip-value{font-weight:700;color:var(--text-primary)}.fin-donut-container{position:relative}.fin-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-70%);text-align:center;pointer-events:none}.fin-donut-total{font-size:16px;font-weight:800;color:var(--text-primary)}.fin-donut-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.fin-legend{padding:0 8px}.fin-legend-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--divider)}.fin-legend-row:last-child{border-bottom:none}.fin-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.fin-legend-name{flex:1;font-size:12px;color:var(--text-secondary)}.fin-legend-value{font-size:13px;font-weight:700;color:var(--text-primary)}.fin-legend-pct{font-size:11px;color:var(--text-muted);min-width:32px;text-align:right}.fin-battery-stats{padding:0 4px 12px}.fin-battery-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--divider)}.fin-battery-row:last-child{border-bottom:none}.fin-battery-label{font-size:12px;color:var(--text-secondary)}.fin-battery-value{font-size:13px;font-weight:700;color:var(--text-primary)}.fin-table-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius, 12px);padding:16px;overflow:hidden}.fin-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.fin-table{width:100%;border-collapse:collapse;font-size:12px}.fin-table th{padding:10px 12px;text-align:right;font-weight:700;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--divider);white-space:nowrap}.fin-table th:first-child{text-align:left}.fin-table td{padding:10px 12px;text-align:right;color:var(--text-primary);border-bottom:1px solid var(--divider);white-space:nowrap}.fin-table td:first-child{text-align:left}.fin-table-month{font-weight:600;color:var(--text-primary)!important}.fin-table tbody tr:hover{background:var(--hover-bg)}.fin-table-highlight{background:#10b9810d!important}.fin-table-total td{border-top:2px solid var(--divider);border-bottom:none;padding-top:12px}.fin-table tfoot{font-size:13px}.fin-rates-info{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;padding:12px;font-size:12px;color:var(--text-muted);background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius, 12px)}@media (max-width: 900px){.fin-charts-grid{grid-template-columns:1fr}.fin-chart-card.fin-chart-wide{grid-column:1}}@media (max-width: 640px){.fin-container{padding:10px;gap:14px}.fin-stats-grid{grid-template-columns:1fr 1fr;gap:8px}.fin-stat-card{padding:12px;gap:10px}.fin-stat-icon{width:36px;height:36px;font-size:16px}.fin-stat-value{font-size:15px}.fin-stat-label{font-size:10px}.fin-period-btn{padding:6px 12px;font-size:12px}.fin-period-bar{gap:10px}.fin-nav-label{font-size:12px;min-width:100px}.fin-rates-info{gap:12px;font-size:11px}}@media (max-width: 440px){.fin-stats-grid{grid-template-columns:1fr}}.energy-sankey{display:flex;flex-direction:column;height:100%;min-height:0;padding:4px 14px 14px;gap:8px}.energy-sankey__head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.energy-sankey__daynav{display:inline-flex;align-items:center;gap:2px;background:var(--hover-bg);border:1px solid var(--card-border);border-radius:var(--radius-pill, 999px);padding:3px}.energy-sankey__daynav-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-secondary);border-radius:50%;cursor:pointer;transition:background .15s ease,color .15s ease}.energy-sankey__daynav-btn:hover:not(:disabled){background:var(--card-bg);color:var(--text-primary)}.energy-sankey__daynav-btn:disabled{opacity:.3;cursor:not-allowed}.energy-sankey__daynav-label{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;padding:2px 10px;min-width:120px;border-radius:14px;font-family:inherit;transition:background .15s ease}.energy-sankey__daynav-label:hover{background:var(--card-bg)}.energy-sankey__daynav-label.is-today{cursor:default}.energy-sankey__daynav-label-main{font-size:12px;font-weight:700;color:var(--text-primary);line-height:1.2}.energy-sankey__daynav-label-sub{font-size:10px;color:var(--text-muted);line-height:1.2}.energy-sankey__tabs{display:inline-flex;background:var(--hover-bg);border:1px solid var(--card-border);border-radius:var(--radius-pill, 999px);padding:3px;gap:2px}.energy-sankey__tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;font-family:inherit;font-size:12px;font-weight:600;color:var(--text-secondary);padding:5px 12px;border-radius:var(--radius-pill, 999px);cursor:pointer;text-transform:capitalize;transition:background .18s var(--ease-out, ease),color .18s ease}.energy-sankey__tab:hover{color:var(--text-primary)}.energy-sankey__tab.is-active{background:var(--card-bg);color:var(--accent-blue);box-shadow:var(--shadow-xs, 0 1px 2px rgba(0,0,0,.06))}.energy-sankey__loading{font-size:12px;color:var(--text-muted);letter-spacing:.1em}.energy-sankey__chart{flex:1;min-height:240px;position:relative;overflow:hidden}.energy-sankey__chart>svg{display:block;max-width:100%}.sankey-node-bar{transition:fill-opacity .18s ease,transform .18s ease}.sankey-node-chip{transition:opacity .18s ease}.sankey-node-chip-bg{fill:var(--card-bg);fill-opacity:.95;stroke-width:1px;stroke-opacity:.45;filter:drop-shadow(0 2px 4px rgba(15,23,42,.08))}.sankey-node-chip-label{font-size:12.5px;font-weight:700;fill:var(--text-primary);letter-spacing:.01em}.sankey-node-chip-value{font-size:11.5px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.01em}.sankey-link-path{transition:stroke-width .18s ease}.energy-sankey__empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px;font-style:italic}.energy-sankey__legend{display:flex;flex-wrap:wrap;gap:12px;padding:4px 2px;font-size:11px;color:var(--text-secondary)}.energy-sankey__legend-item{display:inline-flex;align-items:center;gap:5px;font-weight:500}.energy-sankey__legend-dot{width:9px;height:9px;border-radius:2px;display:inline-block}.energy-sankey__footer{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;padding-top:6px;border-top:1px solid var(--divider)}.energy-sankey__stat{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center;padding:4px 2px;border-radius:var(--radius-sm, 8px);background:var(--hover-bg)}.energy-sankey__stat-label{font-size:10px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.energy-sankey__stat-value{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}@media (max-width: 768px){.energy-sankey__footer{grid-template-columns:repeat(3,minmax(0,1fr))}.energy-sankey{padding:4px 10px 10px}}@media (max-width: 480px){.energy-sankey__footer{grid-template-columns:repeat(2,minmax(0,1fr))}.energy-sankey__tab{padding:4px 9px;font-size:11px}.energy-sankey__legend{gap:8px;font-size:10px}.energy-sankey__daynav-label{min-width:96px}.energy-sankey__daynav-label-main{font-size:11px}.energy-sankey__daynav-label-sub{font-size:9px}}.energy-sankey__detail{position:absolute;width:240px;max-width:calc(100% - 20px);background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:10px 12px 11px;box-shadow:0 8px 24px #0f172a1f,0 1px 2px #0f172a0f;font-size:12px;color:var(--text-primary);pointer-events:none;z-index:5;animation:sankeyDetailIn .12s ease-out}@keyframes sankeyDetailIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.energy-sankey__detail-header{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;padding-right:18px}.energy-sankey__detail-tag{width:8px;height:8px;border-radius:2px;display:inline-block;flex:none}.energy-sankey__detail-from,.energy-sankey__detail-to{color:var(--text-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.energy-sankey__detail-arrow{color:var(--text-muted);font-weight:500}.energy-sankey__detail-value{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1.1;margin:2px 0 4px}.energy-sankey__detail-meta{font-size:11px;color:var(--text-muted);font-weight:500}.energy-sankey__detail-breakdown{margin-top:8px;padding-top:8px;border-top:1px dashed var(--divider);display:flex;flex-direction:column;gap:8px}.energy-sankey__detail-section-title{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:3px}.energy-sankey__detail-row{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-primary);padding:1px 0}.energy-sankey__detail-row-dot{width:7px;height:7px;border-radius:50%;flex:none}.energy-sankey__detail-row-label{flex:1;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.energy-sankey__detail-row-value{font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}@media (max-width: 480px){.energy-sankey__detail{width:calc(100% - 24px);left:12px!important;top:12px!important}.energy-sankey__detail-value{font-size:16px}}:root{--panel-off: #2a3347;--panel-tile-bg: var(--card-bg);--panel-tile-border: var(--card-border)}:root[data-theme=dark]{--panel-off: #1e2535}.panel-array-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius);box-shadow:var(--card-shadow);padding:20px;margin-top:16px}.panel-array-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px}.panel-array-title{display:flex;align-items:center;gap:8px;font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0}.panel-array-title svg{opacity:.6}.panel-array-stats{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-secondary)}.panel-stat strong{color:var(--text-primary)}.panel-stat.muted{color:var(--text-muted);font-size:.8rem}.panel-stat-divider{width:1px;height:14px;background:var(--card-border)}.panel-stat-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:3px}.panel-stat-dot.online{background:var(--accent-green);box-shadow:0 0 4px var(--accent-green)}.panel-strings-container{display:flex;gap:20px}@media (max-width: 768px){.panel-strings-container{flex-direction:column}}.layout-toggle{display:flex;gap:2px;background:var(--hover-bg);border-radius:8px;padding:2px;border:1px solid var(--card-border)}.layout-toggle-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.layout-toggle-btn:hover{color:var(--text-primary);background:#ffffff0f}.layout-toggle-btn.active{background:var(--accent-blue);color:#fff;box-shadow:0 1px 4px #2563eb4d}.layout-toggle-btn svg{flex-shrink:0}.roof-layout{display:flex;flex-direction:column;gap:14px}.roof-string-summary{display:flex;gap:10px;flex-wrap:wrap}.roof-string-pill{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:8px;background:var(--hover-bg);border:1px solid var(--border-color, rgba(255, 255, 255, .06));font-size:.82rem}.roof-string-pill.string-a{border-left:3px solid #f97316}.roof-string-pill.string-b{border-left:3px solid #3b82f6}.roof-string-pill.string-c{border-left:3px solid #06b6d4}.roof-pill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.string-a .roof-pill-dot{background:#f97316}.string-b .roof-pill-dot{background:#3b82f6}.string-c .roof-pill-dot{background:#06b6d4}.roof-pill-label{font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;font-size:.75rem}.roof-pill-power{font-weight:700;font-family:var(--font-mono);color:var(--accent-green)}.roof-pill-voltage{font-weight:600;font-family:var(--font-mono);font-size:.8rem}.roof-layout-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.roof-layout-grid{display:grid;grid-template-columns:repeat(11,1fr);grid-template-rows:repeat(14,1fr);gap:2px;min-width:600px;max-width:900px;margin:0 auto;aspect-ratio:11 / 7}.roof-cell{position:relative;min-height:0;min-width:0}.roof-layout-grid .panel-tile{aspect-ratio:unset;width:100%;height:100%;min-width:0;min-height:0}.roof-cell.string-a .panel-tile{border-color:#f9731659}.roof-cell.string-b .panel-tile{border-color:#3b82f659}.roof-cell.string-c .panel-tile{border-color:#06b6d459}.roof-cell.string-a .panel-tile:hover{border-color:#f97316;box-shadow:0 4px 18px #f9731633}.roof-cell.string-b .panel-tile:hover{border-color:#3b82f6;box-shadow:0 4px 18px #3b82f633}.roof-cell.string-c .panel-tile:hover{border-color:#06b6d4;box-shadow:0 4px 18px #06b6d433}.roof-legend{display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid var(--divider);font-size:.75rem;color:var(--text-muted);flex-wrap:wrap}.roof-legend-item{display:flex;align-items:center;gap:5px}.roof-legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.roof-legend-dot.string-a{background:#f97316}.roof-legend-dot.string-b{background:#3b82f6}.roof-legend-dot.string-c{background:#06b6d4}.roof-legend-sep{width:1px;height:14px;background:var(--card-border);margin:0 4px}.roof-legend-range{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.panel-string{flex:1;min-width:0}.panel-string-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin-bottom:10px;border-radius:8px;background:var(--hover-bg);border:1px solid var(--border-color, rgba(255,255,255,.06))}.panel-string-label{font-size:.85rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.panel-string-stats{display:flex;align-items:center;gap:6px}.panel-string-stat{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.panel-string-stat-label{font-size:.65rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;line-height:1}.panel-string-stat-value{font-size:.9rem;font-weight:700;font-family:var(--font-mono);line-height:1.2}.panel-string-stat-value.power{color:var(--accent-green)}.panel-string-stat-value.vin-ok{color:#22c55e}.panel-string-stat-value.vin-danger{color:#ef4444}.panel-string-stat-value.vin-danger-flash{color:#ef4444;animation:vin-flash .5s ease-in-out infinite alternate}@keyframes vin-flash{0%{opacity:1}to{opacity:.2}}.panel-string-stat-divider{width:1px;height:24px;background:var(--border-color, rgba(255,255,255,.1));margin:0 4px}.panel-string-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:6px}@media (min-width: 900px){.panel-string-grid{grid-template-columns:repeat(7,1fr)}}.panel-string-empty{grid-column:1 / -1;text-align:center;color:var(--text-muted);font-size:.85rem;padding:20px}.panel-tile{position:relative;aspect-ratio:1;border-radius:10px;cursor:pointer;overflow:hidden;border:2px solid var(--card-border);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;background:var(--panel-tile-bg);min-width:90px}.panel-tile:hover{transform:scale(1.06);z-index:2;border-color:var(--accent-blue);box-shadow:0 4px 18px #0003}.panel-tile.selected{border-color:var(--accent-blue);box-shadow:0 0 0 2px var(--accent-blue),0 4px 16px #2563eb40}.panel-tile.offline{opacity:.55}.panel-tile-energy{position:absolute;bottom:0;left:0;right:0;height:var(--energy-pct, 0%);opacity:.35;transition:height 1s ease,opacity .5s ease;border-radius:0 0 8px 8px}.panel-tile:hover .panel-tile-energy{opacity:.5}.panel-tile-status{position:absolute;top:5px;right:5px;width:6px;height:6px;border-radius:50%;z-index:2}.panel-tile-status.on{background:#22c55e;box-shadow:0 0 4px #22c55e}.panel-tile-status.off{background:#64748b;opacity:.5}@keyframes led-blink{0%,to{opacity:1}50%{opacity:.5}}.panel-tile-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:6px 4px;gap:1px}.panel-tile-label{font-size:.72rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.panel-tile-power{font-size:.92rem;font-weight:800;color:var(--text-primary);font-family:var(--font-mono);text-shadow:0 1px 3px rgba(0,0,0,.4);line-height:1.2}.panel-tile-details{display:flex;flex-direction:column;align-items:center;gap:0;margin-top:1px}.panel-tile-details span{font-size:.68rem;font-weight:600;font-family:var(--font-mono);color:#ffffffbf;line-height:1.25;text-shadow:0 1px 2px rgba(0,0,0,.5)}.panel-tile.offline .panel-tile-details span{color:var(--text-muted)}.panel-tile.online .panel-tile-label{color:var(--text-primary)}.panel-tile.online .panel-tile-power{color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}@media (prefers-reduced-motion: reduce){.panel-tile-status.on{animation:none}.panel-tile-energy{transition:none}}@media (max-width: 600px){.panel-array-section{padding:12px 10px}.panel-array-header{gap:6px;margin-bottom:10px}.panel-array-title{font-size:.9rem;gap:6px}.panel-array-stats{font-size:.72rem;gap:6px}.panel-string-header{padding:5px 8px;margin-bottom:6px}.panel-string-label{font-size:.72rem}.panel-string-stat-label{font-size:.55rem}.panel-string-stat-value{font-size:.72rem}.panel-string-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:4px}.panel-tile{min-width:0;border-radius:6px;border-width:1.5px}.panel-string-grid .panel-tile{aspect-ratio:auto;overflow:visible}.roof-layout-grid .panel-tile{aspect-ratio:unset;overflow:hidden}.roof-layout-grid .panel-tile-details{display:none}.panel-tile-inner{padding:4px 2px;gap:1px}.panel-tile-label{font-size:.52rem;letter-spacing:.2px}.panel-tile-power{font-size:.6rem;font-weight:700}.panel-tile-details span{font-size:.48rem;line-height:1.15}.panel-tile-status{top:2px;right:2px;width:4px;height:4px}.roof-layout-grid{min-width:420px;gap:1px}.roof-layout-grid .panel-tile-label{font-size:.5rem}.roof-layout-grid .panel-tile-power{font-size:.58rem}.roof-string-pill{padding:4px 8px;font-size:.7rem;gap:5px}.roof-pill-label{font-size:.62rem}.roof-pill-power{font-size:.72rem}.roof-pill-voltage{font-size:.65rem}.roof-legend{font-size:.65rem;gap:6px;padding-top:8px}.panel-strings-container{gap:12px}}@media (max-width: 380px){.panel-string-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:3px}.panel-tile-label{font-size:.46rem}.panel-tile-power{font-size:.52rem}.panel-tile-details span{font-size:.42rem}.roof-layout-grid{min-width:360px}.roof-layout-grid .panel-tile-label{font-size:.44rem}.roof-layout-grid .panel-tile-power{font-size:.5rem}}.panel-legend{display:flex;align-items:center;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--divider);font-size:.75rem;color:var(--text-muted)}.panel-legend-gradient{flex:0 0 100px;height:8px;border-radius:4px;background:linear-gradient(90deg,#3b82f6,#22c55e,#eab308,#ef4444)}.panel-legend-off{display:flex;align-items:center;gap:4px;margin-left:12px}.panel-legend-off-swatch{display:inline-block;width:12px;height:8px;border-radius:3px;background:var(--panel-off);border:1px solid var(--card-border)}.panel-array-unconfigured{text-align:center;padding:24px;color:var(--text-secondary)}.panel-array-unconfigured code{display:inline-block;margin-top:12px;padding:10px 16px;background:var(--hover-bg);border-radius:6px;font-size:.82rem;font-family:var(--font-mono);line-height:1.6;color:var(--text-muted)}.panel-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--overlay-bg);animation:panelFadeIn .2s ease}@keyframes panelFadeIn{0%{opacity:0}to{opacity:1}}.panel-detail-card{position:relative;background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;box-shadow:0 24px 48px #0003;padding:24px;min-width:320px;max-width:480px;width:90%;max-height:90vh;overflow-y:auto;overflow-x:hidden;animation:panelSlideUp .25s ease}@keyframes panelSlideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.panel-detail-close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:4px}.panel-detail-close:hover{background:var(--hover-bg);color:var(--text-primary)}.panel-detail-title{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:600;margin:0 0 4px}.panel-detail-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.panel-detail-serial{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono);margin-bottom:16px}.panel-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.panel-detail-metric{display:flex;flex-direction:column;gap:2px}.panel-detail-metric-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.panel-detail-metric-value{font-size:1.05rem;font-weight:600;font-family:var(--font-mono);color:var(--text-primary)}.panel-detail-metric-value.power{color:var(--accent-green);font-size:1.2rem}.panel-detail-module{font-size:.78rem;color:var(--text-muted);margin-bottom:12px}.panel-detail-spark-container{margin-top:4px}.panel-detail-spark-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);display:block;margin-bottom:4px}.panel-detail-sparkline{width:100%;height:48px;display:block}.panel-detail-loading{text-align:center;font-size:.82rem;color:var(--text-muted);padding:8px}.panel-period-tabs{display:flex;gap:4px;margin:0 0 14px;padding:4px;background:var(--hover-bg);border-radius:10px;align-items:center;flex-wrap:wrap}.panel-period-tab{flex:1;min-width:60px;padding:7px 12px;background:transparent;border:none;border-radius:7px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease}.panel-period-tab:hover{color:var(--text-primary)}.panel-period-tab.active{background:var(--card-bg);color:var(--accent-blue);box-shadow:0 1px 4px #00000026}.panel-period-loading{font-size:.85rem;color:var(--text-muted);padding:0 8px}.roof-pill-energy{font-family:var(--font-mono);font-size:.78rem;font-weight:600;color:var(--accent-blue);margin-left:6px}.panel-tile.underperformer{border-color:#ef44448c;box-shadow:inset 0 0 0 1px #ef444440}.panel-tile-warn{position:absolute;top:4px;right:4px;font-size:.85rem;color:#ef4444;text-shadow:0 1px 2px rgba(0,0,0,.4);pointer-events:none}.panel-leaderboard{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px;padding-top:16px;border-top:1px solid var(--card-border)}@media (max-width: 768px){.panel-leaderboard{grid-template-columns:1fr}}.panel-leaderboard-col{display:flex;flex-direction:column;gap:4px}.panel-leaderboard-header{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding:4px 6px 8px}.panel-leaderboard-header.top{color:var(--accent-green, #22c55e)}.panel-leaderboard-header.bottom{color:#f97316}.panel-leaderboard-row{display:grid;grid-template-columns:24px 32px 1fr 70px 50px;gap:8px;align-items:center;padding:6px 8px;border-radius:7px;background:var(--hover-bg);border-left:3px solid transparent;cursor:pointer;transition:background .15s ease,transform .15s ease}.panel-leaderboard-row:hover{background:var(--card-bg);transform:translate(2px)}.panel-leaderboard-row.string-a{border-left-color:#f97316}.panel-leaderboard-row.string-b{border-left-color:#3b82f6}.panel-leaderboard-row.string-c{border-left-color:#06b6d4}.panel-leaderboard-row.string-d{border-left-color:#a855f7}.panel-leaderboard-row.underperformer{background:#ef444414}.panel-leaderboard-medal{font-size:.95rem;text-align:center;font-family:var(--font-mono);color:var(--text-muted)}.panel-leaderboard-label{font-weight:700;font-size:.85rem;color:var(--text-primary);font-family:var(--font-mono)}.panel-leaderboard-bar{height:6px;background:var(--card-border);border-radius:4px;overflow:hidden}.panel-leaderboard-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#eab308);border-radius:4px;transition:width .4s ease}.panel-leaderboard-bar-fill.bottom{background:linear-gradient(90deg,#f97316,#ef4444)}.panel-leaderboard-value{font-family:var(--font-mono);font-size:.82rem;font-weight:600;color:var(--text-primary);text-align:right}.panel-leaderboard-pct{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);text-align:right}.panel-leaderboard-pct.warn{color:#ef4444;font-weight:700}.panel-detail-period-tabs{display:flex;gap:2px;margin:14px 0 12px;padding:3px;background:var(--hover-bg);border-radius:8px}.panel-detail-period-tab{flex:1;padding:5px 10px;background:transparent;border:none;border-radius:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);cursor:pointer}.panel-detail-period-tab.active{background:var(--card-bg);color:var(--accent-blue)}.panel-detail-daily{margin-top:14px;padding-top:12px;border-top:1px solid var(--card-border)}.panel-detail-daily-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);margin-bottom:8px}.panel-detail-daily-bars{display:flex;gap:4px;align-items:flex-end;height:80px;padding-bottom:16px;position:relative;overflow-x:auto;overflow-y:hidden;max-width:100%}.panel-detail-daily-bar{flex:1 1 0;height:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;position:relative;min-width:10px;max-width:40px}.panel-detail-daily-bar-fill{width:100%;background:linear-gradient(180deg,var(--accent-blue),rgba(37,99,235,.3));border-radius:3px 3px 0 0;min-height:2px;transition:height .4s ease}.panel-detail-daily-bar:hover .panel-detail-daily-bar-fill{background:linear-gradient(180deg,#22c55e,#22c55e66)}.panel-detail-daily-bar-label{position:absolute;bottom:-14px;font-size:.6rem;font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap}:root{color-scheme:light;--bg: #eaecf0;--bg-elevated: #ffffff;--card-bg: #ffffff;--card-border: #d4d8e0;--card-border-strong: #bbc1cc;--text-primary: #0e131c;--text-secondary: #3f4858;--text-muted: #7a8495;--accent-blue: #006fff;--accent-green: #16a34a;--accent-orange: #ea580c;--accent-purple: #7c3aed;--accent-red: #dc2626;--accent-amber: #f59e0b;--accent-cyan: #06b6d4;--accent-indigo: #6366f1;--accent-pink: #ec4899;--brand-from: #f59e0b;--brand-to: #16a34a;--brand-gradient: linear-gradient(135deg, var(--brand-from) 0%, var(--brand-to) 100%);--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 999px;--border-radius: var(--radius-md);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .07), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 8px -2px rgba(15, 23, 42, .08), 0 2px 4px -2px rgba(15, 23, 42, .05);--shadow-lg: 0 10px 20px -4px rgba(15, 23, 42, .1), 0 4px 8px -4px rgba(15, 23, 42, .06);--shadow-xl: 0 20px 30px -8px rgba(15, 23, 42, .12), 0 8px 12px -6px rgba(15, 23, 42, .07);--card-shadow: var(--shadow-sm);--header-bg: rgba(255, 255, 255, .92);--header-blur: saturate(180%) blur(14px);--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;--divider: #e3e6ec;--hover-bg: #e1e5ec;--input-bg: #ffffff;--input-border: #cdd2db;--overlay-bg: rgba(15, 23, 42, .45);--banner-warn-bg: #fffbeb;--banner-warn-border: #fde68a;--banner-warn-text: #92400e;--banner-err-bg: #fef2f2;--banner-err-border: #fecaca;--banner-err-text: #991b1b;--scrollbar-thumb: rgba(15, 23, 42, .14);--scrollbar-hover: rgba(15, 23, 42, .26);--svg-node-fill: #ffffff;--svg-node-stroke: rgba(15, 23, 42, .12);--svg-label-color: #1f2937;--flow-inactive: #d8dce4;--inv-inner: #dde2ea;--tint-green: #ecfdf4;--tint-orange: #fff3e6;--tint-blue: #e6f0ff;--tint-red: #fdecec;--toolbar-bg-rgb: 234, 236, 240;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1)}:root[data-theme=dark]{color-scheme:dark;--bg: #0a0d14;--bg-elevated: #11151f;--card-bg: #141925;--card-border: #1f2533;--card-border-strong: #2a3245;--text-primary: #e6ecf5;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-blue: #60a5fa;--accent-green: #34d399;--accent-orange: #fb923c;--accent-purple: #a78bfa;--accent-red: #f87171;--accent-amber: #fbbf24;--accent-cyan: #22d3ee;--accent-indigo: #818cf8;--accent-pink: #f472b6;--brand-from: #fbbf24;--brand-to: #34d399;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .4);--card-shadow: var(--shadow-sm);--header-bg: rgba(17, 21, 32, .8);--divider: #1f2533;--hover-bg: #1c2333;--input-bg: #1a1f2e;--input-border: #2a3347;--overlay-bg: rgba(0, 0, 0, .65);--banner-warn-bg: #1a1708;--banner-warn-border: #854d0e;--banner-warn-text: #fbbf24;--banner-err-bg: #1a0808;--banner-err-border: #7f1d1d;--banner-err-text: #fca5a5;--scrollbar-thumb: rgba(255, 255, 255, .08);--scrollbar-hover: rgba(255, 255, 255, .18);--svg-node-fill: #1a1f2e;--svg-node-stroke: rgba(255, 255, 255, .08);--svg-label-color: #cbd5e1;--flow-inactive: #2a3347;--inv-inner: #1e2535;--toolbar-bg-rgb: 10, 13, 20;--tint-green: rgba(34, 197, 94, .12);--tint-orange: rgba(234, 88, 12, .12);--tint-blue: rgba(59, 130, 246, .12);--tint-red: rgba(239, 68, 68, .12)}.app-root,.header,.card,.dashboard-card,.widget-drawer{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.app-root{width:100%;min-height:100vh;background:var(--bg);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);font-size:16px;line-height:1.5}.header{background:var(--header-bg);-webkit-backdrop-filter:var(--header-blur);backdrop-filter:var(--header-blur);border-bottom:1px solid var(--card-border);padding:0 24px;position:sticky;top:0;z-index:100}.header-top{display:flex;justify-content:space-between;align-items:center;padding:12px 0 6px;gap:12px}.header-left{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:32px;height:32px;border-radius:var(--radius-md);background:var(--brand-gradient);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px -2px #f59e0b59,inset 0 1px #ffffff40;position:relative}.brand-mark svg{width:20px;height:20px;color:#fff;filter:drop-shadow(0 1px 1px rgba(0,0,0,.15))}.plant-name{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.header-nav-row{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:0;margin:0 -4px;position:relative;-webkit-mask-image:linear-gradient(to right,transparent 0,#000 16px,#000 calc(100% - 16px),transparent 100%);mask-image:linear-gradient(to right,transparent 0,#000 16px,#000 calc(100% - 16px),transparent 100%);scroll-snap-type:x proximity}.header-nav-row::-webkit-scrollbar{display:none}.header-nav-row .nav-tab{scroll-snap-align:start}.theme-toggle{all:unset;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:background .2s ease,color .2s ease,transform .2s var(--ease-out)}.theme-toggle:hover{background:var(--hover-bg);color:var(--accent-blue);transform:scale(1.06)}.theme-toggle:active{transform:scale(.94)}.theme-toggle__icon{transition:transform .5s cubic-bezier(.34,1.56,.64,1)}.theme-toggle__icon--dark{transform:rotate(40deg)}.header-nav{display:flex;gap:2px;padding:2px 4px}.nav-tab{background:none;border:none;padding:9px 14px;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:color .18s,background .18s;position:relative;white-space:nowrap;font-family:inherit}.nav-tab:after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--accent-blue);transform:scaleX(0);transition:transform .22s var(--ease-out);border-radius:2px}.nav-tab:hover{color:var(--text-primary);background:var(--hover-bg)}.nav-tab.active{color:var(--accent-blue);font-weight:600}.nav-tab.active:after{transform:scaleX(1)}.header-status{display:flex;align-items:center;gap:16px;padding:6px 0 10px;font-size:13px;color:var(--text-muted)}.status-indicator{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px;padding:4px 10px 4px 8px;border-radius:var(--radius-pill);background:var(--hover-bg);border:1px solid var(--card-border);letter-spacing:.01em}.status-indicator.online{color:var(--accent-green);background:var(--tint-green);border-color:#22c55e40}.status-indicator.offline{color:var(--accent-red);background:var(--tint-red);border-color:#ef444440}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;position:relative}.status-indicator.online .status-dot{background:var(--accent-green);box-shadow:0 0 #22c55e80;animation:status-pulse 2.4s var(--ease-out) infinite}@keyframes status-pulse{0%{box-shadow:0 0 #22c55e8c}70%{box-shadow:0 0 0 6px #22c55e00}to{box-shadow:0 0 #22c55e00}}.status-indicator.offline .status-dot{background:var(--accent-red)}.poll-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--card-bg);color:var(--text-primary);border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:4px 22px 4px 10px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;margin-left:8px;transition:border-color .18s,background .18s;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1l4 4 4-4' stroke='%237a8495' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 8px center}.poll-select:hover{border-color:var(--card-border-strong);background-color:var(--hover-bg)}.poll-select:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px;border-color:var(--accent-blue)}.lang-select{margin-left:0;padding:6px 22px 6px 10px;font-size:12.5px;height:32px}.plant-capacity{font-weight:500;color:var(--text-secondary)}.inverter-status,.last-update{color:var(--text-muted);font-size:14px}.overview-layout{padding:16px 24px;display:flex;flex-direction:column;gap:16px}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--border-radius);box-shadow:var(--card-shadow);overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px 10px;border-bottom:1px solid var(--divider)}.card-header h3{margin:0;font-size:15px;font-weight:600;color:var(--text-secondary);letter-spacing:0}.flow-graph-card{display:flex;flex-direction:column;min-height:0;height:100%}.flow-graph{padding:0 8px 8px;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.flow-svg{width:100%;height:100%;flex:1;min-height:0}.flow-svg .flow-node rect{transition:filter .3s}.flow-svg .flow-node:hover rect{filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}.summary-card,.utilization-card{display:flex;flex-direction:column}.error-banner-top{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 24px;background:var(--banner-err-bg);border-bottom:1px solid var(--banner-err-border);color:var(--banner-err-text);font-size:14px;font-weight:500}.error-dismiss{background:none;border:none;color:#c62828;font-size:18px;cursor:pointer;padding:2px 6px;border-radius:4px}.error-dismiss:hover{background:#c628281a}@media (max-width: 900px){.overview-layout{padding:12px}.header{padding:0 14px}.header-status,.card-header{flex-wrap:wrap;gap:8px}}@media (max-width: 600px){.header-nav{flex-wrap:nowrap;white-space:nowrap}.flow-graph{padding:0 2px 2px}.flow-graph-card .card-header{padding:8px 10px 4px}.flow-node-bg{filter:none;stroke-opacity:.4}.pp-chart-scroll{min-height:0!important;-webkit-overflow-scrolling:touch;scrollbar-width:none}.pp-chart-scroll::-webkit-scrollbar{display:none}.card-header{padding:6px 8px 4px}.card-header h3{font-size:13px}.card{border-radius:var(--radius-md)}.header{padding:0 10px}.header-top{padding:8px 0 4px;gap:8px}.brand-mark{width:28px;height:28px}.brand-mark svg{width:17px;height:17px}.plant-name{font-size:15px}.status-indicator{font-size:11px;padding:3px 8px 3px 7px}.status-indicator__label{display:none}.header-status{font-size:11px;gap:6px;padding:4px 0 6px}.nav-tab{padding:7px 12px;font-size:13px;flex-shrink:0}.header-nav-row{margin:0 -10px;padding:0 10px}.theme-toggle{width:34px;height:34px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent}.device-card{padding:0!important}.device-card-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--card-border)}.device-card-header svg{opacity:.6;flex-shrink:0}.device-card-header h3{font-size:1rem;font-weight:600;margin:0;flex:1;color:var(--text-primary)}.device-status-badge{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:12px;white-space:nowrap}.device-status-badge.online{background:#22c55e26;color:#22c55e}.device-status-badge.offline{background:#ef444426;color:#ef4444}.device-status-badge.warn{background:#eab30826;color:#eab308}.device-card-body{padding:12px 20px 16px}.device-info-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--divider, rgba(255,255,255,.04))}.device-info-row:last-child{border-bottom:none}.device-info-label{font-size:.82rem;color:var(--text-muted);font-weight:500}.device-info-value{font-size:.85rem;font-weight:600;color:var(--text-primary)}.device-info-value.mono{font-family:var(--font-mono)}.device-info-value.text-green{color:#22c55e}.device-info-value.text-red{color:#ef4444}.devices-page{display:flex;flex-direction:column;gap:16px;padding:0}.devices-page-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:.95rem}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}@media (max-width: 480px){.devices-grid{grid-template-columns:1fr}}.device-specs-divider{height:1px;background:var(--card-border);margin:8px 0}.device-notes{margin-top:8px;padding:8px 12px;background:var(--bg-secondary, rgba(255,255,255,.03));border-radius:6px;font-size:.8rem;color:var(--text-muted);line-height:1.5}.device-string-block{padding:10px 0;border-bottom:1px solid var(--card-border)}.device-string-block:last-child{border-bottom:none}.device-string-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.device-string-label{font-size:.85rem;font-weight:700;color:var(--accent)}.device-string-power{font-size:.78rem;font-weight:600;color:var(--text-muted)}.device-panels-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.device-panel-tag{font-size:.68rem;font-family:var(--font-mono);padding:2px 6px;border-radius:4px;background:var(--bg-secondary, rgba(255,255,255,.06));color:var(--text-muted);white-space:nowrap}.layout-manager{padding:0 16px 24px}.layout-toolbar{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:8px 4px;margin-bottom:4px;position:sticky;top:0;z-index:50;background:rgba(var(--toolbar-bg-rgb, 248, 250, 252),.97);border-bottom:1px solid var(--card-border)}.layout-toolbar--hidden{display:none}.layout-toolbar__save-indicator{font-size:16px;font-weight:600;transition:color .3s}.layout-toolbar__btn{padding:6px 14px;border-radius:8px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.layout-toolbar__btn:hover,.layout-toolbar__btn--edit{background:var(--hover-bg);border-color:var(--text-muted)}.layout-toolbar__btn--edit.active{background:#006fff1a;border-color:var(--accent-blue);color:var(--accent-blue)}.layout-toolbar__btn--add{background:#f0fdf4;border-color:#86efac;color:#16a34a}.layout-toolbar__btn--add:hover{background:#dcfce7}.layout-toolbar__btn--reset{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.layout-toolbar__btn--reset:hover{background:#ffedd5}.dashboard-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;align-items:start}.dashboard-grid>*{min-width:0;overflow:hidden}.dashboard-grid__item--flowGraph{grid-column:span 5;grid-row:span 2}.dashboard-grid__item--energySankey{grid-column:span 7;grid-row:span 2}.dashboard-grid__item--solarUtilization,.dashboard-grid__item--gridCurves,.dashboard-grid__item--powerProfile,.dashboard-grid__item--panelArray,.dashboard-grid__item--liveCharts{grid-column:span 12}@media (max-width: 996px){.dashboard-grid{grid-template-columns:1fr;gap:10px}.dashboard-grid__item--flowGraph,.dashboard-grid__item--powerProfile,.dashboard-grid__item--solarUtilization,.dashboard-grid__item--energySankey,.dashboard-grid__item--gridCurves,.dashboard-grid__item--panelArray,.dashboard-grid__item--liveCharts{grid-column:span 1;grid-row:auto}}@media (max-width: 768px){.dashboard-grid{gap:8px}}.layout-manager--editing .dashboard-card{box-shadow:0 0 0 1.5px #3b82f61f,0 2px 8px #0000000a}.layout-manager--editing .dashboard-card .dashboard-card__actions{opacity:1}.layout-manager--editing .drag-handle{cursor:grab}.layout-manager--editing .drag-handle:active{cursor:grabbing}.react-grid-placeholder{background:var(--accent-blue)!important;opacity:.12!important;border-radius:14px!important;border:2px dashed var(--accent-blue)!important}.react-resizable-handle{z-index:10}.react-resizable-handle:after{display:none!important}.react-resizable-handle-se,.react-resizable-handle-sw,.react-resizable-handle-ne,.react-resizable-handle-nw,.react-resizable-handle-s,.react-resizable-handle-n,.react-resizable-handle-e,.react-resizable-handle-w{position:absolute;opacity:0;transition:opacity .2s}.layout-manager--editing .react-grid-item:hover>.react-resizable-handle{opacity:1}.react-resizable-handle-s{bottom:0;left:0;right:0;height:12px;cursor:s-resize;background:linear-gradient(to top,rgba(59,130,246,.15),transparent)}.react-resizable-handle-n{top:0;left:0;right:0;height:12px;cursor:n-resize;background:linear-gradient(to bottom,rgba(59,130,246,.15),transparent)}.react-resizable-handle-e{right:0;top:0;bottom:0;width:12px;cursor:e-resize;background:linear-gradient(to left,rgba(59,130,246,.15),transparent)}.react-resizable-handle-w{left:0;top:0;bottom:0;width:12px;cursor:w-resize;background:linear-gradient(to right,rgba(59,130,246,.15),transparent)}.react-resizable-handle-se{bottom:0;right:0;width:20px;height:20px;cursor:se-resize;background:radial-gradient(circle at 85% 85%,rgba(59,130,246,.5) 2px,transparent 2px)}.react-resizable-handle-sw{bottom:0;left:0;width:20px;height:20px;cursor:sw-resize;background:radial-gradient(circle at 15% 85%,rgba(59,130,246,.5) 2px,transparent 2px)}.react-resizable-handle-ne{top:0;right:0;width:20px;height:20px;cursor:ne-resize;background:radial-gradient(circle at 85% 15%,rgba(59,130,246,.5) 2px,transparent 2px)}.react-resizable-handle-nw{top:0;left:0;width:20px;height:20px;cursor:nw-resize;background:radial-gradient(circle at 15% 15%,rgba(59,130,246,.5) 2px,transparent 2px)}.layout-manager--editing .react-grid-item:hover{outline:2px solid rgba(59,130,246,.3);outline-offset:-1px;border-radius:14px}.dashboard-card{display:flex;flex-direction:column;background:var(--card-bg);border-radius:var(--radius-lg, 16px);border:1px solid var(--card-border);overflow:clip;box-shadow:var(--shadow-sm, var(--card-shadow));transition:box-shadow .25s var(--ease-out, ease),border-color .25s var(--ease-out, ease)}.dashboard-card:hover{box-shadow:var(--shadow-md, 0 4px 6px -1px rgba(15, 23, 42, .05));border-color:var(--card-border-strong, var(--divider))}.dashboard-card--minimized{height:auto!important}.dashboard-card--minimized .dashboard-card__header{border-bottom:none}.dashboard-card__header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px 8px;background:transparent;border-bottom:none;flex-shrink:0;-webkit-user-select:none;user-select:none;min-height:36px}.dashboard-card__label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-card__actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .2s ease}.dashboard-card:hover .dashboard-card__actions,.dashboard-card--minimized .dashboard-card__actions{opacity:1}.dashboard-card__btn{width:26px;height:26px;padding:0;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.dashboard-card__btn:hover{background:var(--hover-bg);color:var(--text-secondary)}.dashboard-card__btn--collapse:hover{color:var(--accent-blue)}.dashboard-card__btn--remove:hover{background:#ef444414;color:#ef4444}.dashboard-card__body{padding-top:0;display:flex;flex-direction:column}.dashboard-card__body::-webkit-scrollbar{width:2px;height:2px}.dashboard-card__body::-webkit-scrollbar-track{background:transparent}.dashboard-card__body::-webkit-scrollbar-thumb{background:transparent;border-radius:99px}.dashboard-card__body:hover::-webkit-scrollbar-thumb{background:var(--scrollbar-hover)}.dashboard-card__body>.card{border:none;border-radius:0;box-shadow:none;margin:0;flex:none;min-height:0;display:flex;flex-direction:column;overflow:visible}.dashboard-card__body>.card.live-charts-card{overflow:hidden}.dashboard-card__body>.card.flow-graph-card{overflow:hidden}.dashboard-card__body>.card .card-header{display:none}.live-charts-card{display:flex;flex-direction:column}.live-charts-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px 4px;flex-shrink:0}.live-charts-scroll{overflow-x:hidden;overflow-y:auto;padding:0 20px;max-height:650px}@media (max-width: 768px){.live-charts-scroll{max-height:500px}}.live-charts-scroll::-webkit-scrollbar{width:3px}.live-charts-scroll::-webkit-scrollbar-track{background:transparent}.live-charts-scroll::-webkit-scrollbar-thumb{background:transparent;border-radius:99px}.live-charts-scroll:hover::-webkit-scrollbar-thumb{background:var(--scrollbar-hover, #ccc)}.live-charts-brush{flex-shrink:0;padding:6px 20px 12px;border-top:1px solid var(--divider, #e8ecf1);background:var(--card-bg)}.widget-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:1000;display:flex;justify-content:flex-end;animation:drawerFadeIn .2s ease}@keyframes drawerFadeIn{0%{opacity:0}to{opacity:1}}.widget-drawer{width:360px;max-width:90vw;background:var(--card-bg);box-shadow:-8px 0 24px #0000001f;display:flex;flex-direction:column;animation:drawerSlideIn .25s ease}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.widget-drawer__header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 16px;border-bottom:1px solid var(--card-border)}.widget-drawer__header h3{margin:0;font-size:17px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.widget-drawer__close{width:32px;height:32px;border:none;background:var(--hover-bg);color:var(--text-secondary);font-size:16px;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s}.widget-drawer__close:hover{background:var(--divider)}.widget-drawer__list{flex:1;overflow-y:auto;padding:12px}.widget-drawer__item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:10px;border:1px solid var(--card-border);margin-bottom:8px;transition:all .15s}.widget-drawer__item:hover{border-color:var(--text-muted);background:var(--hover-bg)}.widget-drawer__item-info{display:flex;align-items:center;gap:12px}.widget-drawer__item-icon{font-size:28px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--hover-bg);border-radius:10px}.widget-drawer__item-label{font-size:15px;font-weight:500;color:var(--text-primary)}.widget-drawer__item-desc{font-size:13px;color:var(--text-muted);margin-top:2px;font-weight:400}.widget-drawer__add-btn{padding:6px 14px;border-radius:8px;border:1px solid #86efac;background:#f0fdf4;color:#16a34a;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.widget-drawer__add-btn:hover{background:#dcfce7}.widget-drawer__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;color:var(--text-muted);text-align:center}.widget-drawer__empty p{margin:0;font-size:15px}.widget-drawer__footer{padding:14px 20px;border-top:1px solid var(--card-border)}.widget-drawer__hint{margin:0;font-size:13px;color:#94a3b8;text-align:center}.layout-fab{position:fixed;bottom:24px;right:24px;z-index:100;width:48px;height:48px;border-radius:50%;border:none;background:var(--card-bg);color:var(--text-secondary);font-size:23px;cursor:pointer;box-shadow:0 2px 12px #0000001f,0 0 0 1px #0000000a;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.layout-fab:hover{transform:scale(1.08);box-shadow:0 4px 16px #0000002e,0 0 0 1px #0000000f;background:var(--hover-bg)}.layout-fab--active{background:var(--accent-blue);color:#fff;box-shadow:0 4px 16px #006fff59,0 0 0 2px #006fff26}.layout-fab--active:hover{background:#0059d6;box-shadow:0 4px 20px #006fff73,0 0 0 2px #006fff33}.layout-fab__tooltip{position:absolute;right:56px;top:50%;transform:translateY(-50%);background:#1e293b;color:#fff;font-size:13px;font-weight:500;padding:5px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;font-family:inherit}.layout-fab:hover .layout-fab__tooltip{opacity:1}@media (max-width: 768px){.layout-manager{padding:0 4px 12px}.layout-toolbar{flex-wrap:wrap;gap:6px;padding:6px 4px}.widget-drawer{width:100%;max-width:100%}.layout-toolbar__btn{padding:4px 8px;font-size:12px}.dashboard-card{border-radius:12px}.dashboard-card__header{padding:6px 10px 4px;min-height:28px}.dashboard-card__label{font-size:11px}.dashboard-card__body>.card{overflow:visible}.live-charts-header{padding:8px 12px 2px}.live-charts-scroll{padding:0 10px}.layout-fab{bottom:16px;right:16px;width:42px;height:42px;font-size:20px}}@media (max-width: 480px){.layout-manager{padding:0 2px 8px}.dashboard-card__header{padding:4px 8px 2px;min-height:24px}.dashboard-card__label{font-size:10px}.dashboard-card{border-radius:10px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02","cv03","cv04","cv11";background:var(--bg);color:var(--text-primary);font-size:16px;line-height:1.5;min-height:100vh;transition:background-color .3s ease,color .3s ease}#root{width:100%;min-height:100vh}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}button:disabled{opacity:.6;cursor:not-allowed}
