/* ==========================================================================
   Travel Advantage — style.css
   Architecture : Variables → Reset → Layout → Header → Hero → Composants → Sections → Responsive
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Plus+Jakarta+Sans:wght@500;700;800;900&display=swap');

/* Brevo — polices migrées depuis le bloc <style> inline de index.html */
@font-face {
  font-display: block;
  font-family: Roboto;
  src: url(https://assets.brevo.com/font/Roboto/Latin/normal/normal/7529907e9eaf8ebb5220c5f9850e3811.woff2) format("woff2"),
       url(https://assets.brevo.com/font/Roboto/Latin/normal/normal/25c678feafdc175a70922a116c9be3e7.woff) format("woff");
}
@font-face {
  font-display: fallback;
  font-family: Roboto;
  font-weight: 600;
  src: url(https://assets.brevo.com/font/Roboto/Latin/medium/normal/6e9caeeafb1f3491be3e32744bc30440.woff2) format("woff2"),
       url(https://assets.brevo.com/font/Roboto/Latin/medium/normal/71501f0d8d5aa95960f6475d5487d4c2.woff) format("woff");
}
#sib-container input::placeholder { text-align: left; font-family: Helvetica, sans-serif; color: #c0ccda; }
#sib-container a { text-decoration: underline; color: #2BB2FC; }

/* ==========================================================================
   1. TOKENS / VARIABLES
   ========================================================================== */
:root {
  --blanc:       #ffffff;
  --noir:        #050b14;
  --gris-900:    #0f172a;
  --gris-600:    #475569;
  --gris-500:    #64748b;
  --gris-200:    #e2e8f0;
  --gris-100:    #f8fafc;
  --gris-50:     #f1f5f9;
  --bleu-800:    #1e40af;
  --bleu-nuit:   #0f2444;
  --bleu-600:    #2563eb;
  --bleu-100:    #dbeafe;
  --or:          #d6b15e;
  --or-clair:    #fef3c7;
  --vert:        #16a34a;
  --vert-100:    #dcfce7;
  --font-titre:  'Plus Jakarta Sans', sans-serif;
  --font-texte:  'Inter', sans-serif;
  --shadow-sm:   0 4px 6px -1px rgba(0,0,0,0.05);
  --shadow-md:   0 10px 20px -3px rgba(0,0,0,0.08);
  --shadow-lg:   0 20px 30px -5px rgba(0,0,0,0.12);
  --t-fast:      0.3s cubic-bezier(0.4,0,0.2,1);
  --radius-sm:   12px;
  --radius-md:   20px;
  --radius-lg:   24px;
  --radius-xl:   32px;
  --radius-full: 99px;
}

/* ==========================================================================
   2. RESET & BASE
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font-texte); color: var(--gris-900); background: var(--gris-100); line-height: 1.6; }
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }
ul { list-style: none; margin: 0; padding: 0; }

/* ==========================================================================
   3. TYPOGRAPHIE
   ========================================================================== */
h1,h2,h3,h4 { font-family: var(--font-titre); font-weight: 800; margin-bottom: 1rem; line-height: 1.2; }
.titre-principal  { font-size: clamp(2.5rem,5vw,4.5rem); font-weight: 900; color: var(--blanc); text-shadow: 0 4px 12px rgba(0,0,0,0.3); }
.titre-section    { font-size: clamp(2rem,4vw,2.8rem); color: var(--gris-900); }
.sous-titre       { font-size: clamp(1.1rem,2vw,1.3rem); font-weight: 600; font-family: var(--font-texte); color: var(--bleu-600); }
.texte-centre     { text-align: center; }

/* ==========================================================================
   4. LAYOUT
   ========================================================================== */
.conteneur        { width: min(1200px, calc(100% - 3rem)); margin-inline: auto; }
.conteneur-etroit { width: min(800px, calc(100% - 3rem)); margin-inline: auto; }
.padding-section  { padding: 6rem 0; }
.mb-moyen  { margin-bottom: 1.5rem; }
.mb-grand  { margin-bottom: 3rem; }
.mt-moyen  { margin-top: 1.5rem; }
.mt-espacement-large { margin-top: 2.5rem; }
.mt-espacement-xl    { margin-top: 4rem; }
.bg-blanc { background: var(--blanc); }
.bg-gris  { background: var(--gris-100); }
.bg-nuit  { background: var(--bleu-nuit); }
.bg-bleu-degrade { background: linear-gradient(135deg, var(--bleu-800) 0%, var(--bleu-nuit) 100%); }
.grille-2-colonnes       { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.grille-2-colonnes-video { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.grille-3-colonnes       { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; width: min(1200px,100%); margin-inline: auto; }

/* ==========================================================================
   5. ANIMATIONS SCROLL
   ========================================================================== */
.element-cache   { opacity: 0; transform: translateY(40px); transition: all 0.7s cubic-bezier(0.2,0.8,0.2,1); }
.element-visible { opacity: 1; transform: translateY(0); }
@keyframes fadeIn { from { opacity:0; transform:translateY(15px); } to { opacity:1; transform:translateY(0); } }

/* ==========================================================================
   6. TAGS DE SECTION
   ========================================================================== */
.section-tag,
.section-tag-clair {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border-radius: var(--radius-full);
  margin-bottom: 1.2rem;
}
.section-tag       { background: var(--bleu-100); color: var(--bleu-600); }
.section-tag-clair { background: rgba(255,255,255,0.15); color: #fff; }

/* ==========================================================================
   7. HEADER
   ========================================================================== */
.header-principal { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,1); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(0,0,0,0.06); padding: 0.75rem 0; }
.flex-header { display: flex; justify-content: space-between; align-items: center; }
.navigation-principale ul { display: flex; align-items: center; gap: 1.8rem; }
.lien-nav { font-weight: 600; color: var(--gris-600); transition: color var(--t-fast); display: flex; flex-direction: column; align-items: flex-start; gap: 0; }
.lien-nav:hover { color: var(--bleu-600); }
.nav-titre { font-size: 0.88rem; line-height: 1.2; white-space: nowrap; }
.nav-sous-titre { font-size: 0.72rem; font-weight: 500; color: var(--gris-500); line-height: 1; transition: color var(--t-fast); white-space: nowrap; }
.lien-nav:hover .nav-sous-titre { color: var(--bleu-600); }
.burger-btn { display: none; flex-direction: column; gap: 5px; padding: 8px; cursor: pointer; z-index: 200; }
.burger-btn span { display: block; width: 24px; height: 2px; background: var(--gris-900); border-radius: 2px; transition: all 0.3s ease; }
.burger-btn.is-open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.burger-btn.is-open span:nth-child(2) { opacity: 0; }
.burger-btn.is-open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }
.nav-mobile { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(255,255,255,0.98); backdrop-filter: blur(12px); z-index: 150; flex-direction: column; align-items: center; justify-content: center; gap: 1.5rem; padding: 2rem; }
.nav-mobile.is-open { display: flex; }
.nav-mobile ul { display: flex; flex-direction: column; gap: 1.2rem; text-align: center; width: 100%; }
.lien-nav-mobile { font-size: 1.3rem; font-weight: 700; color: var(--gris-900); padding: 0.5rem 0; display: block; }
.lien-nav-mobile small { display: block; font-size: 0.85rem; font-weight: 500; color: var(--gris-500); }

/* ==========================================================================
   8. BOUTONS
   ========================================================================== */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 0.9rem 1.8rem; border-radius: var(--radius-full); font-weight: 700; font-family: var(--font-titre); transition: all var(--t-fast); text-decoration: none; cursor: pointer; border: none; }
.btn-primaire { background: var(--bleu-600); color: var(--blanc); box-shadow: 0 4px 14px rgba(37,99,235,0.25); }
.btn-primaire:hover { background: var(--bleu-800); transform: translateY(-2px); box-shadow: 0 8px 25px rgba(37,99,235,0.35); }
.btn-secondaire { background: var(--blanc); color: var(--bleu-600); border: 1px solid var(--bleu-600); }
.btn-secondaire:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn-or { background: linear-gradient(135deg,#f3d792,#d6b15e); color: var(--noir); }
.btn-or:hover { transform: translateY(-2px); filter: brightness(1.05); }
.btn-plein { width: 100%; }
.btn-sm { padding: 0.6rem 1.2rem; font-size: 0.9rem; }
.btn-hero { padding: 1.1rem 2.2rem; font-size: 1.05rem; gap: 0.5rem; }
.btn-hero-ghost { padding: 1.1rem 2.2rem; font-size: 1.05rem; background: rgba(255,255,255,0.1); border: 1.5px solid rgba(255,255,255,0.4); color: #fff; border-radius: var(--radius-full); font-weight: 700; font-family: var(--font-titre); transition: all var(--t-fast); cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; }
.btn-hero-ghost:hover { background: rgba(255,255,255,0.2); }
.btn-hero-ghost-blanc { padding: 1.1rem 2.2rem; font-size: 1.05rem; background: rgba(255,255,255,0.15); border: 1.5px solid rgba(255,255,255,0.5); color: #fff; border-radius: var(--radius-full); font-weight: 700; font-family: var(--font-titre); transition: all var(--t-fast); text-decoration: none; display: inline-flex; align-items: center; justify-content: center; }
.btn-hero-ghost-blanc:hover { background: rgba(255,255,255,0.25); }
.btn-texte-lien { color: var(--gris-500); font-size: 0.9rem; text-decoration: underline; padding: 0.5rem; }
.btn-texte-lien:hover { color: var(--bleu-600); }

/* ==========================================================================
   9. HERO — Fond photo
   ========================================================================== */
.section-hero {
  position: relative;
  padding: 10rem 0 14rem;
  color: var(--blanc);
  overflow: visible; /* visible pour que les <p> des .compteur-item ne soient pas clippés (wrapper en bottom:-70px) */
  display: flex;
  align-items: center;
  min-height: 85vh;
  /* Fond photo migré depuis l'attribut style inline de index.html */
  background-image: url('/images/traveladvantage-dubai.png');
  background-size: cover;
  background-position: center;
}
.hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(180deg,rgba(5,11,20,0.72) 0%,rgba(5,11,20,0.42) 100%); z-index: 0; }
.hero-contenu { position: relative; z-index: 5; }
.section-hero p { font-size: 1.2rem; color: rgba(255,255,255,0.9); font-weight: 400; max-width: 700px; margin: 0 auto; }
.hero-badge { display: inline-block; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25); color: rgba(255,255,255,0.9); font-size: 0.85rem; font-weight: 600; padding: 0.5rem 1.2rem; border-radius: var(--radius-full); margin-bottom: 1.5rem; }
.hero-accroche { font-size: clamp(1rem,2vw,1.25rem); color: rgba(255,255,255,0.88); max-width: 640px; margin: 1rem auto 0; line-height: 1.65; }
.hero-ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 2.5rem; }
.hero-reassurance { color: rgba(255,255,255,0.6); font-size: 0.9rem; margin-top: 1.2rem; }

/* ==========================================================================
   10. STATS SUPERPOSÉES
   ========================================================================== */
.hero-stats-wrapper { position: absolute; bottom: -70px; left: 0; width: 100%; z-index: 20; padding: 0 1.5rem; }
.compteur-item { background: var(--blanc); padding: 2.5rem 1rem; border-radius: var(--radius-lg); box-shadow: 0 15px 35px rgba(0,0,0,0.18); border-top: 4px solid var(--bleu-600); transition: transform var(--t-fast); }
.compteur-item:hover { transform: translateY(-8px); box-shadow: 0 25px 50px rgba(0,0,0,0.22); }
.compteur-chiffre { font-size: clamp(1.5rem,3.5vw,2.8rem); font-weight: 900; font-family: var(--font-titre); color: var(--gris-900); line-height: 1; margin-bottom: 0.5rem; overflow-wrap: break-word; }
.compteur-item p { color: var(--gris-600); font-size: 0.95rem; margin: 0; font-weight: 500; }
#presentation { padding-top: 8rem; }
#probleme { padding-top: 5rem; }

/* ==========================================================================
   11. SECTIONS SOLUTION & TEXTE
   ========================================================================== */
.bloc-image img { border-radius: var(--radius-lg); }
.apropos-cartes { display: flex; flex-direction: column; gap: 1.5rem; margin-top: 2rem; }
.carte-info { background: var(--gris-50); padding: 2rem; border-radius: var(--radius-md); border-left: 4px solid var(--bleu-600); transition: all var(--t-fast); cursor: default; }
.carte-info:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); background: var(--blanc); }
.carte-info p { margin: 0; color: var(--gris-600); }
.carte-probleme-photo { background: var(--blanc); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--gris-200); transition: all var(--t-fast); text-align: left; }
.carte-probleme-photo:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); border-color: var(--bleu-600); }
.carte-probleme-photo .prob-img { width: 100%; height: 200px; object-fit: cover; display: block; transition: transform 0.4s ease; }
.carte-probleme-photo:hover .prob-img { transform: scale(1.04); }
.carte-probleme-photo .prob-img-wrap { overflow: hidden; position: relative; }
.carte-probleme-photo .prob-icon-badge { position: absolute; top: 1rem; left: 1rem; background: var(--blanc); border-radius: var(--radius-full); width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; box-shadow: var(--shadow-md); }
.carte-probleme-photo .prob-body { padding: 1.8rem; }
.carte-probleme-photo h3 { font-size: 1.1rem; color: var(--gris-900); margin-bottom: 0.8rem; }
.carte-probleme-photo p { color: var(--gris-600); font-size: 0.95rem; line-height: 1.65; margin: 0; }

/* ==========================================================================
   12. VIDÉOS
   ========================================================================== */
.conteneur-video { width: 100%; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); background: #000; }
.conteneur-video video, .video-embed { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; border-radius: 20px; }
.conteneur-video iframe { width: 100%; height: 100%; min-height: 300px; border: none; display: block; }
/* Wrapper iframe — migré depuis inline styles de script.js renderVideoBloc */
.video-iframe-wrapper { position: relative; aspect-ratio: 16/9; border-radius: 20px; overflow: hidden; }
.video-iframe-wrapper iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; display: block; }
/* Sous-titre section vidéo — migré depuis inline style */
.video-intro-sous-titre { max-width: 600px; margin-left: auto; margin-right: auto; }
/* Wrapper bouton CTA sous la vidéo — migré depuis inline style */
.video-intro-cta { margin-top: 2rem; }
.video-placeholder { position: relative; width: 100%; aspect-ratio: 16/9; border-radius: var(--radius-md); overflow: hidden; background: linear-gradient(135deg, var(--bleu-nuit) 0%, #1e3a5f 100%); display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: var(--shadow-lg); transition: all var(--t-fast); }
.video-placeholder:hover { transform: translateY(-4px); }
.video-ph-inner { text-align: center; color: #fff; padding: 2rem; }
.video-ph-play { width: 72px; height: 72px; background: rgba(255,255,255,0.15); border: 2px solid rgba(255,255,255,0.4); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; transition: all var(--t-fast); }
.video-placeholder:hover .video-ph-play { background: rgba(255,255,255,0.25); transform: scale(1.1); }
.video-ph-play svg { width: 28px; height: 28px; color: #fff; margin-left: 4px; }
.video-ph-badge { display: inline-block; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); color: rgba(255,255,255,0.7); font-size: 0.8rem; padding: 0.25rem 0.8rem; border-radius: var(--radius-full); margin-bottom: 0.8rem; }
.video-ph-titre { font-size: 1.1rem; font-weight: 700; color: #fff; margin-bottom: 0.5rem; font-family: var(--font-titre); }
.video-ph-desc { font-size: 0.9rem; color: rgba(255,255,255,0.65); line-height: 1.5; }
.video-ph-cta { margin-top: 1.5rem; font-size: 0.85rem; color: rgba(255,255,255,0.5); font-style: italic; }

/* ==========================================================================
   13. SIMULATEUR
   ========================================================================== */
.section-simulateur { background: linear-gradient(180deg, #fff 0%, var(--gris-50) 100%); }
.sim-wrapper { background: var(--blanc); border-radius: var(--radius-xl); padding: 4rem; box-shadow: 0 20px 60px rgba(0,0,0,0.08); max-width: 860px; margin: 0 auto; }
.sim-header { margin-bottom: 3rem; }
.sim-header h2 { margin-top: 0.5rem; }
.sim-progress { display: flex; align-items: center; justify-content: center; gap: 0; margin-bottom: 3rem; }
.sim-progress-step { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; opacity: 0.35; transition: all 0.3s ease; }
.sim-progress-step.active, .sim-progress-step.done { opacity: 1; }
.sim-step-dot { width: 40px; height: 40px; border-radius: 50%; background: var(--gris-200); color: var(--gris-600); font-weight: 800; font-family: var(--font-titre); display: flex; align-items: center; justify-content: center; font-size: 1rem; transition: all 0.3s ease; }
.sim-progress-step.active .sim-step-dot { background: var(--bleu-600); color: #fff; box-shadow: 0 4px 12px rgba(37,99,235,0.35); }
.sim-progress-step.done .sim-step-dot { background: var(--vert); color: #fff; }
.sim-progress-step span { font-size: 0.82rem; font-weight: 600; color: var(--gris-600); white-space: nowrap; }
.sim-progress-step.active span { color: var(--bleu-600); }
.sim-progress-line { flex: 1; height: 2px; background: var(--gris-200); min-width: 60px; max-width: 120px; margin-bottom: 1.5rem; transition: background 0.3s ease; }
.sim-etape { display: none; animation: fadeIn 0.4s ease; }
.sim-etape.active { display: block; }
.sim-question { font-size: clamp(1.3rem,2.5vw,1.8rem); color: var(--gris-900); margin-bottom: 0.5rem; }
.sim-sous-question { color: var(--gris-600); margin-bottom: 2rem; }
.sim-profils { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; margin-bottom: 2.5rem; }
.sim-profil-btn { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 1.5rem 1rem; border-radius: var(--radius-md); border: 2px solid var(--gris-200); background: var(--blanc); gap: 0.5rem; transition: all var(--t-fast); cursor: pointer; }
.sim-profil-btn:hover { border-color: var(--bleu-600); background: var(--bleu-100); transform: translateY(-4px); }
.sim-profil-btn.actif { border-color: var(--bleu-600); background: var(--bleu-100); box-shadow: 0 0 0 3px rgba(37,99,235,0.15); }
.sim-profil-icon { font-size: 2rem; }
.sim-profil-nom { font-weight: 700; font-size: 0.85rem; color: var(--gris-900); font-family: var(--font-titre); }
.sim-profil-desc { font-size: 0.75rem; color: var(--gris-600); }
/* Masqué par défaut — migré depuis l'attribut style="display:none" inline */
.sim-error { display: none; color: #dc2626; font-size: 0.9rem; font-weight: 600; margin-bottom: 1rem; background: #fef2f2; padding: 0.8rem 1.2rem; border-radius: 10px; border-left: 4px solid #dc2626; }
.sim-sliders { display: flex; flex-direction: column; gap: 2rem; margin-bottom: 2.5rem; }
.sim-slider-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.8rem; }
.sim-slider-label { font-weight: 600; color: var(--gris-900); }
.sim-slider-val-badge { background: var(--bleu-600); color: #fff; font-weight: 700; font-size: 0.9rem; padding: 0.3rem 0.9rem; border-radius: var(--radius-full); font-family: var(--font-titre); }
input[type="range"] { -webkit-appearance: none; width: 100%; height: 6px; border-radius: 3px; background: var(--gris-200); outline: none; cursor: pointer; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; width: 22px; height: 22px; border-radius: 50%; background: var(--bleu-600); box-shadow: 0 2px 8px rgba(37,99,235,0.35); cursor: pointer; transition: all 0.15s ease; }
input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.2); }
input[type="range"]::-moz-range-thumb { width: 22px; height: 22px; border-radius: 50%; background: var(--bleu-600); border: none; cursor: pointer; }
.sim-slider-ticks { display: flex; justify-content: space-between; margin-top: 0.4rem; }
.sim-slider-ticks span { font-size: 0.75rem; color: var(--gris-500); }
.sim-nav { display: flex; justify-content: center; margin-top: 2rem; }
.sim-nav-double { justify-content: space-between; }
.sim-btn-next { min-width: 260px; }
.sim-res-header { text-align: center; margin-bottom: 2.5rem; }
.sim-res-badge { display: inline-block; background: linear-gradient(135deg, var(--bleu-600), var(--bleu-800)); color: #fff; font-size: 0.82rem; font-weight: 700; letter-spacing: 0.05em; padding: 0.4rem 1rem; border-radius: var(--radius-full); margin-bottom: 1rem; }
.sim-res-header h3 { font-size: clamp(1.4rem,2.5vw,2rem); margin-bottom: 0.5rem; }
.sim-res-chiffres { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; margin-bottom: 2rem; }
.sim-res-item { background: var(--gris-50); border-radius: var(--radius-md); padding: 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; }
.sim-res-item--prudent { background: var(--vert-100); border-color: #86efac; }
.sim-res-item--optimiste { background: var(--bleu-100); border-color: #93c5fd; }
/* grid-column:1/-1 migré depuis inline style */
.sim-res-item--renta { background: var(--or-clair); border-color: #fcd34d; grid-column: 1 / -1; }
.sim-res-label { font-size: 0.82rem; font-weight: 600; color: var(--gris-600); text-transform: uppercase; letter-spacing: 0.04em; }
.sim-res-taux { font-weight: 400; color: var(--gris-500); }
.sim-res-val { font-size: 1.8rem; font-weight: 900; font-family: var(--font-titre); color: var(--gris-900); }
.sim-val-green { color: var(--vert); }
.sim-val-blue { color: var(--bleu-600); }
.sim-res-recommandation { text-align: center; background: var(--gris-50); border-radius: var(--radius-md); padding: 2rem; margin-bottom: 2rem; }
.sim-rec-label { font-size: 0.85rem; font-weight: 600; color: var(--gris-600); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.8rem; }
.sim-res-formule-badge { display: inline-block; font-size: 1.5rem; font-weight: 900; font-family: var(--font-titre); padding: 0.5rem 2rem; border-radius: var(--radius-full); margin: 0.5rem 0 1rem; }
.sim-rec-detail { color: var(--gris-600); font-size: 1rem; margin: 0; }
.sim-res-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-bottom: 1.5rem; }
/* Note "Accès découverte · Sans réduction · Sans CB" — migré depuis inline style */
.sim-cta-note { font-size: 0.78rem; color: var(--gris-500); text-align: center; margin-top: 0.5rem; }
.sim-res-email-bloc { background: var(--bleu-100); border-radius: var(--radius-md); padding: 1.5rem 2rem; text-align: center; margin-bottom: 1.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.sim-res-email-bloc p { margin: 0; color: var(--bleu-800); font-weight: 600; font-size: 0.95rem; }
.sim-btn-email { background: var(--bleu-600); color: #fff; border: none; padding: 0.8rem 1.6rem; border-radius: var(--radius-full); font-weight: 700; font-size: 0.95rem; font-family: var(--font-titre); cursor: pointer; transition: all var(--t-fast); white-space: nowrap; }
.sim-btn-email:hover { background: var(--bleu-800); transform: translateY(-2px); }
.sim-disclaimer { font-size: 0.8rem; color: var(--gris-500); background: var(--gris-50); border-radius: 10px; padding: 1rem 1.2rem; line-height: 1.5; border-left: 3px solid var(--gris-200); margin-bottom: 1rem; }
.sim-comparatif { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.5rem; }
.sim-comp-col { border-radius: var(--radius-md); padding: 1.5rem; border: 2px solid transparent; }
.sim-comp-col--normal { background: var(--gris-50); border-color: var(--gris-200); }
.sim-comp-col--membre { background: linear-gradient(135deg,#e0f2fe,#dbeafe); border-color: var(--bleu-600); }
.sim-comp-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--gris-500); margin-bottom: 0.5rem; }
.sim-comp-col--membre .sim-comp-label { color: var(--bleu-600); }
.sim-comp-val { font-size: 2rem; font-weight: 900; font-family: var(--font-titre); color: var(--gris-900); line-height: 1; }
.sim-comp-col--membre .sim-comp-val { color: var(--bleu-800); }
.sim-comp-sub { font-size: 0.8rem; color: var(--gris-500); margin-top: 0.4rem; }
.sim-comp-col--membre .sim-comp-sub { color: var(--bleu-600); font-weight: 600; }

/* ==========================================================================
   14. FORMULES / TARIFS
   ========================================================================== */
.grille-tarifs { display: grid; grid-template-columns: repeat(3,1fr); gap: 2.5rem; align-items: stretch; margin-top: 3rem; }
.carte-prix { background: var(--blanc); border-radius: var(--radius-xl); padding: 3rem 2rem; box-shadow: var(--shadow-md); display: flex; flex-direction: column; transition: all var(--t-fast); }
.carte-prix:hover { transform: translateY(-15px); box-shadow: var(--shadow-lg); }
.carte-elite { background: var(--noir); color: var(--blanc); transform: scale(1.05); }
.carte-elite:hover { transform: scale(1.05) translateY(-10px); }
.entete-prix { text-align: center; border-bottom: 1px solid var(--gris-50); padding-bottom: 2rem; margin-bottom: 2rem; }
.carte-elite .entete-prix { border-color: rgba(255,255,255,0.1); }
.badge-or { background: rgba(214,177,94,0.1); color: var(--or); padding: 0.4rem 1rem; border-radius: var(--radius-full); font-weight: 800; font-size: 0.9rem; display: inline-block; margin-bottom: 1rem; }
.montant-prix { font-size: 3.5rem; font-weight: 900; font-family: var(--font-titre); line-height: 1; }
.carte-elite .montant-prix { color: var(--or); }
.mois-discret { font-size: 1.1rem; font-weight: 500; color: var(--gris-500); opacity: 0.7; }
/* Texte engagement migré depuis inline style dans renderFormules() */
.carte-engagement { margin-top: 0.5rem; font-size: 0.85rem; color: var(--gris-500); }
.carte-elite .carte-engagement { color: rgba(255,255,255,0.6); }
/* Note "Sans CB · Sans engagement" migré depuis inline style */
.carte-engagement-note { text-align: center; font-size: 0.78rem; color: var(--gris-500); margin-top: 0.8rem; }
.carte-identifiant { font-size: 0.82rem; font-style: italic; color: var(--gris-600); background: var(--gris-50); border-radius: var(--radius-sm); padding: 0.6rem 0.9rem; margin-top: 0.8rem; line-height: 1.4; border-left: 3px solid var(--bleu-100); }
.carte-identifiant--elite { color: rgba(255,255,255,0.65); background: rgba(255,255,255,0.07); border-left-color: rgba(214,177,94,0.4); }
.liste-tarifs { list-style: none; padding: 0; margin: 0 0 2.5rem; flex-grow: 1; }
.liste-tarifs li { margin-bottom: 1.2rem; display: flex; align-items: flex-start; gap: 0.8rem; color: var(--gris-600); font-weight: 500; }
.carte-elite .liste-tarifs li { color: rgba(255,255,255,0.8); }
.liste-tarifs li svg { width: 24px; height: 24px; color: var(--bleu-600); flex-shrink: 0; }
.carte-elite .liste-tarifs li svg { color: var(--or); }
.liste-tarifs__special { display: block; padding: 0.65rem 0.9rem; border-radius: var(--radius-sm); font-size: 0.85rem; font-weight: 600; line-height: 1.4; margin-top: 0.5rem; margin-bottom: 0.2rem; background: var(--gris-50); color: var(--gris-600); border-left: 3px solid var(--gris-200); }
.carte-prix:not(.carte-elite) .liste-tarifs__special { background: #fff8f0; border-left-color: #f59e0b; color: #92400e; }
.liste-tarifs__special--elite { background: rgba(255,255,255,0.06); border-left-color: var(--or); color: rgba(255,255,255,0.75); font-size: 0.82rem; }
.liste-tarifs__special[data-type="warning"] { background: #fef3f2; border-left-color: #f87171; color: #991b1b; }
.encart-turbo { margin-top: 1.5rem; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 1.2rem; }
.turbo-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.8rem; margin-bottom: 0.8rem; }
.turbo-titre { font-size: 0.88rem; font-weight: 700; font-family: var(--font-titre); color: var(--or); line-height: 1.3; }
.turbo-prix { font-size: 0.88rem; font-weight: 800; font-family: var(--font-titre); color: var(--or); white-space: nowrap; text-align: right; flex-shrink: 0; }
.turbo-prix small { display: block; font-weight: 500; font-size: 0.72rem; color: rgba(255,255,255,0.45); font-family: var(--font-texte); }
.turbo-liste { list-style: none; padding: 0; margin: 0 0 0.9rem; display: flex; flex-direction: column; gap: 0.35rem; }
.turbo-liste li { font-size: 0.82rem; color: rgba(255,255,255,0.65); padding-left: 1rem; position: relative; line-height: 1.4; }
.turbo-liste li::before { content: '›'; position: absolute; left: 0; color: var(--or); font-weight: 700; }
.turbo-lien { display: inline-block; font-size: 0.8rem; font-weight: 700; color: var(--or); opacity: 0.8; text-decoration: underline; text-underline-offset: 3px; transition: opacity var(--t-fast); }
.turbo-lien:hover { opacity: 1; color: var(--or); }
.badge-guest { background: var(--gris-200); color: var(--gris-900); }
.badge-vip { background: var(--bleu-100); color: var(--bleu-800); }
.badge-elite { background: linear-gradient(135deg,#f3d792,#d6b15e); color: var(--noir); }
/* Lien MWR dans la note tarifs — migré depuis inline style */
.tarifs-note { font-size: 0.85rem; color: var(--gris-500); margin-top: 2rem; }
.tarifs-note a { color: var(--bleu-600); font-weight: 600; }

/* ==========================================================================
   15. AVANTAGES ONGLETS
   ========================================================================== */
.composant-onglets { background: var(--blanc); border-radius: var(--radius-xl); padding: 3rem; box-shadow: var(--shadow-sm); }
.onglets-navigation { display: flex; justify-content: center; flex-wrap: wrap; gap: 1rem; margin-bottom: 3rem; }
.onglet-btn { padding: 1rem 1.8rem; border-radius: var(--radius-full); background: var(--gris-50); font-weight: 700; color: var(--gris-600); transition: all var(--t-fast); }
.onglet-btn:hover { background: var(--bleu-100); color: var(--bleu-600); }
.onglet-btn.actif { background: var(--bleu-600); color: var(--blanc); box-shadow: 0 8px 20px rgba(37,99,235,0.25); }
.onglet-panneau { display: none; align-items: center; gap: 4rem; animation: fadeIn 0.4s ease forwards; }
/* tab1 visible par défaut — remplace l'attribut style="display:grid" inline */
#tab1 { display: grid; }
.onglet-panneau img { border-radius: var(--radius-md); box-shadow: var(--shadow-md); width: 100%; }
.onglet-panneau p { color: var(--gris-600); font-size: 1.05rem; margin-bottom: 1rem; }
/* Typographie onglet Application — migrée depuis inline styles */
.tab-app-ios-note { text-align: center; color: var(--gris-500); font-size: 0.82rem; margin-top: 0.8rem; }
.tab-app-layout h3 { margin-bottom: 0.5rem; }
.tab-app-desc { color: var(--gris-600); margin-bottom: 1.5rem; }

/* ==========================================================================
   16. GRILLE SERVICES + TÉMOIGNAGES SLIDER
   ========================================================================== */
.grille-services-3x3 { display: grid; grid-template-columns: repeat(3,140px); gap: 1.5rem; justify-content: center; margin-top: 1.5rem; }
.service-item { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 140px; height: 140px; background: var(--blanc); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); transition: all var(--t-fast); border: 1px solid var(--gris-50); }
.service-item:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); border-color: var(--bleu-100); }
.service-item svg { width: 42px; height: 42px; color: var(--bleu-600); margin-bottom: 1rem; transition: transform var(--t-fast); }
.service-item:hover svg { transform: scale(1.1); }
.service-item span { font-weight: 800; font-family: var(--font-titre); font-size: 0.85rem; color: var(--gris-900); text-align: center; }
.tab-app-service { cursor: pointer; }
.temoignages-slider { position: relative; overflow: hidden; }
.temoignages-track { display: flex; transition: transform 0.4s ease; }
.temoignage-card { min-width: 100%; padding: 0 0.5rem; display: none; }
.temoignage-card.active { display: block; }
.temoignage-inner { background: var(--blanc); border-radius: var(--radius-lg); padding: 2.5rem; box-shadow: var(--shadow-md); border: 1px solid var(--gris-200); text-align: center; max-width: 700px; margin: 0 auto; }
.temoignage-stars { color: #f59e0b; font-size: 1.3rem; margin-bottom: 1rem; }
.temoignage-texte { font-size: 1.1rem; color: var(--gris-600); line-height: 1.7; margin-bottom: 1.5rem; font-style: italic; }
.temoignage-auteur { font-weight: 700; color: var(--gris-900); font-family: var(--font-titre); }
.temoignage-profil { font-size: 0.85rem; color: var(--gris-500); margin-top: 0.2rem; }
.temoignage-economie { display: inline-block; background: var(--vert-100); color: var(--vert); font-weight: 700; font-size: 0.9rem; padding: 0.3rem 1rem; border-radius: var(--radius-full); margin-top: 0.8rem; }
.slider-controls { display: flex; align-items: center; justify-content: center; gap: 1.5rem; margin-top: 2rem; }
.slider-btn { width: 44px; height: 44px; border-radius: 50%; background: var(--blanc); border: 2px solid var(--gris-200); color: var(--gris-600); font-size: 1.2rem; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all var(--t-fast); }
.slider-btn:hover { border-color: var(--bleu-600); color: var(--bleu-600); transform: scale(1.05); }
.slider-dots { display: flex; gap: 0.5rem; }
.slider-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gris-200); cursor: pointer; transition: all 0.3s; }
.slider-dot.active { background: var(--bleu-600); transform: scale(1.3); }
/* Wrapper section témoignages — migré depuis inline style */
.temoignages-wrapper { margin-top: 4rem; }
/* Titre témoignages — migré depuis inline style */
.temoignages-title { font-size: clamp(1.5rem,3vw,2rem); }
/* Note disclaimer témoignages — migré depuis inline style */
.temoignages-note { text-align: center; font-size: 0.78rem; color: var(--gris-500); margin-top: 1rem; }

/* ==========================================================================
   17. EXEMPLES
   ========================================================================== */
.grille-exemples { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin: 2rem 0; }
.carte-exemple { background: var(--blanc); border-radius: var(--radius-md); padding: 2rem 1.5rem; text-align: left; transition: all var(--t-fast); box-shadow: var(--shadow-sm); position: relative; overflow: hidden; }
.carte-exemple:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--bleu-600); }
.carte-exemple--featured { border-color: var(--bleu-600); box-shadow: 0 8px 30px rgba(37,99,235,0.15); }
.exemple-badge { position: absolute; top: 1rem; right: 1rem; background: var(--bleu-600); color: #fff; font-size: 0.7rem; font-weight: 800; font-family: var(--font-titre); padding: 0.25rem 0.7rem; border-radius: var(--radius-full); letter-spacing: 0.05em; }
.exemple-icon { font-size: 2.5rem; margin-bottom: 1rem; }
.carte-exemple h3 { font-size: 1.1rem; color: var(--gris-900); margin-bottom: 0.3rem; }
.exemple-frequence { font-size: 0.82rem; color: var(--bleu-600); font-weight: 700; margin-bottom: 1rem; }
.exemple-calcul { background: var(--gris-50); border-radius: var(--radius-sm); padding: 0.8rem 1rem; margin-bottom: 1rem; }
.exemple-calcul p { font-size: 0.82rem; color: var(--gris-600); margin: 0 0 0.3rem; }
.exemple-budget-total { font-size: 0.95rem !important; color: var(--gris-900) !important; font-weight: 600; }
.exemple-economies { margin-bottom: 0.8rem; }
.exemple-economie-prudente, .exemple-economie-optimiste { font-size: 0.88rem; color: var(--gris-700, #374151); margin-bottom: 0.3rem; }
.exemple-detail { font-size: 0.78rem; color: var(--gris-500); font-style: italic; margin: 0; }
.exemples-disclaimer { font-size: 0.8rem; color: var(--gris-500); font-style: italic; margin-top: 1rem; }
/* Couleur bleue sur montants optimistes — migré depuis inline style */
.text-bleu { color: var(--bleu-600); }
/* Bouton CTA exemples — migré depuis inline style */
.exemples-cta { margin-top: 2rem; }

/* ==========================================================================
   18. PREUVES
   ========================================================================== */
.grille-preuves { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; margin-bottom: 4rem; }
.carte-preuve { background: var(--blanc); border-radius: var(--radius-md); padding: 2rem 1.5rem; box-shadow: var(--shadow-sm); transition: all var(--t-fast); }
.carte-preuve:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.preuve-icon { font-size: 2rem; margin-bottom: 1rem; }
.carte-preuve h3 { font-size: 1rem; color: var(--gris-900); margin-bottom: 0.6rem; }
.carte-preuve p { font-size: 0.88rem; color: var(--gris-600); line-height: 1.6; margin: 0; }
.video-temoignage-wrap { display: grid; grid-template-columns: 1fr 1.5fr; gap: 3rem; align-items: center; background: var(--gris-50); border-radius: var(--radius-lg); padding: 3rem; }
.video-temoignage-texte h3 { font-size: 1.5rem; margin-bottom: 0.8rem; }

/* ==========================================================================
   19. FAQ
   ========================================================================== */
.faq-container { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem; }
.faq-item { background: var(--blanc); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); overflow: hidden; }
.faq-question { width: 100%; text-align: left; padding: 1.5rem 2rem; font-size: 1.05rem; font-weight: 700; color: var(--gris-900); display: flex; justify-content: space-between; align-items: center; transition: background var(--t-fast); }
.faq-question:hover { background: var(--gris-50); color: var(--bleu-600); }
.faq-icon { width: 24px; height: 24px; transition: transform 0.3s ease; color: var(--bleu-600); flex-shrink: 0; }
.faq-question.active .faq-icon { transform: rotate(180deg); }
.faq-reponse { max-height: 0; overflow: hidden; transition: max-height 0.3s ease-out; }
.faq-reponse-inner { padding: 1rem 2rem 1.5rem; color: var(--gris-600); font-size: 1rem; border-top: 1px solid var(--gris-50); }
/* Liens dans les réponses FAQ — migré depuis inline styles */
.faq-reponse-inner a { color: var(--bleu-600); }
/* Lien "Contactez-nous" dans le sous-titre FAQ */
.faq-contact-link { color: var(--bleu-600); }

/* ==========================================================================
   20. CAPTURE EMAIL
   ========================================================================== */
.capture-ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.section-capture .capture-ctas { display: flex; flex-direction: column; align-items: center; gap: 0.8rem; }
.section-capture .capture-disclaimer { margin-top: 1rem; text-align: center; width: 100%; }
/* Titre blanc — migré depuis inline style */
.section-capture .titre-section { color: #fff; }
/* Description — migré depuis inline style */
.capture-desc { color: rgba(255,255,255,0.85); font-size: 1.1rem; max-width: 580px; margin: 1rem auto 2.5rem; }
/* Disclaimer — migré depuis inline style */
.capture-disclaimer-text { color: rgba(255,255,255,0.55); font-size: 0.82rem; margin-top: 1.5rem; max-width: 520px; margin-left: auto; margin-right: auto; }
.capture-disclaimer-text strong { color: rgba(255,255,255,0.75); }

/* ==========================================================================
   21. FOOTER
   ========================================================================== */
.footer-principal { background: var(--noir); color: #94a3b8; padding: 5rem 0 2rem; }
.grille-footer { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 4rem; margin-bottom: 3rem; }
.footer-titre { color: var(--blanc); font-size: 1.2rem; margin-bottom: 1.5rem; }
.footer-liens li { margin-bottom: 1rem; }
.footer-liens a { transition: color var(--t-fast); }
.footer-liens a:hover { color: var(--blanc); }
.footer-bottom { text-align: center; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); font-size: 0.9rem; }
.certif-badge { display: inline-block; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: #94a3b8; font-size: 0.75rem; font-weight: 700; padding: 0.3rem 0.8rem; border-radius: 6px; margin: 0.3rem 0.2rem 0 0; }
.footer-certifs { margin-top: 1rem; }
.footer-disclaimer { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07); border-radius: var(--radius-sm); padding: 1.5rem; margin-bottom: 2rem; }
.footer-disclaimer p { font-size: 0.78rem; color: #475569; line-height: 1.6; margin: 0; }
.btn-lien-footer { background: none; border: none; color: inherit; cursor: pointer; font: inherit; padding: 0; text-align: left; transition: color var(--t-fast); }
.btn-lien-footer:hover { color: var(--blanc); }
/* Styles footer — migrés depuis inline styles */
.footer-mwr-note { margin-top: 1rem; font-size: 0.85rem; color: #64748b; }
.footer-contact-email { color: #2563eb; font-weight: bold; }
.footer-contact-detail { color: #64748b; font-size: 0.9rem; }
.footer-disclaimer-p2 { margin-top: 0.5rem; }

/* ==========================================================================
   22. MODALS
   ========================================================================== */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(5px); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.modal-overlay.is-open { opacity: 1; visibility: visible; }
.modal-dialog { background: var(--blanc); width: min(600px,calc(100% - 2rem)); max-height: 90vh; border-radius: var(--radius-md); position: relative; box-shadow: 0 25px 50px rgba(0,0,0,0.25); transform: translateY(20px); transition: transform 0.3s ease; display: flex; flex-direction: column; overflow: hidden; }
.modal-overlay.is-open .modal-dialog { transform: translateY(0); }
.modal-close { position: absolute; top: 15px; right: 15px; width: 35px; height: 35px; background: var(--gris-100); border-radius: 50%; font-size: 1.5rem; color: var(--gris-900); display: flex; align-items: center; justify-content: center; transition: background 0.2s; z-index: 10; }
.modal-close:hover { background: var(--gris-200); }
.modal-content { padding: 2.5rem 2rem; text-align: center; overflow-y: auto; }
.modal-title { font-size: 1.8rem; color: var(--gris-900); margin-bottom: 0.5rem; }
.modal-desc { color: var(--gris-600); margin-bottom: 1.5rem; font-size: 1rem; }
.modal-iframe-wrap { width: 100%; min-height: 400px; border-radius: var(--radius-sm); overflow: hidden; }
.modal-iframe-wrap iframe { width: 100%; height: 420px; border: none; }
.modal-fineprint { font-size: 0.85rem; color: var(--gris-500); margin-top: 1rem; }
.modal-brevo-wrap .sib-form { background: transparent !important; }
.modal-brevo-wrap input.input { width: 100%; padding: 0.95rem 1.5rem; border: 1.5px solid var(--gris-200); border-radius: var(--radius-full); font-size: 1rem; font-family: var(--font-texte); transition: all 0.2s; background: #fff; box-sizing: border-box; }
.modal-brevo-wrap input.input:focus { outline: none; border-color: var(--bleu-600); box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12); }
.modal-brevo-wrap .entry__label { text-align: left; display: block; margin-bottom: 0.4rem; padding-left: 0.5rem; }
.modal-service-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.65); backdrop-filter: blur(6px); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.3s ease; padding: 1rem; }
.modal-service-overlay.is-open { opacity: 1; visibility: visible; }
.modal-service-dialog { background: var(--blanc); border-radius: var(--radius-xl); width: min(680px,100%); max-height: 90vh; overflow-y: auto; position: relative; box-shadow: 0 30px 60px rgba(0,0,0,0.3); transform: translateY(20px); transition: transform 0.3s ease; }
.modal-service-overlay.is-open .modal-service-dialog { transform: translateY(0); }
.modal-service-img { width: 100%; height: 220px; object-fit: cover; border-radius: var(--radius-xl) var(--radius-xl) 0 0; display: block; }
.modal-service-body { padding: 2rem; }
.modal-service-close { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; background: rgba(0,0,0,0.4); border-radius: 50%; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; cursor: pointer; transition: background 0.2s; z-index: 10; border: none; }
.modal-service-close:hover { background: rgba(0,0,0,0.6); }
.modal-service-body h3 { font-size: 1.4rem; margin-bottom: 0.5rem; }
.modal-service-body p { color: var(--gris-600); line-height: 1.7; margin-bottom: 1rem; }
.modal-service-avantages { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.modal-service-avantages li { display: flex; gap: 0.7rem; align-items: flex-start; color: var(--gris-600); font-size: 0.95rem; }
.modal-service-avantages li::before { content: "✓"; color: var(--vert); font-weight: 700; flex-shrink: 0; }
/* CTA wrapper dans les modals service — migré depuis inline style */
.modal-service-cta { text-align: center; margin-top: 1.5rem; }
#sib-container { border-radius: 12px !important; }
.sib-form-block__button { background-color: var(--bleu-600) !important; border-radius: 50px !important; padding: 0.9rem 2rem !important; font-weight: 700 !important; width: 100% !important; font-size: 1rem !important; }

/* ==========================================================================
   23. UTILITAIRES DIVERS
   ========================================================================== */
.vert { color: var(--vert); }
.liste-points { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.8rem; }
.liste-points li { display: flex; align-items: flex-start; gap: 0.8rem; color: var(--gris-600); font-size: 1rem; }
.point-check { color: var(--vert); font-weight: 700; flex-shrink: 0; }
.grille-avantages { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; margin-top: 2rem; }
.article-breadcrumb-wrap { padding: 0.8rem 0; background: transparent; }
.article-header { border-bottom: none; padding-bottom: 1.5rem; }
.article-header + .bg-gris, .article-header ~ .bg-gris:first-of-type { display: none; }
.une-image { min-height: 320px; overflow: hidden; }
.une-image img { width: 100%; height: 100%; min-height: 320px; object-fit: cover; object-position: center; display: block; }
.tab-app-layout img { border: none !important; box-shadow: none !important; outline: none !important; border-radius: var(--radius-md); }
.grille-problemes { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.sim-profils-3 { grid-template-columns: repeat(3,1fr); }
.section-probleme { padding-top: 150px !important; }
.tab-app-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.tab-app-services { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.tab-app-service { display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--gris-50); border-radius: var(--radius-md); padding: 1.2rem 0.8rem; text-align: center; transition: all var(--t-fast); cursor: pointer; }
.tab-app-service:hover { background: var(--bleu-100); border-color: var(--bleu-600); transform: translateY(-3px); }
.tab-app-service svg { width: 32px; height: 32px; color: var(--bleu-600); margin-bottom: 0.6rem; }
.tab-app-service span { font-weight: 800; font-family: var(--font-titre); font-size: 0.78rem; color: var(--gris-900); }

/* ==========================================================================
   24. RESPONSIVE — TABLETTE
   ========================================================================== */
@media (max-width: 1100px) and (min-width: 993px) {
  .navigation-principale ul { gap: 1.2rem; }
  .nav-titre { font-size: 0.82rem; }
  .nav-sous-titre { font-size: 0.68rem; }
}
@media (max-width: 992px) and (min-width: 641px) {
  .padding-section { padding: 4.5rem 0; }
}
@media (max-width: 992px) {
  .navigation-principale ul { display: none; }
  .burger-btn { display: flex; }
  .grille-2-colonnes { grid-template-columns: 1fr; gap: 3rem; }
  .grille-tarifs { grid-template-columns: 1fr; gap: 3rem; }
  .grille-footer { grid-template-columns: 1fr; gap: 3rem; }
  .grille-avantages { grid-template-columns: 1fr; }
  .grille-problemes { grid-template-columns: 1fr !important; gap: 1.5rem; }
  .grille-exemples { grid-template-columns: repeat(2,1fr); gap: 1.2rem; }
  .grille-preuves { grid-template-columns: repeat(2,1fr); gap: 1.2rem; }
  .video-temoignage-wrap { grid-template-columns: 1fr; gap: 2rem; padding: 2rem; }
  .sim-profils { grid-template-columns: repeat(2,1fr); }
  .sim-wrapper { padding: 2.5rem 2rem; }
  .sim-res-chiffres { grid-template-columns: 1fr; }
  .grille-services-3x3 { grid-template-columns: repeat(3,1fr); gap: 1rem; }
  .service-item { width: 100%; height: 120px; }
  .carte-elite { transform: none; }
  .carte-elite:hover { transform: translateY(-10px); }
  .onglet-panneau { gap: 2rem; }
  .onglet-panneau img { order: -1; }
  .hero-stats-wrapper { bottom: -40px; }
  #presentation { padding-top: 7rem; }
  .composant-onglets { padding: 2rem 1.5rem; }
  .tab-app-layout { grid-template-columns: 1fr; }
  .tab-app-layout img { max-height: 280px; object-fit: cover; }
  .tab-app-services { grid-template-columns: repeat(3,1fr); }
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
}
@media (max-width: 768px) {
  .tab-app-services { grid-template-columns: repeat(3,1fr); gap: 0.6rem; }
}

/* ==========================================================================
   25. RESPONSIVE — MOBILE
   ========================================================================== */
@media (min-width: 640px) {
  .section-capture .capture-ctas { flex-direction: row; justify-content: center; flex-wrap: wrap; }
}

@media (max-width: 640px) {
  /* ══ HERO — FIX 1 COLONNE MOBILE ══
     Problème : .section-hero utilisait display:flex (row) sans flex-direction:column.
     Sur desktop, .hero-stats-wrapper est position:absolute (hors flux flex) — OK.
     Sur mobile, il passe en position:relative et entre dans le flux flex → 2 colonnes côte à côte.
     Correction : display:block pour un empilement vertical normal. */
  .section-hero { display: block; padding: 4.5rem 0 3rem; min-height: auto; overflow: hidden; }
  .hero-stats-wrapper { position: relative; bottom: auto; padding: 0; margin-top: 1rem; }
  .hero-stats-wrapper .grille-3-colonnes { grid-template-columns: 1fr; gap: 0.8rem; width: 100%; }
  .hero-ctas { flex-direction: column; align-items: center; }
  .btn-hero { width: 100%; max-width: 320px; }
  .btn-hero-ghost { width: 100%; max-width: 320px; }

  .compteur-item { padding: 1.2rem 1rem; display: flex; align-items: center; gap: 1rem; text-align: left; border-top: 4px solid var(--bleu-600); }
  .compteur-chiffre { font-size: 1.6rem; min-width: 90px; margin-bottom: 0; }
  .compteur-item p { margin: 0; font-size: 0.9rem; }

  #presentation { padding-top: 2rem; }
  #probleme { padding-top: 3rem; }
  .section-probleme { padding-top: 80px !important; }
  .padding-section { padding: 3.5rem 0; }

  .grille-3-colonnes { grid-template-columns: 1fr; gap: 1rem; }
  .grille-exemples { grid-template-columns: 1fr; }
  .grille-preuves { grid-template-columns: 1fr; }
  .grille-problemes { grid-template-columns: 1fr !important; }
  .grille-services-3x3 { grid-template-columns: repeat(2,1fr); }
  .grille-footer { grid-template-columns: 1fr; gap: 2rem; }
  .grille-profils { grid-template-columns: 1fr; }
  .loic-raisons { grid-template-columns: 1fr; }
  .amb-etapes-grid { grid-template-columns: 1fr; }
  .amb-avantages-grid { grid-template-columns: 1fr; }
  .sim-profils-3 { grid-template-columns: 1fr; }

  .service-item { height: 110px; }
  .service-item svg { width: 32px; height: 32px; margin-bottom: 0.6rem; }

  .montant-prix { font-size: 2.5rem; }
  .turbo-header { flex-direction: column; gap: 0.3rem; }
  .turbo-prix { text-align: left; }
  .liste-tarifs__special { font-size: 0.82rem; }

  .composant-onglets { padding: 1.5rem 1rem; }
  .onglet-btn { padding: 0.7rem 1rem; font-size: 0.9rem; }
  .onglets-navigation { overflow-x: auto; flex-wrap: nowrap; justify-content: flex-start; padding-bottom: 0.5rem; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .onglets-navigation::-webkit-scrollbar { display: none; }
  .onglet-btn { white-space: nowrap; flex-shrink: 0; padding: 0.65rem 1rem; font-size: 0.82rem; }
  .onglet-panneau { grid-template-columns: 1fr !important; gap: 1.5rem; }
  .onglet-panneau img { order: -1; }

  .faq-question { font-size: 1rem; padding: 1.2rem; }
  .faq-reponse-inner { padding: 0.8rem 1.2rem 1.2rem; }

  .sim-profils { grid-template-columns: repeat(2,1fr); }
  .sim-wrapper { padding: 1.5rem 1rem; border-radius: var(--radius-md); }
  .sim-progress { gap: 0; }
  .sim-progress-line { min-width: 30px; }
  .sim-progress-step span { font-size: 0.7rem; }
  .sim-res-email-bloc { flex-direction: column; }
  .sim-nav-double { flex-direction: column-reverse; gap: 1rem; align-items: center; }

  .tab-app-services { grid-template-columns: repeat(3,1fr); gap: 0.5rem; }
  .tab-app-service { height: 80px; padding: 0.8rem 0.5rem; }
  .tab-app-service svg { width: 24px; height: 24px; margin-bottom: 0.4rem; }
  .tab-app-service span { font-size: 0.7rem; }

  .article-layout { padding: 1.5rem 0; }
  .article-cta-inline { flex-direction: column; text-align: center; }

  .carte-probleme-photo .prob-img { height: 180px; }
  .prob-body { padding: 1.2rem; }
  .prob-body h3 { font-size: 1rem; }
  .prob-body p { font-size: 0.88rem; }

  .carte-exemple { padding: 1.5rem 1.2rem; }
  .exemple-icon { font-size: 2rem; }

  .capture-ctas { flex-direction: column; align-items: center; }

  .footer-principal { padding: 2.5rem 0 1.5rem; }
  .footer-disclaimer p { font-size: 0.75rem; }

  .modal-content { padding: 1.5rem 1rem; }
  .modal-title { font-size: 1.4rem; }
  .modal-dialog { width: calc(100% - 1.5rem); max-height: 92dvh; margin: 0.75rem; }
  .modal-brevo-wrap input.input { font-size: 16px; }
  .modal-service-dialog { border-radius: var(--radius-md); max-height: 92dvh; }
  .modal-service-img { height: 160px; }
  .modal-service-body { padding: 1.5rem; }

  .carte-une { grid-template-columns: 1fr; }
  .une-image { min-height: 240px; }
  .grille-articles { grid-template-columns: 1fr; }
  .blog-sim-cta-inner { flex-direction: column; }

  .sim-comparatif { grid-template-columns: 1fr; }
  .temoignage-inner { padding: 1.5rem; }
}

@media (max-width: 480px) {
  /* Hero — padding réduit car les stats sont désormais dans le flux normal (plus position:absolute) */
  .section-hero { padding: 4rem 0 2rem; min-height: auto; }
  .titre-principal { font-size: clamp(1.75rem,7vw,2.5rem); }
  .hero-accroche { font-size: 0.95rem; padding: 0 0.5rem; }
  .hero-badge { font-size: 0.78rem; padding: 0.4rem 0.9rem; }
  .hero-reassurance { font-size: 0.82rem; }

  .sim-wrapper { padding: 1.2rem 0.9rem; border-radius: var(--radius-md); }
  .sim-question { font-size: 1.1rem; }
  .sim-profil-btn { padding: 1rem 0.6rem; }
  .sim-profil-icon { font-size: 1.5rem; }
  .sim-profil-nom { font-size: 0.8rem; }
  .sim-profil-desc { font-size: 0.7rem; }
  .sim-res-val { font-size: 1.4rem; }

  .grille-tarifs { gap: 2rem; }
  .carte-prix { padding: 2rem 1.5rem; }
  .montant-prix { font-size: 2.2rem; }

  .grille-preuves { grid-template-columns: 1fr; gap: 1rem; }
  .carte-preuve { padding: 1.5rem 1.2rem; }

  .faq-question { font-size: 0.92rem; padding: 1rem; }
  .faq-reponse-inner { padding: 0.7rem 1rem 1rem; font-size: 0.9rem; }

  .btn-hero, .btn-hero-ghost, .btn-hero-ghost-blanc { padding: 0.95rem 1.5rem; font-size: 0.95rem; max-width: 100%; width: 100%; }

  .logo img { width: 130px; }
}

@media (max-width: 380px) {
  .conteneur, .conteneur-etroit { width: calc(100% - 2rem); }
}
