/* ============================================================
   viz.css — 手写 SVG 信息图样式(随主题变色)
   配合内联 <svg>，描边/填充均引用 CSS 变量。
   ============================================================ */

.viz { margin: var(--s-5) 0; }
.viz svg { display: block; width: 100%; height: auto; overflow: visible; }
.viz__cap { font-size: var(--f-xs); color: var(--txt-3); margin-top: var(--s-2); text-align: center; }

/* 通用 SVG 元素类 */
.v-axis { stroke: var(--line); stroke-width: 1; }
.v-grid { stroke: var(--line-soft); stroke-width: 1; stroke-dasharray: 2 4; }
.v-label { fill: var(--txt-2); font-size: 12px; }
.v-label-sm { fill: var(--txt-3); font-size: 10px; }
.v-val { fill: var(--txt-1); font-size: 13px; font-weight: 700; }
.v-title { fill: var(--txt-1); font-size: 13px; font-weight: 700; }
.v-teal { fill: var(--c-teal); }
.v-blue { fill: var(--c-blue); }
.v-amber { fill: var(--c-amber); }
.v-violet { fill: var(--c-violet); }
.v-stroke-teal { stroke: var(--c-teal); fill: none; }
.v-stroke-blue { stroke: var(--c-blue); fill: none; }

/* 条形 / 阶梯 */
.bar { transition: opacity var(--t-fast); }
.bar-track { fill: var(--panel-2); }
.bar-teal { fill: var(--c-teal); }
.bar-blue { fill: var(--c-blue); }
.bar-amber { fill: var(--c-amber); }
.bar-muted { fill: var(--txt-4); }

/* 环形进度(疗效评分) */
.ring-bg { fill: none; stroke: var(--panel-2); }
.ring-fg { fill: none; stroke: var(--c-teal); stroke-linecap: round; transform: rotate(-90deg); transform-origin: center; }
.ring-fg--amber { stroke: var(--c-amber); }
.ring-fg--blue { stroke: var(--c-blue); }
.ring-val { fill: var(--txt-1); font-family: var(--f-num); font-weight: 800; }
.ring-unit { fill: var(--c-teal); font-weight: 700; }
.ringgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: var(--s-4); margin: var(--s-5) 0; }
.ringgrid figure { margin: 0; text-align: center; }
.ringgrid figcaption { color: var(--txt-2); font-size: var(--f-xs); margin-top: var(--s-2); }
.ringgrid figcaption strong { display:block; color: var(--txt-1); }

/* TRL 地图刻度 */
.trl-track { stroke: var(--line); stroke-width: 6; stroke-linecap: round; }
.trl-fill { stroke-width: 6; stroke-linecap: round; }
.trl-tick { fill: var(--txt-4); font-size: 10px; }
.trl-dot { stroke: var(--bg-1); stroke-width: 2; }

/* 甘特 / 泳道 */
.gantt { margin: var(--s-5) 0; }
.gantt-lane { fill: var(--panel); stroke: var(--line-soft); }
.gantt-lane-label { fill: var(--txt-1); font-size: 12px; font-weight: 600; }
.gantt-bar { rx: 5; }
.gantt-p0 { fill: color-mix(in srgb, var(--c-teal) 78%, transparent); }
.gantt-p1 { fill: color-mix(in srgb, var(--c-blue) 72%, transparent); }
.gantt-p2 { fill: color-mix(in srgb, var(--c-violet) 70%, transparent); }
.gantt-p3 { fill: color-mix(in srgb, var(--c-amber) 72%, transparent); }
.gantt-bar-label { fill: var(--txt-on-accent); font-size: 11px; font-weight: 700; }
.gantt-milestone { fill: var(--c-amber); stroke: var(--bg-1); stroke-width: 1.5; }
.gantt-axis { fill: var(--txt-3); font-size: 11px; }
.gantt-colhead { fill: var(--txt-2); font-size: 11px; font-weight: 700; }

/* 矩阵 / 象限 */
.quad-bg { fill: var(--panel); stroke: var(--line); }
.quad-line { stroke: var(--line); stroke-dasharray: 3 4; }
.quad-axis-label { fill: var(--txt-3); font-size: 11px; }
.quad-zone { opacity: .12; }
.quad-pt { stroke: var(--bg-1); stroke-width: 2; }
.quad-pt-label { fill: var(--txt-1); font-size: 11px; font-weight: 600; }
.quad-pt-hl { fill: var(--c-teal); }

/* 雷达(波特五力) */
.radar-grid { fill: none; stroke: var(--line); }
.radar-axis { stroke: var(--line); }
.radar-area { fill: color-mix(in srgb, var(--c-teal) 22%, transparent); stroke: var(--c-teal); stroke-width: 2; }
.radar-label { fill: var(--txt-2); font-size: 11px; }

/* 环形飞轮 / 闭环 */
.flywheel { margin: var(--s-5) 0; display: flex; justify-content: center; }
.flywheel svg { width: 100%; max-width: 540px; height: auto; overflow: visible; }
.fw-ring { fill: none; stroke: var(--line); stroke-width: 1.5; stroke-dasharray: 4 5; }
.fw-arc { fill: none; stroke: var(--c-teal); stroke-width: 2.5; }
.fw-dir polygon { fill: var(--c-teal); }
.fw-node { fill: var(--panel); stroke: var(--c-teal); stroke-width: 2; }
.fw-node-label { fill: var(--txt-1); font-size: 12px; font-weight: 600; }
.fw-center { fill: var(--txt-1); font-size: 13px; font-weight: 700; }
.fw-center-sub { fill: var(--txt-3); font-size: 10px; }

/* 分层架构 */
.lstack { display: grid; gap: 6px; margin: var(--s-5) 0; }
.layer {
  display: grid; grid-template-columns: 160px 1fr; gap: var(--s-4); align-items: center;
  padding: var(--s-4) var(--s-5); border-radius: var(--r-md);
  border: 1px solid var(--line); position: relative; overflow: hidden;
}
.layer::before { content:""; position:absolute; left:0; top:0; bottom:0; width: 4px; }
.layer__name { font-weight: 700; color: var(--txt-1); font-size: .98rem; }
.layer__name small { display:block; font-weight: 500; color: var(--txt-3); font-size: var(--f-2xs); letter-spacing: .08em; }
.layer__desc { color: var(--txt-2); font-size: var(--f-sm); }
.layer--l1 { background: color-mix(in srgb, var(--c-teal) 9%, var(--panel)); }
.layer--l1::before { background: var(--c-teal); }
.layer--l2 { background: color-mix(in srgb, var(--c-blue) 9%, var(--panel)); }
.layer--l2::before { background: var(--c-blue); }
.layer--l3 { background: color-mix(in srgb, var(--c-violet) 9%, var(--panel)); }
.layer--l3::before { background: var(--c-violet); }
.layer--l4 { background: color-mix(in srgb, var(--c-amber) 9%, var(--panel)); }
.layer--l4::before { background: var(--c-amber); }
.layer--base { background: var(--panel-2); }
.layer--base::before { background: var(--txt-3); }
.lstack__flow { text-align: center; color: var(--txt-3); font-size: var(--f-xs); padding: 2px; }
@media (max-width: 560px){ .layer { grid-template-columns: 1fr; gap: var(--s-2); } }

/* 横向流程箭头(原理4步等)复用 pipeline,但带编号大圆 */
.flowline { display: flex; align-items: stretch; gap: 0; flex-wrap: wrap; margin: var(--s-5) 0; }
.flownode { flex: 1 1 140px; text-align: center; padding: var(--s-4) var(--s-3); position: relative; }
.flownode__circle {
  width: 46px; height: 46px; border-radius: 50%; margin: 0 auto var(--s-3);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--f-num); font-weight: 800; font-size: 1.2rem; color: var(--c-teal);
  border: 2px solid var(--c-teal); background: color-mix(in srgb, var(--c-teal) 10%, transparent);
}
.flownode__t { color: var(--txt-1); font-weight: 700; font-size: var(--f-sm); }
.flownode__d { color: var(--txt-3); font-size: var(--f-xs); margin-top: 4px; line-height: 1.5; }
.flownode:not(:last-child)::after {
  content: "→"; position: absolute; right: -6px; top: 28px; color: var(--c-teal); opacity: .6; font-size: 1.3rem;
}
@media (max-width: 620px){ .flowline { flex-direction: column; } .flownode:not(:last-child)::after { content:"↓"; right: auto; left: 50%; top: auto; bottom: -8px; transform: translateX(-50%);} }
