/* ============================================================
 * Timedecimal 组件样式（header / footer / button / card / nav）
 * 文件：assets/css/components.css
 * 说明：所有页面共享的可复用组件。
 * ============================================================ */

/* ====== 顶部导航 ====== */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: rgba(250,250,250,0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border);
}
.site-header .nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: var(--space-4);
}

/* 品牌 Logo */
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.125rem;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  text-decoration: none;
}
.brand:hover { color: var(--text-primary); text-decoration: none; }
.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  background: var(--text-primary);
  color: var(--text-on-dark);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 1rem;
}

/* 主菜单（桌面） */
.main-nav {
  display: none;
  align-items: center;
  gap: var(--space-2);
}
.main-nav a {
  color: var(--text-secondary);
  font-weight: 500;
  font-size: var(--fs-small);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--r-sm);
  text-decoration: none;
}
.main-nav a:hover,
.main-nav a[aria-current="page"] {
  color: var(--text-primary);
  background: var(--bg-soft);
}

/* 顶部 CTA 按钮（仅桌面） */
.nav-cta { display: none; }

/* 汉堡菜单按钮 */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  width: var(--touch-min); height: var(--touch-min);
  cursor: pointer;
}
.nav-toggle:focus-visible { outline: 0; box-shadow: var(--sh-focus); }
.nav-toggle svg { width: 24px; height: 24px; stroke: var(--text-primary); }

/* 移动端展开后的菜单 */
.mobile-nav {
  display: none;
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  padding: var(--space-3) var(--space-5) var(--space-5);
}
.mobile-nav[data-open="true"] { display: block; }
.mobile-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.mobile-nav a {
  display: flex;
  align-items: center;
  min-height: var(--touch-min);
  color: var(--text-primary);
  font-weight: 500;
  padding: 0 var(--space-3);
  border-radius: var(--r-sm);
  text-decoration: none;
}
.mobile-nav a:hover,
.mobile-nav a[aria-current="page"] { background: var(--bg-soft); text-decoration: none; }
.mobile-nav .group-label {
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-tertiary);
  font-weight: 700;
  padding: var(--space-3) var(--space-3) var(--space-1);
}

@media (min-width: 1024px) {
  .main-nav { display: flex; }
  .nav-toggle { display: none; }
  .nav-cta { display: inline-flex; }
}

/* ====== 按钮 ====== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: var(--touch-min);
  padding: 0 var(--space-5);
  border: 1px solid transparent;
  border-radius: var(--r-md);
  background: var(--text-primary);
  color: var(--text-on-dark);
  font-weight: 600;
  font-size: var(--fs-small);
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--dur-fast), background var(--dur-fast);
  white-space: nowrap;
  letter-spacing: -0.005em;
}
.btn:hover { color: var(--text-on-dark); background: #1a1a1d; text-decoration: none; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn:focus-visible { outline: 0; box-shadow: var(--sh-focus); }

.btn-primary { background: var(--accent); color: var(--text-on-dark); }
.btn-primary:hover { background: var(--accent-hover); color: var(--text-on-dark); }

.btn-secondary {
  background: var(--bg-card);
  color: var(--text-primary);
  border-color: var(--border-strong);
}
.btn-secondary:hover { background: var(--bg-soft); color: var(--text-primary); }

.btn-ghost {
  background: transparent;
  color: var(--text-primary);
  border-color: transparent;
}
.btn-ghost:hover { background: var(--bg-soft); color: var(--text-primary); }

.btn-sm { min-height: 36px; padding: 0 var(--space-3); font-size: var(--fs-tiny); }

/* ====== 卡片 ====== */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5);
  box-shadow: var(--sh-card);
}
.card-flat { box-shadow: none; }
.card-dark {
  background: var(--bg-inverse);
  color: var(--text-on-dark);
  border-color: var(--border-dark);
}

/* ====== Badge / Chip ====== */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 10px;
  font-size: var(--fs-tiny);
  font-weight: 600;
  border-radius: var(--r-pill);
  background: var(--bg-soft);
  color: var(--text-secondary);
  border: 1px solid var(--border);
  letter-spacing: 0.02em;
}
.chip-accent { background: var(--accent-soft); color: var(--accent-hover); border-color: transparent; }

/* ====== Hero（首屏区块） ====== */
.hero {
  padding: var(--space-7) 0 var(--space-6);
}
.hero h1 { margin-bottom: var(--space-4); }
.hero .lead {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: var(--text-secondary);
  max-width: 60ch;
  line-height: 1.55;
}

/* ====== 面包屑 ====== */
.breadcrumb {
  font-size: var(--fs-tiny);
  color: var(--text-tertiary);
  padding: var(--space-4) 0 var(--space-2);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}
.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 4px;
  align-items: center;
}
.breadcrumb li { display: inline-flex; align-items: center; margin: 0; }
.breadcrumb li + li::before {
  content: "/";
  margin: 0 6px;
  color: var(--border-strong);
}
.breadcrumb a { color: var(--text-secondary); }
.breadcrumb [aria-current="page"] { color: var(--text-primary); font-weight: 500; }

/* ====== 通用 section 间距 ====== */
.section {
  padding: var(--space-7) 0;
}
.section-tight { padding: var(--space-6) 0; }
.section-loose { padding: var(--space-8) 0; }

/* ====== 网格 ====== */
.grid { display: grid; gap: var(--space-4); }
.grid-2 { grid-template-columns: 1fr; }
.grid-3 { grid-template-columns: 1fr; }
.grid-4 { grid-template-columns: 1fr; }
@media (min-width: 640px) {
  .grid-2 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-4 { grid-template-columns: repeat(4, 1fr); }
}

/* ====== Footer ====== */
.site-footer {
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  padding: var(--space-7) 0 var(--space-5);
  margin-top: var(--space-9);
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}
@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
}
.footer-col h4 {
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-primary);
  margin: 0 0 var(--space-3);
  font-weight: 700;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--space-2); }
.footer-col a { color: var(--text-secondary); }
.footer-col a:hover { color: var(--text-primary); text-decoration: underline; }
.footer-bottom {
  border-top: 1px solid var(--border);
  padding-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-3);
  font-size: var(--fs-tiny);
  color: var(--text-tertiary);
}
.footer-bottom .legal-links { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* ====== AdSense 占位 ====== */
.ad-slot {
  margin: var(--space-6) 0;
  display: none;                       /* 默认隐藏，加载成功后由 JS 显示 */
}
.ad-slot[data-ad-loaded="true"] { display: block; }
.ad-slot .ad-label {
  display: block;
  font-size: 11px;
  color: var(--text-tertiary);
  text-align: center;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.ad-slot ins.adsbygoogle {
  display: block;
  min-height: 90px;                    /* 防 CLS 占位 */
}

/* ====== Cookie Banner（底部 ≤ 20% 屏幕） ====== */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-banner);
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  padding: var(--space-3) var(--space-4);
  box-shadow: 0 -4px 16px rgba(0,0,0,.08);
  font-size: var(--fs-small);
  display: none;
}
.cookie-banner[data-open="true"] { display: block; }
.cookie-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  max-width: var(--container-wide);
  margin: 0 auto;
}
.cookie-inner p { margin: 0; flex: 1 1 240px; }

/* ====== 阅读进度条（v3.2 强制-UX02） ====== */
.reading-progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: var(--accent);
  z-index: 1000;
  transition: width 0.1s linear;
  pointer-events: none;
}

/* ====== 文章浮动目录（>3000 字文章） ====== */
.floating-toc {
  display: none;
  position: sticky;
  top: 80px;
  align-self: start;
  font-size: var(--fs-small);
  max-height: calc(100vh - 120px);
  overflow-y: auto;
}
.floating-toc h4 {
  font-size: var(--fs-tiny);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin: 0 0 var(--space-3);
  font-weight: 700;
}
.floating-toc ol { list-style: none; padding: 0; margin: 0; counter-reset: item; }
.floating-toc li { margin-bottom: var(--space-2); padding-left: 0; }
.floating-toc a {
  color: var(--text-secondary);
  display: block;
  padding: var(--space-1) var(--space-2);
  border-left: 2px solid transparent;
  border-radius: 0 var(--r-xs) var(--r-xs) 0;
  text-decoration: none;
  font-weight: 500;
}
.floating-toc a:hover, .floating-toc a.is-active {
  color: var(--text-primary);
  background: var(--bg-soft);
  border-left-color: var(--accent);
}
@media (min-width: 1280px) {
  .article-with-toc { display: grid; grid-template-columns: minmax(0,1fr) 240px; gap: var(--space-7); }
  .floating-toc { display: block; }
}

/* ====== 提示框 ====== */
.note, .warning, .info-box {
  border-radius: var(--r-md);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0;
  border-left: 4px solid var(--accent);
  background: var(--accent-soft);
  color: var(--text-primary);
}
.warning { border-left-color: var(--warning); background: #FEF3C7; }
.note    { border-left-color: var(--text-tertiary); background: var(--bg-soft); }
.info-box strong { display: block; margin-bottom: var(--space-1); }

/* ====== 作者卡片 ====== */
.author-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--bg-card);
  margin: var(--space-5) 0;
}
.author-card img {
  width: 56px; height: 56px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
  background: var(--bg-soft);
}
.author-card .author-name { font-weight: 700; color: var(--text-primary); display: block; }
.author-card .author-role { font-size: var(--fs-tiny); color: var(--text-secondary); }
.author-card time { display: block; font-size: var(--fs-tiny); color: var(--text-tertiary); margin-top: 2px; }

/* ====== 内容预告块（强制-UX01） ====== */
.content-preview {
  border: 1px solid var(--border);
  background: var(--bg-card);
  border-radius: var(--r-md);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0;
}
.content-preview ul { list-style: none; padding: 0; margin: var(--space-2) 0; }
.content-preview li::before { content: "✓"; color: var(--success); font-weight: 700; margin-right: 8px; }
.content-preview li { padding-left: 0; }

/* ====== 章节导航（强制-UX02） ====== */
.article-nav {
  background: var(--bg-soft);
  border-radius: var(--r-md);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0;
}
.article-nav ol {
  margin: var(--space-2) 0 0;
  padding-left: 1.4em;
}
.article-nav li { margin-bottom: var(--space-1); }

/* ====== 相关文章卡片 ====== */
.related-articles {
  border-top: 1px solid var(--border);
  margin-top: var(--space-7);
  padding-top: var(--space-6);
}
.related-articles ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-3); }
.related-articles a {
  display: block;
  padding: var(--space-4);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  text-decoration: none;
  transition: transform var(--dur-fast), box-shadow var(--dur-fast);
}
.related-articles a:hover { transform: translateY(-2px); box-shadow: var(--sh-hover); text-decoration: none; }
.related-articles strong { display: block; color: var(--text-primary); margin-bottom: 4px; font-size: 1rem; }
.related-articles span { color: var(--text-secondary); font-size: var(--fs-small); }

/* ====== 工具网格（首页/Cluster 互推） ====== */
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-4); }
.tool-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: transform var(--dur-fast), box-shadow var(--dur-fast), border-color var(--dur-fast);
}
.tool-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-hover);
  border-color: var(--text-primary);
  color: inherit;
  text-decoration: none;
}
.tool-card .tool-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  background: var(--text-primary);
  color: var(--text-on-dark);
  border-radius: var(--r-md);
  font-family: var(--font-mono);
  font-weight: 700;
  margin-bottom: var(--space-2);
}
.tool-card h3 { margin: 0; font-size: 1.1rem; }
.tool-card p { margin: 0; color: var(--text-secondary); font-size: var(--fs-small); line-height: 1.5; }
.tool-card .tool-cta { margin-top: var(--space-3); color: var(--accent); font-weight: 600; font-size: var(--fs-small); }

/* ====== Hero stats（首屏可信度数据） ====== */
.hero-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
}
.hero-stat {
  border: 1px solid var(--border);
  background: var(--bg-card);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
}
.hero-stat .stat-value {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  display: block;
  font-variant-numeric: tabular-nums;
}
.hero-stat .stat-label {
  font-size: var(--fs-tiny);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ====== FAQ ====== */
.faq-list details {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--bg-card);
  margin-bottom: var(--space-3);
  padding: 0;
}
.faq-list summary {
  cursor: pointer;
  padding: var(--space-4) var(--space-5);
  font-weight: 600;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  min-height: var(--touch-min);
}
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after {
  content: "+";
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--text-tertiary);
  transition: transform var(--dur-fast);
}
.faq-list details[open] summary::after { content: "−"; }
.faq-list .faq-answer {
  padding: 0 var(--space-5) var(--space-4);
  color: var(--text-secondary);
}
.faq-list .faq-answer p:last-child { margin-bottom: 0; }
