/* ============================================================
   150 LAYERS — LEGAL PAGES
   Requires design-system.css
   ============================================================ */

.legal-header {
  background: var(--surface-card);
  border-bottom: 1px solid var(--surface-border);
  padding-block: var(--space-16);
}

.legal-header__back {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-decoration: none;
  margin-bottom: var(--space-6);
  transition: color var(--transition-fast);
}

.legal-header__back:hover {
  color: var(--text-secondary);
}

.legal-header__label {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent-red);
  margin-bottom: var(--space-3);
}

.legal-header__title {
  font-size: var(--text-4xl);
  margin-bottom: var(--space-3);
}

.legal-header__meta {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

/* ------------------------------------------------------------
   LEGAL NOTICE BANNER
   ------------------------------------------------------------ */
.legal-notice {
  background: rgba(220, 38, 38, 0.08);
  border: 1px solid rgba(220, 38, 38, 0.2);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-6);
  margin-bottom: var(--space-10);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.legal-notice strong {
  color: var(--accent-red);
}

/* ------------------------------------------------------------
   LEGAL BODY
   ------------------------------------------------------------ */
.legal-body {
  padding-block: var(--space-16);
}

.legal-content {
  max-width: 720px;
}

.legal-content h2 {
  font-size: var(--text-2xl);
  margin-top: var(--space-12);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--surface-border);
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content h3 {
  font-size: var(--text-lg);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
  color: var(--text-secondary);
}

.legal-content p {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  margin-bottom: var(--space-4);
}

.legal-content ul,
.legal-content ol {
  list-style: disc;
  padding-left: var(--space-6);
  margin-bottom: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.legal-content ol {
  list-style: decimal;
}

.legal-content li {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.legal-content strong {
  color: var(--text-primary);
  font-weight: 600;
}

.legal-content a {
  color: var(--accent-red);
  text-decoration: underline;
}

/* Table */
.legal-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-8);
  font-size: var(--text-sm);
}

.legal-content th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  background: var(--surface-elevated);
  color: var(--text-secondary);
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: var(--text-xs);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--surface-border);
}

.legal-content td {
  padding: var(--space-3) var(--space-4);
  color: var(--text-secondary);
  border-bottom: 1px solid var(--surface-border);
  vertical-align: top;
}

.legal-content tr:last-child td {
  border-bottom: none;
}

/* Uppercase warning sections */
.legal-content p:has(+ p),
.legal-uppercase {
  font-size: var(--text-sm);
}

/* Divider */
.legal-content hr {
  border: none;
  border-top: 1px solid var(--surface-border);
  margin-block: var(--space-10);
}

/* Footer contact block */
.legal-contact {
  margin-top: var(--space-12);
  padding: var(--space-8);
  background: var(--surface-card);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-xl);
}

.legal-contact p {
  margin-bottom: var(--space-2);
}

/* ------------------------------------------------------------
   NAV (reused from landing)
   ------------------------------------------------------------ */
.nav__links--open {
  display: flex !important;
}

@media (max-width: 768px) {
  .legal-header__title {
    font-size: var(--text-3xl);
  }

  .legal-content h2 {
    font-size: var(--text-xl);
  }

  .legal-content table {
    display: block;
    overflow-x: auto;
  }
}
