/* ── Legal pages — minimalist editorial layout ── */
.legal-page {
  background: var(--paper);
  min-height: 100vh;
}
.legal-container {
  max-width: 720px;
  margin: 0 auto;
  padding: clamp(80px, 12vw, 160px) 24px 80px;
}
.legal-header {
  margin-bottom: clamp(32px, 5vw, 56px);
  padding-bottom: 24px;
  border-bottom: 1px solid var(--ink-line);
}
.legal-eyebrow {
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 8px;
}
.legal-title {
  font-family: var(--font-serif-soft, var(--font-serif));
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 400;
  line-height: 1.05;
  color: var(--ink);
  margin: 0 0 12px;
  letter-spacing: -0.02em;
}
.legal-meta {
  font: 400 13px/1.4 var(--font-sans);
  color: var(--ink-3);
  margin: 0;
}
.legal-content h2 {
  font-family: var(--font-serif);
  font-size: clamp(20px, 2.5vw, 26px);
  font-weight: 500;
  line-height: 1.2;
  color: var(--ink);
  margin: 48px 0 12px;
  letter-spacing: -0.01em;
}
.legal-content h3 {
  font: 600 15px/1.3 var(--font-sans);
  color: var(--ink);
  margin: 28px 0 8px;
}
.legal-content p {
  font: 400 15px/1.7 var(--font-sans);
  color: var(--ink-2);
  margin: 0 0 14px;
}
.legal-content ul, .legal-content ol {
  font: 400 15px/1.7 var(--font-sans);
  color: var(--ink-2);
  margin: 0 0 14px;
  padding-left: 24px;
}
.legal-content li { margin-bottom: 6px; }
.legal-content strong { color: var(--ink); font-weight: 600; }
.legal-content a { color: var(--vinya-500); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.legal-content a:hover { color: var(--vinya-700); }
.legal-content hr { border: none; border-top: 1px solid var(--ink-line); margin: 40px 0; }
.legal-back {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 13px/1 var(--font-sans);
  color: var(--ink-3); text-decoration: none;
  margin-bottom: 32px;
}
.legal-back:hover { color: var(--ink); }
.legal-lang-switch {
  display: inline-flex;
  border: 1px solid var(--ink-line);
  border-radius: var(--radius-full);
  overflow: hidden;
  background: var(--paper);
  margin-bottom: 24px;
}
.legal-lang-switch button {
  font: 600 11px/1 var(--font-sans);
  padding: 6px 12px;
  color: var(--ink-3);
  background: transparent;
  border: none;
  cursor: pointer;
  letter-spacing: 0.06em;
}
.legal-lang-switch button.on { background: var(--ink); color: var(--paper); }
[data-lang-content] { display: none; }
[data-lang-content].active { display: block; }
