/* =====================
   BLOG — SHARED
   ===================== */
.blog-wrap   { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem 4rem; }
.blog-hero   { background: var(--ivory); padding: 3.5rem 1.25rem 2.5rem; text-align: center; border-bottom: 1px solid var(--ivory3); }
.blog-hero h1 { font-family: var(--serif); font-size: clamp(1.8rem, 5vw, 2.8rem); font-weight: 400; color: var(--text); margin-bottom: 0.75rem; }
.blog-hero h1 em { font-style: italic; color: var(--rose); }
.blog-hero .eyebrow { justify-content: center; }
.blog-hero-sub { color: var(--text2); font-size: 0.92rem; line-height: 1.8; max-width: 520px; margin: 0 auto; }

/* =====================
   FILTERS
   ===================== */
.blog-filters { display: flex; gap: 0.5rem; flex-wrap: wrap; padding: 2rem 0 1.5rem; }
.filter-pill {
  padding: 0.45rem 1.1rem;
  border: 1px solid var(--ivory3);
  font-size: 0.75rem; font-weight: 400; letter-spacing: 0.08em;
  color: var(--text2); background: var(--white);
  transition: all 0.2s; cursor: pointer; text-decoration: none;
}
.filter-pill:hover  { border-color: var(--rose); color: var(--rose); }
.filter-pill.active { background: var(--rose); color: #fff; border-color: var(--rose); }

/* =====================
   BLOG GRID + CARDS
   ===================== */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 2rem;
}
.blog-card { display: flex; flex-direction: column; background: var(--white); border: 1px solid var(--ivory3); }
.blog-card.featured { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr 1fr; }

.blog-card-img-link { display: block; overflow: hidden; }
.blog-card-img-link img {
  width: 100%; height: 220px; object-fit: cover;
  display: block; transition: transform 0.5s ease;
}
.blog-card.featured .blog-card-img-link img { height: 100%; min-height: 280px; }
.blog-card:hover .blog-card-img-link img { transform: scale(1.04); }

.blog-card-body   { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.blog-card-meta   { display: flex; align-items: center; gap: 0.4rem; margin-bottom: 0.75rem; flex-wrap: wrap; }
.blog-cat         { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--rose); font-weight: 500; }
.blog-dot         { color: var(--ivory3); font-size: 0.7rem; }
.blog-date,
.blog-time        { font-size: 0.72rem; color: var(--text3); }
.blog-card-title  { font-family: var(--serif); font-weight: 400; font-size: 1.1rem; line-height: 1.3; margin-bottom: 0.6rem; }
.blog-card-title a { color: var(--text); text-decoration: none; }
.blog-card-title a:hover { color: var(--rose); }
.blog-card.featured .blog-card-title { font-size: 1.5rem; }
.blog-card-excerpt { font-size: 0.85rem; color: var(--text2); line-height: 1.75; flex: 1; }
.blog-read-more {
  display: inline-flex; align-items: center; gap: 0.4rem; margin-top: 1.2rem;
  font-size: 0.75rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--rose); text-decoration: none; transition: gap 0.2s;
}
.blog-read-more svg { width: 14px; height: 14px; transition: transform 0.2s; }
.blog-read-more:hover svg { transform: translateX(3px); }
.no-posts { padding: 3rem 0; color: var(--text3); font-size: 0.9rem; }

/* =====================
   CTA STRIP
   ===================== */
.blog-cta-strip  { background: var(--ivory); border-top: 1px solid var(--ivory3); margin-top: 4rem; padding: 3rem 1.25rem; }
.blog-cta-inner  { max-width: 560px; margin: 0 auto; text-align: center; }
.blog-cta-inner h3 { font-family: var(--serif); font-size: 1.5rem; font-weight: 400; margin-bottom: 0.5rem; }
.blog-cta-inner p  { font-size: 0.88rem; color: var(--text2); margin-bottom: 1.5rem; }

/* =====================
   POST PAGE
   ===================== */
.post-wrap    { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }
.post-header  { padding: 2.5rem 0 2rem; max-width: 720px; }

.breadcrumb   { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1.2rem; flex-wrap: wrap; }
.breadcrumb a { font-size: 0.75rem; color: var(--text3); text-decoration: none; }
.breadcrumb a:hover { color: var(--rose); }
.breadcrumb span { color: var(--ivory3); font-size: 0.75rem; }

.post-meta    { display: flex; align-items: center; gap: 0.4rem; margin-bottom: 1rem; flex-wrap: wrap; }
.post-header h1 {
  font-family: var(--serif); font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 400; color: var(--text); line-height: 1.2; margin-bottom: 0.75rem;
}
.post-excerpt { font-size: 1rem; color: var(--text2); line-height: 1.8; margin-bottom: 1.5rem; font-style: italic; }
.post-author  { display: flex; align-items: center; gap: 0.75rem; }
.author-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--rose-pale); border: 1.5px solid var(--rose-light);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.72rem; font-weight: 500; color: var(--rose-deep); flex-shrink: 0;
}
.post-author strong { display: block; font-size: 0.85rem; font-weight: 500; color: var(--text); }
.post-author span   { font-size: 0.75rem; color: var(--text3); }

.post-hero-img      { margin-bottom: 3rem; }
.post-hero-img img  { width: 100%; max-height: 480px; object-fit: cover; }

.post-body { display: grid; grid-template-columns: 1fr; gap: 3rem; margin-bottom: 3rem; }

/* ── Post content typography ── */
.post-content         { max-width: 680px; }
.post-content p       { font-size: 0.95rem; color: var(--text2); line-height: 1.9; margin-bottom: 1.25rem; }
.post-content h2      { font-family: var(--serif); font-size: 1.35rem; font-weight: 400; color: var(--text); margin: 2.2rem 0 0.75rem; line-height: 1.3; }
.post-content h3      { font-family: var(--serif); font-size: 1.1rem; font-weight: 400; color: var(--text); margin: 1.5rem 0 0.5rem; }
.post-content a       { color: var(--rose); text-decoration: underline; text-decoration-color: var(--rose-light); }
.post-content a:hover { text-decoration-color: var(--rose); }
.post-content ul,
.post-content ol      { margin: 0 0 1.25rem 1.5rem; }
.post-content li      { font-size: 0.95rem; color: var(--text2); line-height: 1.85; margin-bottom: 0.4rem; }
.post-content strong  { color: var(--text); font-weight: 500; }

/* ── Sidebar ── */
.post-sidebar { display: flex; flex-direction: column; gap: 1.5rem; }
.sidebar-card { background: var(--ivory); padding: 1.5rem; border: 1px solid var(--ivory3); }
.sidebar-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--rose-pale); border: 2px solid var(--rose-light);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.8rem; font-weight: 500; color: var(--rose-deep);
  margin-bottom: 0.75rem;
}
.sidebar-name { font-family: var(--serif); font-size: 1rem; font-weight: 400; color: var(--text); margin-bottom: 0.4rem; }
.sidebar-bio  { font-size: 0.82rem; color: var(--text2); line-height: 1.75; }
.sidebar-section-title { font-size: 0.65rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--text3); margin-bottom: 1rem; }
.sidebar-link {
  display: block; padding: 0.75rem 0; border-bottom: 1px solid var(--ivory3);
  font-size: 0.84rem; color: var(--text2); text-decoration: none; line-height: 1.4;
  transition: color 0.2s;
}
.sidebar-link:last-of-type { border-bottom: none; }
.sidebar-link:hover { color: var(--rose); }
.sidebar-link-cat { display: block; font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--rose); margin-bottom: 0.2rem; }
.sidebar-all-link { display: block; margin-top: 0.75rem; font-size: 0.78rem; color: var(--rose); text-decoration: none; font-weight: 500; }
.sidebar-all-link:hover { text-decoration: underline; }

/* ── Share bar ── */
.post-share   { display: flex; align-items: center; gap: 0.75rem; padding: 1.5rem 0; border-top: 1px solid var(--ivory3); border-bottom: 1px solid var(--ivory3); margin-bottom: 4rem; flex-wrap: wrap; }
.post-share span { font-size: 0.78rem; color: var(--text3); letter-spacing: 0.05em; }
.share-btn    { padding: 0.45rem 1rem; font-size: 0.72rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; transition: opacity 0.2s; }
.share-btn:hover { opacity: 0.8; }
.share-btn.wa { background: #25D366; color: #fff; }
.share-btn.fb { background: #1877F2; color: #fff; }
.share-btn.tw { background: #000; color: #fff; }

/* =====================
   RELATED POSTS
   ===================== */
.related-posts  { background: var(--ivory); border-top: 1px solid var(--ivory3); padding: 4rem 1.25rem; }
.related-inner  { max-width: 1100px; margin: 0 auto; }
.related-inner h2 { font-family: var(--serif); font-size: clamp(1.4rem, 3vw, 1.9rem); font-weight: 400; margin-bottom: 2rem; }
.related-inner h2 em { font-style: italic; color: var(--rose); }
.related-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

/* =====================
   RESPONSIVE
   ===================== */
@media (min-width: 700px) {
  .blog-wrap { padding: 0 3rem 5rem; }
  .post-wrap  { padding: 0 3rem; }
  .blog-hero  { padding: 4.5rem 3rem 3rem; }
  .post-body  { grid-template-columns: 1fr 300px; }
}

@media (max-width: 699px) {
  .blog-card.featured { grid-template-columns: 1fr; }
  .blog-card.featured .blog-card-img-link img { height: 220px; }
  .blog-card.featured .blog-card-title { font-size: 1.2rem; }
}

@media (min-width: 1000px) {
  .blog-wrap  { padding: 0 4rem 6rem; }
  .post-wrap  { padding: 0 4rem; }
}
