:root{color-scheme:light;--bg:#fff;--panel:#f0f2f5;--card:#fff;--text:#1e293b;--muted:#64748b;--accent:#2563eb;--border:rgba(15,23,42,0.12)}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

.home-beta-note{margin:0 0 12px;font-size:.78rem;color:var(--muted)}
.home-beta-note a{color:var(--accent)}

/* ── Hero - 样式由 index.html 内联 style 管理 ── */

/* ── KPI 条 - 样式由 index.html 内联 style 管理 ── */

/* ── 主区双栏：左主区 + 右辅栏各自纵向堆叠，顶对齐 ── */
.home-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,280px);gap:14px 16px;align-items:start;margin-bottom:18px;width:100%;max-width:100%}
.home-main{display:flex;flex-direction:column;gap:14px;min-width:0;max-width:100%}
.home-layout .panel{margin-bottom:0}
.home-aside{display:flex;flex-direction:column;gap:10px;min-width:0;max-width:100%}
.home-aside-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:0 1px 3px rgba(15,23,42,.04);flex-shrink:0;min-width:0;max-width:100%;overflow:hidden}
.home-aside-title{margin:0 0 8px;font-size:.82rem;font-weight:700;color:#334155;line-height:1.3}
.home-aside-card .panel-note{margin:0 0 8px}
.home-station-list{list-style:none;margin:0;padding:0}
.home-station-list li{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:8px 0;border-bottom:1px solid rgba(15,23,42,.06);font-size:.78rem;line-height:1.35}
.home-station-list li:last-child{border-bottom:none}
.home-stn-name{font-weight:600;color:#0f172a}
.home-stn-flow{color:var(--muted);font-variant-numeric:tabular-nums;text-align:right}
.home-stn-z{font-weight:700;color:#0d9488;font-variant-numeric:tabular-nums;text-align:right}
.home-meta-list{margin:0;display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:.76rem}
.home-meta-list dt{color:var(--muted)}
.home-meta-list dd{margin:0;color:#334155;font-variant-numeric:tabular-nums}

.panel{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;margin-bottom:18px;box-shadow:0 1px 3px rgba(15,23,42,.05),0 4px 12px rgba(15,23,42,.04);min-width:0;max-width:100%}
.panel:last-child{margin-bottom:0}
.panel h2{margin:0 0 12px;font-size:1.1rem;font-weight:700}
.panel-note{color:var(--muted);font-size:.82rem;margin:-6px 0 12px}

.rain-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.rain-card-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.rain-card-ico{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#0ea5e9,#0284c7);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:#fff;flex-shrink:0}
.rain-card-title{font-size:.92rem;font-weight:700;color:var(--text)}
.rain-card-sub{font-size:.75rem;color:var(--muted);line-height:1.4;white-space:normal;word-break:break-word}
.basin-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.basin-ico{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#0ea5e9,#0284c7);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff;flex-shrink:0}
.basin-title{font-size:.92rem;font-weight:700;color:var(--text)}
.basin-sub{font-size:.72rem;color:var(--muted);line-height:1.4;white-space:normal;word-break:break-word}
.basin-tbl{width:100%;border-collapse:collapse;font-size:.82rem;table-layout:fixed}
.basin-tbl th{padding:8px 10px;text-align:right;font-weight:700;color:#1e293b;border-bottom:2px solid var(--border);font-size:.78rem;white-space:nowrap}
.basin-tbl th:first-child,.basin-tbl td:first-child{text-align:left;width:28%}
.basin-tbl td{padding:8px 10px;border-bottom:1px solid rgba(15,23,42,.06);color:#1e293b;text-align:right;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.82rem}
.basin-tbl tr:last-child td{border-bottom:none}
.basin-tbl tr:hover td{background:rgba(37,99,235,.03)}
.basin-tbl .basin-river{font-weight:600;color:#0f172a}
.basin-tbl .basin-clim{color:var(--muted);font-size:.72rem}
.basin-tbl .basin-sum{font-weight:700;color:var(--text)}
.rain-up{color:#dc2626}.rain-down{color:#16a34a}

.stn-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:0 1px 3px rgba(15,23,42,.04)}
.stn-card-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.stn-card-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.stn-card-ico{width:40px;height:40px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;overflow:hidden}
.stn-card-name{font-size:.88rem;font-weight:700;color:var(--text);flex:1;min-width:0}
.stn-card-date{font-size:.65rem;color:#1e40af;background:#f0f9ff;padding:2px 6px;border-radius:4px;border:1px solid #bae6fd;flex-shrink:0}
.stn-card-z{font-size:.95rem;font-weight:800;color:#0d9488;font-variant-numeric:tabular-nums;flex-shrink:0}
.stn-card-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:8px}
.stn-card-bar-fill{height:100%;border-radius:4px;transition:width 1s cubic-bezier(.22,1,.36,1)}
.stn-card-bar-fill--low{background:linear-gradient(90deg,#38bdf8,#0ea5e9)}
.stn-card-bar-fill--mid{background:linear-gradient(90deg,#22c55e,#16a34a)}
.stn-card-bar-fill--high{background:linear-gradient(90deg,#f59e0b,#d97706)}
.stn-card-bar-fill--full{background:linear-gradient(90deg,#ef4444,#dc2626)}
.stn-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.stn-card-stat{font-size:.72rem;color:var(--muted)}
.stn-card-stat strong{display:block;font-size:.88rem;font-weight:700;color:var(--text);margin-top:2px}

.home-water-cards{display:flex;flex-direction:column;gap:8px}
.home-water-aside .stn-card{padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid rgba(15,23,42,.06);box-shadow:none}
.home-water-aside .stn-card-head{margin-bottom:6px;gap:6px}
.home-water-aside .stn-card-ico{width:34px;height:34px}
.home-water-aside .stn-card-ico img{width:34px;height:34px;border-radius:8px}
.home-water-aside .stn-card-name{font-size:.78rem}
.home-water-aside .stn-card-z{font-size:.92rem}
.home-water-aside .stn-card-bar{height:5px;margin-bottom:6px}
.home-water-aside .stn-card-foot{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;font-size:.64rem;color:#64748b;line-height:1.4}
.home-water-aside .stn-card-foot span{display:flex;align-items:center;gap:2px;min-width:0;white-space:nowrap}
.home-water-aside .stn-card-foot strong{font-weight:600;color:#334155;font-variant-numeric:tabular-nums}

/* 六库发电预测表格 */
.home-power-table{width:100%;border-collapse:collapse;font-size:.78rem;margin-top:8px}
.home-power-table th{padding:8px 6px;text-align:center;font-weight:700;color:#334155;border-bottom:2px solid var(--border);font-size:.72rem;white-space:nowrap;background:#f8fafc}
.home-power-table th:first-child{text-align:left}
.home-power-table td{padding:8px 6px;border-bottom:1px solid rgba(15,23,42,.06);text-align:center;font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.78rem}
.home-power-table td:first-child{text-align:left;font-weight:600;color:#0f172a}
.home-power-table tr:last-child td{border-bottom:none}
.home-power-table tr:hover td{background:rgba(37,99,235,.03)}
.home-power-table .home-stn-total{background:#f8fafc;font-weight:700}
.home-power-table .home-stn-total td{border-top:2px solid var(--border);font-weight:700}
.home-stn-power{color:#2563eb;font-weight:600}

.hist-tbl-wrap{margin-top:0;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.hist-tbl{width:100%;table-layout:fixed;border-collapse:collapse;font-size:.75rem}
.hist-tbl th{padding:6px 4px;text-align:center;font-weight:700;color:#334155;border-bottom:2px solid var(--border);font-size:.7rem;white-space:nowrap;background:#f8fafc}
.hist-tbl th:first-child{text-align:left;width:52px}
.hist-tbl td{padding:6px 4px;border-bottom:1px solid rgba(15,23,42,.06);text-align:center;font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.75rem}
.hist-tbl td:first-child{text-align:left;color:var(--muted);font-weight:500}
.hist-tbl tr:hover td{background:rgba(37,99,235,.03)}
.hist-tbl .yoy-pos{color:#dc2626;font-weight:600}
.hist-tbl .yoy-neg{color:#16a34a;font-weight:600}
.hist-tbl .yoy-zero{color:var(--muted)}
.hist-tbl .no-data{color:#cbd5e1}

.fc-table{width:100%;border-collapse:collapse;font-size:.85rem;table-layout:fixed}
.fc-table th{padding:7px 4px;text-align:center;font-weight:600;color:var(--muted);border-bottom:2px solid var(--border);font-size:.75rem;white-space:nowrap}
.fc-table th:first-child,.fc-table td:first-child{text-align:left;width:12%}
.fc-table td{padding:7px 4px;border-bottom:1px solid rgba(15,23,42,.06);color:#334155;text-align:center;white-space:nowrap}
.fc-table tr:last-child td{border-bottom:none}
.fc-table .fc-pred{color:#2563eb;font-weight:600}
.fc-table .fc-real{color:#0d9488;font-weight:600}
.fc-table tr.fc-total{background:#f8fafc;font-weight:700}
.fc-table tr.fc-total td{border-top:2px solid var(--border)}
.fc-section-title{font-size:.9rem;font-weight:600;margin:18px 0 8px;color:var(--text);display:flex;align-items:center;gap:8px}
.fc-section-title:first-child{margin-top:0}
.fc-unit-note{font-size:.72rem;font-weight:400;color:var(--muted);background:rgba(0,0,0,.04);padding:1px 6px;border-radius:3px}

.beta-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:8px;font-size:.75rem;font-weight:600;border:none;cursor:pointer;text-decoration:none;transition:transform .15s}
.beta-btn-p{background:#2563eb;color:#fff}
.beta-btn-o{background:#fff;color:#334155;border:1px solid #e2e8f0}
.basin-tbl-wrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
.basin-row--jinsha td{background:rgba(243,156,18,.08);font-weight:600}
.basin-row--sanxia td{background:rgba(52,152,219,.08);font-weight:600}
.basin-row--yalong td{background:rgba(8,145,178,.08)}
.basin-row--jialing td{background:rgba(124,58,237,.08)}
.basin-row--minjiang td{background:rgba(29,78,216,.08)}
.basin-row--wujiang td{background:rgba(220,38,38,.08)}
.stn-row--wudongde td{background:rgba(234,179,8,.07)}
.stn-row--baihetan td{background:rgba(168,85,247,.07)}
.stn-row--xiluodu td{background:rgba(14,165,233,.07)}
.stn-row--xiangjiaba td{background:rgba(34,197,94,.07)}
.stn-row--sanxia td{background:rgba(59,130,246,.08);font-weight:600}
.stn-row--gezhouba td{background:rgba(249,115,22,.07)}

/* 水电行业股票卡片 */
.hydro-stock-cards{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.hydro-stock-card{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:8px;background:#f8fafc;border:1px solid rgba(15,23,42,.05)}
.hydro-stock-card:hover{background:rgba(37,99,235,.04)}
.hydro-stock-left{display:flex;flex-direction:column;gap:1px;min-width:0}
.hydro-stock-name{font-size:.78rem;font-weight:600;color:#0f172a;white-space:nowrap}
.hydro-stock-desc{font-size:.64rem;color:#94a3b8;white-space:nowrap}
.hydro-stock-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hydro-stock-price{font-size:.82rem;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.hydro-stock-chg{display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:5px;white-space:nowrap}
.hydro-stock-up{color:#dc2626;background:rgba(220,38,38,.08)}
.hydro-stock-down{color:#16a34a;background:rgba(22,163,74,.08)}
.hydro-stock-flat{color:#64748b;background:rgba(100,116,139,.08)}
.hydro-stock-na{color:#cbd5e1;font-size:.78rem}

/* shimmer - 样式由 index.html 内联 style 管理 */

body.site-layout.site-layout--shell .site-main{overflow-x:clip;max-width:100%}

@media(max-width:960px){
  .home-kpi{grid-template-columns:repeat(2,1fr)}
  .home-layout{grid-template-columns:1fr}
  .home-water-aside .stn-card-z{font-size:.88rem}
}
@media(max-width:768px){
  .home-kpi{grid-template-columns:1fr 1fr}
}


/* ═══════════════════════════════════════════════════════════════
   首页背景
   ═══════════════════════════════════════════════════════════════ */

.hero-particles-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
}

@media (max-width: 768px) {
  .home-hero {
    padding: 16px 14px;
    margin-bottom: 10px;
  }
  
  .home-hero h1 {
    font-size: 1.2rem;
  }
  
  .home-hero p {
    font-size: 0.8rem;
  }
}

@media (max-width: 480px) {
  .home-hero {
    padding: 12px 10px;
    margin-bottom: 8px;
  }
  
  .home-hero h1 {
    font-size: 1.1rem;
  }
  
  .home-hero p {
    font-size: 0.75rem;
  }
}

/* home-hero responsive - 样式由 index.html 内联 style 管理 */
