/* Latimer blog styles — reuses the bespoke design tokens from styles.css
   (--bg, --signal, --ink, --font-display, …). Loaded after styles.css by
   templates/latimer/base.html. Covers blog_index.html + blog_post.html. */

.container-narrow { max-width: 760px; margin: 0 auto; padding: 0 24px; }

/* ---- blog index hero ---- */
.blog-hero { padding: 80px 0 32px; border-bottom: 1px solid var(--line); }
.blog-hero .eyebrow {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--signal); margin-bottom: 14px;
}
.blog-hero h1 { font-family: var(--font-display); font-size: clamp(34px, 5vw, 52px); line-height: 1.05; margin: 0 0 14px; color: var(--ink); }
.blog-hero p { color: var(--ink-dim); font-size: 18px; max-width: 600px; }

/* ---- featured + cards ---- */
.featured-card, .post-card, .related-card {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px;
  overflow: hidden; transition: border-color .2s, box-shadow .2s;
}
.featured-card { display: grid; grid-template-columns: 1.1fr 1fr; gap: 0; margin: 40px 0; }
.featured-img { width: 100%; height: 100%; min-height: 280px; object-fit: cover; }
.featured-body { padding: 32px; }
.featured-card:hover, .post-card:hover, .related-card:hover {
  border-color: var(--line-strong); box-shadow: 0 0 28px rgba(159,232,112,0.12);
}
.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.post-card img, .post-card > a > div { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.post-card-body, .related-card-body { padding: 20px; }
.post-cat, .post-cat-badge {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--signal);
}
.featured-body h2, .post-card-body h3, .related-card-body h3 { font-family: var(--font-display); color: var(--ink); margin: 10px 0; line-height: 1.2; }
.post-card-body h3 a { color: inherit; text-decoration: none; }
.excerpt { color: var(--ink-dim); font-size: 15px; line-height: 1.55; }
.post-meta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 14px; font-family: var(--font-mono); font-size: 12px; color: var(--ink-mute); }

/* ---- pagination ---- */
.pagination { display: flex; gap: 10px; justify-content: center; align-items: center; margin: 48px 0; }
.pagination a, .pagination span { font-family: var(--font-mono); font-size: 14px; padding: 8px 14px; border: 1px solid var(--line); border-radius: 6px; color: var(--ink-dim); text-decoration: none; }
.pagination a:hover { border-color: var(--signal); color: var(--signal); }
.pagination .current { background: var(--signal); color: var(--bg); border-color: var(--signal); }

/* ---- empty state ---- */
.empty-state { text-align: center; padding: 80px 24px; color: var(--ink-dim); }
.empty-state h2 { font-family: var(--font-display); color: var(--ink); }

/* ---- single post ---- */
.breadcrumb { padding: 28px 0 0; font-family: var(--font-mono); font-size: 12px; color: var(--ink-mute); }
.breadcrumb a { color: var(--ink-dim); text-decoration: none; }
.breadcrumb a:hover { color: var(--signal); }
.post-header { padding: 28px 0 24px; }
.post-header h1 { font-family: var(--font-display); font-size: clamp(30px, 4.5vw, 46px); line-height: 1.1; color: var(--ink); margin: 14px 0; }
.post-header .excerpt { font-size: 19px; }
.post-header .meta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 16px; font-family: var(--font-mono); font-size: 13px; color: var(--ink-mute); }
.post-hero { margin: 24px auto; }
.post-hero img { width: 100%; border-radius: 10px; }
.post-body { font-size: 18px; line-height: 1.7; color: var(--ink); }
.post-body h2 { font-family: var(--font-display); font-size: 28px; margin: 40px 0 14px; }
.post-body h3 { font-family: var(--font-display); font-size: 22px; margin: 32px 0 12px; }
.post-body p { margin: 0 0 20px; color: var(--ink-dim); }
.post-body a { color: var(--signal); }
.post-body ul, .post-body ol { color: var(--ink-dim); margin: 0 0 20px 22px; }
.post-body img { max-width: 100%; border-radius: 8px; }

/* ---- post CTA ---- */
.post-cta { margin: 48px 0; padding: 36px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; text-align: center; }
.post-cta h3 { font-family: var(--font-display); font-size: 24px; color: var(--ink); margin: 0 0 10px; }
.post-cta p { color: var(--ink-dim); margin: 0 0 22px; }
.post-cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.post-cta .btn-primary, .post-cta .btn--primary {
  background: var(--signal); color: var(--bg); font-family: var(--font-mono);
  font-weight: 600; padding: 13px 22px; border-radius: 7px; text-decoration: none;
}
.post-cta .btn-outline { border: 1px solid var(--line-strong); color: var(--ink); padding: 13px 22px; border-radius: 7px; text-decoration: none; }

/* ---- tags + related ---- */
.tag-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 28px 0; }
.tag { font-family: var(--font-mono); font-size: 12px; color: var(--ink-mute); border: 1px solid var(--line); border-radius: 20px; padding: 4px 12px; }
.related { padding: 56px 0; border-top: 1px solid var(--line); margin-top: 48px; }
.related h2 { font-family: var(--font-display); color: var(--ink); margin-bottom: 24px; }
.related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; }

@media (max-width: 720px) {
  .featured-card { grid-template-columns: 1fr; }
  .featured-img { min-height: 200px; }
}

/* ---- rich post-body elements (figures, tables, lists) ---- */
.post-body figure { margin: 30px 0; }
.post-body figure img { width: 100%; border: 1px solid var(--line); border-radius: 10px; display: block; }
.post-body figcaption {
  margin-top: 10px; text-align: center; font-family: var(--font-mono);
  font-size: 12.5px; color: var(--ink-mute); line-height: 1.5;
}
.post-body figcaption a { color: var(--ink-dim); }
.post-body table { width: 100%; border-collapse: collapse; margin: 22px 0; font-size: 15px; }
.post-body th, .post-body td { border: 1px solid var(--line); padding: 10px 13px; text-align: left; vertical-align: top; }
.post-body th {
  background: var(--bg-1, #0f1216); color: var(--ink);
  font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.04em;
}
.post-body td { color: var(--ink-dim); }
.post-body ol { color: var(--ink-dim); margin: 0 0 20px 22px; }
.post-body ol li, .post-body ul li { margin-bottom: 6px; }
.post-body hr { border: none; border-top: 1px solid var(--line); margin: 34px 0; }
.post-body strong { color: var(--ink); }
