/**
 * 新闻详情页专用样式（AFS 类门户风格，含桌面端与移动端）
 * 依赖 ./common.css 中的变量与字体栈；请在文章页 index.html 中于 ./common.css 之后引入本文件
 *
 * 约定：凡针对子元素的样式均写全父级选择器链（元素类型、类名、id 等组合），降低富文本内同名类名的样式串扰
 *
 * 类选择器 .detail-prose 内为接口富文本 HTML：不对其子标签写样式，以免覆盖正文自带 class/内联样式；仅对 .detail-prose 容器做防溢出等布局约束。
 */

/* ---------- 面包屑：仅作用于「导航条 + 类名 detail-breadcrumb」及其内部子节点 ---------- */
nav.detail-breadcrumb {
  font-size: 0.8125rem;
  color: var(--text-sub);
  margin: 0 0 clamp(14px, 2.5vw, 20px);
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  /* 与下方 #js-detail-mount 内 article 同列宽，左缘对齐 */
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

nav.detail-breadcrumb a {
  color: var(--text-sub);
  text-decoration: none;
  font-weight: 500;
}

nav.detail-breadcrumb a:hover {
  color: var(--link);
}

nav.detail-breadcrumb .sep {
  color: var(--text-muted);
  user-select: none;
}

nav.detail-breadcrumb .current {
  color: var(--text);
  font-weight: 600;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 559px) {
  nav.detail-breadcrumb .current {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}

/* ---------- 挂载点：与面包屑同宽，保证内层 article 左缘与 nav 左缘一致 ---------- */
#js-detail-mount {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* ---------- 加载与错误状态：仅挂载点 js-detail-mount 内、类名为 detail-state 的节点 ---------- */
#js-detail-mount .detail-state {
  margin: 0;
  padding: clamp(28px, 6vw, 48px) clamp(16px, 4vw, 28px);
  text-align: center;
  font-size: 0.9375rem;
  color: var(--text-sub);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}

#js-detail-mount .detail-state.is-error {
  color: var(--accent);
}

/* ---------- 正文卡片外壳：元素 article 且类名为 detail-article ---------- */
article.detail-article {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 0;
  box-sizing: border-box;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

/* ---------- 上述 article 内、类名为 detail-body 的区域及其子树 ---------- */
article.detail-article .detail-body {
  padding: clamp(18px, 3.5vw, 28px) clamp(16px, 3vw, 28px)
    clamp(28px, 4vw, 40px);
}

article.detail-article .detail-body .detail-header {
  margin-bottom: clamp(20px, 3vw, 28px);
  padding-bottom: clamp(16px, 2.5vw, 22px);
  border-bottom: 1px solid var(--border);
}

article.detail-article .detail-body .detail-header .detail-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  margin: 0 0 12px;
  font-size: 0.8125rem;
  color: var(--text-muted);
}

article.detail-article .detail-body .detail-header .detail-meta .detail-cat {
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.02em;
}

article.detail-article .detail-body .detail-header .detail-meta .detail-date {
  color: var(--text-sub);
}

article.detail-article .detail-body .detail-header .detail-title {
  margin: 0;
  font-size: clamp(1.25rem, 4.2vw, 1.75rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.02em;
  color: var(--text);
}

article.detail-article .detail-body .detail-header .detail-lead {
  margin: 14px 0 0;
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--text-sub);
}

/* ---------- 富文本容器 detail-prose：不选择内部标签，避免覆盖接口 HTML 自带样式 ---------- */
article.detail-article .detail-body .detail-prose {
  min-width: 0;
  word-break: break-word;
  overflow-wrap: break-word;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* 接口富文本包在 .article-content 内，便于统计顶层子节点（文中广告位等） */
article.detail-article .detail-body .detail-prose .article-content {
  min-width: 0;
}

@media (max-width: 559px) {
  article.detail-article .detail-body {
    padding-left: 14px;
    padding-right: 14px;
  }

  article.detail-article .detail-body .detail-header .detail-meta {
    gap: 6px 10px;
  }
}

/* ---------- 法律文档页 privacy.html / terms.html（正文 legal-article） ---------- */
article.legal-article {
  max-width: 100%;
  margin: 0;
  padding: clamp(8px, 2vw, 16px) 0 clamp(32px, 6vw, 56px);
  box-sizing: border-box;
}

article.legal-article .legal-body {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--text-sub);
}

article.legal-article .legal-body p {
  margin: 0 0 1.1em;
}

article.legal-article .legal-body p:last-child {
  margin-bottom: 0;
}

article.legal-article .legal-h1 {
  margin: 0 0 clamp(14px, 3vw, 22px);
  font-size: clamp(1.25rem, 4vw, 1.65rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.02em;
  color: var(--text);
}

@media (max-width: 559px) {
  article.legal-article .legal-body {
    font-size: 0.875rem;
  }
}
