/* ============================================================
 * Home page specifics
 * ============================================================ */

/* Pain stories section */
.pain-grid {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .pain-grid { grid-template-columns: repeat(3, 1fr); } }
.pain-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  transition: transform var(--motion-base), box-shadow var(--motion-base);
}
.pain-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.pain-card__time {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: var(--s-2);
}
.pain-card__title { font-size: var(--fs-lg); margin: 0 0 var(--s-3); }
.pain-card__body { font-size: var(--fs-sm); color: var(--c-text-body); line-height: var(--lh-relaxed); }

.pain-summary {
  margin-top: var(--s-12);
  padding: var(--s-8);
  background: var(--c-brand);
  color: var(--c-white);
  border-radius: var(--r-xl);
  text-align: center;
}
.pain-summary p { color: rgba(255,255,255,0.88); font-size: var(--fs-lg); line-height: var(--lh-relaxed); }
.pain-summary strong { color: var(--c-accent); }

/* Features 8 grid */
.feature-grid {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .feature-grid { grid-template-columns: repeat(4, 1fr); } }

/* Stage preview - 4 cards with mini-chat */
.stage-grid {
  display: grid;
  gap: var(--s-5);
}
@media (min-width: 768px)  { .stage-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .stage-grid { grid-template-columns: repeat(4, 1fr); } }
.stage-mini {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-5);
}
.stage-mini__head {
  display: flex; align-items: center; gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.stage-mini__num {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--c-brand);
  color: var(--c-white);
  border-radius: var(--r-full);
  font-weight: var(--fw-bold);
}
.stage-mini__title { font-size: var(--fs-lg); margin: 0; }
.stage-mini__title small { display: block; font-size: var(--fs-xs); font-weight: var(--fw-regular); color: var(--c-text-subtle); margin-top: 2px; }
.stage-mini__body { font-size: var(--fs-sm); color: var(--c-text-body); line-height: var(--lh-relaxed); margin-bottom: var(--s-3); }

/* Testimonial 3-up */
.testimonials-grid {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .testimonials-grid { grid-template-columns: repeat(3, 1fr); } }

/* Trust grid */
.trust-grid {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .trust-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .trust-grid { grid-template-columns: repeat(3, 1fr); } }

/* Final CTA section */
.cta-section {
  text-align: center;
  background: linear-gradient(135deg, var(--c-brand) 0%, #2E5878 100%);
  color: var(--c-white);
  border-radius: var(--r-2xl);
  padding: var(--s-16) var(--s-6);
  margin-block: var(--s-12);
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: ""; position: absolute;
  top: -100px; right: -100px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(230,122,60,0.25), transparent 70%);
  border-radius: 50%;
}
.cta-section h2 { color: var(--c-white); margin-bottom: var(--s-4); position: relative; z-index: 1; }
.cta-section p  { color: rgba(255,255,255,0.85); position: relative; z-index: 1; max-width: 540px; margin-inline: auto; }
.cta-section .cluster { justify-content: center; margin-top: var(--s-6); position: relative; z-index: 1; }

/* FAQ preview ribbon */
.faq-preview {
  display: grid;
  gap: var(--s-3);
}
