/* ==========================================================================
   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');

/* ==========================================================================
   1. TOKENS / VARIABLES
   ========================================================================== */
:root {
  /* Couleurs */
  --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;

  /* Typographie */
  --font-titre:  'Plus Jakarta Sans', sans-serif;
  --font-texte:  'Inter', sans-serif;

  /* Ombres */
  --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);

  /* Transitions */
  --t-fast:      0.3s cubic-bezier(0.4,0,0.2,1);

  /* Rayons */
  --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; }

/* Espacements utilitaires */
.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; }

/* Fonds */
.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%); }

/* Grilles */
.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); }

/* ==========================================================================
   6. TAGS DE SECTION
   ========================================================================== */
.section-tag {
  display: inline-block;
  background: var(--bleu-100);
  color: var(--bleu-600);
  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-clair {
  display: inline-block;
  background: rgba(255,255,255,0.15);
  color: #fff;
  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;
}

/* ==========================================================================
   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 desktop */
.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 */
.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); }

/* Menu mobile */
.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; }

/* Boutons hero */
.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;
  display: flex;
  align-items: center;
  min-height: 85vh;
  /* background-image défini inline dans le HTML (chemin relatif) */
}
.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 badges & textes */
.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; }
/* Texte des stats — couleur explicite pour éviter l'héritage du blanc du hero */
.compteur-item p { color: var(--gris-600); font-size: 0.95rem; margin: 0; font-weight: 500; }

/* Offset pour la section suivante */
#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); }

/* ==========================================================================
   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;
}
.conteneur-video iframe {
  width: 100%; height: 100%; min-height: 300px; border: none; display: block;
}

/* Placeholder vidéo */
.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); }
.sim-error { 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-resultats {}
.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; }
.sim-res-item--renta { background: var(--or-clair); border-color: #fcd34d; }
.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; }
.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); }
.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; }
.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; }

/* ==========================================================================
   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; }
/* Phrase d'identification par profil */
.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); }
.tarifs-note { font-size: 0.85rem; color: var(--gris-500); margin-top: 2rem; }

/* ==========================================================================
   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; }
.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; }
@keyframes fadeIn { from { opacity:0; transform:translateY(15px); } to { opacity:1; transform:translateY(0); } }

/* ==========================================================================
   16. GRILLE SERVICES
   ========================================================================== */
.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; }

/* ==========================================================================
   17. EXEMPLES — 3 cartes améliorées
   ========================================================================== */
.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; }

/* ==========================================================================
   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); }

/* ==========================================================================
   20. CAPTURE EMAIL
   ========================================================================== */
.capture-ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ==========================================================================
   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; }

/* ==========================================================================
   22. MODAL
   ========================================================================== */
.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; }

/* ==========================================================================
   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; }

/* ==========================================================================
   RESPONSIVE — TABLETTE (max 992px)
   ========================================================================== */
@media (max-width: 992px) {
    .navigation-principale ul { display: none; }
    .burger-btn { display: flex; }
    .grille-2-colonnes { grid-template-columns: 1fr; gap: 3rem; }
    .grille-2-colonnes-video { grid-template-columns: 1fr; gap: 2rem; }
    .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; 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; }
}

/* ==========================================================================
   RESPONSIVE — MOBILE (max 640px)
   ========================================================================== */
@media (max-width: 640px) {
    .section-hero { padding: 6rem 0 10rem; min-height: 70vh; }
    .hero-stats-wrapper { position: relative; bottom: auto; padding: 0; margin-top: -2rem; }
    #presentation { padding-top: 2rem; }
    #probleme { padding-top: 3rem; }
    .grille-3-colonnes { grid-template-columns: 1fr; gap: 1rem; }
    .compteur-item { padding: 1.8rem 1rem; }
    .grille-services-3x3 { grid-template-columns: repeat(2,1fr); }
    .service-item { height: 110px; }
    .service-item svg { width: 32px; height: 32px; margin-bottom: 0.6rem; }
    .montant-prix { font-size: 2.5rem; }
    .faq-question { font-size: 1rem; padding: 1.2rem; }
    .faq-reponse-inner { padding: 0.8rem 1.2rem 1.2rem; }
    .composant-onglets { padding: 1.5rem 1rem; }
    .onglet-btn { padding: 0.7rem 1rem; font-size: 0.9rem; }
    .modal-content { padding: 1.5rem 1rem; }
    .modal-title { font-size: 1.4rem; }
    .grille-footer { grid-template-columns: 1fr; gap: 2rem; }
    .footer-principal { padding: 3rem 0 1.5rem; }
    .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; }
    .grille-exemples { grid-template-columns: 1fr; }
    .grille-preuves { grid-template-columns: 1fr; }
    .hero-ctas { flex-direction: column; align-items: center; }
    .btn-hero { width: 100%; max-width: 320px; }
    .btn-hero-ghost { width: 100%; max-width: 320px; }
    .sim-res-email-bloc { flex-direction: column; }
    .sim-nav-double { flex-direction: column-reverse; gap: 1rem; align-items: center; }
    .capture-ctas { flex-direction: column; align-items: center; }
}

/* ── Simulateur 3 profils ── */
.sim-profils-3 { grid-template-columns: repeat(3,1fr); }
@media (max-width:640px) { .sim-profils-3 { grid-template-columns: 1fr; } }

/* ── Espace stats → problème ── */
.section-probleme { padding-top: 150px !important; }
@media (max-width:640px) { .section-probleme { padding-top: 80px !important; } }

/* ── Modal Brevo ── */
.modal-brevo-wrap { padding: 0 0.5rem; }
.modal-brevo-wrap .sib-form { background: transparent !important; }
.modal-brevo-wrap input.input {
  width: 100%; padding: 0.8rem 1rem;
  border: 1.5px solid var(--gris-200);
  border-radius: var(--radius-sm);
  font-size: 1rem;
  font-family: var(--font-texte);
  transition: border-color 0.2s;
}
.modal-brevo-wrap input.input:focus { outline: none; border-color: var(--bleu-600); }

/* ── Cartes problème : toujours 3 colonnes (sauf mobile strict) ── */
.grille-problemes {
  display: grid;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2rem;
}
@media (max-width: 640px) {
  .grille-problemes { grid-template-columns: 1fr !important; }
}

/* ── Onglet App Mobile : layout photo + grille ── */
.tab-app-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}
.tab-app-layout img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); width: 100%; }
.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);
}
.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); }
@media (max-width: 768px) {
  .tab-app-layout { grid-template-columns: 1fr; }
  .tab-app-services { grid-template-columns: repeat(3, 1fr); gap: 0.6rem; }
}

/* ══ FIXES SESSION 4 ══ */

/* Photo app : pas de shadow ni de border-radius sur fond blanc */
.tab-app-layout img {
  box-shadow: none !important;
  border-radius: var(--radius-md);
  
}

/* Article à la une : photo pleine hauteur */
.une-image img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  object-position: center;
  display: block;
}
.une-image {
  min-height: 320px;
  overflow: hidden;
}

/* Breadcrumb article : pas de barre de fond */
.article-breadcrumb-wrap {
  padding: 0.8rem 0;
  background: transparent;
}

/* Modals services */
.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; }

/* Tab app service cards : curseur pointer */
.tab-app-service { cursor: pointer; }

/* Responsive article */
@media (max-width: 992px) {
  .tab-app-layout { grid-template-columns: 1fr; }
  .tab-app-layout img { max-height: 280px; object-fit: cover; }
}

/* ══ RESPONSIVE FINAL — corrections globales ══ */

/* Supprimer toute barre de fond au-dessus des photos d'articles */
.article-header + .bg-gris,
.article-header ~ .bg-gris:first-of-type {
  display: none;
}

/* Assurer que l'article-header et la photo se suivent sans rupture */
.article-header {
  border-bottom: none;
  padding-bottom: 1.5rem;
}

/* Nav sous-titres : pas de retour à la ligne forcé sur 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; }
}

/* Header sticky : s'assurer que le z-index est correct */
.header-principal { z-index: 200; }

/* Responsive article layout */
@media (max-width: 992px) {
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
  .tab-app-layout { grid-template-columns: 1fr; }
  .tab-app-services { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .article-layout { padding: 1.5rem 0; }
  .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-cta-inline { flex-direction: column; text-align: center; }
  .loic-raisons { grid-template-columns: 1fr; }
  .amb-etapes-grid { grid-template-columns: 1fr; }
  .amb-avantages-grid { grid-template-columns: 1fr; }
  .grille-profils { grid-template-columns: 1fr; }
}

/* Modals services responsive */
@media (max-width: 640px) {
  .modal-service-dialog { border-radius: var(--radius-md); }
  .modal-service-img { height: 160px; }
  .modal-service-body { padding: 1.5rem; }
}

/* Capture section : texte bien positionné sous les boutons */
.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%;
}
@media (min-width: 640px) {
  .section-capture .capture-ctas {
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }
}

/* Blog responsive */
@media (max-width: 640px) {
  .carte-une { grid-template-columns: 1fr; }
  .une-image { min-height: 240px; }
  .grille-articles { grid-template-columns: 1fr; }
  .blog-sim-cta-inner { flex-direction: column; }
}

/* ── Fix border image onglet App Mobile ── */
.tab-app-layout img {
  border: none !important;
  box-shadow: none !important;
}

/* Border image app mobile — suppression définitive */
.tab-app-layout > div:first-child img,
.tab-app-layout img[src*="travel-advantage-app"],
.tab-app-layout img[src*="application"] {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}
