/* ============================================================
   万神殿日报 · 印刷报纸风
   设计:暖纸底 + 黑底白字标题条 + 赤红 accent + 衬线字体
   参考:例子模版.html(2026-05-08)
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;500;700;900&family=Noto+Sans+SC:wght@400;500;700;900&display=swap");

:root {
  --paper: #f5f2e8;
  --paper-soft: #ebe8dc;
  --paper-deep: #d4d0c8;
  --ink: #1a1a1a;
  --ink-soft: #4a4a4a;
  --rule-warm: #8b7355;
  --accent: #b71c1c;
  /* 赤红 */
  --serif-zh: "Noto Serif SC", "Songti SC", serif;
  --sans-zh: "Noto Sans SC", "PingFang SC", sans-serif;
  --serif-en: "Georgia", serif;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  background: var(--paper-deep);
  color: var(--ink);
  font-family: var(--serif-zh);
  font-size: 14.5px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.page {
  width: 1200px;
  max-width: 100%;
  margin: 24px auto;
  background: var(--paper);
  padding: 40px;
  box-shadow:
    0 0 0 1px var(--rule-warm),
    0 0 20px rgba(0, 0, 0, 0.3),
    inset 0 0 100px rgba(255, 255, 255, 0.1);
  position: relative;
}

.page::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 1px,
    rgba(0, 0, 0, 0.02) 1px,
    rgba(0, 0, 0, 0.02) 2px
  );
  pointer-events: none;
  z-index: 0;
}

.page > * {
  position: relative;
  z-index: 1;
}

/* ===== Masthead ===== */
.masthead {
  text-align: center;
  border-bottom: 4px double var(--ink);
  padding-bottom: 18px;
  margin-bottom: 22px;
}

.masthead__wordmark {
  font-family: var(--serif-en);
  font-size: 14px;
  letter-spacing: 4px;
  color: var(--ink-soft);
  text-transform: uppercase;
  margin-bottom: 6px;
}

.masthead__wordmark-zh {
  font-family: var(--sans-zh);
  font-weight: 900;
  font-size: 48px;
  letter-spacing: 8px;
  color: var(--ink);
  margin: 0 0 8px;
  border-bottom: 2px solid var(--accent);
  padding-bottom: 10px;
  display: inline-block;
}

.masthead__rule {
  display: none;
}

.masthead__rule-thin {
  display: none;
}

.masthead__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  margin-top: 14px;
  font-family: var(--sans-zh);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 1px;
}

.masthead__meta span:last-child {
  color: var(--accent);
  font-weight: 700;
}

.masthead__meta span + span::before {
  content: none;
}

/* ===== 装饰小符号(印刷风用 ✦ 替代) ===== */
.ornament {
  text-align: center;
  font-size: 14px;
  color: var(--accent);
  letter-spacing: 6px;
  margin: 14px 0 10px;
}

/* ===== 板块标题条(黑底白字 + 红底边) ===== */
.section-label {
  background: var(--ink);
  color: var(--paper);
  padding: 8px 20px;
  font-family: var(--sans-zh);
  font-weight: 900;
  font-size: 15px;
  letter-spacing: 2px;
  margin: 8px 0 16px;
  border-bottom: 3px solid var(--accent);
  display: inline-block;
}

.section-label--accent {
  background: var(--ink);
}

/* ===== 今日观察 ===== */
.observation {
  border: 3px solid var(--ink);
  padding: 20px 22px 18px;
  background: var(--paper-soft);
  margin-bottom: 24px;
  position: relative;
}

.observation::before {
  content: "本报总编";
  position: absolute;
  top: -10px;
  right: 22px;
  background: var(--accent);
  color: var(--paper);
  padding: 3px 15px;
  font-family: var(--sans-zh);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 2px;
}

.observation .ornament {
  display: none;
}

.observation__title {
  font-family: var(--sans-zh);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 4px;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 8px;
  margin-bottom: 12px;
}

.observation__subtitle {
  font-family: var(--serif-zh);
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 12px;
  font-style: italic;
}

.observation__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  font-size: 14px;
  line-height: 1.85;
  text-align: justify;
}

.observation__body p {
  text-indent: 2em;
  margin: 0 0 8px;
}

.observation__signature {
  text-align: right;
  font-family: var(--sans-zh);
  font-size: 12px;
  letter-spacing: 2px;
  color: var(--accent);
  font-weight: 700;
  margin: 14px 0 0;
}

/* ===== 主版块布局:头条 + sidebar(briefs/AI/Tech) ===== */
.layout-main {
  display: grid;
  grid-template-columns: 1.55fr 1fr;
  gap: 22px;
  margin-bottom: 28px;
}

.layout-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ===== 头条议题 ===== */
.topic--headline {
  border: 3px solid var(--ink);
  padding: 0;
  background: var(--paper);
}

.topic--headline > .ornament {
  display: none;
}

.topic--headline > .section-label {
  display: block;
  margin: 0;
  padding: 12px 18px;
  font-size: 16px;
  text-align: left;
}

.topic__cover--headline {
  margin: 0;
  border-bottom: 2px solid var(--ink);
  height: 320px;
  overflow: hidden;
}

.topic__cover--headline img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.topic--headline .topic__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 12px 18px 0;
  margin: 0;
}

.topic--headline .topic__title {
  font-family: var(--sans-zh);
  font-size: 26px;
  font-weight: 900;
  line-height: 1.28;
  color: var(--ink);
  margin: 10px 18px 8px;
  letter-spacing: 1px;
  border-bottom: none;
}

.topic--headline .topic__subtitle {
  font-family: var(--serif-zh);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.65;
  color: var(--ink);
  padding: 12px 14px;
  margin: 0 18px;
  background: var(--paper-soft);
  border-left: 4px solid var(--accent);
}

.topic--headline .topic__lede {
  font-size: 15px;
  line-height: 1.85;
  text-align: justify;
  padding: 14px 18px 4px;
  margin: 0;
  text-indent: 2em;
}

.topic--headline .topic__lede::first-letter {
  font-family: var(--serif-zh);
  font-size: 48px;
  font-weight: 900;
  float: left;
  line-height: 1;
  margin: 4px 6px 0 0;
  color: var(--accent);
}

.topic--headline .body-section {
  padding: 0 18px;
  margin-top: 8px;
  /* 双栏 */
  column-count: 2;
  column-gap: 22px;
}

.topic--headline .body-section__heading {
  font-family: var(--sans-zh);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--ink);
  margin: 6px 0 6px;
  column-span: all;
  border-left: 3px solid var(--accent);
  padding-left: 8px;
}

.topic--headline .body-section__paragraphs p {
  font-size: 14px;
  line-height: 1.85;
  text-align: justify;
  margin: 0 0 10px;
  text-indent: 2em;
}

/* ===== 标签胶囊 ===== */
.topic__tag {
  font-family: var(--sans-zh);
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  border: 1px solid var(--ink);
  background: var(--paper);
  color: var(--ink);
  letter-spacing: 0.5px;
}

.topic__tags .topic__tag:first-child {
  background: var(--ink);
  color: var(--paper);
}

/* ===== 速览 / Briefs(sidebar) ===== */
.briefs {
  border: 2px solid var(--ink);
  background: var(--paper);
}

.briefs > .ornament {
  display: none;
}

.briefs > .section-label {
  display: block;
  margin: 0;
  padding: 8px 14px;
  font-size: 14px;
  border-bottom: 2px solid var(--accent);
}

.brief {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px dashed var(--rule-warm);
}

.brief:last-child {
  border-bottom: none;
}

.brief__bullet {
  font-family: var(--sans-zh);
  font-weight: 900;
  color: var(--accent);
  font-size: 14px;
}

.brief__headline {
  font-size: 13px;
  line-height: 1.6;
  margin: 0;
}

.brief__sources {
  grid-column: 2;
  font-family: var(--sans-zh);
  font-size: 10.5px;
  color: var(--ink-soft);
  margin-top: 2px;
}

/* ===== AI Pulse / Tech Pulse(sidebar) ===== */
.ai-pulse,
.tech-pulse {
  border: 2px solid var(--ink);
  border-top: 6px solid var(--ink);
  background: var(--paper);
}

.ai-pulse__masthead,
.tech-pulse__masthead {
  background: var(--ink);
  color: var(--paper);
  padding: 12px 15px;
  font-family: var(--sans-zh);
  border-bottom: 3px solid var(--accent);
}

.ai-pulse__label,
.tech-pulse__label {
  font-weight: 900;
  font-size: 18px;
  letter-spacing: 2px;
  font-family: var(--serif-en);
}

.ai-pulse__sublabel,
.tech-pulse__sublabel {
  font-size: 11px;
  letter-spacing: 4px;
  color: var(--paper-deep);
  margin-top: 2px;
}

.ai-feature,
.tech-feature {
  padding: 14px 15px 10px;
  border-bottom: 1px dashed var(--rule-warm);
}

.topic__cover--pulse {
  margin: 0 0 10px;
  height: 160px;
  overflow: hidden;
  border: 1px solid var(--ink);
}

.topic__cover--pulse img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ai-feature__title,
.tech-feature__title {
  font-family: var(--sans-zh);
  font-size: 16px;
  font-weight: 900;
  line-height: 1.3;
  margin: 0 0 8px;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 6px;
}

.ai-feature__lede,
.tech-feature__lede {
  font-size: 13px;
  line-height: 1.7;
  margin: 0 0 8px;
  font-style: italic;
  color: var(--ink-soft);
}

.ai-feature__body,
.tech-feature__body {
  font-size: 13px;
  line-height: 1.8;
  text-align: justify;
  margin: 0;
  text-indent: 2em;
}

.ai-feature__sources,
.tech-feature__sources {
  font-family: var(--sans-zh);
  font-size: 10.5px;
  color: var(--ink-soft);
  margin-top: 8px;
}

.ai-briefs,
.tech-briefs {
  padding: 10px 15px 12px;
}

.ai-briefs__heading,
.tech-briefs__heading {
  font-family: var(--sans-zh);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 3px;
  color: var(--accent);
  margin-bottom: 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--ink);
}

.ai-briefs__heading::before,
.ai-briefs__heading::after {
  content: none;
}

.ai-briefs .brief,
.tech-briefs .brief {
  padding: 8px 0;
}

/* ===== 重要议题 grid-3 卡片 ===== */
.layout-majors {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 4px double var(--ink);
}

.topic--major {
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 0;
  display: flex;
  flex-direction: column;
}

.topic__cover--major {
  margin: 0;
  height: 180px;
  overflow: hidden;
  border-bottom: 1px solid var(--ink);
}

.topic__cover--major img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.topic--major .topic__tags {
  padding: 8px 12px;
  border-bottom: 1px solid var(--ink);
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 0;
}

.topic--major .topic__title {
  font-family: var(--sans-zh);
  font-size: 17px;
  font-weight: 900;
  line-height: 1.32;
  color: var(--ink);
  margin: 12px 14px 8px;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 8px;
}

.topic--major .topic__lede {
  font-size: 13px;
  line-height: 1.7;
  text-align: justify;
  margin: 0 14px 10px;
  padding: 8px 10px;
  background: var(--paper-soft);
  border-left: 3px solid var(--ink);
}

.topic--major .body-section {
  padding: 0 14px;
}

.topic--major .body-section__heading {
  font-family: var(--sans-zh);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 1px;
  margin: 4px 0;
  color: var(--accent);
}

.topic--major .body-section__paragraphs p {
  font-size: 12.5px;
  line-height: 1.7;
  text-align: justify;
  margin: 0 0 6px;
  text-indent: 2em;
}

/* ===== 头条独有元素(perspectives / consensus / disputes / why) ===== */
.pull-quote {
  margin: 14px 18px;
  padding: 14px 16px;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  background: var(--paper-soft);
}

.pull-quote__text {
  font-family: var(--serif-zh);
  font-size: 17px;
  font-weight: 500;
  line-height: 1.55;
  margin: 0;
  text-align: center;
  color: var(--ink);
}

.pull-quote__text::before {
  content: "“";
  color: var(--accent);
  margin-right: 4px;
}

.pull-quote__text::after {
  content: "”";
  color: var(--accent);
  margin-left: 4px;
}

.pull-quote__attribution {
  text-align: right;
  font-family: var(--sans-zh);
  font-size: 11px;
  color: var(--accent);
  margin: 8px 0 0;
  letter-spacing: 1px;
}

.perspectives,
.consensus,
.disputes,
.why-it-matters {
  margin: 14px 18px;
  padding: 14px 16px;
  border: 1px solid var(--ink);
  background: var(--paper);
}

.perspectives__heading,
.consensus__heading,
.disputes__heading,
.why-it-matters__heading {
  font-family: var(--sans-zh);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 4px;
  color: var(--paper);
  background: var(--ink);
  padding: 4px 10px;
  display: inline-block;
  margin: -22px 0 12px;
  border-bottom: 2px solid var(--accent);
}

.perspectives__heading::before,
.perspectives__heading::after {
  content: none;
}

.perspective {
  padding: 10px 0;
  border-bottom: 1px dashed var(--rule-warm);
}

.perspective:last-child {
  border-bottom: none;
}

.perspective__head {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
}

.perspective__outlet {
  font-family: var(--sans-zh);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink);
}

.perspective__outlet-zh {
  color: var(--ink-soft);
  font-weight: 500;
}

.perspective__source-ref a {
  color: var(--accent);
  text-decoration: none;
  font-family: var(--sans-zh);
  font-size: 12px;
}

.perspective__stance {
  font-size: 11px;
  color: var(--ink-soft);
  font-style: italic;
}

.perspective__angle {
  font-size: 13px;
  color: var(--ink);
  margin-bottom: 6px;
}

.perspective__quote {
  font-size: 13px;
  font-style: italic;
  color: var(--ink-soft);
  margin: 4px 0;
  padding-left: 10px;
  border-left: 2px solid var(--rule-warm);
}

.perspective__quote-zh {
  font-size: 13px;
  color: var(--ink);
  margin: 4px 0;
  padding-left: 10px;
  border-left: 2px solid var(--rule-warm);
}

.consensus__list {
  margin: 0;
  padding-left: 18px;
}

.consensus__item {
  font-size: 13px;
  line-height: 1.7;
  margin-bottom: 4px;
}

.consensus__sources {
  font-family: var(--sans-zh);
  font-size: 11px;
  color: var(--accent);
  margin-left: 6px;
}

.dispute {
  margin-bottom: 12px;
}

.dispute__issue {
  font-family: var(--sans-zh);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink);
  margin-bottom: 6px;
}

.dispute__positions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.position {
  border: 1px solid var(--rule-warm);
  padding: 8px 10px;
  background: var(--paper-soft);
}

.position__label {
  font-family: var(--sans-zh);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 4px;
  letter-spacing: 1px;
}

.position__view {
  font-size: 12.5px;
  line-height: 1.6;
  margin: 0 0 4px;
}

.position__sources {
  font-family: var(--sans-zh);
  font-size: 11px;
  color: var(--ink-soft);
}

.why-it-matters__body {
  font-size: 13.5px;
  line-height: 1.8;
  margin: 0;
  text-indent: 2em;
}

.body-section .src-ref a {
  color: var(--accent);
  text-decoration: none;
  font-family: var(--sans-zh);
  font-size: 11px;
  vertical-align: super;
}

/* ===== 来源索引 ===== */
.source-index {
  border: 1px solid var(--ink);
  margin-top: 28px;
}

.source-index__heading {
  background: var(--ink);
  color: var(--paper);
  padding: 10px 15px;
  font-family: var(--sans-zh);
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 2px;
  border-bottom: 2px solid var(--accent);
}

.source-index__subheading {
  display: none;
}

.source-list {
  padding: 14px 16px;
  margin: 0;
  list-style: none;
  display: block;
}

.source-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px dashed var(--rule-warm);
  font-size: 12px;
  line-height: 1.5;
}

.source-item__id {
  font-family: var(--sans-zh);
  font-weight: 900;
  color: var(--accent);
}

.source-item__outlet {
  font-family: var(--sans-zh);
  font-weight: 700;
  color: var(--ink);
}

.source-item__stance {
  font-size: 11px;
  color: var(--ink-soft);
  font-style: italic;
}

.source-item__title {
  color: var(--ink);
}

.source-item__url a {
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 11px;
  word-break: break-all;
}

/* ===== 页脚 ===== */
.colophon {
  text-align: center;
  border-top: 4px double var(--ink);
  padding: 18px 0 0;
  margin-top: 28px;
  font-family: var(--sans-zh);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--ink-soft);
}

.colophon__rule {
  display: none;
}

/* ===== 响应式 ===== */
@media (max-width: 900px) {
  .page {
    padding: 24px;
    margin: 12px auto;
  }

  .masthead__wordmark-zh {
    font-size: 32px;
    letter-spacing: 4px;
  }

  .layout-main {
    grid-template-columns: 1fr;
  }

  .topic--headline .body-section {
    column-count: 1;
  }

  .layout-majors {
    grid-template-columns: 1fr;
  }

  .observation__body {
    grid-template-columns: 1fr;
  }

  .source-list {
    grid-template-columns: 1fr;
  }

  .topic__cover--headline {
    height: 240px;
  }
}

/* ============================================================
  v2.1 §Step 9 · archive 卡片流(china_perspective 板块 archive_mode)
  设计稿:docs/plans/2026-05-14-v2.1-china-perspective-archive.md §7.2-§7.5
  ============================================================ */

/* 事件容器(§7.3)*/
.archive-event-container {
  margin-bottom: 32px;
}

.archive-event-container + .archive-event-container {
  border-top: 4px double var(--ink);
  padding-top: 24px;
}

/* 单卡片容器(§7.2)*/
.archive-cards {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 16px;
}

.archive-card {
  background: var(--paper);
  border: 1px solid var(--rule-warm);
  padding: 28px 32px;
  position: relative;
}

.archive-card__header {
  margin-bottom: 14px;
}

/* 源名(中英),决策 5 D1 — 跟 v2 整体 Serif Bold + 字间距风格融入 */
.archive-source-name {
  font-family: var(--serif-zh);
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 2px;
  line-height: 1.2;
  color: var(--ink);
}

.archive-source-name-en {
  font-family: var(--serif-en);
  font-size: 17px;
  font-style: italic;
  color: var(--ink-soft);
  margin-top: 2px;
  letter-spacing: 0.5px;
}

/* 中译标题 + 原标题 */
.archive-title-zh {
  font-family: var(--serif-zh);
  font-size: 21px;
  font-weight: 700;
  line-height: 1.4;
  margin: 12px 0 4px;
  color: var(--ink);
}

.archive-title-en {
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-soft);
  margin-bottom: 10px;
  line-height: 1.4;
}

/* 元信息行 */
.archive-meta {
  font-family: var(--sans-zh);
  font-size: 12px;
  color: var(--ink-soft);
  letter-spacing: 0.5px;
  margin-bottom: 12px;
}

/* audit_warnings tooltip(决策 3 B3,hover 显示) */
.archive-audit-warning {
  display: inline-block;
  margin-left: 6px;
  color: var(--accent);
  cursor: help;
  font-size: 13px;
}

.archive-divider {
  border: none;
  border-top: 1px solid var(--rule-warm);
  margin: 14px 0;
}

/* 译文正文(§7.2 — 15px Serif 1.8 line-height) */
.archive-translation {
  font-family: var(--serif-zh);
  font-size: 15px;
  line-height: 1.8;
  color: var(--ink);
}

.archive-translation p {
  margin: 0 0 12px;
  text-indent: 2em;
}

.archive-translation p:last-child {
  margin-bottom: 0;
}

.archive-translation h1,
.archive-translation h2,
.archive-translation h3,
.archive-translation h4,
.archive-translation h5,
.archive-translation h6,
.detail-page__article h1,
.detail-page__article h2,
.detail-page__article h3,
.detail-page__article h4,
.detail-page__article h5,
.detail-page__article h6,
.observation-v2__body h1,
.observation-v2__body h2,
.observation-v2__body h3,
.observation-v2__body h4,
.observation-v2__body h5,
.observation-v2__body h6 {
  margin: 0 0 12px;
  line-height: 1.35;
}

.archive-translation ul,
.archive-translation ol,
.detail-page__article ul,
.detail-page__article ol,
.observation-v2__body ul,
.observation-v2__body ol {
  margin: 0 0 14px;
  padding-left: 24px;
}

.archive-translation blockquote,
.detail-page__article blockquote,
.observation-v2__body blockquote {
  margin: 0 0 14px;
  padding-left: 14px;
  border-left: 3px solid var(--rule-warm);
  color: var(--ink-soft);
}

.archive-translation pre,
.detail-page__article pre,
.observation-v2__body pre {
  overflow-x: auto;
  margin: 0 0 14px;
  padding: 12px 14px;
  background: rgba(26, 26, 26, 0.04);
}

.archive-translation code,
.detail-page__article code,
.observation-v2__body code {
  font-family: "SFMono-Regular", "Menlo", monospace;
}

/* fallback 翻译标注(§7.4) */
.archive-fallback-note {
  font-family: var(--sans-zh);
  font-style: italic;
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 10px;
  padding: 6px 10px;
  background: var(--paper-soft);
  border-left: 3px solid var(--accent);
}

/* 卡片底部 */
.archive-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid var(--rule-warm);
  font-family: var(--sans-zh);
  font-size: 12px;
  color: var(--ink-soft);
  letter-spacing: 0.5px;
}

.archive-original-link {
  color: var(--accent);
  text-decoration: none;
  font-weight: 500;
}

.archive-original-link:hover {
  text-decoration: underline;
}

/* 移动端响应式(§7.5)*/
@media (max-width: 900px) {
  .archive-card {
    padding: 18px 16px;
  }

  .archive-source-name {
    font-size: 22px;
    letter-spacing: 1px;
  }

  .archive-source-name-en {
    font-size: 14px;
  }

  .archive-title-zh {
    font-size: 18px;
  }

  .archive-translation {
    font-size: 14.5px;
    line-height: 1.75;
  }
}

/* ============================================================
  v2.2 A2 · 全文页 + 阅读全文按钮(daily 主版面 + full 单文页)
  ============================================================ */

/* daily 主版面"阅读全文"按钮(footer 第一项) */
.archive-full-link {
  display: inline-block;
  margin-right: 12px;
  font-size: 12px;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 1px;
  letter-spacing: 0.5px;
  font-weight: 500;
}

.archive-full-link:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* 全文页外壳 */
.full-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 32px 32px;
  background: var(--bg-paper);
  color: var(--ink);
  font-family: var(--serif-zh);
  line-height: 1.7;
}

.full-page__nav {
  margin-bottom: 24px;
}

.full-page__back {
  font-size: 14px;
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px solid var(--ink-soft);
  padding-bottom: 1px;
}

.full-page__back:hover {
  color: var(--ink);
  border-bottom-color: var(--ink);
}

.full-page__header {
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 4px double var(--ink);
}

.full-page__source {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 1px;
}

.full-page__meta {
  font-size: 13px;
  color: var(--ink-soft);
  margin: 8px 0 16px;
}

.full-page__title-zh {
  font-size: 28px;
  line-height: 1.4;
  margin: 12px 0 4px;
  font-weight: 700;
}

.full-page__title-en {
  font-size: 16px;
  color: var(--ink-soft);
  font-style: italic;
}

.detail-hero-image {
  margin: 0 0 22px;
  border: 1px solid rgba(26, 26, 26, 0.18);
  background: #ded9cd;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(35, 24, 10, 0.12);
}

.detail-hero-image img {
  display: block;
  width: 100%;
  max-height: 420px;
  object-fit: cover;
}

.detail-hero-image figcaption {
  padding: 8px 14px;
  font-family: var(--sans-zh);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  background: rgba(255, 255, 255, 0.72);
}

/* 中英对照 grid 主体 */
.full-page__bilingual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

.full-page__zh,
.full-page__en {
  min-width: 0;
}

.full-page__column-label {
  font-size: 12px;
  color: var(--ink-soft);
  letter-spacing: 2px;
  margin-bottom: 16px;
  text-transform: uppercase;
  font-weight: 600;
}

.full-page__zh p,
.full-page__en p {
  font-size: 15px;
  line-height: 1.85;
  margin: 0 0 14px;
}

.full-page__en p {
  font-family: var(--serif-en, Georgia, serif);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.full-page__footer {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--rule-warm);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
}

.full-page__external {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid var(--accent);
  padding-bottom: 1px;
}

/* B-3 决策:沿用 max-width: 900px 断点(grid → 单列) */
@media (max-width: 900px) {
  .full-page {
    padding: 18px;
  }

  .full-page__title-zh {
    font-size: 22px;
  }

  .full-page__bilingual {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .full-page__en {
    padding-top: 24px;
    border-top: 1px solid var(--rule-warm);
  }
}

/* ============================================================
  详情页(.detail-page)— 单栏纯中文,阅读宽度 800px 居中
  跟 full-page 的双栏中英对照分开;复用 full-page 大部分元素样式。
  ============================================================ */
.full-page.detail-page {
  max-width: 800px;
}

.detail-page__main {
  /* block 流,单栏满宽 */
}

.detail-page__article p {
  font-size: 16px;
  line-height: 1.9;
  margin: 0 0 16px;
}

.detail-page__lede {
  font-size: 16px;
  color: var(--ink-soft);
  margin: 0 0 24px;
  padding-left: 16px;
  border-left: 3px solid var(--rule-warm);
}

.detail-page__sources {
  font-size: 13px;
  color: var(--ink-soft);
}

.detail-page__sources a {
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px dotted var(--ink-soft);
  margin-right: 4px;
}

.detail-page__sources a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* === v2 板块化版面叠加样式(在 theme.css 之上) === */
:root {
  --bg-paper: #fbf9f4;
  --bg-card: #ffffff;
  --bg-observation: #f5f2ea;
  --text-primary: #1a1a1a;
  --text-secondary: #666666;
  --text-tertiary: #999999;
  --accent: #8b0000;
  --line-strong: #000000;
  --line-weak: #dddddd;
  --font-serif-cn:
    "Source Han Serif SC", "Noto Serif SC", "Songti SC", "SimSun", serif;
  --font-serif-en: "Playfair Display", "Cormorant Garamond", Georgia, serif;
  --font-sans:
    "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
}

body {
  background: var(--bg-paper);
  color: var(--text-primary);
}

.page-v2 {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px 48px;
  font-family: var(--font-serif-cn);
}

.masthead-v2 {
  text-align: center;
  padding: 32px 0 16px;
  border-bottom: 3px solid var(--line-strong);
  position: relative;
}

.masthead-v2__wordmark-en {
  font-family: var(--font-serif-en);
  font-size: 48px;
  letter-spacing: 4px;
  font-weight: 700;
}

.masthead-v2__wordmark-zh {
  font-size: 28px;
  margin: 4px 0 12px;
  letter-spacing: 8px;
  font-weight: 700;
}

.masthead-v2__meta {
  font-family: var(--font-sans);
  font-size: 13px;
  letter-spacing: 1px;
  color: var(--text-secondary);
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

.observation-v2 {
  background: var(--bg-observation);
  padding: 28px 36px;
  margin: 24px 0;
  border-bottom: 1px solid var(--line-strong);
}

.observation-v2__title {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 6px;
}

.observation-v2__subtitle {
  color: var(--text-secondary);
  margin-bottom: 14px;
  font-style: italic;
}

.observation-v2__body p {
  font-size: 16px;
  line-height: 1.75;
  margin: 0 0 12px;
  text-indent: 2em;
}

.observation-v2__signature {
  text-align: right;
  color: var(--text-tertiary);
  margin-top: 12px;
  font-size: 13px;
}

.headline-v2 {
  padding: 28px 0 32px;
  border-bottom: 2px solid var(--line-strong);
}

.headline-v2__title {
  font-size: 36px;
  font-weight: 700;
  line-height: 1.3;
  margin: 8px 0;
}

.headline-v2__tags {
  font-size: 12px;
  color: var(--text-tertiary);
  letter-spacing: 2px;
  line-height: 1.7;
  margin: 0 0 12px;
}

.headline-v2__subtitle {
  font-size: 18px;
  font-style: italic;
  color: var(--text-secondary);
  margin-bottom: 16px;
}

.inline-source-ref {
  font-size: 11px;
  color: var(--text-tertiary);
}

.inline-source-ref a {
  color: inherit;
  text-decoration: none;
}

.inline-source-ref a:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.headline-v2__lede {
  font-size: 17px;
  line-height: 1.75;
  font-weight: 600;
}

.headline-v2__body {
  font-size: 16px;
  line-height: 1.75;
}

.headline-v2__body-section {
  font-weight: 700;
  margin: 14px 0 6px;
}

.headline-v2__body p {
  text-indent: 2em;
  margin: 10px 0;
}

.headline-v2__cover {
  float: right;
  width: 380px;
  max-width: 50%;
  margin: 0 0 12px 24px;
}

.headline-v2__cover img {
  width: 100%;
  height: auto;
}

.headline-v2__cover--corner {
  width: 320px;
  max-width: 42%;
  margin: 4px 0 16px 24px;
  overflow: hidden;
}

.headline-v2__cover--corner img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.section-divider-v2 {
  margin: 40px 0 24px;
  padding: 16px 0 0;
  border-top: 4px solid var(--line-strong);
  position: relative;
}

.section-divider-v2::after {
  content: "";
  display: block;
  height: 1px;
  background: var(--line-strong);
  margin-top: 1px;
}

.section-divider-v2__name {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 8px;
  text-align: center;
  padding: 12px 0 16px;
}

.section-lead-v2 {
  padding: 12px 0 24px;
  border-bottom: 1px solid var(--line-strong);
  margin-bottom: 24px;
}

.section-lead-v2__title {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.35;
}

.section-lead-v2__subtitle {
  font-style: italic;
  color: var(--text-secondary);
  margin: 6px 0 12px;
}

.section-lead-v2__lede {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.7;
}

.section-lead-v2__body p {
  font-size: 15px;
  line-height: 1.75;
  text-indent: 2em;
  margin: 8px 0;
}

.section-lead-v2__cover {
  float: right;
  width: 300px;
  max-width: 45%;
  margin: 0 0 12px 18px;
}

.section-lead-v2__cover img {
  width: 100%;
  height: auto;
}

.section-lead-v2__cover--corner {
  width: 280px;
  max-width: 40%;
  margin: 4px 0 16px 20px;
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(35, 24, 10, 0.14);
}

.section-lead-v2__cover--corner img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.section-lead-v2__cover--stacked {
  float: none;
  width: 100%;
  max-width: none;
  margin: 0 0 14px;
}

.section-items-v2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.section-items-v2__item {
  padding: 18px 24px;
  border-top: 1px solid var(--line-weak);
}

.item-v2__cover {
  width: 100%;
  margin: 0 0 14px;
  overflow: hidden;
  box-shadow: 0 10px 20px rgba(35, 24, 10, 0.12);
}

.item-v2__cover img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.section-items-v2__item--lead {
  padding-top: 8px;
}

.section-items-v2__item:nth-child(odd) {
  border-right: 1px solid var(--line-weak);
}

.section-items-v2__item:nth-child(-n + 2) {
  border-top: none;
  padding-top: 8px;
}

.item-v2__rank {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--text-tertiary);
}

.item-v2__title {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.35;
  margin: 4px 0 8px;
}

.item-v2__lede {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.65;
  margin: 0 0 8px;
}

.item-v2__body {
  font-size: 14px;
  line-height: 1.65;
}

.item-v2__body p {
  text-indent: 2em;
  margin: 6px 0;
}

.item-v2__sources,
.section-lead-v2__sources,
.headline-v2__sources {
  font-family: var(--font-sans);
  font-size: 11px;
  color: var(--text-tertiary);
  margin-top: 8px;
}

.content-link-row {
  margin-top: 14px;
}

.article-detail-page {
  padding-bottom: 56px;
}

.article-detail-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin: 22px 0 8px;
  font-family: var(--font-sans);
  font-size: 13px;
}

.article-detail-nav a {
  color: var(--accent);
  text-decoration: none;
}

.article-detail-nav a:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.article-detail-nav--bottom {
  margin: 28px 0 0;
  padding-top: 16px;
  border-top: 1px solid var(--line-strong);
}

.article-detail-body {
  font-size: 16px;
  line-height: 1.85;
}

.detail-bilingual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 22px;
  align-items: start;
}

.detail-bilingual__column {
  min-width: 0;
  padding: 18px 20px;
  background: linear-gradient(180deg, rgba(247, 243, 232, 0.92), rgba(255, 255, 255, 0.78));
  border: 1px solid var(--line-weak);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.detail-bilingual__column .full-page__column-label {
  margin-bottom: 14px;
}

.article-detail-body--original {
  font-family: "Georgia", "Times New Roman", serif;
  font-size: 15px;
  line-height: 1.9;
  color: var(--text-secondary);
}

.detail-page__meta {
  margin: 0 0 8px;
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--text-tertiary);
  letter-spacing: 1px;
}

.article-detail-body p {
  margin: 12px 0;
  text-indent: 2em;
}

.article-detail-body--original p {
  text-indent: 0;
}

.colophon-v2 {
  margin-top: 48px;
  padding-top: 18px;
  border-top: 1px solid var(--line-strong);
  text-align: center;
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--text-secondary);
}

.why-matters-v2 {
  background: rgba(139, 0, 0, 0.04);
  padding: 12px 18px;
  margin-top: 14px;
  border-left: 3px solid var(--accent);
  font-size: 14px;
  line-height: 1.7;
}

.perspectives-v2 {
  margin-top: 18px;
  padding: 14px 0 4px;
  border-top: 1px solid var(--line-weak);
}

.perspectives-v2__heading {
  font-size: 13px;
  letter-spacing: 4px;
  font-weight: 700;
  margin-bottom: 10px;
}

.perspective-v2 {
  margin: 10px 0;
  padding-left: 16px;
  border-left: 2px solid var(--line-weak);
}

.perspective-v2__outlet {
  font-weight: 700;
  font-size: 13px;
}

.perspective-v2__angle {
  font-style: italic;
  color: var(--text-secondary);
  font-size: 13px;
  margin: 4px 0;
}

.perspective-v2__quote-zh {
  font-size: 14px;
  line-height: 1.7;
  margin: 4px 0;
}

.source-index-v2 {
  margin-top: 36px;
  padding-top: 18px;
  border-top: 1px solid var(--line-strong);
  font-family: var(--font-sans);
  font-size: 12px;
}

.source-index-v2__heading {
  font-size: 14px;
  letter-spacing: 4px;
  font-weight: 700;
  margin-bottom: 12px;
}

.source-index-v2 ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.source-index-v2__extra {
  margin-top: 8px;
}

.source-index-v2__list + .source-index-v2__list {
  margin-top: 8px;
}

.source-index-v2 li {
  padding: 4px 0;
  color: var(--text-secondary);
  overflow-wrap: anywhere;
  word-break: break-word;
  scroll-margin-top: 56px;
}

.source-index-v2--collapsible.is-collapsed .source-index-v2__extra {
  display: none;
}

.source-index-v2__toggle {
  margin-top: 12px;
  margin-bottom: 4px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--accent);
  font: inherit;
  font-size: 13px;
  letter-spacing: 0.5px;
  cursor: pointer;
  border-bottom: 1px solid var(--accent);
}

.source-index-v2__toggle:hover {
  color: var(--ink);
  border-bottom-color: var(--ink);
}

.source-index-v2 .si-id {
  font-weight: 700;
  color: var(--text-primary);
  margin-right: 8px;
}

.source-index-v2 a {
  color: var(--accent);
  text-decoration: none;
  overflow-wrap: anywhere;
  word-break: break-all;
}

/* ===== 评论区 / 读者来函栏 ===== */
.detail-page__comments {
  margin-top: 32px;
  padding: 18px 20px 20px;
  border: 3px double var(--ink);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.28), transparent 32%),
    var(--paper-soft);
  box-shadow:
    inset 0 0 0 1px rgba(139, 115, 85, 0.28),
    0 10px 20px rgba(26, 26, 26, 0.05);
}

.detail-page__comments-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--ink);
}

.detail-page__comments-kicker {
  margin: 0 0 4px;
  font-family: var(--sans-zh);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--accent);
}

.detail-page__comments-header h2 {
  margin: 0;
  font-family: var(--sans-zh);
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 1px;
}

.detail-page__comments-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  padding: 4px 12px;
  border: 1px solid var(--ink);
  background: var(--paper);
  font-family: var(--sans-zh);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--ink-soft);
}

.detail-page__comment-form {
  margin-bottom: 18px;
  padding: 16px;
  border: 1px solid var(--rule-warm);
  background: rgba(245, 242, 232, 0.72);
}

.detail-page__comment-form label {
  display: block;
  margin-bottom: 8px;
  font-family: var(--sans-zh);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--ink);
}

.detail-page__comment-form textarea {
  width: 100%;
  min-height: 118px;
  resize: vertical;
  padding: 12px 14px;
  border: 1px solid var(--ink);
  background: rgba(255, 255, 255, 0.46);
  color: var(--ink);
  font-family: var(--serif-zh);
  font-size: 14px;
  line-height: 1.75;
}

.detail-page__comment-form textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(183, 28, 28, 0.1);
}

.detail-page__comment-form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 10px;
}

.detail-page__comment-form-note {
  margin: 0;
  font-family: var(--sans-zh);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--ink-soft);
}

.detail-page__comment-form button,
.detail-page__comment-delete-form button {
  appearance: none;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--sans-zh);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  padding: 8px 14px;
  cursor: pointer;
  transition:
    background 120ms ease,
    color 120ms ease,
    border-color 120ms ease,
    transform 120ms ease;
}

.detail-page__comment-form button:hover,
.detail-page__comment-delete-form button:hover {
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-1px);
}

.detail-page__comment-feedback {
  margin: 12px 0 0;
  padding: 8px 10px;
  border-left: 3px solid var(--accent);
  background: rgba(183, 28, 28, 0.08);
  color: var(--ink);
  font-family: var(--sans-zh);
  font-size: 12px;
}

.detail-page__comment-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.detail-page__comment-item {
  padding: 14px 0 16px;
  border-bottom: 1px dashed var(--rule-warm);
}

.detail-page__comment-item:last-child {
  padding-bottom: 4px;
  border-bottom: none;
}

.detail-page__comment-item-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 8px;
}

.detail-page__comment-index {
  flex: 0 0 auto;
  min-width: 34px;
  padding-top: 1px;
  font-family: var(--sans-zh);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 1px;
  color: var(--accent);
}

.detail-page__comment-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px 12px;
  font-family: var(--sans-zh);
}

.detail-page__comment-meta strong {
  font-size: 13px;
  letter-spacing: 0.5px;
}

.detail-page__comment-meta span {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--ink-soft);
}

.detail-page__comment-body {
  margin: 0 0 10px 46px;
  font-size: 14px;
  line-height: 1.85;
  text-align: justify;
  color: var(--ink);
}

.detail-page__comment-delete-form {
  margin-left: 46px;
}

.detail-page__comment-delete-form button {
  background: transparent;
  color: var(--ink-soft);
  border-color: var(--rule-warm);
  padding: 6px 10px;
  font-size: 11px;
}

.detail-page__comment-empty {
  margin: 0;
  padding: 16px 14px;
  border: 1px dashed var(--rule-warm);
  background: rgba(255, 255, 255, 0.28);
  text-align: center;
  font-family: var(--serif-zh);
  font-size: 14px;
  color: var(--ink-soft);
}

/* === 配图(A3:16:9 cover 规整裁切),archive 卡 + 普通条目共用 === */
.archive-card__cover {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  margin: 0 0 12px;
}

.archive-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.item-cover {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  margin: 0 0 10px;
}

.item-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* === Tab 导航(file:// 兼容,纯 inline JS)=== */
.tab-nav-v2 {
  display: flex;
  gap: 0;
  margin: 24px 0 0;
  padding: 0;
  border-bottom: 2px solid var(--line-strong);
  position: sticky;
  top: 0;
  background: var(--bg-paper);
  z-index: 50;
}

.tab-nav-v2__btn {
  flex: 1;
  padding: 14px 12px;
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-secondary);
  background: transparent;
  border: 0;
  border-bottom: 3px solid transparent;
  cursor: pointer;
  letter-spacing: 1px;
  transition:
    color 120ms,
    border-color 120ms;
}

.tab-nav-v2__btn:hover {
  color: var(--text-primary);
}

.tab-nav-v2__btn.is-active {
  color: var(--text-primary);
  border-bottom-color: var(--accent);
}

.tab-panel-v2 {
  display: none;
}

.tab-panel-v2.is-active {
  display: block;
}

/* 2c:tab 模式下重复大标题隐藏,顶部分隔线保留 */
.section-divider-v2__name {
  display: none;
}

@media (max-width: 768px) {
  .page-v2 {
    padding: 0 16px 32px;
  }

  .masthead-v2__wordmark-en {
    font-size: 32px;
  }

  .masthead-v2__wordmark-zh {
    font-size: 20px;
  }

  .observation-v2 {
    padding: 18px 16px;
  }

  .observation-v2__body p {
    font-size: 15px;
  }

  .headline-v2__title {
    font-size: 28px;
  }

  .headline-v2__cover,
  .section-lead-v2__cover,
  .item-v2__cover {
    float: none;
    width: 100%;
    max-width: 100%;
    margin: 0 0 14px;
  }

  .detail-hero-image img {
    max-height: 280px;
  }

  .section-divider-v2__name {
    font-size: 22px;
    letter-spacing: 4px;
  }

  .section-items-v2 {
    grid-template-columns: 1fr;
  }

  .section-items-v2__item:nth-child(odd) {
    border-right: none;
  }

  .section-items-v2__item:nth-child(-n + 2) {
    padding-top: 18px;
    border-top: 1px solid var(--line-weak);
  }

  .section-items-v2__item:first-child {
    border-top: none;
    padding-top: 8px;
  }

  .detail-bilingual {
    grid-template-columns: 1fr;
  }
}

@media print {
  body {
    background: white;
  }

  .scoring-toggle,
  .scoring {
    display: none !important;
  }

  .section-divider-v2 {
    page-break-before: always;
  }

  .masthead-v2__wordmark-en {
    font-size: 32pt;
  }

  .headline-v2__body,
  .section-lead-v2__body,
  .item-v2__body {
    font-size: 11pt;
  }

  /* 打印时 tab 栏隐藏,三 panel 全展开,板块标题还原 */
  .tab-nav-v2 {
    display: none;
  }

  .tab-panel-v2 {
    display: block !important;
  }

  .section-divider-v2__name {
    display: block;
  }
}

/* === 评分 toggle(沿用 v1) === */
.scoring-toggle {
  position: absolute;
  top: 24px;
  right: 24px;
  background: transparent;
  border: 1px solid currentColor;
  padding: 5px 12px;
  font-size: 11.5px;
  cursor: pointer;
  opacity: 0.55;
  color: inherit;
  border-radius: 2px;
}

.scoring-toggle:hover {
  opacity: 1;
}

.scoring {
  display: none;
  margin: 12px 0;
  padding: 10px 14px;
  border-top: 1px solid var(--line-weak);
  font-size: 12.5px;
  opacity: 0.78;
}

body.show-scoring .scoring {
  display: block;
}
