/* Bedrock docs — dark theme, layered on landing.css tokens.
   Load AFTER landing.css (which defines the :root vars + nav/brand). */

body { background: var(--bg-canvas); }
/* docs read better without the moving graph — calm, solid canvas + a faint top glow */
.docs-glow {
  position: fixed; inset: 0 0 auto 0; height: 420px; z-index: 0; pointer-events: none;
  background: radial-gradient(720px 320px at 20% -10%, rgba(79,164,122,.12), transparent 70%);
}

.nav .docs-label { color: var(--ink-mute); font-weight: 500; margin-left: -4px; }

.docs-shell {
  position: relative; z-index: 1;
  max-width: 1200px; margin: 0 auto; padding: 0 28px;
  display: grid; grid-template-columns: 252px 1fr; gap: 48px; align-items: start;
}

/* sidebar */
.docs-side {
  position: sticky; top: 60px; align-self: start;
  max-height: calc(100vh - 60px); overflow-y: auto;
  padding: 30px 8px 40px; display: flex; flex-direction: column; gap: 2px;
}
.docs-side .shd {
  font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-mute); padding: 0 12px; margin: 18px 0 8px;
}
.docs-side .shd:first-child { margin-top: 4px; }
.docs-side a {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 12px; border-radius: 9px; font-size: 14px; color: var(--ink-soft);
  line-height: 1.35; transition: background var(--ease) .15s, color var(--ease) .15s;
}
.docs-side a .n {
  width: 18px; flex: none; text-align: right; font-size: 11.5px;
  color: var(--ink-mute); font-variant-numeric: tabular-nums; font-family: var(--font-mono);
}
.docs-side a:hover { background: rgba(255,255,255,.05); color: var(--ink); }
.docs-side a.active { background: rgba(79,164,122,.12); color: var(--ink); font-weight: 600; }
.docs-side a.active .n { color: var(--sage-400); }

/* article */
.docs-main { min-width: 0; padding: 40px 0 96px; }
.docs-crumb { font-size: 12.5px; color: var(--ink-mute); margin-bottom: 22px; display: flex; gap: 8px; align-items: center; }
.docs-crumb a { color: var(--ink-mute); }
.docs-crumb a:hover { color: var(--ink-soft); }

.md { max-width: 740px; font-size: 16px; line-height: 1.72; color: var(--ink-soft); }
.md > :first-child { margin-top: 0; }
.md h1 {
  font-family: var(--font-display); font-size: clamp(30px,4vw,40px); line-height: 1.08;
  letter-spacing: -.025em; font-weight: 700; color: var(--ink); margin: 0 0 .5em;
}
.md h2 {
  font-family: var(--font-display); font-size: 24px; letter-spacing: -.01em; font-weight: 600;
  color: var(--ink); margin: 2em 0 .55em; padding-top: 1.4em; border-top: 1px solid var(--border);
}
.md h3 { font-family: var(--font-display); font-size: 18.5px; font-weight: 600; color: var(--ink); margin: 1.7em 0 .45em; }
.md p { margin: 0 0 1.05em; }
.md strong { color: var(--ink); font-weight: 600; }
.md em { color: var(--ink-soft); }
.md a { color: var(--sage-400); border-bottom: 1px solid rgba(79,164,122,.32); padding-bottom: 1px; transition: border-color var(--ease) .15s, color var(--ease) .15s; }
.md a:hover { color: var(--sage-300); border-color: var(--sage-400); }

.md ul, .md ol { padding-left: 1.3em; margin: 0 0 1.1em; }
.md li { margin: .35em 0; }
.md li::marker { color: var(--ink-mute); }

.md code {
  font-family: var(--font-mono); font-size: .86em;
  background: rgba(255,255,255,.06); border: 1px solid var(--border);
  padding: .12em .42em; border-radius: 6px; color: var(--sage-300);
}
.md pre {
  background: var(--bg-sidebar); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px 18px; overflow-x: auto; margin: 0 0 1.2em;
}
.md pre code { background: none; border: none; padding: 0; color: var(--ink); font-size: 13px; line-height: 1.6; }

.md blockquote {
  margin: 1.3em 0; padding: 14px 18px; border-left: 3px solid var(--sage-500);
  background: rgba(79,164,122,.07); border-radius: 0 10px 10px 0; color: var(--ink-soft);
}
.md blockquote p { margin: 0; }

.md table { border-collapse: collapse; width: 100%; margin: 0 0 1.4em; font-size: 14.5px; }
.md th, .md td { border: 1px solid var(--border); padding: 9px 14px; text-align: left; vertical-align: top; }
.md th { background: var(--bg-sidebar); color: var(--ink); font-weight: 600; }
.md td { color: var(--ink-soft); }
.md tr:nth-child(even) td { background: rgba(255,255,255,.02); }

.md hr { border: none; border-top: 1px solid var(--border); margin: 2.2em 0; }

/* subscribe band at the foot of every doc page */
.docs-subscribe {
  margin-top: 40px; border: 1px solid var(--border-strong); border-radius: 16px;
  padding: 24px 26px; background: var(--panel-solid); position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1fr auto; gap: 22px 28px; align-items: center;
}
.docs-subscribe::before {
  content: ""; position: absolute; right: -50px; top: -50px; width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(79,164,122,.16), transparent 70%); pointer-events: none;
}
.docs-subscribe .ds-copy h3 { font-family: var(--font-display); font-size: 18px; color: var(--ink); margin: 0 0 5px; letter-spacing: -.01em; }
.docs-subscribe .ds-copy p { font-size: 13.5px; color: var(--ink-soft); margin: 0; line-height: 1.5; max-width: 42ch; }
.docs-subscribe .sub-form { min-width: 320px; }
@media (max-width: 720px) {
  .docs-subscribe { grid-template-columns: 1fr; gap: 16px; padding: 22px; }
  .docs-subscribe .sub-form { min-width: 0; }
}

/* prev / next */
.docs-pager { display: flex; gap: 14px; margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--border); }
.docs-pager a {
  flex: 1; min-width: 0; border: 1px solid var(--border); border-radius: 14px; padding: 16px 18px;
  background: var(--panel); transition: border-color var(--ease) .18s, background var(--ease) .18s;
}
.docs-pager a:hover { border-color: var(--border-strong); background: var(--card); }
.docs-pager .dir { font-size: 11.5px; color: var(--ink-mute); letter-spacing: .04em; text-transform: uppercase; }
.docs-pager .ttl { font-size: 15px; color: var(--ink); font-weight: 600; margin-top: 4px; }
.docs-pager a.next { text-align: right; }
.docs-pager .ph { flex: 1; }

@media (max-width: 900px) {
  .docs-shell { grid-template-columns: 1fr; gap: 0; }
  .docs-side {
    position: static; max-height: none; overflow: visible; flex-direction: row; flex-wrap: wrap;
    gap: 4px; padding: 14px 0 6px; border-bottom: 1px solid var(--border); margin-bottom: 8px;
  }
  .docs-side .shd { display: none; }
  .docs-side a { padding: 6px 11px; font-size: 13px; }
  .docs-side a .n { display: none; }
  .docs-main { padding: 24px 0 72px; }
}
