/* =========================================================
   LEGAL / 会社概要・特定商取引法に基づく表記
   ========================================================= */
.legal-main { padding-block: clamp(40px, 6vw, 80px) clamp(60px, 8vw, 110px); }

.legal-head { max-width: 820px; margin-bottom: clamp(40px, 5vw, 64px); }
.legal-head .eyebrow { margin-bottom: 18px; }
.legal-head h1 {
  font-family: var(--serif);
  font-weight: 800;
  font-size: clamp(30px, 5vw, 50px);
  line-height: 1.3;
  letter-spacing: .02em;
}
.legal-head h1 .en {
  display: block;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .3em;
  color: var(--sumi-faint);
  margin-top: 14px;
  text-transform: uppercase;
}
.legal-head p { margin-top: 20px; color: var(--sumi-soft); font-size: 15px; line-height: 1.95; max-width: 64ch; }

.legal-block { margin-bottom: clamp(48px, 6vw, 80px); }
.legal-block:last-of-type { margin-bottom: 0; }
.legal-block-head {
  display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap;
  margin-bottom: 26px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--enji);
}
.legal-block-head h2 {
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 30px);
  letter-spacing: .02em;
}
.legal-block-head .lh-en { font-family: var(--mono); font-size: 11.5px; letter-spacing: .16em; color: var(--sumi-faint); text-transform: uppercase; }

.info-table {
  border-top: 1px solid var(--line);
  margin: 0;
}
.info-row {
  display: grid;
  grid-template-columns: 240px 1fr;
  border-bottom: 1px solid var(--line);
}
.info-row dt {
  padding: 20px 24px;
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 15px;
  color: var(--sumi);
  background: var(--washi);
  border-right: 1px solid var(--line);
}
.info-row dd {
  padding: 20px 26px;
  margin: 0;
  color: var(--sumi-soft);
  font-size: 14.5px;
  line-height: 1.95;
}
.info-row dd a { color: var(--enji); text-decoration: underline; text-underline-offset: 3px; }
.info-row dd .strong { color: var(--sumi); font-weight: 700; }
.info-row dd ul { margin: 6px 0 0; display: flex; flex-direction: column; gap: 8px; }
.info-row dd ul li { display: flex; gap: 10px; }
.info-row dd ul li::before { content: "・"; color: var(--enji); }
.info-row dd .sub { display: block; margin-top: 8px; font-size: 12.5px; color: var(--sumi-faint); }
.info-row dd .pend { color: var(--enji); font-weight: 700; }

.legal-note {
  margin-top: 26px;
  background: var(--enji-wash);
  border: 1px dashed var(--enji-line);
  border-radius: 4px;
  padding: 20px 26px;
  font-size: 13.5px;
  color: var(--sumi-soft);
  line-height: 1.9;
}
.legal-note b { font-family: var(--serif); color: var(--enji); }

.legal-back {
  margin-top: clamp(44px, 6vw, 72px);
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.legal-updated { font-family: var(--mono); font-size: 12px; color: var(--sumi-faint); letter-spacing: .04em; }

/* simplified header back link */
.header-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 500; color: var(--sumi-soft);
  transition: color .2s ease;
}
.header-back:hover { color: var(--enji); }
.header-back svg { width: 16px; height: 16px; }

@media (max-width: 640px) {
  .info-row { grid-template-columns: 1fr; }
  .info-row dt { border-right: none; border-bottom: 1px solid var(--line-soft); padding: 14px 18px; }
  .info-row dd { padding: 16px 18px; }
}
