﻿/* 前端页面CSS */
*{margin:0;padding:0;box-sizing:border-box}
:root{--primary-color:#409eff;--success-color:#67c23a;--warning-color:#e6a23c;--danger-color:#f56c6c;--bg-dark:#001529;--bg-light:#f0f2f5}

/* v-cloak: 隐藏Vue未编译的模板语法{{xxx}} */
[v-cloak]{display:none!important}

html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}
body{background-image:url(../images/086.jpg);background-size:cover;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Hiragino Sans GB','Microsoft YaHei',sans-serif;/*background:var(--bg-light)*/}
/* .video-cd{position:absolute;top:57%;left:53%;transform:translate(-50%,-50%);width:162%;height:160%;object-fit:cover;z-index:-1;/*opacity:0.2;*//*pointer-events:none} */
/* 登录页面 */
.login-container{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0b2f52 0%,#063b81 100%);position:relative;overflow:hidden}
.login-container::before{content:'';position:absolute;width:100%;height:100%;background:url('../images/086.png') center/cover;opacity:0.03}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.login-box{width:520px;padding:56px 48px;background:#fff;border-radius:20px;box-shadow:0 12px 48px rgba(0,0,0,0.08);position:relative;z-index:1}
.login-header{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:40px}
.login-header .logo-icon{font-size:48px;margin:0}
.login-header h1{font-size:24px;color:#1a202c;margin:0;font-weight:700;letter-spacing:1px}
.login-header p{color:#64748b;font-size:14px;margin-top:6px}

/* 主容器 */
.main-container{height:100vh;display:flex;overflow:hidden;position:relative}

/* 侧边栏 */
.sidebar{width:240px;background:linear-gradient(180deg,#001529 0%,#002140 100%);color:#fff;display:flex;flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;height:100vh;z-index:1000;transform:translateX(-100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);box-shadow:4px 0 20px rgba(0,0,0,0.3)}
.sidebar.expanded{transform:translateX(0)}
.sidebar-trigger{position:fixed;left:0;top:0;width:20px;height:100vh;z-index:999;background:transparent}
.logo{height:64px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:bold;background:rgba(255,255,255,0.05);border-bottom:1px solid rgba(255,255,255,0.1)}
.logo-icon{font-size:28px;margin-right:8px}
.menu{flex:1;padding:16px 0;overflow-y:auto}
.menu-item{padding:14px 24px;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:12px;margin:4px 12px;border-radius:8px}
.menu-item:hover{background:rgba(64,158,255,0.2)}
.menu-item.active{background:linear-gradient(90deg,#409eff,#53a8ff);box-shadow:0 4px 12px rgba(64,158,255,0.4)}
.menu-icon{font-size:18px}

/* 主内容区 */
.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;/*background:#f5f7fa*/}
.header{height:70px;/*background:#fff;*/display:flex;align-items:center;justify-content:space-between;padding:0 24px;/*box-shadow:0 1px 4px rgba(0,0,0,0.08);*/flex-shrink:0;z-index:10;background-image: url(../images/digital-top/db9394f.png);background-size: cover;position:relative;}
.header-left{display:flex;align-items:center;gap:16px}
.header-logo{height:40px;width:auto;object-fit:contain;}
.glow-divider{width:2px;height:40px;background:linear-gradient(180deg, transparent, #67c23a, transparent);box-shadow:0 0 10px #67c23a, 0 0 20px rgba(103,194,58,0.5);animation:divider-glow 2s ease-in-out infinite;}
@keyframes divider-glow{0%,100%{opacity:0.6}50%{opacity:1}}
.station-count{display:flex;flex-direction:column;align-items:center;color:#fff;}
.station-count-label{font-size:12px;color:rgba(255,255,255,0.7);margin-bottom:2px;}
.station-count-value{font-size:20px;font-weight:700;color:#67c23a;text-shadow:0 0 10px rgba(103,194,58,0.8);}
.header-title{font-size:18px;font-weight:600;color:#a3a7b0}
.header-center{position:absolute;left:50%;top:50%;transform:translate(-50%, -50%);font-size:24px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.5);letter-spacing:2px;}
.header-right{display:flex;align-items:center;gap:16px;}
.admin-info{display:flex;align-items:center;gap:12px;}
.admin-name{font-size:16px;color:#bbc0c9;font-weight:500;}
.time-display{display:flex;flex-direction:column;align-items:center;color:#fff;}
.time-date{font-size:12px;color:rgba(255,255,255,0.8);}
.time-clock{font-size:16px;font-weight:600;color:#67c23a;text-shadow:0 0 8px rgba(103,194,58,0.6);margin-top:2px;}
.qr-code-wrapper{position:relative;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border-radius:8px;border:1px solid rgba(103,194,58,0.3);transition:all 0.3s;}
.qr-code-wrapper:hover{background:rgba(103,194,58,0.2);border-color:#67c23a;box-shadow:0 0 15px rgba(103,194,58,0.5);}
.qr-icon{font-size:24px;color:#67c23a;}
.qr-popup{position:absolute;top:calc(100% + 10px);right:0;background:rgba(15,23,42,0.98);border:2px solid #67c23a;border-radius:12px;padding:16px;box-shadow:0 8px 32px rgba(0,0,0,0.6), 0 0 20px rgba(103,194,58,0.4);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all 0.3s ease;z-index:1000;backdrop-filter:blur(10px);}
.qr-code-wrapper:hover .qr-popup{opacity:1;visibility:visible;transform:translateY(0);}
.qr-popup::before{content:'';position:absolute;top:-8px;right:20px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #67c23a;}
.qr-popup-image{width:180px;height:180px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;color:#999;font-size:12px;}
.content{flex:1;padding:20px;overflow:auto}

/* 大屏首页 */
.dashboard-container{display:flex;/*gap:16px;*/height:100%;min-width:0}
.dashboard-left{width:280px;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;height:100%}
.dashboard-left-scroll{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;display:flex;flex-direction:column;gap:16px;min-height:0}
.dashboard-left-scroll::-webkit-scrollbar{display:none}
.dashboard-center{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}
.dashboard-right{width:320px;display:flex;flex-direction:column;gap:16px;flex-shrink:0}

/* 环保数据卡片 */
.eco-panel{border-radius:12px;/*padding:16px;*/position:relative;overflow:hidden;display:flex;flex-direction:column;gap:12px}
.eco-panel::before{content:'';position:absolute;top:-50%;right:-50%;width:200%;height:200%;animation:eco-pulse 6s ease-in-out infinite}
@keyframes eco-pulse{0%,100%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.1) rotate(45deg)}}
.eco-header{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid rgba(103,194,58,0.2);position:relative;z-index:1}
.eco-icon{font-size:28px;filter:drop-shadow(0 4px 8px rgba(103,194,58,0.4))}
.eco-title{color:#fff;font-size:16px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.eco-stats{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.eco-cards-container{display:flex;flex-direction:row;gap:8px}
.eco-data-card{flex:1;border:1px solid rgba(103,194,58,0.25);border-radius:10px;padding:12px;background:rgba(0,0,0,0.1)}
.eco-card-header{display:flex;align-items:center;gap:6px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid rgba(103,194,58,0.2)}
.eco-card-icon{font-size:16px;filter:drop-shadow(0 2px 4px rgba(255,255,255,0.3))}
.eco-card-title{color:#fff;font-size:13px;font-weight:600}
.eco-card-body{display:flex;flex-direction:column;gap:0}
.eco-card-main-value{display:flex;align-items:baseline;gap:4px;justify-content:center;padding:12px 0}
.eco-value-number{font-size:26px;font-weight:700;background:linear-gradient(135deg,#86efac,#67c23a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 2px 8px rgba(134,239,172,0.3)}
.eco-value-unit{font-size:12px;color:rgba(255,255,255,0.7);font-weight:500}
.eco-card-details{display:flex;justify-content:space-around;padding-top:4px;border-top:1px solid rgba(103,194,58,0.15)}
.eco-detail-item{display:flex;flex-direction:column;align-items:center;gap:2px}
.eco-detail-label{font-size:10px;color:rgba(255,255,255,0.5)}
.eco-detail-value{font-size:14px;color:#86efac;font-weight:600}
.eco-detail-unit{font-size:9px;color:rgba(255,255,255,0.5);margin-left:2px}
.eco-label{color:rgba(255,255,255,0.85);font-size:13px;margin-bottom:8px;display:flex;align-items:center;gap:6px;font-weight:500}
.eco-emoji{font-size:16px;filter:drop-shadow(0 2px 4px rgba(103,194,58,0.3))}
.eco-value-row{display:flex;align-items:baseline;gap:6px;margin-bottom:10px}
.eco-value{color:#67c23a;font-size:28px;font-weight:700;text-shadow:0 2px 8px rgba(103,194,58,0.4);font-family:'Arial',sans-serif}
.eco-unit{color:rgba(255,255,255,0.7);font-size:13px;font-weight:500}
.eco-details{display:flex;gap:12px;margin-bottom:8px;padding:8px;background:rgba(0,0,0,0.15);border-radius:6px;border:1px solid rgba(103,194,58,0.15)}
.eco-detail-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.eco-detail-label{font-size:10px;color:rgba(255,255,255,0.6)}
.eco-detail-value{font-size:16px;font-weight:700;color:#86efac;text-shadow:0 1px 4px rgba(134,239,172,0.3)}
.eco-detail-unit{font-size:10px;color:rgba(255,255,255,0.5)}
.eco-trend-bar{margin-top:4px}
.eco-trend-label{font-size:10px;color:rgba(255,255,255,0.6);margin-bottom:4px}
.eco-progress{height:18px;background:rgba(0,0,0,0.2);border-radius:10px;overflow:hidden;position:relative;border:1px solid rgba(103,194,58,0.2)}
.eco-progress-fill{height:100%;background:linear-gradient(90deg,#4ade80,#67c23a);border-radius:10px;display:flex;align-items:center;justify-content:flex-end;padding:0 8px;transition:width 0.5s ease;position:relative;box-shadow:0 0 10px rgba(103,194,58,0.3)}
.eco-progress-fill::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);animation:shimmer 2s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.eco-progress-text{font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.5);z-index:1}
.eco-summary{/*background:linear-gradient(135deg,rgba(103,194,58,0.15),rgba(67,154,38,0.12));*/border:1px solid rgba(103,194,58,0.3);border-radius:10px;padding:12px;margin-top:4px}
.eco-summary-title{display:flex;align-items:center;gap:6px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(103,194,58,0.25)}
.eco-summary-icon{font-size:18px;filter:drop-shadow(0 2px 4px rgba(255,215,0,0.5))}
.eco-summary-title span:last-child{color:#fff;font-size:13px;font-weight:600}
.eco-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.eco-summary-item{background:rgba(0,0,0,0.15);border-radius:6px;padding:8px;text-align:center;border:1px solid rgba(103,194,58,0.15);transition:all 0.3s}
.eco-summary-item:hover{background:rgba(0,0,0,0.25);border-color:rgba(103,194,58,0.3);transform:translateY(-2px)}
.eco-summary-label{font-size:10px;color:rgba(255,255,255,0.65);margin-bottom:4px;display:block}
.eco-summary-value{font-size:16px;font-weight:700;color:#86efac;text-shadow:0 1px 4px rgba(134,239,172,0.3)}
.eco-summary-unit{font-size:10px;color:rgba(255,255,255,0.6);margin-left:2px}

/* 虚拟电厂和电力市场容器 */
/* 虚拟电厂与电力市场统一模块 */
.vpp-market-module{/*background:linear-gradient(135deg,#1a1a2e,#16213e);padding:16px;*/border-radius:12px;flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.vpp-market-scroll{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;display:flex;flex-direction:column;gap:16px;/*padding-right:4px*/}
.vpp-market-scroll::-webkit-scrollbar{display:none}

/* 虚拟电厂调度 */
.vpp-panel{border-radius:12px;display:flex;flex-direction:column;gap:12px}
.vpp-header{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid rgba(33,150,243,0.2)}
.vpp-icon{font-size:24px;filter:drop-shadow(0 4px 8px rgba(33,150,243,0.4))}
.vpp-title{color:#f8f2f2f8;font-size:14px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.vpp-content{display:flex;flex-direction:column;gap:10px}
.vpp-status-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.vpp-card{background:rgba(0,0,0,0.2);border:1px solid rgba(33,150,243,0.25);border-radius:8px;padding:10px;text-align:center}
.vpp-card-label{font-size:10px;color:rgba(255,255,255,0.6);margin-bottom:6px}
.vpp-card-value{font-size:20px;font-weight:700;color:#2196f3;text-shadow:0 2px 8px rgba(33,150,243,0.3)}
.vpp-unit{font-size:11px;color:rgba(255,255,255,0.6);margin-left:4px}
.vpp-schedule-info{background:rgba(0,0,0,0.2);border:1px solid rgba(33,150,243,0.25);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px}
.vpp-info-row{display:flex;justify-content:space-between;font-size:11px}
.vpp-info-label{color:rgba(255,255,255,0.6)}
.vpp-info-value{color:#2196f3;font-weight:600}
.vpp-info-value.charging{color:#4caf50}
.vpp-info-value.discharging{color:#ff9800}
.vpp-info-value.normal{color:#4caf50}
.vpp-info-value.peak{color:#ff5722}

/* 电力市场化交易 */
.market-panel{border-radius:12px;display:flex;flex-direction:column;gap:12px}
.market-header{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid rgba(156,39,176,0.2)}
.market-icon{font-size:24px;filter:drop-shadow(0 4px 8px rgba(156,39,176,0.4))}
.market-title{color:#f8f2f2f8;font-size:14px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.market-content{display:flex;flex-direction:column;gap:10px}
.market-price-display{background:rgba(0,0,0,0.2);border:1px solid rgba(156,39,176,0.25);border-radius:8px;padding:12px;text-align:center}
.market-price-item{display:flex;flex-direction:column;gap:4px}
.market-price-label{font-size:11px;color:rgba(255,255,255,0.6)}
.market-price-value{font-size:24px;font-weight:700;color:#ab47bc;text-shadow:0 2px 8px rgba(171,71,188,0.3)}
.market-price-unit{font-size:12px;color:rgba(255,255,255,0.6);margin-left:4px}
.market-price-trend{font-size:12px;font-weight:600;margin-top:4px}
.market-price-trend.up{color:#f44336}
.market-price-trend.down{color:#4caf50}
.market-trade-info{background:rgba(0,0,0,0.2);border:1px solid rgba(156,39,176,0.25);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px}
.market-info-row{display:flex;justify-content:space-between;font-size:11px}
.market-label{color:rgba(255,255,255,0.6)}
.market-value{color:#ab47bc;font-weight:600}
.market-value.revenue{color:#4caf50}
.market-value.active{color:#4caf50}
.market-value.pending{color:#ff9800}

/* 项目列表 */
.project-list{/*background:linear-gradient(135deg,#1a1a2e,#16213e);*/border-radius:12px;/*padding:16px;*/flex:1;overflow:hidden;display:flex;flex-direction:column}
.project-list-title{color:#ffffff9d;font-size:16px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.project-list-content{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}
.project-list-content::-webkit-scrollbar{display:none}
.project-item{background:rgba(255,255,255,0.08);border-radius:8px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .3s;border:1px solid transparent}
.project-item:hover{background:rgba(64,158,255,0.2);border-color:rgba(64,158,255,0.5);transform:translateX(4px)}
.project-item.active{background:rgba(64,158,255,0.3);border-color:#409eff}
.project-name{color:#fff;font-size:14px;font-weight:500;margin-bottom:6px}
.project-info{display:flex;justify-content:space-between;color:rgba(255,255,255,0.6);font-size:12px}
.project-status{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px}
.project-status.online{background:rgba(103,194,58,0.2);color:#67c23a}
.project-status.offline{background:rgba(245,108,108,0.2);color:#f56c6c}

/* 地图和卡片整体上移50px */
.dashboard-center{margin-top:-50px}

/* 地图容器 */
.map-container{background-image:url(../images/44.png);background-size:cover;background-position:center;border-radius:12px;flex:1;position:relative;overflow:hidden;min-height:400px;display:flex;flex-direction:column}
.map-header{position:absolute;top:36px;left:16px;right:16px;display:flex;justify-content:space-between;align-items:center;z-index:10}
.map-title{color:#ffffffa4;font-size:18px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,0.3)}

/* 地图切换按钮样式 - 在地图左上角 */
.map-switch{display:flex;gap:8px}
.map-switch .el-button{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:#fff;padding:4px 12px;font-size:13px;min-height:auto;border-radius:4px}
.map-switch .el-button.active,.map-switch .el-button:hover{background:rgba(64,158,255,0.3);border-color:#409eff}

/* header中的地图按钮(已弃用,保留防报错) */
.header-map-switch{display:none}
#mapChart{width:100%;height:100%;min-height:400px;flex:1}

/* 统计卡片 */
.stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.stat-card{/*background:linear-gradient(135deg,#1e3a5f,#2d4a6f);*/border-radius:10px;padding:16px;text-align:center;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;/*background:linear-gradient(90deg,var(--card-color),transparent)*/}
.stat-card[data-type="capacity"]{--card-color:#409eff}
.stat-card[data-type="charge"]{--card-color:#67c23a}
.stat-card[data-type="discharge"]{--card-color:#e6a23c}
.stat-card[data-type="today-charge"]{--card-color:#9966ff}
.stat-card[data-type="today-discharge"]{--card-color:#ff6699}
.stat-card[data-type="revenue"]{--card-color:#ffcc00}
.stat-label{color:rgba(255,255,255,0.7);font-size:12px;margin-bottom:8px}
.stat-value{color:#7fe74c;font-size:26px;font-weight:700}
.stat-unit{font-size:12px;color:rgba(255, 153, 0, 0.692);margin-left:4px}

/* 右侧面板 */
.panel{border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.panel-title{font-size:15px;font-weight:600;color:#cdcdcdc7;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.chart-container{width:100%;height:220px;min-height:200px}

/* 右侧紧凑型项目列表 */
.project-list-right{flex:1;display:flex;flex-direction:column;overflow:hidden}
.project-list-scroll {
  flex: 1;
  overflow-y: auto;
  padding-right: 4px;
}

/* 隐藏滚动条 - 兼容性更好的方案 */
.project-list-scroll::-webkit-scrollbar {
  display: none;
}

/* Firefox 兼容性 */
@supports (scrollbar-width: none) {
  .project-list-scroll {
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
}
.project-list-scroll::-webkit-scrollbar{display:none}
.project-item-compact{/*background:rgba(255,255,255,0.08);*/border-radius:6px;padding:10px;margin-bottom:8px;cursor:pointer;transition:all .3s;border:1px solid rgba(64,158,255,0.15)}
.project-item-compact:hover{background:rgba(64,158,255,0.15);border-color:rgba(64,158,255,0.4);transform:translateX(3px);box-shadow:0 2px 8px rgba(64,158,255,0.2)}
.project-item-compact.active{background:rgba(64,158,255,0.25);border-color:#409eff;box-shadow:0 0 12px rgba(64,158,255,0.4)}
.project-compact-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.project-compact-name{color:#fff;font-size:13px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.project-status-badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500}
.project-status-badge.online{background:rgba(103,194,58,0.25);color:#67c23a;border:1px solid rgba(103,194,58,0.4)}
.project-status-badge.offline{background:rgba(245,108,108,0.25);color:#f56c6c;border:1px solid rgba(245,108,108,0.4)}
.project-compact-info{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.project-compact-item{display:flex;flex-direction:column;align-items:center;background:rgba(0,0,0,0.15);border-radius:4px;padding:4px 2px}
.project-compact-label{font-size:9px;color:rgba(255,255,255,0.5);margin-bottom:2px}
.project-compact-value{font-size:11px;color:rgba(255,255,255,0.85);font-weight:600}

/* 项目详情模态框 */
.project-detail-modal .el-dialog__header{background:linear-gradient(90deg,#409eff,#53a8ff);padding:20px}
.project-detail-modal .el-dialog__title{color:#fff;font-size:18px}
.detail-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.detail-stat{background:#f5f7fa;border-radius:8px;padding:16px;text-align:center}
.detail-stat .label{color:#909399;font-size:12px;margin-bottom:8px}
.detail-stat .value{font-size:24px;font-weight:600;color:#303133}

/* 通用卡片样式 */
.card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 12px rgba(0,0,0,0.08);margin-bottom:16px}
.card-title{font-size:16px;font-weight:600;color:#303133;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #ebeef5;display:flex;justify-content:space-between;align-items:center}

/* 响应式 */
@media(max-width:1400px){
.dashboard-left{width:240px}
.dashboard-right{width:280px}
.stats-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1200px){
.dashboard-container{flex-direction:column}
.dashboard-left,.dashboard-right{width:100%;flex-direction:row;flex-wrap:wrap}
.project-list{min-height:200px}
.stats-row{grid-template-columns:repeat(2,1fr)}
}

/* 移动端优化 - 平板 (≤768px) */
@media(max-width:768px){
/* ========== 1. 头部精简：只留LOGO和管理员 ========== */
.header-logo{display:block!important;height:32px!important}
.station-count{display:none!important}
.time-display{display:none!important}
.header .glow-divider{display:none!important}
.qr-code-wrapper{display:none!important}
.header{height:56px;padding:0 12px;background-image:none!important;background-color:rgba(0,21,41,0.3)!important}
.header-left{gap:0}
.header-right{gap:0}
.header-center{display:none!important}
.admin-name{font-size:13px;color:#67c23a;font-weight:600}
.admin-info:hover .admin-name{color:#85d45a}

/* ========== 2. 地图置顶 + 按钮精简 ========== */
.dashboard-container{flex-direction:column!important}
.dashboard-left,.dashboard-right{width:100%!important;flex-shrink:unset!important}
.dashboard-center{order:-1!important}
.map-container{min-height:400px!important;border-radius:0!important;flex:none!important}
#mapChart{height:400px!important}

/* ========== 2.1 手机端世界地图独立高度控制 ========== */
/* 使用说明：切换世界地图时，通过JS给#mapChart添加.world-map-active类
   例：switchMap('world')时同步执行 document.getElementById('mapChart').classList.add('world-map-active')
       switchMap('china')时同步执行 document.getElementById('mapChart').classList.remove('world-map-active')
   这样可以在手机端为中国地图和世界地图设置不同的显示高度 */
#mapChart.world-map-active{height:350px!important}

/* 隐藏左上角储能分布标题 */
.map-title{display:none!important}
/* 地图切换按钮精简 - 在地图左上角 */
.map-switch .el-button{background:transparent!important;border:none!important;padding:4px 8px!important;font-size:12px!important;color:#ffffffa4!important;box-shadow:none!important;min-height:auto!important;border-radius:4px!important}
.map-switch .el-button.active{color:#fff!important;font-weight:700!important;background:rgba(255,255,255,0.1)!important}

/* ========== 3. 隐藏环保、收益图表、充放电图表 ========== */
.eco-panel{display:none!important}
.panel:has(#revenueChartDisplay){display:none!important}
.panel:has(#projectPowerStepChartDisplay){display:none!important}
.project-list-right{display:none!important}
.vpp-market-module{display:none!important}

/* ========== 4. 六组数据卡片化 ========== */
.stats-row{grid-template-columns:repeat(2,1fr);gap:18px;padding:10px}
.stat-card{padding:15px 12px;border-radius:8px;background:rgba(0,21,41,0.75)!important;border:1px solid rgba(64,158,255,0.25)!important;box-shadow:0 2px 8px rgba(0,0,0,0.3)!important;backdrop-filter:blur(8px)}
.stat-card::before{height:2px!important}
.stat-label{font-size:11px;color:rgba(255,255,255,0.7)}
.stat-value{font-size:18px;color:#7fe74c}
.stat-unit{font-size:10px;color:rgba(255,153,0,0.7)}

/* 项目列表3行滚动 */
.project-list-scroll{max-height:180px;overflow-y:auto}
.project-list-scroll::-webkit-scrollbar{width:3px}
.project-list-scroll::-webkit-scrollbar-thumb{background:rgba(103,194,58,0.3);border-radius:2px}
/* 虚拟电厂3行滚动 */
.vpp-market-scroll{max-height:200px;overflow-y:auto}
.vpp-market-scroll::-webkit-scrollbar{width:3px}
.vpp-market-scroll::-webkit-scrollbar-thumb{background:rgba(33,150,243,0.3);border-radius:2px}

/* 右侧面板间距 */
.dashboard-right{gap:12px!important}
.dashboard-left-scroll{gap:12px!important}
}

/* 移动端优化 - 手机 (≤480px) */
@media(max-width:480px){
/* 头部更紧凑 */
.header{height:48px;padding:0 8px}
.header-center{font-size:13px;letter-spacing:0.5px}
.header-logo{height:26px!important}
.admin-name{font-size:12px}

/* 地图更小 */
.map-container{min-height:240px!important}
#mapChart{height:220px!important}
.map-switch .el-button{font-size:11px!important;padding:2px 6px!important}

/* 统计卡片紧凑 */
.stats-row{grid-template-columns:repeat(2,1fr);gap:15px}
.stat-card{padding:13px;border-radius:6px}
.stat-label{font-size:10px}
.stat-value{font-size:16px}
.stat-unit{font-size:9px}

/* 项目列表更紧凑 */
.project-list-scroll{max-height:150px}
.vpp-market-scroll{max-height:160px}

/* 登录框适配 */
.login-box{width:92%;padding:32px 20px;border-radius:16px}
.login-header h1{font-size:18px!important}
.login-header img{height:28px!important}
}

/* ========== 移动端底部导航栏 (桌面端隐藏) ========== */
.mobile-nav{display:none}
.mobile-panel{display:none}
.mobile-overlay{display:none}

@media(max-width:768px){
.content{padding-bottom:64px!important}
/* 底部导航栏 */
.mobile-nav{display:flex!important;position:fixed;bottom:0;left:0;right:0;height:56px;background:rgba(0,15,30,0.95)!important;border-top:1px solid rgba(64,158,255,0.2);z-index:1000;backdrop-filter:blur(12px);justify-content:space-around;align-items:center;padding:0 8px}
.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;width:56px;height:48px;border-radius:8px;cursor:pointer;transition:all 0.2s;color:rgba(255,255,255,0.5);font-size:22px;-webkit-tap-highlight-color:transparent}
.mobile-nav-item:active,.mobile-nav-item.active{color:#409eff!important;background:rgba(64,158,255,0.15)}
.mobile-nav-item .nav-icon{font-size:22px;line-height:1}
/* 弹出面板 */
.mobile-panel{display:none;position:fixed;bottom:56px;left:0;right:0;max-height:50vh;background:rgba(0,15,30,0.97)!important;border-top:1px solid rgba(64,158,255,0.3);z-index:999;backdrop-filter:blur(12px);border-radius:16px 16px 0 0;overflow:hidden}
.mobile-panel.show{display:block!important}
.mobile-panel-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(64,158,255,0.15)}
.mobile-panel-title{color:#fff;font-size:15px;font-weight:600}
.mobile-panel-close{color:rgba(255,255,255,0.5);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px}
.mobile-panel-close:active{color:#fff;background:rgba(255,255,255,0.1)}
.mobile-panel-body{overflow-y:auto;max-height:calc(50vh - 48px);padding:12px 16px;-webkit-overflow-scrolling:touch}
.mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:56px;background:rgba(0,0,0,0.4);z-index:998}
.mobile-overlay.show{display:block!important}
}
@media(max-width:480px){
.mobile-nav{height:52px}
.mobile-nav-item{width:50px;height:44px;font-size:20px}
.mobile-nav-item .nav-icon{font-size:20px}
.mobile-panel{bottom:52px}
}

/* 验证码样式 */
.captcha-row{display:flex;gap:12px;align-items:stretch}
.captcha-row .el-form-item{flex:1;margin-bottom:0}
.captcha-box{position:relative;display:flex;align-items:center;justify-content:center;width:120px;height:40px;background:linear-gradient(135deg,#409eff,#53a8ff);border-radius:6px;cursor:pointer;transition:opacity 0.05s ease-in-out;z-index:99999!important}
.captcha-box:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(64,158,255,0.4)}
.captcha-box::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 120 40"><line x1="0" y1="20" x2="120" y2="10" stroke="rgba(255,255,255,0.2)" stroke-width="1"/><line x1="0" y1="10" x2="120" y2="30" stroke="rgba(255,255,255,0.2)" stroke-width="1"/></svg>');opacity:0.5}
.captcha-text{font-size:24px;font-weight:bold;color:#fff;letter-spacing:8px;text-shadow:2px 2px 4px rgba(0,0,0,0.3);position:relative;z-index:1;font-family:Arial,sans-serif}

/* ECharts tooltip样式 */
.echarts-tooltip,.custom-tooltip,div[class*="echarts-tooltip"]{pointer-events:none!important;-webkit-user-select:none!important;user-select:none!important;transition:opacity 0.05s ease-in-out,left 0.05s ease-out,top 0.05s ease-out!important;z-index:99999!important}
.echarts-tooltip *{pointer-events:none!important;-webkit-user-select:none!important;user-select:none!important}
