/* ==========================================================================
   Legal Pages — Imprint, Terms of Service, Data Privacy
   ========================================================================== */

.legal {
  max-width: 780px;
  margin: 0 auto;
  padding: var(--space-2xl) 0 var(--space-3xl);
}

.legal__title {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  color: var(--color-text);
  letter-spacing: -0.03em;
  margin-bottom: var(--space-xl);
}

.legal__section-title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 1.25rem;
  color: var(--color-text);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-sm);
}

.legal__subsection-title {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 1.1rem;
  color: var(--color-text);
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
}

.legal p {
  color: var(--color-text-secondary);
  font-size: 0.95rem;
  line-height: 1.75;
  margin-bottom: var(--space-md);
}

.legal ul,
.legal ol {
  color: var(--color-text-secondary);
  font-size: 0.95rem;
  line-height: 1.75;
  margin-bottom: var(--space-md);
  padding-left: var(--space-lg);
}

.legal li {
  margin-bottom: var(--space-xs);
}

.legal a {
  color: var(--color-cyan);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.legal a:hover {
  color: var(--color-green-bright);
}

.legal hr {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-2xl) 0;
}

.legal strong {
  color: var(--color-text);
  font-weight: var(--fw-semibold);
}

/* Language divider */
.legal__lang-divider {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--color-text-muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin: var(--space-2xl) 0 var(--space-xl);
  position: relative;
}

.legal__lang-divider::before,
.legal__lang-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 30%;
  border-top: 1px solid var(--color-border);
}

.legal__lang-divider::before { left: 0; }
.legal__lang-divider::after { right: 0; }
