/* Docs site layout. Depends on colors_and_type.css + components.css */
.docs { background: var(--bg); color: var(--fg-1); min-height: 100vh; }

/* Top bar */
.docs-top { position: sticky; top: 0; z-index: 30; height: 56px; display: flex; align-items: center; gap: 18px; padding: 0 22px; border-bottom: 1px solid var(--line); background: color-mix(in srgb, var(--bg) 88%, transparent); backdrop-filter: blur(10px); }
.docs-top .brand { display: flex; align-items: center; gap: 9px; font-weight: 600; font-size: 15px; }
.docs-top .brand img { height: 24px; width: 24px; }
.docs-top .brand .tag { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 1px 6px; margin-left: 2px; }
.docs-search { margin-left: auto; display: flex; align-items: center; gap: 8px; width: 280px; height: 34px; padding: 0 11px; border: 1px solid var(--line); border-radius: var(--r); background: var(--surface-1); color: var(--fg-3); font-size: 13px; cursor: text; }
.docs-search .k { margin-left: auto; font-family: var(--font-mono); font-size: 11px; border: 1px solid var(--line); border-radius: 4px; padding: 1px 5px; background: var(--bg); }
.docs-top .ghbtn { font-size: 13px; color: var(--fg-2); text-decoration: none; }

/* Layout */
.docs-layout { display: grid; grid-template-columns: 256px minmax(0,1fr) 220px; max-width: 1340px; margin: 0 auto; align-items: start; }

/* Sidebar */
.docs-side { position: sticky; top: 56px; height: calc(100vh - 56px); overflow: auto; padding: 26px 18px 40px; border-right: 1px solid var(--line); }
.docs-side .grp { margin-bottom: 22px; }
.docs-side .grp-t { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: var(--fg-3); padding: 0 10px 8px; }
.docs-side a { display: block; padding: 6px 10px; border-radius: var(--r-sm); font-size: 13.5px; color: var(--fg-2); text-decoration: none; border-left: 2px solid transparent; transition: color var(--dur-fast) var(--ease); cursor: pointer; }
.docs-side a:hover { color: var(--fg-1); }
.docs-side a.on { color: var(--accent); border-left-color: var(--accent); font-weight: 500; }

/* Content */
.docs-main { padding: 36px 56px 80px; min-width: 0; }
.crumbs { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); margin-bottom: 18px; }
.crumbs .sep { margin: 0 7px; }
.doc h1 { font-size: 38px; letter-spacing: -0.02em; margin: 0 0 8px; }
.doc .doc-lede { font-size: 18px; color: var(--fg-2); line-height: 1.55; margin: 0 0 30px; }
.doc h2 { font-size: 24px; letter-spacing: -0.01em; margin: 42px 0 14px; padding-top: 8px; }
.doc h3 { font-size: 17px; margin: 28px 0 10px; }
.doc p { font-size: 15.5px; line-height: 1.7; color: var(--fg-1); margin: 0 0 16px; max-width: 64ch; }
.doc p, .doc li { text-wrap: pretty; }
.doc a.inline { color: var(--accent); text-decoration: none; border-bottom: 1px solid var(--accent-weak-line); }
.doc strong { font-weight: 600; }
.doc code { font-family: var(--font-mono); font-size: 0.88em; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 1px 5px; color: var(--fg-1); }
.doc ul { margin: 0 0 16px; padding-left: 22px; }
.doc li { font-size: 15.5px; line-height: 1.7; margin: 0 0 7px; max-width: 64ch; }
.doc blockquote { margin: 0 0 20px; padding: 4px 0 4px 18px; border-left: 3px solid var(--accent); font-size: 18px; line-height: 1.5; color: var(--fg-1); font-weight: 500; }

.doc-table { width: 100%; border-collapse: collapse; margin: 0 0 22px; font-size: 14px; }
.doc-table th { text-align: left; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-3); padding: 9px 12px; border-bottom: 1px solid var(--line-strong); }
.doc-table td { padding: 11px 12px; border-bottom: 1px solid var(--line); vertical-align: top; color: var(--fg-2); }
.doc-table td:first-child { color: var(--fg-1); }
.doc-table code { font-size: 12.5px; }

.callout { display: flex; gap: 12px; padding: 14px 16px; border-radius: var(--r-md); border: 1px solid var(--accent-weak-line); background: var(--accent-weak); margin: 0 0 22px; }
.callout .ci { color: var(--accent); flex: none; margin-top: 1px; }
.callout p { margin: 0; font-size: 14px; color: var(--fg-1); }
.callout.warn { border-color: var(--state-pending-line); background: var(--state-pending-bg); }
.callout.warn .ci { color: var(--state-pending-fg); }

.codeblock { background: var(--terminal-bg); color: var(--terminal-fg); font-family: var(--font-mono); font-size: 13px; line-height: 1.7; border-radius: var(--r-md); padding: 16px 18px; margin: 0 0 22px; overflow: auto; }
.codeblock .c { color: var(--terminal-muted); }
.codeblock .pmt { color: #6fd0b3; }
.codeblock .ok { color: #6fd0b3; }
.codeblock .warn { color: #dba94a; }

.doc-foot { display: flex; justify-content: space-between; gap: 16px; margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line); }
.doc-foot a { text-decoration: none; border: 1px solid var(--line); border-radius: var(--r-md); padding: 12px 16px; min-width: 180px; transition: border-color var(--dur) var(--ease); }
.doc-foot a:hover { border-color: var(--accent); }
.doc-foot .dir { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }
.doc-foot .ttl { font-size: 14px; color: var(--fg-1); margin-top: 3px; }
.doc-foot .next { text-align: right; }

/* TOC */
.docs-toc { position: sticky; top: 56px; height: calc(100vh - 56px); overflow: auto; padding: 36px 22px; }
.docs-toc .toc-t { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 12px; }
.docs-toc a { display: block; font-size: 13px; color: var(--fg-3); text-decoration: none; padding: 5px 0 5px 12px; border-left: 2px solid var(--line); transition: color var(--dur-fast) var(--ease); }
.docs-toc a:hover, .docs-toc a.on { color: var(--accent); border-left-color: var(--accent); }
.docs-toc .edit { margin-top: 20px; font-size: 13px; }
.docs-toc .edit a { border-left: 0; padding-left: 0; color: var(--fg-2); display: inline-flex; gap: 6px; align-items: center; }

@media (max-width: 1100px) { .docs-layout { grid-template-columns: 240px minmax(0,1fr); } .docs-toc { display: none; } }
@media (max-width: 820px) { .docs-layout { grid-template-columns: 1fr; } .docs-side { display: none; } .docs-main { padding: 28px 22px 60px; } }
