/*
 * Legal page — /en/legal/, /nl/legal/, /fr/legal/.
 * Imprint + Privacy. Terms section omitted (board did not deliver copy).
 * Canonical source: NEO-79 ux-spec §8 (legal identity block), §10 (a11y).
 *
 * Long-form reading page. Single column, narrow measure, clear hierarchy.
 * No motion beyond the base focus-ring behaviour.
 */

.legal-page {
  padding-block: var(--space-9) var(--space-10);
  padding-inline: var(--gutter-mobile);
  max-inline-size: var(--container-max);
  margin-inline: auto;
  position: relative;
}

@media (min-width: 768px) {
  .legal-page {
    padding-inline: var(--gutter-desktop);
  }
}

.legal-page__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-block-end: var(--space-7);
  border-block-end: var(--border-hairline);
  margin-block-end: var(--space-8);
}

.legal-page__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.legal-page__meta-dot {
  inline-size: 8px;
  block-size: 8px;
  background-color: var(--color-accent);
  display: inline-block;
}

.legal-page__title {
  font-size: var(--text-display-l);
  letter-spacing: var(--tracking-display-tight);
}

.legal-page__lede {
  max-inline-size: 68ch;
  font-size: var(--text-body-lg);
  color: var(--color-text-muted);
}

.legal-page__grid {
  display: grid;
  gap: var(--space-9);
  grid-template-columns: 1fr;
}

@media (min-width: 960px) {
  .legal-page__grid {
    grid-template-columns: 200px minmax(0, 1fr);
    gap: var(--space-8);
    align-items: start;
  }
}

.legal-page__toc {
  position: sticky;
  inset-block-start: calc(var(--nav-height) + var(--space-5));
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-mono-xs);
  letter-spacing: var(--tracking-mono-wide);
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding-inline-start: var(--space-4);
  border-inline-start: var(--border-hairline);
}

.legal-page__toc-label {
  color: var(--color-text);
}

.legal-page__toc a {
  transition: color var(--motion-fast) var(--ease-out);
}

.legal-page__toc a:hover,
.legal-page__toc a:focus-visible {
  color: var(--color-accent);
}

.legal-page__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-9);
  max-inline-size: 72ch;
}

.legal-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  scroll-margin-block-start: calc(var(--nav-height) + var(--space-5));
}

.legal-section__kicker {
  font-family: var(--font-mono);
  font-size: var(--text-mono-xs);
  letter-spacing: var(--tracking-mono-wide);
  text-transform: uppercase;
  color: var(--color-accent);
}

.legal-section__heading {
  font-size: var(--text-display-m);
  letter-spacing: var(--tracking-display);
}

.legal-section__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.legal-section__body p {
  max-inline-size: 68ch;
}

.legal-section__body code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  padding: 2px 6px;
  background-color: var(--color-surface);
  border: 1px solid var(--border-soft);
  color: var(--color-text);
}

.legal-section__sub {
  font-family: var(--font-display);
  font-size: var(--text-display-s);
  font-weight: 500;
  color: var(--color-text);
  margin-block-start: var(--space-5);
}

.legal-section__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-inline-start: var(--space-5);
  border-inline-start: 2px solid var(--color-accent-line);
  color: var(--color-text-muted);
  max-inline-size: 68ch;
}

.legal-section__list li {
  position: relative;
  line-height: var(--leading-normal);
}

.legal-section__list li::before {
  content: "—";
  position: absolute;
  inset-inline-start: -28px;
  color: var(--color-accent);
  font-family: var(--font-mono);
}

.legal-imprint-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding: var(--space-6);
  background-color: var(--color-bg-elev);
  border: var(--border-hairline);
  border-inline-start: 3px solid var(--color-accent);
  max-inline-size: 520px;
}

.legal-imprint-block .legal-identity {
  padding-inline-start: 0;
  border-inline-start: 0;
  font-size: 13px;
  line-height: 1.8;
}

.legal-imprint-block__meta {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-2) var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-mono-sm);
  letter-spacing: var(--tracking-mono);
  color: var(--color-text-muted);
  padding-block-start: var(--space-4);
  border-block-start: var(--border-hairline);
}

.legal-imprint-block__meta dt {
  text-transform: uppercase;
  font-size: var(--text-mono-xs);
  letter-spacing: var(--tracking-mono-wide);
  color: var(--color-text-muted);
}

.legal-imprint-block__meta dd {
  color: var(--color-text);
  margin-inline-start: 0;
}

.legal-section__timestamp {
  margin-block-start: var(--space-8);
  padding-block-start: var(--space-5);
  border-block-start: var(--border-hairline);
  font-family: var(--font-mono);
  font-size: var(--text-mono-xs);
  letter-spacing: var(--tracking-mono-wide);
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.legal-section a.legal-link {
  color: var(--color-text);
  text-decoration: underline;
  text-decoration-color: var(--color-accent-line);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--motion-fast) var(--ease-out);
}

.legal-section a.legal-link:hover,
.legal-section a.legal-link:focus-visible {
  text-decoration-color: var(--color-accent);
}
