/* ===================================================================
   EXPATMAN — Thème sur mesure (enfant Devfox)
   Design system "Institutionnel & confiance"
   Feuille maîtresse partagée par tous les gabarits.
   =================================================================== */

/* ---------- 1. TOKENS ---------- */
:root{
  --navy-900:#081628; --navy-800:#0C2038; --navy-700:#122B49;
  --navy-600:#1B3A60; --navy-500:#27507f;
  --gold:#C9A227; --gold-soft:#E3C766; --gold-bg:rgba(201,162,39,.10);
  --gold-deep:#876512;            /* or « bronze » : ≥4.5:1 sur fond clair (texte AA) + bon endpoint de dégradé */
  --ivory:#F8F6F0; --paper:#FFFFFF; --ink:#16202E; --muted:#5A6573;
  --line:#E8E3D6; --line-soft:#F0ECE1;

  /* Surfaces sémantiques (pilotent le mode sombre) */
  --surface:var(--paper);        /* fond des cartes/menus/widgets */
  --surface-alt:var(--ivory);    /* sections alternées */
  --on-surface:var(--ink);       /* texte principal */
  --on-surface-muted:var(--muted);
  --hairline:var(--line);        /* bordures fines */
  --overlay-1:rgba(255,255,255,.06);
  --skeleton-1:#ECE7DA; --skeleton-2:#F5F1E8;

  --shadow-sm:0 1px 3px rgba(8,22,40,.06);
  --shadow-md:0 10px 30px -12px rgba(8,22,40,.20);
  --shadow-lg:0 30px 60px -22px rgba(8,22,40,.32);

  --focus:0 0 0 3px rgba(201,162,39,.55), 0 0 0 5px rgba(8,22,40,.85); /* anneau de focus doré */

  --font-head:'Playfair Display', Georgia, serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --container:1180px;
  --radius:16px;
}

/* ===================== MODE SOMBRE (MANUEL via .em-dark — défaut CLAIR) =====================
   Manuel (et non prefers-color-scheme) car les pages Elementor ont des couleurs fixes
   qui deviennent illisibles en sombre automatique. L'utilisateur choisit via le bouton. */
html.em-dark{
  --paper:#0E1A2B;             /* cartes/menus en bleu nuit */
  --surface:#0E1A2B;
  --surface-alt:#0A1421;       /* sections alternées plus sombres */
  --ivory:#0A1421;
  --ink:#E8EDF4; --on-surface:#E8EDF4;
  --muted:#9DA9B8; --on-surface-muted:#9DA9B8;
  --line:#22344B; --hairline:#22344B; --line-soft:#1A2A3C;
  --gold-deep:#D9BE6E;         /* or clair lisible sur fond sombre */
  --skeleton-1:#16263a; --skeleton-2:#1d3148;
  --shadow-md:0 10px 30px -12px rgba(0,0,0,.5);
  --shadow-lg:0 30px 60px -22px rgba(0,0,0,.6);
  --focus:0 0 0 3px rgba(227,199,102,.6), 0 0 0 5px rgba(0,0,0,.85);
}

/* ---------- 2. BASE ---------- */
*{box-sizing:border-box}
.em body, body.expatman{margin:0}
.expatman{
  font-family:var(--font-body); color:var(--ink); background:var(--paper);
  line-height:1.65; -webkit-font-smoothing:antialiased; margin:0;
  overflow-x:hidden;
}
/* Garde-fous layout : neutralise tout float/largeur hérité d'un thème parent */
.expatman #em-main{display:block;width:100%;float:none;clear:both;padding:0;margin:0}
.expatman .em-hero,.expatman .em-trust,.expatman .em-section,.expatman .em-footer,.expatman .em-topbar,.expatman .em-header{width:100%;float:none;clear:both}
.expatman .em-container{width:100%}
.expatman img{max-width:100%;height:auto;display:block}
.expatman a{color:var(--navy-700);text-decoration:none;transition:color .2s}
.expatman a:hover{color:var(--gold-deep)}
.em-container{max-width:var(--container);margin:0 auto;padding:0 28px}
.em-h1,.em-h2,.em-h3,.expatman h1,.expatman h2,.expatman h3{
  font-family:var(--font-head);font-weight:700;color:var(--navy-900);
  line-height:1.15;letter-spacing:-.4px;margin:0 0 .5em;
}
.em-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:600;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:18px;
}
.em-eyebrow .l{width:34px;height:1px;background:var(--gold)}
.em-eyebrow.on-dark{color:var(--gold-soft)}
.em-lead{font-size:18px;color:var(--muted)}

/* ---------- 3. BUTTONS ---------- */
.em-btn{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:15px;
  padding:14px 28px;border-radius:9px;border:1px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.em-btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:var(--navy-900);box-shadow:0 8px 20px -8px rgba(201,162,39,.7)}
.em-btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(201,162,39,.85);color:var(--navy-900)}
.em-btn-navy{background:var(--navy-800);color:#fff}
.em-btn-navy:hover{transform:translateY(-2px);background:var(--navy-900);color:#fff}
.em-btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.em-btn-ghost:hover{border-color:var(--gold-soft);color:var(--gold-soft)}
.em-btn-outline{background:transparent;color:var(--navy-800);border-color:var(--line)}
.em-btn-outline:hover{border-color:var(--gold);color:var(--gold-deep)}

/* ---------- 4. TOPBAR ---------- */
.em-topbar{background:var(--navy-900);color:rgba(255,255,255,.72);font-size:13px}
.em-topbar .em-container{display:flex;justify-content:space-between;align-items:center;min-height:42px;flex-wrap:wrap;gap:6px}
.em-topbar a{color:rgba(255,255,255,.72)}
.em-topbar a:hover{color:var(--gold-soft)}
.em-topbar .tl span{margin-right:22px}
.em-topbar .tl i{color:var(--gold);margin-right:7px;font-style:normal}
.em-topbar .tr span{margin-left:18px}
.em-topbar .tr .lang{font-weight:600;color:#fff}

/* ---------- 5. HEADER ---------- */
.em-header{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.em-header .em-container{display:flex;align-items:center;min-height:84px;gap:36px}
.em-brand{display:flex;align-items:center;gap:13px}
.em-brand .em-logo,.em-brand .custom-logo{max-height:52px;width:auto;display:block}
.em-brand .mark{width:46px;height:46px;border-radius:10px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;box-shadow:inset 0 0 0 1px rgba(201,162,39,.35)}
.em-brand .mark svg{width:24px;height:24px}
.em-brand .name{font-family:var(--font-head);font-weight:700;font-size:23px;color:var(--navy-800);line-height:1}
.em-brand .name b{color:var(--gold-deep)}
.em-brand .tag{display:block;font-size:10px;letter-spacing:2.2px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:3px}
.em-nav{display:flex;gap:28px;margin-left:auto}
.em-nav ul{display:flex;gap:28px;list-style:none;margin:0;padding:0;align-items:center}
.em-nav li{position:relative}
.em-nav a{color:var(--navy-800);font-weight:500;font-size:15px;position:relative;padding:6px 0;display:inline-block}
.em-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--gold);transition:width .25s ease}
.em-nav a:hover,.em-nav a.active{color:var(--navy-900)}
.em-nav a:hover::after,.em-nav a.active::after{width:100%}
.em-header .em-btn{margin-left:8px}
.em-burger{display:none;margin-left:auto;width:46px;height:46px;border-radius:10px;border:1px solid var(--line);background:var(--surface);cursor:pointer}

/* ---------- 6. HERO ---------- */
.em-hero{position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(1100px 500px at 78% -10%, rgba(201,162,39,.14), transparent 60%),
             linear-gradient(160deg,var(--navy-800) 0%,var(--navy-900) 55%,#06101e 100%);}
.em-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px);background-size:100% 46px;opacity:.6;pointer-events:none}
.em-hero .em-container{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:84px 28px 92px}
.em-hero h1{font-size:clamp(34px,4.6vw,56px);color:#fff;margin-bottom:20px}
.em-hero h1 em{font-style:italic;color:var(--gold-soft)}
.em-hero p{font-size:19px;color:rgba(255,255,255,.80);max-width:560px;margin:0 0 32px}
.em-hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.em-hero-visual{position:relative}
.em-hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:30px;backdrop-filter:blur(6px)}
.em-hero-card h4{font-family:var(--font-head);color:#fff;font-size:20px;margin:0 0 18px}
.em-hero-list{list-style:none;margin:0;padding:0}
.em-hero-list li{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.88);font-size:15px}
.em-hero-list li:last-child{border-bottom:0}
.em-hero-list .chk{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--gold-bg);color:var(--gold-soft);flex:none}

/* ---------- 7. TRUST STRIP ---------- */
.em-trust{background:var(--navy-900);border-top:1px solid rgba(255,255,255,.08)}
.em-trust .em-container{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding:34px 28px}
.em-trust .item{text-align:center;flex:1;min-width:140px}
.em-trust .num{font-family:var(--font-head);font-weight:700;font-size:34px;color:#fff}
.em-trust .num b{color:var(--gold-soft)}
.em-trust .lbl{font-size:13px;color:rgba(255,255,255,.6);margin-top:4px}

/* ---------- 8. SECTIONS ---------- */
.em-section{padding:92px 0}
.em-section.alt{background:var(--ivory)}
.em-section.dark{background:linear-gradient(160deg,var(--navy-800),var(--navy-900));color:#fff}
.em-section.dark h2{color:#fff}
.em-head{text-align:center;max-width:680px;margin:0 auto 54px}
.em-head h2{font-size:clamp(28px,3.4vw,40px)}
.em-head p{font-size:17px;color:var(--muted)}
.em-section.dark .em-head p{color:rgba(255,255,255,.72)}

/* ---------- 9. SERVICE CARDS ---------- */
.em-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
/* Grille services en FLEX centré : les rangées incomplètes (ex. 5 cartes = 3+2,
   ou 4+1) sont CENTRÉES au lieu de coller à gauche → plus d'orpheline déséquilibrée.
   Largeur de carte uniforme, cartes de même hauteur par rangée. */
.em-grid-4{display:flex;flex-wrap:wrap;justify-content:center;gap:24px}
.em-grid-4 > *{flex:0 1 320px}
.em-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s ease,border-color .35s ease}
.em-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-soft));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.em-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.em-card:hover::before{transform:scaleX(1)}
.em-card .ico{width:60px;height:60px;border-radius:14px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;margin-bottom:22px;box-shadow:inset 0 0 0 1px rgba(201,162,39,.30),var(--shadow-md);transition:transform .35s ease}
.em-card .ico svg{width:28px;height:28px;stroke:var(--gold-soft)}
.em-card:hover .ico{transform:rotate(-6deg) scale(1.06)}
.em-card h3{font-size:21px;margin-bottom:10px}
.em-card p{color:var(--muted);font-size:15px;margin:0 0 20px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
/* « En savoir plus » poussé en bas → aligné sur toutes les cartes d'une rangée */
.em-card .more{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:14px;color:var(--navy-700)}
.em-card .more .arr{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--gold-bg);color:var(--gold-deep);transition:all .25s ease}
.em-card:hover .more{color:var(--gold-deep)}
.em-card:hover .more .arr{background:var(--gold);color:#fff;transform:translateX(4px)}
.em-card .num{position:absolute;top:24px;right:28px;font-family:var(--font-head);font-weight:700;font-size:44px;color:var(--navy-900);opacity:.05;line-height:1}

/* ---------- 10. PROCESS ---------- */
.em-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.em-step{position:relative;padding-top:14px}
.em-step .n{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:22px;color:var(--gold-soft);background:rgba(255,255,255,.06);border:1px solid rgba(201,162,39,.35);margin-bottom:18px}
.em-section.dark .em-step h3{color:#fff;font-size:19px}
.em-step p{color:rgba(255,255,255,.70);font-size:14.5px}

/* ---------- 10b. TEAM ---------- */
.em-team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.em-member{text-align:center}
.em-member .photo{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:3/4;background:linear-gradient(150deg,var(--navy-600),var(--navy-900));box-shadow:var(--shadow-md);margin-bottom:18px}
.em-member .photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.em-member:hover .photo img{transform:scale(1.05)}
.em-member .photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,22,40,.5),transparent 55%);pointer-events:none}
.em-member .photo .ph-initials{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:40px;color:var(--gold-soft);opacity:.85}
.em-member .photo::before{content:"";position:absolute;left:18px;right:18px;bottom:0;height:3px;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-soft));transform:scaleX(0);transform-origin:center;transition:transform .4s ease;z-index:2}
.em-member:hover .photo::before{transform:scaleX(1)}
.em-member h3{font-size:19px;margin:0 0 4px}
.em-member .role{font-size:12px;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold-deep)}

/* ---------- 11. CTA BAND ---------- */
.em-cta{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--navy-900);border-radius:22px;padding:54px 48px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;box-shadow:var(--shadow-lg)}
.em-cta h2{color:var(--navy-900);margin:0 0 8px;font-size:clamp(24px,3vw,34px)}
.em-cta p{margin:0;color:rgba(8,22,40,.78);font-size:17px}

/* ---------- 12. FOOTER ---------- */
.em-footer{background:linear-gradient(180deg,var(--navy-900),#05101d);color:rgba(255,255,255,.66)}
.em-footer .em-container{padding:70px 28px 34px}
.em-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.em-footer h5{color:#fff;font-family:var(--font-head);font-size:17px;margin:0 0 18px}
.em-footer ul{list-style:none;margin:0;padding:0}
.em-footer li{margin-bottom:11px}
.em-footer a{color:rgba(255,255,255,.66)}
.em-footer a:hover{color:var(--gold-soft)}
.em-footer .brand .name{font-family:var(--font-head);font-size:22px;color:#fff;font-weight:700}
.em-footer .brand .name b{color:var(--gold-soft)}
.em-footer .brand p{margin:14px 0 0;font-size:14.5px;max-width:300px}
.em-footer-bottom{border-top:1px solid rgba(255,255,255,.10);margin-top:46px;padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13.5px;color:rgba(255,255,255,.5)}

/* ---------- 12b. ANIMATIONS & IMMERSIF ---------- */

/* Révélation au scroll (progressive enhancement : visible si pas de JS) */
.em-js .em-reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.em-js .em-reveal.is-in{opacity:1;transform:none}
/* Filet ultime 100% CSS : si le JS ne tourne pas du tout, l'opacité revient seule
   (cible l'opacité uniquement → ne casse pas les transform de survol). */
.em-js .em-reveal:not(.em-stagger),
.em-js .em-stagger > *{animation:em-failsafe .01s linear 5s forwards}
@keyframes em-failsafe{to{opacity:1}}

/* Conteneurs à effet "cascade" : le conteneur reste visible, ses enfants entrent en décalé */
.em-js .em-stagger{opacity:1;transform:none}
.em-js .em-stagger > *{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1)}
.em-js .em-stagger.is-in > *{opacity:1;transform:none}
.em-js .em-stagger.is-in > *:nth-child(1){transition-delay:.05s}
.em-js .em-stagger.is-in > *:nth-child(2){transition-delay:.11s}
.em-js .em-stagger.is-in > *:nth-child(3){transition-delay:.17s}
.em-js .em-stagger.is-in > *:nth-child(4){transition-delay:.23s}
.em-js .em-stagger.is-in > *:nth-child(5){transition-delay:.29s}
.em-js .em-stagger.is-in > *:nth-child(6){transition-delay:.35s}
.em-js .em-stagger.is-in > *:nth-child(7){transition-delay:.41s}
.em-js .em-stagger.is-in > *:nth-child(8){transition-delay:.47s}

/* Halo vivant du hero (aurore dorée qui respire) */
.em-hero::after{
  content:"";position:absolute;top:-20%;right:-10%;width:60%;height:80%;
  background:radial-gradient(closest-side, rgba(201,162,39,.16), transparent 70%);
  filter:blur(10px);pointer-events:none;
  animation:em-aurora 12s ease-in-out infinite alternate;
}
@keyframes em-aurora{
  0%{transform:translate(0,0) scale(1);opacity:.7}
  100%{transform:translate(-6%,8%) scale(1.18);opacity:1}
}
/* Carte hero : suit légèrement la souris (JS) avec une transition douce */
.em-hero-card{transition:transform .25s cubic-bezier(.16,1,.3,1), box-shadow .3s ease;will-change:transform}

/* En-tête : ombre + compactage au défilement */
.em-header{transition:box-shadow .3s ease, background .3s ease}
.em-header.is-scrolled{box-shadow:0 10px 30px -16px rgba(8,22,40,.28)}

/* Trait d'eyebrow qui se trace */
.em-js .em-reveal.is-in .em-eyebrow .l,
.em-js .em-stagger.is-in .em-eyebrow .l{animation:em-draw .6s ease forwards}
@keyframes em-draw{from{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1)}}

/* Boutons or : balayage lumineux au survol */
.em-btn-gold{position:relative;overflow:hidden}
.em-btn-gold::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-18deg);transition:left .6s ease;
}
.em-btn-gold:hover::after{left:140%}

/* Compteurs */
.em-trust .num b{display:inline-block;min-width:1ch}

/* Respect des préférences d'accessibilité */
@media (prefers-reduced-motion: reduce){
  .em-js .em-reveal,.em-js .em-stagger > *{opacity:1!important;transform:none!important;transition:none!important}
  .em-hero::after{animation:none}
  .em-btn-gold::after{display:none}
}

/* ---------- 13. RESPONSIVE ---------- */
@media(max-width:1080px){
  .em-hero .em-container{grid-template-columns:1fr;gap:36px;padding-top:60px;padding-bottom:64px}
  .em-grid-3{grid-template-columns:repeat(2,1fr)}
  .em-grid-4{grid-template-columns:repeat(2,1fr)}
  .em-team-grid{grid-template-columns:repeat(2,1fr)}
  .em-steps{grid-template-columns:repeat(2,1fr)}
  .em-footer-grid{grid-template-columns:1fr 1fr}
  .em-nav{display:none}
  .em-nav.is-open{display:block;position:absolute;top:100%;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);padding:14px 28px;margin:0}
  .em-nav.is-open ul{flex-direction:column;align-items:flex-start;gap:4px;width:100%}
  .em-nav.is-open li{width:100%}
  .em-nav.is-open a{display:block;padding:11px 0;width:100%}
  /* sous-menus mobiles : dépliés en statique, indentés */
  .em-nav.is-open .sub-menu{position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:0;background:transparent;padding:0 0 6px 16px;max-height:none;min-width:0}
  .em-nav.is-open .sub-menu a{padding:8px 0;font-size:14px;color:var(--muted)}
  .em-nav.is-open .menu-item-has-children > a::after{opacity:.4}
  .em-burger{display:block}
}
@media(max-width:600px){
  .em-grid-3,.em-grid-4,.em-steps,.em-team-grid{grid-template-columns:1fr}
  .em-footer-grid{grid-template-columns:1fr}
  .em-cta{padding:38px 28px}
  .em-section{padding:64px 0}
}

/* ===================================================================
   14. v2 — SOUS-MENUS · CARROUSEL ÉQUIPE · FOOTER+ · HERO IMMERSIF
   =================================================================== */

/* ---- Nav : compacter + pas de retour à la ligne ---- */
.em-header .em-container{gap:22px}
.em-nav{gap:20px}
.em-nav ul{gap:20px}
.em-nav a{white-space:nowrap;font-size:14.5px}

/* ---- Sous-menus déroulants (rendu riche via walker : icône + libellé + description) ---- */
.em-nav .menu-item-has-children{position:relative}
.em-nav .em-mi-caret{display:inline-block;width:6px;height:6px;margin-left:7px;vertical-align:middle;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);opacity:.55;transition:transform .25s ease,opacity .2s ease}
.em-nav .menu-item-has-children:hover > a .em-mi-caret{transform:rotate(-135deg);opacity:.9}
.em-nav .sub-menu{
  list-style:none;margin:0;padding:10px;display:block;
  position:absolute;top:calc(100% + 16px);left:50%;
  transform:translateX(-50%) translateY(10px);
  min-width:300px;max-width:340px;max-height:74vh;overflow-y:auto;
  background:var(--surface);border:1px solid var(--hairline);border-radius:14px;
  box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;
  transition:opacity .22s ease, transform .22s ease;z-index:60;
}
.em-nav .menu-item-has-children::after{content:"";position:absolute;left:0;right:0;top:100%;height:18px} /* pont de survol */
.em-nav .menu-item-has-children:hover > .sub-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.em-nav .sub-menu li{width:100%}
.em-nav .sub-menu a{display:flex;gap:12px;align-items:flex-start;white-space:normal;padding:10px 12px;border-radius:10px;color:var(--on-surface);font-weight:500}
.em-nav .sub-menu a::after{display:none}
.em-nav .sub-menu a:hover{background:var(--gold-bg)}
.em-sub-ico{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:var(--surface-alt);color:var(--gold-deep);border:1px solid var(--hairline);transition:background .2s,color .2s,border-color .2s}
.em-sub-ico svg{width:18px;height:18px}
.em-nav .sub-menu a:hover .em-sub-ico{background:var(--navy-800);color:var(--gold-soft);border-color:transparent}
.em-sub-text{display:flex;flex-direction:column;min-width:0}
.em-sub-title{font-size:14px;font-weight:600;line-height:1.3;color:var(--on-surface)}
.em-nav .sub-menu a:hover .em-sub-title{color:var(--gold-deep)}
.em-sub-desc{font-size:12px;color:var(--on-surface-muted);margin-top:2px;line-height:1.35}
.em-nav .sub-menu .sub-menu{top:-11px;left:calc(100% + 10px);transform:translateX(10px)}
.em-nav .sub-menu .menu-item-has-children:hover > .sub-menu{transform:translateX(0)}

/* ---- Boutons : lisibilité renforcée (on bat la règle .expatman a) ---- */
.expatman a.em-btn-ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.6)}
.expatman a.em-btn-ghost:hover{background:rgba(201,162,39,.18);border-color:var(--gold-soft);color:#fff}
.expatman a.em-btn-navy{color:#fff}
.expatman a.em-btn-gold{color:var(--navy-900)}
.em-hero p{color:rgba(255,255,255,.88)}
.em-hero-list li{color:#fff}

/* ---- Carrousel équipe ---- */
.em-carousel{position:relative}
.em-carousel-track{
  display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 14px;scrollbar-width:none;-ms-overflow-style:none;
}
.em-carousel-track::-webkit-scrollbar{display:none}
.em-carousel-track > .em-member{flex:0 0 calc((100% - 72px)/4);scroll-snap-align:start;text-align:center}
.em-carousel-nav{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:30px}
.em-carousel-btn{
  width:50px;height:50px;border-radius:50%;border:1px solid var(--line);background:var(--surface);
  color:var(--navy-800);cursor:pointer;display:grid;place-items:center;font-size:20px;line-height:1;
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.em-carousel-btn:hover{background:var(--navy-800);color:#fff;border-color:var(--navy-800);transform:translateY(-2px)}
.em-carousel-btn:disabled{opacity:.35;cursor:default;transform:none;background:var(--surface);color:var(--navy-800)}
.em-carousel-count{font-size:14px;color:var(--muted);min-width:64px;text-align:center;font-weight:600}
@media(max-width:980px){.em-carousel-track > .em-member{flex:0 0 calc((100% - 24px)/2)}}
@media(max-width:600px){.em-carousel-track > .em-member{flex:0 0 86%}}

/* ---- Hero immersif : image de fond + motifs flottants ---- */
.em-hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.em-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.32;
  animation:em-kenburns 22s ease-in-out infinite alternate}
@keyframes em-kenburns{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.12) translate(-2%,-2%)}}
.em-hero.has-bg{background:
  radial-gradient(1100px 520px at 80% -10%, rgba(201,162,39,.16), transparent 60%),
  linear-gradient(120deg, var(--navy-900) 8%, rgba(8,22,40,.78) 48%, rgba(8,22,40,.55) 100%)}
.em-hero .em-container{position:relative;z-index:2}
.em-hero::after{z-index:1}
.em-motif{position:absolute;z-index:1;color:var(--gold-soft);opacity:.13;pointer-events:none}
.em-motif svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.4}
.em-motif.m1{top:14%;right:8%;width:88px;height:88px;animation:em-float 9s ease-in-out infinite}
.em-motif.m2{bottom:16%;left:4%;width:66px;height:66px;animation:em-float 11s ease-in-out infinite reverse}
.em-motif.m3{top:54%;right:38%;width:52px;height:52px;animation:em-float 13s ease-in-out infinite}
@keyframes em-float{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-16px) rotate(4deg)}}

/* ---- Footer enrichi ---- */
.em-footer{border-top:3px solid transparent;border-image:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-soft)) 1}
.em-footer-top{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  padding-bottom:40px;margin-bottom:42px;border-bottom:1px solid rgba(255,255,255,.10)}
.em-footer-top .lead{max-width:520px}
.em-footer-top .lead h4{font-family:var(--font-head);color:#fff;font-size:23px;margin:0 0 8px}
.em-footer-top .lead p{margin:0;color:rgba(255,255,255,.62);font-size:14.5px}
.em-footer-social{display:flex;gap:12px}
.em-footer-social a{width:42px;height:42px;border-radius:11px;border:1px solid rgba(255,255,255,.14);
  display:grid;place-items:center;color:rgba(255,255,255,.8);transition:all .2s ease}
.em-footer-social a:hover{background:var(--gold);color:var(--navy-900);border-color:var(--gold);transform:translateY(-2px)}
.em-footer-social svg{width:19px;height:19px;fill:currentColor}
.em-footer .locs{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.em-footer .locs span{font-size:12.5px;color:rgba(255,255,255,.7);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);border-radius:999px;padding:5px 12px}
.em-footer .hours{margin-top:16px;font-size:13.5px;color:rgba(255,255,255,.6)}
.em-footer .hours b{color:var(--gold-soft);font-weight:600}
@media(max-width:980px){.em-footer-top{flex-direction:column;align-items:flex-start}}

/* ===================================================================
   15. PAGES INTÉRIEURES — bannière, contenu, blog, single, services
   =================================================================== */

/* ---- Bannière de page ---- */
.em-pagehero{
  position:relative;overflow:hidden;color:#fff;text-align:center;
  background:
    radial-gradient(900px 420px at 80% -20%, rgba(201,162,39,.16), transparent 60%),
    linear-gradient(160deg,var(--navy-800),var(--navy-900) 60%,#06101e);
}
.em-pagehero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px);background-size:100% 46px;opacity:.5}
.em-pagehero .em-container{position:relative;padding:64px 28px}
.em-pagehero h1{font-size:clamp(28px,4vw,46px);color:#fff;margin:0 0 12px}
.em-breadcrumb{font-size:13.5px;color:rgba(255,255,255,.66);display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.em-breadcrumb a{color:rgba(255,255,255,.66)}
.em-breadcrumb a:hover{color:var(--gold-soft)}
.em-breadcrumb .sep{opacity:.5}
.em-breadcrumb .cur{color:var(--gold-soft)}
.em-pagehero-sub{color:rgba(255,255,255,.80);max-width:660px;margin:14px auto 0;font-size:17px}

/* ---- Layout contenu + sidebar ---- */
.em-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.em-layout.no-side{grid-template-columns:minmax(0,820px);justify-content:center}
.em-sidebar{position:sticky;top:104px;display:flex;flex-direction:column;gap:24px}
.em-widget{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px}
.em-widget h4{font-family:var(--font-head);font-size:18px;color:var(--navy-900);margin:0 0 14px}
.em-widget ul{list-style:none;margin:0;padding:0}
.em-widget li{margin-bottom:9px}
.em-widget a{color:var(--ink);font-size:14.5px;display:flex;gap:8px}
.em-widget a:hover{color:var(--gold-deep)}
.em-widget.cta{background:linear-gradient(150deg,var(--navy-700),var(--navy-900));color:#fff;text-align:center}
.em-widget.cta h4{color:#fff}
.em-widget.cta p{color:rgba(255,255,255,.78);font-size:14px;margin:0 0 16px}

/* ---- Prose (the_content) ---- */
.em-prose{color:var(--ink);font-size:16.5px;line-height:1.8}
.em-prose > *:first-child{margin-top:0}
.em-prose h2{font-family:var(--font-head);font-size:28px;color:var(--navy-900);margin:1.8em 0 .6em}
.em-prose h3{font-family:var(--font-head);font-size:22px;color:var(--navy-900);margin:1.5em 0 .5em}
.em-prose p{margin:0 0 1.1em}
.em-prose a{color:var(--navy-700);text-decoration:underline;text-decoration-color:rgba(201,162,39,.45);text-underline-offset:3px}
.em-prose a:hover{color:var(--gold-deep)}
.em-prose ul,.em-prose ol{margin:0 0 1.2em;padding-left:1.3em}
.em-prose li{margin-bottom:.5em}
.em-prose img{border-radius:14px;box-shadow:var(--shadow-md);margin:1em 0}
.em-prose blockquote{border-left:3px solid var(--gold);background:var(--ivory);margin:1.4em 0;padding:18px 24px;border-radius:0 12px 12px 0;font-style:italic;color:var(--navy-800)}
.em-prose h2:first-of-type{margin-top:.2em}

/* ---- Blog ---- */
.em-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.em-post-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s ease}
.em-post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.em-post-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--navy-700)}
.em-post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.em-post-card:hover .em-post-thumb img{transform:scale(1.05)}
.em-post-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.em-post-meta{font-size:12.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:10px}
.em-post-card h3{font-size:20px;line-height:1.3;margin:0 0 10px}
.em-post-card h3 a{color:var(--navy-900)}
.em-post-card h3 a:hover{color:var(--gold-deep)}
.em-post-card p{color:var(--muted);font-size:14.5px;margin:0 0 16px;flex:1}
.em-post-more{font-weight:600;font-size:14px;color:var(--navy-700);display:inline-flex;gap:8px}
.em-post-card:hover .em-post-more{color:var(--gold-deep)}

/* ---- Pagination ---- */
.em-pagination{display:flex;justify-content:center;gap:8px;margin-top:48px;flex-wrap:wrap}
.em-pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 12px;border-radius:10px;border:1px solid var(--line);color:var(--navy-800);font-weight:600;font-size:14.5px}
.em-pagination .page-numbers.current{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}
.em-pagination a.page-numbers:hover{border-color:var(--gold);color:var(--gold-deep)}

/* ---- Single (article / service) ---- */
.em-single-thumb{margin:0 0 30px;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md)}
.em-single-thumb img{width:100%;height:auto;display:block}
.em-meta-row{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:14px;margin-bottom:8px}
.em-meta-row .it{display:inline-flex;align-items:center;gap:7px}
.em-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:30px}
.em-tags a{font-size:13px;background:var(--ivory);border:1px solid var(--line);border-radius:999px;padding:6px 14px;color:var(--navy-800)}
.em-tags a:hover{border-color:var(--gold);color:var(--gold-deep)}

/* ---- Responsive pages ---- */
@media(max-width:980px){
  .em-layout{grid-template-columns:1fr;gap:36px}
  .em-sidebar{position:static}
  .em-blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .em-blog-grid{grid-template-columns:1fr}
}

/* ===================================================================
   16. ACCESSIBILITÉ, MODE SOMBRE (composants), POLISH
   =================================================================== */

/* ---- Lien d'évitement (skip-to-content) ---- */
.em-skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--navy-900);color:#fff;
  padding:12px 20px;border-radius:0 0 10px 0;font-weight:600;text-decoration:none}
.em-skip:focus{left:0}

/* ---- Focus clavier visible (WCAG 2.4.7) ---- */
.expatman a:focus-visible,
.expatman button:focus-visible,
.expatman input:focus-visible,
.expatman select:focus-visible,
.expatman textarea:focus-visible,
.expatman [tabindex]:focus-visible,
.em-carousel-track:focus-visible{
  outline:none;box-shadow:var(--focus);border-radius:6px;position:relative;z-index:3;
}
/* anneau adapté pour les éléments sur fond sombre */
.em-hero a:focus-visible,.em-section.dark a:focus-visible,.em-pagehero a:focus-visible,
.em-footer a:focus-visible,.em-topbar a:focus-visible,.em-widget.cta a:focus-visible{
  box-shadow:0 0 0 3px rgba(227,199,102,.7),0 0 0 5px rgba(255,255,255,.5);
}

/* ---- Micro-interaction :active (retour <100ms) ---- */
.em-btn:active{transform:translateY(0) scale(.98)}
.em-carousel-btn:active{transform:scale(.94)}
.em-card:active{transform:translateY(-4px)}

/* ---- Carrousel : indicateur + zone focusable ---- */
.em-carousel-track{outline:none}
.em-carousel-count{font-size:14px;color:var(--on-surface-muted);min-width:74px;text-align:center;font-weight:600;font-variant-numeric:tabular-nums}

/* ---- Skeleton de chargement des images (performance perçue) ----
   NB : pas sur les photos de membres (elles ont déjà un fond marine + initiales). */
.em-post-thumb,.em-single-thumb{position:relative;background:var(--skeleton-1)}
.em-post-thumb::after,.em-single-thumb::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg,var(--skeleton-1) 25%,var(--skeleton-2) 50%,var(--skeleton-1) 75%);
  background-size:600px 100%;animation:em-shimmer 1.6s linear infinite}
.em-post-thumb img,.em-single-thumb img{position:relative;z-index:1}
.em-member .photo .ph-initials{z-index:2}
@keyframes em-shimmer{0%{background-position:-300px 0}100%{background-position:300px 0}}

/* ---- Barre de progression de lecture ---- */
.em-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;
  background:linear-gradient(90deg,var(--gold-soft),var(--gold));transition:width .1s linear}

/* ---- Cibles tactiles ≥44px (menu mobile) ---- */
@media(max-width:1080px){
  .em-nav.is-open a{min-height:44px;display:flex;align-items:center}
  .em-nav.is-open .sub-menu a{min-height:40px}
}

/* ---- Mode sombre : couleurs de composants (les surfaces flippent déjà via tokens) ---- */
.em-dark .expatman h1,.em-dark .expatman h2,.em-dark .expatman h3,
.em-dark .em-head h2,.em-dark .em-card h3,.em-dark .em-member h3,.em-dark .em-widget h4,
.em-dark .em-post-card h3 a,.em-dark .em-prose h2,.em-dark .em-prose h3{color:var(--on-surface)}
.em-dark .em-nav > ul > li > a,.em-dark .em-brand .name{color:var(--on-surface)}
.em-dark .em-brand .name b{color:var(--gold-deep)}
.em-dark .em-card .more,.em-dark .em-post-more{color:var(--gold-deep)}
.em-dark .em-pagination .page-numbers{color:var(--on-surface)}
.em-dark .em-prose a,.em-dark .em-tags a,.em-dark .em-widget a{color:var(--on-surface)}
.em-dark .em-prose a:hover,.em-dark .em-widget a:hover{color:var(--gold-deep)}
/* sous-menus en mode sombre : liens clairs, survol doré (corrige l'invisibilité) */
.em-dark .em-nav .sub-menu a{color:var(--on-surface)}
.em-dark .em-nav .sub-menu a:hover{color:var(--gold-deep);background:var(--gold-bg)}
.em-dark .em-card{box-shadow:var(--shadow-sm)}
.em-dark .em-burger{color:var(--on-surface)}
/* logo (version claire = sombre) éclairci pour rester visible sur en-tête sombre */
.em-dark .em-brand .em-logo,.em-dark .em-brand .custom-logo img{filter:brightness(0) invert(1)}

/* Transition douce lors de la bascule clair/sombre */
.expatman,.em-header,.em-card,.em-section,.em-footer,.em-nav .sub-menu,.em-widget,.em-post-card{
  transition:background-color .35s ease, color .35s ease, border-color .35s ease;
}

/* ===================================================================
   17. REDUCED-MOTION — couverture complète (WCAG 2.3.3)
   =================================================================== */
@media (prefers-reduced-motion: reduce){
  .em-js .em-reveal,.em-js .em-stagger > *{opacity:1 !important;transform:none !important;transition:none !important}
  .em-hero::after,.em-motif,.em-hero-bg img{animation:none !important}
  .em-post-thumb::after,.em-member .photo::after{animation:none !important}
  .em-btn-gold::after{display:none}
  .em-carousel-track{scroll-behavior:auto}
  .em-progress{transition:none}
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}

/* ---- État vide (avec CTA) ---- */
.em-empty{text-align:center;padding:64px 20px;max-width:480px;margin:0 auto}
.em-empty-ico{font-size:54px;line-height:1;margin-bottom:14px;opacity:.45}
.em-empty p{color:var(--on-surface-muted);font-size:17px;margin:0 0 22px}

/* ---- Palier intermédiaire : compacter l'en-tête (évite que le CTA déborde) ---- */
@media (max-width:1400px) and (min-width:1081px){
  .em-header .em-container{gap:14px}
  .em-nav,.em-nav ul{gap:13px}
  .em-nav a{font-size:13.5px}
  .em-brand .tag{display:none}
  .em-header .em-btn{padding:11px 16px;font-size:13.5px}
  .em-theme-toggle{width:38px;height:38px}
}

/* ===================================================================
   18. TOGGLE THÈME · LANGUES · ANIMATIONS PAGES INTÉRIEURES
   =================================================================== */

/* ---- Sélecteur de langue (WPML) dans la topbar ---- */
.em-lang{display:inline-flex;gap:6px;align-items:center;margin-left:18px}
.em-lang a{color:rgba(255,255,255,.6);font-weight:600;font-size:12.5px;padding:2px 6px;border-radius:6px;text-transform:uppercase}
.em-lang a:hover{color:var(--gold-soft)}
.em-lang a.active{color:#fff;background:rgba(255,255,255,.12)}

/* ---- Bouton bascule clair/sombre ---- */
.em-theme-toggle{
  width:42px;height:42px;border-radius:11px;border:1px solid var(--hairline);
  background:var(--surface);color:var(--on-surface);cursor:pointer;display:grid;place-items:center;
  margin-left:6px;flex:none;transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.em-theme-toggle:hover{transform:translateY(-2px);border-color:var(--gold);color:var(--gold-deep)}
.em-theme-toggle svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.em-theme-toggle .ic-moon{display:block}
.em-theme-toggle .ic-sun{display:none}
.em-dark .em-theme-toggle .ic-moon{display:none}
.em-dark .em-theme-toggle .ic-sun{display:block}

/* ---- Reveal directionnels (inspiration e-businessafrika) ---- */
.em-js .em-reveal-left{opacity:0;transform:translateX(-36px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.em-js .em-reveal-right{opacity:0;transform:translateX(36px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.em-js .em-reveal-left.is-in,.em-js .em-reveal-right.is-in{opacity:1;transform:none}

/* ---- Fade pour sections Elementor / contenus tiers (opacité seule, sans transform : ne casse pas leurs layouts) ---- */
.em-js .em-fade{opacity:0;transition:opacity .9s ease}
.em-js .em-fade.is-in{opacity:1}
.em-js .em-fade{animation:em-failsafe .01s linear 5s forwards}

/* ---- Couvre les nouveaux reveals en reduced-motion ---- */
@media (prefers-reduced-motion: reduce){
  .em-js .em-reveal-left,.em-js .em-reveal-right,.em-js .em-fade{opacity:1 !important;transform:none !important;transition:none !important}
}

/* ===================================================================
   19. COMPOSANTS PAGES BESPOKE (À propos, etc.)
   =================================================================== */
.em-prose-wide{max-width:820px;margin:0 auto}
.em-cols-2{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}

/* Liste à puces dorées */
.em-checklist{list-style:none;margin:0;padding:0;display:grid;gap:13px}
.em-checklist li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--on-surface);line-height:1.6}
.em-checklist .ck{flex:none;width:25px;height:25px;border-radius:50%;background:var(--gold-bg);color:var(--gold-deep);display:grid;place-items:center;font-weight:700;font-size:13px;margin-top:2px}
.em-checklist li b{color:var(--on-surface)}

/* Carte panneau (interfaces, encarts) */
.em-panel{background:var(--surface);border:1px solid var(--hairline);border-radius:18px;padding:32px 30px}
.em-panel.dark{background:linear-gradient(150deg,var(--navy-700),var(--navy-900));border-color:transparent;color:#fff}
.em-panel.dark h3,.em-panel.dark .em-checklist li{color:#fff}
.em-panel h3{font-size:21px;margin:0 0 16px}
.em-panel .tagline{font-size:12.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-deep);margin-bottom:10px}
.em-panel.dark .tagline{color:var(--gold-soft)}

/* Témoignages */
.em-quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.em-quote{background:var(--surface);border:1px solid var(--hairline);border-radius:16px;padding:32px 28px 26px;position:relative;transition:transform .35s ease,box-shadow .35s ease}
.em-quote:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.em-quote .qm{font-family:var(--font-head);font-size:60px;line-height:.6;color:var(--gold);opacity:.45;display:block;height:26px}
.em-quote p{color:var(--on-surface);font-size:15px;font-style:italic;margin:0 0 20px}
.em-quote .who b{display:block;font-family:var(--font-head);color:var(--on-surface);font-size:16px}
.em-quote .who span{font-size:12.5px;color:var(--gold-deep);font-weight:600}

/* Partenaires */
.em-partners{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center}
.em-partners .p{padding:14px 26px;border:1px solid var(--hairline);border-radius:12px;background:var(--surface);font-weight:700;color:var(--on-surface-muted);font-size:15px;transition:border-color .2s,color .2s}
.em-partners .p:hover{border-color:var(--gold);color:var(--gold-deep)}

@media(max-width:820px){.em-cols-2{grid-template-columns:1fr}.em-quote-grid{grid-template-columns:1fr}}

/* ===================================================================
   20. PAGE CONTACT + FORMULAIRES CF7 (UX premium)
   =================================================================== */
.em-contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:40px;align-items:start}
.em-contact-info{display:grid;gap:14px}
.em-cinfo{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--hairline);border-radius:14px;padding:18px 20px;transition:transform .25s ease,box-shadow .25s ease}
.em-cinfo:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.em-cinfo .ic{flex:none;width:44px;height:44px;border-radius:11px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));display:grid;place-items:center;color:var(--gold-soft);box-shadow:inset 0 0 0 1px rgba(201,162,39,.3)}
.em-cinfo .ic svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.em-cinfo .t{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--on-surface-muted);font-weight:600;margin-bottom:4px}
.em-cinfo .v{font-size:15.5px;color:var(--on-surface);font-weight:500;line-height:1.5}
.em-cinfo .v a{color:var(--on-surface)}
.em-cinfo .v a:hover{color:var(--gold-deep)}

.em-form-panel{background:var(--surface);border:1px solid var(--hairline);border-radius:18px;padding:34px 32px;box-shadow:var(--shadow-md)}
.em-form-panel h3{font-size:22px;margin:0 0 6px}
.em-form-panel .sub{color:var(--on-surface-muted);font-size:15px;margin:0 0 22px}

/* Contrôles CF7 (et formulaires natifs) — labels au-dessus, 16px anti-zoom iOS, focus doré */
.em-form-panel .wpcf7-form p,.em-form-panel form p{margin:0 0 16px}
.em-form-panel label{display:block;font-weight:600;font-size:14px;color:var(--on-surface);margin-bottom:7px}
.em-form-panel input[type=text],.em-form-panel input[type=email],.em-form-panel input[type=tel],
.em-form-panel input[type=url],.em-form-panel input[type=number],.em-form-panel input[type=date],
.em-form-panel select,.em-form-panel textarea{
  width:100%;font-family:inherit;font-size:16px;color:var(--on-surface);background:var(--surface-alt);
  border:1px solid var(--hairline);border-radius:10px;padding:12px 14px;transition:border-color .2s,box-shadow .2s}
.em-form-panel textarea{min-height:130px;resize:vertical}
.em-form-panel input:focus,.em-form-panel select:focus,.em-form-panel textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-bg)}
.em-form-panel .wpcf7-submit,.em-form-panel button[type=submit]{
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:var(--navy-900);border:0;width:auto;
  font-family:inherit;font-weight:600;font-size:15px;padding:14px 30px;border-radius:9px;cursor:pointer;
  box-shadow:0 8px 20px -8px rgba(201,162,39,.7);transition:transform .2s,box-shadow .2s}
.em-form-panel .wpcf7-submit:hover,.em-form-panel button[type=submit]:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(201,162,39,.85)}
.em-form-panel .wpcf7-not-valid-tip{color:#d33;font-size:13px;margin-top:5px;font-weight:500}
.em-form-panel .wpcf7-spinner{margin:0 0 0 10px}
.wpcf7-response-output{border-radius:10px;padding:12px 16px;margin:14px 0 0!important;font-size:14px}
.wpcf7 form.invalid .wpcf7-response-output,.wpcf7 form.unaccepted .wpcf7-response-output{border:1px solid #e7b3b3;background:#fdeaea;color:#a33}
.wpcf7 form.sent .wpcf7-response-output{border:1px solid #b7e0c0;background:#eafaf0;color:#207d4a}
.em-dark .wpcf7 form.invalid .wpcf7-response-output{background:rgba(200,60,60,.12)}
.em-dark .wpcf7 form.sent .wpcf7-response-output{background:rgba(60,170,110,.12)}

@media(max-width:860px){.em-contact-grid{grid-template-columns:1fr}}

/* ===================================================================
   21. WHATSAPP (canal direct — ligne, bouton, séparateur, flottant)
   =================================================================== */
:root{--wa:#25d366;--wa-deep:#128c7e}

/* Tuile icône WhatsApp dans les coordonnées : vert de marque + glyphe plein */
.em-cinfo .ic.ic-wa{background:linear-gradient(150deg,var(--wa),var(--wa-deep));color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}
.em-cinfo .ic.ic-wa svg{fill:currentColor;stroke:none;width:21px;height:21px}
.em-wa-inline{font-weight:600;color:var(--wa-deep)!important}
.em-dark .em-wa-inline{color:#3ddc7f!important}
.em-wa-inline:hover{text-decoration:underline}

/* Bouton « Discuter sur WhatsApp » */
.em-btn-wa{background:linear-gradient(135deg,var(--wa),var(--wa-deep));color:#fff;box-shadow:0 8px 20px -8px rgba(18,140,126,.7)}
.em-btn-wa:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(18,140,126,.85);color:#fff}
.expatman a.em-btn-wa{color:#fff}
.em-btn-wa svg{width:20px;height:20px;fill:currentColor;vertical-align:-4px;margin-right:8px}
.em-wa-cta{display:inline-flex;align-items:center;justify-content:center;width:100%;margin-bottom:18px}

/* Séparateur « ou écrivez-nous » */
.em-or{display:flex;align-items:center;gap:14px;color:var(--on-surface-muted);font-size:13px;text-transform:uppercase;letter-spacing:1px;margin:0 0 18px}
.em-or::before,.em-or::after{content:"";flex:1;height:1px;background:var(--hairline)}

/* Icône WhatsApp dans le footer social */
.em-footer-social .is-wa svg{fill:currentColor;stroke:none}

/* Bouton flottant site-wide */
.em-wa-float{position:fixed;right:20px;bottom:20px;z-index:9990;display:inline-flex;align-items:center;
  width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--wa),var(--wa-deep));
  color:#fff;box-shadow:0 12px 30px -8px rgba(18,140,126,.85);overflow:hidden;
  transition:width .3s cubic-bezier(.4,0,.2,1),box-shadow .3s,transform .2s;text-decoration:none}
.em-wa-float svg{flex:none;width:30px;height:30px;fill:currentColor;margin:0 14px}
.em-wa-float-tip{white-space:nowrap;font-weight:600;font-size:14.5px;opacity:0;transition:opacity .2s ease .05s;padding-right:4px}
.em-wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(37,211,102,.55);animation:emWaPulse 2.4s ease-out infinite}
.em-wa-float:hover{width:auto;transform:translateY(-2px);color:#fff;box-shadow:0 16px 34px -8px rgba(18,140,126,.95)}
.em-wa-float:hover .em-wa-float-tip{opacity:1}
.em-wa-float:hover::after{animation:none}
.em-wa-float:focus-visible{outline:3px solid #fff;outline-offset:3px}
@keyframes emWaPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@media(max-width:600px){.em-wa-float{right:16px;bottom:16px;width:54px;height:54px}.em-wa-float:hover{width:54px}.em-wa-float:hover .em-wa-float-tip{display:none}}
@media(prefers-reduced-motion:reduce){.em-wa-float::after{animation:none}.em-wa-float,.em-wa-float:hover{transition:none}}

/* ===================================================================
   22. PAGE COMPTES BANCAIRES (cartes + copie en un clic)
   =================================================================== */
/* Encart d'avertissement */
.em-callout{display:flex;gap:16px;align-items:flex-start;max-width:920px;margin:0 auto 40px;
  background:var(--gold-bg);border:1px solid rgba(201,162,39,.35);border-radius:14px;padding:18px 22px}
.em-callout .ic{flex:none;width:38px;height:38px;border-radius:10px;background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  display:grid;place-items:center;color:var(--navy-900)}
.em-callout .ic svg{width:20px;height:20px}
.em-callout p{margin:0;font-size:15px;color:var(--on-surface);line-height:1.6}
.em-dark .em-callout{background:rgba(201,162,39,.08)}

/* Grille des comptes */
.em-bank-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:26px}
.em-bank{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--hairline);
  border-radius:18px;padding:26px 26px 22px;box-shadow:var(--shadow-md);
  transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s,border-color .35s}
.em-bank:hover{transform:translateY(-4px);border-color:rgba(201,162,39,.4)}

.em-bank-head{display:flex;align-items:flex-start;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--hairline)}
.em-bank-flag{font-size:26px;line-height:1.1}
.em-bank-id{flex:1;min-width:0}
.em-bank-region{display:block;font-size:11.5px;text-transform:uppercase;letter-spacing:1px;color:var(--on-surface-muted);font-weight:600;margin-bottom:3px}
.em-bank-id h3{font-size:18.5px;margin:0;line-height:1.25}
.em-bank-cur{flex:none;align-self:flex-start;font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--gold-deep);
  background:var(--gold-bg);border:1px solid rgba(201,162,39,.35);border-radius:999px;padding:4px 11px}
.em-dark .em-bank-cur{color:var(--gold-soft)}

.em-bank-addr{display:flex;gap:8px;align-items:flex-start;margin:14px 0 6px;font-size:13.5px;color:var(--on-surface-muted);line-height:1.5}
.em-bank-addr svg{flex:none;width:16px;height:16px;margin-top:1px}

/* Lignes clé/valeur */
.em-bank-rows{margin:8px 0 0}
.em-bank-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px dashed var(--hairline)}
.em-bank-row dt{font-size:12.5px;color:var(--on-surface-muted);font-weight:600;flex:none}
.em-bank-row dd{margin:0;display:flex;align-items:center;gap:8px;min-width:0}
.em-bank-row .val{font-family:ui-monospace,"SF Mono",Menlo,Consolas,monospace;font-size:14.5px;font-weight:600;
  color:var(--on-surface);letter-spacing:.3px;word-break:break-all;text-align:right}

/* Bouton copier */
.em-copy{position:relative;flex:none;display:inline-grid;place-items:center;width:30px;height:30px;border-radius:8px;
  border:1px solid var(--hairline);background:var(--surface-alt);color:var(--on-surface-muted);cursor:pointer;
  transition:color .2s,border-color .2s,background .2s,transform .15s}
.em-copy svg{width:15px;height:15px}
.em-copy:hover{color:var(--gold-deep);border-color:var(--gold);background:var(--gold-bg)}
.em-dark .em-copy:hover{color:var(--gold-soft)}
.em-copy:active{transform:scale(.92)}
.em-copy:focus-visible{outline:none;box-shadow:var(--focus)}
.em-copy-done{position:absolute;bottom:calc(100% + 6px);right:0;background:var(--navy-900);color:#fff;font-size:11px;
  font-weight:600;padding:3px 8px;border-radius:6px;white-space:nowrap;opacity:0;transform:translateY(4px);
  pointer-events:none;transition:opacity .2s,transform .2s}
.em-copy.is-copied{color:#1e9e54;border-color:#1e9e54}
.em-copy.is-copied .em-copy-done{opacity:1;transform:translateY(0)}

/* Méta (usage / délai / frais) */
.em-bank-meta{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:9px}
.em-bank-meta li{display:flex;gap:10px;align-items:baseline;font-size:13.5px;color:var(--on-surface);line-height:1.45}
.em-bank-meta li span{flex:none;width:54px;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--on-surface-muted);font-weight:700}

.em-bank-warn{margin:16px 0 0;font-size:12.5px;line-height:1.5;color:var(--on-surface-muted);
  background:var(--surface-alt);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;padding:9px 12px}

@media(max-width:560px){
  .em-bank-row{flex-direction:column;align-items:flex-start;gap:5px}
  .em-bank-row .val{text-align:left}
  .em-bank-row dd{width:100%;justify-content:space-between}
}

/* ===================================================================
   23. PAGE DIPLOMATIE (annuaire — TablePress + DataTables 1.x ET 2.x)
   NB : TablePress force background:#fff sur les <td> → en mode sombre le
   texte clair devenait illisible. On force donc le fond des cellules en
   transparent et on gère le striping au niveau <td> (!important).
   TablePress 2.x = DataTables 2.x → classes .dt-* (en plus des .dataTables_*).
   =================================================================== */
.em-table-wrap{background:var(--surface);border:1px solid var(--hairline);border-radius:14px;box-shadow:var(--shadow-md);overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ---- Contrôles haut : « Afficher N éléments » + « Rechercher: » ---- */
.expatman .em-table-wrap .dataTables_length,
.expatman .em-table-wrap .dataTables_filter,
.expatman .em-table-wrap .dt-length,
.expatman .em-table-wrap .dt-search{padding:16px 18px;font-size:14px;color:var(--on-surface);font-weight:500}
.expatman .em-table-wrap .dataTables_length{float:left}
.expatman .em-table-wrap .dataTables_filter{float:right}
.expatman .em-table-wrap .dataTables_length select,
.expatman .em-table-wrap .dataTables_filter input,
.expatman .em-table-wrap .dt-length select,
.expatman .em-table-wrap .dt-search input{
  font-family:inherit;font-size:15px;color:var(--on-surface);background:var(--surface);
  border:1px solid var(--hairline);border-radius:9px;padding:8px 12px;margin:0 6px;transition:border-color .2s,box-shadow .2s}
.expatman .em-table-wrap .dataTables_length select,
.expatman .em-table-wrap .dt-length select{min-width:72px;padding-right:26px}
.expatman .em-table-wrap .dataTables_filter input,
.expatman .em-table-wrap .dt-search input{min-width:200px}
.expatman .em-table-wrap .dataTables_length select:focus,
.expatman .em-table-wrap .dataTables_filter input:focus,
.expatman .em-table-wrap .dt-length select:focus,
.expatman .em-table-wrap .dt-search input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-bg)}

.em-table-wrap table{border-collapse:collapse;margin:0;clear:both}

/* ---- Tableau ---- */
.expatman .em-table-wrap table{width:100%;font-size:14.5px;background:transparent;color:var(--on-surface)}
.expatman .em-table-wrap thead th{background:linear-gradient(180deg,var(--navy-700),var(--navy-800)) !important;color:#fff !important;
  text-align:left;padding:14px 16px;font-weight:600;font-size:13px;letter-spacing:.3px;border:0 !important;border-bottom:2px solid var(--gold) !important;white-space:nowrap;cursor:pointer;position:relative}
.expatman .em-table-wrap tbody td{padding:12px 16px;border:0;border-top:1px solid var(--hairline);
  color:var(--on-surface) !important;background-color:transparent !important;opacity:1;vertical-align:top;line-height:1.5}
.expatman .em-table-wrap tbody tr:nth-child(even) td{background-color:var(--surface-alt) !important}
.expatman .em-table-wrap tbody tr:hover td{background-color:var(--gold-bg) !important}
.expatman .em-table-wrap tbody td:first-child{font-weight:600}
.expatman .em-table-wrap a{color:var(--gold-deep) !important;font-weight:500;word-break:break-word}
.expatman .em-table-wrap a:hover{text-decoration:underline}

/* ---- Flèches de tri (1.x .sorting + 2.x .dt-column-order) lisibles sur header marine ---- */
.expatman .em-table-wrap table.dataTable thead .sorting:after,
.expatman .em-table-wrap table.dataTable thead .sorting_asc:after,
.expatman .em-table-wrap table.dataTable thead .sorting_desc:after,
.expatman .em-table-wrap table.dataTable thead .dt-column-order::before,
.expatman .em-table-wrap table.dataTable thead .dt-column-order::after{color:rgba(255,255,255,.95);opacity:.45}
.expatman .em-table-wrap table.dataTable thead .sorting_asc:after,
.expatman .em-table-wrap table.dataTable thead .sorting_desc:after,
.expatman .em-table-wrap table.dataTable thead .dt-ordering-asc .dt-column-order::before,
.expatman .em-table-wrap table.dataTable thead .dt-ordering-desc .dt-column-order::after{opacity:1;color:var(--gold-soft)}

/* ---- Bas : info + pagination (1.x .dataTables_* + 2.x .dt-*) ---- */
.expatman .em-table-wrap .dataTables_info,
.expatman .em-table-wrap .dt-info{padding:14px 18px;font-size:13px;color:var(--on-surface-muted);clear:both}
.expatman .em-table-wrap .dataTables_paginate,
.expatman .em-table-wrap .dt-paging{padding:12px 18px;text-align:right}
.expatman .em-table-wrap .dataTables_paginate .paginate_button,
.expatman .em-table-wrap .dt-paging .dt-paging-button{display:inline-block;min-width:34px;text-align:center;
  padding:6px 11px;margin-left:5px;border-radius:8px;border:1px solid var(--hairline);color:var(--on-surface) !important;
  background:var(--surface) !important;cursor:pointer;text-decoration:none;font-size:13.5px;box-shadow:none;
  transition:border-color .2s,color .2s,background .2s}
.expatman .em-table-wrap .dataTables_paginate .paginate_button:hover,
.expatman .em-table-wrap .dt-paging .dt-paging-button:hover{border-color:var(--gold);color:var(--gold-deep) !important;background:var(--gold-bg) !important}
.expatman .em-table-wrap .dataTables_paginate .paginate_button.current,
.expatman .em-table-wrap .dt-paging .dt-paging-button.current{background:var(--navy-800) !important;border-color:var(--navy-800);color:#fff !important}
.expatman .em-table-wrap .dataTables_paginate .paginate_button.disabled,
.expatman .em-table-wrap .dt-paging .dt-paging-button.disabled{opacity:.4;cursor:default;border-color:transparent}

@media(max-width:600px){
  .expatman .em-table-wrap thead th,.expatman .em-table-wrap tbody td{padding:10px 12px;font-size:13.5px}
  .expatman .em-table-wrap .dataTables_length,.expatman .em-table-wrap .dataTables_filter{float:none;display:block}
  .expatman .em-table-wrap .dataTables_filter input,.expatman .em-table-wrap .dt-search input{min-width:0;width:60%}
}

/* ===================================================================
   24. HUB FORMULAIRES (grille de cartes-liens)
   =================================================================== */
.em-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:22px;margin-bottom:40px}
.expatman a.em-formcard{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--hairline);
  border-radius:16px;padding:20px 22px;box-shadow:var(--shadow-md);text-decoration:none;position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s,border-color .35s}
.expatman a.em-formcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);
  transform:scaleY(0);transform-origin:top;transition:transform .35s ease}
.expatman a.em-formcard:hover{transform:translateY(-3px);border-color:rgba(201,162,39,.5);box-shadow:0 16px 34px -14px rgba(8,22,40,.4)}
.expatman a.em-formcard:hover::before{transform:scaleY(1)}
.expatman a.em-formcard:focus-visible{outline:none;box-shadow:var(--focus)}

.em-formcard-ico{flex:none;width:52px;height:52px;border-radius:13px;background:linear-gradient(150deg,var(--navy-700),var(--navy-900));
  display:grid;place-items:center;color:var(--gold-soft);box-shadow:inset 0 0 0 1px rgba(201,162,39,.3)}
.em-formcard-ico svg{width:24px;height:24px}
.em-formcard-body{flex:1;min-width:0;display:flex;flex-direction:column}
.em-formcard-kicker{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--on-surface-muted);font-weight:600}
.expatman .em-formcard-title{font-family:"Playfair Display",Georgia,serif;font-size:18.5px;color:var(--on-surface);font-weight:600;line-height:1.2;margin-top:2px}
.em-formcard-aud{font-size:13.5px;color:var(--on-surface-muted);margin-top:4px}
.em-formcard-cta{flex:none;align-self:center;font-size:14px;font-weight:600;color:var(--gold-deep);white-space:nowrap;
  display:inline-flex;align-items:center;gap:4px;transition:gap .25s ease}
.em-dark .em-formcard-cta{color:var(--gold-soft)}
.expatman a.em-formcard:hover .em-formcard-cta{gap:9px}

@media(max-width:480px){
  .expatman a.em-formcard{flex-wrap:wrap}
  .em-formcard-cta{width:100%;margin-top:6px}
}

/* ===================================================================
   25. PAGE FORMULAIRE (Gravity Forms 2.7 « gravity-theme » stylé)
   NB : GF met certains labels en #333 (illisibles en mode sombre) et des
   inputs blancs → on force couleurs/fonds via sélecteurs + !important.
   =================================================================== */
.em-narrow{max-width:780px}
.em-form-wrap.em-form-panel{padding:32px 30px}

/* Labels + astérisque obligatoire */
.expatman .em-form-wrap .gfield_label,
.expatman .em-form-wrap legend.gfield_label,
.expatman .em-form-wrap .gform_wrapper legend{color:var(--on-surface) !important;font-weight:600;font-size:14px;margin-bottom:7px}
.expatman .em-form-wrap .gfield_required,
.expatman .em-form-wrap .gfield_required_text{color:var(--gold-deep) !important;font-weight:600}
.em-dark .em-form-wrap .gfield_required,
.em-dark .em-form-wrap .gfield_required_text{color:var(--gold-soft) !important}

/* Sous-labels + descriptions d'aide */
.expatman .em-form-wrap .gform-field-label--type-sub,
.expatman .em-form-wrap .ginput_complex label,
.expatman .em-form-wrap .gfield_description,
.expatman .em-form-wrap .gform_fileupload_rules{color:var(--on-surface-muted) !important;font-weight:400}

/* Champs de saisie */
.expatman .em-form-wrap input[type=text],
.expatman .em-form-wrap input[type=email],
.expatman .em-form-wrap input[type=tel],
.expatman .em-form-wrap input[type=url],
.expatman .em-form-wrap input[type=number],
.expatman .em-form-wrap input[type=date],
.expatman .em-form-wrap input[type=password],
.expatman .em-form-wrap select,
.expatman .em-form-wrap textarea{
  width:100%;font-family:inherit;font-size:16px;color:var(--on-surface) !important;
  background:var(--surface-alt) !important;border:1px solid var(--hairline) !important;border-radius:10px !important;
  padding:11px 14px !important;box-shadow:none !important;transition:border-color .2s,box-shadow .2s}
.expatman .em-form-wrap textarea{min-height:120px}
.expatman .em-form-wrap input::placeholder,
.expatman .em-form-wrap textarea::placeholder{color:var(--on-surface-muted);opacity:1}
.expatman .em-form-wrap input:focus,
.expatman .em-form-wrap select:focus,
.expatman .em-form-wrap textarea:focus{outline:none;border-color:var(--gold) !important;box-shadow:0 0 0 3px var(--gold-bg) !important}

/* Menus déroulants natifs — LISIBILITÉ (bug macOS mode sombre).
   Le popup natif <select> sur macOS (OS en sombre) rend un texte pâle illisible
   et IGNORE bg/color des <option>. Le seul levier respecté est `color-scheme` :
   on force le schéma CLAIR → popup blanc + texte foncé, lisible partout
   (clair comme sombre). La commande fermée garde son style sombre via les
   règles .em-form-panel/.em-form-wrap plus haut. */
.expatman .em-form-wrap select,
.expatman .em-form-panel select,
.expatman .em-table-wrap select,
.expatman select.monmodule-picker,
.expatman .em-form-wrap input[type=date]{color-scheme:light}
.expatman .em-form-wrap select option,
.expatman .em-form-panel select option,
.expatman .em-table-wrap select option{background-color:#ffffff !important;color:#1A2A3C !important}

/* Radios / cases à cocher */
.expatman .em-form-wrap input[type=radio],
.expatman .em-form-wrap input[type=checkbox]{accent-color:var(--gold);width:auto !important;margin-right:8px}
.expatman .em-form-wrap .gchoice label,
.expatman .em-form-wrap .gfield-choice-input + label{color:var(--on-surface) !important;font-weight:500}

/* Séparateur de section */
.expatman .em-form-wrap .gsection{border-bottom:1px solid var(--hairline);margin:12px 0 4px;padding-bottom:8px}
.expatman .em-form-wrap .gsection_title{font-family:"Playfair Display",Georgia,serif;font-size:19px;color:var(--on-surface) !important;font-weight:600}

/* Bouton d'envoi */
.expatman .em-form-wrap .gform_footer{margin-top:26px;padding:0}
.expatman .em-form-wrap .gform_button,
.expatman .em-form-wrap input[type=submit],
.expatman .em-form-wrap .gform_footer button{
  background:linear-gradient(135deg,var(--gold-soft),var(--gold)) !important;color:var(--navy-900) !important;
  border:0 !important;width:auto !important;font-family:inherit;font-weight:600;font-size:15px;
  padding:14px 32px !important;border-radius:9px !important;cursor:pointer;
  box-shadow:0 8px 20px -8px rgba(201,162,39,.7) !important;transition:transform .2s,box-shadow .2s}
.expatman .em-form-wrap .gform_button:hover,
.expatman .em-form-wrap input[type=submit]:hover,
.expatman .em-form-wrap .gform_footer button:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(201,162,39,.85) !important;color:var(--navy-900) !important}

/* Validation */
.expatman .em-form-wrap .gfield_error input,
.expatman .em-form-wrap .gfield_error select,
.expatman .em-form-wrap .gfield_error textarea{border-color:#d9534f !important}
.expatman .em-form-wrap .gfield_validation_message,
.expatman .em-form-wrap .validation_message{color:#d9534f !important;background:transparent !important;border:0 !important;padding:4px 0 0 !important;font-size:13px}
.expatman .em-form-wrap .gform_validation_errors{background:#fdeaea !important;border:1px solid #e7b3b3 !important;border-radius:10px !important;padding:14px 18px !important;box-shadow:none !important;margin-bottom:20px}
.expatman .em-form-wrap .gform_validation_errors .gform_submission_error{color:#a33 !important}
.em-dark .em-form-wrap .gform_validation_errors{background:rgba(200,60,60,.12) !important;border-color:rgba(200,60,60,.4) !important}
.em-dark .em-form-wrap .gform_validation_errors .gform_submission_error{color:#f0a8a8 !important}

/* Confirmation après envoi */
.expatman .em-form-wrap .gform_confirmation_message{color:var(--on-surface);font-size:16px;line-height:1.6;text-align:center;padding:18px 0}

/* Utilitaires */
.em-pt0{padding-top:0}
.em-mb-lg{margin-bottom:22px}
