/* ═══════════════════════════════════════════════
   基础样式 — Reset、排版、布局工具
   所有颜色通过 var(--color-xxx) 引用，不在本文件写死色值
   ═══════════════════════════════════════════════ */

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-body);
  font-weight: var(--weight-normal);
  line-height: var(--leading-body);
  color: var(--color-body);
  background: var(--color-canvas);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── 排版层级 ── */
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: var(--weight-normal);
  color: var(--color-ink);
  margin: 0 0 var(--spacing-md);
}

h1 {
  font-size: var(--text-h1);
  line-height: var(--leading-tight);
}

h2 {
  font-size: var(--text-h2);
  line-height: var(--leading-snug);
}

h3 {
  font-size: var(--text-h3);
  line-height: var(--leading-relaxed);
}

p {
  margin: 0 0 var(--spacing-md);
}

a {
  color: var(--color-primary);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

code, pre {
  font-family: var(--font-code);
  font-size: var(--text-code);
  line-height: var(--leading-body);
}

blockquote {
  margin: var(--spacing-lg) 0;
  padding-left: var(--spacing-md);
  border-left: 3px solid var(--color-primary);
  color: var(--color-muted);
}

hr {
  border: none;
  border-top: 1px solid var(--color-hairline);
  margin: var(--spacing-2xl) 0;
}

::selection {
  background: rgba(var(--color-primary-rgb), 0.2);
  color: var(--color-ink);
}

/* ── 布局工具 ── */
.container {
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
}

main.container {
  padding-top: var(--spacing-2xl);
  padding-bottom: var(--spacing-2xl);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ── 页脚 ── */
.site-footer {
  margin-top: var(--spacing-2xl);
  padding: var(--spacing-xl) 0;
  border-top: 1px solid var(--color-hairline);
  font-size: var(--text-caption);
  color: var(--color-muted);
}

.site-footer p {
  margin: 0;
}

/* ═══════════════════════════════════════════════
   响应式断点
   ═══════════════════════════════════════════════ */

/* 平板及以下：缩小标题、减小间距 */
@media (max-width: 768px) {
  :root {
    --text-h1: 28px;
    --text-h2: 24px;
    --text-h3: 20px;
    --text-body: 15px;
  }

  .container {
    padding: 0 var(--spacing-md);
  }

  main.container {
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
  }
}

/* 中等屏幕：居中过渡 */
@media (min-width: 769px) and (max-width: 1024px) {
  .container {
    padding: 0 var(--spacing-lg);
  }
}

/* ═══════════════════════════════════════════════
   无障碍：尊重用户运动偏好
   ═══════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
