/* ============================================================
   Mentionova Docs — layout + prose styles
   Built on top of lib.css (tokens) + site.css (nav/footer).
   ============================================================ */

/* ---------- DOCS SHELL ---------- */
.docs-shell {
  display:flex;
  max-width:var(--content-max);
  margin:0 auto;
  min-height:calc(100vh - 66px);
}

/* ---------- SIDEBAR ---------- */
.doc-sidebar {
  position:sticky;
  top:66px;
  width:260px;
  height:calc(100vh - 66px);
  flex:none;
  overflow-y:auto;
  border-right:1px solid var(--border);
  background:var(--bg);
  z-index:20;
  padding:0 0 32px;
  scrollbar-width:thin;
  scrollbar-color:var(--border-strong) transparent;
}
.doc-sidebar::-webkit-scrollbar { width:5px; }
.doc-sidebar::-webkit-scrollbar-thumb { background:var(--border-strong); border-radius:4px; }

.doc-sidebar .sb-brand {
  display:flex;
  align-items:center;
  gap:8px;
  padding:20px 20px 16px;
  border-bottom:1px solid var(--border);
  margin-bottom:8px;
  text-decoration:none;
  color:var(--text);
}
.doc-sidebar .sb-brand .wm {
  font-family:var(--font-display);
  font-weight:500;
  font-size:18px;
  letter-spacing:-.02em;
}
.doc-sidebar .sb-brand .sb-label {
  font-size:13px;
  color:var(--text-subtle);
  font-weight:400;
  margin-left:2px;
}

.doc-sidebar nav { padding:0 10px; }

/* section toggle */
.sb-section {}
.sb-toggle {
  display:flex;
  align-items:center;
  gap:7px;
  width:100%;
  padding:8px 10px;
  border:none;
  border-radius:var(--r-sm);
  background:transparent;
  cursor:pointer;
  font-family:var(--font-sans);
  font-size:13.5px;
  font-weight:600;
  color:var(--text-muted);
  transition:color var(--dur-fast), background var(--dur-fast);
  text-align:left;
}
.sb-toggle:hover { color:var(--text); background:var(--surface-2); }
.sb-toggle.is-active { color:var(--text); }

.sb-chevron {
  width:12px; height:12px;
  flex:none;
  transition:transform var(--dur-base) var(--ease-out);
  color:var(--text-faint);
}
.sb-toggle[aria-expanded="true"] .sb-chevron { transform:rotate(90deg); }

/* section pages */
.sb-pages {
  display:none;
  margin:0 0 4px 16px;
  padding:0 0 0 12px;
  border-left:1px solid var(--border);
  list-style:none;
}
.sb-pages.is-open { display:block; }

.sb-pages a {
  display:block;
  padding:5px 10px;
  border-radius:var(--r-sm);
  font-size:13px;
  color:var(--text-muted);
  transition:color var(--dur-fast), background var(--dur-fast);
  text-decoration:none;
  line-height:1.4;
}
.sb-pages a:hover { color:var(--text); background:var(--surface-2); }
.sb-pages a.is-current {
  background:var(--mark-bg);
  color:var(--mark-text);
  font-weight:500;
}

/* ---------- MOBILE SIDEBAR ---------- */
.doc-mob-toggle {
  display:none;
  position:fixed;
  bottom:20px;
  right:20px;
  z-index:60;
  width:48px; height:48px;
  border-radius:50%;
  border:none;
  background:var(--signal);
  color:var(--signal-ink);
  cursor:pointer;
  box-shadow:var(--shadow-lg);
  align-items:center;
  justify-content:center;
}
.doc-mob-toggle svg { width:20px; height:20px; }

.doc-overlay {
  display:none;
  position:fixed;
  inset:0;
  z-index:15;
  background:var(--overlay);
}

@media(max-width:860px){
  .doc-sidebar {
    position:fixed;
    top:0; left:0;
    height:100vh;
    z-index:50;
    transform:translateX(-100%);
    transition:transform var(--dur-slow) var(--ease-out);
  }
  .doc-sidebar.is-open { transform:translateX(0); }
  .doc-mob-toggle { display:flex; }
  .doc-overlay.is-open { display:block; }
}

/* ---------- MAIN CONTENT ---------- */
.doc-main {
  flex:1;
  min-width:0;
  padding:36px 28px 64px 48px;
  max-width:780px;
}
@media(max-width:860px){
  .doc-main { padding:28px 20px 48px; }
}

/* ---------- BREADCRUMBS ---------- */
.doc-crumbs {
  display:flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--text-faint);
  margin-bottom:24px;
  flex-wrap:wrap;
}
.doc-crumbs a {
  color:var(--text-subtle);
  text-decoration:none;
  transition:color var(--dur-fast);
}
.doc-crumbs a:hover { color:var(--signal); }
.doc-crumbs .sep {
  display:inline-flex;
  color:var(--text-faint);
  opacity:.6;
}
.doc-crumbs .sep svg { width:10px; height:10px; }

/* ---------- PAGE HEADER ---------- */
.doc-title {
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(28px,4vw,38px);
  line-height:1.1;
  letter-spacing:-.025em;
  color:var(--text);
  margin:0 0 8px;
}
.doc-desc {
  font-size:16px;
  line-height:1.6;
  color:var(--text-muted);
  margin:0 0 40px;
  max-width:60ch;
}

/* ---------- PROSE ---------- */
.doc-prose { line-height:1.7; }

.doc-prose h2 {
  font-family:var(--font-display);
  font-weight:500;
  font-size:22px;
  letter-spacing:-.018em;
  color:var(--text);
  margin:44px 0 16px;
  line-height:1.2;
}
.doc-prose h2:first-child { margin-top:0; }

.doc-prose h3 {
  font-family:var(--font-display);
  font-weight:500;
  font-size:18px;
  color:var(--text);
  margin:32px 0 12px;
  line-height:1.25;
}

.doc-prose p {
  font-size:14.5px;
  line-height:1.7;
  color:var(--text-muted);
  margin:0 0 16px;
}

.doc-prose strong {
  color:var(--text);
  font-weight:600;
}

.doc-prose a {
  color:var(--signal);
  text-decoration:none;
  transition:color var(--dur-fast);
}
.doc-prose a:hover { text-decoration:underline; }

.doc-prose ul, .doc-prose ol {
  margin:0 0 18px;
  padding-left:22px;
}
.doc-prose li {
  font-size:14.5px;
  line-height:1.65;
  color:var(--text-muted);
  margin-bottom:6px;
}
.doc-prose li strong { color:var(--text); }

.doc-prose code {
  font-family:var(--font-mono);
  font-size:13px;
  background:var(--surface-2);
  padding:2px 6px;
  border-radius:var(--r-xs);
  color:var(--text);
}

/* tables */
.doc-prose table {
  width:100%;
  border-collapse:collapse;
  font-size:13.5px;
  margin:0 0 24px;
}
.doc-prose th {
  text-align:left;
  font-weight:600;
  color:var(--text);
  border-bottom:2px solid var(--border);
  padding:8px 14px 8px 0;
}
.doc-prose td {
  border-bottom:1px solid var(--border);
  padding:8px 14px 8px 0;
  color:var(--text-muted);
  vertical-align:top;
}
.doc-prose tr:last-child td { border-bottom:none; }

/* ---------- PREV / NEXT ---------- */
.doc-pager {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-top:56px;
  padding-top:32px;
  border-top:1px solid var(--border);
}
.doc-pager a {
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:14px 16px;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  text-decoration:none;
  transition:border-color var(--dur-fast), background var(--dur-fast);
}
.doc-pager a:hover {
  border-color:var(--signal);
  background:var(--surface);
}
.doc-pager a.pager-next { text-align:right; justify-content:flex-end; }
.doc-pager .pager-dir {
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-faint);
  margin-bottom:3px;
}
.doc-pager .pager-label {
  font-size:14px;
  font-weight:500;
  color:var(--text);
  transition:color var(--dur-fast);
}
.doc-pager a:hover .pager-label { color:var(--signal); }
.doc-pager .pager-arrow {
  width:16px; height:16px;
  flex:none;
  color:var(--text-faint);
  margin-top:2px;
  transition:color var(--dur-fast);
}
.doc-pager a:hover .pager-arrow { color:var(--signal); }
.doc-pager .pager-spacer { visibility:hidden; }

@media(max-width:560px){
  .doc-pager { grid-template-columns:1fr; }
}

/* ---------- DOCS INDEX PAGE ---------- */
.doc-index { padding:48px 28px 64px; max-width:840px; margin:0 auto; }
@media(max-width:860px){ .doc-index { padding:32px 20px 48px; } }
.doc-index h1 {
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(30px,4.5vw,42px);
  letter-spacing:-.025em;
  color:var(--text);
  margin:0 0 8px;
  line-height:1.1;
}
.doc-index .idx-desc {
  font-size:16px;
  color:var(--text-muted);
  margin:0 0 40px;
  max-width:56ch;
  line-height:1.6;
}
.idx-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px,1fr));
  gap:16px;
}
.idx-card {
  display:block;
  padding:20px;
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  text-decoration:none;
  transition:border-color var(--dur-fast), background var(--dur-fast), box-shadow var(--dur-fast);
  background:var(--surface);
}
.idx-card:hover {
  border-color:var(--signal);
  box-shadow:var(--shadow-sm);
}
.idx-card h2 {
  font-family:var(--font-display);
  font-weight:500;
  font-size:18px;
  color:var(--text);
  margin:0 0 6px;
  letter-spacing:-.015em;
}
.idx-card p {
  font-size:13.5px;
  line-height:1.5;
  color:var(--text-muted);
  margin:0 0 10px;
}
.idx-card .idx-count {
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-faint);
}
