/* ===========================================
   page.css — 固定ページ用スタイル
   style.css は変更せず、このファイルで追加定義する
   =========================================== */

/* ── ヘッダー分の余白（fixedヘッダーに隠れないよう） ── */
.page-main {
  padding-top: 0;
}

/* ── ページヒーロー（グラデーション背景 + パンくず + タイトル） ── */
.page-hero {
  background: linear-gradient(150deg, #e4daf5 0%, #d5ebf7 45%, #e2f2ea 100%);
  padding-top: 112px; /* fixedヘッダー（top offset ≈ 40px + 高さ ≈ 60px）＋余白12px */
  padding-bottom: 96px;
}

/* ── パンくずリスト ── */
.page-breadcrumb ol {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 6px;
  list-style: none;
  margin: 0 0 48px;
  padding: 0;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text);
}

.page-breadcrumb li + li::before {
  content: "›";
  margin-right: 6px;
  opacity: 0.45;
}

.page-breadcrumb a {
  opacity: 0.6;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: opacity 180ms ease;
}

.page-breadcrumb a:hover {
  opacity: 1;
}

/* ── ページヒーロー：ラベル（excerpt を設定した場合に表示） ── */
.page-hero__label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-family: var(--font-en);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-gradient-c);
  margin: 0 0 16px;
  text-align: center;
}

.page-hero__label::before {
  content: "";
  display: block;
  width: 28px;
  height: 2px;
  background: currentColor;
  flex-shrink: 0;
}

/* ── ページヒーロー：タイトル ── */
.page-hero__title {
  font-family: var(--font-jp);
  font-size: clamp(28px, 4vw, 52px);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.01em;
  color: var(--color-dark);
  margin: 0;
  padding: 0;
  text-align: center;
}

/* ── コンテンツエリア ── */
.page-content {
  background: #fff;
  padding: 80px 0 120px;
}

/* style.css でマージンが 0 にリセットされているため、
   コンテンツ内の見出し・段落に改めてマージンを付与する */
.page-content h1,
.page-content h2,
.page-content h3,
.page-content h4,
.page-content h5,
.page-content h6 {
  font-weight: 700;
  line-height: 1.5;
  color: var(--color-dark);
  margin-top: 56px;
  margin-bottom: 16px;
}

.page-content h1:first-child,
.page-content h2:first-child,
.page-content h3:first-child {
  margin-top: 0;
}

.page-content h2 {
  font-size: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--color-line);
}

.page-content h3 {
  font-size: 17px;
}

.page-content p {
  margin-top: 0;
  margin-bottom: 20px;
  line-height: 2;
}

.page-content ul,
.page-content ol {
  list-style: revert;
  padding-left: 1.5em;
  margin-bottom: 20px;
}

.page-content li {
  margin-bottom: 6px;
  line-height: 1.9;
}

.page-content a {
  color: #3e9e80;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.page-content a:hover {
  opacity: 0.75;
}

.page-content strong {
  font-weight: 700;
}

/* ── レスポンシブ ── */
@media (max-width: 1024px) {
  .page-hero {
    padding-top: 96px;
    padding-bottom: 72px;
  }
}

@media (max-width: 768px) {
  .page-hero {
    padding-top: 80px;
    padding-bottom: 56px;
  }

  .page-hero__title {
    font-size: clamp(22px, 7vw, 36px);
  }

  .page-breadcrumb ol {
    margin-bottom: 32px;
    font-size: 12px;
  }

  .page-content {
    padding: 56px 0 80px;
  }

  .page-content h2 {
    font-size: 18px;
  }
}

@media (max-width: 480px) {
  .page-hero {
    padding-top: 72px;
  }
}
