/* ============================================
 * base.css — reset + 字体 + 纸张纹理
 * ============================================ */

/* 引入字体（用 Google Fonts CDN） */
@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&family=Fraunces:opsz,wght@9..144,500;9..144,700;9..144,900&display=swap');

/* === reset === */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
input, textarea, select { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; margin: 0; }
img, svg, canvas { display: block; max-width: 100%; }
h1, h2, h3, h4 { margin: 0; font-weight: 700; }
p { margin: 0; }

/* === 全局纸张背景：暖色 + 细微纹理 === */
html { font-size: var(--fs-md); }

body {
  font-family: var(--font-ui);
  color: var(--ink);
  background: var(--paper);
  min-height: 100vh;
  /* 三层叠加：纸张底色 + 横向纹路 + 噪点 */
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent 0px,
      transparent 3px,
      rgba(31, 26, 23, .012) 3px,
      rgba(31, 26, 23, .012) 4px
    ),
    radial-gradient(
      ellipse 80% 60% at 20% 10%,
      rgba(242, 180, 65, .08),
      transparent 60%
    ),
    radial-gradient(
      ellipse 70% 50% at 90% 90%,
      rgba(91, 122, 153, .07),
      transparent 60%
    );
  background-attachment: fixed;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* 噪点叠加：纯 CSS（多重 radial-gradient 模拟） */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image:
    radial-gradient(rgba(31,26,23,.05) 1px, transparent 1px),
    radial-gradient(rgba(31,26,23,.04) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
  opacity: .35;
  mix-blend-mode: multiply;
}

/* === 容器 === */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--sp-5);
  position: relative;
  z-index: 2;
}

/* === 标题字体 === */
h1, .display {
  font-family: var(--font-display);
  font-weight: 900;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
h1 { font-size: var(--fs-2xl); }
h2 { font-size: var(--fs-xl); font-family: var(--font-display); font-weight: 700; }
h3 { font-size: var(--fs-lg); }

.hand { font-family: var(--font-hand); font-weight: 700; }
.mono { font-family: var(--font-mono); }

/* === 排版细节 === */
.muted { color: var(--ink-soft); }
.faint { color: var(--ink-faint); }
.tilt-l { transform: rotate(-1.5deg); }
.tilt-r { transform: rotate(1.5deg); }
.center { text-align: center; }

/* === 焦点环（无障碍）=== */
:focus-visible {
  outline: 3px solid var(--sun);
  outline-offset: 3px;
  border-radius: var(--r-sm);
}

/* === 滚动条：纸张风 === */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--paper-deep); }
::-webkit-scrollbar-thumb {
  background: var(--ink-soft);
  border-radius: var(--r-md);
  border: 2px solid var(--paper-deep);
}

/* === 选择高亮 === */
::selection { background: var(--sun); color: var(--ink); }

/* === 工具类 === */
.flex { display: flex; }
.col { flex-direction: column; }
.gap-1 { gap: var(--sp-1); }
.gap-2 { gap: var(--sp-2); }
.gap-3 { gap: var(--sp-3); }
.gap-4 { gap: var(--sp-4); }
.gap-5 { gap: var(--sp-5); }
.gap-6 { gap: var(--sp-6); }
.between { justify-content: space-between; }
.center-y { align-items: center; }
.wrap { flex-wrap: wrap; }
.grow { flex: 1; }
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.mt-5 { margin-top: var(--sp-5); }
.mt-6 { margin-top: var(--sp-6); }
.mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); }
.hidden { display: none !important; }

/* === 响应式 === */
@media (max-width: 768px) {
  :root { --fs-2xl: 32px; --fs-xl: 22px; }
}
