/* prose.css — 长文阅读排版（methodology / faq / news_item / intel_detail）
 *
 * 设计原则：
 *   1. 列宽 68ch（约 65-72 字符）—— 编辑学最佳阅读宽度
 *   2. 行高 1.75 / 段间距 1.4em —— 暗色屏长读疲劳最小
 *   3. h2 上方 0.5px hairline + 字号阶梯 32 / 22 / 18
 *   4. <code> 内联走 mono + gold-tint 背景，区别于正文
 *   5. <ul> 走 — em-dash 项目符（替换默认圆点，编辑感）
 *   6. CJK 行尾标点压缩 + 段首悬挂
 */

.seo-prose {
  max-width: 68ch;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.75;
  color: var(--text-primary, #EAECEF);
  font-feature-settings: 'kern' 1, 'liga' 0, 'cv11' 1;
}

/* 段落 */
.seo-prose p {
  margin: 0 0 1.4em;
}
.seo-prose p:first-child {
  margin-top: 0;
}

/* 强调 */
.seo-prose strong {
  color: var(--gold-300, #FCD535);
  font-weight: 600;
}
.seo-prose em {
  color: var(--gray-50, #EAECEF);
  font-style: italic;
  letter-spacing: 0.01em;
}

/* 标题层级 */
.seo-prose h2 {
  font-family: var(--font-display);
  font-size: 1.625rem;       /* 26px */
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 2.6em 0 0.8em;
  padding-top: 1.2em;
  border-top: 1px solid var(--border-subtle, #2B3139);
  color: var(--text-primary, #EAECEF);
  position: relative;
}
.seo-prose h2:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}
.seo-prose h2::before {
  content: counter(prose-h2, decimal-leading-zero);
  counter-increment: prose-h2;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--gold-300, #FCD535);
  letter-spacing: 0.1em;
  display: block;
  margin-bottom: 0.4em;
  opacity: 0.85;
}
.seo-prose {
  counter-reset: prose-h2;
}

.seo-prose h3 {
  font-family: var(--font-display);
  font-size: 1.25rem;        /* 20px */
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.015em;
  margin: 2em 0 0.6em;
  color: var(--text-primary, #EAECEF);
}

/* 链接 */
.seo-prose a {
  color: var(--gold-300, #FCD535);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--gold-300, #FCD535) 35%, transparent);
  transition: border-color 0.15s ease, color 0.15s ease;
}
.seo-prose a:hover {
  border-bottom-color: var(--gold-300, #FCD535);
  color: #FFE25C;
}
.seo-prose a[rel*="external"]::after {
  content: '↗';
  font-size: 0.85em;
  margin-left: 0.15em;
  opacity: 0.7;
}

/* 内联代码 */
.seo-prose :not(pre) > code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  padding: 0.1em 0.45em;
  background: color-mix(in srgb, var(--gold-300, #FCD535) 10%, var(--gray-700, #181A20));
  border: 1px solid color-mix(in srgb, var(--gold-300, #FCD535) 18%, transparent);
  border-radius: 4px;
  color: var(--gold-50, #FEF9E1);
  white-space: pre;
}

/* 块级代码（pre） */
.seo-prose pre {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  line-height: 1.6;
  padding: 1em 1.2em;
  background: var(--gray-800, #0B0E11);
  border: 1px solid var(--border-subtle, #2B3139);
  border-left: 3px solid var(--gold-300, #FCD535);
  border-radius: 6px;
  overflow-x: auto;
  margin: 1.6em 0;
  color: var(--gray-50, #EAECEF);
}
.seo-prose pre code {
  background: transparent;
  border: 0;
  padding: 0;
  color: inherit;
  font-size: inherit;
}

/* 列表 */
.seo-prose ul, .seo-prose ol {
  margin: 0 0 1.4em;
  padding-left: 0;
  list-style: none;
}
.seo-prose li {
  position: relative;
  padding-left: 1.6em;
  margin-bottom: 0.5em;
}
.seo-prose ul > li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--gold-300, #FCD535);
  font-family: var(--font-mono);
  font-weight: 500;
}
.seo-prose ol {
  counter-reset: prose-ol;
}
.seo-prose ol > li {
  counter-increment: prose-ol;
}
.seo-prose ol > li::before {
  content: counter(prose-ol, decimal-leading-zero);
  position: absolute;
  left: 0;
  color: var(--gold-300, #FCD535);
  font-family: var(--font-mono);
  font-size: 0.85em;
  font-weight: 500;
}

/* 引用 */
.seo-prose blockquote {
  margin: 1.8em 0;
  padding: 0 0 0 1.5em;
  border-left: 3px solid var(--gold-300, #FCD535);
  color: var(--gray-100, #B7BDC6);
  font-style: italic;
  font-size: 1.05em;
}

/* 表格 */
.seo-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.6em 0;
  font-size: 0.9rem;
  font-variant-numeric: tabular-nums;
}
.seo-prose th, .seo-prose td {
  text-align: left;
  padding: 0.6em 0.8em;
  border-bottom: 1px solid var(--border-subtle, #2B3139);
}
.seo-prose th {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-300, #FCD535);
  border-bottom: 1.5px solid var(--gold-300, #FCD535);
}

/* 图片 / 图块 */
.seo-prose img {
  max-width: 100%;
  display: block;
  margin: 2em auto;
  border-radius: 6px;
  border: 1px solid var(--border-subtle, #2B3139);
}

/* HR — 用 monospace 字符代替 */
.seo-prose hr {
  border: 0;
  margin: 3em 0;
  text-align: center;
  height: auto;
}
.seo-prose hr::before {
  content: '◆ ◆ ◆';
  font-family: var(--font-mono);
  letter-spacing: 1em;
  color: var(--gold-700, #A68A0A);
  font-size: 0.7rem;
}

/* CJK：行尾压缩 + 中英混排自动空格（CSS Text Module 4，Chrome/Safari 已支持） */
:lang(zh) .seo-prose {
  text-spacing-trim: trim-start;
  hanging-punctuation: first allow-end last;
}
:lang(zh) .seo-prose p {
  /* CJK 段首悬挂避头尾 */
  word-break: keep-all;
  overflow-wrap: break-word;
}

/* Mobile：缩小字号 + 适度收紧 */
@media (max-width: 720px) {
  .seo-prose {
    font-size: 15px;
    line-height: 1.7;
  }
  .seo-prose h2 {
    font-size: 1.4rem;
    margin-top: 2.2em;
  }
  .seo-prose h3 {
    font-size: 1.1rem;
  }
}

/* Print：优化打印 */
@media print {
  .seo-prose {
    color: #000;
    max-width: 100%;
    font-size: 11pt;
  }
  .seo-prose a {
    color: #000;
    border-bottom: 1px solid #999;
  }
  .seo-prose a[rel*="external"]::after {
    content: ' (' attr(href) ')';
    font-size: 0.8em;
    color: #666;
  }
}
