﻿/* Asia/Tokyo, 2025-11-28 16:45(UTC+09:00) /css/privacypolicy.css */

/* Uses common .page-body, .list, .u-right from common.css */

#policy.about {
  padding: var(--section-space) 0;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(0, 117, 201, 0.08) 0, transparent 55%),
    radial-gradient(120% 120% at 100% 0%, rgba(17, 119, 19, 0.05) 0, transparent 55%),
    #f9fafb;
}

#policy .container {
  max-width: 880px;
  margin-inline: auto;
  padding: clamp(2.4rem, 3vw, 3.2rem) clamp(2.4rem, 4vw, 3.6rem);
  background: #ffffff;
  border-radius: 18px;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
  border: 1px solid #e5e7eb;
}

/* 日付ラベル */
#policy .date {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 0 2.4rem auto;
  padding: 0.4rem 1.2rem;
  font-size: var(--fs-14);
  letter-spacing: 0.05em;
  color: #4b5563;
  background: #f3f4ff;
  border-radius: 999px;
  border: 1px solid #c7d2fe;
}

/* セクション見出し（理念・方針・お問い合わせ窓口） */
#policy .section-title {
  position: relative;
  display: inline-block;
  margin: 0;
  margin-bottom: 1.6rem;
  padding: 0 0 0.9rem 0;
  font-size: clamp(2.4rem, 2rem + 0.9vw, 3rem);
  color: #111827;
  border: none;
}

#policy .section-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #0075c9, #22c55e);
}

/* 見出し直後のリード文の間隔 */
#policy .section-title + p {
  margin-top: 0.4rem;
}

#policy .section-title + p + p {
  margin-top: 0.8rem;
}

#policy .section-title:first-of-type {
  margin-top: 0;
}

#policy .section-title:not(:first-of-type) {
  margin-top: clamp(2.4rem, 3vw, 3.2rem);
}

/* 本文全体のタイポグラフィ */
#policy p {
  margin: 0;
  font-size: var(--fs-17);
  line-height: 1.9;
  color: #374151;
}

#policy p + p {
  margin-top: 0.7rem;
}

/* お問い合わせ窓口ブロックのカード化 */
#policy h2.section-title:last-of-type {
  margin-top: clamp(2.6rem, 3vw, 3.4rem);
}

#policy h2.section-title:last-of-type + p {
  margin-top: 1.4rem;
  padding: 1.6rem 2rem;
  border-radius: 12px;
  background: linear-gradient(135deg, #eff6ff, #e0f2fe);
  border: 1px solid #bfdbfe;
  font-weight: 500;
}

/* メールリンクのスタイル */
#policy a {
  color: #0057a4;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

#policy a:hover,
#policy a:focus-visible {
  text-decoration-thickness: 0.16em;
}

/* レスポンシブ調整 */
@media (max-width: 768px) {
  #policy.about {
    padding: var(--section-space) 0;
  }

  #policy .container {
    padding: 2rem 1.8rem;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  }

  #policy .date {
    font-size: var(--fs-13);
    margin-bottom: 2rem;
  }

  #policy .section-title {
    font-size: clamp(2.2rem, 5vw, 2.6rem);
  }

  #policy h2.section-title:last-of-type + p {
    padding: 1.4rem 1.6rem;
  }
}

@media (max-width: 480px) {
  #policy .container {
    padding: 1.8rem 1.6rem;
    border-radius: 12px;
  }

  #policy p {
    font-size: var(--fs-16);
  }
}
