/* =========================================================
   components.css · 通用组件
   ========================================================= */

/* v4.5-UI3 P0-1 / UI4 P0-2：固定作战条阶段进度（单行紧凑，可横向滚动，固定高度） */
.workbar-progress{
  flex:0 0 24px; max-height:24px;
  display:flex; align-items:center; gap:4px;
  flex-wrap:nowrap; overflow-x:auto; overflow-y:hidden; white-space:nowrap;
  padding:3px 0 0; margin-top:4px;
  border-top:1px dashed var(--bd-soft); font-size:11px; color:var(--tx-3);
  scrollbar-width:thin;
}
.workbar-progress::-webkit-scrollbar{ height:4px; }
.workbar-progress::-webkit-scrollbar-thumb{ background:rgba(62,218,244,.4); border-radius:2px; }
.wp-label{ color:var(--tx-3); font-size:10px; letter-spacing:1px; margin-right:4px; flex-shrink:0; }
.wp-step{ color:var(--tx-4); flex-shrink:0; cursor:pointer; transition:color .15s; }
.wp-step:hover{ color:var(--text-main); }
.wp-step.done{ color:var(--ok); }
.wp-step.active{ color:var(--tech-cyan); font-weight:600; }
.wp-sep{ color:var(--tx-4); flex-shrink:0; }

/* v4.5-1238++ 右上角用户胶囊：左侧加小头像（SVG 人形 + 圆形渐变底）*/
.user-pill{
  height:30px; padding:0 12px 0 4px;
  display:inline-flex; align-items:center; gap:6px;
  border-radius:15px; background:var(--card-bg);
  border:1px solid var(--bd-soft); color:#fff;
  font-size:12px; white-space:nowrap; margin-left:8px;
}
.user-pill .avatar{
  width:22px; height:22px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--tech-cyan), var(--ai-purple));
  color:#fff; flex:0 0 auto; overflow:hidden;
}
.user-pill .avatar svg{ display:block; opacity:.95; }
.user-pill .role{ color:var(--tx-3); font-size:10.5px; }

/* v4.5-UI3 P0-5：顶栏快捷场景按钮（与 .chip 视觉区分） */
.scene-btn{
  height:28px; padding:0 11px; border-radius:14px;
  font-size:11.5px; cursor:pointer; transition:.15s;
  background:var(--card-bg); border:1px solid var(--bd-soft);
  color:var(--tx-2); margin-left:6px;
  display:inline-flex; align-items:center; gap:4px;
}
.scene-btn:hover{ color:#fff; border-color:var(--tech-cyan); }
.scene-btn.warn{ background:rgba(255,138,61,.15); border-color:var(--orange); color:var(--orange); }
.scene-btn.warn:hover{ background:rgba(255,138,61,.25); }

/* v4.5-UI3 P1-5 / UI6-0712 P1-5：表格横向滚动容器（仅 .wide-table 强制最小宽度；表头 sticky）*/
.table-scroll-x{ width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; max-height:520px; overflow-y:auto; }
.table-scroll-x table{ width:100%; }
.table-scroll-x table.wide-table{ min-width:920px; }
.table-scroll-x table thead th{
  position:sticky; top:0; z-index:2;
  background:var(--panel-bg);
  backdrop-filter:blur(4px);
}
.table-scroll-x::-webkit-scrollbar{ height:6px; width:6px; }
.table-scroll-x::-webkit-scrollbar-thumb{ background:rgba(62,218,244,.4); border-radius:3px; }

/* v4.5-UI2 P1-1：对象研判工作区 Tab */
.work-tabs{}
.work-tab{ padding:4px 14px; font-size:12px; color:var(--tx-3); background:transparent; border:none; border-bottom:2px solid transparent; cursor:pointer; transition:.15s; }
.work-tab:hover{ color:var(--tx-1); }
.work-tab.active{ color:var(--tech-cyan); border-bottom-color:var(--tech-cyan); font-weight:600; }

/* v4.5-UI2 P1-5：通用组件类，减少 inline style */
.empty-state{ padding:16px; background:rgba(43,108,255,.04); border:1px dashed var(--bd-soft); border-radius:6px; color:var(--tx-2); font-size:12px; line-height:1.7; text-align:center; }
.empty-state .ttl{ color:var(--tx-1); font-weight:600; }
.empty-state .sub{ color:var(--tx-3); font-size:11px; }
.gov-note{ padding:8px 12px; background:rgba(246,199,97,.08); border-left:2px solid var(--wheat-gold); border-radius:0 3px 3px 0; font-size:11.5px; color:var(--tx-2); line-height:1.7; }
.gov-note.cyan{ background:rgba(62,218,244,.06); border-left-color:var(--tech-cyan); }
.gov-note.purple{ background:rgba(169,116,255,.06); border-left-color:var(--ai-purple); }

/* 面板 */
.panel{
  background:var(--panel-bg);
  border:1px solid var(--bd-soft); border-radius:8px;
  display:flex; flex-direction:column; min-height:0;
  box-shadow:var(--shadow-card);
}
.panel-head{
  height:36px; padding:0 12px; flex:0 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--bd-soft);
}
.panel-head .title{font-size:13px; color:var(--text-main); font-weight:600; letter-spacing:1px;}
.panel-head .title.gold{color:var(--wheat-gold);}
.panel-head .extra{font-size:11px; color:var(--tx-3);}
.panel-body{padding:10px 12px; flex:1; overflow:auto;}

/* 按钮 */
.btn{
  padding:6px 14px; font-size:12px; color:var(--tx-1);
  background:var(--card-bg); border:1px solid var(--bd);
  border-radius:6px; transition:all .2s; cursor:pointer;
}
.btn:hover{border-color:var(--tech-cyan); filter:brightness(1.08);}
.btn.primary{background:linear-gradient(90deg,var(--gov-blue),var(--gov-blue-2)); border-color:transparent; color:#fff;}
.btn.warn{background:linear-gradient(90deg,#d97706,var(--orange)); border-color:transparent; color:#fff;}
.btn.high{background:linear-gradient(90deg,#b91c1c,var(--high)); border-color:transparent; color:#fff;}
.btn.ai{background:linear-gradient(90deg,#8b5cf6,var(--ai-purple)); border-color:transparent; color:#fff;}
.btn.ghost{background:transparent;}
.btn.sm{padding:3px 8px; font-size:11px;}

/* 标签 */
.tag-pill{
  display:inline-block; padding:1px 8px; border-radius:9px;
  font-size:10px; font-weight:600; letter-spacing:.5px;
  background:rgba(43,108,255,.18); color:var(--gov-blue-2);
  border:1px solid rgba(43,108,255,.4);
}
.tag-pill.red{   background:rgba(255,61,79,.18);  color:var(--high);       border-color:rgba(255,61,79,.4);}
.tag-pill.orange{background:rgba(255,138,61,.18); color:var(--orange);     border-color:rgba(255,138,61,.4);}
.tag-pill.gold,
.tag-pill.yellow{background:rgba(246,199,97,.18); color:var(--wheat-gold); border-color:rgba(246,199,97,.4);}
.tag-pill.cyan{  background:rgba(62,218,244,.18); color:var(--tech-cyan);  border-color:rgba(62,218,244,.4);}
.tag-pill.green{ background:rgba(55,201,138,.18); color:var(--ok);         border-color:rgba(55,201,138,.4);}
.tag-pill.purple{background:rgba(169,116,255,.18);color:var(--ai-purple);  border-color:rgba(169,116,255,.4);}
.tag-pill.blue{  background:rgba(43,108,255,.18); color:var(--gov-blue-2); border-color:rgba(43,108,255,.4);}

/* 表格 */
table.tbl{width:100%; border-collapse:collapse; font-size:12px;}
table.tbl thead tr{background:var(--table-head-bg);}
table.tbl th{
  padding:8px 9px; text-align:left;
  font-weight:500; color:var(--tx-3); border-bottom:1px solid var(--bd-soft);
  white-space:nowrap;
}
table.tbl td{
  padding:8px 9px; color:var(--tx-1); border-bottom:1px solid var(--table-border);
}
table.tbl tr:hover{background:var(--table-row-hover);}

/* KPI 卡 */
.kpi-row{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:12px;}
.kpi-card{
  padding:10px 12px; background:var(--card-bg);
  border:1px solid var(--bd-soft); border-radius:8px;
  cursor:pointer; transition:transform .15s ease, box-shadow .15s ease;
}
.kpi-card:hover{transform:translateY(-2px); box-shadow:0 6px 14px rgba(0,0,0,.28);}
.kpi-card .k-label{font-size:11px; color:var(--tx-3); letter-spacing:1px;}
.kpi-card .k-value{font-size:22px; color:var(--text-main); font-weight:700; margin-top:4px; font-family:'DIN Alternate',sans-serif;}
.kpi-card .k-value .unit{font-size:11px; color:var(--tx-3); margin-left:3px; font-weight:400;}
.kpi-card .k-delta{font-size:10px; margin-top:2px; color:var(--tx-3);}
.kpi-card.warn{border-color:rgba(255,138,61,.40);}
.kpi-card.warn .k-value{color:var(--orange);}
.kpi-card.danger{border-color:rgba(255,61,79,.40);}
.kpi-card.danger .k-value{color:var(--high);}
.kpi-card.gold{border-color:rgba(246,199,97,.40);}
.kpi-card.gold .k-value{color:var(--wheat-gold);}
.kpi-card.green{border-color:rgba(55,201,138,.40);}
.kpi-card.green .k-value{color:var(--ok);}
.kpi-card.purple{border-color:rgba(169,116,255,.40);}
.kpi-card.purple .k-value{color:var(--ai-purple);}

/* 模态 */
.modal-mask{
  position:fixed; inset:0; background:var(--overlay-bg); backdrop-filter:blur(2px);
  display:none; align-items:center; justify-content:center; z-index:99999;
}
.modal-mask.show{display:flex;}
.modal-box{
  width:560px; max-width:90vw; max-height:80vh;
  background:var(--bg-page); border:1px solid var(--bd-strong);
  border-radius:10px; overflow:hidden; display:flex; flex-direction:column;
}
.modal-head{
  height:42px; padding:0 16px; flex:0 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--bd-soft);
  font-size:14px; color:var(--text-main); font-weight:600;
}
.modal-body{padding:14px 16px; overflow:auto; flex:1; font-size:13px; color:var(--tx-1); line-height:1.85;}
.modal-foot{padding:10px 16px; border-top:1px solid var(--bd-soft); text-align:right;}
.modal-foot .btn{margin-left:8px;}

/* 下拉菜单（取代 chip） */
.dropdown{position:relative; display:inline-block;}
.dropdown-menu{
  display:none; position:absolute; top:calc(100% + 4px); left:0;
  min-width:150px; max-height:340px; overflow:auto;
  background:var(--bg-page); border:1px solid var(--bd); border-radius:6px;
  box-shadow:0 8px 18px rgba(0,0,0,.45); z-index:9999; padding:4px 0;
}
.dropdown.open .dropdown-menu{display:block;}
.dropdown-opt{
  padding:6px 12px; font-size:12px; color:var(--tx-2);
  cursor:pointer; letter-spacing:.5px;
}
.dropdown-opt:hover{background:rgba(43,108,255,.15); color:var(--text-main);}
.dropdown-opt.demo{color:var(--ok); font-weight:600;}
.dropdown-opt.demo::before{content:'🟢 '; margin-right:2px;}

/* 风险卡（首页左队列） */
.risk-card{
  position:relative;            /* v4.5-UI3+ P1-4：容纳右下"详情"按钮 */
  padding:8px 10px; background:var(--card-bg);
  border:1px solid var(--bd-soft); border-radius:6px;
  border-left:3px solid var(--tech-cyan);
  cursor:pointer; transition:all .15s;
}
/* v4.5-UI3+ P1-4：当前主线卡视觉强化（不再使用 inline outline）*/
.risk-card.is-active{
  outline:2px solid var(--tech-cyan);
  background:linear-gradient(135deg,rgba(62,218,244,.06),var(--card-bg));
  cursor:default;
}
.risk-card:hover{transform:translateX(2px); border-left-color:var(--tech-cyan); background:rgba(43,108,255,.08);}
.risk-card .head{display:flex; justify-content:space-between; align-items:center;}
.risk-card .id{font-family:'DIN Alternate',monospace; font-size:11px; color:var(--tech-cyan);}
.risk-card .nm{font-size:12.5px; color:var(--text-main); margin-top:3px; font-weight:600;}
.risk-card .meta{font-size:11px; color:var(--tx-3); margin-top:2px; display:flex; justify-content:space-between;}
.risk-card .next-act{font-size:10.5px; color:var(--tx-2); margin-top:2px;}
.risk-card.lvl-red{   border-left-color:var(--high);}
.risk-card.lvl-orange{border-left-color:var(--orange);}
.risk-card.lvl-yellow{border-left-color:var(--wheat-gold);}
.risk-card.lvl-blue{  border-left-color:var(--blue-lvl);}

/* 风险矩阵单元 */
.matrix-cell{
  padding:6px 4px; text-align:center; font-size:11px;
  border:1px solid var(--bd-soft); cursor:pointer;
  transition:all .15s;
}
.matrix-cell:hover{background:rgba(43,108,255,.12);}
.matrix-cell.lv-red{   background:rgba(255,61,79,.15);   color:var(--high);}
.matrix-cell.lv-orange{background:rgba(255,138,61,.15);  color:var(--orange);}
.matrix-cell.lv-yellow{background:rgba(246,199,97,.15);  color:var(--wheat-gold);}
.matrix-cell.lv-blue{  background:rgba(43,108,255,.10);  color:var(--blue-lvl);}
.matrix-cell.empty{color:var(--tx-4); cursor:default;}

/* 生育期带 */
.stage-bar-row{display:grid; grid-template-columns:80px 1fr 120px; gap:10px; align-items:center; padding:6px 4px; border-bottom:1px solid var(--bd-soft);}
.stage-bar-row .crop-name{display:flex; align-items:center; gap:5px; font-size:12px; color:var(--text-main);}
.stage-bar-row .progress{position:relative; height:14px; background:rgba(43,108,255,.10); border-radius:7px; overflow:hidden;}
.stage-bar-row .progress .fill{position:absolute; left:0; top:0; bottom:0; background:linear-gradient(90deg,var(--agri-green-2),var(--agri-green));}
.stage-bar-row .progress .cur{
  position:absolute; top:-2px; bottom:-2px; width:2px;
  background:var(--tech-cyan); box-shadow:0 0 6px var(--tech-cyan);
}
.stage-bar-row .stage-name{font-size:11px; color:var(--tx-2); text-align:right;}

/* ============ R3 阶段 1.5 新增样式 ============ */
/* sidenav 分组标签（verify 核查阶段 / 复产阶段） */
.sidenav-group-label{
  padding:8px 10px 4px;
  font-size:10px; color:var(--tx-4); letter-spacing:1.5px;
  border-top:1px dashed var(--bd-soft); margin-top:6px;
}
.sidenav-group-label:first-of-type{ border-top:none; margin-top:0; }

/* sidenav-item 内嵌的 AI / badge */
.sidenav-item{justify-content:flex-start;}
.sidenav-item .badge,
.sidenav-item .nb-ai{margin-left:auto;}

/* v4.5-UI6-0712 P0-2：会商与报告侧栏色条（替代 emoji） */
.nb-tab{
  display:inline-block; width:3px; height:12px; margin-right:8px;
  background:var(--gov-blue-2); border-radius:1px; vertical-align:middle;
  flex-shrink:0;
}
.sidenav-item.active .nb-tab{ background:var(--wheat-gold); }

/* AI 标签（紫色徽章） */
.nb-ai{
  display:inline-block; padding:0 5px;
  background:rgba(169,116,255,.18); color:var(--ai-purple);
  border:1px solid rgba(169,116,255,.4); border-radius:3px;
  font-size:9px; letter-spacing:.5px; font-weight:600;
}

/* 地图标题快捷入口 mini-link */
.mini-link{
  padding:3px 10px; font-size:11px;
  background:var(--card-bg); border:1px solid var(--bd-soft);
  border-radius:10px; color:var(--tx-2); cursor:pointer;
  transition:all .2s;
}
.mini-link:hover{ filter:brightness(1.15); }

/* 地图图层切换按钮 */
.map-toolbox{
  display:flex; flex-direction:column; gap:4px;
  background:var(--map-overlay-bg); border:1px solid var(--map-overlay-border);
  border-radius:6px; padding:6px;
}
.layer-btn{
  font-size:11px; padding:4px 10px;
  background:transparent; color:var(--tx-3);
  border:1px solid var(--bd-soft); border-radius:4px;
  cursor:pointer; text-align:left; transition:all .15s;
}
.layer-btn:hover{ color:#fff; border-color:var(--tech-cyan); }
.layer-btn.on{
  color:var(--tech-cyan); border-color:var(--tech-cyan);
  background:rgba(62,218,244,.08);
}

/* 公文样式（领导简报/调度令/灾情快报 等使用） */
.gov-doc{
  background:#fff; color:#111; padding:24px 32px;
  border-radius:6px; line-height:2;
  font-family:"SimSun","STSong",serif;
}
.gov-doc .doc-title{
  text-align:center; font-size:22px; font-weight:700;
  color:#b91c1c; letter-spacing:6px;
}
.gov-doc .doc-no{
  text-align:center; font-size:13px; color:#555; margin-top:6px;
}
.gov-doc .doc-meta{
  text-align:right; font-size:12px; color:#555; margin-top:10px;
}
.gov-doc h3{
  border-left:4px solid #b91c1c; padding-left:8px;
  margin-top:16px; font-size:14px; color:#333;
}
.gov-doc .doc-sign{
  text-align:right; margin-top:24px; font-size:12px; color:#333;
}
.gov-doc .demo-tip{
  margin-top:14px; font-size:11px; color:#888;
  border-top:1px dashed #ddd; padding-top:8px;
}

/* mini-link 语义色基底（两皮肤通用，保证经典色态保留金/橙标识；浅色态由下方 LIGHT FIX 细化） */
.mini-link.gold{ color:var(--wheat-gold); border-color:rgba(246,199,97,.45); }
.mini-link.warn{ color:var(--orange); border-color:rgba(255,138,61,.45); }

/* =========================================================
   LIGHT FIX · 省厅端浅色态组件对齐市县端业务态（v5 像素级修正）
   ========================================================= */
:root[data-theme="light"] .panel{
  background:#fff;
  border-color:#dde6f2;
  box-shadow:0 1px 4px rgba(31,55,98,.06);
}
:root[data-theme="light"] .panel-head{
  min-height:40px;
  height:auto;
  padding:10px 14px;
  border-bottom-color:#dde6f2;
}
:root[data-theme="light"] .panel-head .title{
  font-size:14px;
  font-weight:600;
  color:var(--text-main);
}
:root[data-theme="light"] .panel-head .extra{ color:var(--text-mute); }

:root[data-theme="light"] .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  height:30px;
  padding:0 14px;
  background:linear-gradient(180deg,var(--gov-blue-2),var(--gov-blue));
  border:1px solid var(--gov-blue);
  border-radius:6px;
  color:#fff;
  white-space:nowrap;
  box-shadow:none;
}
:root[data-theme="light"] .btn:hover{
  filter:none;
  box-shadow:0 0 0 2px rgba(36,87,214,.10);
}
:root[data-theme="light"] .btn.sm{
  height:24px;
  padding:0 10px;
  font-size:11px;
}
:root[data-theme="light"] .btn.ghost{
  background:#fff;
  border:1px solid #d8e2f0;
  color:var(--text-main);
}
:root[data-theme="light"] .btn.ghost:hover{
  border-color:var(--gov-blue);
  color:var(--gov-blue);
}
:root[data-theme="light"] .btn.warn{
  background:linear-gradient(180deg,#ffb547,var(--orange));
  border-color:rgba(255,138,61,.60);
  color:#21130a;
}
:root[data-theme="light"] .btn.high{
  background:linear-gradient(180deg,#ff6075,var(--high));
  border-color:rgba(255,61,79,.60);
  color:#fff;
}
:root[data-theme="light"] .btn.ai{
  background:linear-gradient(180deg,#b388ff,var(--ai-purple));
  border-color:rgba(132,89,230,.55);
  color:#fff;
}

:root[data-theme="light"] table.tbl .btn.sm{
  background:rgba(36,87,214,.06);
  border-color:rgba(36,87,214,.30);
  color:var(--gov-blue);
  box-shadow:none;
}
:root[data-theme="light"] table.tbl .btn.sm:hover{
  background:rgba(36,87,214,.14);
  color:var(--gov-blue);
  box-shadow:none;
}
:root[data-theme="light"] table.tbl .btn.ai.sm{
  background:rgba(132,89,230,.08);
  border-color:rgba(132,89,230,.28);
  color:var(--ai-purple);
}
:root[data-theme="light"] table.tbl .btn.warn.sm{
  background:rgba(255,138,61,.08);
  border-color:rgba(255,138,61,.35);
  color:var(--orange);
}
:root[data-theme="light"] table.tbl .btn.high.sm{
  background:rgba(255,61,79,.08);
  border-color:rgba(255,61,79,.35);
  color:var(--high);
}

:root[data-theme="light"] .mini-link{
  padding:2px 8px;
  font-size:11px;
  border-radius:10px;
  color:var(--gov-blue);
  border-color:rgba(36,87,214,.30);
  background:rgba(36,87,214,.06);
}
:root[data-theme="light"] .mini-link:hover{
  background:rgba(36,87,214,.14);
  color:var(--gov-blue);
  filter:none;
}
:root[data-theme="light"] .mini-link.gold{
  color:var(--wheat-gold-2);
  border-color:rgba(212,168,67,.32);
  background:rgba(246,199,97,.12);
}
:root[data-theme="light"] .mini-link.warn{
  color:var(--orange);
  border-color:rgba(255,138,61,.32);
  background:rgba(255,138,61,.10);
}

:root[data-theme="light"] table.tbl thead tr{ background:#f1f5fb; }
:root[data-theme="light"] table.tbl th{
  padding:8px 10px;
  color:var(--text-soft);
  font-weight:600;
  font-size:11.5px;
  border-bottom:1px solid #dde6f2;
}
:root[data-theme="light"] table.tbl td{
  padding:8px 10px;
  border-bottom:1px solid #e3eaf3;
}
:root[data-theme="light"] table.tbl tr:hover td{ background:#eef5ff; }

:root[data-theme="light"] .tag-pill{
  background:rgba(36,87,214,.10);
  color:var(--gov-blue);
  border-color:transparent;
}
:root[data-theme="light"] .tag-pill.gold,
:root[data-theme="light"] .tag-pill.yellow{
  background:rgba(246,199,97,.16);
  color:var(--wheat-gold-2);
  border-color:transparent;
}
:root[data-theme="light"] .tag-pill.cyan{
  background:rgba(31,166,216,.10);
  color:var(--tech-cyan);
  border-color:transparent;
}
:root[data-theme="light"] .tag-pill.purple{
  background:rgba(132,89,230,.10);
  color:var(--ai-purple);
  border-color:transparent;
}
:root[data-theme="light"] .tag-pill.green{
  background:rgba(55,201,138,.12);
  color:#16a34a;
  border-color:transparent;
}
:root[data-theme="light"] .tag-pill.red{
  background:rgba(255,61,79,.10);
  color:var(--high);
  border-color:transparent;
}

:root[data-theme="light"] .dropdown-menu{
  background:#fff;
  border-color:#d8e2f0;
  box-shadow:0 6px 16px rgba(31,55,98,.12);
}
:root[data-theme="light"] .dropdown-opt:hover{
  background:#eef5ff;
  color:var(--gov-blue);
}

:root[data-theme="light"] .map-toolbox{
  background:rgba(255,255,255,.92);
  border-color:#dde6f2;
}
:root[data-theme="light"] .layer-btn{
  background:#fff;
  border-color:#d8e2f0;
  color:var(--text-soft);
}
:root[data-theme="light"] .layer-btn:hover{
  background:#eef5ff;
  border-color:var(--gov-blue);
  color:var(--gov-blue);
}
:root[data-theme="light"] .layer-btn.on{
  background:rgba(36,87,214,.06);
  border-color:rgba(36,87,214,.35);
  color:var(--gov-blue);
}

/* 地图 tooltip：token 化（§5），经典态深底浅字 / 浅色态白底深字，随主题切换 */
.map-tooltip{
  padding:6px 10px;
  font-size:12px;
  color:var(--map-tooltip-text);
  background:var(--map-tooltip-bg);
  border:1px solid var(--map-tooltip-border);
  border-radius:6px;
  box-shadow:var(--shadow-soft);
  max-width:260px; line-height:1.6;
}

/* =========================================================
   LIGHT FINAL FIX · §6 工作区 tab 政务蓝 + §7 行内提示/空态/进度收敛
   ========================================================= */
:root[data-theme="light"] .work-tab{ color:var(--text-mute); }
:root[data-theme="light"] .work-tab:hover{ color:var(--gov-blue); }
:root[data-theme="light"] .work-tab.active{
  color:var(--gov-blue);
  border-bottom-color:var(--gov-blue);
  font-weight:600;
}

:root[data-theme="light"] .empty-state{
  background:#f8fbff;
  border:1px dashed #c7d5e8;
  color:var(--text-soft);
}
:root[data-theme="light"] .gov-note{
  background:#fff8e8;
  border-left-color:var(--wheat-gold-2);
  color:var(--text-soft);
}
:root[data-theme="light"] .gov-note.cyan{
  background:#eef7ff;
  border-left-color:var(--gov-blue);
}
:root[data-theme="light"] .gov-note.purple{
  background:#f4f0ff;
  border-left-color:var(--ai-purple);
}
:root[data-theme="light"] .nb-ai{
  background:rgba(132,89,230,.08);
  color:var(--ai-purple);
  border-color:rgba(132,89,230,.22);
}
:root[data-theme="light"] .workbar-progress{ border-top-color:#e3eaf3; }
:root[data-theme="light"] .wp-label,
:root[data-theme="light"] .wp-step,
:root[data-theme="light"] .wp-sep{ color:var(--text-mute); }
:root[data-theme="light"] .wp-step.done{ color:#16a34a; }
:root[data-theme="light"] .wp-step.active{ color:var(--gov-blue); }
