/* I am scoping these styles to the blog so I do not disturb the rest of the site. */
.blog-tools { margin-bottom: 28px; }
.blog-search-wrap { position: relative; margin-bottom: 18px; }
.blog-search-wrap input {
  width: 100%;
  border: 1px solid #ddd;
  padding: 14px 16px 14px 46px;
  font-size: 15px;
  background: #fff;
}
.blog-search-wrap .fa-search {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: #999;
}
.blog-filter-group { margin-bottom: 16px; }
.blog-filter-label {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #777;
  margin-bottom: 8px;
}
.blog-filter-row { display: flex; flex-wrap: wrap; gap: 10px; }
.blog-filter-btn {
  border: 1px solid #ddd;
  background: #fff;
  color: #333;
  padding: 10px 14px;
  font-size: 13px;
  cursor: pointer;
  transition: 0.2s ease;
}
.blog-filter-btn:hover,
.blog-filter-btn.active {
  background: #1f1f1f;
  color: #fff;
  border-color: #1f1f1f;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 24px;
}
.blog-card { height: 100%; display: flex; flex-direction: column; }
.blog-card-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border: 1px solid #eee;
  margin-bottom: 16px;
}
.blog-card h4 { margin-bottom: 12px; }
.blog-card h4 a { color: #222; }
.blog-tags { margin-top: auto; padding-top: 12px; }
.blog-card-actions { margin-top: 14px; }
.blog-empty { display: none; }
.blog-empty p { margin: 0; }
.blog-post-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 7;
  object-fit: cover;
  border: 1px solid #eee;
  margin-bottom: 24px;
}
.blog-post-body p {
  line-height: 1.85;
  color: #444;
  margin-bottom: 18px;
}
.blog-post-body h4 { margin: 30px 0 14px; }
.blog-post-meta { margin-bottom: 14px; }
.blog-post-tags { margin: 18px 0 28px; }
.blog-author-link { margin-top: 18px; }
@media (max-width: 991px) {
  .blog-grid { grid-template-columns: 1fr; }
}

.blog-source-note { font-size: 13px; line-height: 1.6; color: #777; margin-bottom: 12px; }


.blog-subscribe-strip { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; margin: 0 0 24px; padding: 14px 18px; border: 1px solid #eee; background: #fafafa; }
.blog-subscribe-link { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: #222; }
.blog-subscribe-note { color: #777; font-size: 14px; }
.blog-home-subscribe { margin: 14px 0 0; }
.blog-home-subscribe a { font-weight: 600; }
