/* ─────────────────────────────────────────────────────────────────
   CRO Block 6 — Stats Carousel (final override)
   Loaded last via base.html.twig 1..17 loop. Token-bound rebuild
   of the carousel + cards. Critical: caps icon/SVG sizing so the
   per-card SVG never explodes to viewport size.
   ───────────────────────────────────────────────────────────── */

.section.cro-stats-carousel,
.section.block-cro-block-6 {
  background: var(--ds-paper) !important;
  color: var(--ds-ink) !important;
  padding: var(--ds-section-py-lg) 0 !important;
  overflow: hidden;
  position: relative;
}
@media (max-width: 768px) {
  .section.cro-stats-carousel,
  .section.block-cro-block-6 { padding: var(--ds-section-py-sm) 0 !important; }
}

/* Section header */
.cro-stats-carousel .section-title h1,
.cro-stats-carousel .section-title h2,
.cro-stats-carousel .section-title h3 {
  font-family: var(--ds-font-display);
  font-size: var(--ds-fs-display-lg);
  line-height: 1;
  text-transform: uppercase;
  color: var(--ds-ink);
  letter-spacing: 0.005em;
  margin: 0 0 var(--ds-space-3);
}
.cro-stats-carousel .section-subtitle,
.cro-stats-carousel .section-subtitle p {
  font-family: var(--ds-font-body);
  color: var(--ds-ink-soft);
  font-size: var(--ds-fs-body-lg);
  margin: 0 0 var(--ds-space-4);
}
.cro-stats-carousel .section-header { text-align: center; margin-bottom: var(--ds-space-6); }
.cro-stats-carousel .section-header-divider {
  width: 60px; height: 3px; margin: var(--ds-space-3) auto 0;
  background: var(--ds-cta); border-radius: 2px;
}

/* Carousel wrapper — responsive grid (no horizontal scroll for now;
   the legacy autoplay carousel was visually broken in the baseline).
   Build a clean responsive grid that always reads well. */
.cro-stats-carousel .stats-carousel-wrapper {
  position: relative;
  padding: 0;
}
.cro-stats-carousel .stats-carousel,
.cro-stats-carousel .stats-carousel-wrapper .stats-carousel {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--ds-space-4) !important;
  list-style: none;
  margin: 0;
  padding: 0 !important;
  /* nuke any legacy flex/scroll behavior */
  overflow: visible !important;
  scroll-snap-type: none !important;
  transform: none !important;
  width: 100% !important;
  max-width: 100% !important;
  cursor: default !important;
}
@media (min-width: 600px) {
  .cro-stats-carousel .stats-carousel,
  .cro-stats-carousel .stats-carousel-wrapper .stats-carousel { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (min-width: 992px) {
  .cro-stats-carousel .stats-carousel,
  .cro-stats-carousel .stats-carousel-wrapper .stats-carousel { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: var(--ds-space-5) !important; }
}
.cro-stats-carousel .stats-carousel-wrapper { overflow: visible !important; padding: 0 !important; }

/* Cards */
.cro-stats-carousel .stat-card-v2 {
  background: transparent;
  margin: 0 !important;
  padding: 0 !important;
  flex: none !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  scroll-snap-align: none !important;
  list-style: none;
  transform: none !important;
}
.cro-stats-carousel .stat-card-inner {
  background: #fff;
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-radius-lg);
  padding: var(--ds-space-5);
  box-shadow: var(--ds-shadow-sm);
  position: relative;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--ds-space-3);
  transition: transform var(--ds-duration) var(--ds-ease),
              box-shadow var(--ds-duration) var(--ds-ease);
}
.cro-stats-carousel .stat-card-inner:hover {
  transform: translateY(-2px);
  box-shadow: var(--ds-shadow-md);
}

/* Top progress bar (decorative accent) */
.cro-stats-carousel .card-progress-bar {
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important; background: var(--ds-rule) !important;
  overflow: hidden !important;
  padding: 0 !important;
}
.cro-stats-carousel .card-progress-fill {
  height: 100% !important; width: 100% !important;
  background: var(--card-accent, var(--ds-cta)) !important;
  background-size: auto !important;
  opacity: 0.85;
  animation: none !important;
}
.cro-stats-carousel .card-progress-fill::after,
.cro-stats-carousel .card-progress-fill::before { display: none !important; }

/* Header row: icon + number */
.cro-stats-carousel .stat-header-row {
  display: flex; align-items: center; gap: var(--ds-space-3);
  margin-top: var(--ds-space-2);
}

/* CRITICAL: cap all icons so SVGs without intrinsic size cannot blow
   up to viewport width. This is the fix for the catastrophic baseline. */
.cro-stats-carousel .stat-icon-v2 {
  display: inline-flex !important;
  align-items: center; justify-content: center;
  flex: 0 0 auto !important;
  width: 56px !important; height: 56px !important;
  background: color-mix(in srgb, var(--card-accent, var(--ds-cta)) 12%, white);
  border: 1.5px solid color-mix(in srgb, var(--card-accent, var(--ds-cta)) 30%, transparent);
  border-radius: var(--ds-radius);
}
.cro-stats-carousel .stat-icon-v2 .icon-preset,
.cro-stats-carousel .stat-icon-v2 .icon-svg,
.cro-stats-carousel .stat-icon-v2 .icon-custom {
  display: inline-flex !important;
  width: 32px !important; height: 32px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  align-items: center; justify-content: center;
  color: var(--card-accent, var(--ds-cta));
}
.cro-stats-carousel .stat-icon-v2 .icon-preset svg,
.cro-stats-carousel .stat-icon-v2 .icon-svg svg,
.cro-stats-carousel .stat-icon-v2 svg {
  width: 32px !important; height: 32px !important;
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  stroke: currentColor !important;
  fill: none;
}
.cro-stats-carousel .stat-icon-v2 svg[fill]:not([fill="none"]),
.cro-stats-carousel .stat-icon-v2 svg *[fill]:not([fill="none"]) {
  fill: currentColor !important;
}
.cro-stats-carousel .stat-icon-v2 .icon-custom .icon-img,
.cro-stats-carousel .stat-icon-v2 .icon-custom img {
  width: 32px !important; height: 32px !important;
  max-width: 32px; max-height: 32px;
  object-fit: contain;
}

/* Stat number block (override inline style="background:...; border-color:...") */
.cro-stats-carousel .stat-number-v2[style] {
  display: inline-flex !important;
  align-items: baseline; gap: 0.1rem;
  padding: 0.5rem 0.95rem !important;
  background: var(--ds-paper-2) !important;
  border: 1px solid var(--ds-rule) !important;
  border-radius: var(--ds-radius) !important;
  box-shadow: none !important;
}
.cro-stats-carousel .stat-number-v2 {
  display: inline-flex;
  align-items: baseline; gap: 0.1rem;
  padding: 0.5rem 0.95rem;
  background: var(--ds-paper-2);
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-radius);
  box-shadow: none;
}
.cro-stats-carousel .stat-prefix,
.cro-stats-carousel .stat-suffix {
  font-family: var(--ds-font-display);
  font-size: clamp(1.2rem, 1.6vw, 1.6rem);
  font-weight: 400;
  line-height: 1;
  color: var(--ds-ink-soft) !important;
  align-self: flex-end;
  padding-bottom: 0.2rem;
}
.cro-stats-carousel .stat-count {
  font-family: var(--ds-font-display);
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0.005em;
  color: var(--ds-ink) !important;
}

/* Label */
.cro-stats-carousel .stat-label-v2 {
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body);
  font-weight: 600;
  color: var(--ds-ink);
  margin: 0;
}

/* Comparison bars */
.cro-stats-carousel .stat-comparison { margin-top: var(--ds-space-2); }
.cro-stats-carousel .comparison-bar {
  position: relative;
  height: 6px;
  background: var(--ds-rule);
  border-radius: 999px;
  overflow: hidden;
}
.cro-stats-carousel .bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--ds-trust);
  border-radius: 999px;
}
.cro-stats-carousel .bar-fill.bar-success { background: var(--ds-trust); }
.cro-stats-carousel .bar-fill.bar-warning { background: var(--ds-cta); }
.cro-stats-carousel .bar-comparison {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: rgba(118, 115, 106, 0.45);
  border-radius: 999px;
}
.cro-stats-carousel .comparison-text {
  display: block;
  margin-top: 0.4rem;
  font-size: var(--ds-fs-body-sm);
  color: var(--ds-ink-soft);
}

/* Micro CTA */
.cro-stats-carousel a.stat-micro-cta,
.cro-stats-carousel .stat-micro-cta {
  display: inline-flex !important;
  align-items: center; gap: 0.4rem;
  background: var(--ds-ink) !important;
  color: #fff !important;
  text-decoration: none !important;
  padding: 0.55rem 0.95rem !important;
  border-radius: var(--ds-radius-sm) !important;
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body-sm);
  font-weight: 600;
  align-self: flex-start;
  border: none !important;
  box-shadow: none !important;
  transition: background var(--ds-duration-fast) var(--ds-ease),
              transform var(--ds-duration-fast) var(--ds-ease);
}
.cro-stats-carousel a.stat-micro-cta:hover,
.cro-stats-carousel .stat-micro-cta:hover { background: var(--ds-cta) !important; transform: translateY(-1px); }
.cro-stats-carousel .stat-micro-cta .cta-arrow-svg,
.cro-stats-carousel .stat-micro-cta svg { width: 14px !important; height: 14px !important; stroke: currentColor !important; }

/* Ticker — show only the first item as a caption */
.cro-stats-carousel .stat-ticker {
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ds-ink-mute);
  border-top: 1px dashed var(--ds-rule);
  padding-top: var(--ds-space-2);
  margin-top: auto;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.cro-stats-carousel .ticker-scroll {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cro-stats-carousel .ticker-scroll span { color: var(--ds-ink-mute); }
.cro-stats-carousel .ticker-scroll span:not(:first-child) { display: none; }

/* Verification + urgency badges */
.cro-stats-carousel .verification-badge {
  position: absolute; top: var(--ds-space-3); right: var(--ds-space-3);
  display: inline-flex; align-items: center; gap: 0.3rem;
  background: color-mix(in srgb, var(--ds-trust) 14%, white);
  color: var(--ds-trust);
  border: 1px solid color-mix(in srgb, var(--ds-trust) 35%, transparent);
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  font-family: var(--ds-font-body);
}
.cro-stats-carousel .verification-badge svg { width: 12px !important; height: 12px !important; }
.cro-stats-carousel .urgency-overlay {
  display: inline-flex; align-items: center; gap: 0.3rem;
  background: color-mix(in srgb, var(--ds-cta) 14%, white);
  color: var(--ds-cta-dk);
  border: 1px solid color-mix(in srgb, var(--ds-cta) 35%, transparent);
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  font-size: var(--ds-fs-body-sm);
  font-weight: 600;
  align-self: flex-start;
}
.cro-stats-carousel .urgency-overlay svg { width: 14px !important; height: 14px !important; }

/* Final CTA card */
.cro-stats-carousel .stat-card-v2.cta-card .stat-card-inner {
  background: var(--ds-ink) !important;
  color: #fff;
  border: none;
  text-align: center;
  align-items: center;
  justify-content: center;
}
.cro-stats-carousel .cta-card-icon {
  width: 64px; height: 64px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: 999px;
  margin-bottom: var(--ds-space-2);
}
.cro-stats-carousel .cta-card-icon .icon-preset,
.cro-stats-carousel .cta-card-icon .icon-svg,
.cro-stats-carousel .cta-card-icon .icon-custom {
  display: inline-flex !important;
  width: 32px !important; height: 32px !important;
  background: transparent !important; border: none !important;
  align-items: center; justify-content: center;
  color: var(--ds-cta);
}
.cro-stats-carousel .cta-card-icon svg {
  width: 32px !important; height: 32px !important;
  max-width: 100%; max-height: 100%;
  stroke: var(--ds-cta);
}
.cro-stats-carousel .cta-card-title {
  font-family: var(--ds-font-display);
  font-size: var(--ds-fs-display-sm);
  text-transform: uppercase;
  color: #fff !important;
  margin: 0 0 var(--ds-space-2);
}
.cro-stats-carousel .cta-card-subtitle { color: rgba(255,247,227,.85); margin: 0 0 var(--ds-space-3); }
.cro-stats-carousel .cta-card-button {
  display: inline-flex; align-items: center; gap: 0.45rem;
  background: var(--ds-cta) !important;
  color: #fff !important;
  text-decoration: none;
  padding: 0.85rem 1.35rem;
  border-radius: var(--ds-radius-sm);
  font-family: var(--ds-font-body);
  font-weight: 700;
  box-shadow: var(--ds-shadow-cta);
  transition: background var(--ds-duration-fast) var(--ds-ease), transform var(--ds-duration-fast) var(--ds-ease);
}
.cro-stats-carousel .cta-card-button:hover { background: var(--ds-cta-dk) !important; transform: translateY(-1px); }
.cro-stats-carousel .cta-card-button svg { width: 16px !important; height: 16px !important; }

.cro-stats-carousel .cta-card-trust {
  margin-top: var(--ds-space-3);
  display: flex; flex-wrap: wrap; gap: 0.6rem 1rem; justify-content: center;
}
.cro-stats-carousel .cta-card-trust .trust-item {
  display: inline-flex; align-items: center; gap: 0.3rem;
  font-size: var(--ds-fs-body-sm);
  color: rgba(255,247,227,.85);
  font-family: var(--ds-font-body);
}
.cro-stats-carousel .cta-card-trust .trust-item svg { width: 14px !important; height: 14px !important; stroke: var(--ds-trust); }

/* Progress dots — clean horizontal row */
.cro-stats-carousel .carousel-progress {
  display: flex; gap: 0.5rem; justify-content: center;
  margin-top: var(--ds-space-4);
}
.cro-stats-carousel .progress-dot {
  width: 24px; height: 4px;
  background: var(--ds-rule);
  border: none; border-radius: 999px;
  cursor: pointer;
  transition: background var(--ds-duration-fast) var(--ds-ease),
              width var(--ds-duration-fast) var(--ds-ease);
  padding: 0;
}
.cro-stats-carousel .progress-dot.active,
.cro-stats-carousel .progress-dot:hover {
  background: var(--ds-cta);
  width: 32px;
}

/* Hard fallback: any rogue SVG inside this section is constrained */
.cro-stats-carousel svg { max-width: 100%; height: auto; }
