/* Legal pages — shared styling */
.legal-hero { padding: 160px 0 40px; }
.legal-hero .crumb { font-family: var(--font-mono); font-size: 12px; color: var(--foreground-subtle); letter-spacing: 0.06em; margin-bottom: 20px; }
.legal-hero .crumb a { color: var(--foreground-muted); }
.legal-hero .crumb a:hover { color: var(--foreground); }
.legal-hero .crumb .sep { margin: 0 8px; opacity: 0.5; }
.legal-hero h1 { font-size: clamp(2rem, 4vw, 3.25rem); }
.legal-hero .updated { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: 999px; background: rgba(99,102,241,0.08); border: 1px solid rgba(99,102,241,0.2); font-family: var(--font-mono); font-size: 11px; color: var(--accent-glow); letter-spacing: 0.04em; margin-top: 24px; }
.legal-hero .updated::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent-glow); }

.legal-layout { display: grid; grid-template-columns: 240px 1fr; gap: 64px; align-items: start; padding: 40px 0 80px; }
@media (max-width: 900px) { .legal-layout { grid-template-columns: 1fr; gap: 32px; } }

.legal-toc { position: sticky; top: 100px; max-height: calc(100vh - 120px); overflow-y: auto; }
.legal-toc h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--foreground-subtle); margin-bottom: 16px; font-weight: 500; }
.legal-toc ol { list-style: none; counter-reset: toc; display: flex; flex-direction: column; gap: 4px; }
.legal-toc li { counter-increment: toc; }
.legal-toc a {
  display: flex; gap: 10px; padding: 8px 12px; border-radius: 8px;
  font-size: 13px; color: var(--foreground-muted); transition: all 180ms;
  border-left: 2px solid transparent;
}
.legal-toc a::before { content: counter(toc, decimal-leading-zero); font-family: var(--font-mono); font-size: 11px; color: var(--foreground-subtle); }
.legal-toc a:hover { color: var(--foreground); background: rgba(255,255,255,0.02); }
.legal-toc a.active { color: var(--foreground); background: rgba(99,102,241,0.08); border-left-color: var(--accent); }
@media (max-width: 900px) { .legal-toc { position: static; max-height: none; } }

.legal-body { max-width: 768px; }
.legal-body section { scroll-margin-top: 100px; padding-bottom: 32px; }
.legal-body section + section { border-top: 1px solid var(--border); padding-top: 32px; }
.legal-body h2 { font-size: 1.5rem; margin-bottom: 16px; letter-spacing: -0.02em; display: flex; align-items: baseline; gap: 12px; }
.legal-body h2 .nm { font-family: var(--font-mono); font-size: 0.85rem; color: var(--accent-glow); font-weight: 500; }
.legal-body h3 { font-size: 1.05rem; margin: 24px 0 12px; font-weight: 600; }
.legal-body p { color: var(--foreground-muted); font-size: 15px; line-height: 1.75; margin-bottom: 14px; }
.legal-body ul { padding-left: 20px; color: var(--foreground-muted); font-size: 15px; line-height: 1.75; margin-bottom: 14px; }
.legal-body li { margin-bottom: 6px; }
.legal-body strong { color: var(--foreground); font-weight: 500; }
.legal-body .placeholder {
  padding: 16px 20px; border: 1px dashed var(--border-elevated); border-radius: var(--radius);
  background: rgba(245,158,11,0.03); color: var(--foreground-subtle);
  font-family: var(--font-mono); font-size: 12px; line-height: 1.6; letter-spacing: 0.02em;
  margin: 8px 0 14px;
}
.legal-body a { color: var(--accent-glow); }
.legal-body a:hover { color: var(--foreground); }

.legal-footer {
  margin-top: 64px; padding: 32px; border: 1px solid var(--border); border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.015);
}
.legal-footer h4 { font-size: 14px; margin-bottom: 16px; font-family: var(--font-mono); letter-spacing: 0.06em; text-transform: uppercase; color: var(--foreground-subtle); font-weight: 500; }
.legal-footer-links { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.legal-footer-links a { padding: 14px 18px; border: 1px solid var(--border); border-radius: var(--radius); color: var(--foreground); font-size: 14px; transition: all 180ms; display: flex; justify-content: space-between; align-items: center; }
.legal-footer-links a:hover { border-color: var(--border-elevated); background: rgba(255,255,255,0.02); color: var(--foreground); }
.legal-footer-links a svg { color: var(--foreground-subtle); transition: transform 180ms; }
.legal-footer-links a:hover svg { transform: translateX(3px); color: var(--accent-glow); }
@media (max-width: 600px) { .legal-footer-links { grid-template-columns: 1fr; } }

@media print {
  .nav, .footer, .legal-toc, .cookie, .atmos, .noise { display: none; }
  body { background: white; color: black; }
  .legal-body { max-width: none; }
  .legal-body p, .legal-body ul, .legal-body li { color: #222; }
  .legal-body strong { color: black; }
  .legal-hero { padding: 0 0 24px; }
}
