/* Apex Fitness — shared legal document styles */

body.legal-page {
  padding: 100px 20px 48px;
  background:
    var(--void),
    var(--void);
  min-height: 100vh;
  transition: background var(--transition-theme), color var(--transition-theme);
}

.legal-wrap {
  max-width: 820px;
  margin: 0 auto;
}

.legal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin-bottom: 20px;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--faint);
}

.legal-meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.legal-doc-shell {
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 2rem 2.25rem 2.5rem;
  transition: all var(--transition);
}

.legal-doc-shell h1 {
  font-size: clamp(1.85rem, 4vw, 2.5rem);
  margin-bottom: 12px;
  letter-spacing: 0.04em;
}

.legal-lead {
  font-size: 1rem;
  color: var(--muted);
  margin-bottom: 24px;
  line-height: 1.75;
}

.legal-callout {
  margin: 0 0 28px;
  padding: 18px 20px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--glass-border);
  background: var(--tile-bg);
  font-size: 0.92rem;
  line-height: 1.65;
  color: #e4e4e7;
}

.legal-callout strong {
  color: var(--electric);
  font-weight: 600;
}

.legal-toc {
  margin: 0 0 28px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: rgba(9, 9, 11, 0.5);
}

.legal-toc-title {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--faint);
  margin-bottom: 10px;
}

.legal-toc ol {
  margin: 0;
  padding-left: 1.2rem;
  columns: 2;
  column-gap: 24px;
}

.legal-toc a {
  font-size: 0.86rem;
  color: var(--muted);
  text-decoration: none;
}

.legal-toc a:hover {
  color: var(--electric);
}

.legal-body h2 {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--white);
  margin: 32px 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(39, 39, 42, 0.6);
}

.legal-body h2:first-of-type {
  margin-top: 8px;
}

.legal-body p,
.legal-body li {
  font-size: 0.94rem;
  color: var(--muted);
  line-height: 1.75;
  margin-bottom: 12px;
}

.legal-body ul,
.legal-body ol {
  margin: 0 0 16px 1.25rem;
}

.legal-body li {
  margin-bottom: 8px;
}

.legal-ph {
  color: var(--electric);
  font-family: var(--font-mono);
  font-size: 0.82em;
  background: var(--tile-bg);
  padding: 1px 6px;
  border-radius: 4px;
  white-space: nowrap;
}

.legal-related {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  font-size: 0.88rem;
  color: var(--faint);
}

.legal-related a {
  color: var(--electric);
}

.legal-site-footer {
  max-width: 820px;
  margin: 32px auto 0;
  padding: 24px 0 8px;
  text-align: center;
  border-top: 1px solid var(--border);
}

.legal-footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px 20px;
  margin-bottom: 16px;
}

.legal-footer-nav a {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
}

.legal-footer-nav a:hover,
.legal-footer-nav a[aria-current="page"] {
  color: var(--electric);
}

.legal-site-footer p {
  font-size: 0.82rem;
  color: var(--faint);
  margin: 4px 0;
}

@media (max-width: 720px) {
  body.legal-page {
    padding-top: 88px;
  }
  .legal-doc-shell {
    padding: 22px 18px 28px;
  }
  .legal-toc ol {
    columns: 1;
  }
  .nav {
    padding: 12px 16px;
  }
  .nav-links {
    gap: 4px;
  }
  .nav-links a {
    font-size: 0.75rem;
    padding: 6px 10px;
  }
}
