/* Blog-specific styles */
.article-wrap { padding: 130px 0 90px; min-height: 70vh; }
.article-narrow { max-width: 760px; }
.back-link { color: var(--accent); font-family: var(--mono); font-size: 0.9rem; display: inline-block; margin-bottom: 30px; }
.back-link:hover { text-decoration: underline; }

.blog-index__title { font-size: clamp(2.2rem, 6vw, 3.2rem); color: var(--heading); font-weight: 800; }
.blog-index__sub { color: var(--text-dim); font-size: 1.1rem; margin: 12px 0 40px; }
.posts--list { grid-template-columns: 1fr; }

/* Article */
.article__meta { font-family: var(--mono); color: var(--accent); font-size: 0.88rem; }
.article__title { font-size: clamp(2rem, 6vw, 3rem); color: var(--heading); font-weight: 800; line-height: 1.15; margin: 12px 0 30px; letter-spacing: -0.5px; }
.article__body { color: var(--text-dim); font-size: 1.08rem; }
.article__body h2 { color: var(--heading); font-size: 1.5rem; margin: 38px 0 14px; }
.article__body h3 { color: var(--heading); font-size: 1.2rem; margin: 26px 0 10px; }
.article__body p { margin-bottom: 18px; }
.article__body ul, .article__body ol { margin: 0 0 18px 22px; }
.article__body li { margin-bottom: 8px; list-style: disc; }
.article__body ol li { list-style: decimal; }
.article__body strong { color: var(--text); }
.article__body a { color: var(--accent); text-decoration: underline; }
.article__body blockquote {
  border-left: 3px solid var(--accent); padding: 4px 0 4px 20px; margin: 22px 0;
  color: var(--text); font-style: italic;
}
.article__body code {
  font-family: var(--mono); font-size: 0.88em; background: rgba(124,92,255,0.14);
  color: var(--accent); padding: 2px 7px; border-radius: 6px;
}
.article__body pre {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px;
  padding: 20px; overflow-x: auto; margin: 22px 0; font-size: 0.9rem;
}
.article__body pre code { background: none; color: var(--text); padding: 0; }
.article__tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 36px 0; }
.article__nav { border-top: 1px solid var(--border); margin-top: 50px; padding-top: 26px; }
