/* ─── BLOG LISTING ─── */
.page-hero--compact { padding-top: 56px; padding-bottom: 56px; }

.blog-page { background: var(--cream); padding: 72px 0 88px; }

.blog-intro {
  max-width: 640px;
  margin-bottom: 48px;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.blog-card {
  background: var(--white);
  border: 1px solid #e0dbd0;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  transition: transform 0.25s, box-shadow 0.25s;
}
.blog-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}

.blog-card-media {
  position: relative;
  aspect-ratio: 16 / 10;
  background: linear-gradient(145deg, var(--green-dark), var(--green-darker));
  overflow: hidden;
}
.blog-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s;
}
.blog-card:hover .blog-card-media img { transform: scale(1.04); }

.blog-card-media-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 48px;
  opacity: 0.35;
}

.blog-card-date {
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: var(--gold);
  color: var(--brown-dark);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 5px 10px;
  border-radius: 2px;
}

.blog-card-body { padding: 26px 26px 28px; flex: 1; display: flex; flex-direction: column; }

.blog-card-meta {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--green-accent);
  margin-bottom: 10px;
}

.blog-card-title {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  line-height: 1.25;
  margin-bottom: 12px;
}
.blog-card-title a {
  color: var(--green-dark);
  transition: color 0.2s;
}
.blog-card-title a:hover { color: var(--green-accent); }

.blog-card-excerpt {
  font-size: 14.5px;
  color: var(--text-mid);
  line-height: 1.7;
  flex: 1;
  margin-bottom: 20px;
}

.blog-card-link {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--green-dark);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.blog-card-link::after { content: '→'; transition: transform 0.2s; }
.blog-card:hover .blog-card-link::after { transform: translateX(4px); }

.blog-empty {
  text-align: center;
  padding: 80px 24px;
  background: var(--white);
  border: 1px dashed #d4cfc4;
  border-radius: 4px;
}
.blog-empty h3 {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  color: var(--green-dark);
  margin-bottom: 12px;
}

.blog-pagination {
  margin-top: 52px;
  display: flex;
  justify-content: center;
}
.blog-pagination-nav {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.blog-pagination-nav a,
.blog-pagination-nav span {
  padding: 10px 16px;
  border: 1px solid #e0dbd0;
  background: var(--white);
  font-size: 14px;
  font-weight: 600;
  color: var(--green-dark);
  border-radius: 2px;
}
.blog-pagination-nav span[aria-current="page"] {
  background: var(--green-dark);
  color: var(--white);
  border-color: var(--green-dark);
}
.blog-pagination-nav .blog-pag-disabled {
  opacity: 0.45;
  cursor: default;
}
.blog-pagination-nav .blog-pag-ellipsis {
  border: none;
  background: transparent;
}

/* ─── BLOG ARTICLE ─── */
.blog-article-page { background: var(--cream); padding: 0 0 80px; }

.blog-article-wrap {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 var(--site-gutter);
}

.blog-article-hero-img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  border-radius: 4px;
  margin: -40px auto 36px;
  display: block;
  box-shadow: var(--shadow-lg);
}

.blog-article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  font-size: 13px;
  color: var(--text-light);
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid #ddd8cc;
}
.blog-article-meta strong { color: var(--green-dark); }

.blog-article-content {
  font-size: 17px;
  line-height: 1.85;
  color: var(--text-dark);
}
.blog-article-content h2,
.blog-article-content h3 {
  font-family: 'Playfair Display', serif;
  color: var(--green-dark);
  margin: 2em 0 0.75em;
}
.blog-article-content p { margin-bottom: 1.25em; }
.blog-article-content a { color: var(--green-accent); text-decoration: underline; }
.blog-article-content ul,
.blog-article-content ol { margin: 0 0 1.25em 1.5em; }
.blog-article-content img { border-radius: 4px; margin: 1.5em 0; }

.blog-article-footer {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid #ddd8cc;
}

.blog-related {
  margin-top: 64px;
  padding-top: 48px;
  border-top: 2px solid #ddd8cc;
}
.blog-related h3 {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  color: var(--green-dark);
  margin-bottom: 28px;
  text-align: center;
}

.blog-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.blog-related-card {
  background: var(--white);
  border: 1px solid #e0dbd0;
  padding: 20px;
  border-radius: 4px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.2s;
}
.blog-related-card:hover { box-shadow: var(--shadow-md); }
.blog-related-card time {
  font-size: 11px;
  color: var(--text-light);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.blog-related-card h4 {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  margin: 8px 0 0;
  line-height: 1.3;
}
.blog-related-card h4 a { color: var(--green-dark); }

@media (max-width: 1024px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-related-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
  .blog-related-grid { grid-template-columns: 1fr; }
}
