/**
 * index-landing.css — Hero mega + harmonisation sections
 * nael.so / + parcours restaurateurs + consultants
 */

body.mkt-index-page,
body.mkt-audience-resto,
body.mkt-audience-consultant {
  --hero-mega-pad-top: 88px;
}

@media (min-width: 768px) {
  body.mkt-index-page,
body.mkt-audience-resto,
body.mkt-audience-consultant {
    --hero-mega-pad-top: 96px;
  }
}

/* ─── Hero mega (produit d'abord) ─── */

/* Hero copy — même graisse resto / consultant */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .hero-mega .hero-sub strong {
  color: var(--text, #1c1a14);
  font-weight: 500;
}

body.mkt-index-page .hero-mega ,
body.mkt-audience-resto .hero-mega ,
body.mkt-audience-consultant .hero-mega {
  position: relative;
  padding: var(--hero-mega-pad-top) 0 56px;
  overflow: hidden;
}

@media (min-width: 768px) {
  body.mkt-index-page .hero-mega ,
body.mkt-audience-resto .hero-mega ,
body.mkt-audience-consultant .hero-mega {
    padding-bottom: 72px;
  }
}

body.mkt-index-page .hero-mega__ambient ,
body.mkt-audience-resto .hero-mega__ambient ,
body.mkt-audience-consultant .hero-mega__ambient {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  /* Lueurs locales seulement — le dégradé de page est sur body::before */
  background:
    radial-gradient(ellipse 90% 60% at 12% -10%, rgba(27, 79, 204, 0.11), transparent 55%),
    radial-gradient(ellipse 70% 50% at 88% 20%, rgba(28, 26, 20, 0.05), transparent 50%);
}

body.mkt-index-page .hero-mega .container ,
body.mkt-audience-resto .hero-mega .container ,
body.mkt-audience-consultant .hero-mega .container {
  position: relative;
  z-index: 1;
  max-width: 1160px;
}

body.mkt-index-page .hero-mega .hero-inner ,
body.mkt-audience-resto .hero-mega .hero-inner ,
body.mkt-audience-consultant .hero-mega .hero-inner {
  display: flex;
  gap: 52px;
  align-items: center;
}

body.mkt-index-page .hero-mega .hero-right ,
body.mkt-audience-resto .hero-mega .hero-right ,
body.mkt-audience-consultant .hero-mega .hero-right {
  width: min(460px, 100%);
}

body.mkt-index-page .hero-mega .hero-stage ,
body.mkt-audience-resto .hero-mega .hero-stage ,
body.mkt-audience-consultant .hero-mega .hero-stage {
  position: relative;
  animation: mkt-hero-rise 0.95s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes mkt-hero-rise {
  from {
    opacity: 0;
    transform: translateY(22px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

body.mkt-index-page .hero-stat-pill ,
body.mkt-audience-resto .hero-stat-pill ,
body.mkt-audience-consultant .hero-stat-pill {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  padding: 8px 14px 8px 10px;
  margin-bottom: 18px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow: 0 2px 12px rgba(28, 26, 20, 0.06);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted, #6b6560);
}

body.mkt-index-page .hero-stat-pill strong ,
body.mkt-audience-resto .hero-stat-pill strong ,
body.mkt-audience-consultant .hero-stat-pill strong {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 15px;
  font-weight: 400;
  color: var(--red, #dc2626);
  letter-spacing: -0.02em;
}

body.mkt-index-page .hero-stat-pill .hero-stat-sep ,
body.mkt-audience-resto .hero-stat-pill .hero-stat-sep ,
body.mkt-audience-consultant .hero-stat-pill .hero-stat-sep {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--text-faint, #9b9590);
  opacity: 0.6;
}

body.mkt-index-page .hero-hosting-pill ,
body.mkt-audience-resto .hero-hosting-pill ,
body.mkt-audience-consultant .hero-hosting-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  margin-bottom: 14px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow: 0 2px 12px rgba(28, 26, 20, 0.06);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted, #6b6560);
  letter-spacing: 0.02em;
}

body.mkt-index-page .hero.hero-mega.mkt-hero ,
body.mkt-audience-resto .hero.hero-mega.mkt-hero ,
body.mkt-audience-consultant .hero.hero-mega.mkt-hero {
  padding: var(--hero-mega-pad-top) 0 56px !important;
  background: transparent !important;
}

body.mkt-index-page .hero-mega h1 ,
body.mkt-audience-resto .hero-mega h1 ,
body.mkt-audience-consultant .hero-mega h1 {
  font-size: clamp(2.15rem, 5vw, 3.45rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.03em;
  max-width: 540px;
  margin-bottom: 10px;
}

body.mkt-index-page .hero-mega .hero-source ,
body.mkt-audience-resto .hero-mega .hero-source ,
body.mkt-audience-consultant .hero-mega .hero-source {
  font-size: 13px;
  line-height: 1.45;
  color: var(--text-faint);
  max-width: 480px;
  margin-bottom: 16px;
}

body.mkt-index-page .hero-mega .hero-sub ,
body.mkt-audience-resto .hero-mega .hero-sub ,
body.mkt-audience-consultant .hero-mega .hero-sub {
  font-size: clamp(1rem, 1.65vw, 1.12rem);
  line-height: 1.62;
  max-width: 480px;
  margin-bottom: 12px;
}

body.mkt-index-page .hero-mega .hero-product ,
body.mkt-audience-resto .hero-mega .hero-product ,
body.mkt-audience-consultant .hero-mega .hero-product {
  font-size: clamp(0.95rem, 1.5vw, 1.05rem);
  line-height: 1.58;
  max-width: 480px;
  color: var(--text-muted);
  margin-bottom: 26px;
}

body.mkt-index-page .hero-mega .hero-cta ,
body.mkt-audience-resto .hero-mega .hero-cta ,
body.mkt-audience-consultant .hero-mega .hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-bottom: 4px;
}

body.mkt-index-page .hero-mega .hero-mention ,
body.mkt-audience-resto .hero-mega .hero-mention ,
body.mkt-audience-consultant .hero-mega .hero-mention {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  max-width: 440px;
  margin-top: 18px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(28, 26, 20, 0.06);
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-muted);
}

body.mkt-index-page .hero-mega .hero-mention i ,
body.mkt-audience-resto .hero-mega .hero-mention i ,
body.mkt-audience-consultant .hero-mega .hero-mention i {
  color: var(--accent);
  margin-top: 3px;
  flex-shrink: 0;
}

body.mkt-index-page .hero-mega .hero-glow ,
body.mkt-audience-resto .hero-mega .hero-glow ,
body.mkt-audience-consultant .hero-mega .hero-glow {
  inset: -20% -15% -10% -10%;
  background:
    radial-gradient(ellipse 60% 50% at 75% 25%, rgba(27, 79, 204, 0.2), transparent 68%),
    radial-gradient(ellipse 45% 40% at 10% 90%, rgba(28, 26, 20, 0.07), transparent 65%);
}

body.mkt-index-page .hero-float-card ,
body.mkt-audience-resto .hero-float-card ,
body.mkt-audience-consultant .hero-float-card {
  position: absolute;
  right: -6px;
  bottom: -18px;
  z-index: 10;
  width: min(252px, 52%);
  padding: 14px 16px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.04),
    0 12px 32px rgba(28, 26, 20, 0.12);
  animation: mkt-hero-float 5.2s ease-in-out 0.6s infinite;
}

body.mkt-index-page .hero-float-label ,
body.mkt-audience-resto .hero-float-label ,
body.mkt-audience-consultant .hero-float-label {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent, #1b4fcc);
  margin-bottom: 6px;
}

body.mkt-index-page .hero-float-title ,
body.mkt-audience-resto .hero-float-title ,
body.mkt-audience-consultant .hero-float-title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.35rem;
  font-weight: 400;
  color: var(--red, #dc2626);
  letter-spacing: -0.02em;
  margin-bottom: 8px;
  line-height: 1.1;
}

body.mkt-index-page .hero-float-line ,
body.mkt-audience-resto .hero-float-line ,
body.mkt-audience-consultant .hero-float-line {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
  padding-left: 10px;
  border-left: 2px solid var(--orange, #d97706);
}

body.mkt-index-page .hero-float-line strong ,
body.mkt-audience-resto .hero-float-line strong ,
body.mkt-audience-consultant .hero-float-line strong {
  color: var(--text);
  font-weight: 600;
}

body.mkt-index-page .mkt-trust-row ,
body.mkt-audience-resto .mkt-trust-row ,
body.mkt-audience-consultant .mkt-trust-row {
  justify-content: flex-start;
}

@media (max-width: 960px) {
  body.mkt-index-page .mkt-trust-row ,
body.mkt-audience-resto .mkt-trust-row ,
body.mkt-audience-consultant .mkt-trust-row {
    justify-content: center;
  }

  body.mkt-index-page .hero-mega h1 ,
body.mkt-audience-resto .hero-mega h1 ,
body.mkt-audience-consultant .hero-mega h1 {
    max-width: none;
  }

  body.mkt-index-page .hero-mega .hero-mention ,
body.mkt-audience-resto .hero-mega .hero-mention ,
body.mkt-audience-consultant .hero-mega .hero-mention {
    margin-left: auto;
    margin-right: auto;
  }

  body.mkt-index-page .hero-float-card ,
body.mkt-audience-resto .hero-float-card ,
body.mkt-audience-consultant .hero-float-card {
    position: relative;
    right: auto;
    bottom: auto;
    width: 100%;
    margin-top: 14px;
    animation: none;
  }
}

/* Gateway — sous la hero, secondaire */
body.mkt-index-page .audience-gateway--after-hero {
  padding: 48px 0 56px;
  background: transparent !important;
  border: none !important;
}

body.mkt-index-page .audience-gateway--after-hero .audience-gateway__head h2 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 400;
  line-height: 1.15;
  margin-bottom: 10px;
}

body.mkt-index-page .audience-gateway--after-hero .audience-gateway__head h2 em {
  font-style: italic;
  color: var(--accent);
}

/* Sections → bands Apple */
body.mkt-index-page .mkt-band ,
body.mkt-audience-resto .mkt-band ,
body.mkt-audience-consultant .mkt-band {
  padding: 64px 0 72px;
}

body.mkt-index-page .mkt-band--white ,
body.mkt-audience-resto .mkt-band--white ,
body.mkt-audience-consultant .mkt-band--white {
  background: transparent;
  border: none;
}

body.mkt-index-page .mkt-band--cream ,
body.mkt-audience-resto .mkt-band--cream ,
body.mkt-audience-consultant .mkt-band--cream {
  background: transparent;
}

body.mkt-index-page .mkt-band .container ,
body.mkt-audience-resto .mkt-band .container ,
body.mkt-audience-consultant .mkt-band .container {
  max-width: 1100px;
}

body.mkt-index-page .mkt-band-head ,
body.mkt-audience-resto .mkt-band-head ,
body.mkt-audience-consultant .mkt-band-head {
  text-align: center;
  max-width: 640px;
  margin: 0 auto 40px;
}

body.mkt-index-page .mkt-band-head h2 ,
body.mkt-audience-resto .mkt-band-head h2 ,
body.mkt-audience-consultant .mkt-band-head h2 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.65rem, 3.2vw, 2.35rem);
  font-weight: 400;
  line-height: 1.15;
  margin: 0 0 10px;
}

body.mkt-index-page .mkt-band-head h2 em ,
body.mkt-audience-resto .mkt-band-head h2 em ,
body.mkt-audience-consultant .mkt-band-head h2 em {
  font-style: italic;
  color: var(--accent);
}

body.mkt-index-page .mkt-band-head .section-desc ,
body.mkt-audience-resto .mkt-band-head .section-desc ,
body.mkt-audience-consultant .mkt-band-head .section-desc {
  font-size: 15px;
  color: var(--text-muted);
  line-height: 1.65;
  margin: 0;
}

body.mkt-index-page .tools-section.mkt-band ,
body.mkt-audience-resto .tools-section.mkt-band ,
body.mkt-audience-consultant .tools-section.mkt-band {
  padding-top: 56px;
}

body.mkt-index-page .proof.mkt-band ,
body.mkt-audience-resto .proof.mkt-band ,
body.mkt-audience-consultant .proof.mkt-band {
  padding-bottom: 80px;
}

body.mkt-index-page .section-compare.mkt-band,
body.mkt-index-page .section-pricing.mkt-band,
body.mkt-index-page .story-section.mkt-band,
body.mkt-audience-resto .section-compare.mkt-band,
body.mkt-audience-consultant .section-compare.mkt-band,
body.mkt-audience-consultant .section-compare.mkt-band ,
body.mkt-audience-resto .section-pricing.mkt-band,
body.mkt-audience-resto .story-section.mkt-band {
  padding: 72px 0;
}

body.mkt-index-page .section-form.mkt-band ,
body.mkt-audience-resto .section-form.mkt-band ,
body.mkt-audience-consultant .section-form.mkt-band {
  padding: 64px 0 80px;
}

body.mkt-index-page .section-trust.mkt-band ,
body.mkt-audience-resto .section-trust.mkt-band ,
body.mkt-audience-consultant .section-trust.mkt-band {
  padding: 48px 0 64px;
}

body.mkt-index-page .section-faq.mkt-band ,
body.mkt-audience-resto .section-faq.mkt-band ,
body.mkt-audience-consultant .section-faq.mkt-band {
  padding: 56px 0 72px;
}

body.mkt-index-page .section-sources.mkt-band ,
body.mkt-audience-resto .section-sources.mkt-band ,
body.mkt-audience-consultant .section-sources.mkt-band {
  padding: 40px 0 56px;
  font-size: 12px;
}

/* Cartes outils / proof — ombres float unifiées */
body.mkt-index-page .proof-metrics .proof-card,
body.mkt-audience-resto .proof-metrics .proof-card ,
body.mkt-audience-consultant .proof-metrics .proof-card {
  border-radius: 22px;
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.03),
    0 10px 28px rgba(28, 26, 20, 0.08);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

body.mkt-index-page .proof-metrics .proof-card:hover,
body.mkt-audience-resto .proof-metrics .proof-card:hover ,
body.mkt-audience-consultant .proof-metrics .proof-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(28, 26, 20, 0.1);
}

body.mkt-index-page .step-card,
body.mkt-index-page .pricing-card,
body.mkt-index-page .compare-col,
body.mkt-index-page .method-card,
body.mkt-index-page .story-card,
body.mkt-audience-resto .step-card,
body.mkt-audience-consultant .step-card,
body.mkt-audience-resto .pricing-card,
body.mkt-audience-resto .compare-col,
body.mkt-audience-resto .method-card,
body.mkt-audience-resto .story-card {
  border-radius: 22px;
}

body.mkt-index-page .section-header ,
body.mkt-audience-resto .section-header ,
body.mkt-audience-consultant .section-header {
  margin-bottom: 40px;
}

body.mkt-index-page .section-header h2 ,
body.mkt-audience-resto .section-header h2 ,
body.mkt-audience-consultant .section-header h2 {
  font-family: 'Fraunces', Georgia, serif;
}

@media (prefers-reduced-motion: reduce) {
  body.mkt-index-page .hero-mega .hero-stage,
  body.mkt-index-page .hero-float-card,
  body.mkt-audience-resto .hero-mega .hero-stage,
  body.mkt-audience-consultant .hero-mega .hero-stage,
  body.mkt-audience-resto .hero-float-card {
    animation: none;
  }
}

/* ─── Bloc restaurateurs (index + page dédiée) ─── */
body.mkt-index-page .resto-diy-band.mkt-band,
body.mkt-audience-resto .resto-diy-band.mkt-band ,
body.mkt-audience-consultant .resto-diy-band.mkt-band {
  padding: 64px 0 72px;
  background: transparent;
  border: none;
}

body.mkt-index-page .resto-diy-band__grid,
body.mkt-audience-resto .resto-diy-band__grid ,
body.mkt-audience-consultant .resto-diy-band__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

@media (max-width: 800px) {
  body.mkt-index-page .resto-diy-band__grid,
  body.mkt-audience-resto .resto-diy-band__grid ,
  body.mkt-audience-consultant .resto-diy-band__grid {
    grid-template-columns: 1fr;
  }
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .resto-diy-band .mkt-cross-audience {
  margin: 48px auto 0;
  max-width: 640px;
}

@media (max-width: 640px) {
  :is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .resto-diy-band .mkt-cross-audience {
    margin-top: 32px;
  }
}

body.mkt-index-page .mkt-band-foot,
body.mkt-audience-resto .mkt-band-foot ,
body.mkt-audience-consultant .mkt-band-foot {
  margin: 28px 0 0;
  text-align: center;
  font-size: 14px;
}

body.mkt-index-page .mkt-band-foot a,
body.mkt-audience-resto .mkt-band-foot a ,
body.mkt-audience-consultant .mkt-band-foot a {
  color: var(--accent, #1b4fcc);
  font-weight: 600;
  text-decoration: none;
}

body.mkt-index-page .mkt-band-foot a:hover,
body.mkt-audience-resto .mkt-band-foot a:hover ,
body.mkt-audience-consultant .mkt-band-foot a:hover {
  text-decoration: underline;
}

/* Carte restaurateur — accent vert discret */
body.mkt-index-page .audience-gateway--after-hero .audience-card--resto {
  border-color: rgba(22, 163, 74, 0.14);
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.03),
    0 10px 28px rgba(28, 26, 20, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

body.mkt-index-page .audience-gateway--after-hero .audience-card--resto:hover {
  border-color: rgba(22, 163, 74, 0.32);
  box-shadow:
    0 4px 8px rgba(28, 26, 20, 0.04),
    0 16px 40px rgba(22, 163, 74, 0.1);
}

body.mkt-index-page .audience-gateway--after-hero .audience-card--pro {
  border-color: rgba(27, 79, 204, 0.12);
}

body.mkt-index-page .audience-gateway--after-hero .audience-card--pro:hover {
  border-color: rgba(27, 79, 204, 0.28);
}

/* ═══════════════════════════════════════
   Landings client + restaurateurs — fond bleu consultant (aligné landing-consultant)
═══════════════════════════════════════ */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) {
  background: #f4f7ff;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

body.mkt-audience-resto .nav-brand {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant).canvas-page.canvas-consultant {
  background-color: #f4f7ff !important;
  background-image: none !important;
  background-attachment: scroll !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant)::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse 90% 55% at 12% -8%, rgba(27, 79, 204, 0.12), transparent 58%),
    radial-gradient(ellipse 75% 50% at 88% 12%, rgba(12, 21, 39, 0.04), transparent 52%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(27, 79, 204, 0.06), transparent 55%),
    linear-gradient(180deg, #eef2fc 0%, #f4f7ff 28%, #f4f7ff 100%);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) > nav,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) > main,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) > footer {
  position: relative;
  z-index: 1;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) main > section,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-page-flow > section,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-page-flow > .audience-gateway {
  background: transparent !important;
  border: none !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-band--white,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-band--cream,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .resto-diy-band.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .cons-diy-band.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .feat-section.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-glissement.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .story-section.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-compare.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-pricing.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-trust.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-faq.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-form.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-sources.mkt-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-hero.mkt-band {
  background: transparent !important;
  border: none !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .audience-gateway--after-hero {
  border-bottom: none;
  padding-bottom: 48px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .feat-section.mkt-band {
  padding: 64px 0;
}

@media (min-width: 768px) {
  body.mkt-index-page .feat-section.mkt-band {
    padding: 72px 0;
  }
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .feat-section .feat-text h2 {
  font-family: 'Fraunces', Georgia, serif;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .feat-section .feat-text h2 em {
  font-style: italic;
  color: var(--accent);
}

/* Proof metrics — bandeau sombre (22 000 €) */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics {
  background: var(--dark);
  border-radius: var(--radius-xl);
  padding: 6px;
  box-shadow: var(--shadow-float-dark);
  gap: 12px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: #f7f5f0;
  box-shadow: none;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-card:hover {
  transform: none;
  box-shadow: none;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-label {
  color: rgba(247, 245, 240, 0.65);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-label strong {
  color: #f7f5f0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-num {
  color: #fff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-num.red {
  color: #fca5a5;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-num.orange {
  color: #fcd34d;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-metrics .proof-num.blue {
  color: #a8c0ff;
}

/* Proof — bloc conversion (questions restaurateur) */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-band .proof-card--q {
  text-align: left;
  padding: 26px 22px 22px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-band .proof-card-q {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--accent);
  margin: 0 0 14px;
  line-height: 1.35;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-band .proof-num {
  text-align: left;
  margin-bottom: 10px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-band .proof-label {
  text-align: left;
  font-size: 14px;
  line-height: 1.55;
  margin-bottom: 14px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-band .proof-source {
  display: block;
  text-align: left;
  font-size: 11px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert {
  margin-top: 36px;
  padding: 28px 32px;
  border-radius: 22px;
  background: linear-gradient(165deg, #f0efe9 0%, #fff 55%, #f7f5f0 100%);
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow: 0 10px 28px rgba(28, 26, 20, 0.06);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-lead {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.1rem, 2vw, 1.28rem);
  line-height: 1.45;
  color: var(--text);
  margin: 0 0 12px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-body {
  font-size: 15px;
  line-height: 1.65;
  color: var(--text-muted);
  margin: 0 0 22px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px 20px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-note {
  font-size: 13px;
  color: var(--text-faint);
}

@media (max-width: 680px) {
  :is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert {
    padding: 22px 20px;
  }

  :is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-actions {
    flex-direction: column;
    align-items: stretch;
  }

  :is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-actions .btn-primary {
    justify-content: center;
    text-align: center;
  }
}

/* Glissement — mode clair */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-glissement {
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-glissement .section-eyebrow {
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-glissement h2 {
  color: var(--text);
  font-family: 'Fraunces', serif;
}

/* Glissement dans l'îlot sombre — texte clair */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-glissement {
  color: #f7f5f0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-glissement .section-eyebrow {
  color: rgba(247, 245, 240, 0.55);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-glissement h2,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-glissement .section-header h2 {
  color: #f7f5f0;
}

/* Parcours dans l'îlot sombre — texte clair (évite sombre sur sombre) */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-how .section-header .section-badge {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.18);
  color: rgba(247, 245, 240, 0.85);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-how .section-header h2,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-how .section-header h2 em {
  color: #f7f5f0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-how .section-header .section-desc {
  color: rgba(247, 245, 240, 0.78);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .section-how .section-header .section-desc strong {
  color: #fff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.03),
    0 10px 28px rgba(28, 26, 20, 0.08);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-card p {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-card strong {
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-stats {
  border-top-color: rgba(28, 26, 20, 0.08);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-stat {
  background: var(--cream, #f7f5f0);
  border: 1px solid rgba(28, 26, 20, 0.08);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-stat .num {
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-stat .lbl {
  color: var(--text-muted);
}

/* Comment ça marche — cartes claires */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .section-eyebrow {
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .section-header h2 {
  color: var(--text);
  font-family: 'Fraunces', Georgia, serif;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .section-header .section-desc {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .step-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.03),
    0 10px 28px rgba(28, 26, 20, 0.08);
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .step-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(28, 26, 20, 0.1);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .step-num {
  background: var(--accent-light);
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .step-title {
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .step-desc {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-how .step-desc strong {
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .source-note {
  color: var(--text-faint);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .product-shell.shell-compact {
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.04),
    0 12px 32px rgba(28, 26, 20, 0.12),
    0 0 0 1px rgba(28, 26, 20, 0.06);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .product-shell.shell-compact:hover {
  transform: translateY(-4px);
  box-shadow:
    0 4px 8px rgba(28, 26, 20, 0.06),
    0 16px 40px rgba(28, 26, 20, 0.12),
    0 0 0 1px rgba(27, 79, 204, 0.08);
}

/* CTA « Aller plus loin » — carte flottante claire */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-hero {
  padding: 48px 0 64px;
}

body.canvas-page:is(.mkt-index-page, .mkt-audience-resto) .diy-hero .diy-hero-inner {
  padding: 56px 36px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.96) !important;
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.03),
    0 16px 48px rgba(28, 26, 20, 0.1);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-hero .diy-hero-inner::before {
  background: radial-gradient(ellipse 70% 60% at 50% 100%, rgba(27, 79, 204, 0.08) 0%, transparent 70%);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-eyebrow {
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-hero h2 {
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-hero h2 em {
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-hero p.diy-sub {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-pill {
  background: var(--cream, #f7f5f0);
  border-color: rgba(28, 26, 20, 0.1);
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-pill a {
  color: inherit;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .btn-diy {
  background: var(--accent);
  color: #fff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-note {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .diy-note a {
  color: var(--accent);
}

/* Footer — même fond, discret */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) footer.mkt-footer,
body.mkt-apple-page:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-footer {
  background: transparent !important;
  border: none !important;
  padding: 32px 0 48px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) footer .footer-brand {
  color: var(--text);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) footer .footer-brand em {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) footer .footer-links a {
  color: var(--text-muted);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) footer .footer-links a:hover {
  color: var(--accent);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) footer .footer-copy {
  color: var(--text-faint);
}

/* Sections titres — typo Apple unifiée */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-header h2,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-glissement .section-header h2 {
  font-family: 'Fraunces', Georgia, serif;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-pricing .pricing-card,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .section-form .form-card {
  box-shadow:
    0 2px 4px rgba(28, 26, 20, 0.03),
    0 10px 28px rgba(28, 26, 20, 0.08);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .pricing-features {
  gap: 8px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .pricing-features li {
  gap: 8px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .pricing-feature-detail {
  color: var(--text-muted);
}

/* ─── Zéro traits de coupure (fond crème continu) ─── */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .audience-gateway,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .audience-gateway--after-hero,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .audience-gateway--compact {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .resto-diy-band,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .resto-diy-band.mkt-band {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) main > section,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-page-flow > section {
  background: transparent !important;
  border-top: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant).canvas-page .proof-metrics {
  background: var(--dark) !important;
  box-shadow: var(--shadow-float-dark) !important;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .hero-mega {
  background: transparent;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .hero-mega__ambient {
  background:
    radial-gradient(ellipse 90% 60% at 12% -10%, rgba(27, 79, 204, 0.11), transparent 55%),
    radial-gradient(ellipse 70% 50% at 88% 20%, rgba(28, 26, 20, 0.05), transparent 50%);
}

/* Îlots sombres (produit + CTA) */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark,
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) > .raft-dark {
  position: relative;
  z-index: 1;
}

/* Évite la pastille cream-dark qui casse la continuité */
body.mkt-audience-resto.mkt-apple-page .mkt-cross-audience {
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(28, 26, 20, 0.08);
  box-shadow: 0 2px 12px rgba(28, 26, 20, 0.05);
}

/* marketing-apple.css — bandes blanches avec bordures */
body.mkt-audience-resto.mkt-apple-page .mkt-band.mkt-band--white {
  background: transparent !important;
  border: none !important;
}

/* Proof — 2 cartes centrées */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-grid--duo {
  grid-template-columns: repeat(2, 1fr);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 680px) {
  :is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-grid--duo {
    grid-template-columns: 1fr;
    max-width: none;
  }
}

/* Badge plan (suivi Essentiel) */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .mkt-plan-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #eef4ff;
  color: #1b4fcc;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 12px;
}

/* Hero — ligne d'urgence */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .hero-urgency {
  margin-top: 10px;
  font-size: 14px;
  color: var(--text-muted, #6b7280);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .hero-urgency strong {
  color: #1a1a1a;
}

/* Coulages — en-tête lisible sur fond sombre */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .mkt-band-head .section-eyebrow {
  color: rgba(247, 245, 240, 0.72);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .mkt-band-head h2 {
  color: #f7f5f0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .mkt-band-head h2 em {
  color: #c5d4ff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .mkt-band-head .section-desc {
  color: rgba(247, 245, 240, 0.82);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .mkt-band-head .section-desc strong {
  color: #f7f5f0;
  font-weight: 600;
}

/* Coulages — stats & note sur fond sombre */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .glissement-stats {
  border-top-color: rgba(247, 245, 240, 0.12);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .glissement-stat {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.12);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .glissement-stat .num {
  color: #a8c0ff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .glissement-stat .lbl {
  color: rgba(247, 245, 240, 0.65);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .feat-section.dark .source-note {
  color: rgba(247, 245, 240, 0.45);
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .raft-dark .proof-convert {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.97) 0%, #fff 55%, #f7f5f0 100%);
}

/* CTA inline dans sections produit */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .feat-text .proof-convert-actions {
  margin-top: 24px;
}

/* Espace — duo tarifaire */
:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 40px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-card {
  padding: 28px;
  border-radius: 16px;
  height: 100%;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-card--free {
  background: #fff;
  border: 1px solid #e8e4de;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-card--paid {
  background: linear-gradient(135deg, #f8faff 0%, #eef4ff 100%);
  border: 1.5px solid #c7d9ff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 16px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-badge--free {
  background: #f0fdf4;
  color: #16a34a;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-badge--paid {
  background: #1b4fcc;
  color: #fff;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-card h3 {
  font-size: 18px;
  font-weight: 600;
  color: #1a1a1a;
  margin: 0 0 12px;
  line-height: 1.3;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-card p {
  font-size: 14px;
  color: #6b7280;
  line-height: 1.6;
  margin: 0 0 16px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-list li {
  font-size: 13px;
  color: #374151;
  line-height: 1.5;
  padding: 6px 0;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-list li i {
  color: #16a34a;
  font-size: 10px;
  margin-top: 5px;
  flex-shrink: 0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo-card--paid .esp-duo-list li i {
  color: #1b4fcc;
}

@media (max-width: 720px) {
  :is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .esp-duo {
    grid-template-columns: 1fr;
  }
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) #espace .mkt-cross-audience {
  margin: 32px auto 0;
  max-width: 640px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .feat-desc--tight {
  margin-top: 12px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .glissement-stats--feat {
  margin-top: 20px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert--center {
  margin-top: 48px;
  text-align: center;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-lead--narrow {
  max-width: 520px;
  margin: 0 auto 12px;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) .proof-convert-actions--center {
  justify-content: center;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) #espace.mkt-band {
  background: #fafaf8;
  padding: 80px 0;
}

:is(body.mkt-index-page, body.mkt-audience-resto, body.mkt-audience-consultant) #espace .proof-convert-actions {
  justify-content: center;
}

/* Resto — hero centré (desktop + mobile) */
body.mkt-audience-resto .hero-mega .hero-inner {
  flex-direction: column;
  text-align: center;
  align-items: center;
  gap: 44px;
}

body.mkt-audience-resto .hero-mega .hero-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 640px;
}

body.mkt-audience-resto .hero-mega h1,
body.mkt-audience-resto .hero-mega .hero-sub,
body.mkt-audience-resto .hero-mega .hero-product,
body.mkt-audience-resto .hero-mega .hero-source {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

body.mkt-audience-resto .hero-mega .hero-cta,
body.mkt-audience-resto .hero-mega .mkt-trust-row {
  justify-content: center;
}

body.mkt-audience-resto .hero-mega .hero-mention {
  margin-left: auto;
  margin-right: auto;
  max-width: 480px;
}

body.mkt-audience-resto .hero-mega .hero-right {
  width: min(460px, 100%);
  margin-left: auto;
  margin-right: auto;
}

/* Hero above fold — visible dès le chargement */
body.mkt-audience-resto .hero-mega .reveal {
  opacity: 1;
  transform: none;
}

/* Resto — panneaux & blocs centrés */
body.mkt-audience-resto #proof .proof-convert {
  text-align: center;
}

body.mkt-audience-resto #proof .proof-convert-actions {
  justify-content: center;
}

body.mkt-audience-resto #espace .esp-tier-head {
  justify-content: center;
  text-align: center;
}

body.mkt-audience-resto #espace .esp-tier-note {
  flex: 0 0 100%;
  text-align: center;
}

body.mkt-audience-resto .mkt-cross-audience {
  text-align: center;
}

/* Inscription inline — landing restaurateurs */
body.mkt-audience-resto .section-form.mkt-band {
  padding: 80px 0;
}

@media (min-width: 768px) {
  body.mkt-audience-resto .section-form.mkt-band {
    padding: 96px 0;
  }
}

body.mkt-audience-resto .section-form .form-inner {
  flex-direction: column;
  align-items: center;
  gap: 40px;
}

body.mkt-audience-resto .section-form .form-left {
  text-align: center;
  max-width: 560px;
}

body.mkt-audience-resto .section-form .form-right {
  width: 100%;
  max-width: 520px;
}

body.mkt-audience-resto .section-form .form-lead {
  font-size: 15px;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 440px;
  margin: 0 auto 20px;
}

body.mkt-audience-resto .section-form .form-checklist {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 14px;
  color: var(--text-muted);
  text-align: left;
  margin: 0 auto;
  max-width: 440px;
  padding: 0;
}

body.mkt-audience-resto .form-checklist i {
  color: var(--green, #16a34a);
  margin-right: 8px;
}

/* CSP — restaurateurs inline style migration */
body.mkt-audience-resto .container--920 { max-width: 920px; }
body.mkt-audience-resto .container--820 { max-width: 820px; }
body.mkt-audience-resto .container--960 { max-width: 960px; }
body.mkt-audience-resto .proof-source i { font-size: 9px; }
body.mkt-audience-resto .mkt-band-head--center { text-align: center; }
body.mkt-audience-resto .section-desc--600 { max-width: 600px; margin: 0 auto; }
body.mkt-audience-resto .glissement-stats--feat-center {
  justify-content: center;
  margin-top: 40px;
}
body.mkt-audience-resto .proof-convert-actions--spaced {
  margin-top: 48px;
  justify-content: center;
}
body.mkt-audience-resto .proof-convert-note a {
  color: inherit;
  text-decoration: underline;
}
body.mkt-audience-resto .label-hint {
  font-weight: 400;
  color: var(--text-faint, #9b9590);
}
body.mkt-audience-resto .fe-sticky-cta i { font-size: 11px; }

body.mkt-audience-resto .esp-feat-icon--blue { background: #EEF4FF; color: #1B4FCC; }
body.mkt-audience-resto .esp-feat-icon--green { background: #F0FDF4; color: #16A34A; }
body.mkt-audience-resto .esp-feat-icon--amber { background: #FEF3C7; color: #D97706; }
body.mkt-audience-resto .esp-feat-icon--purple { background: #FDF4FF; color: #9333EA; }

body.mkt-audience-resto .esp-tier { margin-top: 36px; padding: 24px; border-radius: 16px; }
body.mkt-audience-resto .esp-tier--free { background: #fff; border: 1px solid #E8E4DE; }
body.mkt-audience-resto .esp-tier--paid {
  background: linear-gradient(135deg, #F8FAFF 0%, #EEF4FF 100%);
  border: 1.5px solid #C7D9FF;
  margin-top: 28px;
}
body.mkt-audience-resto .esp-tier-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
body.mkt-audience-resto .esp-tier-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
body.mkt-audience-resto .esp-tier-label--free { color: #16A34A; }
body.mkt-audience-resto .esp-tier-label--paid { color: #1B4FCC; }
body.mkt-audience-resto .esp-tier-badge {
  font-size: 12px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 20px;
  white-space: nowrap;
}
body.mkt-audience-resto .esp-tier-badge--free { background: #F0FDF4; color: #16A34A; }
body.mkt-audience-resto .esp-tier-badge--paid { background: #1B4FCC; color: #fff; }
body.mkt-audience-resto .esp-tier-note { font-size: 12px; color: #6B7280; }
body.mkt-audience-resto .esp-tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
body.mkt-audience-resto .esp-feat-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: #fff;
  padding: 22px;
  border-radius: 14px;
  border: 1px solid #E8E4DE;
  height: 100%;
}
body.mkt-audience-resto .esp-tier--paid .esp-feat-card { border-color: #E0EAFF; }
body.mkt-audience-resto .esp-feat-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 17px;
}
body.mkt-audience-resto .esp-feat-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}
body.mkt-audience-resto .esp-feat-title strong {
  font-size: 14px;
  font-weight: 600;
  color: #1a1a1a;
  line-height: 1.35;
}
body.mkt-audience-resto .esp-feat-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 20px;
  white-space: nowrap;
  flex-shrink: 0;
}
body.mkt-audience-resto .esp-feat-tag--free { background: #F0FDF4; color: #16A34A; }
body.mkt-audience-resto .esp-feat-tag--incl { background: #EEF4FF; color: #1B4FCC; }
body.mkt-audience-resto .esp-feat-desc {
  font-size: 13px;
  color: #6B7280;
  line-height: 1.55;
  margin: 0;
  flex: 1;
}
@media (max-width: 860px) {
  body.mkt-audience-resto .esp-tier-grid { grid-template-columns: 1fr; }
}

body.mkt-audience-resto .form-grid {
  display: grid;
  gap: 0;
}

@media (min-width: 600px) {
  body.mkt-audience-resto .form-grid--2 {
    grid-template-columns: 1fr 1fr;
    gap: 0 14px;
  }
}

body.mkt-audience-resto .parrain-banner {
  margin: 0 0 20px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(27, 79, 204, 0.06);
  border: 1px solid rgba(27, 79, 204, 0.18);
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-muted);
}

body.mkt-audience-resto .parrain-banner p {
  margin: 0;
}

body.mkt-audience-resto .landing-signup textarea.input {
  resize: vertical;
  min-height: 72px;
}

body.mkt-audience-resto .landing-signup .btn-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 16px 32px;
  margin-top: 4px;
}

body.mkt-audience-resto .form-founder {
  margin-top: 12px;
  font-size: 11px;
  color: var(--text-muted);
  text-align: center;
  line-height: 1.7;
}

body.mkt-audience-resto .form-feedback {
  margin-top: 12px;
  font-size: 13px;
  text-align: center;
  padding: 10px;
  border-radius: var(--radius, 12px);
  display: none;
}

body.mkt-audience-resto .form-feedback.error {
  display: block;
  background: var(--red-bg, #fef2f2);
  color: var(--red, #dc2626);
}

body.mkt-audience-resto #resto-signup-form.is-hidden {
  display: none;
}

body.mkt-audience-resto.canvas-page .raft-dark,
body.mkt-audience-resto.canvas-page .raft-dark--solo {
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 768px) {
  body.mkt-audience-resto.canvas-page .raft-dark,
  body.mkt-audience-resto.canvas-page .raft-dark--solo {
    margin-top: 56px;
    margin-bottom: 64px;
    margin-left: auto;
    margin-right: auto;
  }

  body.mkt-audience-resto.canvas-page .raft-dark--solo {
    margin-bottom: 56px;
  }
}

body.mkt-audience-resto .raft-dark .container {
  margin-left: auto;
  margin-right: auto;
}

/* ── Resto locked teaser (sentir l'os, pas le montrer) ── */
body.mkt-audience-resto .resto-locked-wrap {
  position: relative;
}

body.mkt-audience-resto .resto-locked-grid {
  display: grid;
  gap: 12px;
  position: relative;
}

body.mkt-audience-resto .resto-locked-grid--hero {
  grid-template-columns: repeat(2, 1fr);
}

body.mkt-audience-resto .resto-locked-grid--diag {
  grid-template-columns: repeat(3, 1fr);
  margin-top: 32px;
}

body.mkt-audience-resto .resto-locked-card {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(28, 26, 20, 0.08);
  border-radius: 14px;
  padding: 18px 16px;
  filter: blur(4px);
  user-select: none;
  pointer-events: none;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

body.mkt-audience-resto .raft-dark .resto-locked-card {
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(255, 255, 255, 0.12);
}

body.mkt-audience-resto .resto-locked-card__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6b7280;
  margin-bottom: 8px;
}

body.mkt-audience-resto .resto-locked-card__val {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
  color: #1a1a1a;
  letter-spacing: -0.03em;
}

body.mkt-audience-resto .resto-locked-card__val--red { color: #dc2626; }
body.mkt-audience-resto .resto-locked-card__val--orange { color: #d97706; }
body.mkt-audience-resto .resto-locked-card__val--green { color: #16a34a; }

body.mkt-audience-resto .resto-locked-card__sub {
  font-size: 11px;
  color: #9ca3af;
  margin-top: 6px;
}

body.mkt-audience-resto .resto-locked-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 24px 20px;
  text-align: center;
  z-index: 2;
  border-radius: 16px;
}

body.mkt-audience-resto .resto-locked-overlay--hero {
  background: radial-gradient(ellipse at 50% 45%, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0.88) 65%);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

body.mkt-audience-resto .raft-dark .resto-locked-overlay--diag {
  background: radial-gradient(ellipse at 50% 40%, rgba(42, 38, 28, 0.35) 0%, rgba(22, 20, 15, 0.82) 70%);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

body.mkt-audience-resto .resto-locked-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1b4fcc;
  border-radius: 12px;
  color: #fff;
  font-size: 18px;
  box-shadow: 0 8px 24px rgba(27, 79, 204, 0.35);
}

body.mkt-audience-resto .raft-dark .resto-locked-icon {
  background: #f7f5f0;
  color: #1b4fcc;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
}

body.mkt-audience-resto .resto-locked-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #1b4fcc;
}

body.mkt-audience-resto .raft-dark .resto-locked-eyebrow {
  color: #a8c0ff;
}

body.mkt-audience-resto .resto-locked-title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  font-weight: 400;
  line-height: 1.35;
  color: #1a1a1a;
  margin: 0;
  max-width: 280px;
}

body.mkt-audience-resto .raft-dark .resto-locked-title {
  color: #f7f5f0;
  max-width: 360px;
}

body.mkt-audience-resto .resto-locked-sub {
  font-size: 13px;
  color: #6b7280;
  margin: 0;
  max-width: 300px;
  line-height: 1.5;
}

body.mkt-audience-resto .raft-dark .resto-locked-sub {
  color: rgba(247, 245, 240, 0.72);
}

body.mkt-audience-resto .resto-locked-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}

body.mkt-audience-resto .resto-locked-pill {
  font-size: 10px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(27, 79, 204, 0.08);
  color: #1b4fcc;
  border: 1px solid rgba(27, 79, 204, 0.14);
}

body.mkt-audience-resto .raft-dark .resto-locked-pill {
  background: rgba(255, 255, 255, 0.08);
  color: #dbeafe;
  border-color: rgba(255, 255, 255, 0.14);
}

body.mkt-audience-resto .resto-hero-locked {
  position: relative;
  min-height: 280px;
}

body.mkt-audience-resto .resto-diag-locked {
  position: relative;
  max-width: 640px;
  min-height: 200px;
  margin: 40px auto 0;
}

/* Promesse — cartes verrouillées (suivi) */
body.mkt-audience-resto .resto-promise-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 36px;
}

body.mkt-audience-resto .resto-promise-card {
  background: #fff;
  border: 1px solid #e8e4de;
  border-radius: 16px;
  padding: 24px 20px;
  position: relative;
  overflow: hidden;
}

body.mkt-audience-resto .resto-promise-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(250, 250, 248, 0.92) 100%);
  pointer-events: none;
}

body.mkt-audience-resto .resto-promise-lock {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: 600;
  color: #1b4fcc;
  background: #eef4ff;
  padding: 3px 9px;
  border-radius: 20px;
  margin-bottom: 12px;
}

body.mkt-audience-resto .resto-promise-card h3 {
  font-size: 15px;
  font-weight: 600;
  color: #1a1a1a;
  margin: 0 0 8px;
  line-height: 1.35;
}

body.mkt-audience-resto .resto-promise-card p {
  font-size: 13px;
  color: #6b7280;
  line-height: 1.55;
  margin: 0;
}

body.mkt-audience-resto .resto-promise-tease {
  font-size: 12px;
  color: #9ca3af;
  margin-top: 12px;
  font-style: italic;
  text-align: center;
}

body.mkt-audience-resto .resto-promise-tease a {
  color: #1b4fcc;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Parcours 3 étapes */
body.mkt-audience-resto .resto-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 36px 0 8px;
}

body.mkt-audience-resto .resto-step {
  text-align: center;
  padding: 20px 14px;
  background: #fff;
  border: 1px solid #e8e4de;
  border-radius: 14px;
}

body.mkt-audience-resto .resto-step-num {
  width: 28px;
  height: 28px;
  margin: 0 auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1b4fcc;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  border-radius: 50%;
}

body.mkt-audience-resto .resto-step strong {
  display: block;
  font-size: 13px;
  color: #1a1a1a;
  margin-bottom: 4px;
}

body.mkt-audience-resto .resto-step span {
  font-size: 12px;
  color: #6b7280;
  line-height: 1.4;
}

@media (max-width: 768px) {
  body.mkt-audience-resto .resto-locked-grid--diag,
  body.mkt-audience-resto .resto-promise-grid,
  body.mkt-audience-resto .resto-steps {
    grid-template-columns: 1fr;
  }
  body.mkt-audience-resto .resto-hero-locked { min-height: 320px; }
}
