/* Shared CSS for legal pages */
.legal-hero { padding: 80px 0 50px; }
.legal-hero h1 { margin-top: 22px; font-size: clamp(48px, 6vw, 84px); }
.legal-hero .lede { margin-top: 24px; max-width: 740px; }
.meta-row {
  margin-top: 36px;
  display: flex; flex-wrap: wrap; gap: 28px;
  font-size: 12px; color: var(--ink-2); letter-spacing: 0.08em; text-transform: uppercase;
}
.dl-link {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  color: #6d28d9 !important;
  letter-spacing: 0.05em;
  text-transform: none;
  font-size: 12.5px;
  font-family: var(--font-mono);
}

.legal-section { padding: 30px 0 80px; }
.legal-grid {
  display: grid;
  grid-template-columns: minmax(0, 240px) minmax(0, 1fr);
  gap: 60px;
  align-items: start;
  min-width: 0;
}

/* TOC */
.toc {
  padding: 28px 24px;
  border-radius: var(--radius-lg);
  position: sticky; top: 110px;
  align-self: start;
  min-width: 0;
}
.toc h4 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 500;
  margin: 0 0 16px;
}
.toc nav { display: flex; flex-direction: column; gap: 8px; }
.toc nav a {
  display: flex;
  align-items: center;
  min-width: 0;
  min-height: 40px;
  font-size: 13.5px;
  color: var(--ink-2);
  padding: 6px 0;
  transition: color 0.15s;
  overflow-wrap: anywhere;
}
.toc nav a:hover { color: var(--ink-0); }

/* PROSE */
.prose { max-width: 720px; min-width: 0; }
.prose section { margin-bottom: 56px; scroll-margin-top: 100px; }
.prose section:last-child { margin-bottom: 0; }
.prose h2 { font-size: 26px; letter-spacing: -0.02em; margin-bottom: 18px; }
.prose p, .prose li { color: var(--ink-1); font-size: 15.5px; line-height: 1.7; margin: 0 0 14px; }
.prose strong { font-weight: 600; color: var(--ink-0); }
.tldr {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.55;
  padding: 14px 18px;
  margin: 0 0 22px;
  border-radius: 12px;
  background: rgba(255,255,255,0.6);
  border: 1px solid rgba(255,255,255,0.95);
  color: var(--ink-1);
  position: relative;
  padding-left: 56px;
}
.tldr::before {
  content: "TL;DR";
  position: absolute;
  left: 14px; top: 14px;
  font-size: 9px;
  letter-spacing: 0.16em;
  color: #6d28d9;
  font-weight: 600;
}

.sp-list { list-style: none; padding: 0; margin: 0; }
.sp-list li {
  padding: 12px 0;
  border-bottom: 1px solid rgba(20,18,28,0.06);
}
.sp-list li:last-child { border-bottom: 0; }

@media (max-width: 1000px) {
  .legal-grid { grid-template-columns: minmax(0, 1fr); gap: 32px; }
  .toc { position: static; }
}
