/* ============================================================
   page-legal.css — 法務系ページ共通 (個人情報保護方針 / プライバシーポリシー / 特定商取引法)
   ============================================================ */

/* ── Hero ─────────────────────────────────────────── */
.sec-legal-hero {
  background: var(--paper);
  padding: 56px 40px 28px;
}
.sec-legal-hero__inner {
  max-width: 1180px;
  margin: 0 auto;
}
.sec-legal-hero__en {
  font-family: Outfit, sans-serif;
  font-weight: 700;
  font-size: 56px;
  color: var(--navy);
  line-height: 1.1;
  margin: 0;
  letter-spacing: .02em;
}
.sec-legal-hero__ja {
  font-weight: 700;
  font-size: 17px;
  color: var(--navy);
  margin: 12px 0 0;
  letter-spacing: .04em;
}

/* ── Body (個人情報保護方針 / プライバシーポリシー) ── */
.sec-legal-body {
  background: var(--paper);
  padding: 32px 40px 80px;
}
.sec-legal-body__inner {
  max-width: 880px;
  margin: 0 auto;
  background: #fff;
  padding: 56px 60px;
  border: 1px solid #d6e3f1;
  border-radius: 4px;
}
.legal-body__title {
  font-weight: 800;
  font-size: 20px;
  color: var(--navy);
  margin: 0 0 24px;
}
.legal-body__intro,
.legal-body__section-body {
  font-size: 14px;
  line-height: 2;
  color: #333;
  margin: 0 0 22px;
}
.legal-body__section {
  margin: 0 0 26px;
}
.legal-body__section-title {
  font-weight: 800;
  font-size: 15px;
  color: var(--navy);
  margin: 0 0 8px;
  letter-spacing: .02em;
}
.legal-body__list {
  margin: 8px 0 22px;
  padding-left: 1.5em;
  list-style: disc;
}
.legal-body__list li {
  font-size: 14px;
  line-height: 1.95;
  color: #333;
  margin: 2px 0;
}
.legal-body__contact-list {
  margin: 8px 0 22px;
  padding-left: 1.5em;
  list-style: disc;
}
.legal-body__contact-list li {
  font-size: 14px;
  line-height: 2;
  color: #333;
}
.legal-body__dates {
  margin: 36px 0 0;
  font-size: 13px;
  line-height: 1.9;
  color: #4d4d4d;
}

/* ── Table (特定商取引法に基づく表記) ──────── */
.legal-table {
  list-style: none;
  margin: 0;
  padding: 0;
}
.legal-table__row {
  margin: 0 0 8px;
}
.legal-table__label {
  background: var(--navy);
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  padding: 12px 22px;
  letter-spacing: .04em;
}
.legal-table__value {
  background: #fff;
  border: 1px solid #d6e3f1;
  border-top: 0;
  padding: 18px 22px;
  font-size: 14px;
  line-height: 1.95;
  color: #333;
}
.legal-table__value p { margin: 0 0 6px; }
.legal-table__value p:last-child { margin: 0; }
.legal-table__value a { color: var(--navy); text-decoration: underline; }

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 1023px) {
  .sec-legal-hero { padding: 48px 32px 24px; }
  .sec-legal-hero__en { font-size: 44px; }
  .sec-legal-hero__ja { font-size: 15px; }
  .sec-legal-body { padding: 24px 32px 64px; }
  .sec-legal-body__inner { padding: 40px 36px; }
  .legal-table__label,
  .legal-table__value { padding: 12px 18px; }
}
@media (max-width: 767px) {
  .sec-legal-hero { padding: 32px 20px 18px; }
  .sec-legal-hero__en { font-size: 32px; line-height: 1.2; }
  .sec-legal-hero__ja { font-size: 13px; }
  .sec-legal-body { padding: 16px 20px 48px; }
  .sec-legal-body__inner { padding: 28px 22px; }
  .legal-body__intro,
  .legal-body__section-body,
  .legal-body__list li,
  .legal-body__contact-list li,
  .legal-table__value { font-size: 13px; line-height: 1.9; }
  .legal-body__section-title { font-size: 14px; }
  .legal-table__label { padding: 10px 16px; font-size: 13px; }
  .legal-table__value { padding: 14px 16px; }
}
