.blog-page,
.blog-article-page {
  --blog-ink: #08233f;
  --blog-muted: #526277;
  --blog-border: #dce6ea;
  --blog-soft: #f2f9f8;
  background: #fff;
  color: var(--blog-ink);
}

.blog-shell {
  width: min(1120px, calc(100% - 32px));
  margin-inline: auto;
}

.blog-hero {
  padding: 56px 0 44px;
  background: linear-gradient(145deg, #eef9f7 0%, #fff 65%);
  border-bottom: 1px solid var(--blog-border);
}

.blog-kicker,
.blog-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 999px;
  color: #087c73;
  background: #e3f6f3;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.blog-kicker { padding: 8px 12px; }
.blog-badge { padding: 6px 10px; }

.blog-hero h1,
.article-header h1 {
  margin-top: 18px;
  color: var(--rsw-heading-navy);
  font-size: var(--rsw-h1-blog-size);
  line-height: var(--rsw-h1-blog-line);
  font-weight: var(--rsw-h1-blog-weight);
  letter-spacing: var(--rsw-h1-blog-spacing);
}

.blog-hero h1 > .text-secondary,
.article-header h1 > .text-secondary {
  color: var(--rsw-heading-accent);
}

.blog-hero p,
.article-deck {
  max-width: 760px;
  margin-top: 18px;
  color: var(--blog-muted);
  font-size: 1.08rem;
  line-height: 1.75;
}

.blog-section { padding: 48px 0; }
.blog-section + .blog-section { padding-top: 8px; }

.blog-section-title {
  margin-bottom: 22px;
  font-size: clamp(1.7rem, 4vw, 2.35rem);
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -.025em;
}

.featured-card,
.blog-card,
.related-card {
  display: block;
  border: 1px solid var(--blog-border);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 16px 45px -32px rgba(8, 35, 63, .5);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.featured-card:hover,
.blog-card:hover,
.related-card:hover {
  transform: translateY(-3px);
  border-color: #9ed7d0;
  box-shadow: 0 22px 52px -30px rgba(8, 35, 63, .55);
}

.featured-card {
  display: grid;
  gap: 24px;
  padding: 28px;
  background: linear-gradient(135deg, #fff, var(--blog-soft));
}

.featured-icon {
  min-height: 190px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  color: #fff;
  background: linear-gradient(145deg, #08233f, #0b8278);
}

.featured-icon .material-symbols-outlined { font-size: 72px; }

.blog-card-grid,
.related-grid {
  display: grid;
  gap: 18px;
}

.blog-card { padding: 22px; }
.blog-card h2,
.blog-card h3,
.featured-card h2,
.related-card h3 {
  margin-top: 14px;
  color: var(--blog-ink);
  font-size: 1.25rem;
  line-height: 1.35;
  font-weight: 700;
  letter-spacing: -.018em;
}

.blog-card p,
.featured-card p {
  margin-top: 12px;
  color: var(--blog-muted);
  line-height: 1.65;
}

.blog-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-top: 15px;
  color: #68798d;
  font-size: 13px;
  font-weight: 650;
}

.blog-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 18px;
  color: #087c73;
  font-weight: 800;
}

.category-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.category-chips span {
  padding: 9px 13px;
  border: 1px solid var(--blog-border);
  border-radius: 999px;
  color: #405269;
  background: #fff;
  font-size: 13px;
  font-weight: 700;
}

.blog-cta {
  padding: 30px;
  border-radius: 24px;
  color: #fff;
  background: linear-gradient(135deg, #08233f, #0b8278);
  box-shadow: 0 22px 50px -32px rgba(8, 35, 63, .8);
}

.blog-cta h2,
.blog-cta h3,
.article-content .blog-cta h2,
.article-content .blog-cta h3 {
  color: #fff;
  font-size: clamp(1.65rem, 5vw, 2.5rem);
  font-weight: 700;
}
.blog-cta p,
.article-content .blog-cta p { margin-top: 10px; color: rgba(255, 255, 255, .92); line-height: 1.65; }
.blog-cta-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.blog-button {
  display: inline-flex;
  justify-content: center;
  padding: 13px 18px;
  border-radius: 12px;
  background: #fff;
  color: #08233f;
  font-weight: 800;
}
.blog-button.secondary { background: #25d366; color: #fff; }

.article-header { padding: 46px 0 34px; background: linear-gradient(145deg, #eef9f7, #fff); }
.breadcrumb { display: flex; flex-wrap: wrap; gap: 7px; color: #68798d; font-size: 13px; }
.article-header h1 { max-width: 900px; }
.article-layout { display: grid; gap: 30px; padding: 38px 0 56px; }
.article-content { min-width: 0; color: #263a50; font-size: 1.02rem; line-height: 1.8; }
.article-content h2 { margin: 42px 0 14px; color: var(--blog-ink); font-size: 1.75rem; line-height: 1.25; font-weight: 700; letter-spacing: -.025em; }
.article-content h3 { margin: 26px 0 10px; color: var(--blog-ink); font-size: 1.25rem; font-weight: 700; }
.article-content p + p { margin-top: 15px; }
.article-content ul { margin: 14px 0; padding-left: 22px; list-style: disc; }
.article-content li + li { margin-top: 8px; }
.article-content a { color: #087c73; font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }
.toc { padding: 20px; border: 1px solid var(--blog-border); border-radius: 18px; background: var(--blog-soft); }
.toc strong { display: block; margin-bottom: 10px; color: var(--blog-ink); }
.toc a { display: block; padding: 5px 0; color: #405269; font-size: 14px; font-weight: 700; }
.info-box { margin: 24px 0; padding: 20px; border-left: 4px solid #0b8278; border-radius: 0 16px 16px 0; background: var(--blog-soft); }
.article-content .blog-cta { margin: 38px 0; }
.faq-item { margin-top: 12px; padding: 18px; border: 1px solid var(--blog-border); border-radius: 16px; background: #fff; }
.faq-item h3 { margin: 0 0 6px; font-size: 1.08rem; }
.related-card { padding: 18px; }
.related-card h3 { margin-top: 8px; font-size: 1.05rem; }

@media (min-width: 700px) {
  .blog-shell { width: min(1120px, calc(100% - 64px)); }
  .blog-hero { padding: 76px 0 62px; }
  .blog-section { padding: 66px 0; }
  .featured-card { grid-template-columns: .8fr 1.2fr; align-items: center; padding: 34px; }
  .blog-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .related-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
  .blog-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .article-layout { grid-template-columns: minmax(0, 760px) 260px; align-items: start; }
  .article-layout .toc { position: sticky; top: 104px; grid-column: 2; grid-row: 1; }
  .article-content { grid-column: 1; grid-row: 1; }
}

@media (max-width: 767px) {
  .blog-page,
  .blog-article-page { padding-bottom: 72px; }
  .blog-cta-actions,
  .blog-button { width: 100%; }
}
