/* =============================================
   FLOWGENT Ã¢ÂÂ BENTO MODERNISME 2026 v5.0
   Spec: #FFFFFF ÃÂ· #111827 ÃÂ· #2563EB ÃÂ· Inter 800
   Surgical White ÃÂ· Titanium Grey ÃÂ· Electric Cobalt
   cubic-bezier(0.16,1,0.3,1) ÃÂ· blur(25px)
   ============================================= */

/* Ã¢ÂÂ CSS Variables Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
:root {
  --fg-white:         #FBFBFD;
  --fg-surface:       #F5F5F7;
  --fg-surface-2:     #F0F0F2;
  --fg-border:        rgba(0,0,0,0.06);
  --fg-border-hover:  #2563EB;
  --fg-border-card:   1px solid rgba(0,0,0,0.06);

  --fg-text:          #1d1d1f;
  --fg-text-sub:      #6e6e73;
  --fg-text-muted:    #a1a1a6;

  --fg-cobalt:        #2563EB;
  --fg-cobalt-dark:   #1D4ED8;
  --fg-cobalt-light:  #EEF2FF;
  --fg-cobalt-mid:    #DBEAFE;
  --fg-cobalt-glow:   rgba(37,99,235,0.15);

  --fg-radius:        28px;
  --fg-radius-sm:     14px;
  --fg-radius-pill:   100px;

  --fg-ease:          cubic-bezier(0.16, 1, 0.3, 1);
  --fg-ease-out:      cubic-bezier(0.22, 1, 0.36, 1);

  --fg-shadow-xs:     0 1px 3px rgba(0,0,0,0.04);
  --fg-shadow-sm:     0 2px 8px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --fg-shadow-md:     0 8px 24px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --fg-shadow-lg:     0 20px 56px rgba(0,0,0,0.10), 0 4px 14px rgba(0,0,0,0.06);
  --fg-shadow-xl:     0 32px 80px rgba(0,0,0,0.12), 0 8px 28px rgba(0,0,0,0.06);
  --fg-shadow-cobalt: 0 8px 32px rgba(37,99,235,0.25);
}

/* Ã¢ÂÂ Global Reset Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
html {
  background: var(--fg-white) !important;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  background: var(--fg-white) !important;
  color: var(--fg-text-sub) !important;
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "cv02","cv03","cv04","cv11";
}

*, *::before, *::after { box-sizing: border-box; }

#page, .site, .site-content, #content,
.elementor-page, .elementor-section-wrap,
.e-con, .e-con-inner,
.elementor-container, .elementor-column-wrap {
  background: var(--fg-white) !important;
}

/* Kill ALL inline Elementor color overrides that break the system */
[style*="#3582C4"],
[style*="#808080"],
[style*="color: rgb(53, 130, 196)"],
[style*="color: grey"],
[style*="color: gray"] {
  color: var(--fg-cobalt) !important;
}

/* Ã¢ÂÂ Typography Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
h1, h2, h3, h4, h5, h6,
.elementor-heading-title,
.elementor-widget-heading h1,
.elementor-widget-heading h2,
.elementor-widget-heading h3 {
  font-family: "Inter", system-ui, sans-serif !important;
  font-weight: 800 !important;
  color: var(--fg-text) !important;
  letter-spacing: -0.04em !important;
  line-height: 1.08 !important;
  margin-bottom: 0.5em !important;
}

h1, .elementor-heading-title.elementor-size-xxl {
  font-size: clamp(2.8rem, 6vw, 4.5rem) !important;
  letter-spacing: -0.05em !important;
  line-height: 1.0 !important;
}
h2, .elementor-heading-title.elementor-size-xl {
  font-size: clamp(2rem, 3.8vw, 3.2rem) !important;
  letter-spacing: -0.04em !important;
}
h3, .elementor-heading-title.elementor-size-large {
  font-size: clamp(1.3rem, 2.2vw, 1.8rem) !important;
  letter-spacing: -0.03em !important;
}
h4, .elementor-heading-title.elementor-size-medium { font-size: 1.15rem !important; }
h5, h6 {
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--fg-cobalt) !important;
}

p, li, span:not(.elementor-icon):not(.fa),
.elementor-text-editor p,
.elementor-widget-text-editor p,
.elementor-widget-text-editor li {
  font-family: "Inter", system-ui !important;
  font-weight: 400 !important;
  font-size: 1.05rem !important;
  line-height: 1.82 !important;
  color: var(--fg-text-sub) !important;
}

strong, b {
  font-weight: 700 !important;
  color: var(--fg-text) !important;
}

a { color: var(--fg-cobalt) !important; text-decoration: none !important; }
a.btn-primary, .btn-primary { color: #fff !important; }
a.btn-ghost, .btn-ghost { color: var(--cobalt) !important; }
a:hover { text-decoration: underline !important; }

/* Ã¢ÂÂ Navigation Ã¢ÂÂ Glassmorphism 2.0 Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
header,
.elementor-location-header,
#masthead,
.site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  background: rgba(251,251,253,0.75) !important;
  backdrop-filter: blur(25px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(25px) saturate(180%) !important;
  border-bottom: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 0 0 0 transparent !important;
  transition: background var(--fg-ease) 0.3s, box-shadow var(--fg-ease) 0.3s !important;
}

header.fg-scrolled {
  background: rgba(251,251,253,0.92) !important;
  box-shadow: 0 1px 0 rgba(0,0,0,0.08), var(--fg-shadow-sm) !important;
}

.elementor-nav-menu a, nav a, .elementor-nav-menu__item a {
  font-family: "Inter", system-ui !important;
  font-weight: 500 !important;
  font-size: 0.88rem !important;
  color: var(--fg-text-sub) !important;
  letter-spacing: -0.01em !important;
  transition: color 0.2s ease !important;
}
.elementor-nav-menu a:hover, nav a:hover,
.elementor-nav-menu__item:hover a { color: var(--fg-cobalt) !important; text-decoration: none !important; }

/* Ã¢ÂÂ Sections Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-top-section,
.elementor-section,
.e-con.e-parent {
  background: var(--fg-white) !important;
  padding-top: clamp(72px, 8vw, 112px) !important;
  padding-bottom: clamp(72px, 8vw, 112px) !important;
  position: relative !important;
}

/* Separator fine line */
.elementor-top-section + .elementor-top-section::before,
.e-con.e-parent + .e-con.e-parent::before {
  content: "";
  position: absolute; top: 0; left: 8%; right: 8%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,0,0,0.06) 20%, rgba(0,0,0,0.06) 80%, transparent);
}

/* Alternate sections */
.elementor-top-section:nth-child(even),
.e-con.e-parent:nth-child(even) {
  background: var(--fg-surface) !important;
}

/* Ã¢ÂÂ Hero Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-top-section:first-of-type,
.e-con.e-parent:first-of-type {
  background: linear-gradient(160deg, #EEF2FF 0%, #F5F7FF 30%, var(--fg-white) 70%) !important;
  padding-top: clamp(96px, 12vw, 160px) !important;
  padding-bottom: clamp(80px, 10vw, 130px) !important;
}
.elementor-top-section:first-of-type::before,
.e-con.e-parent:first-of-type::before { display: none !important; }

/* Hero badge above H1 */
.elementor-top-section:first-of-type h5,
.elementor-top-section:first-of-type .elementor-heading-title.elementor-size-small {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--fg-cobalt) !important;
  background: var(--fg-cobalt-light) !important;
  border: 1px solid rgba(37,99,235,0.2) !important;
  border-radius: var(--fg-radius-pill) !important;
  padding: 5px 18px !important;
  display: inline-block !important;
  margin-bottom: 20px !important;
}

/* Ã¢ÂÂ Bento Cards (icon-box) Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-icon-box-wrapper {
  background: var(--fg-white) !important;
  border: var(--fg-border-card) !important;
  border-radius: var(--fg-radius) !important;
  padding: 36px !important;
  box-shadow: var(--fg-shadow-sm) !important;
  transition: border-color 0.3s var(--fg-ease),
              box-shadow 0.4s var(--fg-ease),
              transform 0.4s var(--fg-ease) !important;
  position: relative !important;
  overflow: hidden !important;
  height: 100% !important;
}

.elementor-icon-box-wrapper::after {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--fg-cobalt), #60A5FA);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s var(--fg-ease);
  border-radius: var(--fg-radius) var(--fg-radius) 0 0;
}

.elementor-icon-box-wrapper:hover {
  border-color: rgba(37,99,235,0.2) !important;
  box-shadow: var(--fg-shadow-lg) !important;
  transform: translateY(-6px) !important;
}

.elementor-icon-box-wrapper:hover::after { transform: scaleX(1); }

.elementor-icon-box-icon .elementor-icon-box-icon-inner,
.elementor-icon-box-icon .elementor-icon {
  background: var(--fg-cobalt-light) !important;
  border-radius: var(--fg-radius-sm) !important;
  width: 56px !important;
  height: 56px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 24px !important;
  color: var(--fg-cobalt) !important;
  font-size: 1.4rem !important;
}

.elementor-icon-box-icon { margin-bottom: 24px !important; }
.elementor-icon i, .elementor-icon svg { color: var(--fg-cobalt) !important; }

.elementor-icon-box-title {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--fg-text) !important;
  letter-spacing: -0.025em !important;
  margin-bottom: 12px !important;
  line-height: 1.3 !important;
  font-family: "Inter", system-ui !important;
}

.elementor-icon-box-description {
  font-size: 0.95rem !important;
  line-height: 1.82 !important;
  color: var(--fg-text-sub) !important;
}

/* Ã¢ÂÂ Buttons Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-button,
.elementor-button-wrapper .elementor-button,
.wp-block-button a {
  font-family: "Inter", system-ui !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  letter-spacing: -0.015em !important;
  border-radius: var(--fg-radius-pill) !important;
  padding: 15px 32px !important;
  cursor: pointer !important;
  transition: all 0.35s var(--fg-ease) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.elementor-widget-button .elementor-button,
.elementor-button[style*="background"],
.elementor-button.elementor-size-sm,
.elementor-button.elementor-size-md,
.elementor-button.elementor-size-lg {
  background: var(--fg-cobalt) !important;
  color: #FFFFFF !important;
  border: none !important;
  box-shadow: var(--fg-shadow-cobalt) !important;
}

.elementor-widget-button .elementor-button:hover {
  background: var(--fg-cobalt-dark) !important;
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow: 0 14px 44px rgba(37,99,235,0.32) !important;
  color: #FFFFFF !important;
}

/* Ã¢ÂÂ Stats Counters Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-counter .elementor-counter-number-wrapper {
  font-family: "Inter", system-ui !important;
  font-weight: 800 !important;
  font-size: clamp(2.4rem, 4vw, 3.2rem) !important;
  color: var(--fg-cobalt) !important;
  letter-spacing: -0.05em !important;
  line-height: 1 !important;
}
.elementor-counter .elementor-counter-number-prefix,
.elementor-counter .elementor-counter-number-suffix {
  font-weight: 800 !important;
  color: var(--fg-cobalt) !important;
}
.elementor-counter .elementor-counter-title {
  font-size: 0.82rem !important;
  color: var(--fg-text-muted) !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  margin-top: 8px !important;
  text-transform: uppercase !important;
}

/* Ã¢ÂÂ Icon list Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-icon-list-icon i,
.elementor-icon-list-icon svg { color: var(--fg-cobalt) !important; }
.elementor-icon-list-text {
  color: var(--fg-text-sub) !important;
  font-size: 0.97rem !important;
  line-height: 1.75 !important;
}

/* Ã¢ÂÂ Testimonials Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-testimonial-wrapper,
.elementor-testimonial__text-wrapper {
  background: var(--fg-white) !important;
  border: var(--fg-border-card) !important;
  border-radius: var(--fg-radius) !important;
  padding: 36px !important;
  box-shadow: var(--fg-shadow-sm) !important;
  transition: border-color 0.3s var(--fg-ease), box-shadow 0.3s var(--fg-ease) !important;
}
.elementor-testimonial-wrapper:hover {
  border-color: rgba(37,99,235,0.2) !important;
  box-shadow: var(--fg-shadow-md) !important;
}
.elementor-testimonial-content,
.elementor-testimonial__text {
  color: var(--fg-text-sub) !important;
  font-style: italic !important;
  line-height: 1.85 !important;
  font-size: 1.05rem !important;
}
.elementor-testimonial-name,
.elementor-testimonial__name { color: var(--fg-text) !important; font-weight: 700 !important; }
.elementor-star-rating__star { color: #F59E0B !important; }

/* Ã¢ÂÂ Images Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-image img,
.elementor-widget-image img {
  border-radius: var(--fg-radius) !important;
  box-shadow: var(--fg-shadow-md) !important;
  transition: transform 0.5s var(--fg-ease), box-shadow 0.5s var(--fg-ease) !important;
}
.elementor-image:hover img,
.elementor-widget-image:hover img {
  transform: scale(1.02) !important;
  box-shadow: var(--fg-shadow-xl) !important;
}

/* Ã¢ÂÂ Image carousel (logos) Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-widget-image-carousel .swiper-slide-image {
  border-radius: 12px !important;
  filter: grayscale(30%) !important;
  opacity: 0.85 !important;
  transition: filter 0.3s ease, opacity 0.3s ease !important;
}
.elementor-widget-image-carousel .swiper-slide:hover .swiper-slide-image {
  filter: grayscale(0%) !important;
  opacity: 1 !important;
}

/* Ã¢ÂÂ CTA last section Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.elementor-top-section:last-of-type,
.e-con.e-parent:last-of-type {
  background: linear-gradient(135deg, var(--fg-cobalt-light) 0%, #F0F4FF 50%, var(--fg-white) 100%) !important;
  border-top: 1px solid rgba(37,99,235,0.1) !important;
}

/* Ã¢ÂÂ Footer Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
footer, .elementor-location-footer, #colophon {
  background: var(--fg-surface) !important;
  border-top: 1px solid rgba(0,0,0,0.06) !important;
}
footer p, footer span, .elementor-location-footer p,
footer a { color: var(--fg-text-muted) !important; font-size: 0.875rem !important; }
footer a:hover { color: var(--fg-cobalt) !important; text-decoration: none !important; }

/* Ã¢ÂÂ Forms Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
input, textarea, select, .elementor-field {
  background: var(--fg-white) !important;
  border: 1px solid rgba(0,0,0,0.1) !important;
  border-radius: var(--fg-radius-sm) !important;
  color: var(--fg-text) !important;
  font-family: "Inter", system-ui !important;
  font-size: 0.95rem !important;
  padding: 13px 16px !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
input:focus, textarea:focus, .elementor-field:focus {
  border-color: var(--fg-cobalt) !important;
  box-shadow: 0 0 0 3px var(--fg-cobalt-glow) !important;
  outline: none !important;
}

/* Ã¢ÂÂ Scroll animations (reveal) Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
[data-fg-reveal] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s var(--fg-ease),
              transform 0.7s var(--fg-ease);
}
[data-fg-reveal].fg-visible {
  opacity: 1;
  transform: translateY(0);
}
[data-fg-reveal]:nth-child(2) { transition-delay: 0.08s; }
[data-fg-reveal]:nth-child(3) { transition-delay: 0.16s; }
[data-fg-reveal]:nth-child(4) { transition-delay: 0.24s; }
[data-fg-reveal]:nth-child(5) { transition-delay: 0.32s; }
[data-fg-reveal]:nth-child(6) { transition-delay: 0.40s; }

/* Ã¢ÂÂ Page entrance Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
body { animation: fg-page-in 0.5s var(--fg-ease-out) both; }
@keyframes fg-page-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Ã¢ÂÂ Scrollbar Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.12); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--fg-cobalt); }

/* Ã¢ÂÂ Selection Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
::selection { background: var(--fg-cobalt-mid); color: var(--fg-cobalt-dark); }

/* Ã¢ÂÂ Mobile Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
@media (max-width: 767px) {
  .elementor-top-section:first-of-type,
  .e-con.e-parent:first-of-type { padding: 72px 20px 56px !important; }
  h1 { font-size: 2.4rem !important; letter-spacing: -0.03em !important; }
  h2 { font-size: 1.85rem !important; }
  .elementor-icon-box-wrapper { padding: 24px !important; border-radius: 20px !important; }
  .elementor-widget-button .elementor-button {
    width: 100% !important;
    justify-content: center !important;
    min-height: 54px !important;
  }
  .elementor-top-section, .e-con.e-parent {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }
}

/* Ã¢ÂÂ Tablet Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
@media (min-width: 768px) and (max-width: 1024px) {
  h1 { font-size: 3.2rem !important; }
  h2 { font-size: 2.4rem !important; }
}

/* CookieAdmin Pro â override colors to match design system */
.cookieadmin_slider { background-color: #9CA3AF !important; }
input:checked + .cookieadmin_slider,
input:disabled + .cookieadmin_slider { background-color: #2563EB !important; }

/* âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
   FLOWGENT DESIGN v6.0 â Premium Layer
   Bento Grid Â· SVG Icons Â· Micro-animations Â· Polish
   âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */

/* --- Gradient Text --- */
.gradient-text {
  background: linear-gradient(135deg, #2563EB 0%, #3B82F6 50%, #60A5FA 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* --- Noise texture overlay subtle --- */
.noise-overlay {
  position: relative;
}
.noise-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  opacity: 0.025;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
}

/* --- Bento Grid Feature Layout --- */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: auto;
  gap: 16px;
  margin-top: 40px;
}
.bento-card {
  background: white;
  border: 1px solid rgba(37,99,235,.08);
  border-radius: 24px;
  padding: 32px 28px;
  position: relative;
  overflow: hidden;
  transition: transform .35s cubic-bezier(0.16,1,0.3,1), 
              box-shadow .35s cubic-bezier(0.16,1,0.3,1);
  box-shadow: 0 1px 3px rgba(15,23,42,.04), 0 4px 16px rgba(15,23,42,.04);
}
.bento-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 24px rgba(37,99,235,.10), 0 1px 3px rgba(15,23,42,.06);
}
/* Card sizes */
.bento-card.span-4 { grid-column: span 4; }
.bento-card.span-8 { grid-column: span 8; }
.bento-card.span-6 { grid-column: span 6; }
.bento-card.span-3 { grid-column: span 3; }
.bento-card.span-5 { grid-column: span 5; }
.bento-card.span-7 { grid-column: span 7; }
.bento-card.span-12 { grid-column: span 12; }

/* Card accent top border */
.bento-card.accent::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, #2563EB, #3B82F6, transparent);
  border-radius: 24px 24px 0 0;
}

/* --- SVG Icon Containers --- */
.icon-wrap {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(37,99,235,.07);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  flex-shrink: 0;
}
.icon-wrap svg {
  width: 22px;
  height: 22px;
  stroke: #2563EB;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.icon-wrap.lg { width: 56px; height: 56px; border-radius: 18px; }
.icon-wrap.lg svg { width: 26px; height: 26px; }

/* --- Stat number with animation --- */
.stat-big {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  letter-spacing: -.06em;
  color: var(--cobalt);
  line-height: 1;
  display: block;
}
.stat-label {
  font-size: .82rem;
  color: var(--muted);
  margin-top: 4px;
  display: block;
}

/* --- Sparkline mini chart --- */
.sparkline-wrap {
  margin-top: 16px;
  height: 40px;
  display: flex;
  align-items: flex-end;
  gap: 3px;
}
.spark-bar {
  flex: 1;
  background: rgba(37,99,235,.15);
  border-radius: 3px 3px 0 0;
  position: relative;
  overflow: hidden;
  transition: height .5s cubic-bezier(0.16,1,0.3,1);
}
.spark-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(37,99,235,.7) 0%, rgba(37,99,235,.3) 100%);
  border-radius: inherit;
}
.spark-bar.active { background: rgba(37,99,235,.25); }
.spark-bar.active::after { 
  background: linear-gradient(180deg, #2563EB 0%, rgba(37,99,235,.6) 100%); 
}

/* --- Floating badge upgrade --- */
.float-badge {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: white;
  border: 1px solid rgba(37,99,235,.12);
  border-radius: 100px;
  padding: 8px 14px 8px 10px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--text);
  box-shadow: 0 4px 20px rgba(15,23,42,.10), 0 1px 4px rgba(15,23,42,.06);
  white-space: nowrap;
  z-index: 3;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.float-badge .badge-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.float-badge .badge-dot.green { background: #16a34a; box-shadow: 0 0 0 3px rgba(22,163,74,.15); }
.float-badge .badge-dot.cobalt { background: #2563EB; box-shadow: 0 0 0 3px rgba(37,99,235,.15); }
.float-badge .badge-dot.amber { background: #D97706; box-shadow: 0 0 0 3px rgba(217,119,6,.15); }

/* Float badge positions */
.float-badge-1 { top: 16px; right: -12px; animation: floatY 4s ease-in-out infinite; }
.float-badge-2 { bottom: 60px; left: -16px; animation: floatY 4s ease-in-out infinite 1.5s; }
.float-badge-3 { bottom: 16px; right: 20px; animation: floatY 4s ease-in-out infinite 3s; }

@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* --- Testimonial card upgrade --- */
.testi-card-v2 {
  background: white;
  border: 1px solid rgba(37,99,235,.08);
  border-radius: 24px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: 0 2px 12px rgba(15,23,42,.05);
  transition: transform .3s cubic-bezier(0.16,1,0.3,1), box-shadow .3s;
}
.testi-card-v2:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(37,99,235,.10); }
.testi-stars { color: #F59E0B; font-size: .9rem; letter-spacing: 2px; }
.testi-quote { font-size: 1.5rem; color: rgba(37,99,235,.2); font-family: Georgia, serif; line-height: 1; margin-bottom: -8px; }
.testi-text-v2 { font-size: .95rem; line-height: 1.8; color: var(--sub); font-style: italic; }
.testi-author-row { display: flex; align-items: center; gap: 14px; }
.testi-avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: linear-gradient(135deg, #2563EB, #60A5FA);
  display: flex; align-items: center; justify-content: center;
  font-size: .95rem; font-weight: 800; color: white;
  flex-shrink: 0;
}
.testi-author-name { font-size: .9rem; font-weight: 700; color: var(--text); display: block; }
.testi-author-role { font-size: .78rem; color: var(--muted); display: block; margin-top: 1px; }
.testi-result-pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(22,163,74,.08);
  border: 1px solid rgba(22,163,74,.15);
  border-radius: 100px;
  padding: 5px 12px;
  font-size: .76rem; font-weight: 700; color: #16a34a;
  margin-top: 4px; width: fit-content;
}

/* --- Button upgrade with inner glow --- */
.btn-primary {
  position: relative;
  background: linear-gradient(160deg, #2563EB 0%, #1d55d4 100%) !important;
  box-shadow: 0 2px 8px rgba(37,99,235,.30), 0 1px 2px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.15) !important;
}
.btn-primary:hover {
  background: linear-gradient(160deg, #3B82F6 0%, #2563EB 100%) !important;
  box-shadow: 0 4px 20px rgba(37,99,235,.40), 0 1px 4px rgba(15,23,42,.10), inset 0 1px 0 rgba(255,255,255,.2) !important;
  transform: translateY(-2px) !important;
}

/* --- Section backgrounds with subtle gradients --- */
.section-hero-bg {
  background: radial-gradient(ellipse 80% 60% at 70% -10%, rgba(37,99,235,.06) 0%, transparent 60%),
              linear-gradient(180deg, #f8faff 0%, #FBFBFD 100%);
}
.section-alt-gradient {
  background: linear-gradient(180deg, var(--alt) 0%, rgba(239,246,255,.4) 100%);
}

/* --- Image mockup upgrade --- */
.img-glow-wrap {
  position: relative;
  border-radius: 20px;
}
.img-glow-wrap::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(37,99,235,.2), rgba(99,102,241,.1), transparent);
  z-index: 0;
}
.img-glow-wrap img {
  position: relative;
  z-index: 1;
  border-radius: 18px;
  width: 100%;
}

/* --- Tag/pill upgrade --- */
.fg-eyebrow {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cobalt);
  background: rgba(37,99,235,.07);
  border: 1px solid rgba(37,99,235,.12);
  border-radius: 100px;
  padding: 5px 14px;
  display: inline-block;
}

/* --- Hero upgrade --- */
.hero-glow-bg {
  position: absolute;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(37,99,235,.08) 0%, transparent 70%);
  top: -200px; right: -200px;
  pointer-events: none;
  z-index: 0;
}

/* --- Number counter animate --- */
@keyframes countUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.count-animate { animation: countUp .6s cubic-bezier(0.16,1,0.3,1) forwards; }

/* --- Scroll reveal upgrade --- */
/* data-r : visible par dÃ©faut, animation uniquement si JS ajoute .pre-r */
[data-r] {
  opacity: 1;
  transform: none;
  transition: opacity .7s cubic-bezier(0.16,1,0.3,1), transform .7s cubic-bezier(0.16,1,0.3,1);
}
[data-r].pre-r {
  opacity: 0;
  transform: translateY(24px);
}
[data-r].visible {
  opacity: 1;
  transform: none;
}

/* --- Bento responsive --- */
@media (max-width: 900px) {
  .bento-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .bento-card.span-4, .bento-card.span-8, .bento-card.span-6,
  .bento-card.span-3, .bento-card.span-5, .bento-card.span-7 { grid-column: span 2; }
}
@media (max-width: 600px) {
  .bento-grid { grid-template-columns: 1fr; }
  .bento-card.span-4, .bento-card.span-8, .bento-card.span-6,
  .bento-card.span-3, .bento-card.span-5, .bento-card.span-7 { grid-column: span 1; }
  .float-badge-1, .float-badge-2, .float-badge-3 { display: none; }
}

/* --- Trust bar upgrade --- */
.trust-bar-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.trust-bar-num {
  font-size: 1.6rem; font-weight: 900; letter-spacing: -.05em;
  color: var(--text); line-height: 1;
}
.trust-bar-lbl { font-size: .75rem; color: var(--muted); font-weight: 500; }

/* --- Process step card --- */
.process-step {
  display: flex; align-items: flex-start; gap: 20px;
}
.process-num {
  width: 40px; height: 40px; border-radius: 12px;
  background: linear-gradient(135deg, #2563EB, #3B82F6);
  color: white; font-size: .88rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(37,99,235,.30);
}

/* --- Logo geo item upgrade --- */
.logo-geo-item {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 12px;
  background: white;
  border: 1px solid rgba(37,99,235,.08);
  border-radius: 16px;
  transition: transform .3s cubic-bezier(0.16,1,0.3,1), box-shadow .3s;
}
.logo-geo-item:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(37,99,235,.10); }
.logo-geo-item img { height: 36px; width: auto; object-fit: contain; }
.logo-geo-item span { font-size: .68rem; color: var(--muted); font-weight: 600; text-align: center; }

/* --- Section divider --- */
.section-divider {
  width: 48px; height: 3px;
  background: linear-gradient(90deg, #2563EB, rgba(37,99,235,.2));
  border-radius: 3px;
  margin: 0 auto 24px;
}

@media (max-width: 700px) {
  .testi-grid { grid-template-columns: 1fr !important; }
}

/* âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
   HERO UI MOCKUP â Dashboard simulÃ©
   âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */

.hero-ui-mockup {
  width: 100%;
  max-width: 480px;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(15,23,42,.16), 0 4px 20px rgba(37,99,235,.08);
  border: 1px solid rgba(37,99,235,.08);
  background: white;
  position: relative;
  z-index: 2;
}

/* Barre de titre type macOS/navigateur */
.ui-header {
  background: #f8fafc;
  border-bottom: 1px solid rgba(15,23,42,.07);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ui-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.ui-dot.red { background: #FF5F57; }
.ui-dot.amber { background: #FFBD2E; }
.ui-dot.green { background: #28CA41; }
.ui-url {
  font-size: .68rem;
  color: #94a3b8;
  font-family: 'SF Mono', 'Fira Code', monospace;
}

/* Corps */
.ui-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* MÃ©triques */
.ui-metrics-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ui-metric {
  background: #f8fafc;
  border-radius: 12px;
  padding: 10px 10px 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  border: 1px solid rgba(15,23,42,.05);
}
.ui-metric-val {
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: -.05em;
  color: var(--text);
  line-height: 1;
}
.ui-metric-val.cobalt { color: #2563EB; }
.ui-metric-val.green { color: #16a34a; }
.ui-metric-lbl { font-size: .65rem; color: #94a3b8; font-weight: 500; }
.ui-metric-trend { font-size: .6rem; font-weight: 700; }
.ui-metric-trend.up { color: #16a34a; }

/* Graphique bars */
.ui-chart-row {
  background: #f8fafc;
  border-radius: 12px;
  padding: 10px 12px 8px;
  border: 1px solid rgba(15,23,42,.05);
}
.ui-chart-label {
  font-size: .65rem;
  color: #94a3b8;
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
}
.ui-chart-bars {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 40px;
}
.ui-bar {
  flex: 1;
  border-radius: 3px 3px 0 0;
  background: rgba(37,99,235,.15);
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.ui-bar.active { background: rgba(37,99,235,.35); }
.ui-bar.pulse-bar {
  background: #2563EB;
  animation: barPulse 2s ease-in-out infinite;
}
@keyframes barPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .7; }
}
.ui-bar-val {
  font-size: .5rem;
  color: #94a3b8;
  position: absolute;
  bottom: -14px;
  font-weight: 600;
}

/* Liste appels */
.ui-calls-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ui-call-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid rgba(15,23,42,.04);
}
.ui-call-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ui-call-dot.green { background: #16a34a; box-shadow: 0 0 0 3px rgba(22,163,74,.15); }
.ui-call-dot.cobalt { background: #2563EB; box-shadow: 0 0 0 3px rgba(37,99,235,.15); }
.ui-call-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.ui-call-name {
  font-size: .68rem;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ui-call-action {
  font-size: .6rem;
  color: #94a3b8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ui-call-amount {
  font-size: .72rem;
  font-weight: 800;
  color: #16a34a;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Barre status */
.ui-status-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(22,163,74,.06);
  border: 1px solid rgba(22,163,74,.12);
  border-radius: 10px;
  padding: 8px 12px;
}
.ui-status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #16a34a;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(22,163,74,.2);
  animation: statusPulse 2s ease-in-out infinite;
}
@keyframes statusPulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(22,163,74,.2); }
  50% { box-shadow: 0 0 0 6px rgba(22,163,74,.1); }
}
.ui-status-bar span {
  font-size: .7rem;
  color: #16a34a;
  font-weight: 600;
}

/* Responsive mockup */
@media (max-width: 1100px) {
  .hero-ui-mockup { max-width: 420px; }
}
@media (max-width: 900px) {
  .hero-ui-mockup { max-width: 100%; }
}

/* âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
   SECTION HOW IT WORKS â 3 Ã©tapes verticales
   âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */
.how-steps {
  max-width: 700px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.how-step {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}
.how-step-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}
.how-step-line {
  width: 2px;
  flex: 1;
  min-height: 32px;
  background: linear-gradient(180deg, rgba(37,99,235,.3) 0%, rgba(37,99,235,.05) 100%);
  margin: 6px 0;
}
.how-step-content {
  flex: 1;
  padding-bottom: 32px;
}
.how-step-card {
  background: white;
  border: 1px solid rgba(37,99,235,.08);
  border-radius: 20px;
  padding: 24px 24px 20px;
  transition: box-shadow .3s cubic-bezier(0.16,1,0.3,1), transform .3s;
}
.how-step-card:hover {
  box-shadow: 0 8px 32px rgba(37,99,235,.10);
  transform: translateX(4px);
}
@media (max-width: 600px) {
  .how-step { gap: 16px; }
  .how-step-card { padding: 18px; }
}

/* âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
   VS TABLE â Comparaison Flowgent vs Humain
   âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */
.vs-table {
  max-width: 800px;
  margin: 0 auto;
  border: 1px solid rgba(37,99,235,.10);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(15,23,42,.06);
}
.vs-header, .vs-row {
  display: grid;
  grid-template-columns: 1fr 1.2fr 1.2fr;
}
.vs-header {
  background: #f8fafc;
  border-bottom: 1px solid rgba(37,99,235,.08);
  padding: 16px 0;
}
.vs-header > div {
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.vs-header .flowgent { 
  background: rgba(37,99,235,.05);
  border-left: 1px solid rgba(37,99,235,.08);
  border-right: 1px solid rgba(37,99,235,.08);
}
.vs-header strong { font-size: .9rem; color: var(--text); }
.vs-row {
  border-top: 1px solid rgba(15,23,42,.05);
  transition: background .2s;
}
.vs-row:hover { background: rgba(37,99,235,.02); }
.vs-col-label, .vs-col {
  padding: 14px 20px;
  font-size: .87rem;
  display: flex;
  align-items: center;
  gap: 8px;
}
.vs-col-label { font-weight: 600; color: var(--sub); }
.vs-col.flowgent { 
  background: rgba(37,99,235,.03);
  border-left: 1px solid rgba(37,99,235,.06);
  border-right: 1px solid rgba(37,99,235,.06);
  color: var(--text);
  font-weight: 500;
}
.vs-col.human { color: var(--sub); }
@media (max-width: 700px) {
  .vs-header, .vs-row { grid-template-columns: 1fr; }
  .vs-col-label { 
    background: rgba(15,23,42,.03); 
    font-size: .75rem;
    padding: 10px 16px;
    border-radius: 0;
  }
  .vs-col { padding: 10px 16px; }
}

.ticker-glow{position:absolute;width:600px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.ticker-num{font-family:'Space Grotesk','Inter',sans-serif;font-size:clamp(2rem,4vw,2.8rem);font-weight:800;letter-spacing:-.05em;color:white;line-height:1;display:block}
.ticker-lbl{font-size:.78rem;color:rgba(255,255,255,.7);font-weight:500;display:block;margin-top:4px}
.ticker-divider{width:1px;height:48px;background:rgba(255,255,255,.2)}
h1,h2,h3{font-family:'Space Grotesk','Inter',sans-serif}
@media(max-width:600px){.ticker-divider{display:none}}

/* Nav glassmorphism upgrade */
.fg-nav{position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:1000;display:flex;align-items:center;gap:48px;background:rgba(251,251,253,0.88);backdrop-filter:blur(25px) saturate(180%);-webkit-backdrop-filter:blur(25px) saturate(180%);border:1px solid rgba(0,0,0,0.07);border-radius:100px;padding:14px 32px;box-shadow:0 4px 20px rgba(0,0,0,0.08);white-space:nowrap}
.fg-nav a{color:var(--sub);text-decoration:none;font-size:.875rem;font-weight:500;letter-spacing:-.01em;transition:color .2s}
.fg-nav a:hover,.fg-nav a.active{color:var(--cobalt)}
.fg-nav-logo{text-decoration:none;display:flex;align-items:center}
.fg-nav-logo img{height:40px;width:auto;display:block;background:transparent}
.fg-nav-cta{background:var(--cobalt);color:#fff!important;padding:10px 22px;border-radius:100px;font-size:.82rem;font-weight:600;box-shadow:var(--sh-cobalt);transition:all .3s var(--ease)}
.fg-nav-cta:hover{background:var(--cobalt-dark)!important;transform:translateY(-1px)}
.fg-nav.scrolled{box-shadow:0 8px 32px rgba(15,23,42,.12)!important;background:rgba(251,251,253,.97)!important}
.fg-nav.scrolled {
  background: rgba(251,251,253,.95) !important;
  box-shadow: 0 4px 32px rgba(15,23,42,.10) !important;
}

/* Stats v2 */
.stats-bar-v2{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.stat-item-v2{display:flex;align-items:flex-start;gap:16px;padding:0 clamp(20px,3vw,40px)}
.stat-icon-v2{width:44px;height:44px;border-radius:14px;background:rgba(37,99,235,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.stat-sep{width:1px;height:56px;background:rgba(37,99,235,.15);flex-shrink:0}
.stat-trend{display:flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;color:#16a34a;margin-top:4px}
@media(max-width:900px){.stats-bar-v2{gap:20px}.stat-sep{display:none}}
@media(max-width:600px){.stat-item-v2{padding:0 12px}}

/* Logos grid v2 */
.logos-grid-v2{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:32px}
.logo-card-geo{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8fafc;border:1px solid rgba(37,99,235,.07);border-radius:16px;transition:transform .3s,box-shadow .3s}
.logo-card-geo:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(37,99,235,.10)}
.logo-card-geo img{width:40px;height:40px;object-fit:cover;border-radius:8px;flex-shrink:0}
.logo-card-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.logo-card-info strong{font-size:.78rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.logo-card-info span{font-size:.65rem;color:var(--muted)}
.placeholder-geo{opacity:.6}
.logo-placeholder-icon{width:40px;height:40px;border-radius:8px;background:rgba(37,99,235,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0}
/* Trust bar v2 */
.trust-bar-v2{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;margin-top:8px;background:rgba(37,99,235,.04);border:1px solid rgba(37,99,235,.08);border-radius:20px;padding:16px 24px}
.trust-item-v2{display:flex;flex-direction:column;align-items:center;gap:2px;padding:0 clamp(16px,3vw,40px)}
.trust-big-num{font-family:'Space Grotesk','Inter',sans-serif;font-size:1.4rem;font-weight:800;letter-spacing:-.04em;color:var(--text)}
.trust-big-lbl{font-size:.72rem;color:var(--muted);font-weight:500}
.trust-v-sep{width:1px;height:36px;background:rgba(37,99,235,.15)}
.live-dot{width:7px;height:7px;border-radius:50%;background:#16a34a;display:inline-block;box-shadow:0 0 0 3px rgba(22,163,74,.2);animation:livePulse 2s infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 3px rgba(22,163,74,.2)}50%{box-shadow:0 0 0 6px rgba(22,163,74,.08)}}
@media(max-width:900px){.logos-grid-v2{grid-template-columns:repeat(2,1fr)}.trust-v-sep{display:none}}
@media(max-width:500px){.logos-grid-v2{grid-template-columns:1fr}}

.results-grid-v2{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.result-card-v2{border:1px solid rgba(37,99,235,.08);border-radius:20px;overflow:hidden;transition:transform .3s,box-shadow .3s}
.result-card-v2:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(37,99,235,.10)}
.result-card-featured{border-color:rgba(37,99,235,.2);box-shadow:0 4px 24px rgba(37,99,235,.12)}
.result-card-header{padding:20px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.result-size-badge{font-size:.75rem;font-weight:800;padding:5px 14px;border-radius:100px;background:rgba(37,99,235,.08);color:#2563EB;border:1px solid rgba(37,99,235,.15)}
.result-icon-v2{width:36px;height:36px;border-radius:10px;background:rgba(37,99,235,.06);display:flex;align-items:center;justify-content:center;margin-left:auto}
.result-card-body{padding:20px}
.result-metric-v2{margin-bottom:16px}
.result-val-v2{font-family:'Space Grotesk','Inter',sans-serif;font-size:1.6rem;font-weight:800;letter-spacing:-.04em;color:var(--cobalt);display:block;line-height:1}
.result-lbl-v2{font-size:.72rem;color:var(--muted);display:block;margin-top:4px}
.result-list-v2{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.result-list-v2 li{font-size:.82rem;color:var(--sub);display:flex;align-items:center;gap:8px}
.result-list-v2 li::before{content:'';width:6px;height:6px;border-radius:50%;background:#2563EB;flex-shrink:0}
@media(max-width:800px){.results-grid-v2{grid-template-columns:1fr}}

/* âââ FAQ v2 accordion âââ */
.faq-list-v2{display:flex;flex-direction:column;gap:8px;max-width:720px;margin:0 auto}
.faq-item{border:1px solid rgba(37,99,235,.08);border-radius:16px;overflow:hidden;background:white;transition:border-color .3s,box-shadow .3s}
.faq-item.open{border-color:rgba(37,99,235,.2);box-shadow:0 4px 20px rgba(37,99,235,.08)}
.faq-question{width:100%;background:none;border:none;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;text-align:left}
.faq-q-left{display:flex;align-items:center;gap:14px}
.faq-icon-wrap{width:36px;height:36px;border-radius:10px;background:rgba(37,99,235,.07);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.faq-question span{font-size:.95rem;font-weight:600;color:var(--text)}
.faq-chevron{flex-shrink:0;color:#94a3b8;transition:transform .3s cubic-bezier(0.16,1,0.3,1)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(0.16,1,0.3,1)}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer-inner{padding:0 20px 18px 70px;font-size:.88rem;color:var(--sub);line-height:1.75}
@media(max-width:600px){.faq-answer-inner{padding:0 16px 16px 16px}}

/* Process num hover pulse */
.process-num{transition:transform .3s cubic-bezier(0.16,1,0.3,1),box-shadow .3s}
.process-num:hover{transform:scale(1.1);box-shadow:0 8px 24px rgba(37,99,235,.3)}

/* How step card hover effect upgrade */
.how-step-card{transition:box-shadow .3s cubic-bezier(0.16,1,0.3,1),transform .3s,border-color .3s}
.how-step-card:hover{box-shadow:0 12px 40px rgba(37,99,235,.12);transform:translateX(6px);border-color:rgba(37,99,235,.2)}

/* Gradient text utility */
.gradient-text{background:linear-gradient(135deg,#2563EB 0%,#7C3AED 60%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Testi result pill improvements */
.testi-result-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(22,163,74,.08);border:1px solid rgba(22,163,74,.2);border-radius:100px;padding:6px 14px;font-size:.75rem;font-weight:600;color:#16a34a}
.reporting-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.reporting-card{background:white;border:1px solid rgba(37,99,235,.08);border-radius:20px;padding:24px;transition:transform .3s,box-shadow .3s}.reporting-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(37,99,235,.10)}@media(max-width:700px){.reporting-grid{grid-template-columns:1fr}}
/* âââ Waveform vocale animÃ©e âââ */
.ui-waveform-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:rgba(37,99,235,.04);border-radius:8px}
.ui-waveform{display:flex;align-items:center;gap:2px;height:24px}
.wf-bar{width:3px;border-radius:2px;background:linear-gradient(180deg,#60A5FA,#2563EB);height:var(--h);animation:wfPulse 1.2s ease-in-out infinite alternate}
@keyframes wfPulse{0%{height:var(--h);opacity:.7}100%{height:calc(var(--h) * 1.6);opacity:1}}

/* âââ Footer v2 âââ */
.footer-v2{background:linear-gradient(180deg,#0f172a 0%,#1e2a3a 100%);padding:60px clamp(24px,6vw,80px) 0;position:relative}
.footer-v2::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(37,99,235,.4),transparent)}
.footer-v2-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-brand-col{gap:0}
.footer-col-title{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.3);margin-bottom:6px}
.footer-col a{font-size:.85rem;color:rgba(255,255,255,.55);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:white}
.footer-socials{display:flex;gap:8px;margin-top:16px}
.footer-social-link{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);text-decoration:none;transition:background .2s,color .2s,border-color .2s}
.footer-social-link:hover{background:rgba(37,99,235,.2);color:#60A5FA;border-color:rgba(37,99,235,.3)}
.footer-v2-bottom{display:flex;align-items:center;justify-content:space-between;padding:20px 0;flex-wrap:wrap;gap:12px}
.footer-trust-badge{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;color:rgba(255,255,255,.4);font-weight:500}
@media(max-width:900px){.footer-v2-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:600px){.footer-v2-top{grid-template-columns:1fr}.footer-v2-bottom{flex-direction:column;align-items:flex-start}}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}.pricing-card{border:1px solid rgba(37,99,235,.1);border-radius:24px;padding:32px;background:white;position:relative;transition:transform .3s,box-shadow .3s}.pricing-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(37,99,235,.10)}.pricing-featured{background:linear-gradient(160deg,#1e40af 0%,#2563EB 60%,#3b82f6 100%);border-color:transparent;box-shadow:0 12px 48px rgba(37,99,235,.3);transform:scale(1.03);color:#fff}.pricing-featured:hover{transform:scale(1.03) translateY(-4px)}
/* --- pricing-featured white text overrides --- */
.pricing-featured .pricing-period,
.pricing-featured .pricing-sub,
.pricing-featured .pricing-amount,
.pricing-featured .pricing-name,
.pricing-featured .pricing-feature{color:#fff}
.pricing-featured .pricing-feature::before{background:#fff!important;opacity:.7}
.pricing-featured .pricing-cta.btn-ghost{color:#fff;border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.12)}
.pricing-featured .pricing-cta.btn-ghost:hover{background:rgba(255,255,255,.2);color:#fff}
.pricing-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#F59E0B,#FBBF24);color:#1d1d1f;font-size:.65rem;font-weight:800;padding:4px 14px;border-radius:100px;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}.pricing-plan-name{font-family:'Space Grotesk','Inter',sans-serif;font-size:1rem;font-weight:800;letter-spacing:-.02em;color:var(--cobalt);margin-bottom:4px}.pricing-ideal{font-size:.75rem;color:var(--muted);margin-bottom:20px}.pricing-price{display:flex;align-items:baseline;gap:2px;margin-bottom:4px}.pricing-amount{font-family:'Space Grotesk','Inter',sans-serif;font-size:2.6rem;font-weight:800;letter-spacing:-.06em;color:var(--text);line-height:1}.pricing-currency{font-size:1.4rem;font-weight:700}.pricing-period{font-size:.85rem;color:var(--muted);margin-left:4px}.pricing-sub{font-size:.72rem;color:var(--muted);margin-bottom:24px}.pricing-features{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px}.pricing-features li{font-size:.85rem;color:var(--sub);display:flex;align-items:center;gap:8px}.pricing-feature-off{opacity:.45}.pricing-cta{display:block;padding:14px;border-radius:100px;text-decoration:none;font-size:.9rem;font-weight:700;text-align:center;transition:transform .2s,box-shadow .2s}.pricing-cta:hover{transform:translateY(-1px)}.pricing-cta.btn-ghost{border:1.5px solid rgba(37,99,235,.25);color:#2563EB;background:white}@media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}.pricing-featured{transform:none}}
/* âââââââââââââââââââââââââââââââââââââââââââ
   MOBILE CRITICAL â iPhone 15 390px fixes
   âââââââââââââââââââââââââââââââââââââââââââ */

/* A) Hamburger menu nav */
.fg-nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px}
.fg-nav-hamburger svg{display:block}
.fg-nav-mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,23,42,.5);z-index:9998;backdrop-filter:blur(4px)}
.fg-nav-mobile-menu{display:none;position:fixed;top:0;right:0;width:min(300px,85vw);height:100vh;background:white;z-index:9999;padding:24px;box-shadow:-4px 0 40px rgba(15,23,42,.15);flex-direction:column;gap:4px}
.fg-nav-mobile-close{align-self:flex-end;background:none;border:none;cursor:pointer;padding:4px;margin-bottom:16px}
.fg-nav-mobile-menu a{display:block;padding:14px 16px;font-size:1rem;font-weight:600;color:var(--text);text-decoration:none;border-radius:12px;transition:background .2s}
.fg-nav-mobile-menu a:hover{background:rgba(37,99,235,.06);color:var(--cobalt)}
.fg-nav-mobile-menu .fg-nav-cta{background:#2563EB;color:white!important;text-align:center;margin-top:8px;border-radius:100px}

@media(max-width:720px){
  /* Nav desktop links hidden, hamburger shown */
  .fg-nav > a:not(.fg-nav-logo){display:none}
  .fg-nav-hamburger{display:flex;align-items:center;justify-content:center}

  /* Hero: stack col */
  .hero-inner{flex-direction:column!important;gap:32px!important;padding:40px 20px 32px!important}
  .hero-left{max-width:100%!important;text-align:center!important}
  .hero-left h1{font-size:clamp(1.8rem,7vw,2.4rem)!important}
  .hero-cta-row{justify-content:center!important}
  .hero-right{width:100%!important;max-width:420px!important;margin:0 auto!important}
  .hero-ui-mockup{width:100%!important;max-width:100%!important}

  /* Stats bar */
  .stats-bar-v2{grid-template-columns:repeat(2,1fr)!important;gap:16px!important}

  /* Bento grid */
  .bento-grid{grid-template-columns:1fr!important}

  /* Split layout */
  .split-layout{flex-direction:column!important;gap:32px!important}
  .fondateur-img-wrap{max-width:380px!important;margin:0 auto!important}

  /* CTA section */
  #cta-sec .notfound-links,.notfound-links{flex-direction:column!important;align-items:center!important}

  /* Logos grid */
  .logos-grid-v2{grid-template-columns:repeat(2,1fr)!important}

  /* Trust bar */
  .trust-bar-v2{grid-template-columns:repeat(2,1fr)!important}

  /* How steps */
  .how-steps{flex-direction:column!important}

  /* Footer v2 */
  .footer-v2{overflow-x:hidden}
  .footer-v2-top{grid-template-columns:1fr!important;gap:24px!important}
  .footer-v2-bottom{flex-direction:column!important;gap:8px!important}

  /* Pricing grid */
  .pricing-grid{grid-template-columns:1fr!important;max-width:420px!important;margin:0 auto!important}
  .pricing-featured{transform:none!important}

  /* Results grid */
  .results-grid-v2{grid-template-columns:1fr!important}

  /* Reporting grid */
  .reporting-grid{grid-template-columns:1fr!important}

  /* VS table */
  .vs-header,.vs-row{grid-template-columns:1fr!important}
  .vs-header>div:first-child,.vs-row>div:first-child{display:none}

  /* General overflow protection */
  body{overflow-x:hidden}
  .fg-inner{padding-left:16px!important;padding-right:16px!important}

  /* Float badges hide on mobile to avoid overflow */
  .float-badge{display:none!important}

/* Fondateur badge - visible sur photo */
.fondateur-img-wrap .float-badge {
  display: inline-flex!important;
  background: var(--cobalt);
  border-color: rgba(255,255,255,.2);
  color: #fff;
  box-shadow: 0 4px 20px rgba(37,99,235,.4);
}
.fondateur-img-wrap .float-badge .badge-dot.green { background: #4ade80; box-shadow: 0 0 0 3px rgba(74,222,128,.2); }
/* Caption fondateur */
.fondateur-caption {
  text-align: center;
  margin-top: 12px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--sub);
  letter-spacing: .01em;
}


  /* Exit popup */
  #fg-exit-popup .exit-popup-inner{padding:24px 20px!important}
}

@media(max-width:480px){
  .fg-note{text-align:center}
  .hero-stat-num{font-size:1.6rem!important}
  .cta-badges{flex-direction:column!important;align-items:center!important;gap:8px!important}
  h1{word-break:break-word}
}


/* =============================================
   AVANT / APRES â comparison table /services/
   ============================================= */
.comparison-wrap{border:1.5px solid #e5e7eb;border-radius:20px;overflow:hidden;background:white}
.comparison-header{display:grid;grid-template-columns:1fr 1fr;border-bottom:1.5px solid #e5e7eb}
.comparison-col-header{padding:14px 20px;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;text-align:center}
.comparison-col-header.bad{background:#fef2f2;color:#dc2626;border-right:1.5px solid #e5e7eb}
.comparison-col-header.good{background:#f0fdf4;color:#16a34a}
.comparison-rows{display:flex;flex-direction:column}
.comparison-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid #f0f0f0}
.comparison-row:last-child{border-bottom:none}
.comparison-cell{padding:16px 20px;font-size:.85rem;line-height:1.6;color:#374151;display:flex;align-items:flex-start;gap:10px}
.comparison-cell.bad{border-right:1.5px solid #e5e7eb;background:#fafafa}
.comparison-cell.good{background:#fafffe}
.comparison-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
@media(max-width:640px){
  .comparison-header,.comparison-row{grid-template-columns:1fr}
  .comparison-cell.bad{border-right:none;border-bottom:1px solid #e5e7eb}
}

/* --- Dark CTA block â force white text (override any Elementor/global rules) --- */
.dark-cta, .dark-cta *:not(a){color:#fff!important}
.dark-cta p{color:rgba(255,255,255,.85)!important}
.dark-cta h3,.dark-cta h2,.dark-cta h1{color:#fff!important}
.dark-cta a.btn-primary,.dark-cta a[style*="background:#2563EB"]{color:#fff!important;background:#2563EB!important}

/* Reveal animation — classe .in (ajoutée par IntersectionObserver) */
[data-r].in {
  opacity: 1;
  transform: none;
}
/* Version 5.7.0 — micro-animations reveal sur tous les templates */


/* ═══════════════════════════════════════════════════
   CSS v5.8.0 — Hover states enrichis — CYCLE 38
   Cohérence UX : box-shadow cobalt sur toutes les cards
   ═══════════════════════════════════════════════════ */

.pricing-card:hover,
.pricing-card:focus-within {
  box-shadow: 0 12px 40px rgba(37,99,235,.18) !important;
  transform: translateY(-3px);
  border-color: rgba(37,99,235,.25) !important;
}

.faq-item:hover {
  box-shadow: 0 4px 24px rgba(37,99,235,.12) !important;
  border-color: rgba(37,99,235,.2) !important;
}

.testi-card-v2:hover {
  box-shadow: 0 8px 32px rgba(37,99,235,.14) !important;
  transform: translateY(-2px);
  border-color: rgba(37,99,235,.22) !important;
}

/* Transitions cohérentes */
.pricing-card,
.faq-item,
.testi-card-v2 {
  transition: box-shadow .22s ease, transform .22s ease, border-color .22s ease !important;
}

/* Hover renforcé sur fg-slot (grille créneaux demo) */
.fg-slot:hover:not([style*="background:#EEF2FF"]) {
  background: #f0f4ff !important;
  border-color: #93c5fd !important;
  box-shadow: 0 2px 12px rgba(37,99,235,.1) !important;
}

.fg-slot[style*="background:#EEF2FF"]:hover {
  box-shadow: 0 4px 20px rgba(37,99,235,.2) !important;
  transform: translateY(-1px);
}

/* ─── Nav mobile C69 — fix logo/hamburger overlap ─── */
@media(max-width:720px){
  .fg-nav{
    width:calc(100vw - 32px)!important;
    max-width:calc(100vw - 32px)!important;
    padding:10px 16px!important;
    gap:0!important;
    justify-content:space-between!important;
  }
  .fg-nav-logo img{height:32px!important}
}
