/* dev-docs — technical documentation site. Mono-heavy, structured, code-first. */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: var(--fs-base, 15px); }
body { margin: 0; font-family: var(--f-body, system-ui, -apple-system, sans-serif); background: var(--c-bg, #FFFFFF); color: var(--c-text, #1F2328); line-height: var(--lh, 1.6); -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--c-accent, #0969DA); text-decoration: none; }
a:hover { text-decoration: underline; }
code, pre { font-family: var(--f-code, 'JetBrains Mono', 'Fira Code', monospace); }
pre { background: #0D1117; color: #C9D1D9; padding: 1rem 1.25rem; overflow-x: auto; border-radius: 6px; font-size: 0.85rem; line-height: 1.5; }
code { background: #F6F8FA; color: #0550AE; padding: 0.15em 0.45em; border-radius: 4px; font-size: 0.9em; border: 1px solid #D0D7DE; }
pre code { background: transparent; color: inherit; padding: 0; border: none; }
.container { max-width: var(--max-w, 880px); margin: 0 auto; padding: 0 1.5rem; }
.site-header { background: #0D1117; color: #C9D1D9; padding: 0.85rem 0; border-bottom: 1px solid #30363D; }
.site-header .container { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; }
.brand { font-family: var(--f-code); font-weight: 700; font-size: 1.1rem; color: #FFFFFF; letter-spacing: -0.01em; }
.brand::before { content: '$ '; color: #58A6FF; }
.tagline { display: none; }
.primary-nav { display: flex; gap: 1.25rem; }
.primary-nav a { color: #C9D1D9; font-size: 0.9rem; font-weight: 500; }
.primary-nav a:hover { color: #58A6FF; }
.site-main { padding: 2.5rem 0 5rem; }
.page-title { font-family: var(--f-heading); font-size: 1.5rem; font-weight: 700; margin: 0 0 1.5rem; padding-bottom: 0.75rem; border-bottom: 1px solid #D0D7DE; color: var(--c-primary); }
.posts { list-style: none; padding: 0; margin: 0; }
.post-card { padding: 1.25rem 0; border-bottom: 1px solid #EAEEF2; }
.post-card .cover img { margin-bottom: 0.75rem; max-height: 200px; object-fit: cover; }
.post-card h2 { font-family: var(--f-heading); font-size: 1.15rem; font-weight: 600; margin: 0.25rem 0 0.4rem; }
.post-card h2 a { color: var(--c-primary, #1F2328); }
.post-card h2 a:hover { color: var(--c-accent, #0969DA); text-decoration: underline; }
.post-card .meta { color: var(--c-muted, #656D76); font-size: 0.8rem; font-family: var(--f-code); }
.post-card .excerpt { font-size: 0.92rem; color: var(--c-text); margin: 0.4rem 0; }
.read-more { font-family: var(--f-code); font-size: 0.85rem; color: var(--c-accent); }
.read-more::before { content: '→ '; }
.post-single .post-header h1 { font-family: var(--f-heading); font-size: 2rem; font-weight: 700; margin: 0 0 0.5rem; color: var(--c-primary); letter-spacing: -0.01em; }
.post-single .meta { color: var(--c-muted); font-size: 0.85rem; font-family: var(--f-code); padding-bottom: 1rem; border-bottom: 1px solid #EAEEF2; }
.post-single .cover { margin: 1.5rem 0; }
.post-body h2 { font-family: var(--f-heading); color: var(--c-primary); margin-top: 2.5rem; font-size: 1.5rem; padding-bottom: 0.4rem; border-bottom: 1px solid #D0D7DE; }
.post-body h3 { font-family: var(--f-heading); color: var(--c-primary); margin-top: 1.75rem; font-size: 1.2rem; }
.post-body h2::before, .post-body h3::before { content: '# '; color: var(--c-muted); font-family: var(--f-code); }
.post-body p { margin: 0.9rem 0; }
.post-body blockquote { background: #FFF8C5; border-left: 4px solid #D4A72C; padding: 0.85rem 1rem; border-radius: 0 6px 6px 0; margin: 1.25rem 0; }
.post-body blockquote::before { content: '⚠ Note: '; font-weight: 600; color: #9A6700; }
.post-body table { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: 0.9rem; }
.post-body th, .post-body td { border: 1px solid #D0D7DE; padding: 0.5rem 0.75rem; }
.post-body th { background: #F6F8FA; font-weight: 600; }
.post-footer { margin-top: 3rem; padding-top: 1.5rem; border-top: 1px solid #D0D7DE; font-family: var(--f-code); font-size: 0.9rem; }
.error-page { text-align: center; padding: 4rem 0; font-family: var(--f-code); }
.error-page h1 { color: var(--c-primary); font-size: 2rem; }
.site-footer { border-top: 1px solid #D0D7DE; padding: 1.5rem 0; color: var(--c-muted); font-family: var(--f-code); font-size: 0.85rem; background: #F6F8FA; }
.empty { color: var(--c-muted); font-family: var(--f-code); }
