/* Shared Journal index styles — used by /blog (page 1), /blog/page/[n],
   and /blog/category/[category]. Extracted 2026-05-14 to keep the three
   pages from drifting when we tweak typography or grid breakpoints. */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

:root {
  --cream: #f5f0e8;
  --ink: #111;
  --ink-soft: #333;
  --muted: #6b6157;
  --rule: #111;
  --accent: #b0392c;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Inter', -apple-system, sans-serif; background: var(--cream); color: var(--ink); line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }

/* Nav + Footer styling lives in Nav.astro / Footer.astro — don't duplicate here. */

.hero { max-width: 1200px; margin: 0 auto; padding: 160px 32px 48px; border-bottom: 1px solid var(--ink); }
.eyebrow { font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-bottom: 20px; }
.hero h1 { font-family: 'Playfair Display', serif; font-weight: 900; font-size: clamp(48px, 8vw, 104px); line-height: 0.95; letter-spacing: -0.03em; margin-bottom: 24px; }
.hero h1 em { font-style: italic; }
.hero p { font-size: 19px; max-width: 680px; color: var(--ink-soft); }
.hero p a { border-bottom: 1px solid var(--ink); }
.hero p a:hover { color: var(--accent); border-color: var(--accent); }

.cats { max-width: 1200px; margin: 0 auto; padding: 32px; display: flex; gap: 12px; flex-wrap: wrap; border-bottom: 1px solid var(--ink); }
.cat { padding: 8px 16px; border: 1px solid var(--ink); font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer; background: transparent; font-family: 'Inter', sans-serif; color: var(--ink); text-decoration: none; transition: background 0.18s, color 0.18s; }
.cat:hover, .cat.active { background: var(--ink); color: var(--cream); }

.grid { max-width: 1200px; margin: 0 auto; padding: 48px 32px 64px; display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 48px 32px; }
.post { display: flex; flex-direction: column; border-top: 2px solid var(--ink); padding-top: 20px; }
.post-meta { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
.post-meta span + span::before { content: " · "; margin: 0 6px; color: var(--muted); }
.post h2 { font-family: 'Playfair Display', serif; font-weight: 900; font-size: 28px; line-height: 1.08; letter-spacing: -0.01em; margin-bottom: 14px; }
.post h2 a:hover { color: var(--accent); }
.post p { font-size: 15px; color: var(--ink-soft); margin-bottom: 18px; flex: 1; }
.post .read { font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; border-bottom: 1px solid var(--ink); padding-bottom: 2px; align-self: flex-start; }
.post .read:hover { color: var(--accent); border-color: var(--accent); }
.featured { grid-column: 1 / -1; display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; border-top: 4px solid var(--ink); padding-top: 24px; margin-bottom: 16px; }
.featured h2 { font-size: clamp(36px, 5vw, 56px); line-height: 1.02; }
.featured .post-meta { font-size: 12px; }
.featured p { font-size: 17px; }

.pagination { max-width: 1200px; margin: 0 auto; padding: 32px 32px 96px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--ink); gap: 16px; flex-wrap: wrap; }
.pagination-current { font-size: 12px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.pagination a { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; padding: 10px 24px; border: 1px solid var(--ink); transition: background 0.18s, color 0.18s; }
.pagination a:hover { background: var(--ink); color: var(--cream); }
.pagination-prev { margin-right: auto; }
.pagination-next { margin-left: auto; }

@media (max-width: 800px) { .featured { grid-template-columns: 1fr; gap: 20px; } }
@media (max-width: 600px) { .hero { padding: 120px 20px 32px; } .grid { padding: 32px 20px 48px; gap: 36px 24px; } .cats { padding: 20px; } .pagination { padding: 24px 20px 64px; } }
