/* ─────────────────────────────────────────────────────────────
   Legal pages — clean, readable, on-brand
   Shared between privacy / terms / data-deletion / cookies
   ───────────────────────────────────────────────────────────── */

.legal-draft {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(90deg, rgba(255,46,138,0.18) 0%, rgba(255,209,92,0.18) 100%);
  border: 1px solid rgba(255,209,92,0.45);
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 12.5px;
  color: var(--ink-1);
  font-weight: 500;
  margin-bottom: 18px;
  text-align: left;
  max-width: 720px;
  line-height: 1.45;
}
.legal-draft strong {
  color: var(--gold);
  letter-spacing: 0.06em;
  font-weight: 700;
}

.legal-hero {
  position: relative;
  padding-top: calc(var(--nav-h) + 48px);
  padding-bottom: 48px;
  background:
    radial-gradient(50% 50% at 50% 0%, rgba(255,46,138,0.12) 0%, transparent 60%),
    var(--bg-0);
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.legal-hero .h-eyebrow { margin-bottom: 18px; }
.legal-hero h1 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(34px, 4.5vw, 56px);
  letter-spacing: -0.03em; line-height: 1.05;
  margin: 0 auto 16px;
  max-width: 880px;
  color: var(--ink-0);
}
.legal-hero .meta {
  font-size: 13px; color: var(--ink-3);
  letter-spacing: 0.06em;
}
.legal-hero .meta strong { color: var(--ink-1); }
.legal-hero .meta .sep { margin: 0 10px; opacity: 0.5; }

.legal-body {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(40px, 6vw, 72px) var(--gutter);
}
.legal-toc {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 22px 24px;
  margin-bottom: 48px;
}
.legal-toc .lbl {
  font-family: var(--font-body); font-weight: 700;
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 12px;
}
.legal-toc ol {
  margin: 0; padding: 0; list-style: none;
  counter-reset: legal;
  font-size: 14.5px;
  columns: 2;
  column-gap: 28px;
}
.legal-toc li {
  counter-increment: legal;
  margin-bottom: 6px;
  break-inside: avoid;
}
.legal-toc li::before {
  content: counter(legal, decimal-leading-zero) " ";
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold); margin-right: 6px;
}
.legal-toc a { color: var(--ink-1); }
.legal-toc a:hover { color: var(--pink-glow); }
@media (max-width: 560px) { .legal-toc ol { columns: 1; } }

.legal-body h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(22px, 2.6vw, 28px);
  letter-spacing: -0.02em; line-height: 1.15;
  margin: 48px 0 14px;
  color: var(--ink-0);
}
.legal-body h2:first-child { margin-top: 0; }
.legal-body h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; letter-spacing: -0.015em; line-height: 1.2;
  margin: 28px 0 10px;
  color: var(--ink-0);
}
.legal-body p,
.legal-body ul,
.legal-body ol {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-1);
  margin: 0 0 1.1em;
}
.legal-body a { color: var(--pink-glow); border-bottom: 1px solid rgba(255,102,176,0.3); }
.legal-body a:hover { border-bottom-color: var(--pink-glow); }
.legal-body strong { color: var(--ink-0); font-weight: 700; }
.legal-body ul, .legal-body ol { padding-left: 22px; }
.legal-body li { margin-bottom: 8px; }
.legal-body li::marker { color: var(--pink-glow); }

.legal-callout {
  background:
    radial-gradient(80% 100% at 0% 0%, rgba(255,209,92,0.08) 0%, transparent 60%),
    var(--surface);
  border: 1px solid rgba(255,209,92,0.25);
  border-left: 3px solid var(--gold);
  border-radius: var(--r-md);
  padding: 18px 22px;
  margin: 24px 0;
}
.legal-callout p:last-child { margin-bottom: 0; }
.legal-callout strong { color: var(--gold); }

.legal-contact-block {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 22px 24px;
  margin-top: 40px;
}
.legal-contact-block h3 { margin-top: 0; }
.legal-contact-block ul { list-style: none; padding: 0; }
.legal-contact-block li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  font-size: 14.5px;
}
.legal-contact-block li:last-child { border-bottom: none; }
.legal-contact-block li strong {
  flex-basis: 100px; flex-shrink: 0;
  font-size: 12px;
  color: var(--ink-3);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.legal-contact-block li a { word-break: break-word; }

@media (max-width: 560px) {
  .legal-contact-block { padding: 18px 18px; }
  .legal-contact-block li {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 12px 0;
    font-size: 14px;
    line-height: 1.5;
  }
  .legal-contact-block li strong {
    flex-basis: auto;
  }
}

.legal-form {
  margin-top: 28px;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  display: grid; gap: 14px;
}
.legal-form label {
  display: block;
  font-size: 13px; font-weight: 600;
  color: var(--ink-1);
  margin-bottom: 6px;
}
.legal-form input,
.legal-form textarea,
.legal-form select {
  width: 100%;
  padding: 12px 14px;
  background: var(--bg-0);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  color: var(--ink-0);
  font: inherit;
  font-size: 14.5px;
}
.legal-form textarea { resize: vertical; min-height: 90px; font-family: inherit; }
.legal-form input:focus,
.legal-form textarea:focus,
.legal-form select:focus {
  outline: none;
  border-color: var(--pink);
}
.legal-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 560px) { .legal-form .row { grid-template-columns: 1fr; } }
