/*
 * RAXE Design System — Table of Contents / Sidebar
 * Sticky sidebar, scroll-spy nav, nested sections.
 * Depends on: tokens.css
 */

/* ── Layout: sidebar + content ── */
.layout-sidebar {
  display: grid; grid-template-columns: 220px 1fr; gap: var(--space-12);
  padding-top: var(--space-12);
}
@media (max-width: 1024px) {
  .layout-sidebar { grid-template-columns: 1fr; }
  .sidebar { display: none; }
}

/* ── Sidebar ── */
.sidebar {
  position: sticky; top: calc(var(--nav-height) + var(--space-6));
  max-height: calc(100vh - var(--nav-height) - var(--space-12));
  overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(56,189,248,0.2) transparent;
}

/* ── TOC title ── */
.toc-title {
  font-family: var(--font-mono); font-size: 9px; font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
  color: var(--text-dim); margin-bottom: var(--space-3);
  padding: 0 var(--space-3);
}

/* ── TOC list ── */
.toc-list { list-style: none; padding: 0; margin: 0; }
.toc-item { margin-bottom: 2px; }

/* ── TOC link ── */
.toc-link {
  display: block; font-size: var(--fs-caption); color: var(--text-muted);
  padding: 6px var(--space-3);
  border-left: 2px solid transparent;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  transition: all var(--duration-fast) var(--ease-default);
}
.toc-link:hover {
  color: var(--text-primary); background: rgba(56,189,248,0.05);
  border-left-color: var(--border-strong);
}
.toc-link.active {
  color: var(--text-primary); font-weight: var(--weight-semibold);
  background: rgba(56,189,248,0.06);
  border-left-color: var(--cyan);
}

/* ── Nested sub-links ── */
.toc-sub .toc-link {
  padding-left: var(--space-6); font-size: var(--fs-label);
}

/* ── Group label (sidebar section headings) ── */
.toc-group-label {
  font-family: var(--font-mono); font-size: 9px; font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest); text-transform: uppercase;
  color: var(--text-dim);
  padding: var(--space-3) var(--space-3) var(--space-1);
  margin-top: var(--space-2);
}
.toc-group-label:first-child { margin-top: 0; }

/* ── Floating sidebar variant (TI report style) ── */
.sidebar-floating {
  position: fixed; left: var(--space-6); top: 50%;
  transform: translateY(-50%); z-index: var(--z-overlay);
  opacity: 0; visibility: hidden; transition: var(--transition-ui);
  background: var(--surface-overlay); border: 1px solid var(--border-default);
  border-radius: var(--radius-lg); padding: var(--space-4);
  width: 180px; box-shadow: var(--shadow-md);
}
.sidebar-floating.visible { opacity: 1; visibility: visible; }
