/* 华利外联自动化 V1+ · 主样式扩展（design_tokens.css 之上）*/

/* === V1+ 扩展色：状态背景三档 === */
:root{
  --c-mid2:#0C447C;
  --c-mid3:var(--color-info);
  --c-blue4:#378ADD;

  --bg-urgent:#FEF2F2;
  --bg-warn:var(--color-warning-bg);
  --bg-ok:var(--color-success-bg);
  --bg-orange:var(--color-warning-bg);

  --c-orange:var(--color-warning);

  --space-card:16px;
  --space-section:24px;
}

/* === 风险温度计 banner === */
.risk-banner{
  display:flex;align-items:center;gap:18px;padding:16px 20px;
  border-radius:var(--r);border:.5px solid var(--c-border);
  margin-bottom:var(--space-section);position:relative;overflow:hidden;
}
.risk-banner.green {background:var(--bg-ok);    border-color:rgba(15,110,86,.25)}
.risk-banner.yellow{background:var(--bg-warn);  border-color:rgba(154,103,0,.25)}
.risk-banner.orange{background:var(--bg-orange);border-color:rgba(217,119,6,.30)}
.risk-banner.red   {background:var(--bg-urgent);border-color:rgba(163,45,45,.30)}

.risk-banner .score-block{
  width:120px;flex:none;text-align:center;
  background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  padding:12px 0;
}
.risk-banner.green   .score-block .num{color:var(--c-normal)}
.risk-banner.yellow  .score-block .num{color:var(--c-mid-warn)}
.risk-banner.orange  .score-block .num{color:var(--c-orange)}
.risk-banner.red     .score-block .num{color:var(--c-urgent)}
.risk-banner .score-block .num{font-size:34px;font-weight:500;line-height:1}
.risk-banner .score-block .lab{font-size:11px;color:var(--c-text-mute);margin-top:6px;letter-spacing:.5px}

.risk-banner .body{flex:1;min-width:0}
.risk-banner .body h2{font-size:18px;font-weight:500;margin-bottom:4px}
.risk-banner .body .lvl{font-size:13px;color:var(--c-text-sub)}
.risk-banner .body .bd-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.risk-banner .body .bd-list .pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 8px;border-radius:12px;font-size:11px;
  background:var(--c-card);border:.5px solid var(--c-border);color:var(--c-text-sub);
}
.risk-banner .body .bd-list .pill b{color:var(--c-text);font-weight:500}

.risk-banner .actions{flex:none;display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.btn-primary{
  display:inline-block;padding:7px 14px;border-radius:6px;
  background:var(--c-deep);color:#fff;font-size:13px;border:none;cursor:pointer;
}
.btn-primary:hover{background:var(--c-mid);text-decoration:none;color:#fff}
.btn-ghost{
  display:inline-block;padding:7px 14px;border-radius:6px;
  background:var(--c-card);color:var(--c-text);border:.5px solid var(--c-border);font-size:13px;cursor:pointer;
}
.btn-ghost:hover{border-color:var(--c-mid);color:var(--c-mid);text-decoration:none}

/* === 风险趋势图 SVG === */
.risk-trend{height:120px;width:100%;display:block}
.risk-trend .grid line{stroke:var(--c-border);stroke-dasharray:2 4;stroke-width:.5}
.risk-trend .band-green {fill:var(--bg-ok);}
.risk-trend .band-yellow{fill:var(--bg-warn);}
.risk-trend .band-orange{fill:var(--bg-orange);}
.risk-trend .band-red   {fill:var(--bg-urgent);}
.risk-trend .line{fill:none;stroke:var(--c-deep);stroke-width:1.5;stroke-linejoin:round}
.risk-trend .dot{fill:#fff;stroke:var(--c-deep);stroke-width:1.2}

/* === 增强 KPI: 新加 5 列布局，公司直接列 === */
.kpi-row.kpi-5{grid-template-columns:repeat(5,1fr)}
.kpi.direct{border-color:var(--c-border);background:linear-gradient(135deg,var(--c-card),var(--color-info-bg))}
.kpi.direct .lab{color:var(--c-mid)}

/* === 公司直接相关置顶区 === */
.direct-pin{
  background:linear-gradient(135deg,var(--c-card),var(--color-info-bg));
  border:.5px solid var(--c-border);border-radius:var(--r);
  padding:14px 16px;margin-bottom:var(--space-section);
}
.direct-pin .hd{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.direct-pin .hd h3{font-size:16px;color:var(--c-deep);font-weight:500}
.direct-pin .hd .count{font-size:12px;color:var(--c-text-sub);margin-left:auto}
.direct-pin .arts .art{background:var(--c-card)}

/* === 印尼语段落区分（SOP 详情）=== */
.sop-body p[data-lang="id"],
.sop-body li[data-lang="id"]{
  background:var(--v46-bg-subtle);border-left:3px solid var(--c-mid);
  padding:6px 10px;margin-left:0;border-radius:0 4px 4px 0;
}
.sop-body[data-show="zh"] p[data-lang="id"],
.sop-body[data-show="zh"] li[data-lang="id"]{display:none}
.sop-body[data-show="id"] p[data-lang="zh"],
.sop-body[data-show="id"] li[data-lang="zh"]{display:none}

/* === SOP 卡片：双语标题 + 简介 === */
.sop-card .ttl-id{font-size:12px;color:var(--c-text-sub);margin-top:2px;font-weight:400}
.sop-card .brief{font-size:12px;color:var(--c-text-sub);line-height:1.55;margin-top:6px}

/* === 设置 tab === */
.settings-grid{display:grid;grid-template-columns:200px 1fr;gap:18px;align-items:start}
.set-tabs{display:flex;flex-direction:column;background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);overflow:hidden;position:sticky;top:76px}
.set-tabs a{display:block;padding:10px 14px;font-size:13px;color:var(--c-text-sub);border-left:3px solid transparent}
.set-tabs a:hover{background:var(--c-pale);color:var(--c-mid);text-decoration:none}
.set-tabs a.on{background:var(--c-pale);color:var(--c-deep);border-left-color:var(--c-deep);font-weight:500}
.set-panel{background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);padding:18px 20px}
.set-panel h3{font-size:16px;font-weight:500;margin-bottom:12px;color:var(--c-deep)}
.set-panel .row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:.5px dashed var(--c-border);font-size:13px}
.set-panel .row:last-child{border-bottom:none}
.set-panel .row .k{color:var(--c-text-sub)}
.set-panel .row .v{color:var(--c-text);font-variant-numeric:tabular-nums}

/* === 审计日志表 === */
.audit-table{width:100%;border-collapse:collapse;font-size:12px}
.audit-table th,.audit-table td{
  text-align:left;padding:6px 8px;border-bottom:.5px solid var(--c-border);
  vertical-align:top;
}
.audit-table th{background:var(--c-pale);color:var(--c-deep);font-weight:500;position:sticky;top:0}
.audit-table td.col-action{font-weight:500}
.audit-table td.col-ts{color:var(--c-text-mute);white-space:nowrap}
.audit-table td.col-diff{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--c-text-sub);max-width:380px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* === 输入控件 === */
input.input,select.input,textarea.input{
  padding:6px 9px;border:.5px solid var(--c-border);border-radius:6px;font-size:13px;
  background:var(--c-card);font-family:inherit;color:var(--c-text);outline:none;
}
input.input:focus,select.input:focus{border-color:var(--c-mid)}
input[type="number"].input{width:80px}

/* === 顶部 banner 增强 === */
.banner .meta .wita{font-variant-numeric:tabular-nums;color:var(--c-text-sub)}
.banner .lang-toggle{margin-left:6px}
.banner .avatar{
  width:28px;height:28px;border-radius:50%;
  background:var(--c-deep);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;letter-spacing:1px;font-weight:500;cursor:pointer;
}
.banner .avatar.avatar-admin{background:var(--c-deep);box-shadow:0 0 0 2px rgba(4,44,83,.15)}
.banner .avatar.avatar-editor{background:var(--c-mid);box-shadow:0 0 0 2px rgba(24,95,165,.15)}
.banner .avatar.avatar-viewer{background:var(--v46-text-tertiary)}

.user-menu{position:relative;cursor:pointer}
.user-menu .user-menu-pop{
  display:none;position:absolute;top:38px;right:0;min-width:220px;
  background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  box-shadow:0 8px 24px rgba(15,23,42,.12);z-index:80;overflow:hidden;
}
.user-menu.open .user-menu-pop{display:block}
.user-menu-pop .user-menu-h{padding:12px 14px;background:var(--c-pale);
  border-bottom:.5px solid var(--c-border)}
.user-menu-pop .user-menu-h .u-name{font-size:13px;font-weight:500;color:var(--c-deep)}
.user-menu-pop .user-menu-h .u-meta{font-size:11px;color:var(--c-text-sub);margin-top:3px}
.user-menu-pop a, .user-menu-pop button{
  display:block;width:100%;padding:9px 14px;font-size:13px;color:var(--c-text);
  background:var(--c-card);border:none;text-align:left;cursor:pointer;text-decoration:none;
}
.user-menu-pop a:hover, .user-menu-pop button:hover{background:var(--c-pale);color:var(--c-mid)}

/* 角色徽章 */
.badge.role-admin{background:rgba(4,44,83,.10);color:var(--c-deep);border-color:rgba(4,44,83,.25)}
.badge.role-editor{background:var(--c-pale);color:var(--c-mid);border-color:rgba(24,95,165,.25)}
.badge.role-viewer{background:var(--v46-bg-subtle);color:var(--c-text-sub);border-color:var(--c-border)}

/* === viewer 角色：隐藏所有写操作 UI === */
body.role-viewer a.btn-primary,
body.role-viewer button.btn-primary,
body.role-viewer button[type="submit"],
body.role-viewer .stt-btn,
body.role-viewer .kb-card[draggable]{ display:none !important }
body.role-viewer form[method="get"] button[type="submit"]{ display:inline-flex !important }
body.role-viewer .user-menu-pop button{ display:block !important }
body.role-viewer #prog-slider{ display:inline-block !important }
body.role-viewer::before{
  content:"🔒 你以「只读」角色登录 · 仅能浏览，无法编辑";
  display:block;background:var(--c-mid-warn);color:#fff;
  text-align:center;padding:6px;font-size:12px;font-weight:500;
  position:fixed;top:0;left:0;right:0;z-index:200;letter-spacing:.5px;
}
body.role-viewer{padding-top:30px}

/* === 占位页 === */
.placeholder.with-back{padding:48px 24px}
.placeholder .back-btn{
  display:inline-block;margin-top:18px;padding:7px 14px;
  background:var(--c-deep);color:#fff;border-radius:6px;font-size:13px;
}
.placeholder .back-btn:hover{background:var(--c-mid);text-decoration:none;color:#fff}

/* === 总览 grid === */
.overview-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}
.overview-grid .col{display:flex;flex-direction:column;gap:16px}

/* === 移动版 sidebar 隐藏，底部 tab bar === */
.mobile-tabbar{display:none}

/* === 人物 tab === */
.people-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:12px;
}
.person-card{
  display:flex;gap:12px;background:var(--c-card);border:.5px solid var(--c-border);
  border-radius:var(--r);padding:14px;transition:border-color .15s, box-shadow .15s;
}
.person-card:hover{border-color:var(--c-mid);box-shadow:0 2px 8px rgba(15,23,42,.06);text-decoration:none}
.person-card .ava{
  width:44px;height:44px;flex:none;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;
}
.person-card .bd{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.person-card .ttl{font-size:14px;font-weight:500;color:var(--c-text)}
.person-card .sub-id{font-size:12px;color:var(--c-text-sub);font-style:italic}
.person-card .role{font-size:11px;color:var(--c-text-mute);line-height:1.5}
.person-card .meta-row{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}
.person-card .stars{font-size:11px;color:#F59E0B;letter-spacing:1px}
.person-card .footrow{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px}
.person-card .footrow .overdue{color:var(--c-urgent);font-weight:500}
.person-card .footrow .fresh{color:var(--c-text-sub)}

/* hero */
.person-hero{
  display:flex;gap:16px;align-items:flex-start;
  background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  padding:18px 20px;margin-bottom:16px;
}
.person-hero .ava-lg{
  width:64px;height:64px;flex:none;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:26px;font-weight:500;
}
.person-hero .bd{flex:1;min-width:0}
.person-hero h1{font-size:20px;font-weight:500;margin:0 0 2px;color:var(--c-deep)}
.person-hero .sub-id{font-size:13px;color:var(--c-text-sub);font-style:italic;margin-bottom:4px}
.person-hero .title-line{font-size:13px;color:var(--c-text);margin-bottom:8px}
.person-hero .meta-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.person-hero .actions{display:flex;flex-direction:column;gap:6px;flex:none;min-width:140px}

.section-tabs{display:flex;flex-direction:row;flex-wrap:wrap;background:var(--c-card);
  border:.5px solid var(--c-border);border-radius:var(--r);padding:0;overflow:hidden}
.section-tabs a{flex:1;min-width:120px;text-align:center;padding:10px 8px;
  border-left:none;border-bottom:3px solid transparent;font-size:13px;color:var(--c-text-sub)}
.section-tabs a.on{border-bottom-color:var(--c-deep);background:var(--c-pale);color:var(--c-deep);font-weight:500}
.section-tabs a:hover{background:var(--c-pale);color:var(--c-mid);text-decoration:none}

/* info table */
.info-table{width:100%;font-size:13px;border-collapse:collapse}
.info-table td{padding:6px 8px;vertical-align:top;border-bottom:.5px dashed var(--c-border)}
.info-table td.k{width:140px;color:var(--c-text-sub);white-space:nowrap}
.info-table td.v{color:var(--c-text)}
.info-table td.v .badge{margin-right:4px}

/* md content */
.md-body{font-size:13px;line-height:1.85;color:var(--c-text);white-space:pre-wrap;word-break:break-word}
.md-body strong{font-weight:500;color:var(--c-deep)}

/* 关系侧栏 */
.rel-line{display:flex;align-items:center;gap:10px;padding:8px 6px;
  border-radius:6px;font-size:13px;color:var(--c-text)}
.rel-line:hover{background:var(--c-pale);text-decoration:none}
.rel-line .ava-sm{width:28px;height:28px;border-radius:50%;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;flex:none}
.rel-line .rl-name{font-weight:500}
.rel-line .rl-sub{font-size:11px;color:var(--c-text-mute)}

/* edit form */
.edit-form .row{display:flex;align-items:flex-start;gap:14px;padding:8px 0;
  border-bottom:.5px dashed var(--c-border)}
.edit-form .row label{width:160px;font-size:13px;color:var(--c-text-sub);padding-top:8px;flex:none}
.edit-form .row .input,.edit-form .row textarea{flex:1;width:100%}

/* mermaid container */
pre.mermaid{font-family:inherit;background:transparent;padding:8px 0;text-align:center}

/* 议题 tab */
.issue-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));
  gap:12px;
}
.issue-card{display:flex;flex-direction:column;gap:6px;
  background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  padding:14px 16px;transition:border-color .15s,box-shadow .15s;
}
.issue-card:hover{border-color:var(--c-mid);box-shadow:0 2px 8px rgba(15,23,42,.06);text-decoration:none}
.issue-card .ttl{font-size:15px;font-weight:500;color:var(--c-text)}
.issue-card .sub-id{font-size:12px;color:var(--c-text-sub);font-style:italic}
.issue-card .row1{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;align-items:center}
.issue-card .stats{font-size:12px;color:var(--c-text-sub);margin-top:6px}
.issue-card .footrow{display:flex;justify-content:space-between;font-size:11px;color:var(--c-text-mute);margin-top:6px}

.pbc-A{background:var(--color-danger-bg);color:var(--color-danger);border-color:#FCA5A5}
.pbc-B{background:var(--color-warning-bg);color:#92400E;border-color:#FCD34D}
.pbc-C{background:#DBEAFE;color:#1E40AF;border-color:#93C5FD}

/* 时间线 */
.timeline{position:relative;padding-left:36px;border-left:2px solid var(--c-border);margin-top:8px}
.tl-item{position:relative;padding:8px 0 14px;font-size:13px}
.tl-item::before{
  content:"";position:absolute;left:-44px;top:14px;width:10px;height:10px;border-radius:50%;
  background:var(--c-card);border:2px solid var(--c-mid);
}
.tl-item.action-our::before{border-color:var(--c-deep);background:var(--c-deep)}
.tl-item.action-their::before{border-color:var(--c-orange);background:var(--c-orange)}
.tl-item.media::before{border-color:var(--c-mid);background:var(--c-card)}
.tl-item.policy::before{border-color:var(--c-normal);background:var(--c-normal)}
.tl-item.src-report::before{border-color:#7C3AED;background:#7C3AED}
.tl-item.src-task::before{border-color:#EA580C;background:#EA580C}
.tl-item.src-template::before{border-color:var(--v46-text-tertiary);background:var(--c-card);border-style:dashed}

/* === EV 事件记录 === */
.ev-subnav{display:inline-flex;background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);overflow:hidden}
.ev-subnav a{padding:8px 16px;font-size:13px;color:var(--c-text-sub);background:var(--c-card);border-right:.5px solid var(--c-border);text-decoration:none}
.ev-subnav a:last-child{border-right:none}
.ev-subnav a.on{background:var(--c-deep);color:#fff;font-weight:500}
.ev-subnav a:hover:not(.on){background:var(--c-pale);color:var(--c-mid);text-decoration:none}

.incident-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(360px, 1fr));gap:12px}
.incident-card{display:block;background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  padding:14px 16px;text-decoration:none;color:var(--c-text);transition:.15s;border-left-width:4px}
.incident-card.sev-I{border-left-color:var(--color-danger)}
.incident-card.sev-II{border-left-color:var(--color-warning)}
.incident-card.sev-III{border-left-color:var(--color-success)}
.incident-card:hover{box-shadow:0 2px 8px rgba(15,23,42,.06);text-decoration:none}
.incident-card .row1{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.incident-card .ttl{font-size:14px;font-weight:500;color:var(--c-text);line-height:1.4}
.incident-card .meta{font-size:11px;color:var(--c-text-mute);margin-top:4px}
.incident-card .prog-row{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:11px}
.incident-card .prog-row .bar{flex:1;height:5px;background:var(--v46-bg-subtle);border-radius:3px;overflow:hidden}
.incident-card .prog-row .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--c-mid),var(--c-deep))}
.sev-block{font-size:10px;font-weight:500;padding:2px 8px;border-radius:4px;border:.5px solid;letter-spacing:.5px}

.incident-hero{display:flex;gap:18px;border:.5px solid var(--c-border);border-left-width:5px;
  border-radius:var(--r);padding:16px 20px;margin-bottom:16px}
.incident-hero .sev-big{flex:none;width:64px;height:64px;border-radius:8px;border:2.5px solid;
  display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;
  letter-spacing:1px;background:var(--c-card)}
.incident-hero .bd{flex:1;min-width:0}
.incident-hero h1{font-size:20px;font-weight:500;color:var(--c-deep);margin-bottom:6px}
.incident-hero .meta-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:8px}
.incident-hero .closure-summary{display:flex;align-items:center;gap:8px;margin-top:4px}
.incident-hero .bar-lg{display:inline-block;width:200px;height:6px;background:rgba(255,255,255,.6);
  border-radius:4px;overflow:hidden;border:.5px solid var(--c-border)}
.incident-hero .bar-lg i{display:block;height:100%;background:var(--c-deep)}

.inc-tpl-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:12px 6px;border:1.5px solid;border-radius:var(--r);cursor:pointer;
  text-align:center;background:var(--c-card);
  transition:border-color 200ms ease-out, box-shadow 200ms ease-out, transform 200ms ease-out;
  will-change:transform;transform:translateY(0)}
.inc-tpl-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(15,23,42,.08)}
.inc-tpl-card:active{transform:translateY(-2px);background:var(--c-bg)}
.inc-tpl-card input{display:none}
.inc-tpl-card input:checked ~ .ico{font-weight:700}
.inc-tpl-card .ico{font-size:24px}
.inc-tpl-card .lbl{font-size:11px;color:var(--c-text);font-weight:500}
.inc-tpl-card .sev-mini{font-size:9px;padding:1px 5px;border-radius:8px}

.closure-row{display:flex;align-items:center;gap:10px;padding:8px 4px;
  border-bottom:.5px dashed var(--c-border);background:transparent;border-left:0;border-right:0;border-top:0;margin:0;
  width:100%;cursor:pointer;text-align:left}
.closure-row:hover{background:var(--c-pale)}
.closure-row.done{background:rgba(15,110,86,.06)}
.closure-row .ck{font-size:18px;width:28px;height:28px;border:1.5px solid var(--c-border);
  border-radius:50%;background:var(--c-card);color:var(--c-text-sub);cursor:pointer}
.closure-row.done .ck{background:var(--c-normal);color:#fff;border-color:var(--c-normal)}
.closure-row .lbl{flex:1;font-size:13px;color:var(--c-text)}
.closure-row.done .lbl{color:var(--c-normal);font-weight:500}

.tl-item .what{font-size:13px;line-height:1.7;color:var(--c-text);margin-top:2px}
.tl-item .actor{font-size:11px;color:var(--c-text-sub);font-style:italic}

/* === 报告 tab === */
.report-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(360px, 1fr));gap:12px}
.report-card{background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:.15s}
.report-card:hover{border-color:var(--c-mid);box-shadow:0 2px 8px rgba(15,23,42,.06);text-decoration:none}
.report-card.type-daily{border-left:3px solid var(--c-mid3)}
.report-card.type-weekly{border-left:3px solid var(--c-mid-warn)}
.report-card.type-monthly{border-left:3px solid var(--c-deep)}
.report-card.type-sitrep{border-left:3px solid var(--c-urgent)}
.report-card .row1{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.report-card .ttl{font-size:14px;font-weight:500;color:var(--c-text)}
.report-card .footrow{display:flex;justify-content:space-between;font-size:11px;color:var(--c-text-mute);margin-top:4px}

/* 报告编辑 */
.report-edit{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}
.report-edit .col-drawer{position:sticky;top:76px;max-height:calc(100vh - 96px);overflow-y:auto}
.sec-card .sec-textarea{width:100%;font-family:inherit;font-size:13px;line-height:1.7;
  border:.5px solid var(--c-border);border-radius:6px;padding:8px 10px;outline:none;resize:vertical}
.sec-card .sec-textarea:focus{border-color:var(--c-mid);box-shadow:0 0 0 2px rgba(24,95,165,.08)}
.drawer-h{font-size:12px;font-weight:500;color:var(--c-deep);margin-bottom:6px;padding-bottom:3px;border-bottom:.5px solid var(--c-border)}
.drawer-it{padding:6px 0;border-bottom:.5px dashed var(--c-border);font-size:12px;line-height:1.55}
.drawer-it .ins{margin-top:3px}
.drawer-it .ins a{font-size:11px;color:var(--c-mid);background:var(--c-pale);padding:2px 8px;border-radius:10px}
.drawer-it .ins a:hover{background:var(--c-deep);color:#fff;text-decoration:none}

/* 公函 tab */
.letter-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(380px, 1fr));gap:12px}
.letter-card{background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);
  padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:.15s}
.letter-card:hover{border-color:var(--c-mid);box-shadow:0 2px 8px rgba(15,23,42,.06);text-decoration:none}
.letter-card .nomor{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--c-mid);letter-spacing:.5px}
.letter-card .hal{font-size:14px;font-weight:500;color:var(--c-text)}
.letter-card .meta{font-size:11px;color:var(--c-text-mute)}
.letter-card .row1{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px}

/* 状态徽章 */
.lst-draft{background:var(--v46-bg-subtle);color:var(--c-text-sub);border-color:var(--c-border)}
.lst-pending_review{background:rgba(154,103,0,.10);color:var(--c-mid-warn);border-color:rgba(154,103,0,.25)}
.lst-pending_approval{background:rgba(217,119,6,.10);color:var(--c-orange);border-color:rgba(217,119,6,.25)}
.lst-approved{background:rgba(15,110,86,.10);color:var(--c-normal);border-color:rgba(15,110,86,.25)}
.lst-sent{background:var(--c-pale);color:var(--c-deep);border-color:rgba(24,95,165,.30)}

/* 公函编辑 */
.letter-edit{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}
.bilingual-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bilingual-grid .col h4{font-size:13px;color:var(--c-text-sub);margin-bottom:6px;letter-spacing:.5px}
.bilingual-grid .col textarea{width:100%;min-height:340px;font-family:inherit;font-size:13px;line-height:1.85;
  padding:14px 16px;border:.5px solid var(--c-border);border-radius:6px;outline:none;resize:vertical}
.bilingual-grid .col textarea:focus{border-color:var(--c-mid);box-shadow:0 0 0 2px rgba(24,95,165,.08)}
.bilingual-grid .col.id{background:var(--c-bg);border-radius:6px;padding:0}

/* 状态机进度条 */
.workflow{display:flex;align-items:center;gap:0;background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);padding:14px 18px;margin-bottom:16px}
.workflow .step{flex:1;text-align:center;font-size:11px;color:var(--c-text-mute);position:relative}
.workflow .step .dot{display:block;width:24px;height:24px;line-height:22px;border-radius:50%;background:var(--c-card);border:1.5px solid var(--c-border);margin:0 auto 4px;font-size:11px;font-weight:500;color:var(--c-text-mute)}
.workflow .step.done .dot{background:var(--c-deep);border-color:var(--c-deep);color:#fff}
.workflow .step.cur  .dot{background:var(--c-mid);border-color:var(--c-mid);color:#fff;box-shadow:0 0 0 4px rgba(24,95,165,.15)}
.workflow .step.done .name,.workflow .step.cur .name{color:var(--c-deep);font-weight:500}
.workflow .arrow{flex:0 0 30px;height:1px;background:var(--c-border);margin-bottom:18px}
.workflow .arrow.done{background:var(--c-deep)}

/* Kop Surat 预览 */
.kop-preview{background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);padding:18px 22px;margin-bottom:14px;font-size:12px}
.kop-preview .company{font-size:18px;font-weight:500;color:var(--c-deep);letter-spacing:1px;margin-bottom:2px}
.kop-preview .company-zh{font-size:13px;color:var(--c-text-sub);margin-bottom:6px}
.kop-preview .meta{color:var(--c-text-sub)}
.kop-preview hr{border:none;border-top:1.5px solid var(--c-deep);margin-top:8px}

/* === W4 任务中心 === */
.task-shell{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}
.task-sidebar{position:sticky;top:76px;max-height:calc(100vh - 96px);overflow-y:auto;
  background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);padding:10px}
.task-sidebar .ts-section{margin-bottom:14px}
.task-sidebar .ts-h{font-size:11px;color:var(--c-text-sub);font-weight:500;letter-spacing:.5px;
  margin-bottom:6px;padding:0 6px}
.task-sidebar .ts-item{display:flex;justify-content:space-between;align-items:center;
  padding:6px 8px;font-size:13px;color:var(--c-text);border-radius:5px;
  text-decoration:none;line-height:1.45}
.task-sidebar .ts-item:hover{background:var(--c-pale);color:var(--c-mid);text-decoration:none}
.task-sidebar .ts-item.on{background:var(--c-deep);color:#fff;font-weight:500}
.task-sidebar .ts-item.on:hover{background:var(--c-mid);color:#fff}
.task-sidebar .ts-item .ts-n{font-size:11px;background:rgba(255,255,255,.15);padding:1px 6px;border-radius:8px;color:inherit}
.task-sidebar .ts-item:not(.on) .ts-n{background:var(--v46-bg-subtle);color:var(--c-text-mute)}

.task-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.layout-switch{display:inline-flex;border:.5px solid var(--c-border);border-radius:6px;overflow:hidden}
.layout-switch a{padding:5px 10px;font-size:12px;color:var(--c-text-sub);background:var(--c-card);border-right:.5px solid var(--c-border)}
.layout-switch a:last-child{border-right:none}
.layout-switch a.on{background:var(--c-deep);color:#fff}
.layout-switch a:hover{text-decoration:none}

.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%}
.status-dot.stt-todo{background:var(--v46-bg-subtle);border:1.5px solid var(--v46-text-tertiary)}
.status-dot.stt-in_progress{background:var(--c-mid);box-shadow:0 0 0 3px rgba(24,95,165,.15)}
.status-dot.stt-done{background:var(--c-normal)}
.status-dot.stt-cancelled{background:var(--v46-border-strong)}
.status-dot.stt-blocked{background:var(--c-urgent)}

.badge.stt-todo{background:var(--v46-bg-subtle);color:var(--c-text-sub);border-color:var(--c-border)}
.badge.stt-in_progress{background:var(--c-pale);color:var(--c-deep);border-color:rgba(24,95,165,.3)}
.badge.stt-done{background:rgba(15,110,86,.10);color:var(--c-normal);border-color:rgba(15,110,86,.25)}
.badge.stt-cancelled{background:var(--v46-bg-subtle);color:var(--c-text-mute);border-color:var(--c-border)}
.badge.stt-blocked{background:rgba(163,45,45,.08);color:var(--c-urgent);border-color:rgba(163,45,45,.25)}

/* V2.0 SE 模块状态：投诉/承诺/CSR */
.badge.stt-received{background:var(--v46-bg-subtle);color:var(--v46-text-secondary);border-color:var(--v46-border-strong)}
.badge.stt-under_investigation{background:var(--color-info-bg);color:var(--c-deep);border-color:rgba(24,95,165,.3)}
.badge.stt-response_drafted{background:var(--color-warning-bg);color:#9A6700;border-color:#FCD34D}
.badge.stt-responded{background:var(--color-warning-bg);color:var(--color-warning);border-color:#FCD34D}
.badge.stt-follow_up{background:var(--color-info-bg);color:var(--c-mid);border-color:rgba(24,95,165,.3)}
.badge.stt-closed{background:rgba(15,110,86,.10);color:var(--c-normal);border-color:rgba(15,110,86,.25)}
.badge.stt-planned{background:var(--v46-bg-subtle);color:var(--v46-text-secondary);border-color:var(--v46-border-strong)}
.badge.stt-fulfilled{background:rgba(15,110,86,.10);color:var(--c-normal);border-color:rgba(15,110,86,.25)}
.badge.stt-partially_fulfilled{background:var(--color-warning-bg);color:#9A6700;border-color:#FCD34D}
.badge.stt-broken{background:rgba(163,45,45,.08);color:var(--c-urgent);border-color:rgba(163,45,45,.25)}
.badge.stt-ongoing{background:var(--color-info-bg);color:var(--c-deep);border-color:rgba(24,95,165,.3)}
.badge.stt-completed{background:rgba(15,110,86,.10);color:var(--c-normal);border-color:rgba(15,110,86,.25)}
.badge.stt-suspended{background:var(--color-warning-bg);color:var(--color-warning);border-color:#FCD34D}

/* V2.0 SE 模块严重度：投诉 (low/medium/high/critical) */
.incident-card.sev-low{background:var(--color-success-bg);border-color:var(--color-success)}
.incident-card.sev-medium{background:var(--color-warning-bg);border-color:#9A6700}
.incident-card.sev-high{background:var(--color-warning-bg);border-color:var(--color-warning)}
.incident-card.sev-critical{background:var(--color-danger-bg);border-color:var(--color-danger)}

.badge.prio-low{background:var(--v46-bg-subtle);color:var(--c-text-sub);border-color:var(--c-border)}
.badge.prio-medium{background:var(--c-pale);color:var(--c-mid);border-color:rgba(24,95,165,.25)}
.badge.prio-high{background:var(--color-warning-bg);color:var(--c-orange);border-color:#FCD34D}
.badge.prio-critical{background:var(--color-danger-bg);color:var(--color-danger);border-color:#FCA5A5}

.task-table{width:100%;font-size:13px;border-collapse:collapse;background:var(--c-card)}
.task-table th{background:var(--c-pale);color:var(--c-deep);font-weight:500;text-align:left;
  padding:8px 10px;font-size:12px;border-bottom:.5px solid var(--c-border)}
.task-table td{padding:10px 10px;border-bottom:.5px dashed var(--c-border);vertical-align:top;cursor:pointer}
.task-table tr:hover td{background:var(--c-pale)}
.task-table .t-ttl{font-weight:500;color:var(--c-text);line-height:1.4}
.task-table .t-rel{margin-top:3px;display:flex;gap:4px;flex-wrap:wrap}
.task-table .t-rel .badge{font-size:10px;padding:1px 6px}
.task-table .overdue{color:var(--c-urgent);font-weight:500}
.task-table .prog{display:flex;align-items:center;gap:6px}
.task-table .prog .bar{flex:1;height:5px;background:var(--v46-bg-subtle);border-radius:3px;overflow:hidden}
.task-table .prog .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--c-mid),var(--c-deep));border-radius:3px}

.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;align-items:start}
.kb-col{background:var(--v46-bg-subtle);border:.5px solid var(--c-border);border-radius:var(--r);overflow:hidden;min-height:300px}
.kb-h{padding:10px 12px;background:var(--c-card);border-bottom:.5px solid var(--c-border);display:flex;align-items:center;gap:8px}
.kb-body{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:240px;transition:.15s}
.kb-body.drop-here{background:var(--c-pale)}
.kb-card{display:block;background:var(--c-card);border:.5px solid var(--c-border);border-radius:6px;
  padding:10px 12px;font-size:12px;color:var(--c-text);cursor:grab;
  border-left-width:3px;line-height:1.5;transition:.15s}
.kb-card:hover{border-color:var(--c-mid);box-shadow:0 2px 6px rgba(15,23,42,.06);text-decoration:none}
.kb-card.dragging{opacity:.4}
.kb-card.prio-critical-edge{border-left-color:var(--color-danger)}
.kb-card.prio-high-edge{border-left-color:var(--c-orange)}
.kb-card.prio-medium-edge{border-left-color:var(--c-mid)}
.kb-card.prio-low-edge{border-left-color:var(--v46-text-tertiary)}
.kb-row1{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.kb-ttl{font-weight:500;color:var(--c-deep);font-size:13px;line-height:1.4}
.kb-rel{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.kb-rel .badge{font-size:10px;padding:1px 6px}
.kb-foot{display:flex;justify-content:space-between;font-size:11px;margin-top:6px;color:var(--c-text-mute)}
.kb-foot .overdue{color:var(--c-urgent);font-weight:500}
.kb-prog .bar{height:3px;background:var(--v46-bg-subtle);border-radius:2px;overflow:hidden;margin-top:4px}
.kb-prog .bar i{display:block;height:100%;background:var(--c-mid)}

.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:90;align-items:center;justify-content:center}
.modal-backdrop.open{display:flex}
.modal{background:var(--c-card);border-radius:var(--r);width:520px;max-width:90vw;max-height:85vh;
  overflow-y:auto;box-shadow:0 8px 32px rgba(15,23,42,.3)}
.modal-h{padding:14px 18px;border-bottom:.5px solid var(--c-border);display:flex;align-items:center}
.modal-h h3{font-size:16px;font-weight:500;color:var(--c-deep);flex:1}
.modal-x{font-size:22px;background:none;border:none;cursor:pointer;color:var(--c-text-sub)}
.modal-b{padding:18px}

.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--c-border);
  border:.5px solid var(--c-border);border-radius:var(--r);overflow:hidden}
.cal-h{background:var(--c-pale);color:var(--c-deep);text-align:center;font-size:12px;padding:8px;font-weight:500}
.cal-h.cal-weekend{color:var(--c-mid-warn)}
.cal-cell{background:var(--c-card);min-height:90px;padding:6px;font-size:11px;display:flex;flex-direction:column;gap:3px}
.cal-cell.empty-cell{background:var(--c-bg)}
.cal-cell.cal-today{background:var(--c-pale)}
.cal-cell.cal-weekend{background:var(--c-bg)}
.cal-d{font-size:13px;font-weight:500;color:var(--c-text);margin-bottom:2px}
.cal-task{display:block;font-size:10px;padding:2px 5px;background:var(--c-pale);color:var(--c-deep);
  border-radius:3px;border-left:2px solid var(--c-mid);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-task:hover{background:var(--c-deep);color:#fff;text-decoration:none}
.cal-task.prio-critical{border-left-color:var(--color-danger);background:var(--color-danger-bg);color:var(--color-danger)}
.cal-task.prio-high{border-left-color:var(--c-orange);background:var(--color-warning-bg);color:#92400E}
.cal-more{font-size:10px;color:var(--c-text-mute);text-align:right}

.gantt-wrap{font-size:12px;overflow-x:auto;padding-bottom:8px}
.gantt-axis{display:flex;border-bottom:.5px solid var(--c-border);padding:6px 0;background:var(--c-pale)}
.gantt-label-col{flex:0 0 240px;padding:0 10px;font-size:12px;color:var(--c-text);display:flex;align-items:center;gap:6px}
.gantt-axis-track{position:relative;height:18px}
.gantt-week-mark{position:absolute;top:0;height:100%;border-right:.5px dashed var(--v46-border-strong)}
.gantt-today-line{position:absolute;top:-4px;width:2px;height:calc(100% + 8px);background:var(--c-urgent);z-index:2}
.gantt-row{display:flex;align-items:center;height:30px;border-bottom:.5px dashed var(--c-border)}
.gantt-row.gantt-group{background:var(--v46-bg-subtle);height:26px;border-bottom:.5px solid var(--c-border)}
.gantt-group-h{font-weight:500;color:var(--c-deep)}
.gantt-track{position:relative;height:100%;background-image:linear-gradient(to right, transparent 0, transparent 96%, rgba(0,0,0,.03) 96%, rgba(0,0,0,.03) 100%);background-size:112px 100%}
.gantt-bar{position:absolute;top:7px;height:16px;border-radius:3px;cursor:pointer;overflow:hidden;
  background:var(--c-mid);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.gantt-bar:hover{filter:brightness(1.1)}
.gantt-bar.prio-critical{background:var(--color-danger)}
.gantt-bar.prio-high{background:var(--c-orange)}
.gantt-bar.prio-medium{background:var(--c-mid)}
.gantt-bar.prio-low{background:var(--v46-text-tertiary)}
.gantt-bar.stt-done{opacity:.5}
.gantt-bar.stt-cancelled{opacity:.3;background:var(--v46-text-tertiary)}
.gantt-bar .gb-prog{display:block;height:100%;background:rgba(255,255,255,.35)}
.gt-ttl{font-size:12px;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}

.task-detail{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}
.task-detail .td-side{position:sticky;top:76px;max-height:calc(100vh - 96px);overflow-y:auto}
/* === 状态↔进度联动 UI === */
.task-card-main{position:relative;transition:background .25s}
.task-card-main.is-done{background:linear-gradient(180deg,var(--c-card),var(--color-success-bg))}
.task-card-main .done-badge{position:absolute;top:14px;right:16px;width:38px;height:38px;
  border-radius:50%;background:var(--c-normal);color:#fff;display:flex;align-items:center;
  justify-content:center;font-size:22px;font-weight:700;line-height:1;
  box-shadow:0 4px 12px rgba(15,110,86,.4);z-index:50;animation:done-pop .35s;
  border:3px solid #fff}
@keyframes done-pop{
  0% { transform:scale(0); opacity:0 }
  60% { transform:scale(1.18); opacity:1 }
  100% { transform:scale(1) }
}

.prog-line{display:flex;gap:10px;align-items:center;margin-top:14px;flex-wrap:wrap;
  padding-top:12px;border-top:.5px dashed var(--c-border)}
.prog-line.prog-locked{opacity:.55}
.prog-line.prog-locked input[type=range]{filter:grayscale(1)}
.prog-line input[type=range]{flex:0 0 200px;cursor:pointer}
.prog-line input[type=range]:disabled{cursor:not-allowed}
.prog-track{flex:1;min-width:120px;height:8px;background:rgba(24,95,165,.10);border-radius:5px;
  overflow:hidden;position:relative}
.prog-fill{height:100%;background:var(--c-mid);border-radius:5px;
  transition:width .25s, background .25s}

/* 状态按钮（fetch 驱动 · 过渡 200ms 淡入淡出）*/
.stt-btn{transition:background .2s, color .2s, border-color .2s, box-shadow .2s}
.stt-btn.on.stt-todo{background:var(--v46-text-secondary);color:#fff;border-color:var(--v46-text-secondary)}
.stt-btn.on.stt-in_progress{background:var(--c-mid);color:#fff;border-color:var(--c-mid);
  box-shadow:0 0 0 3px rgba(24,95,165,.15)}
.stt-btn.on.stt-done{background:var(--c-normal);color:#fff;border-color:var(--c-normal);
  box-shadow:0 0 0 3px rgba(15,110,86,.18)}
.stt-btn.on.stt-cancelled{background:var(--v46-text-tertiary);color:#fff;border-color:var(--v46-text-tertiary)}
.stt-btn.on.stt-blocked{background:var(--c-urgent);color:#fff;border-color:var(--c-urgent);
  box-shadow:0 0 0 3px rgba(163,45,45,.15)}

/* V14 议题热度榜 */
.issue-heat-card .bd{padding:14px 18px}
.ihl-list{display:flex;flex-direction:column;gap:14px}
.ihl-row{display:block;padding:10px 12px;border:1px solid var(--c-border);border-radius:6px;
  background:var(--c-card);text-decoration:none;color:var(--c-text);
  transition:border-color 200ms ease-out, box-shadow 200ms ease-out;will-change:transform}
.ihl-row:hover{border-color:var(--c-mid);box-shadow:0 2px 8px rgba(15,23,42,.05);text-decoration:none}
.ihl-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.ihl-name{font-size:14px;font-weight:500;color:var(--c-deep)}
.ihl-ratio{font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}
.ihl-sens{font-size:12px;color:var(--c-text-sub)}
.ihl-bar{height:10px;background:rgba(15,95,165,.08);border-radius:5px;overflow:hidden;margin:6px 0 4px}
.ihl-bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--color-info),#5B8BC3);border-radius:5px}
.ihl-sentiment-bar{height:5px;display:flex;border-radius:3px;overflow:hidden;background:var(--v46-bg-subtle)}
.ihl-seg{display:block;height:100%}
.ihl-seg-pos{background:var(--color-success)}
.ihl-seg-neu{background:var(--v46-text-tertiary)}
.ihl-seg-neg{background:var(--color-warning)}
.ihl-seg-cri{background:var(--color-danger)}
.ihl-meta{display:flex;align-items:center;gap:14px;margin-top:8px;font-size:11px;color:var(--c-text-sub);flex-wrap:wrap}
.ihl-stmt .ihl-num{font-weight:500}
.ihl-stmt .ihl-num.pos{color:var(--color-success)}
.ihl-stmt .ihl-num.neu{color:var(--v46-text-secondary)}
.ihl-stmt .ihl-num.neg{color:var(--color-warning)}
.ihl-stmt .ihl-num.cri{color:var(--color-danger)}
.ihl-people{display:inline-flex;align-items:center;gap:4px;margin-left:auto}
.ihl-ava{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;
  border-radius:50%;color:#fff;font-size:10px;font-weight:500;
  border:2px solid #fff;box-shadow:0 0 0 1px var(--c-border);margin-right:-6px}
.ihl-more{font-size:11px;color:var(--c-text-sub);margin-left:8px}

/* Toast */
.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;
  gap:8px;z-index:200;pointer-events:none}
.toast{padding:10px 16px;border-radius:8px;font-size:13px;font-weight:500;
  box-shadow:0 4px 16px rgba(15,23,42,.15);max-width:380px;
  opacity:0;transform:translateY(10px);transition:.22s;pointer-events:auto}
.toast.show{opacity:1;transform:translateY(0)}
.toast-ok{background:var(--c-deep);color:#fff;border-left:3px solid var(--c-normal)}
.toast-err{background:var(--color-danger-bg);color:var(--color-danger);border-left:3px solid var(--color-danger)}

.cmt{padding:8px 10px;background:var(--c-bg);border-radius:6px;border-left:3px solid var(--c-border)}
.cmt.cmt-q{border-left-color:var(--c-mid-warn);background:var(--color-warning-bg)}
.cmt-meta{font-size:11px;color:var(--c-text-sub)}
.cmt-text{font-size:13px;line-height:1.6;margin-top:3px;white-space:pre-wrap}

.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.team-card{background:var(--c-card);border:.5px solid var(--c-border);border-radius:var(--r);padding:14px;
  display:flex;align-items:center;gap:12px}
.team-card .ava-lg{flex:none;width:44px;height:44px;border-radius:50%;background:var(--c-deep);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:500}
.team-card .stats{font-size:12px;color:var(--c-text-sub);margin-top:4px}
.team-card .progress-ring{flex:none;width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:#fff;background:var(--c-mid)}

/* 打印（PDF 简报）=== */
@media print{
  .sidebar,.banner,.actions,.btn-primary,.btn-ghost,
  .lang-toggle,.set-tabs,.mobile-tabbar,.banner .meta{display:none !important}
  .main{display:block}
  .content{padding:0}
  .risk-banner{break-inside:avoid;page-break-inside:avoid}
  .card{break-inside:avoid;page-break-inside:avoid;border:.5px solid #ddd}
  body{background:var(--c-card)}
}

/* ===================== V44 chip + silent badge ===================== */
.v44-chip{
  display:inline-flex;align-items:center;gap:3px;
  padding:1px 7px;border-radius:9px;
  font-size:11px;font-weight:500;line-height:1.3;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  color:var(--c-text-sub,#6B7280);
  max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.v44-chip[data-status="friendly"]{ color:var(--c-normal,#1A7F37); border-color:rgba(26,127,55,0.4); background:rgba(26,127,55,0.10); }
.v44-chip[data-status="neutral"] { color:#9A6700;                 border-color:rgba(154,103,0,0.4); background:rgba(154,103,0,0.10); }
.v44-chip[data-status="critical"]{ color:var(--c-urgent,var(--color-danger)); border-color:rgba(186,5,23,0.45);  background:rgba(186,5,23,0.10); }
.v44-chip[data-status="unknown"] { opacity:0.55; }

.v44-silent-badge{
  display:inline-flex;align-items:center;gap:3px;
  padding:1px 6px;border-radius:8px;
  font-size:10px;font-weight:600;
  color:var(--c-urgent,var(--color-danger));
  background:rgba(186,5,23,0.10);
  border:1px solid rgba(186,5,23,0.35);
}

/* ============================================================
 * 双语筛选树 / 多维侧栏(子菜单)：单语模式只显示当前语言
 * 默认模板把 中文(sft-zh/mfs-zh) + 印尼文(sft-id/mfs-id_lang) 双语堆叠;
 * lang=id 时隐藏中文并把印尼文升为主样式;lang=zh 时隐藏印尼文;
 * lang=bilingual 不加规则 → 双语并存。
 * ============================================================ */
html[lang="id"] .sft-zh,
html[lang="id"] .mfs-zh { display: none; }
html[lang="id"] .sft-id,
html[lang="id"] .mfs-id,
html[lang="id"] .mfs-id_lang {
  font-size: inherit;
  color: var(--c-text, #1e293b);
  font-style: normal;
}
html[lang="zh"] .sft-id,
html[lang="zh"] .mfs-id,
html[lang="zh"] .mfs-id_lang { display: none; }
