/* Blog-specific UI improvements */
:root {
  --blog-text: #111;
  --blog-muted: #5b5b5b;
  --blog-border: #dcdcdc;
  --blog-link: #0a58ca;
  --blog-bg: #fff;
}

/* Scope reset for blog pages */
.blog-page, .blog-page * { box-sizing: border-box; }
body.blog-page { background: var(--blog-bg); color: var(--blog-text); line-height: 1.7; letter-spacing: .2px; }
body.blog-page a { color: var(--blog-link); }
body.blog-page a:hover { text-decoration: underline; }

/* Index */
.blog-hero {
  background: #fff;
  color: #101010;
  max-width: 860px;
  margin: 0 auto;
  padding: 28px 24px 10px;
}
.blog-hero .lead { color: var(--blog-muted); margin: 8px 0 0; }

.clusters, .latest { max-width: 860px; margin: 0 auto; padding: 18px 24px; }
.clusters h2, .latest h2 { margin: 24px 0 12px; }

ul.cards { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat( auto-fit, minmax(220px, 1fr) ); gap: 12px; }
.cards .card { border: 1px solid var(--blog-border); border-radius: 10px; overflow: hidden; background: #fff; }
.cards .card-link { display: block; padding: 14px; text-decoration: none; color: inherit; }
.cards .card-title { font-weight: 600; }
.cards .card-meta { color: var(--blog-muted); font-size: 13px; margin-top: 4px; }

ul.posts { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: 18px; }
ul.posts .post { display: grid; grid-template-columns: 160px 1fr; gap: 16px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--blog-border); }
ul.posts .post .thumb img { width: 160px; height: auto; border-radius: 8px; display: block; }
ul.posts .post .title { display: inline-block; font-size: 18px; font-weight: 650; color: var(--blog-text); text-decoration: none; margin: 0 0 6px; }
ul.posts .post .title:hover { text-decoration: underline; }
ul.posts .post .meta { color: var(--blog-muted); font-size: 13px; margin-bottom: 4px; }
ul.posts .post .meta a { color: inherit; }
ul.posts .post .desc { color: #1a1a1a; margin: 0; }

@media (max-width: 720px) {
  ul.posts .post { grid-template-columns: 1fr; }
  ul.posts .post .thumb img { width: 100%; }
}

/* Article page enhancements injected by enhance-blog */
nav.breadcrumb { font-size: 13px; color: var(--blog-muted); margin: 8px 0 8px; }
nav.breadcrumb a { color: inherit; text-decoration: none; }

.article-meta { display:flex; flex-wrap: wrap; gap: 10px; align-items: center; color: var(--blog-muted); font-size: 13px; margin: 6px 0 10px; }
.article-meta .badge { background: #f1f5ff; color: var(--blog-link); border: 1px solid #dbe7ff; border-radius: 999px; padding: 3px 8px; text-decoration: none; }
.article-share { display:flex; gap: 8px; margin: 8px 0 12px; }
.article-share a { display:inline-flex; align-items:center; gap:6px; color: var(--blog-link); text-decoration: none; font-size: 13px; }
.article-share svg { width: 16px; height: 16px; }

/* TOC */
nav.toc { border: 1px solid var(--blog-border); border-radius: 8px; padding: 10px 12px; margin: 10px 0 16px; background: #fafafa; }
nav.toc strong { display:block; margin-bottom: 6px; }
nav.toc ol { margin: 0 0 0 16px; }

/* Read next / Related */
section.read-next, section.related { margin-top: 24px; }
section.read-next .nav { font-size: 14px; }

/* Base typographic tweaks */
main p { margin: 0 0 14px; color: #1a1a1a; }
main h1 { color: #0f0f0f; }
main h2 { margin: 22px 0 10px; color: #141414; }
main ul { margin: 0 0 14px 20px; color: #1a1a1a; }

.article-share img.share-icon{ width:18px; height:18px; display:inline-block; vertical-align:-3px; border-radius:4px; }\n
