/* ============================================================
   client-portal-hs-consultants.css
   Conversion layout for client-portal-health-safety-consultants.html only
   ============================================================ */

.page-main .hero-headline {
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.25;
  color: var(--text);
  margin: 0 0 var(--space-3);
  max-width: 720px;
}

.page-main .lede {
  margin-bottom: var(--space-5);
}

/* --- Process flow ----------------------------------------- */

.process-flow {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items: stretch;
  gap: var(--space-3);
  margin: 0 0 var(--space-7);
}

.process-step {
  background: var(--card-bg, #fff);
  border: 1px solid var(--card-border, var(--border));
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
}

.process-step .feature-icon {
  margin: 0 auto var(--space-3);
}

.process-step p {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.35;
  margin: 0;
}

.process-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--teal, #0d9488);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
  padding-top: var(--space-6);
}

.process-arrow::after {
  content: "\2192";
}

@media (max-width: 900px) {
  .process-flow {
    grid-template-columns: 1fr;
    gap: var(--space-2);
  }

  .process-arrow {
    padding: 0;
  }

  .process-arrow::after {
    content: "\2193";
  }
}

.page-main .feature-grid {
  margin-bottom: var(--space-7);
}

.page-main .feature-card .feature-icon {
  background: var(--teal-light, #f0fdfa);
  color: var(--teal, #0d9488);
}

.page-main .feature-card:hover {
  border-color: var(--teal, #0d9488);
}

.page-main .feature-card h3 {
  font-size: 1rem;
}

.page-main .outcome-grid .feature-card p,
.page-main .included-grid .feature-card p {
  margin: 0;
  font-size: 0.96rem;
}

.page-main .section-intro {
  color: var(--text-muted);
  margin-bottom: var(--space-4);
  max-width: 720px;
}

.page-main .outcome-grid {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.page-main .included-grid {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 768px) {
  .page-main .included-grid {
    grid-template-columns: 1fr;
  }
}
