/* Blog list page */
.blog-list { padding-top: 120px; min-height: 100vh; }
.blog-list .container { max-width: 800px; }
.blog-list h1 { margin-bottom: 2rem; }
.blog-post-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 2rem;
    margin-bottom: 1.5rem;
    transition: border-color 0.2s ease;
}
.blog-post-card:hover { border-color: var(--accent); }
.blog-post-card h2 { font-size: 1.5rem; margin-bottom: 0.5rem; }
.blog-post-card h2 a { color: var(--text-primary); text-decoration: none; }
.blog-post-card h2 a:hover { color: var(--accent); }
.blog-post-meta { font-size: 0.875rem; color: var(--text-muted); margin-bottom: 1rem; }
.blog-post-summary { color: var(--text-secondary); margin: 0; }

/* Blog single post */
.blog-post { padding-top: 120px; min-height: 100vh; }
.blog-post .container { max-width: 960px; }
.blog-post-header { margin-bottom: 3rem; padding-bottom: 2rem; border-bottom: 1px solid var(--border); }
.blog-post-header h1 { margin-bottom: 0.75rem; }
.blog-post-body { line-height: 1.8; }
.blog-post-body h2 { margin-top: 2.5rem; margin-bottom: 1rem; }
.blog-post-body h3 { margin-top: 2rem; margin-bottom: 0.75rem; }
.blog-post-body p { margin-bottom: 1.25rem; }
.blog-post-body ul, .blog-post-body ol { margin-bottom: 1.25rem; padding-left: 1.5rem; }
.blog-post-body li { margin-bottom: 0.5rem; }
.blog-post-body code {
    font-family: var(--font-mono);
    font-size: 0.85em;
    background: var(--bg-tertiary);
    padding: 0.2em 0.4em;
    border-radius: 4px;
    color: var(--accent);
}
.blog-post-body a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.blog-post-body a:hover { color: var(--accent-hover); }
.blog-nav { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.blog-nav a { color: var(--text-muted); }
.blog-post-body figure { text-align: center; margin: 2rem 0; }
.blog-post-body figure img { max-width: 100%; height: auto; border-radius: 8px; border: 1px solid var(--border); }
.blog-post-body figcaption { font-size: 0.875rem; color: var(--text-muted); margin-top: 0.75rem; font-style: italic; }
.blog-post-subtitle { font-family: var(--font-body); font-size: 1.2rem; color: var(--text-secondary); font-weight: 400; margin-top: 0.5rem; }
.blog-post-body table { width: 100%; border-collapse: collapse; margin: 2rem 0; font-size: 0.9rem; }
.blog-post-body thead th { background: var(--bg-tertiary); color: var(--text-primary); font-weight: 600; text-align: left; padding: 0.75rem 1rem; border-bottom: 2px solid var(--accent); white-space: nowrap; }
.blog-post-body tbody td { padding: 0.65rem 1rem; border-bottom: 1px solid var(--border); color: var(--text-secondary); }
.blog-post-body tbody tr:hover { background: rgba(255, 255, 255, 0.02); }
.blog-post-body tbody td strong { color: var(--text-primary); }
