/* docs.krowforge.com — minimal, fast, dark, themed to match the IDE */
:root {
  --bg-0: #0b0d10;
  --bg-1: #11141a;
  --bg-2: #161a22;
  --bg-3: #1d222c;
  --border: #232934;
  --border-strong: #2f3744;
  --ink-0: #e7ecf3;
  --ink-1: #b9c1cd;
  --ink-2: #7e8794;
  --ink-3: #59616d;
  --accent: #9b8cff;
  --accent-soft: rgba(155, 140, 255, 0.18);
  --accent-line: rgba(155, 140, 255, 0.45);
  --code-bg: #0d1017;
  --kbd-bg: #1d222c;
  --good: #4ec9b0;
  --warn: #e2c08d;
  --bad: #f48771;
  --maxw: 760px;
  --rail: 248px;
  --font-sans: ui-sans-serif, -apple-system, "Segoe UI", Inter, system-ui, sans-serif;
  --font-mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  background: var(--bg-0);
  color: var(--ink-0);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------- layout ---------- */
.docs-shell { display: grid; grid-template-columns: var(--rail) minmax(0, 1fr); min-height: 100vh; }
.docs-rail {
  position: sticky; top: 0; align-self: start; height: 100vh;
  background: var(--bg-1);
  border-right: 1px solid var(--border);
  padding: 18px 14px 24px 18px;
  overflow-y: auto;
}
.docs-main {
  padding: 32px max(28px, calc((100vw - var(--rail) - var(--maxw)) / 2)) 80px;
  min-width: 0;
}
.docs-content { max-width: var(--maxw); }

/* ---------- rail ---------- */
.docs-brand {
  display: flex; align-items: center; gap: 8px;
  margin: 4px 0 18px;
  font-weight: 700; letter-spacing: -0.01em; font-size: 15px;
  color: var(--ink-0);
}
.docs-brand-mark {
  width: 22px; height: 22px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--accent), #6ce0c5);
  display: inline-flex; align-items: center; justify-content: center;
  color: #0b0d10; font-weight: 800; font-size: 11px;
}
.docs-rail h5 {
  margin: 18px 6px 6px;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  font-weight: 600;
}
.docs-rail nav a {
  display: block;
  padding: 5px 8px;
  border-radius: 6px;
  color: var(--ink-1);
  font-size: 13.5px;
  line-height: 1.45;
  margin: 1px 0;
}
.docs-rail nav a:hover { background: var(--bg-2); color: var(--ink-0); text-decoration: none; }
.docs-rail nav a.active {
  background: var(--accent-soft);
  color: var(--ink-0);
  box-shadow: inset 2px 0 0 var(--accent);
}

/* ---------- typography ---------- */
.docs-content h1 {
  font-size: 28px; font-weight: 700; letter-spacing: -0.02em;
  margin: 0 0 6px;
}
.docs-content .lede {
  color: var(--ink-1); font-size: 16px; margin: 0 0 28px;
}
.docs-content h2 {
  font-size: 19px; font-weight: 600; letter-spacing: -0.01em;
  margin: 36px 0 10px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}
.docs-content h2:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.docs-content h3 {
  font-size: 15.5px; font-weight: 600;
  margin: 24px 0 6px;
  color: var(--ink-0);
}
.docs-content p { margin: 8px 0 12px; color: var(--ink-1); }
.docs-content ul, .docs-content ol { padding-left: 22px; color: var(--ink-1); }
.docs-content li { margin: 4px 0; }
.docs-content strong { color: var(--ink-0); font-weight: 600; }

/* ---------- code / kbd ---------- */
code, kbd, pre {
  font-family: var(--font-mono);
}
:not(pre) > code {
  background: var(--bg-2);
  border: 1px solid var(--border);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 0.88em;
  color: #e0c8ff;
}
pre {
  background: var(--code-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 16px;
  overflow-x: auto;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-1);
  margin: 14px 0 18px;
}
pre code { background: transparent; border: 0; padding: 0; color: inherit; font-size: inherit; }
kbd {
  background: var(--kbd-bg);
  border: 1px solid var(--border-strong);
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 11.5px;
  color: var(--ink-0);
  display: inline-block;
  line-height: 1.4;
}

/* ---------- tables ---------- */
table {
  width: 100%;
  border-collapse: collapse;
  margin: 14px 0 18px;
  font-size: 13.5px;
}
th, td {
  text-align: left;
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
th { color: var(--ink-0); font-weight: 600; background: var(--bg-1); }
tbody tr:hover { background: var(--bg-1); }

/* ---------- callouts ---------- */
.note, .tip, .warn {
  border-left: 3px solid var(--accent);
  background: var(--bg-1);
  padding: 10px 14px;
  margin: 14px 0 18px;
  border-radius: 0 6px 6px 0;
  color: var(--ink-1);
}
.tip { border-left-color: var(--good); }
.warn { border-left-color: var(--warn); }
.note strong, .tip strong, .warn strong { color: var(--ink-0); }

/* ---------- footer ---------- */
.docs-footer {
  margin-top: 60px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  display: flex; gap: 16px; justify-content: space-between;
  font-size: 12.5px; color: var(--ink-3);
}
.docs-footer a { color: var(--ink-2); }

/* ---------- mobile ---------- */
@media (max-width: 820px) {
  .docs-shell { grid-template-columns: 1fr; }
  .docs-rail { position: static; height: auto; border-right: 0; border-bottom: 1px solid var(--border); }
  .docs-main { padding: 24px 18px 60px; }
}
