/**
 * base.css — Pattern E inabe (paper-grain variant)
 * 基本タイポグラフィ・ボディ・コンテナ・ユーティリティ
 *
 * [paper variant 追加]
 * body::before で全画面固定の紙質ノイズオーバーレイを実装。
 * opacity 0.04 / mix-blend-mode multiply でごく控えめに表現。
 * pointer-events: none で操作を一切妨げない。
 */

/* ===== 紙質ノイズ グローバルオーバーレイ ===== */
/*
  SVG feTurbulence ベースのタイリングノイズを全画面に固定重ね。
  - background-size を素数的な値(257px × 193px)にしてリピートのグリッド感を防止
  - mix-blend-mode: multiply で白背景では効果なし / 有色部では自然に馴染む
  - opacity: 0.04 (4%) で「かすかに感じる」程度に抑える
  - z-index: 9999 + pointer-events: none でUI操作に影響なし
*/
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: url("../images/paper-noise.svg");
  background-repeat: repeat;
  background-size: 257px 193px;
  opacity: 0.04;
  pointer-events: none;
  mix-blend-mode: multiply;
  z-index: 9999;
}

/* アクセシビリティ: 透明度低減設定でオーバーレイを無効化 */
@media (prefers-reduced-transparency: reduce) {
  body::before {
    display: none;
  }
}

/* ===== Body ===== */
body {
  font-family: "IBM Plex Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN",
               "Noto Sans JP", sans-serif;
  font-weight: 400;
  color: var(--ink);
  background: var(--bg);
  background-image:
    radial-gradient(circle at 8% 15%,  rgba(83,150,184,.03), transparent 30%),
    radial-gradient(circle at 92% 80%, rgba(83,150,184,.03), transparent 30%);
}

/* ===== コンテナ ===== */
.container {
  width: var(--container);
  margin-inline: auto;
}

.container--md {
  width: var(--container-md);
  margin-inline: auto;
}

.container--sm {
  width: var(--container-sm);
  margin-inline: auto;
}

/* ===== セクション共通 ===== */
.section {
  padding-block: var(--space-section);
  position: relative;
  overflow: hidden;
}

.section--bg-soft {
  background: var(--bg-soft);
}

.section--bg-blue-tint {
  background: var(--bg-blue-tint);
}

/* ===== セクションヘッダー ===== */
.section-header {
  text-align: center;
  margin-block-end: clamp(40px, 5vw, 72px);
}

.section-header .eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blue-500);
  margin-block-end: 14px;
}

.section-header h2 {
  font-size: clamp(26px, 3.6vw, 40px);
  font-weight: 700;
  line-height: 1.28;
  color: var(--ink);
  letter-spacing: 0.02em;
}

.section-header .section-lead {
  margin-block-start: 20px;
  font-size: clamp(15px, 1.4vw, 17px);
  color: var(--ink-soft);
  line-height: 1.9;
  max-width: 560px;
  margin-inline: auto;
}

/* ===== 見出しタイポ ===== */
h1 {
  font-size: clamp(30px, 4.8vw, 64px);
  font-weight: 700;
  line-height: 1.22;
  letter-spacing: 0.01em;
}

h2 {
  font-size: clamp(24px, 3.2vw, 38px);
  font-weight: 700;
  line-height: 1.28;
}

h3 {
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 700;
  line-height: 1.4;
}

/* ===== fade-up アニメーション ===== */
.js-fadeup {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}

.js-fadeup.is-inview {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .js-fadeup {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ===== ディレイ ===== */
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }

/* ===== スクリーンリーダー専用 ===== */
.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;
}
