/*
  EST - Feuille de style principale
  ------------------------------------------------------------
  Notes de maintenance :
  - Les tailles sont fluides pour éviter les débordements FR/EN.
  - Les correctifs mobiles sont regroupés en bas du fichier.
  - CSS chargé en stylesheet classique pour éviter le FOUC / CLS.
*/

:root{
  --navy:#000020;
  --blue-900:#00153a;
  --blue-800:#002050;
  --blue-700:#003a75;
  --blue-600:#005090;
  --blue-500:#0070B0;
  --gray-50:#F7F9FC;
  --gray-100:#EFF3F8;
  --gray-200:#DCE5F0;
  --gray-300:#B8C6D9;
  --gray-400:#667085;
  --gray-500:#344054;
  --gray-600:#2D3B50;
  --gray-700:#223046;
  --white:#fff;

  --font-display:system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-body:system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --shadow-sm:0 1px 3px rgba(0,0,32,.10);
  --shadow-md:0 10px 30px rgba(0,0,32,.12);
  --shadow-lg:0 18px 60px rgba(0,0,32,.18);

  --radius-sm:10px;
  --radius-md:14px;
  --radius-lg:22px;
  --radius-xl:30px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px;scrollbar-gutter:stable both-edges}
body{
  font-family:var(--font-body);
  color:var(--gray-700);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.15;color:var(--navy)}
.section{padding:110px 0}
.section.alt{background:var(--gray-50)}
.section-label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);
  font-weight:700;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--blue-500);margin-bottom:14px
}
.section-label:before{content:"";width:28px;height:2px;background:var(--blue-500);border-radius:2px}
.section-title{font-size:clamp(2rem,3.8vw,3rem);margin-bottom:18px}
.section-subtitle{max-width:760px;color:var(--gray-500);font-size:1.08rem;line-height:1.85}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;
  padding:14px 26px;border-radius:var(--radius-sm);
  border:1.5px solid transparent;cursor:pointer;
  transition:.25s ease;
  user-select:none;
}
.btn-primary{background:var(--blue-600);color:var(--white)}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-1px);box-shadow:0 14px 40px rgba(0,80,144,.18)}
.btn-outline{background:transparent;color:var(--navy);border-color:rgba(0,32,80,.18)}
.btn-outline:hover{border-color:rgba(0,32,80,.35);background:rgba(0,80,144,.04)}

.btn-label-short{display:none}

.badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:999px;
  font-family:var(--font-display);
  font-size:.85rem;font-weight:600;
  background:rgba(0,112,176,.10);
  border:1px solid rgba(0,112,176,.18);
  color:var(--blue-500);
}

.card{
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  transition:.25s ease;
}
.card:hover{border-color:rgba(0,112,176,.28);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card.pad{padding:34px}
.grid{display:grid;gap:22px}

/* Barre de navigation fixe : stabilité desktop + mobile */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(0,0,32,.88);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-inner{height:78px;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;position:relative}
.nav-logo{display:flex;align-items:center;gap:12px;min-width:0}
.nav-logo img{height:48px;width:auto}
.navbar .nav-logo img{background:rgba(255,255,255,.92);border-radius:12px;padding:6px}
.nav-logo-text{font-family:var(--font-display);font-weight:800;color:var(--white);line-height:1.2;max-width:220px}
.nav-logo-text span{display:block;font-weight:500;font-size:.72rem;color:rgba(255,255,255,.60);letter-spacing:.05em}
.nav-links{display:flex;align-items:center;justify-content:center;gap:4px;list-style:none;min-width:0}
.nav-links a{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.88rem;
  color:rgba(255,255,255,.74);
  padding:8px 10px;border-radius:10px;
  transition:.25s ease
}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.10);color:var(--white)}
.nav-right{display:flex;align-items:center;gap:10px;justify-content:flex-end;min-width:300px}
.lang-item{display:none!important}

/* Sélecteur de langue */
.lang-switch{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:40px;padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.86);
  font-family:var(--font-display);
  font-weight:800;
  font-size:.82rem;
  background:rgba(255,255,255,.06);
  transition:.2s ease;
}
.lang-switch:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.26)}
.nav-right{white-space:nowrap} /* réserve une largeur stable (FR/EN) pour limiter les micro-décalages */
/* Largeur réservée pour éviter les micro-décalages du CTA entre FR/EN */
.nav-right .btn-primary{min-width:178px}
.nav-phone{
  font-family:var(--font-display);
  font-weight:700;font-size:.9rem;
  color:rgba(255,255,255,.82);
  padding:9px 12px;border-radius:10px;
  border:1px solid rgba(255,255,255,.10);
}
.nav-phone:hover{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.04)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:.25s ease}

.hero{
  position:relative;min-height:88vh;
  background:linear-gradient(180deg, rgba(0,32,80,.92), rgba(0,0,32,.98));
  display:flex;align-items:center;overflow:hidden
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 70% 30%, rgba(0,112,176,.22) 0%, transparent 55%),
    radial-gradient(ellipse 60% 60% at 10% 80%, rgba(0,80,144,.25) 0%, transparent 52%);
  z-index:1
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:68px 68px;
  z-index:1
}
.hero-content{position:relative;z-index:2;padding-top:78px;max-width:760px}
.hero h1{color:var(--white);font-size:clamp(2.4rem,5.2vw,4.2rem);font-weight:900;margin:18px 0 18px}
.hero p{color:rgba(255,255,255,.70);font-size:1.12rem;line-height:1.9;max-width:640px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-slogan{margin-top:26px;padding-top:18px;border-top:1px solid rgba(255,255,255,.10);max-width:520px}
.hero-slogan .l1{color:rgba(255,255,255,.92);font-family:var(--font-display);font-weight:800}
.hero-slogan .l2{color:rgba(255,255,255,.62);margin-top:6px;font-weight:600}

.pills{display:flex;gap:10px;flex-wrap:wrap}
.pill{
  display:inline-flex;align-items:center;
  padding:8px 12px;border-radius:999px;
  border:1px solid var(--gray-200);
  background:var(--white);
  color:var(--gray-500);
  font-family:var(--font-display);
  font-weight:700;
  font-size:.85rem;
}
.pill:hover{border-color:rgba(0,112,176,.30);background:rgba(0,112,176,.04)}

.icon-card{padding:28px}
.icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,112,176,.10);
  border:1px solid rgba(0,112,176,.18);
  color:var(--blue-500);
  font-size:1.3rem;
  margin-bottom:16px;
}
.icon svg{width:28px;height:28px;display:block}

.list{display:grid;gap:12px;list-style:none}
.list li{display:flex;gap:10px;align-items:flex-start;justify-content:flex-start;color:var(--gray-500)}
.list li .dot{width:22px;height:22px;border-radius:50%;background:rgba(0,112,176,.12);display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:var(--blue-500);font-weight:900}

.split{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}

.form-wrap{padding:34px}
.form-tabs{display:flex;gap:4px;background:var(--gray-50);padding:4px;border-radius:12px;margin-bottom:18px;border:1px solid var(--gray-200)}
.form-tab{flex:1;border:none;background:transparent;padding:12px;border-radius:10px;font-family:var(--font-display);font-weight:800;color:var(--gray-400);cursor:pointer}
.form-tab.active{background:var(--white);color:var(--navy);box-shadow:var(--shadow-sm)}
.form-group{margin-bottom:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:block;font-family:var(--font-display);font-weight:800;font-size:.84rem;color:var(--gray-500);margin-bottom:6px}
input,select,textarea{
  width:100%;padding:12px 14px;border-radius:12px;
  border:1.5px solid var(--gray-200);
  font-family:var(--font-body);
  font-size:.95rem;
  outline:none;
}
textarea{min-height:120px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(0,112,176,.55);box-shadow:0 0 0 3px rgba(0,112,176,.12)}
/* Boutons d'envoi formulaires (uniformisés FR/EN) */
.form-submit{
  width:100%;
  appearance:none;
  border:1px solid transparent;
  background:linear-gradient(180deg,var(--blue-600),var(--blue-700));
  color:#fff;
  font-weight:700;
  font-size:.98rem;
  border-radius:12px;
  min-height:44px;
  padding:11px 14px;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,80,144,.18);
  transition:transform .15s ease, box-shadow .2s ease, filter .15s ease;
}
.form-submit:hover{transform:translateY(-1px); box-shadow:0 14px 28px rgba(0,80,144,.24)}
.form-submit:active{transform:translateY(0)}
.form-submit:focus-visible{outline:3px solid rgba(0,112,176,.28); outline-offset:2px}
.form-submit[disabled]{opacity:.72; cursor:not-allowed}

.form-feedback{display:none;padding:12px 14px;border-radius:12px;margin:12px 0;font-weight:700}
.form-feedback.success{display:block;background:#ECFDF5;border:1px solid #A7F3D0;color:#065F46}
.form-feedback.error{display:block;background:#FEF2F2;border:1px solid #FECACA;color:#991B1B}
.form-honeypot{position:absolute;left:-9999px}

.file-upload{position:relative;border:2px dashed var(--gray-200);border-radius:16px;padding:22px;text-align:center;cursor:pointer;transition:.2s ease;margin-bottom:12px;background:var(--white)}
.file-upload:hover{border-color:rgba(0,112,176,.40);background:rgba(0,112,176,.03)}
.file-upload.has-file{border-color:#10b981;background:rgba(16,185,129,.04)}
.file-upload input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.file-upload .hint{font-size:.8rem;color:var(--gray-400)}
.file-upload .name{font-weight:800;color:#065f46}

.footer{
  background:rgba(0,0,32,.98);
  color:rgba(255,255,255,.70);
  padding:70px 0 0
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px;padding-bottom:44px}
.footer .footer-title{color:rgba(255,255,255,.92);font-family:var(--font-display);font-size:.9rem;margin-bottom:14px;line-height:1.3}
.footer-links{list-style:none;display:grid;gap:10px}
.footer-links a:hover{color:var(--white)}
.footer-contact{display:grid;gap:10px;font-size:.92rem}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:18px 0;
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap
}
.small{font-size:.86rem;color:rgba(255,255,255,.55)}
.footer-badges{display:flex;gap:10px;flex-wrap:wrap}
.footer-badge{padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);font-family:var(--font-display);font-weight:700;font-size:.74rem;color:rgba(255,255,255,.62)}
.social-links{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.social-link{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.65);font-size:.9rem}
.social-link svg{width:18px;height:18px}
.social-link:hover{color:rgba(255,255,255,.92)}


/* Bandeau cookies (RGPD - cookies techniques uniquement) */
.cookiebar{position:fixed;left:16px;right:16px;bottom:16px;z-index:2000;display:none}
.cookiebar .inner{max-width:1100px;margin:0 auto;background:rgba(0,0,32,.94);border:1px solid rgba(255,255,255,.10);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:16px;padding:14px 16px;display:flex;gap:14px;align-items:flex-start;justify-content:flex-start;justify-content:space-between;box-shadow:var(--shadow-lg)}
.cookiebar p{color:rgba(255,255,255,.75);font-size:.9rem;line-height:1.5;margin:0}
.cookiebar a{color:rgba(255,255,255,.92);text-decoration:underline}
.cookiebar .actions{display:flex;gap:10px;flex-shrink:0}
.cookiebar .btn-mini{padding:10px 14px;border-radius:12px;font-family:var(--font-display);font-weight:800;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:rgba(255,255,255,.92);cursor:pointer}
.cookiebar .btn-mini.primary{background:var(--blue-500);border-color:rgba(0,112,176,.55)}

/* Animations d'apparition (mode anti-CLS) :
   - On conserve les classes .reveal pour la maintenance
   - Mais on neutralise le déplacement/opacity au chargement pour éviter les CLS Lighthouse */
.reveal{opacity:1;transform:none}
.js-ready .reveal{opacity:1;transform:none;transition:none}
.js-ready .reveal.visible{opacity:1;transform:none}

@media (max-width: 1024px){
  .split{grid-template-columns:1fr;gap:26px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 1180px){
  .nav-logo-text span{display:none}

  .nav-logo{min-width:170px}
  .nav-links a{font-size:.84rem;padding:8px 10px}
  .btn{padding:13px 18px}
}
@media (max-width: 1024px){
  .nav-links{display:none;position:absolute;top:78px;left:0;right:0;background:rgba(0,0,32,.97);flex-direction:column;padding:14px 18px;border-top:1px solid rgba(255,255,255,.06)}
  .nav-links.open{display:flex}
  .nav-toggle{display:flex;grid-column:2;justify-self:center}
  .nav-logo{min-width:auto}
  .nav-logo-text span{display:none}
  .nav-logo-text{font-size:.92rem}
  /* On garde la langue + le CTA visibles dans l'en-tête mobile */
  .nav-right{gap:10px;min-width:auto}
  .lang-switch{display:inline-flex}
  .nav-right .btn-primary{display:inline-flex}

  /* Évite les doublons dans le menu burger */
  
  .nav-cta-mobile{display:none}
}
@media (max-width: 620px){
  .nav-logo-text{max-width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}

  /* Libellé CTA raccourci sur petits écrans */
  .btn-label-full{display:none}
  .btn-label-short{display:inline}
}

@media (max-width: 520px){
  .container{padding:0 18px}
  .nav-logo{gap:10px}
  .nav-logo-text{max-width:160px;font-size:.95rem}
  .nav-logo-text span{display:none}
  .btn.btn-primary{padding:12px 14px;font-size:.88rem}
}
@media (max-width: 390px){
  .nav-logo-text{display:none}
  .nav-inner{gap:10px}
  .btn.btn-primary{padding:11px 12px;font-size:.84rem}
}


/* ---------- Formulaires : labels et consentement ---------- */
.form-group > label{
  display:block;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.92rem;
  letter-spacing:0;
  text-transform:none;
  color:var(--gray-700);
  margin:0 0 8px 0;
}
.form-group label.check{
  display:flex;
  align-items:flex-start;justify-content:flex-start;
  gap:10px;
  font-family:var(--font-body);
  font-weight:500;
  font-size:.92rem;
  letter-spacing:0;
  text-transform:none;
  color:var(--gray-600);
  margin:10px 0 0 0;
  cursor:pointer;
}
.form-group label.check input[type="checkbox"]{
  width:18px;height:18px;
  margin-top:2px;
  accent-color: var(--blue-500);
  flex:0 0 auto;
}
.form-group label.check span{
  line-height:1.35;
}
.form-group label.check a{color:var(--blue-500);text-decoration:underline;text-underline-offset:2px}
.form-group label.check a:hover{color:var(--blue-600)}

/* ---------- Logos partenaires (tuiles typographiques) ---------- */
.logo-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;justify-items:stretch;margin-top:14px}
.logo-tile{
  display:flex;align-items:center;justify-content:center;
  padding:14px 10px;border-radius:16px;
  background:var(--white);
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow-sm);
  font-family:var(--font-display);
  font-weight:800;
  color:var(--navy);
  letter-spacing:.02em;
  text-align:center;
  min-height:56px;
}
.logo-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
@media (max-width:1024px){.logo-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:620px){.logo-grid{grid-template-columns:repeat(2,1fr)}}


/* ---------- Recrutement : liste des postes ---------- */
.job-list{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.job-card{position:relative}
.job-top{display:flex;align-items:flex-start;justify-content:flex-start;justify-content:space-between;gap:12px}
.job-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.job-meta-item{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid var(--gray-200);
  background:var(--gray-50);
  color:var(--gray-600);
  font-size:.84rem;
}
.job-meta-item svg{width:16px;height:16px;flex:0 0 auto;opacity:.9}
.job-card.spontaneous{
  border-style:dashed;
  background:linear-gradient(180deg, rgba(0,112,176,.06), rgba(255,255,255,0));
}
.job-card .job-cta{
  margin-top:14px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-display);
  font-weight:700;
  color:var(--blue-500);
}
.job-card .job-cta:hover{text-decoration:underline}

/* ---------- Navbar : taille du logo adaptée au mobile ---------- */
.navbar .nav-logo img{
  width:48px;height:48px;
  padding:0;
  background:rgba(255,255,255,.94);
  border-radius:14px;
  object-fit:contain;
}
@media (max-width:520px){
  .navbar .nav-logo img{width:46px;height:46px;border-radius:14px}
}

.hidden{display:none!important}

.hero .badge{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.26);color:rgba(255,255,255,.94)}

.anchor{position:relative;top:-90px;height:0;}

.turnstile{margin:14px 0 6px}

.lang-item{display:none!important}
.lang-link{font-weight:800 !important;color:rgba(255,255,255,.92) !important}


/* Grilles responsives réutilisables */
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
}

/* CTA réservé au menu burger (si activé plus tard) */
.nav-cta-mobile{display:none}
.nav-cta{display:flex;justify-content:center;align-items:center;padding:10px 14px;border-radius:12px;background:var(--blue-500);color:var(--white);font-family:var(--font-display);font-weight:700}
.nav-cta:hover{filter:brightness(0.95)}

/* Cartes d'offres d'emploi */
.job-card h4{font-size:1.05rem}
.job-top{display:flex;align-items:flex-start;justify-content:flex-start;justify-content:space-between;gap:12px}
.job-pill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(0,112,176,.10);
  border:1px solid rgba(0,112,176,.18);
  color:var(--blue-600);
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  white-space:nowrap;
}
.job-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;color:var(--gray-400);font-size:.86rem}
.job-meta span{background:var(--gray-50);border:1px solid var(--gray-200);padding:6px 10px;border-radius:999px}


/* --- Correctifs hérités (compatibilité v10) --- */
.form-group label.check{display:flex!important;flex-direction:row!important;align-items:flex-start!important;justify-content:flex-start!important;gap:10px!important}
.form-group label.check input[type="checkbox"]{margin:2px 0 0 0!important}
@media (max-width:520px){.nav-logo-text span{display:none}.nav-logo-text{font-size:.95rem;max-width:120px}}
.form-group label.check span{display:inline!important}


/* Garde-fous de mise en page (anti-débordement FR/EN) */
.grid > *, .split > *{min-width:0}
.card{overflow-wrap:anywhere}
.pill{white-space:normal;line-height:1.2;text-align:center}
.form-tabs{flex-wrap:wrap}
.form-tab{min-width:0}
@media (max-width:620px){
  .form-wrap{padding:22px}
  .form-tabs{gap:6px;padding:6px}
  .form-tab{width:100%;flex:1 1 100%}
}


/* Accessibilité : réduction des animations si demandée par l'utilisateur */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
}


/* ============================================================
   v15 modernisation visuelle + sélecteur de langue + homogénéité FR/EN
   ============================================================ */

:root{
  --brand-glow: rgba(0,112,176,.20);
  --brand-line: rgba(255,255,255,.10);
  --shadow-card: 0 14px 34px rgba(2,12,42,.08);
  --shadow-card-hover: 0 20px 42px rgba(2,12,42,.12);
}

/* CLS: on évite de verrouiller le scroll du body à l'ouverture de la modale langue */
body.modal-open{}

/* Fond de page plus "premium" sans casser la lisibilité */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background:
    radial-gradient(600px 260px at 8% -5%, rgba(0,112,176,.06), transparent 70%),
    radial-gradient(700px 300px at 96% 8%, rgba(0,32,80,.06), transparent 72%);
}

.navbar{
  background:linear-gradient(180deg, rgba(0,0,32,.90), rgba(0,0,32,.78));
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 40px rgba(0,0,0,.18);
}
.nav-links a{
  border-radius:12px;
  font-weight:700;
  color:rgba(255,255,255,.82);
}
.nav-links a:hover,
.nav-links a.active{
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.98);
}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-right .btn-primary{
  background:linear-gradient(135deg, #0070B0 0%, #005090 100%);
  border-color:rgba(255,255,255,.10);
  box-shadow:0 10px 25px rgba(0,80,144,.20);
}
.nav-right .btn-primary:hover{box-shadow:0 16px 35px rgba(0,80,144,.25)}
.lang-switch{border-color:rgba(255,255,255,.16)}

.hero{min-height:min(92vh, 860px)}
.hero::before{
  background:
    radial-gradient(ellipse 60% 56% at 80% 18%, rgba(0,112,176,.26) 0%, transparent 60%),
    radial-gradient(ellipse 48% 52% at 12% 88%, rgba(0,80,144,.28) 0%, transparent 58%),
    radial-gradient(ellipse 40% 30% at 52% 72%, rgba(255,255,255,.06) 0%, transparent 72%);
}
.hero-grid{opacity:.75}
.hero-content{max-width:820px}
.hero h1{letter-spacing:-.02em;text-wrap:balance}
.hero p{max-width:720px;text-wrap:pretty}
.hero .badge{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.hero-actions .btn{min-height:48px}

.section-title{letter-spacing:-.02em;text-wrap:balance}
.section-subtitle{text-wrap:pretty}

.card{
  border-color:rgba(0,32,80,.08);
  box-shadow:var(--shadow-card);
  background:linear-gradient(180deg,#fff 0%, #fff 74%, rgba(247,249,252,.8) 100%);
}
.card:hover{box-shadow:var(--shadow-card-hover);border-color:rgba(0,112,176,.20)}
.card.pad{padding:32px}

/* Homogénéité des tuiles FR/EN (services, moyens, blocs valeur) */
.grid.grid-2, .grid.grid-4{align-items:stretch}
.icon-card{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:4px;
  padding:26px;
}
.icon-card .icon{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(180deg, rgba(0,112,176,.12), rgba(0,112,176,.07));
  border-color:rgba(0,112,176,.22);
}
.icon-card h3{
  font-size:1.04rem;
  line-height:1.25;
  min-height:2.55em; /* stabilise la hauteur des titres FR/EN */
}
.icon-card p{
  color:var(--gray-500);
  margin-top:4px !important;
  line-height:1.55;
}

.logo-grid{gap:14px}
.logo-tile{
  min-height:62px;
  padding:12px 10px;
  border-radius:18px;
  background:linear-gradient(180deg,#fff, #f9fbff);
  border-color:rgba(0,32,80,.08);
  box-shadow:var(--shadow-card);
}

.pills{gap:8px}
.pill{
  border-radius:999px;
  border-color:rgba(0,32,80,.10);
  background:rgba(255,255,255,.9);
}

.split{align-items:start;gap:28px}
.form-wrap{
  border-radius:24px;
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border:1px solid rgba(0,32,80,.08);
  box-shadow:var(--shadow-card);
}
.form-tabs{background:rgba(0,32,80,.03);border-color:rgba(0,32,80,.08)}
.form-tab{font-weight:700;color:var(--gray-500)}
.form-tab.active{box-shadow:0 8px 16px rgba(2,12,42,.06)}
input,select,textarea{background:#fff;border-color:rgba(0,32,80,.12)}
input::placeholder, textarea::placeholder{color:#8190A8}

.job-card{
  border-radius:20px;
  border-color:rgba(0,32,80,.08);
}
.job-card .job-cta{font-weight:800}
.job-pill{background:rgba(0,112,176,.08)}

.footer{
  margin-top:20px;
  background:
    radial-gradient(650px 220px at 88% 0%, rgba(0,112,176,.13), transparent 70%),
    linear-gradient(180deg, rgba(0,0,32,.98), rgba(0,0,32,.99));
}
.footer .nav-logo img{box-shadow:0 8px 22px rgba(0,0,0,.18)}

/* Modal de choix de langue (1er passage) */
.lang-modal{
  position:fixed; inset:0; z-index:3000; display:none;
}
.lang-modal.open{display:block}
.lang-modal-backdrop{position:absolute; inset:0; background:rgba(0,0,32,.58); backdrop-filter:blur(4px)}
.lang-modal-card{
  position:relative;
  width:min(560px, calc(100% - 32px));
  margin:10vh auto 0;
  background:linear-gradient(180deg,#fff,#f7fbff);
  border:1px solid rgba(0,32,80,.10);
  border-radius:22px;
  padding:22px;
  box-shadow:0 28px 80px rgba(0,0,0,.28);
}
.lang-modal-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  background:rgba(0,112,176,.10); color:var(--blue-600);
  border:1px solid rgba(0,112,176,.18);
  font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em;
}
.lang-modal-card h2{font-size:1.35rem; margin:12px 0 8px; letter-spacing:-.02em}
.lang-modal-card p{color:var(--gray-500); line-height:1.6}
.lang-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.lang-choice{
  border:1px solid rgba(0,32,80,.12);
  background:#fff;
  border-radius:14px;
  padding:12px 14px;
  text-align:left;
  font-weight:800;
  cursor:pointer;
  transition:.18s ease;
}
.lang-choice:hover{transform:translateY(-1px); border-color:rgba(0,112,176,.35); box-shadow:0 8px 20px rgba(0,32,80,.08)}

/* Evite un CLS lié aux images/logo en cas de chargement tardif */
.nav-logo img, .footer .nav-logo img{aspect-ratio:1/1}

@media (max-width: 1024px){
  .hero{min-height:auto;padding:26px 0 18px}
  .hero-content{padding-top:92px}
  .lang-modal-card{margin-top:8vh}
}

@media (max-width: 620px){
  .card.pad{padding:22px}
  .icon-card{padding:22px}
  .icon-card h3{min-height:0}
  .lang-modal-card{padding:18px}
  .lang-modal-actions{grid-template-columns:1fr}
  .nav-right .btn-primary{min-width:132px}
}


/* =====================================================================
   V17 — Refonte visuelle accueil (méthode / secteurs / slider / hero)
   Objectif : rendu plus moderne, lisible, homogène FR/EN, sans casser le site.
   ===================================================================== */

/* --- HERO : contraste et lisibilité renforcés --- */
.hero{position:relative}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,10,35,.08) 0%, rgba(0,10,35,.18) 100%);
  z-index:1;
}
.hero-content{max-width:860px}
.hero h1{line-height:1.04; letter-spacing:-.02em; text-wrap:balance}
.hero h1 .highlight{
  display:inline-block;
  color:#fff;
  background:linear-gradient(90deg, rgba(0,112,176,.95), rgba(0,156,214,.95));
  padding:4px 12px 7px;
  border-radius:14px;
  box-shadow:0 10px 24px rgba(0,112,176,.22);
}
.hero .hero-text,
.hero p{color:rgba(255,255,255,.92); max-width:700px; font-weight:500; line-height:1.72}
.hero-actions{gap:12px; align-items:center}
.hero .btn{
  min-height:48px;
  border-radius:14px;
  font-weight:800;
  box-shadow:0 12px 26px rgba(0,0,32,.18);
}
.hero .btn.btn-primary{
  background:linear-gradient(180deg, #0a8fd8 0%, #006fb0 100%);
  border:1px solid rgba(255,255,255,.12);
}
.hero .btn.btn-primary:hover{filter:brightness(1.03)}
.hero .btn.btn-outline{
  color:#fff;
  border:1px solid rgba(255,255,255,.34);
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(6px);
}
.hero .btn.btn-outline:hover{background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.52)}
.hero-slogan{max-width:680px; border-top-color:rgba(255,255,255,.16)}
.hero-slogan .l2{color:rgba(255,255,255,.88); font-weight:700; letter-spacing:.01em}

/* Bandeau atouts (sous slogan) */
.metrics-strip{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  max-width:860px;
}
.metric-chip{
  display:flex; flex-direction:column; gap:4px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  backdrop-filter:blur(6px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.metric-chip .k{display:block; color:#fff; font-family:var(--font-display); font-weight:800; font-size:.92rem}
.metric-chip .v{display:block; color:rgba(255,255,255,.86); font-size:.82rem; line-height:1.35}

/* --- Collaborations : tuiles harmonisées FR/EN + effet plus premium --- */
.logo-grid{grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px}
.logo-tile{
  position:relative;
  height:76px; min-height:76px;
  padding:12px 16px;
  border-radius:18px;
  border:1px solid rgba(0,32,80,.10);
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,255,.96));
  font-size:.96rem;
  line-height:1.15;
  letter-spacing:.01em;
  text-align:center;
  overflow:hidden;
}
.logo-tile::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(0,112,176,.05) 45%, transparent 100%);
  opacity:0; transform:translateX(-20%);
  transition:opacity .2s ease, transform .35s ease;
}
.logo-tile:hover::before{opacity:1; transform:translateX(0)}
.logo-tile:hover{border-color:rgba(0,112,176,.20)}

/* --- Slider animé (cas d'usage) --- */
.case-slider-wrap{margin-top:8px}
.case-slider{
  position:relative;
  border-radius:24px;
  border:1px solid rgba(0,32,80,.08);
  background:linear-gradient(180deg,#fff,#f7fbff);
  box-shadow:var(--shadow-card);
  overflow:hidden;
}
.case-slider::before{
  content:""; position:absolute; inset:0 auto 0 0; width:6px;
  background:linear-gradient(180deg, var(--blue-500), rgba(0,112,176,.35));
}
.case-slider-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 18px 8px 22px;
}
.case-slider-title{font-family:var(--font-display); font-weight:800; color:var(--navy); font-size:1rem}
.case-slider-controls{display:flex; align-items:center; gap:8px}
.slider-btn{
  width:36px; height:36px; border-radius:10px; border:1px solid rgba(0,32,80,.10);
  background:#fff; color:var(--navy); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:.18s ease;
}
.slider-btn:hover{border-color:rgba(0,112,176,.28); color:var(--blue-600); transform:translateY(-1px)}
.slider-btn svg{width:17px;height:17px}
.case-slider .slider-viewport{overflow:hidden; padding:6px 8px 10px 8px}
.case-slider .slider-track{display:flex; transition:transform .45s ease; will-change:transform}
.case-slide{min-width:100%; padding:8px}
.case-slide-inner{
  display:grid; grid-template-columns:1.05fr .95fr; gap:16px;
  padding:18px;
  border-radius:18px;
  border:1px solid rgba(0,32,80,.08);
  background:linear-gradient(180deg,#ffffff,#fbfdff);
}
.case-slide h3{font-size:1.18rem; margin:0 0 8px 0}
.case-slide p{color:var(--gray-500); line-height:1.6; margin:0}
.case-badges{display:flex; flex-wrap:wrap; gap:8px; margin-top:12px}
.case-badge{
  display:inline-flex; align-items:center; gap:7px;
  padding:7px 10px; border-radius:999px;
  background:rgba(0,112,176,.06);
  border:1px solid rgba(0,112,176,.14);
  color:var(--blue-700);
  font-weight:700; font-size:.8rem;
}
.case-panel{
  border-radius:14px;
  border:1px solid rgba(0,32,80,.08);
  background:rgba(0,32,80,.02);
  padding:14px;
}
.case-panel h4{font-size:.92rem; margin:0 0 10px 0; color:var(--navy)}
.case-list{list-style:none; margin:0; padding:0; display:grid; gap:9px}
.case-list li{display:flex; gap:8px; align-items:flex-start; color:var(--gray-600); line-height:1.4; font-size:.88rem}
.case-list li::before{
  content:""; width:7px; height:7px; border-radius:50%; margin-top:6px; flex:0 0 auto;
  background:linear-gradient(180deg, var(--blue-500), var(--blue-700));
  box-shadow:0 0 0 3px rgba(0,112,176,.10);
}
.slider-dots{display:flex; justify-content:center; gap:8px; padding:0 12px 16px}
.slider-dot{
  width:9px; height:9px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(0,32,80,.18); transition:transform .18s ease, background .18s ease;
}
.slider-dot.active{background:var(--blue-500); transform:scale(1.15)}

/* --- Secteurs : vraies cartes stylées (anciennement brut) --- */
.sectors-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.sector-card{
  position:relative;
  padding:18px;
  border-radius:18px;
  border:1px solid rgba(0,32,80,.09);
  background:linear-gradient(180deg, #fff, #f9fbff);
  box-shadow:var(--shadow-sm);
  min-height:174px;
  display:flex;
  flex-direction:column;
}
.sector-card::before{
  content:"";
  position:absolute; left:0; top:0; bottom:0; width:5px;
  border-radius:18px 0 0 18px;
  background:linear-gradient(180deg, rgba(0,112,176,.75), rgba(0,112,176,.18));
}
.sector-card h3{margin:0 0 8px 0; font-size:1.05rem; padding-right:8px}
.sector-card p{margin:0; color:var(--gray-500); line-height:1.55; font-size:.93rem}
.mini-tags{display:flex; flex-wrap:wrap; gap:8px; margin-top:auto; padding-top:14px}
.mini-tags span{
  display:inline-flex; align-items:center;
  padding:6px 10px; border-radius:999px;
  border:1px solid rgba(0,32,80,.09);
  background:#fff;
  color:var(--gray-600);
  font-size:.78rem; font-weight:700;
}

/* --- Méthode : timeline + CTA intégré (plus de bloc perdu au milieu) --- */
.process-steps{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.process-steps::before{
  content:"";
  position:absolute;
  left:8%; right:8%; top:32px;
  height:2px;
  background:linear-gradient(90deg, rgba(0,112,176,.18), rgba(0,112,176,.35), rgba(0,112,176,.18));
  z-index:0;
}
.step-card{
  position:relative; z-index:1;
  padding:18px 16px 16px;
  border-radius:18px;
  border:1px solid rgba(0,32,80,.09);
  background:linear-gradient(180deg,#fff,#fbfdff);
  box-shadow:var(--shadow-sm);
  min-height:190px;
}
.step-card .n{
  width:28px; height:28px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, var(--blue-500), var(--blue-700));
  color:#fff; font-weight:800; font-size:.88rem;
  box-shadow:0 0 0 6px #fff;
  margin-bottom:10px;
}
.step-card h3{font-size:1rem; margin:0 0 8px 0; line-height:1.25}
.step-card p{margin:0; color:var(--gray-500); line-height:1.52; font-size:.9rem}

.cta-band{
  margin-top:16px;
  border-radius:20px;
  border:1px solid rgba(0,32,80,.10);
  background:
    radial-gradient(400px 140px at 100% 0%, rgba(0,112,176,.10), transparent 70%),
    linear-gradient(180deg,#fff,#f7fbff);
  box-shadow:var(--shadow-card);
}
.cta-band-inner{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:16px 18px;
}
.cta-band h3{margin:0; font-size:1.05rem; line-height:1.25}
.cta-band p{margin:6px 0 0 0; color:var(--gray-500); line-height:1.5; font-size:.92rem; max-width:720px}
.cta-band .btn{white-space:nowrap}

/* --- Boutons d'envoi : style plus moderne --- */
.form-submit{
  position:relative;
  overflow:hidden;
  font-family:var(--font-display);
  font-weight:800;
  border-radius:14px;
  min-height:46px;
  background:linear-gradient(180deg,#0a8fd8 0%, #006fae 100%);
  border-color:rgba(255,255,255,.18);
  box-shadow:0 12px 28px rgba(0,80,144,.20), inset 0 1px 0 rgba(255,255,255,.12);
}
.form-submit::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.18) 35%, transparent 70%);
  transform:translateX(-130%);
  transition:transform .45s ease;
}
.form-submit:hover::before{transform:translateX(130%)}
.form-submit::after{
  content:"→";
  display:inline-block;
  margin-left:8px;
  font-weight:900;
  transition:transform .18s ease;
}
.form-submit:hover::after{transform:translateX(2px)}

/* --- Responsive --- */
@media (max-width: 1024px){
  .metrics-strip{grid-template-columns:1fr}
  .process-steps{grid-template-columns:repeat(2,minmax(0,1fr))}
  .process-steps::before{display:none}
  .step-card{min-height:170px}
  .case-slide-inner{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .logo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .logo-tile{height:70px; min-height:70px; font-size:.9rem}
  .sectors-grid{grid-template-columns:1fr}
  .sector-card{min-height:0}
  .process-steps{grid-template-columns:1fr}
  .cta-band-inner{flex-direction:column; align-items:flex-start}
  .cta-band .btn{width:100%}
  .case-slider-head{padding:14px 14px 6px 18px}
  .case-slide{padding:4px}
  .case-slide-inner{padding:14px}
}
@media (max-width: 620px){
  .hero .hero-text, .hero p{font-size:1rem; line-height:1.62}
  .hero h1 .highlight{padding:3px 10px 6px}
  .metrics-strip{margin-top:14px}
  .metric-chip{padding:10px 11px}
  .metric-chip .v{font-size:.8rem}
  .hero .btn{width:100%}
  .hero-actions{flex-direction:column; align-items:stretch}
}


/* ============================================================
   V18 - Harmonisation UI (hover, lisibilité hero, méthode, stats)
   ============================================================ */

/* HERO : contraste renforcé pour la lecture et CTA secondaire visible */
.hero::before{background:linear-gradient(180deg,rgba(0,0,32,.68),rgba(0,0,32,.50) 36%,rgba(0,0,32,.66) 100%)}
.hero::after{background:radial-gradient(1000px 420px at 14% 18%,rgba(0,112,176,.22),transparent 62%),radial-gradient(900px 380px at 82% 78%,rgba(0,80,144,.18),transparent 65%)}
.hero-title{color:#fff;text-shadow:0 6px 20px rgba(0,0,32,.22)}
.hero-sub{color:rgba(255,255,255,.96);max-width:780px;text-shadow:0 2px 12px rgba(0,0,32,.16)}
.hero .btn-outline{
  border-color:rgba(255,255,255,.70);
  color:#fff;
  background:rgba(255,255,255,.10);
  box-shadow:0 8px 20px rgba(0,0,32,.16);
}
.hero .btn-outline:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.92);transform:translateY(-2px)}
.hero-slogan{background:rgba(0,0,32,.38);border-color:rgba(255,255,255,.16);backdrop-filter:blur(8px)}
.hero-slogan .l2{color:rgba(255,255,255,.92)}
.metrics-strip{gap:12px}
.metric-chip{
  background:linear-gradient(180deg,rgba(0,16,46,.58),rgba(0,16,46,.44));
  border-color:rgba(255,255,255,.16);
  box-shadow:0 12px 30px rgba(0,0,32,.18);
}
.metric-chip .k{color:#fff}
.metric-chip .v{color:rgba(255,255,255,.94);font-weight:500}

/* Hovers harmonisés (menu, tuiles, cartes) */
.nav-links a,.logo-tile,.icon-card,.sector-card,.step-card,.case-slide-inner,.stat-card,.slider-btn,.form-tab,.card{transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background-color .2s ease, color .2s ease}
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:12px;right:12px;bottom:7px;height:2px;background:var(--blue-500);transform:scaleX(0);transform-origin:left;transition:transform .18s ease;opacity:.9;border-radius:2px}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a:hover{background:rgba(255,255,255,.10);color:#fff;transform:translateY(-1px)}
.logo-tile{min-height:78px;line-height:1.2;text-align:center;box-shadow:var(--shadow-sm)}
.logo-tile:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(0,0,32,.10);border-color:rgba(0,112,176,.26)}
.icon-card:hover,.sector-card:hover,.step-card:hover,.stat-card:hover,.card.pad:hover{transform:translateY(-4px)}
.icon-card:hover,.sector-card:hover,.step-card:hover,.stat-card:hover{box-shadow:0 16px 34px rgba(0,0,32,.10);border-color:rgba(0,112,176,.18)}

/* Slider : style plus moderne + cohérent avec les cartes */
.case-slider{background:linear-gradient(180deg,#fff, #f8fbff);border:1px solid var(--gray-200);border-radius:24px;box-shadow:0 16px 34px rgba(0,0,32,.07)}
.case-slider-head{padding-bottom:14px;margin-bottom:6px;border-bottom:1px solid rgba(0,80,144,.10)}
.case-slider-title{font-size:1.05rem;letter-spacing:.01em}
.case-slide-inner{border:1px solid rgba(0,80,144,.08);background:#fff}
.case-slide-inner:hover{border-color:rgba(0,112,176,.22);box-shadow:0 16px 34px rgba(0,0,32,.08)}
.case-panel{background:linear-gradient(180deg,#f4f8fd,#edf4fb)}
.slider-btn{background:#fff;border-color:rgba(0,80,144,.16);box-shadow:0 6px 16px rgba(0,0,32,.06)}
.slider-btn:hover{color:var(--blue-600);border-color:rgba(0,112,176,.30);transform:translateY(-1px)}
.slider-dot{background:#c9d8ea}
.slider-dot.active{background:var(--blue-500)}

/* Méthode : rendu timeline (on garde le même HTML, juste un style plus fort) */
.process-steps{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  align-items:stretch;
  margin-top:8px;
}
.process-steps::before{
  content:"";
  position:absolute;
  left:26px; right:26px; top:30px;
  height:2px;
  background:linear-gradient(90deg,rgba(0,112,176,.25),rgba(0,112,176,.10));
  z-index:0;
}
.step-card{
  position:relative;
  z-index:1;
  background:linear-gradient(180deg,#fff,#f8fbff);
  border:1px solid var(--gray-200);
  border-radius:18px;
  padding:18px 16px 16px;
  min-height:170px;
}
.step-card .n{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:999px;
  background:var(--blue-500);color:#fff;font-weight:800;
  margin-bottom:10px;box-shadow:0 8px 20px rgba(0,112,176,.24)
}
.step-card h3{font-size:1rem;margin-bottom:8px}
.step-card p{color:var(--gray-500);font-size:.95rem;line-height:1.55}
.cta-band{margin-top:18px}
.cta-band-inner{border:1px solid var(--gray-200);box-shadow:0 14px 30px rgba(0,0,32,.07);background:linear-gradient(135deg,#f7fbff,#f2f7fd 58%,#eaf3ff)}
.cta-band-inner h3{font-size:1.08rem}
.cta-band-inner p{color:var(--gray-600)}

/* Carte "cadre de service" dans Entreprise (remplace doublon Méthode) */
.ops-framework-card{background:linear-gradient(180deg,#fff,#f9fbff);border:1px solid var(--gray-200)}
.ops-framework-card .dot{background:linear-gradient(180deg,#0b7cc1,#0063a6);font-size:.78rem}
.ops-framework-note{margin-top:14px;color:var(--gray-500);font-size:.93rem;line-height:1.55}

/* Section chiffres clés + mini-carte */
.stats-zone-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:18px;align-items:stretch}
.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.stat-card{
  background:linear-gradient(180deg,#fff,#f8fbff);
  border:1px solid var(--gray-200);
  border-radius:18px;
  padding:16px;
  box-shadow:var(--shadow-sm);
}
.stat-value{
  font-family:var(--font-display);font-weight:800;color:var(--navy);
  font-size:clamp(1.9rem,2.7vw,2.35rem);line-height:1;
  margin-bottom:8px;
}
.stat-label{font-family:var(--font-display);font-weight:700;color:var(--gray-700);margin-bottom:6px}
.stat-card p{color:var(--gray-500);font-size:.92rem;line-height:1.55}
.zones-mini-card{
  background:linear-gradient(180deg,#fff,#f8fbff);
  border:1px solid var(--gray-200);
  border-radius:18px;
  padding:16px;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.zones-mini-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.zones-mini-head h3{font-size:1rem}
.zones-map-svg{border:1px solid rgba(0,80,144,.08);border-radius:14px;background:radial-gradient(circle at 10% 10%,rgba(0,112,176,.05),transparent 45%),#fff;padding:8px}
.zones-map-svg svg{width:100%;height:auto;display:block}
.zones-map-svg text{font-family:var(--font-display);font-size:12px;fill:var(--gray-600);font-weight:700}
.zones-map-svg .zone-node{fill:#0a6fae;stroke:#fff;stroke-width:2}
.zones-map-svg .zone-node.benelux{fill:#0c8b73}
.zones-tags{display:flex;flex-wrap:wrap;gap:8px}
.zones-tags span{padding:6px 10px;border-radius:999px;background:#eef5fd;border:1px solid rgba(0,112,176,.16);font-size:.8rem;font-weight:700;color:var(--blue-700)}

/* Formulaires : bouton d'envoi plus propre */
.form-submit{
  width:100%;
  border:none;
  border-radius:12px;
  padding:13px 16px;
  font-family:var(--font-display);
  font-weight:800;
  letter-spacing:.01em;
  color:#fff;
  background:linear-gradient(180deg,var(--blue-500),#0066a6);
  box-shadow:0 10px 22px rgba(0,112,176,.22);
  cursor:pointer;
}
.form-submit:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(0,112,176,.28)}
.form-submit:disabled{opacity:.72;cursor:not-allowed;transform:none;box-shadow:none}

/* Ajustements mobiles */
@media (max-width: 980px){
  .stats-zone-layout{grid-template-columns:1fr}
}
@media (max-width: 840px){
  .process-steps{grid-template-columns:1fr 1fr}
  .process-steps::before{left:18px;right:18px;top:28px}
}
@media (max-width: 640px){
  .stats-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .process-steps::before{display:none}
  .step-card{min-height:unset}
  .hero-slogan{padding:10px 12px}
  .metric-chip{padding:10px 12px}
}


/* =========================================================
   V19 - Conversion + GTM ready
   Ajustements visuels finaux (CTA, hovers, sections, sticky mobile)
   ========================================================= */

/* Hero plus lisible et plus "vendeur" */
.hero::before{background:linear-gradient(135deg, rgba(3,15,45,.74), rgba(0,55,100,.54));}
.hero-content{position:relative; z-index:2;}
.hero h1{max-width:14ch; text-shadow:0 8px 24px rgba(2,8,25,.35);}
.hero p{max-width:62ch; color:rgba(255,255,255,.92); text-shadow:0 4px 14px rgba(2,8,25,.22);}
.hero-actions{gap:12px;}
.hero .btn{font-weight:800; border-radius:12px;}
.hero .btn.btn-primary{box-shadow:0 14px 35px rgba(0,80,144,.28);}
.hero .btn.btn-outline{color:#fff; border-color:rgba(255,255,255,.68); background:rgba(255,255,255,.10);}
.hero .btn.btn-outline:hover{background:rgba(255,255,255,.18);}
.hero-slogan{background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); backdrop-filter:blur(6px);}
.hero-slogan .l1,.hero-slogan .l2{color:rgba(255,255,255,.96);}

/* Chips / preuves plus contrastés */
.metric-chip{background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.09)); border-color:rgba(255,255,255,.17);}
.metric-chip .k{color:#fff; font-weight:800;}
.metric-chip .v{color:rgba(255,255,255,.86);}

/* Harmonisation hover globale */
.nav-links a,.logo-tile,.card,.icon-card,.step-card,.stat-card,.case-slide-inner,.slider-btn,.form-tab,.pill,.form-submit{transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background-color .2s ease, color .2s ease, opacity .2s ease;}
.card:hover,.icon-card:hover,.step-card:hover,.stat-card:hover,.case-slide-inner:hover{transform:translateY(-3px); box-shadow:0 18px 36px rgba(2,12,42,.12);}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.14);}
.logo-tile{min-height:78px; border-radius:16px; font-weight:700;}
.logo-tile:hover{box-shadow:0 14px 28px rgba(2,12,42,.10);}

/* Section méthode : un seul bloc, rendu premium */
.process-steps{gap:16px; margin-top:14px;}
.step-card{border-radius:18px; background:linear-gradient(180deg,#fff,#f7fbff); border:1px solid rgba(13,110,253,.10);}
.step-card .n{box-shadow:0 8px 16px rgba(0,112,176,.15);}
.cta-band{margin-top:16px; border-radius:18px; background:linear-gradient(135deg, rgba(0,80,144,.06), rgba(0,112,176,.03)); border:1px solid rgba(0,112,176,.14);}
.cta-band h3{color:var(--navy);}
.cta-band p{color:var(--gray-600);}

/* Slider secteurs : même langage visuel que méthodes/cartes */
.case-slider{border-radius:18px; border:1px solid rgba(0,112,176,.12); box-shadow:0 10px 28px rgba(2,12,42,.06);}
.case-slide-inner{border-radius:16px; border:1px solid rgba(0,112,176,.10);}
.case-panel{background:linear-gradient(180deg,#F7FBFF,#FFFFFF); border:1px solid rgba(0,112,176,.10);}

/* Formulaires : bouton envoyé premium + état hover homogène */
.form-wrap{border-radius:20px; border:1px solid rgba(0,112,176,.12); box-shadow:0 12px 30px rgba(2,12,42,.07);}
.form-tabs{background:#f3f7fb; border-radius:14px; padding:4px;}
.form-tab{border-radius:10px; font-weight:700;}
.form-tab.active{box-shadow:0 6px 14px rgba(2,12,42,.08);}
.form-submit{position:relative; isolation:isolate; background:linear-gradient(135deg, #006BB6, #004F90); border:0; color:#fff; font-weight:800; letter-spacing:.01em; min-height:44px; border-radius:12px; box-shadow:0 10px 22px rgba(0,80,144,.22);}
.form-submit:hover{transform:translateY(-1px); box-shadow:0 14px 28px rgba(0,80,144,.26); filter:saturate(1.05);}
.form-submit:focus-visible{outline:3px solid rgba(0,112,176,.26); outline-offset:2px;}
.form-submit[disabled]{opacity:.75; cursor:not-allowed;}

/* Mini barre CTA mobile (conversion) */
.mobile-quickbar{display:none;}
@media (max-width: 860px){
  .mobile-quickbar{
    display:grid; grid-template-columns:1fr 1.2fr; gap:10px; position:fixed; left:10px; right:10px; bottom:10px; z-index:70;
    background:rgba(255,255,255,.90); border:1px solid rgba(0,32,80,.10); border-radius:14px; padding:8px;
    box-shadow:0 18px 34px rgba(2,12,42,.18); backdrop-filter:blur(8px);
  }
  .mobile-quickbar-btn{
    display:inline-flex; align-items:center; justify-content:center; min-height:42px; border-radius:10px; text-decoration:none;
    border:1px solid rgba(0,32,80,.14); color:var(--navy); background:#fff; font-weight:700; padding:0 10px;
  }
  .mobile-quickbar-btn.primary{background:linear-gradient(135deg, #006BB6, #004F90); color:#fff; border-color:transparent;}
  .mobile-quickbar-btn:hover{transform:translateY(-1px);}
  body{padding-bottom:76px;}
}

/* Accessibilité : hover = focus visible cohérent */
.nav-links a:focus-visible, .logo-tile:focus-visible, .slider-btn:focus-visible, .mobile-quickbar-btn:focus-visible{
  outline:3px solid rgba(0,112,176,.28); outline-offset:2px;
}

/* =========================================================
   V20 - Correctif ciblé HERO (suppression de la "tuile" sur le slogan)
   ========================================================= */
/* Le slogan reste lisible mais sans carte superposée */
.hero-slogan{
  margin-top:18px;
  max-width:720px;
  background:transparent !important;
  border:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  box-shadow:none !important;
  padding:0 !important;
}
.hero-slogan::before{
  content:"";
  display:block;
  width:84px;
  height:2px;
  border-radius:999px;
  background:rgba(255,255,255,.28);
  margin-bottom:10px;
}
.hero-slogan .l1{
  display:block;
  color:rgba(255,255,255,.98);
  text-shadow:0 4px 12px rgba(2,8,25,.18);
}
.hero-slogan .l2{
  display:block;
  margin-top:4px;
  color:rgba(255,255,255,.88) !important;
}
@media (max-width:640px){
  .hero-slogan{margin-top:16px}
  .hero-slogan::before{width:64px}
}


/* ============================================================
   V23 - Correctif méthode + harmonisation visuelle des tuiles
   ============================================================ */

/* CTA de la section Méthode : même langage visuel que les autres cartes */
.cta-band{
  margin-top:18px;
  border:none;
  background:transparent;
  box-shadow:none;
}
.cta-band-inner{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(0,112,176,.12);
  background:linear-gradient(180deg,#ffffff,#f7fbff);
  box-shadow:0 10px 28px rgba(2,12,42,.06);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.cta-band-inner::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:5px;
  border-radius:18px 0 0 18px;
  background:linear-gradient(180deg, rgba(0,112,176,.80), rgba(0,112,176,.22));
}
.cta-band-inner > *{position:relative; z-index:1;}
.cta-band-inner:hover{
  transform:translateY(-2px);
  border-color:rgba(0,112,176,.22);
  box-shadow:0 16px 34px rgba(2,12,42,.09);
}
.cta-band h3{font-size:1.05rem; margin:0;}
.cta-band p{color:var(--gray-600);}
.cta-band .btn{
  min-width:200px;
  justify-content:center;
  box-shadow:0 8px 20px rgba(0,112,176,.20);
}
@media (max-width: 720px){
  .cta-band .btn{min-width:0; width:100%;}
}

/* Harmonisation : on généralise le liseré bleu à gauche sur les tuiles clés */
.icon-card, .step-card, .stat-card, .ops-framework-card{
  position:relative;
  overflow:hidden;
}
.icon-card::before, .step-card::before, .stat-card::before, .ops-framework-card::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:5px;
  border-radius:18px 0 0 18px;
  background:linear-gradient(180deg, rgba(0,112,176,.78), rgba(0,112,176,.18));
  opacity:.95;
}
/* La tuile de collaboration garde son effet animé (::before), on ajoute le liseré via ::after */
.logo-tile::after{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  border-radius:18px 0 0 18px;
  background:linear-gradient(180deg, rgba(0,112,176,.78), rgba(0,112,176,.15));
}
/* Le fond du slider a déjà un liseré ; on ajoute le même accent sur sa tuile interne pour cohérence */
.case-slide-inner{position:relative; overflow:hidden;}
.case-slide-inner::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  border-radius:16px 0 0 16px;
  background:linear-gradient(180deg, rgba(0,112,176,.78), rgba(0,112,176,.15));
}
/* On conserve le liseré existant sur .sector-card, mais on l'aligne visuellement */
.sector-card::before{width:4px;}

/* Petits espacements pour ne pas coller le texte au liseré */
.icon-card, .step-card, .stat-card, .ops-framework-card, .case-slide-inner{padding-left:18px;}
@media (max-width: 720px){
  .icon-card, .step-card, .stat-card, .ops-framework-card, .case-slide-inner{padding-left:16px;}
}

/* V23B - Ajustement fin des liserés (sans casser les paddings d'origine) */
.icon-card::before,
.step-card::before,
.stat-card::before,
.ops-framework-card::before{
  left:10px;
  top:12px;
  bottom:12px;
  width:4px;
  border-radius:999px;
}
.cta-band-inner::before{
  left:10px;
  top:14px;
  bottom:14px;
  width:4px;
  border-radius:999px;
}
.logo-tile::after{
  left:10px;
  top:10px;
  bottom:10px;
  width:3px;
  border-radius:999px;
}
.case-slide-inner::before{
  left:10px;
  top:12px;
  bottom:12px;
  width:4px;
  border-radius:999px;
}
.sector-card::before{
  left:10px;
  top:12px;
  bottom:12px;
  width:4px;
  border-radius:999px;
}

/* On restaure les paddings natifs (le bloc V23 ajoutait un padding-left trop agressif) */
.icon-card{padding-left:28px;}
.step-card{padding-left:16px;}
.stat-card{padding-left:16px;}
.ops-framework-card{padding-left:32px;}
.case-slide-inner{padding-left:18px;}
@media (max-width: 720px){
  .icon-card{padding-left:22px;}
  .ops-framework-card{padding-left:22px;}
  .case-slide-inner{padding-left:14px;}
}


/* ============================================================
   V26 - Harmonisation finale des tuiles et des hover
   Objectif : un seul langage visuel (cartes + liseré bleu à gauche)
   ============================================================ */

/* On neutralise les anciens liserés spécifiques pour éviter les doubles effets */
.icon-card::before,
.step-card::before,
.stat-card::before,
.ops-framework-card::before,
.cta-band-inner::before,
.case-slide-inner::before,
.logo-tile::after,
.sector-card::before{
  display:none !important;
}

/* Base visuelle commune pour toutes les tuiles principales */
.card,
.logo-tile,
.case-slide-inner,
.step-card,
.sector-card,
.stat-card,
.cta-band-inner,
.zones-mini-card,
.form-wrap,
.file-upload,
.job-meta-item,
.metric-chip{
  border-radius:18px;
  border:1px solid rgba(0,32,80,.10);
  box-shadow:0 10px 24px rgba(2,12,42,.07);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background-color .2s ease;
}

/* Liseré bleu généralisé (inset = pas de pseudo-élément, donc plus stable) */
.card,
.logo-tile,
.case-slide-inner,
.step-card,
.sector-card,
.stat-card,
.cta-band-inner,
.zones-mini-card,
.form-wrap,
.file-upload{
  box-shadow:
    inset 4px 0 0 rgba(0,112,176,.88),
    0 10px 24px rgba(2,12,42,.07);
}

/* Les chips du hero gardent un style sombre mais avec le même langage */
.metric-chip{
  position:relative;
  overflow:hidden;
  box-shadow:
    inset 3px 0 0 rgba(255,255,255,.92),
    0 10px 24px rgba(0,0,32,.18);
}

/* Uniformisation des fonds pour éviter les "tuiles bizarres" */
.card,
.case-slide-inner,
.step-card,
.sector-card,
.stat-card,
.cta-band-inner,
.zones-mini-card,
.form-wrap,
.file-upload,
.logo-tile{
  background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%) !important;
}

/* Le slider principal conserve son identité mais s'aligne avec les autres blocs */
.case-slider{
  border-radius:20px;
  border:1px solid rgba(0,32,80,.10);
  box-shadow:
    inset 4px 0 0 rgba(0,112,176,.88),
    0 14px 30px rgba(2,12,42,.08);
}
.case-slider::before{display:none !important;} /* on remplace l'ancien liseré par l'inset */

/* Hover homogène partout */
.card:hover,
.logo-tile:hover,
.case-slide-inner:hover,
.step-card:hover,
.sector-card:hover,
.stat-card:hover,
.cta-band-inner:hover,
.zones-mini-card:hover,
.form-wrap:hover,
.file-upload:hover{
  transform:translateY(-3px);
  border-color:rgba(0,112,176,.22);
  box-shadow:
    inset 4px 0 0 rgba(0,112,176,.95),
    0 18px 34px rgba(2,12,42,.11);
}

/* Menu : rétablit un hover visible et cohérent */
.nav-links a{
  position:relative;
}
.nav-links a:hover,
.nav-links a.active{
  transform:translateY(-1px);
  background:rgba(255,255,255,.14);
  color:#fff;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:12px; right:12px; bottom:6px;
  height:2px;
  border-radius:999px;
  background:rgba(0,143,216,.95);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .18s ease;
}
.nav-links a:hover::after,
.nav-links a.active::after{
  transform:scaleX(1);
}

/* Tuiles de collaborations : taille strictement harmonisée FR/EN */
.logo-grid{align-items:stretch}
.logo-tile{
  min-height:78px;
  height:78px;
  padding:12px 14px 12px 18px; /* laisse de l'air après le liseré */
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  line-height:1.2;
}

/* Cartes de service & moyens : même ratio visuel */
#services .card.pad,
#moyens .card.icon-card,
#contact .card.pad,
#recrutement .job-card,
#entreprise .ops-framework-card{
  border-radius:18px;
}
#services .card.pad,
#moyens .card.icon-card,
#contact .card.pad,
#recrutement .job-card,
#entreprise .ops-framework-card,
#entreprise .icon-card{
  padding-left:20px !important;
}

/* Section méthode : CTA aligné avec les autres tuiles */
.cta-band{background:transparent !important; border:none !important; box-shadow:none !important}
.cta-band-inner{
  padding-left:22px !important;
  align-items:center;
}
.cta-band .btn{box-shadow:0 10px 22px rgba(0,80,144,.20)}

/* Slide interne : un peu plus d'air pour le liseré à gauche */
.case-slide-inner{padding-left:20px !important}

/* Petites tuiles "chips"/meta : hover plus discret mais homogène */
.job-meta-item{
  background:linear-gradient(180deg,#fff,#f8fbff);
  border-color:rgba(0,32,80,.10);
}
.job-meta-item:hover{
  border-color:rgba(0,112,176,.18);
  transform:translateY(-1px);
}

/* Mobile : on réduit légèrement le liseré et le relief pour garder de la place */
@media (max-width: 720px){
  .card,
  .logo-tile,
  .case-slide-inner,
  .step-card,
  .sector-card,
  .stat-card,
  .cta-band-inner,
  .zones-mini-card,
  .form-wrap,
  .file-upload{
    box-shadow:
      inset 3px 0 0 rgba(0,112,176,.88),
      0 8px 18px rgba(2,12,42,.07);
  }
  .card:hover,
  .logo-tile:hover,
  .case-slide-inner:hover,
  .step-card:hover,
  .sector-card:hover,
  .stat-card:hover,
  .cta-band-inner:hover,
  .zones-mini-card:hover,
  .form-wrap:hover,
  .file-upload:hover{
    box-shadow:
      inset 3px 0 0 rgba(0,112,176,.95),
      0 12px 24px rgba(2,12,42,.10);
  }
  .logo-tile{padding-left:16px}
  .cta-band-inner,
  #services .card.pad,
  #moyens .card.icon-card,
  #contact .card.pad,
  #recrutement .job-card,
  #entreprise .ops-framework-card,
  #entreprise .icon-card,
  .case-slide-inner{padding-left:16px !important}
}
