/* ============================================================
   VividCharts — Solution category pages (/solution/[slug])
   Hero + benefits grid; catalog card styles come from solutions.css.
   ============================================================ */

/* Hero */
.sol-cat-hero { padding: 64px 0 48px; background: var(--light-cream); }
.sol-cat-hero .eyebrow { margin-bottom: 16px; }
.sol-cat-hero h1 { font-size: clamp(32px, 4.2vw, 48px); max-width: 22ch; margin: 8px 0; }
.sol-cat-sub { font-size: clamp(16px, 1.4vw, 19px); color: var(--ink-2); line-height: 1.55; max-width: 58ch; margin: 0 0 32px; }
.sol-cat-cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* Benefits */
.sol-cat-benefits { padding-top: 64px; }
.sol-cat-ben-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; margin-top: 40px; }
.sol-cat-ben { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-md); padding: 24px; }
.sol-cat-ben h3 { font-size: 16px; margin: 0 0 8px; }
.sol-cat-ben p { font-size: 14px; color: var(--ink-3); line-height: 1.55; margin: 0; }

@media (max-width: 560px) {
  .sol-cat-ben-grid { grid-template-columns: 1fr; }
}

/* ---- Role pages (/solutions/roles/<slug>) ---- */
/* 3-up pain / help grids; collapse cleanly on small screens. */
.sol-role-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.sol-role-outcome {
  margin: 40px auto 0;
  max-width: 52ch;
  text-align: center;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 600;
  line-height: 1.4;
  color: var(--ink-1);
}

@media (max-width: 880px) {
  .sol-role-grid { grid-template-columns: 1fr; }
}

/* ---- Role page intro narrative (markdown body, below hero) ---- */
.sol-role-intro { padding-top: 64px; padding-bottom: 8px; }
.sol-role-prose {
  max-width: 64ch;
  margin: 0 auto;
}
.sol-role-prose p {
  color: var(--ink-2);
  font-size: clamp(17px, 1.6vw, 19px);
  line-height: 1.7;
  margin: 0 0 18px;
}
.sol-role-prose p strong { color: var(--ink); font-weight: 700; }
.sol-role-prose ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}
.sol-role-prose li {
  position: relative;
  padding-left: 28px;
  color: var(--ink-2);
  font-size: clamp(15.5px, 1.4vw, 17px);
  line-height: 1.55;
}
.sol-role-prose li::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 9px;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: var(--brand);
}
