.eco-monitor[data-v-08dd3862]{padding:20px;min-height:100vh;background:#f8fafc;overflow-y:auto;scrollbar-width:none}.eco-monitor[data-v-08dd3862]::-webkit-scrollbar{display:none}.page-header[data-v-08dd3862]{margin-bottom:24px}.header-content[data-v-08dd3862]{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center}.title-section[data-v-08dd3862]{display:flex;gap:16px;align-items:center}.title-bar[data-v-08dd3862]{width:4px;height:48px;background:linear-gradient(180deg,#10b981,#059669);border-radius:2px}.page-title[data-v-08dd3862]{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 4px 0}.page-subtitle[data-v-08dd3862]{font-size:13px;color:#6b7280;margin:0}.status-badge[data-v-08dd3862]{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;background:#fee2e2;color:#991b1b;font-size:13px;font-weight:600}.status-badge.online[data-v-08dd3862]{background:#d1fae5;color:#065f46}.status-dot[data-v-08dd3862]{width:8px;height:8px;border-radius:50%;background:#ef4444;animation:pulse-08dd3862 2s infinite}.status-badge.online .status-dot[data-v-08dd3862]{background:#10b981}@keyframes pulse-08dd3862{0%,to{opacity:1}50%{opacity:.5}}.metrics-row[data-v-08dd3862]{margin-bottom:24px}.metric-card[data-v-08dd3862]{background:#fff;border-radius:16px;padding:16px 20px;box-shadow:0 1px 3px rgba(0,0,0,.05);border:1px solid #f1f5f9;height:130px;display:flex;flex-direction:column;justify-content:space-between;box-sizing:border-box}.metric-header[data-v-08dd3862]{display:flex;align-items:center;gap:8px;margin-bottom:8px}.metric-icon[data-v-08dd3862]{font-size:18px}.metric-label[data-v-08dd3862]{flex:1;font-size:13px;color:#6b7280;font-weight:600}.status-indicator[data-v-08dd3862]{width:8px;height:8px;border-radius:50%;background:#10b981}.status-indicator.inactive[data-v-08dd3862]{background:#9ca3af;animation:none}.status-indicator.warning[data-v-08dd3862]{background:#f59e0b;animation:warningPulse-08dd3862 2s infinite}@keyframes warningPulse-08dd3862{0%,to{opacity:1;box-shadow:0 0 0 0 rgba(245,158,11,.4)}50%{opacity:.8;box-shadow:0 0 0 6px rgba(245,158,11,0)}}.metric-value[data-v-08dd3862]{font-size:28px;font-weight:800;color:#059669;line-height:1;margin-bottom:2px}.metric-value .unit[data-v-08dd3862]{font-size:16px;color:#6b7280;font-weight:500;margin-left:4px}.metric-trend[data-v-08dd3862]{height:24px;opacity:.6}.metric-desc[data-v-08dd3862]{font-size:12px;color:#9ca3af}.source-hint[data-v-08dd3862]{color:#f59e0b;font-size:11px;margin-left:4px}.light-switch-body[data-v-08dd3862]{flex:1;display:flex;align-items:center;justify-content:center;min-height:36px}.metric-card--light .metric-desc[data-v-08dd3862]{min-height:32px}.weather-row[data-v-08dd3862]{margin-bottom:4px;display:flex;align-items:stretch}.weather-row .el-col[data-v-08dd3862]{display:flex}.weather-row .el-card[data-v-08dd3862]{flex:1}.glass-panel[data-v-08dd3862]{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:24px;box-shadow:0 1px 3px rgba(0,0,0,.05)}.panel-header[data-v-08dd3862]{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px}.panel-title[data-v-08dd3862]{font-size:16px;font-weight:700;color:#1f2937;margin:0 0 4px 0}.panel-subtitle[data-v-08dd3862]{font-size:12px;color:#6b7280;margin:0}.alert-timeline[data-v-08dd3862]{max-height:280px;overflow-y:auto}.timeline-items[data-v-08dd3862]{display:flex;flex-direction:column;gap:16px}.timeline-item[data-v-08dd3862]{position:relative;padding-left:24px;padding-bottom:16px;border-left:2px solid #e5e7eb}.timeline-item[data-v-08dd3862]:last-child{border-left-color:transparent}.timeline-dot[data-v-08dd3862]{position:absolute;left:-5px;top:4px;width:8px;height:8px;border-radius:50%;background:#10b981;border:2px solid #fff}.timeline-item.warning .timeline-dot[data-v-08dd3862]{background:#f59e0b}.timeline-item.danger .timeline-dot[data-v-08dd3862]{background:#ef4444}.timeline-time[data-v-08dd3862]{font-size:11px;color:#9ca3af;margin-bottom:4px}.timeline-title[data-v-08dd3862]{font-size:13px;font-weight:600;color:#374151;margin-bottom:4px}.timeline-desc[data-v-08dd3862]{font-size:12px;color:#6b7280}.empty-state[data-v-08dd3862]{text-align:center;padding:40px 20px}.empty-icon[data-v-08dd3862]{font-size:48px;margin-bottom:12px}.empty-text[data-v-08dd3862]{font-size:14px;color:#6b7280}.chart-row[data-v-08dd3862]{margin-bottom:24px}.card-header[data-v-08dd3862]{font-weight:600;font-size:14px;color:#1f2937;display:flex;align-items:center;gap:6px}.header-icon[data-v-08dd3862]{width:20px;height:20px;-o-object-fit:contain;object-fit:contain}.segment-control[data-v-08dd3862]{margin-left:auto;display:flex;background:#f3f4f6;border-radius:20px;padding:3px;gap:2px}.segment-btn[data-v-08dd3862]{padding:5px 14px;border:none;background:transparent;border-radius:16px;font-size:12px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease}.segment-btn.active[data-v-08dd3862]{background:#fff;color:#059669;box-shadow:0 1px 3px rgba(0,0,0,.1);font-weight:600}.forecast-rail[data-v-08dd3862]{position:relative;display:flex;align-items:center;gap:8px}.forecast-scroll-wrapper[data-v-08dd3862]{flex:1;overflow:hidden;position:relative}.scroll-btn[data-v-08dd3862]{flex-shrink:0;width:28px;height:28px;border:none;border-radius:50%;background:rgba(5,150,105,.1);color:#059669;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.forecast-scroll[data-v-08dd3862]{position:relative;display:flex;gap:0;overflow-x:auto;padding:10px 0;scroll-behavior:smooth;scrollbar-width:none;min-height:150px}.forecast-scroll[data-v-08dd3862]::-webkit-scrollbar{display:none}.temp-trend-svg[data-v-08dd3862]{position:absolute;top:10px;left:0;pointer-events:none;z-index:1}.forecast-column[data-v-08dd3862]{flex:0 0 64px;display:flex;flex-direction:column;align-items:center;z-index:2}.col-time[data-v-08dd3862]{font-size:12px;color:#6b7280;margin-bottom:6px;font-weight:600;white-space:nowrap}.col-icon[data-v-08dd3862]{font-size:22px;margin-bottom:4px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08))}.col-spacer[data-v-08dd3862]{height:60px;width:100%}.col-wind[data-v-08dd3862]{font-size:11px;color:#9ca3af;white-space:nowrap;font-weight:500}.forecast-scroll-7d[data-v-08dd3862]{padding:10px 4px;gap:12px}.forecast-7d-col[data-v-08dd3862]{flex:0 0 86px;background:rgba(248,250,252,.8);border:1px solid #f1f5f9;border-radius:12px;padding:14px 0;display:flex;flex-direction:column;align-items:center}.col-temp-range[data-v-08dd3862]{font-size:14px;font-weight:700;color:#1f2937}.col-temp-range .temp-divider[data-v-08dd3862]{color:#9ca3af;margin:0 4px;font-weight:400}.alert-list[data-v-08dd3862]{min-height:60px;display:flex;flex-direction:column;justify-content:center}.alert-item[data-v-08dd3862]{display:flex;align-items:flex-start;padding:10px;margin-bottom:8px;border-radius:8px;background:#fef0f0;border-left:3px solid #f56c6c}.alert-item.warning[data-v-08dd3862]{background:#fdf6ec;border-left-color:#e6a23c}.alert-item i[data-v-08dd3862]{font-size:18px;margin-right:8px;color:#f56c6c}.alert-item.warning i[data-v-08dd3862]{color:#e6a23c}.alert-content[data-v-08dd3862]{flex:1}.alert-title[data-v-08dd3862]{font-weight:600;font-size:13px;color:#1f2937;margin-bottom:4px}.alert-desc[data-v-08dd3862]{font-size:11px;color:#4b5563;line-height:1.4}.alert-card[data-v-08dd3862],.chart-row .el-card[data-v-08dd3862],.weather-forecast-card[data-v-08dd3862]{background:#fff!important;border-radius:12px!important;box-shadow:0 2px 8px rgba(0,0,0,.04)!important;border:1px solid #e5e7eb!important}.alert-card[data-v-08dd3862]{height:100%}.alert-card .el-card__body[data-v-08dd3862]{padding:10px!important;height:calc(100% - 44px);display:flex;align-items:center;justify-content:center}.alert-card .el-card__header[data-v-08dd3862],.weather-forecast-card .el-card__header[data-v-08dd3862]{background:#fff!important;padding:6px 12px!important;border-bottom:1px solid #f1f5f9!important;border-radius:12px 12px 0 0!important}.weather-forecast-card .el-card__body[data-v-08dd3862]{padding:6px 10px!important}.alert-card .el-card__body[data-v-08dd3862]{padding:6px!important}