/* ============================================================
   KAMEGEMZ BLOG — styles (index + post pages)
   Uses the global palette vars from style.css (--void, --mint,
   --gold, --bone, --border). Namespaced under .blog-* / .post.
   ============================================================ */

/* ---- INDEX HERO ---- */
.blog-hero { padding: 9rem 0 3rem; border-bottom: 1px solid var(--border); }
.blog-hero__title { font-family: 'Syne', sans-serif; font-weight: 800; font-size: clamp(2.4rem, 7vw, 4rem); line-height: 1; color: var(--bone); margin: 0.6rem 0 0; }
.blog-hero__sub { color: var(--bone-dim); max-width: 52ch; margin-top: 1rem; font-size: 1.02rem; line-height: 1.55; }

/* ---- POST GRID ---- */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.4rem; padding: 3rem 0 6rem; }
.blog-card {
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--void-mid); border: 1px solid var(--border); border-radius: 12px;
  transition: border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}
.blog-card:hover { border-color: var(--border-mid); transform: translateY(-3px); box-shadow: 0 18px 40px rgba(0,0,0,0.4); }
.blog-card__cover { aspect-ratio: 16 / 9; background: #0a0e14 center/cover no-repeat; border-bottom: 1px solid var(--border); }
.blog-card__body { padding: 1.3rem 1.4rem 1.5rem; display: flex; flex-direction: column; gap: 0.6rem; flex: 1; }
.blog-card__meta { display: flex; align-items: center; gap: 0.7rem; font-size: 0.7rem; letter-spacing: 0.06em; color: var(--bone-dim); }
.blog-card__tag { color: var(--mint); text-transform: uppercase; letter-spacing: 0.18em; }
.blog-card__title { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.22rem; line-height: 1.2; color: var(--bone); }
.blog-card:hover .blog-card__title { color: var(--mint); }
.blog-card__excerpt { color: var(--bone-dim); font-size: 0.92rem; line-height: 1.5; }
.blog-card__more { margin-top: auto; font-family: 'Syne', sans-serif; font-weight: 700; font-size: 0.8rem; color: var(--mint); letter-spacing: 0.03em; }
.blog-empty { color: var(--bone-dim); padding: 3rem 0 6rem; }

/* ---- POST PAGE ---- */
.post { padding: 9rem 0 5rem; }
.post__wrap { width: 92%; max-width: 760px; margin: 0 auto; }
.post__meta { display: flex; align-items: center; gap: 0.8rem; font-size: 0.72rem; letter-spacing: 0.06em; color: var(--bone-dim); margin-bottom: 1rem; }
.post__tag { color: var(--mint); text-transform: uppercase; letter-spacing: 0.2em; }
.post__title { font-family: 'Syne', sans-serif; font-weight: 800; font-size: clamp(2rem, 6vw, 3.2rem); line-height: 1.05; color: var(--bone); margin: 0 0 2rem; }
.post__cover { width: 100%; border-radius: 12px; border: 1px solid var(--border); margin: 0 0 2.5rem; }
.post__body { color: #d7e2dc; font-size: 1.08rem; line-height: 1.75; }
.post__body p { margin: 0 0 1.4rem; }
.post__body h2 { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.5rem; color: var(--bone); margin: 2.6rem 0 1rem; }
.post__body h3 { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1.15rem; color: var(--bone); margin: 2rem 0 0.8rem; }
.post__body a { color: var(--mint); text-decoration: underline; text-underline-offset: 3px; }
.post__body blockquote { margin: 1.6rem 0; padding: 0.6rem 0 0.6rem 1.4rem; border-left: 2px solid var(--mint-dim); color: var(--bone); font-style: italic; }
.post__body ul, .post__body ol { margin: 0 0 1.4rem 1.3rem; }
.post__body li { margin: 0.4rem 0; }
.post__back { display: inline-flex; align-items: center; gap: 7px; margin-top: 3rem; font-family: 'Syne', sans-serif; font-weight: 700; font-size: 0.85rem; color: var(--mint); }
