/* ==============================
   BoaBique Blog page styles
   ============================== */

.blog-hero {
  padding-top: var(--space-8);
  padding-bottom: var(--space-6);
  text-align: center;
}
.blog-title {
  font-family: var(--font-serif);
  font-size: var(--font-size-4xl);
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}
.blog-intro {
  font-size: var(--font-size-lg);
  color: var(--color-gray-600);
  max-width: 46ch;
  margin: 0 auto var(--space-5) auto;
}

.blog-posts {
  margin-bottom: var(--space-8);
}
.blog-posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: var(--space-6);
}
.blog-post-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition);
}
.blog-post-card:hover {
  box-shadow: var(--shadow-lg);
}
.blog-post-card img {
  aspect-ratio: 4/3;
  width: 100%;
  object-fit: cover;
  border-top-left-radius: var(--radius-lg);
  border-top-right-radius: var(--radius-lg);
}
.blog-post-content {
  padding: var(--space-5);
  flex: 1 1 auto;
}
.blog-post-content h3 {
  margin-bottom: var(--space-2);
  color: var(--color-primary);
  font-size: var(--font-size-xl);
  font-family: var(--font-serif);
}
.blog-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--color-gray-500);
  margin-top: var(--space-2);
}
.tag {
  background: var(--color-gray-100);
  color: var(--color-gray-700);
  font-size: var(--font-size-xs);
  border-radius: var(--radius-full);
  padding: 2px 10px;
  display: inline-block;
}
.tag-popular {
  background: var(--color-success);
  color: #fff;
}
.tag-qna {
  background: var(--color-warning);
  color: #fff;
}
.tag-trend {
  background: var(--color-primary);
  color: #fff;
}
.tag-guest {
  background: var(--color-danger);
  color: #fff;
}

/* Two-column blog sections (how-to, trends, qna, stories) */
.blog-sections {
  display: flex;
  gap: var(--space-8);
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}
.blog-half {
  flex: 1 1 300px;
  min-width: 270px;
}
.blog-half h2 {
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  margin-bottom: var(--space-3);
}
.blog-list,
.story-list,
.resource-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.blog-list li,
.story-list li,
.resource-list li {
  margin-bottom: var(--space-3);
  line-height: var(--line-height-base);
}
.blog-list a,
.resource-list a { color: var(--color-text); }
.blog-list a:hover,
.resource-list a:hover { color: var(--color-primary); text-decoration: underline; }

.qna-list details {
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-base);
}
.qna-list summary {
  font-weight: 500;
  cursor: pointer;
  color: var(--color-primary);
}
.qna-list[open] {
  background: var(--color-gray-100);
}

.blog-resources {
  margin-bottom: var(--space-8);
}
.resource-list a {
  text-decoration: underline;
}

.blog-engagement {
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-4);
  margin-bottom: var(--space-8);
  text-align: center;
}
.engagement-actions {
  margin: var(--space-4) 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
}
.comment-call {
  margin-top: var(--space-2);
}
.comment-call-text {
  color: var(--color-gray-600);
  font-size: var(--font-size-sm);
}

.button.button-outline {
  background: transparent;
  border: 1.5px solid var(--color-primary);
  color: var(--color-primary);
}
.button.button-outline:hover,
.button.button-outline:focus-visible {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

/* Responsive styles */
@media (max-width: 1040px) {
  .blog-sections {
    flex-direction: column;
    gap: var(--space-5);
  }
  .blog-half {
    max-width: 100%;
  }
}
@media (max-width: 600px) {
  .blog-hero {
    padding-top: var(--space-5);
    padding-bottom: var(--space-4);
  }
  .blog-sections {
    gap: var(--space-2);
    padding: 0;
  }
  .blog-posts-grid {
    gap: var(--space-4);
  }
  .blog-engagement {
    padding: var(--space-4) var(--space-2);
  }
}
