/* ============================================================
 * Components · 文本组件 / 数据卡片 / 表格 / 引文 / 脚注
 * ============================================================ */

/* ─── Lead Paragraph · 章节首段 ─── */
.lead {
  font-family: var(--font-serif);
  font-size: var(--t-lead);
  line-height: var(--lh-normal);
  color: var(--ink-700);
  margin: 0 0 var(--space-4) 0;
}

.lead--drop::first-letter {
  font-family: var(--font-display);
  font-size: 96px;
  font-weight: var(--w-medium);
  line-height: 0.85;
  float: left;
  padding: 6px 12px 0 0;
  color: var(--red-press);
}

/* ─── Body Text · 主体正文 ─── */
.body {
  font-family: var(--font-serif);
  font-size: var(--t-body);
  line-height: var(--lh-relaxed);
  color: var(--ink-700);
  margin: 0;
}

.body + .body {
  margin-top: var(--space-3);
}

.body strong, .body b {
  font-weight: var(--w-semibold);
  color: var(--ink-900);
}

.body em, .body i {
  font-style: italic;
}

.body code, .mono-inline {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--ink-200);
  padding: 1px 5px;
  border-radius: var(--radius-sm);
  color: var(--ink-900);
}

.body sup, .body sub {
  font-size: 0.7em;
  line-height: 0;
}

/* 公式块 */
.formula {
  font-family: var(--font-mono);
  font-size: var(--t-caption);
  line-height: var(--lh-normal);
  color: var(--ink-900);
  background: var(--ink-200);
  border-left: 3px solid var(--red-press);
  padding: var(--space-3);
  margin: var(--space-3) 0;
  overflow-x: auto;
  white-space: pre;
}

.formula-label {
  display: block;
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  margin-bottom: var(--space-2);
}

/* ─── 五维结构列表（现象 / 微观 / 推演 / 机制 / 证据） ─── */
.dim-list {
  display: grid;
  gap: var(--space-3);
  list-style: none;
  margin: var(--space-3) 0;
  padding: 0;
  font-family: var(--font-serif);
  font-size: var(--t-body);
  line-height: var(--lh-relaxed);
}

.dim-list > li {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: var(--space-3);
  padding-left: var(--space-3);
  border-left: 2px solid var(--ink-300);
  min-width: 0;
}

.dim-list > li > * {
  min-width: 0;
}

.dim-list > li[data-dim="phenom"]   { border-left-color: var(--ink-500); }
.dim-list > li[data-dim="micro"]    { border-left-color: var(--blue-link); }
.dim-list > li[data-dim="deduce"]   { border-left-color: var(--orange-warn); }
.dim-list > li[data-dim="mech"]     { border-left-color: var(--red-press); }
.dim-list > li[data-dim="evidence"] { border-left-color: var(--green-up); }

.dim-list > li::before {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  padding-top: 4px;
  align-self: start;
}

.dim-list > li[data-dim="phenom"]::before   { content: "现象"; color: var(--ink-500); }
.dim-list > li[data-dim="micro"]::before    { content: "微观原理"; color: var(--blue-link); }
.dim-list > li[data-dim="deduce"]::before   { content: "逻辑推演"; color: var(--orange-warn); }
.dim-list > li[data-dim="mech"]::before     { content: "心理机制"; color: var(--red-press); }
.dim-list > li[data-dim="evidence"]::before { content: "证据 / 数据"; color: var(--green-up); }

.dim-list > li > div {
  align-self: start;
}

/* ─── Pull Quote ─── */
.pullquote {
  grid-column: 4 / span 6;
  margin: var(--space-5) 0;
  padding: var(--space-4) 0;
  border-top: var(--border-red-2);
  border-bottom: var(--border-red-2);
  font-family: var(--font-display);
  font-size: var(--t-quote);
  line-height: var(--lh-snug);
  color: var(--ink-900);
  font-weight: var(--w-medium);
  text-align: left;
}

.pullquote p {
  margin: 0;
}

.pullquote-attr {
  display: block;
  margin-top: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  font-weight: var(--w-medium);
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}

/* ─── Big Number ─── */
.bignum {
  display: grid;
  gap: var(--space-2);
  align-content: start;
  padding: var(--space-3) 0;
}

.bignum-val {
  font-family: var(--font-display);
  font-size: var(--t-h1);
  font-weight: var(--w-medium);
  line-height: 1;
  letter-spacing: var(--tracking-display);
  color: var(--red-press);
  margin: 0;
  font-variant-numeric: tabular-nums;
}

.bignum-val--xl   { font-size: var(--t-display); }
.bignum-val--ink  { color: var(--ink-900); }

.bignum-unit {
  display: inline-block;
  font-size: 0.32em;
  vertical-align: 0.7em;
  margin-left: 0.15em;
  color: var(--ink-700);
  font-weight: var(--w-regular);
  font-family: var(--font-sans);
  letter-spacing: 0;
}

.bignum-label {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--ink-500);
  margin: 0;
}

.bignum-source {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  color: var(--ink-400);
  margin: 0;
}

/* ─── Data Card · 终端纪律 ─── */
.datacard {
  border: var(--border-1);
  background: var(--ink-100);
  font-family: var(--font-sans);
  padding: 0;
}

.datacard-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  border-bottom: var(--border-1);
  background: var(--ink-200);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  color: var(--ink-700);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  height: var(--term-header-h);
}

.datacard-tag {
  font-size: var(--t-micro);
  font-weight: var(--w-medium);
  color: var(--red-press);
}

.datacard-body {
  padding: var(--space-3);
  display: grid;
  gap: var(--space-1);
}

.datacard-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-3);
  align-items: baseline;
  padding: 4px 0;
  border-bottom: 1px dotted var(--ink-300);
}

.datacard-row:last-child { border-bottom: 0; }

.datacard-key {
  font-family: var(--font-sans);
  font-size: var(--t-data);
  color: var(--ink-500);
}

.datacard-val {
  font-family: var(--font-mono);
  font-size: var(--t-data);
  font-weight: var(--w-semibold);
  color: var(--ink-900);
  text-align: right;
}

.datacard-val--up   { color: var(--green-up); }
.datacard-val--down { color: var(--red-down); }
.datacard-val--info { color: var(--blue-link); }

.datacard-foot {
  padding: var(--space-2) var(--space-3);
  border-top: var(--border-1);
  background: var(--ink-200);
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  color: var(--ink-500);
}

/* ─── Footnote ─── */
sup.fn, .fn {
  font-family: var(--font-sans);
  font-size: 0.65em;
  vertical-align: super;
  line-height: 0;
  color: var(--red-press);
  text-decoration: none;
  font-weight: var(--w-semibold);
  padding: 0 0.1em;
  cursor: pointer;
}

.fn:hover {
  text-decoration: underline;
}

/* footnote popup（JS 控制位置） */
.fn-popup {
  position: absolute;
  z-index: var(--z-overlay);
  background: var(--ink-900);
  color: var(--ink-100);
  padding: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  line-height: var(--lh-normal);
  max-width: 320px;
  pointer-events: auto;
  box-shadow: var(--shadow-modal);
}

.fn-popup-cite {
  display: block;
  margin-top: var(--space-1);
  color: var(--ink-300);
  font-style: italic;
}

/* 章末脚注列表 */
.footnotes {
  grid-column: 1 / -1;
  border-top: var(--border-3);
  margin-top: var(--space-5);
  padding-top: var(--space-4);
}

.footnotes-title {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  margin: 0 0 var(--space-3) 0;
}

.footnotes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  line-height: var(--lh-normal);
  color: var(--ink-600);
}

.footnotes-list > li {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: var(--space-2);
  padding-bottom: var(--space-2);
  border-bottom: 1px dotted var(--ink-300);
  min-width: 0;
}

.footnotes-list > li > * {
  min-width: 0;
}

.footnotes-list > li:last-child {
  border-bottom: 0;
}

.fn-num {
  font-family: var(--font-mono);
  font-weight: var(--w-semibold);
  color: var(--red-press);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.footnotes-list a {
  color: var(--blue-link);
  text-decoration: none;
}

.footnotes-list a:hover {
  text-decoration: underline;
}

.footnotes-list cite {
  font-style: italic;
  color: var(--ink-500);
}

/* ─── Chart Card ─── */
.chart {
  grid-column: 3 / span 9;
  display: grid;
  gap: var(--space-2);
  margin: var(--space-4) 0;
}

.chart--full { grid-column: 1 / -1; }
.chart--half { grid-column: 3 / span 5; }

.chart-caption {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-top: var(--border-2);
  padding-top: var(--space-2);
  font-family: var(--font-sans);
  gap: var(--space-3);
}

.chart-num {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  color: var(--red-press);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  font-weight: var(--w-semibold);
  white-space: nowrap;
}

.chart-title {
  font-size: var(--t-caption);
  font-weight: var(--w-semibold);
  color: var(--ink-900);
  flex: 1;
  margin: 0;
}

.chart-canvas {
  background: var(--ink-100);
  border: var(--border-1);
  display: block;
  width: 100%;
}

.chart-canvas--paper { background: var(--ink-200); }

.chart-deck {
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  line-height: var(--lh-normal);
  color: var(--ink-600);
  margin: 0;
}

.chart-source {
  display: flex;
  justify-content: space-between;
  border-top: var(--border-1);
  padding-top: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  color: var(--ink-400);
}

.chart-source-label {
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  font-weight: var(--w-medium);
}

/* ─── Institutional Table ─── */
.itable-wrap {
  grid-column: 3 / span 9;
  margin: var(--space-4) 0;
  border: var(--border-1);
  background: var(--ink-100);
  overflow-x: auto;
}

.itable-wrap--full { grid-column: 1 / -1; }

.itable {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-sans);
  font-size: var(--t-data);
  font-variant-numeric: tabular-nums;
}

.itable thead {
  background: var(--ink-200);
  position: sticky;
  top: 56px;
  z-index: 1;
}

.itable thead th {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  text-align: left;
  padding: var(--space-2) var(--space-3);
  color: var(--ink-700);
  border-bottom: var(--border-2);
  white-space: nowrap;
  height: var(--term-header-h);
  vertical-align: middle;
}

.itable thead th.num {
  text-align: right;
}

.itable tbody td {
  height: var(--term-row-h);
  padding: 0 var(--space-3);
  border-bottom: 1px solid var(--ink-200);
  color: var(--ink-700);
  vertical-align: middle;
  white-space: nowrap;
}

.itable tbody td.num {
  text-align: right;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.itable tbody td.up   { color: var(--green-up); font-weight: var(--w-semibold); }
.itable tbody td.down { color: var(--red-down); font-weight: var(--w-semibold); }
.itable tbody td.dim  { color: var(--ink-400); }
.itable tbody td.em   { font-weight: var(--w-semibold); color: var(--ink-900); }

.itable--wrap thead th,
.itable--wrap tbody th,
.itable--wrap tbody td {
  height: auto;
  min-height: var(--term-row-h);
  white-space: normal;
  overflow-wrap: anywhere;
  vertical-align: top;
  padding-top: var(--space-2);
  padding-bottom: var(--space-2);
}

.itable tbody tr:hover {
  background: var(--ink-200);
}

.itable tbody tr.section-row td {
  background: var(--ink-200);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  font-size: var(--t-micro);
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  height: 28px;
}

@media (max-width: 640px) {
  .itable {
    display: block;
    max-width: 100%;
    overflow-x: visible;
  }

  .itable thead,
  .itable tbody,
  .itable tr,
  .itable th,
  .itable td {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    box-sizing: border-box;
  }

  .itable thead {
    position: static;
  }

  .itable thead th,
  .itable tbody th,
  .itable tbody td {
    height: auto;
    min-height: 0;
    white-space: normal;
    overflow-wrap: anywhere;
    padding: var(--space-2) var(--space-3);
  }

  .itable tbody th {
    font-family: var(--font-sans);
    font-size: var(--t-micro);
    font-weight: var(--w-semibold);
    color: var(--red-press);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    background: var(--ink-200);
    border-bottom: 1px solid var(--ink-300);
  }

  .itable tbody tr {
    border-bottom: var(--border-1);
  }

  .itable tbody tr:last-child {
    border-bottom: 0;
  }
}

.itable-foot {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  color: var(--ink-500);
  padding: var(--space-2) var(--space-3);
  border-top: var(--border-1);
  background: var(--ink-200);
  display: flex;
  justify-content: space-between;
}

/* ─── Institutional Table Figure（带 figcaption 的表）─── */
.itable-figure {
  grid-column: 1 / -1;
  margin: var(--space-4) 0;
  border: var(--border-1);
  background: var(--ink-100);
  overflow-x: auto;
  min-width: 0;
}

.itable-figure > .itable-caption {
  font-family: var(--font-sans);
  font-size: var(--t-data);
  padding: var(--space-2) var(--space-3);
  border-bottom: var(--border-1);
  background: var(--ink-200);
  display: flex;
  gap: var(--space-3);
  align-items: baseline;
}

.itable-figure > .itable-caption .itable-num {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  color: var(--red-press);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}

.itable-figure > .itable-caption .itable-title {
  color: var(--ink-700);
  font-weight: var(--w-medium);
}

/* ─── Block Quote 引用块 ─── */
.boxquote {
  grid-column: 3 / span 7;
  border-left: 3px solid var(--red-press);
  padding: var(--space-2) var(--space-3);
  margin: var(--space-4) 0;
  font-family: var(--font-serif);
  font-size: var(--t-body);
  line-height: var(--lh-relaxed);
  font-style: italic;
  color: var(--ink-600);
  background: var(--ink-200);
}

.boxquote p { margin: 0; }

.boxquote-attr {
  display: block;
  margin-top: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  font-style: normal;
  color: var(--ink-500);
}

/* ─── Callout（警示 / 提示框） ─── */
.callout {
  grid-column: 3 / span 9;
  border: var(--border-1);
  border-left: 4px solid var(--red-press);
  padding: var(--space-3) var(--space-4);
  margin: var(--space-3) 0;
  background: var(--ink-200);
  font-family: var(--font-sans);
  font-size: var(--t-caption);
  line-height: var(--lh-normal);
  color: var(--ink-700);
}

.callout p { margin: 0; }
.callout p + p { margin-top: var(--space-2); }

.callout-label {
  display: inline-block;
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  margin-right: var(--space-2);
}

/* Wyckoff 系统直接含义 — 教科书核心 callout，视觉权重最高 */
.callout--wyckoff {
  border-left-width: 6px;
  background: var(--ink-100);
  border-color: var(--red-press);
  border-top: 1px solid var(--red-press);
  border-bottom: 1px solid var(--red-press);
  border-right: 1px solid var(--red-press);
  padding: var(--space-4);
}

.callout--wyckoff .callout-label {
  color: var(--red-press);
  font-size: var(--t-meta);
}

.callout--wyckoff::before {
  content: "Wyckoff 系统锚点";
  display: block;
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  margin-bottom: var(--space-2);
  font-weight: var(--w-semibold);
}

.callout--warn  { border-left-color: var(--orange-warn); }
.callout--warn .callout-label { color: var(--orange-warn); }
.callout--ok    { border-left-color: var(--green-up); }
.callout--ok .callout-label { color: var(--green-up); }
.callout--info  { border-left-color: var(--blue-link); }
.callout--info .callout-label { color: var(--blue-link); }

/* ─── 置信度标记 ─── */
.conf {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  padding: 1px 6px;
  border: var(--border-1);
  vertical-align: 0.1em;
  margin: 0 4px;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  font-weight: var(--w-semibold);
}

.conf--high { color: var(--green-up); border-color: var(--green-up); }
.conf--mid  { color: var(--orange-warn); border-color: var(--orange-warn); }
.conf--low  { color: var(--red-down); border-color: var(--red-down); }

/* ─── Key Takeaways 章节摘要 ─── */
.takeaways {
  grid-column: 1 / -1;
  border-top: var(--border-3);
  border-bottom: var(--border-2);
  padding: var(--space-4) 0;
  margin: var(--space-5) 0 var(--space-4) 0;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--space-4);
  min-width: 0;
}

.takeaways-label {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  align-self: start;
}

.takeaways-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
  font-family: var(--font-serif);
  font-size: var(--t-body);
  line-height: var(--lh-normal);
  color: var(--ink-700);
  min-width: 0;
}

.takeaways-list > li {
  position: relative;
  padding-left: var(--space-4);
  min-width: 0;
}

.takeaways-list > li::before {
  content: "—";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--red-press);
  font-weight: var(--w-semibold);
}

@media (max-width: 1024px) {
  .takeaways {
    grid-template-columns: 1fr;
  }
}

/* ─── Glossary 术语表 ─── */
.glossary {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3) var(--grid-gap);
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  line-height: var(--lh-normal);
  border-top: var(--border-2);
  padding-top: var(--space-4);
  margin-top: var(--space-5);
}

.glossary dt {
  font-weight: var(--w-semibold);
  color: var(--ink-900);
  border-bottom: 1px dotted var(--ink-400);
  padding-bottom: var(--space-1);
  margin-bottom: var(--space-1);
}

.glossary dd {
  margin: 0 0 var(--space-3) 0;
  color: var(--ink-600);
}

.glossary-en {
  font-style: italic;
  color: var(--ink-500);
  font-weight: var(--w-regular);
  margin-left: 4px;
}

@media (max-width: 1024px) {
  .glossary { grid-template-columns: 1fr; }
}

/* ─── Counters · 数字计数器列 ─── */
.counters {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--grid-gap);
  border-top: var(--border-2);
  border-bottom: var(--border-1);
  padding: var(--space-4) 0;
  margin: var(--space-4) 0;
}

@media (max-width: 1024px) {
  .counters { grid-template-columns: repeat(2, 1fr); }
}

.counter {
  display: grid;
  gap: var(--space-1);
}

.counter-val {
  font-family: var(--font-display);
  font-size: var(--t-h2);
  font-weight: var(--w-medium);
  line-height: 1;
  color: var(--red-press);
  letter-spacing: var(--tracking-tight);
  font-variant-numeric: tabular-nums;
}

.counter-label {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--ink-500);
}

.counter-note {
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  color: var(--ink-700);
  line-height: var(--lh-normal);
  margin-top: var(--space-1);
}

/* ─── SVG Figure 容器 ─── */
.svg-figure {
  grid-column: 3 / span 9;
  display: grid;
  gap: var(--space-2);
  margin: var(--space-4) 0;
}

.svg-figure--full { grid-column: 1 / -1; }
.svg-figure--half { grid-column: 3 / span 5; }

.svg-figure svg {
  width: 100%;
  height: auto;
  display: block;
  background: var(--ink-100);
  border: var(--border-1);
}

.svg-figure svg.paper {
  background: var(--ink-200);
}

.svg-figure svg text {
  font-family: var(--font-sans);
  font-size: 11px;
  fill: var(--ink-700);
}

.svg-figure svg .axis-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  fill: var(--ink-500);
}

.svg-figure svg .data-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  fill: var(--ink-900);
}

.chart-wrap {
  grid-column: 1 / -1;
  width: 100%;
  max-width: 100%;
  margin: var(--space-4) 0;
  overflow: hidden;
}

.chart-wrap svg {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  overflow: hidden;
  border: var(--border-1);
  background: var(--ink-200);
}

.chart-wrap svg + svg {
  margin-top: var(--space-2);
}

.chart-wrap figcaption {
  margin-top: var(--space-2);
}

/* ─── Cross-reference link · 章节内联跳转 ─── */
.xref {
  color: var(--blue-link);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  font-family: inherit;
}

.xref:hover {
  background: var(--ink-200);
  text-decoration: none;
}

/* ─── CTA Button · 主行动按钮（封面页「阅读完整章节」、章节页「返回封面」） ─── */
.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--red-press);
  color: var(--ink-100);
  padding: 10px 18px;
  font-family: var(--font-sans);
  font-size: var(--t-meta);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  text-decoration: none;
  border: 1px solid var(--red-press);
  transition: background var(--tx-fast), color var(--tx-fast);
  white-space: nowrap;
}

.cta-btn:hover {
  background: var(--ink-900);
  border-color: var(--ink-900);
  color: var(--ink-100);
  text-decoration: none;
}

.cta-btn--ghost {
  background: transparent;
  color: var(--ink-900);
  border-color: var(--ink-900);
}

.cta-btn--disabled {
  background: transparent;
  color: var(--ink-400);
  border-color: var(--ink-300);
  cursor: not-allowed;
  pointer-events: none;
}

.cta-btn--disabled:hover {
  background: transparent;
  color: var(--ink-400);
  border-color: var(--ink-300);
}

.cta-btn--ghost:hover {
  background: var(--ink-900);
  color: var(--ink-100);
}

.cta-btn .arrow {
  font-family: var(--font-mono);
  font-weight: var(--w-regular);
}

.topbar .cta-btn {
  padding: 6px 12px;
  font-size: var(--t-micro);
}

/* ─── Tag · 概念小标 ─── */
.tag {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  padding: 1px 6px;
  border: var(--border-1);
  color: var(--ink-700);
  margin: 0 2px;
  vertical-align: 0.05em;
  letter-spacing: var(--tracking-wide);
}

.tag--red { color: var(--red-press); border-color: var(--red-press); }
.tag--up  { color: var(--green-up); border-color: var(--green-up); }
.tag--info { color: var(--blue-link); border-color: var(--blue-link); }

/* ─── Definition pair（首次术语英文括注） ─── */
.term {
  font-weight: var(--w-semibold);
  color: var(--ink-900);
}

.term-en {
  font-family: var(--font-sans);
  font-style: italic;
  font-weight: var(--w-regular);
  color: var(--ink-500);
  font-size: 0.9em;
  margin-left: 2px;
}

/* ─── 章节末导航 ─── */
.chapter-nav {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--grid-gap);
  border-top: var(--border-2);
  margin-top: var(--space-5);
  padding-top: var(--space-4);
}

.chapter-nav-link {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-3);
  border: var(--border-1);
  text-decoration: none;
  color: var(--ink-700);
  transition: background var(--tx-fast);
}

.chapter-nav-link:hover {
  background: var(--ink-200);
  text-decoration: none;
}

.chapter-nav-link[data-dir="next"] { text-align: right; }

.chapter-nav-eyebrow {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
}

.chapter-nav-title {
  font-family: var(--font-display);
  font-size: var(--t-h3);
  font-weight: var(--w-medium);
  line-height: 1.2;
  color: var(--ink-900);
}

/* ─────────── QUANT-RULE · 量化判定式 ───────────
   每个 Wyckoff 事件块末尾的可证伪不等式集合。
   面向量化桌：Bloomberg / Bookmap / 自建扫描器可直接对齐。
*/
.quant-rule {
  margin: var(--space-4) 0 var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--ink-50, #f4f1ea);
  border-left: 3px solid var(--red-press);
  font-family: var(--font-mono);
  font-size: var(--t-small);
  line-height: 1.65;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
}

.quant-rule-head {
  font-family: var(--font-sans);
  font-size: var(--t-micro);
  font-weight: var(--w-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--red-press);
  margin: 0 0 var(--space-2) 0;
}

.quant-rule-eq {
  display: block;
  white-space: pre-wrap;
  margin: 0 0 var(--space-1) 0;
  word-break: break-word;
}

.quant-rule-eq + .quant-rule-eq {
  border-top: 1px dashed var(--ink-200, #d8d2c5);
  padding-top: var(--space-1);
}

.quant-rule-note {
  font-family: var(--font-serif);
  font-size: var(--t-small);
  font-style: italic;
  color: var(--ink-500);
  margin: var(--space-2) 0 0 0;
}
