/* Casken — pages légales (Confidentialité, Conditions).
   S'appuie sur les tokens de styles.css ; registre sobre, même langue visuelle. */

.legal-nav {
  display: flex;
  align-items: center;
  padding: 22px 52px;
  border-bottom: 1px solid var(--ink-ghost);
  background: var(--bone);
}
.legal-nav a { font-size: 18px; color: var(--ink); }

.legal {
  max-width: 720px;
  margin: 0 auto;
  padding: 72px 24px 96px;
}

.legal h1 {
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.04;
}
.legal-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-more);
  margin-top: 14px;
}

.legal h2 {
  font-size: 21px;
  font-weight: 400;
  margin: 44px 0 12px;
  color: var(--ink);
}

.legal p, .legal li {
  font-size: 16.5px;
  line-height: 1.6;
  color: var(--ink-dim);
}
.legal p + p { margin-top: 14px; }
.legal-intro { margin-top: 28px; }

.legal ul { margin: 14px 0 0; padding-left: 22px; }
.legal li + li { margin-top: 8px; }

.legal strong { font-weight: 500; color: var(--ink); }

.legal a { color: var(--brass-deep); transition: color 180ms ease; }
.legal a:hover { color: var(--ink); }

.legal-contact {
  border: 1px solid var(--ink-ghost);
  background: var(--bone-deep);
  padding: 22px 24px;
  margin-top: 48px;
}
.legal-contact h2 { margin: 0 0 8px; }

.legal-foot {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px 64px;
  border-top: 1px solid var(--ink-ghost-2);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}
.legal-foot .mono { font-size: 11px; color: var(--ink-more); }
.legal-foot a { transition: color 180ms ease; }
.legal-foot a:hover { color: var(--ink); }

@media (max-width: 900px) {
  .legal-nav { padding: 18px 24px; }
  .legal { padding: 56px 24px 72px; }
}
