/* ============================================================
   blogs.css — SAR Marine · Blog Listing Page
   Page Header inherited from about.css
   ============================================================ */

/* ── 1. PAGE WRAPPER ──────────────────────────────────────────── */
.blogs-page .blog-grid-view {
  padding-block: 0;
}

.blogs-page .blog-grid {
  grid-template-columns: repeat(4, 1fr);
}

.blog-item {
  width: 100%;
  padding: 0;
}

/* ── 3. BLOG CARD ─────────────────────────────────────────────── */
.blog-article {
  background: var(--color-white);
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition:
    border-color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-base);
}

.blog-article:hover {
  border-color: rgba(224, 92, 11, 0.3) !important;
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

/* Image */
.blog-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
  background: var(--color-ink-05);
}

.blog-img a {
  display: block;
  height: 100%;
}

.blog-img img {
  width: 100%;
  height: 100% !important; /* Override inline height:200px */
  object-fit: cover;
  transition: transform 0.4s ease;
  display: block;
}

.blog-article:hover .blog-img img {
  transform: scale(1.05);
}

/* Content */
.blog-content {
  padding: var(--space-5) var(--space-5) var(--space-6) !important;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}

.blog-content h2 {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-ink);
  line-height: var(--leading-snug);
  margin: 0;
}

.blog-content h2 a {
  color: inherit;
  transition: color var(--transition-fast);
}

.blog-content h2 a:hover {
  color: var(--color-orange);
}

/* Meta list */
.publish-detail {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  list-style: none;
  padding: 0;
  margin: 0;
}

.publish-detail li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-ink-20);
}

.publish-detail .icon {
  font-size: 12px;
  color: var(--color-orange);
}

/* Excerpt */
.blog-content .content {
  font-size: var(--text-sm);
  color: var(--color-ink-40);
  line-height: var(--leading-loose);
  flex: 1;
  /* Clamp to 3 lines */
  display: -webkit-box;
  line-clamp: 3;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Read more: layout.css (.blog-content .btn-outline-primary) */

/* Responsive — Blogs */
@media (max-width: 1200px) {
  .blogs-page .blog-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .blogs-page .blog-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}

@media (max-width: 425px) {
  .blogs-page .blog-grid {
    grid-template-columns: 1fr;
  }
}

/* ─── 375px and below ─────────────────────────────────────────── */
@media (max-width: 375px) {
  .blogs-page .blog-grid {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
}

/* ─── 320px and below ─────────────────────────────────────────── */
@media (max-width: 320px) {
  .blogs-page .blog-grid {
    grid-template-columns: 1fr;
    gap: var(--space-2);
  }
}

/* ─── 480px legacy, covered by 425px above ── */
@media (max-width: 480px) {
  /* Styles inherited from 425px breakpoint */
}
