.insights-hero { background: #F4FAF8; padding: 4rem 2rem 3rem; border-bottom: 1px solid #C8E6D5; }
.insights-hero-inner { max-width: 1100px; margin: 0 auto; }
.insights-hero-title { font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; letter-spacing: -0.03em; color: #0A2E22; margin-bottom: 0.5rem; }
.insights-hero-sub { font-size: 1.05rem; color: #4A6655; }
.insights-main { max-width: 1100px; margin: 0 auto; padding: 2.5rem 2rem 5rem; }
.insights-filters { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid #C8E6D5; }
.cat-pill { padding: 0.4rem 1rem; border-radius: 999px; font-size: 0.78rem; font-weight: 600; border: 1.5px solid #C8E6D5; background: #fff; color: #4A6655; cursor: pointer; transition: all 0.2s; font-family: var(--font); }
.cat-pill:hover { border-color: #0D7A45; color: #0D7A45; }
.cat-pill.active { background: #0D7A45; color: #fff; border-color: #0D7A45; }

/* Featured — full width, image left + text right */
.article-featured { display: grid; grid-template-columns: 1fr 1fr; border-radius: 12px; overflow: hidden; border: 1px solid #C8E6D5; text-decoration: none; margin-bottom: 2rem; transition: box-shadow 0.22s, transform 0.22s; }
.article-featured:hover { box-shadow: 0 10px 36px rgba(10,46,34,0.12); transform: translateY(-3px); }
.article-featured-image-wrap { overflow: hidden; flex-shrink: 0; }
.article-featured-image { width: 100%; height: 280px; object-fit: cover; object-position: center; display: block; }
.article-featured-placeholder { width: 100%; height: 280px; background: linear-gradient(135deg, #0A2E22, #156B40); display: flex; align-items: center; justify-content: center; font-size: 3rem; }
.article-featured-body { padding: 2rem 1.75rem; background: #fff; display: flex; flex-direction: column; justify-content: center; gap: 0.6rem; }
.article-featured-tag { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #0D7A45; }
.article-featured-meta { font-size: 0.78rem; color: #4A6655; }
.article-featured-title { font-size: 1.4rem; font-weight: 700; color: #0A2E22; line-height: 1.3; }
.article-featured-excerpt { font-size: 0.875rem; color: #4A6655; line-height: 1.65; }
.article-featured-link { font-size: 0.82rem; font-weight: 700; color: #0D7A45; margin-top: 0.5rem; }

/* Secondary cards grid — 2 columns */
.insights-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; }
.article-card { background: #fff; border-radius: 10px; border: 1px solid #C8E6D5; overflow: hidden; text-decoration: none; display: flex; flex-direction: column; transition: box-shadow 0.22s, transform 0.22s; }
.article-card:hover { box-shadow: 0 8px 28px rgba(10,46,34,0.11); transform: translateY(-3px); }
.article-card-image-wrap { height: 160px; overflow: hidden; flex-shrink: 0; }
.article-card-image { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.article-card-placeholder { width: 100%; height: 160px; background: linear-gradient(135deg, #0A2E22, #156B40); display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.article-card-body { padding: 1.1rem 1.25rem 1.4rem; flex: 1; display: flex; flex-direction: column; gap: 0.4rem; }
.article-card-meta { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.article-cat { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #0D7A45; background: #E8F5EE; padding: 0.18rem 0.55rem; border-radius: 4px; }
.article-date { font-size: 0.75rem; color: #4A6655; }
.article-read-time { font-size: 0.75rem; color: #4A6655; }
.article-card-title { font-size: 1rem; font-weight: 700; color: #0A2E22; line-height: 1.35; }
.article-card-excerpt { font-size: 0.82rem; color: #4A6655; line-height: 1.6; flex: 1; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.article-card-link { font-size: 0.78rem; font-weight: 700; color: #0D7A45; margin-top: 0.5rem; }

.insights-empty { text-align: center; padding: 5rem 2rem; color: #4A6655; }

/* Suppress inherited link colours inside cards */
.article-featured,
.article-featured *,
.article-card,
.article-card * { text-decoration: none; color: inherit; }
.article-featured-link,
.article-card-link { color: #0D7A45; }
.article-featured-tag,
.article-cat { color: #0D7A45; }

/* Article detail */
.article-hero { background: #F4FAF8; padding: 3rem 2rem 2.5rem; border-bottom: 1px solid #C8E6D5; }
.article-hero-inner { max-width: 800px; margin: 0 auto; }
.article-hero-meta { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; flex-wrap: wrap; }
.article-hero-title { font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 700; color: #0A2E22; line-height: 1.2; margin-bottom: 1rem; }
.article-hero-excerpt { font-size: 1.1rem; color: #4A6655; line-height: 1.7; }
.article-body-wrap { max-width: 800px; margin: 3rem auto; padding: 0 2rem 4rem; }
.article-body { font-size: 1rem; color: #2C2C2C; line-height: 1.8; }
.article-body h2 { font-size: 1.4rem; font-weight: 700; color: #0A2E22; margin: 2rem 0 0.75rem; }
.article-body h3 { font-size: 1.15rem; font-weight: 600; color: #0A2E22; margin: 1.5rem 0 0.5rem; }
.article-body p { margin-bottom: 1.25rem; }
.article-body ul, .article-body ol { margin: 0 0 1.25rem 1.5rem; }
.article-body li { margin-bottom: 0.4rem; }
.article-body strong { color: #0A2E22; }
.article-body a { color: #0D7A45; }

@media (max-width: 700px) {
  .article-featured { grid-template-columns: 1fr; }
  .article-featured-image, .article-featured-placeholder { height: 200px; }
  .insights-cards { grid-template-columns: 1fr; }
}
