/* Legal pages vertical sidebar and layout */
:root { --primary: #7c3aed; --text: #0f172a; --border: #e2e8f0; --card: #ffffff; }

/* Fill available height and ensure columns stretch equally */
.legal-container, main { display: flex; flex-direction: column; flex: 1 0 auto; min-height: 0; }
.legal-layout { display:grid; grid-template-columns: 220px 1fr; gap: 24px; align-items: stretch; min-height: 0; }
.legal, .legal-sidebar { height: 100%; }
.legal-sidebar { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 12px; align-self: start; position: sticky; top: 72px; }
.legal-sidebar h3 { margin: 0 0 8px; font-size: 16px; color: #111827; }
.side-links { display:flex; flex-direction:column; gap: 8px; }
.side-link { display:block; padding: 8px 12px; border-radius: 8px; border: 1px solid var(--border); color: var(--text); font-weight: 600; background: #fff; }
.side-link:hover { border-color: var(--primary); color: var(--primary); background: rgba(124,58,237,.06); }
.side-link[aria-current="page"] { background: var(--primary); color: #fff; border-color: var(--primary); }

@media (max-width: 768px) {
  .legal-layout { grid-template-columns: 1fr; }
  .legal-sidebar { position: static; }
}