/* Blog-specific styles, layered on top of /css/style.css */

.blog-index-hero {
  background: linear-gradient(120deg, #0B2545, #13315C);
  color: var(--c-white);
  padding: 80px 0 56px;
}
.blog-index-hero h1 { color: var(--c-white); font-size: clamp(2.2rem, 4vw, 3.2rem); }
.blog-index-hero p { color: rgba(255,255,255,.75); font-size: 1.1rem; max-width: 720px; }

.blog-filter-bar {
  background: var(--c-ice-2);
  border-bottom: 1px solid var(--c-border);
  padding: 18px 0;
  position: sticky;
  top: calc(var(--header-h) + var(--utility-h));
  z-index: 50;
}
.blog-filter-bar .container { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.blog-filter-bar button {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: 999px;
  padding: 8px 16px;
  font-size: .88rem; font-weight: 600; color: var(--c-text-soft);
  cursor: pointer; font-family: var(--f-sans);
  transition: all .15s;
}
.blog-filter-bar button:hover { border-color: var(--c-orange); color: var(--c-navy); }
.blog-filter-bar button.active { background: var(--c-navy); color: var(--c-white); border-color: var(--c-navy); }
.blog-search {
  margin-left: auto;
  padding: 10px 16px;
  border: 1px solid var(--c-border); border-radius: var(--r-md);
  font-size: .9rem; font-family: var(--f-sans);
  min-width: 240px;
}

.blog-post {
  background: var(--c-white);
}
.blog-post-hero {
  background-size: cover;
  background-position: center;
  color: var(--c-white);
  padding: 96px 0 72px;
  border-bottom: 1px solid var(--c-border);
}
.blog-post-hero h1 {
  color: var(--c-white);
  font-size: clamp(1.8rem, 3.4vw, 2.8rem);
  max-width: 880px;
  margin: 12px 0 16px;
}
.blog-post-hero .lead {
  color: rgba(255,255,255,.85);
  font-size: 1.05rem;
  max-width: 760px;
  margin: 0;
}
.blog-post-hero .breadcrumbs { color: rgba(255,255,255,.7); margin-bottom: 10px; }
.blog-post-hero .breadcrumbs a { color: rgba(255,255,255,.85); }
.blog-post-hero .breadcrumbs a:hover { color: var(--c-orange-2); }

.blog-body {
  display: grid; grid-template-columns: 1fr 320px;
  gap: 56px;
  padding: 64px 24px;
  align-items: flex-start;
}
@media (max-width: 1024px) { .blog-body { grid-template-columns: 1fr; } }

.blog-content { max-width: 760px; font-size: 1.04rem; line-height: 1.78; color: var(--c-text); }
.blog-content h2 { font-size: 1.6rem; margin: 40px 0 14px; }
.blog-content h3 { font-size: 1.2rem; margin: 28px 0 10px; }
.blog-content p  { margin: 0 0 1.1em; color: var(--c-text); }
.blog-content ul, .blog-content ol { padding-left: 1.4em; margin: 0 0 1.2em; }
.blog-content li { margin-bottom: .35em; color: var(--c-text); }
.blog-content table { width: 100%; border-collapse: collapse; margin: 16px 0 24px; font-size: .95rem; }
.blog-content table th, .blog-content table td { padding: 12px 16px; border-bottom: 1px solid var(--c-border); text-align: left; }
.blog-content table th { background: var(--c-ice-2); font-weight: 700; color: var(--c-navy); }
.blog-content a { color: var(--c-orange); text-decoration: underline; text-underline-offset: 2px; }
.blog-content a:hover { color: var(--c-orange-2); }
.blog-content blockquote {
  border-left: 3px solid var(--c-orange);
  padding: 8px 18px;
  margin: 16px 0;
  color: var(--c-text-soft);
  background: var(--c-ice-2);
  border-radius: 0 var(--r-md) var(--r-md) 0;
}

.blog-side { position: sticky; top: calc(var(--header-h) + var(--utility-h) + 88px); }
.side-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 22px;
  margin-bottom: 18px;
}
.side-card h4 { font-size: 1rem; margin: 0 0 8px; color: var(--c-navy); }
.side-card p { font-size: .92rem; margin: 0 0 14px; }

.blog-faq { margin-top: 56px; }
.blog-cta {
  margin-top: 48px; padding: 32px;
  background: linear-gradient(120deg, var(--c-navy), var(--c-navy-2));
  color: var(--c-white); border-radius: var(--r-lg);
}
.blog-cta p { color: rgba(255,255,255,.85); margin: 0 0 14px; }

/* Index grid card variant — uses the existing .card but adds intent badge */
.blog-card .card-tag.intent-supplier   { background: rgba(242,92,5,.10); color: var(--c-orange); }
.blog-card .card-tag.intent-replacement{ background: rgba(11,37,69,.06); color: var(--c-navy); }
.blog-card .card-tag.intent-problem    { background: rgba(27,153,139,.10); color: var(--c-green); }
.blog-card .card-tag.intent-howto      { background: rgba(140,107,177,.10); color: #6E4AA0; }
.blog-card .card-tag.intent-spec       { background: rgba(92,103,125,.10); color: var(--c-steel); }
.blog-card .card-tag.intent-comparison { background: rgba(245,164,57,.10); color: #C57B17; }

/* Pagination */
.blog-pagination {
  display: flex; justify-content: center; gap: 6px; padding: 48px 0;
}
.blog-pagination a, .blog-pagination span {
  padding: 10px 14px; border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  font-weight: 600; font-size: .9rem; color: var(--c-text-soft);
}
.blog-pagination a:hover { border-color: var(--c-orange); color: var(--c-orange); }
.blog-pagination .current { background: var(--c-navy); color: var(--c-white); border-color: var(--c-navy); }
