/* ── Legal Pages (Privacy / Terms) ── */
.legal {
  padding: calc(var(--header-height, 80px) + 4rem) 0 var(--section-gap);
}

.legal__title {
  font-size: var(--fs-h1);
  color: var(--color-text);
  margin-bottom: 0.5rem;
}

.legal__updated {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  margin-bottom: 3rem;
}

.legal__body {
  max-width: 720px;
}

.legal__body h2 {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  font-weight: 600;
  color: var(--color-text);
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
}

.legal__body p {
  color: var(--color-text-secondary);
  line-height: 1.8;
  margin-bottom: 1rem;
}

.legal__body ul {
  list-style: disc;
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}

.legal__body li {
  color: var(--color-text-secondary);
  line-height: 1.8;
  margin-bottom: 0.25rem;
}

.legal__body a {
  color: var(--color-accent);
  font-weight: 500;
  transition: opacity 0.2s;
}

.legal__body a:hover {
  opacity: 0.7;
}

.legal__contact {
  list-style: none;
  padding-left: 0;
  margin-top: 1rem;
}

.legal__contact li {
  margin-bottom: 0.25rem;
}

@media (max-width: 768px) {
  .legal {
    padding-top: calc(var(--header-height, 70px) + 2.5rem);
  }

  .legal__title {
    font-size: var(--fs-h2);
  }
}
