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


/* ============================================================
   v30 — Carrousel d'images (img-carousel)
   Styles intégrés dans le langage visuel EST existant.
   Images de test : dégradés bleu marine identitaires.
   ============================================================ */

/* ---- Conteneur principal ---------------------------------- */
.img-carousel{
  position: relative;
  user-select: none;
}

/* ---- Viewport & track ------------------------------------- */
.img-carousel-viewport{
  overflow: hidden;
  border-radius: 20px;
  box-shadow: 0 20px 60px rgba(0,0,32,.18);
}
.img-carousel-track{
  display: flex;
  transition: transform .60s cubic-bezier(.77,0,.18,1);
  will-change: transform;
}

/* ---- Slide ------------------------------------------------ */
.img-carousel-slide{
  min-width: 100%;
  position: relative;
}
.img-carousel-img{
  position: relative;
  height: 460px;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

/* --- Images de test : dégradés dans la palette EST --------- */
.img-slide-1{
  background:
    radial-gradient(ellipse 80% 60% at 70% 30%, rgba(0,112,176,.55) 0%, transparent 65%),
    radial-gradient(ellipse 60% 70% at 10% 80%, rgba(0,58,117,.60) 0%, transparent 60%),
    linear-gradient(145deg, #000020 0%, #00153a 40%, #002050 100%);
}
.img-slide-2{
  background:
    radial-gradient(ellipse 70% 55% at 20% 25%, rgba(0,80,144,.60) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 85% 75%, rgba(0,21,58,.65) 0%, transparent 55%),
    linear-gradient(135deg, #00153a 0%, #001a45 45%, #000828 100%);
}
.img-slide-3{
  background:
    radial-gradient(ellipse 90% 50% at 50% 20%, rgba(0,58,117,.50) 0%, transparent 65%),
    radial-gradient(ellipse 55% 65% at 5% 90%, rgba(0,112,176,.40) 0%, transparent 55%),
    linear-gradient(160deg, #000020 0%, #002050 50%, #00153a 100%);
}
.img-slide-4{
  background:
    radial-gradient(ellipse 65% 65% at 80% 20%, rgba(0,112,176,.48) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 15% 70%, rgba(0,32,80,.55) 0%, transparent 58%),
    linear-gradient(120deg, #001020 0%, #001a45 38%, #002558 100%);
}
.img-slide-5{
  background:
    radial-gradient(ellipse 75% 60% at 30% 40%, rgba(0,80,144,.55) 0%, transparent 62%),
    radial-gradient(ellipse 60% 55% at 90% 80%, rgba(0,21,58,.50) 0%, transparent 55%),
    linear-gradient(155deg, #00060f 0%, #001230 42%, #002050 100%);
}

/* Motif de grille subtil (cohérent avec le hero) */
.img-carousel-img::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);
  background-size: 56px 56px;
  z-index: 1;
  pointer-events: none;
}

/* --- Overlay de texte -------------------------------------- */
.img-slide-overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 36px 38px;
  background: linear-gradient(to top,
    rgba(0,0,20,.85) 0%,
    rgba(0,0,20,.45) 45%,
    rgba(0,0,20,.08) 100%);
}
.img-slide-label{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  margin-bottom: 10px;
}
.img-slide-label::before{
  content: "";
  width: 24px;
  height: 2px;
  background: var(--blue-500);
  border-radius: 2px;
  flex: 0 0 auto;
}
.img-slide-title{
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.6vw, 1.9rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.18;
  margin-bottom: 10px;
  text-wrap: balance;
  letter-spacing: -.02em;
}
.img-slide-desc{
  font-size: .95rem;
  color: rgba(255,255,255,.78);
  line-height: 1.65;
  max-width: 620px;
}

/* --- Boutons de navigation --------------------------------- */
.img-carousel-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.22);
  background: rgba(0,0,32,.62);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: rgba(255,255,255,.88);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.img-carousel-btn svg{
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
}
.img-carousel-btn:hover{
  background: var(--blue-600);
  border-color: transparent;
  transform: translateY(-50%) scale(1.07);
}
.img-carousel-prev{ left: -20px; }
.img-carousel-next{ right: -20px; }

/* --- Pagination dots --------------------------------------- */
.img-carousel-dots{
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 22px;
}
.img-carousel-dot{
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gray-300);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .25s ease, transform .25s ease, width .25s ease;
}
.img-carousel-dot.active{
  background: var(--blue-500);
  width: 26px;
  border-radius: 999px;
  transform: none;
}

/* --- Animation d'entrée du texte par slide ----------------- */
.img-carousel-slide .img-slide-label,
.img-carousel-slide .img-slide-title,
.img-carousel-slide .img-slide-desc{
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .45s ease, transform .45s ease;
}
.img-carousel-slide.ic-active .img-slide-label{
  opacity: 1; transform: none; transition-delay: .05s;
}
.img-carousel-slide.ic-active .img-slide-title{
  opacity: 1; transform: none; transition-delay: .14s;
}
.img-carousel-slide.ic-active .img-slide-desc{
  opacity: 1; transform: none; transition-delay: .22s;
}

/* --- Responsive -------------------------------------------- */
@media (max-width: 900px){
  .img-carousel-img{ height: 380px; }
  .img-slide-overlay{ padding: 26px 28px; }
}
@media (max-width: 620px){
  .img-carousel-img{ height: 300px; }
  .img-slide-overlay{ padding: 20px 20px; }
  .img-carousel-prev{ left: -12px; }
  .img-carousel-next{ right: -12px; }
  .img-carousel-btn{ width: 40px; height: 40px; }
}


/* ============================================================
   v30b — Carrousel en fond du hero (hero--carousel)
   Les slides remplacent le gradient fixe du hero.
   ============================================================ */

/* Le hero garde ses dimensions, on enlève son gradient fixe */
.hero--carousel{
  background: var(--navy); /* fallback si JS désactivé */
}
.hero--carousel::before{
  /* On conserve le vignettage radial original mais par-dessus les slides */
  z-index: 3;
  pointer-events: none;
}

/* Conteneur du carrousel : couvre tout le hero en absolu */
.hero-bg-carousel{
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

/* Track : flex horizontal, les slides se superposent par cross-fade */
.hero-bg-track{
  position: absolute;
  inset: 0;
}

/* Chaque slide = fond plein couvrant tout le hero */
.hero-bg-slide{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.1s ease;
}
.hero-bg-slide.ic-active{
  opacity: 1;
}

/* Réutilisation des dégradés définis précédemment */
.hero-bg-slide.img-slide-1{
  background:
    radial-gradient(ellipse 80% 60% at 70% 30%, rgba(0,112,176,.55) 0%, transparent 65%),
    radial-gradient(ellipse 60% 70% at 10% 80%, rgba(0,58,117,.60) 0%, transparent 60%),
    linear-gradient(145deg, #000020 0%, #00153a 40%, #002050 100%);
}
.hero-bg-slide.img-slide-2{
  background:
    radial-gradient(ellipse 70% 55% at 20% 25%, rgba(0,80,144,.60) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 85% 75%, rgba(0,21,58,.65) 0%, transparent 55%),
    linear-gradient(135deg, #00153a 0%, #001a45 45%, #000828 100%);
}
.hero-bg-slide.img-slide-3{
  background:
    radial-gradient(ellipse 90% 50% at 50% 20%, rgba(0,58,117,.50) 0%, transparent 65%),
    radial-gradient(ellipse 55% 65% at 5% 90%, rgba(0,112,176,.40) 0%, transparent 55%),
    linear-gradient(160deg, #000020 0%, #002050 50%, #00153a 100%);
}
.hero-bg-slide.img-slide-4{
  background:
    radial-gradient(ellipse 65% 65% at 80% 20%, rgba(0,112,176,.48) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 15% 70%, rgba(0,32,80,.55) 0%, transparent 58%),
    linear-gradient(120deg, #001020 0%, #001a45 38%, #002558 100%);
}
.hero-bg-slide.img-slide-5{
  background:
    radial-gradient(ellipse 75% 60% at 30% 40%, rgba(0,80,144,.55) 0%, transparent 62%),
    radial-gradient(ellipse 60% 55% at 90% 80%, rgba(0,21,58,.50) 0%, transparent 55%),
    linear-gradient(155deg, #00060f 0%, #001230 42%, #002050 100%);
}

/* Overlay d'assombrissement pour lisibilité du texte */
.hero-bg-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0,0,20,.50) 0%,
    rgba(0,0,20,.30) 50%,
    rgba(0,0,20,.55) 100%
  );
  z-index: 1;
}

/* La grille reste au-dessus de l'overlay */
.hero--carousel .hero-grid{
  z-index: 2;
}

/* Le contenu texte au-dessus de tout */
.hero--carousel .container{
  position: relative;
  z-index: 4;
}

/* Boutons prev/next positionnés dans le hero */
.hero--carousel .img-carousel-btn{
  position: absolute;
  z-index: 5;
  top: 50%;
  transform: translateY(-50%);
}
.hero--carousel .img-carousel-prev{ left: 20px; }
.hero--carousel .img-carousel-next{ right: 20px; }

/* Dots en bas du hero */
.hero--carousel .img-carousel-dots{
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 5;
  display: flex;
  gap: 8px;
}
/* Dots blancs sur fond sombre */
.hero--carousel .img-carousel-dot{
  background: rgba(255,255,255,.35);
}
.hero--carousel .img-carousel-dot.active{
  background: rgba(255,255,255,.92);
}

@media (max-width: 720px){
  .hero--carousel .img-carousel-prev{ left: 10px; }
  .hero--carousel .img-carousel-next{ right: 10px; }
  .hero--carousel .img-carousel-btn{ width: 40px; height: 40px; }
}


/* ============================================================
   v30c — Fix boutons carousel + images de test réelles
   ============================================================ */

/* --- Images de test (remplacer par vos vraies photos) ------- */
/* Dossier : assets/img/carousel/
   Fichiers : slide-1.jpg à slide-5.jpg  (1600×900 recommandé) */
.hero-bg-slide.img-slide-1{ background-image: url('../img/carousel/slide-1.jpg'); background-size:cover; background-position:center; }
.hero-bg-slide.img-slide-2{ background-image: url('../img/carousel/slide-2.jpg'); background-size:cover; background-position:center; }
.hero-bg-slide.img-slide-3{ background-image: url('../img/carousel/slide-3.jpg'); background-size:cover; background-position:center; }
.hero-bg-slide.img-slide-4{ background-image: url('../img/carousel/slide-4.jpg'); background-size:cover; background-position:center; }
.hero-bg-slide.img-slide-5{ background-image: url('../img/carousel/slide-5.jpg'); background-size:cover; background-position:center; }

/* --- Boutons prev/next directement dans le <header> --------- */
/* (positionnés hors du hero-bg-carousel pour éviter le piège z-index) */
.hero-carousel-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;                      /* au-dessus de TOUT dans le hero */
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.30);
  background: rgba(0,0,30,.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.hero-carousel-btn svg{ width:22px; height:22px; flex:0 0 auto; }
.hero-carousel-btn:hover{
  background: var(--blue-600);
  border-color: transparent;
  transform: translateY(-50%) scale(1.08);
}
.hero-carousel-prev{ left: 22px; }
.hero-carousel-next{ right: 22px; }

/* --- Dots directement dans le <header> ---------------------- */
.hero-carousel-dots{
  position: absolute;
  bottom: 26px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  display: flex;
  gap: 8px;
  align-items: center;
}
.hero-carousel-dot{
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .25s ease, width .25s ease;
}
.hero-carousel-dot.active{
  background: rgba(255,255,255,.92);
  width: 26px;
  border-radius: 999px;
}

@media (max-width: 720px){
  .hero-carousel-prev{ left: 10px; }
  .hero-carousel-next{ right: 10px; }
  .hero-carousel-btn{ width: 42px; height: 42px; }
}


/* ============================================================
   v30d — Carousel dynamique PHP : styles génériques
   Les images sont injectées en style inline par PHP,
   plus besoin des classes img-slide-1 à img-slide-N.
   ============================================================ */

/* Slide chargée dynamiquement : background-image en inline style */
.hero-bg-slide{
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Fallback si aucune image dans le dossier */
.hero-bg-fallback{
  background:
    radial-gradient(ellipse 70% 55% at 70% 25%, rgba(0,112,176,.45) 0%, transparent 65%),
    radial-gradient(ellipse 55% 60% at 10% 80%, rgba(0,58,117,.50) 0%, transparent 58%),
    linear-gradient(145deg, #000020 0%, #00153a 45%, #002050 100%);
}

/* ic-active = slide visible, ic-hidden = invisible */
.hero-bg-slide.ic-active  { opacity: 1; }
.hero-bg-slide.ic-hidden  { opacity: 0; }



/* ===== v33 — Harmonisation finale EST =====
   Correctifs ciblés :
   - carrousel hero pleine largeur avec meilleure lisibilité
   - sélecteur de langue (drapeaux + menu déroulant)
   - harmonisation des tuiles (liseré bleu à gauche)
   - réduction des espaces blancs entre sections
   - style de boutons de formulaire plus propre
   ======================================================== */

/* 1) Espacement vertical global : on compacte légèrement le site */
.hero{margin-bottom:0 !important;}
.hero + .section{padding-top:34px !important;}
.section{padding:54px 0 !important;}
.section + .section{padding-top:34px !important;}
.section.alt{padding:54px 0 !important;}
.container.case-slider-wrap{margin-top:0 !important;}

/* 2) Hero carrousel : fond photo + texte lisible */
.hero.hero--carousel{
  position:relative;
  overflow:hidden;
  min-height:720px;
  background:#00153a !important;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.hero.hero--carousel .hero-grid{
  opacity:.18;
  z-index:2;
  background-size: 52px 52px;
}
.hero-bg-carousel{position:absolute; inset:0; z-index:0; overflow:hidden;}
.hero-bg-track{position:absolute; inset:0;}
.hero-bg-slide{position:absolute; inset:0; opacity:0; transform:scale(1.03); transition:opacity .9s ease, transform 6.5s ease; background-size:cover; background-position:center; background-repeat:no-repeat;}
.hero-bg-slide.ic-active{opacity:1 !important; transform:scale(1);}
.hero-bg-slide.ic-hidden{opacity:0 !important;}
.hero-bg-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(90deg, rgba(0,8,26,.78) 0%, rgba(0,16,50,.58) 46%, rgba(0,20,60,.36) 100%),
    linear-gradient(180deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,.35) 100%);
  pointer-events:none;
}
.hero.hero--carousel .container{position:relative; z-index:4;}
.hero.hero--carousel .hero-content{max-width:880px; padding-right:18px;}
.hero.hero--carousel .badge{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.28);
  color:#F4F8FF;
  box-shadow:0 6px 20px rgba(0,0,0,.14);
  backdrop-filter: blur(6px);
}
.hero.hero--carousel h1,
.hero.hero--carousel .hero-text,
.hero.hero--carousel .hero-slogan .l1,
.hero.hero--carousel .hero-slogan .l2{color:#fff !important; text-shadow:0 2px 16px rgba(0,0,0,.22);}
.hero.hero--carousel .hero-text{max-width:760px; font-weight:500; color:rgba(255,255,255,.93) !important;}
.hero.hero--carousel .btn-outline{
  color:#fff !important;
  border-color:rgba(255,255,255,.42) !important;
  background:rgba(255,255,255,.08) !important;
  backdrop-filter: blur(6px);
}
.hero.hero--carousel .btn-outline:hover{background:rgba(255,255,255,.14) !important;}
.hero.hero--carousel .hero-slogan{
  border-top:1px solid rgba(255,255,255,.18);
  margin-top:18px;
  padding-top:14px;
  max-width:760px;
}
.metrics-strip{
  margin-top:16px !important;
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:10px;
  max-width:920px;
}
.metric-chip{
  position:relative;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.08)) !important;
  border:1px solid rgba(255,255,255,.22) !important;
  border-radius:16px !important;
  padding:12px 14px 12px 16px !important;
  box-shadow:0 12px 28px rgba(0,0,0,.14);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.metric-chip::before{
  content:'';
  position:absolute;
  left:0; top:8px; bottom:8px;
  width:4px;
  border-radius:0 8px 8px 0;
  background:linear-gradient(180deg, #39B7FF, #006FB0);
  opacity:.95;
}
.metric-chip .k{display:block; color:#fff !important; font-weight:800; margin-left:2px;}
.metric-chip .v{display:block; color:rgba(235,245,255,.92) !important; font-size:.91rem; line-height:1.35; margin-top:4px;}

.hero-carousel-btn{
  position:absolute; z-index:5; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%; border:1px solid rgba(255,255,255,.28);
  background:rgba(5,14,34,.52); color:#fff; display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  box-shadow:0 8px 26px rgba(0,0,0,.25);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.hero-carousel-btn:hover{background:rgba(0,111,176,.88); border-color:rgba(255,255,255,.5); transform:translateY(-50%) scale(1.05);}
.hero-carousel-prev{left:18px;} .hero-carousel-next{right:18px;}
.hero-carousel-dots{position:absolute; left:50%; transform:translateX(-50%); bottom:18px; z-index:5; display:flex; gap:8px;}
.hero-carousel-dot{width:8px; height:8px; border-radius:999px; border:0; background:rgba(255,255,255,.36); padding:0; cursor:pointer; transition:.2s ease;}
.hero-carousel-dot.active{width:26px; background:#fff;}

/* 3) Sélecteur de langue : dropdown avec drapeaux */
.nav-right{display:flex; align-items:center; gap:10px;}
.lang-switch{display:none !important;}
.lang-item--mobile .lang-link{display:flex; align-items:center; gap:6px;}
.lang-menu{position:relative;}
.lang-menu-summary{
  list-style:none;
  display:flex; align-items:center; gap:8px;
  min-height:42px;
  padding:0 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.04);
  color:#fff;
  cursor:pointer;
  user-select:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.lang-menu-summary::-webkit-details-marker{display:none;}
.lang-menu-summary .flag{font-size:1rem; line-height:1;}
.lang-menu-summary .txt{font-weight:700; font-size:.9rem;}
.lang-menu-summary svg{width:16px; height:16px; opacity:.9; transition:transform .18s ease;}
.lang-menu[open] .lang-menu-summary svg{transform:rotate(180deg);}
.lang-menu-list{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:170px;
  background:#fff;
  border:1px solid rgba(0,80,144,.15);
  border-radius:14px;
  padding:6px;
  box-shadow:0 16px 36px rgba(2,12,42,.16);
  display:grid;
  gap:4px;
  z-index:50;
}
.lang-menu-list a{
  display:flex; align-items:center; gap:8px;
  text-decoration:none; color:var(--navy);
  font-weight:600; font-size:.92rem;
  border-radius:10px;
  padding:9px 10px;
}
.lang-menu-list a:hover{background:#F1F7FD; color:var(--blue-700);}

/* 4) Harmonisation des cartes / tuiles (liseré bleu à gauche) */
.icon-card, .step-card, .stat-card, .ops-framework-card, .case-slide-inner, .logo-tile, .card{
  border-radius:18px !important;
  border:1px solid rgba(0,112,176,.12) !important;
}
.icon-card, .step-card, .stat-card, .ops-framework-card, .case-slide-inner{
  position:relative;
  overflow:hidden;
}
.icon-card::before, .step-card::before, .stat-card::before, .ops-framework-card::before, .case-slide-inner::before{
  content:'';
  position:absolute;
  left:0; top:10px; bottom:10px;
  width:4px;
  border-radius:0 8px 8px 0;
  background:linear-gradient(180deg, #39B7FF, #006FB0) !important;
  opacity:.95;
  z-index:0;
}
.icon-card > *, .step-card > *, .stat-card > *, .ops-framework-card > *, .case-slide-inner > *{position:relative; z-index:1;}

/* 5) Slider secteurs / flux : design plus compact et lisible */
.case-slider{
  position:relative;
  padding:14px 14px 10px !important;
  border-radius:22px !important;
  border:1px solid rgba(0,112,176,.16) !important;
  background:linear-gradient(180deg,#ffffff,#f6fafe) !important;
  box-shadow:0 14px 30px rgba(2,12,42,.08) !important;
}
.case-slider-head{
  padding:0 2px 12px 2px !important;
  margin:0 0 10px 0 !important;
  border-bottom:1px solid rgba(0,80,144,.10) !important;
}
.case-slider-title{font-size:1.05rem !important; font-weight:800 !important;}
.case-slider .slider-viewport{padding:2px 0 4px !important; overflow:hidden;}
.case-slide{padding:0 !important;}
.case-slide-inner{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,.95fr);
  gap:16px;
  padding:18px 18px 18px 22px !important;
  border-radius:18px !important;
  background:#fff !important;
  box-shadow:none !important;
  min-height:170px;
}
.case-slide h3{margin:0 0 8px 0 !important; font-size:1.08rem !important; line-height:1.3;}
.case-slide p{margin:0 !important; color:#334155 !important; line-height:1.55;}
.case-badges{margin-top:14px !important; display:flex; flex-wrap:wrap; gap:8px;}
.case-badge{
  border-radius:999px !important;
  border:1px solid rgba(0,112,176,.16) !important;
  background:#F3F8FD !important;
  color:#0D3C75 !important;
  padding:7px 11px !important;
  font-weight:700 !important;
  font-size:.86rem !important;
}
.case-panel{
  border-radius:14px !important;
  border:1px solid rgba(0,112,176,.10) !important;
  background:linear-gradient(180deg,#F6FAFF,#EEF5FC) !important;
  padding:14px 14px 12px !important;
  align-self:stretch;
}
.case-panel h4{margin:0 0 8px 0 !important; color:var(--navy) !important; font-size:.95rem !important;}
.case-list{margin:0 !important; padding-left:16px !important;}
.case-list li{margin:0 0 6px 0 !important; color:#334155 !important; line-height:1.45;}
.case-slider-controls .slider-btn{
  width:36px; height:36px; border-radius:10px !important;
  border:1px solid rgba(0,112,176,.12) !important;
  background:#fff !important;
  color:var(--navy) !important;
}
.case-slider-controls .slider-btn:hover{background:#F2F8FE !important; color:var(--blue-700) !important;}
.slider-dots{margin-top:10px !important; justify-content:center;}

/* 6) Carte "Méthode / Cadre de service" plus moderne et harmonisée */
.ops-framework-card{
  background:linear-gradient(180deg,#ffffff,#F8FBFF) !important;
  box-shadow:0 14px 30px rgba(2,12,42,.07) !important;
  padding:20px 18px 18px 22px !important;
}
.ops-framework-card .list li{margin-bottom:9px;}
.ops-framework-card .dot{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:22px; height:22px;
  border-radius:999px;
  background:linear-gradient(180deg,#1EAFFF,#006FB0) !important;
  color:#fff;
  font-weight:700;
  box-shadow:0 4px 12px rgba(0,111,176,.25);
}
.ops-framework-note{color:#475569 !important;}

/* 7) Boutons de formulaires : plus propres / cohérents */
.form-submit{
  appearance:none;
  border:1px solid rgba(0,80,144,.10) !important;
  background:linear-gradient(180deg,#0D9EEA 0%, #007BC4 100%) !important;
  color:#fff !important;
  font-weight:700 !important;
  letter-spacing:.01em;
  min-height:44px;
  border-radius:12px !important;
  padding:0 14px !important;
  box-shadow:0 10px 22px rgba(0,111,176,.18);
}
.form-submit:hover{transform:translateY(-1px); box-shadow:0 14px 26px rgba(0,111,176,.22);}
.form-submit:disabled{opacity:.65; cursor:not-allowed; transform:none;}

/* 8) Ajustements mobile */
@media (max-width: 980px){
  .hero.hero--carousel{min-height:680px;}
  .metrics-strip{grid-template-columns:1fr; max-width:640px;}
  .hero-carousel-btn{display:none;}
  .case-slide-inner{grid-template-columns:1fr; gap:12px; min-height:auto;}
  .lang-menu-summary .txt{display:none;}
  .lang-menu-summary{padding:0 10px; min-width:44px; justify-content:center;}
  .lang-menu-list{right:auto; left:0;}
}
@media (max-width: 720px){
  .hero.hero--carousel{min-height:640px;}
  .hero.hero--carousel .hero-content{padding-right:0;}
  .hero.hero--carousel .hero-text{font-size:.98rem;}
  .metric-chip{padding:10px 12px 10px 14px !important;}
  .section{padding:44px 0 !important;}
  .case-slider{padding:12px 10px 8px !important; border-radius:18px !important;}
  .case-slider-title{font-size:1rem !important;}
  .case-slide-inner{padding:14px 12px 14px 16px !important; border-radius:14px !important;}
}


/* === v34 refinements start ===
   Harmonisation finale : hero carousel, collaborations, slider secteurs, espacements
   Ces règles surchargent proprement les versions précédentes sans casser le site.
=== */

/* 1) HERO : montrer les images (moins d'opacité), garder la lisibilité du texte */
.hero.hero--carousel{
  position:relative;
  min-height:660px !important;
  padding:0 !important;
}
.hero-bg-carousel{position:absolute; inset:0; overflow:hidden;}
.hero-bg-slide{
  background-size:cover !important;
  background-position:center center !important;
  transform:scale(1.02);
  transition:opacity .55s ease, transform 6s ease;
}
.hero-bg-slide.ic-active{transform:scale(1.05);}
.hero-bg-overlay{
  background:
    linear-gradient(90deg, rgba(2,8,28,.78) 0%, rgba(2,12,36,.68) 34%, rgba(2,12,36,.34) 62%, rgba(2,12,36,.22) 100%),
    linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.16) 100%) !important;
}
.hero.hero--carousel .container{position:relative; z-index:3; height:100%;}
.hero.hero--carousel .hero-content{
  max-width:760px !important;
  padding:92px 0 58px !important;
  position:relative;
}
.hero.hero--carousel .hero-content::before{
  content:"";
  position:absolute;
  inset:76px -24px 18px -18px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(4,16,44,.30), rgba(4,16,44,.16));
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(4px);
  box-shadow:0 18px 42px rgba(0,0,0,.18);
  z-index:-1;
}
.hero.hero--carousel h1{max-width:680px; line-height:.98;}
.hero.hero--carousel .hero-text{
  max-width:660px;
  color:rgba(255,255,255,.94) !important;
  text-shadow:0 1px 0 rgba(0,0,0,.22);
}
.hero-slogan{
  margin-top:14px !important;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.22);
  max-width:620px;
}
.hero-slogan .l1,.hero-slogan .l2{color:#fff !important; text-shadow:0 1px 2px rgba(0,0,0,.25);}
.hero-slogan .l2{opacity:.94;}
.metrics-strip{
  margin-top:14px !important;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  max-width:820px;
}
.metric-chip{
  position:relative;
  min-height:76px;
  border-radius:16px !important;
  border:1px solid rgba(255,255,255,.20) !important;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.08)) !important;
  color:#fff !important;
  box-shadow:0 10px 20px rgba(0,0,0,.15);
  backdrop-filter: blur(3px);
  padding:12px 12px 12px 16px !important;
}
.metric-chip::before{
  content:""; position:absolute; left:0; top:8px; bottom:8px; width:4px;
  border-radius:0 8px 8px 0; background:linear-gradient(180deg,#3CC0FF,#0078C4);
}
.metric-chip .k,.metric-chip .v{color:#fff !important;}
.metric-chip .k{font-weight:800; letter-spacing:.01em;}
.metric-chip .v{opacity:.92; font-size:.86rem;}
.hero-carousel-btn{
  background:rgba(6,20,52,.45) !important;
  border:1px solid rgba(255,255,255,.28) !important;
  backdrop-filter: blur(3px);
}
.hero-carousel-btn:hover{background:rgba(8,28,70,.65) !important; transform:translateY(-1px);}
.hero-carousel-dots{bottom:14px !important;}
.hero-carousel-dot{background:rgba(255,255,255,.40) !important;}
.hero-carousel-dot.active{background:#fff !important; width:26px !important;}

/* 2) Espacements : supprimer les blancs excessifs entre blocs */
.section{padding:34px 0 !important;}
.section:first-of-type{padding-top:0 !important;}
.section-collabs{padding-top:24px !important; padding-bottom:20px !important;}
.section-cases--floating{
  margin-top:-6px;
  padding-top:0 !important;
  padding-bottom:30px !important;
}
.container.case-slider-wrap{margin-top:0 !important;}

/* 3) Collaborations : conserver la section + style premium harmonisé */
.section-collabs .section-subtitle{max-width:860px; color:var(--gray-500);}
.logo-grid{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:12px !important;
  margin-top:10px !important;
}
.logo-tile{
  position:relative;
  min-height:78px !important;
  display:flex; align-items:center; justify-content:center;
  border-radius:16px !important;
  border:1px solid rgba(0,112,176,.15) !important;
  background:linear-gradient(180deg,#ffffff,#f7fbff) !important;
  font-weight:800 !important;
  color:var(--navy) !important;
  overflow:hidden;
}
.logo-tile::before{
  content:""; position:absolute; inset:0 auto 0 0; width:4px;
  background:linear-gradient(180deg,#39B7FF,#006FB0); opacity:.95;
}
.logo-tile:hover{transform:translateY(-2px); box-shadow:0 12px 24px rgba(2,12,42,.10) !important;}

/* 4) Secteurs & flux : intégrer visuellement au hero (moins de vide, plus moderne) */
.case-slider-wrap{
  position:relative;
  z-index:4;
}
.case-slider{
  position:relative;
  padding:12px 12px 10px !important;
  border-radius:20px !important;
  border:1px solid rgba(0,112,176,.14) !important;
  background:linear-gradient(180deg, rgba(255,255,255,.97), rgba(247,251,255,.97)) !important;
  box-shadow:0 14px 30px rgba(2,12,42,.10) !important;
}
.case-slider::after{
  content:""; position:absolute; inset:0 auto 0 0; width:4px; border-radius:20px 0 0 20px;
  background:linear-gradient(180deg,#39B7FF,#006FB0);
}
.case-slider-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:2px 4px 12px 8px !important;
  border-bottom:1px solid rgba(0,80,144,.10) !important;
  margin:0 0 8px 0 !important;
}
.case-slider-title{font-size:1rem !important; color:var(--navy) !important; font-weight:800 !important;}
.case-slider .slider-viewport{padding:2px 2px 2px 2px !important;}
.case-slide{padding:0 !important;}
.case-slide-inner{
  display:grid !important;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr) !important;
  gap:14px !important;
  padding:16px !important;
  min-height:156px !important;
  border-radius:16px !important;
  border:1px solid rgba(0,112,176,.08) !important;
  background:linear-gradient(180deg,#fff,#fbfdff) !important;
  box-shadow:none !important;
}
.case-slide-inner > div:first-child{
  position:relative; padding-left:12px;
}
.case-slide-inner > div:first-child::before{
  content:""; position:absolute; left:0; top:2px; bottom:2px; width:4px; border-radius:0 8px 8px 0;
  background:linear-gradient(180deg,#39B7FF,#006FB0);
}
.case-slide h3{font-size:1.02rem !important; margin:0 0 8px !important;}
.case-slide p{font-size:.95rem !important; color:#334155 !important; line-height:1.5 !important;}
.case-badges{margin-top:10px !important; gap:8px !important;}
.case-badge{
  background:#EDF5FF !important;
  border:1px solid rgba(0,112,176,.14) !important;
  color:#0D3C75 !important;
  font-size:.82rem !important;
  font-weight:700 !important;
  padding:6px 10px !important;
  border-radius:999px !important;
}
.case-panel{
  border-radius:14px !important;
  border:1px solid rgba(0,112,176,.10) !important;
  background:linear-gradient(180deg,#F4F9FF,#EEF5FC) !important;
  padding:12px 12px 10px !important;
}
.case-panel h4{margin:0 0 8px !important; font-size:.93rem !important;}
.case-list{padding-left:16px !important;}
.case-list li{margin:0 0 6px !important; line-height:1.4 !important;}
.slider-dots{margin-top:8px !important;}
.slider-dot{width:8px; height:8px;}
.slider-dot.active{width:22px;}

/* 5) Petits ajustements visuels globaux */
.btn.btn-outline{background:rgba(255,255,255,.10) !important; border-color:rgba(255,255,255,.38) !important;}
.btn.btn-outline:hover{background:rgba(255,255,255,.18) !important;}
.form-tabs, .form-card, .card, .icon-card, .step-card, .stat-card, .ops-framework-card{border-radius:18px !important;}

/* 6) Responsive */
@media (max-width: 1100px){
  .hero.hero--carousel .hero-content{max-width:700px !important;}
  .metrics-strip{grid-template-columns:1fr; max-width:560px;}
}
@media (max-width: 768px){
  .hero.hero--carousel{min-height:720px !important;}
  .hero.hero--carousel .hero-content{padding:88px 0 54px !important;}
  .hero.hero--carousel .hero-content::before{inset:70px -10px 10px -8px; border-radius:18px;}
  .hero.hero--carousel h1{font-size:clamp(2.1rem,10vw,3rem) !important;}
  .hero.hero--carousel .hero-text{max-width:none; font-size:.96rem !important;}
  .hero-carousel-btn{display:none !important;}
  .hero-carousel-dots{bottom:8px !important;}
  .section{padding:28px 0 !important;}
  .section-collabs{padding-top:16px !important;}
  .logo-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important; gap:10px !important;}
  .logo-tile{min-height:66px !important; font-size:.9rem !important; padding:0 8px;}
  .case-slider{padding:10px 8px 8px !important; border-radius:16px !important;}
  .case-slider-head{padding:2px 2px 10px 6px !important;}
  .case-slider-title{font-size:.95rem !important;}
  .case-slide-inner{grid-template-columns:1fr !important; gap:10px !important; padding:12px !important; min-height:auto !important;}
}

/* === v34 refinements end === */


/* === v35 fix — mobile header + hero carousel runtime/caching ===
   - Corrige l'affichage du nom en mobile
   - Réduit la largeur CTA/langue sur petits écrans
   - Renforce la visibilité des images du hero
   ============================================================ */

/* Hero : on garde la lisibilité mais on laisse mieux voir la photo */
.hero-bg-overlay{
  background:
    linear-gradient(90deg, rgba(2,8,28,.70) 0%, rgba(2,12,36,.56) 34%, rgba(2,12,36,.28) 64%, rgba(2,12,36,.16) 100%),
    linear-gradient(180deg, rgba(0,0,0,.03) 0%, rgba(0,0,0,.10) 100%) !important;
}
.hero.hero--carousel .hero-content::before{
  background:linear-gradient(180deg, rgba(4,16,44,.22), rgba(4,16,44,.10)) !important;
}

/* Mobile navbar : éviter l'ellipse "E..." sur le nom */
@media (max-width: 560px){
  .nav-inner{gap:8px !important; grid-template-columns:auto auto auto !important;}
  .nav-logo{min-width:auto !important; gap:8px !important;}
  .nav-logo img{width:42px !important; height:42px !important;}
  .nav-logo-text{
    max-width:none !important;
    overflow:visible !important;
    text-overflow:clip !important;
    white-space:nowrap !important;
    font-size:.92rem !important;
    line-height:1 !important;
  }
  .nav-logo-text span{display:none !important;}
  .nav-right{gap:8px !important; min-width:auto !important;}
  .nav-right .btn-primary{
    min-width:100px !important;
    padding:10px 12px !important;
    border-radius:12px !important;
    font-size:.86rem !important;
  }
  .lang-menu-summary{
    min-width:40px !important;
    padding:0 8px !important;
    height:42px !important;
  }
  .lang-menu-summary .txt{display:none !important;}
  .lang-menu-summary svg{width:14px !important; height:14px !important;}
}

/* Très petits mobiles : on masque le texte (logo seul) pour garantir une barre propre */
@media (max-width: 460px){
  .nav-logo-text{display:none !important;}
  .nav-right .btn-primary{min-width:92px !important;}
}

/* Les contrôles du carrousel restent cliquables au-dessus du contenu */
.hero-carousel-btn,
.hero-carousel-dots{z-index:6 !important;}
.hero-bg-slide{will-change: opacity, transform;}


/* ===== v36 — Ajustement hero carrousel (moins zoomé + fond plus clair) =====
   - Desktop : images affichées en pleine hauteur (moins de crop/zoom)
   - Overlay bleu éclairci pour mieux voir les visuels
   - Mobile : on conserve cover pour éviter les bandes vides
   ======================================================== */
.hero.hero--carousel .hero-grid{opacity:.10 !important;}
.hero-bg-slide{filter:brightness(1.12) saturate(1.06);}
.hero-bg-overlay{
  background:
    linear-gradient(90deg, rgba(0,8,26,.50) 0%, rgba(0,16,50,.28) 44%, rgba(0,20,60,.10) 100%),
    linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.18) 100%) !important;
}
@media (min-width: 992px){
  .hero-bg-slide{
    /* Affiche l'image sur toute la hauteur du hero pour réduire l'effet zoom */
    background-size:auto 100% !important;
    background-position:right center !important;
    transform:none !important;
    transition:opacity .8s ease !important;
  }
  .hero-bg-slide.ic-active{transform:none !important;}
}
@media (max-width: 991px){
  .hero-bg-slide{
    background-size:cover !important;
    background-position:center center !important;
    filter:brightness(1.08) saturate(1.04);
  }
  .hero-bg-overlay{
    background:
      linear-gradient(180deg, rgba(0,10,28,.46) 0%, rgba(0,14,42,.38) 36%, rgba(0,20,60,.24) 100%),
      linear-gradient(180deg, rgba(0,0,0,.06) 0%, rgba(0,0,0,.14) 100%) !important;
  }
}

/* ===== v37 — Hero carousel plein cadre + voile plus clair =====
   Corrections :
   1) Les images remplissent de nouveau tout le hero (desktop + mobile)
   2) Voile bleu nettement éclairci pour mieux voir les visuels
   3) Zoom/Ken Burns réduit pour éviter l'effet trop zoomé
   =============================================================== */

/* Réduit le voile sombre hérité des versions précédentes */
.hero.hero--carousel::before{
  background: linear-gradient(
    90deg,
    rgba(2, 8, 24, .16) 0%,
    rgba(2, 12, 36, .08) 42%,
    rgba(2, 12, 36, .03) 100%
  ) !important;
}

/* Grille plus discrète pour laisser respirer les photos */
.hero.hero--carousel .hero-grid{
  opacity: .06 !important;
}

/* Slides : toujours en cover (plus de bandes vides) + zoom très léger seulement */
.hero-bg-slide{
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  transform: scale(1.005) !important;
  transition: opacity .65s ease, transform 5.5s ease !important;
  filter: brightness(1.18) saturate(1.08) contrast(1.03) !important;
}
.hero-bg-slide.ic-active{
  transform: scale(1.015) !important;
}

/* Focal point desktop : décale légèrement vers la droite pour garder le texte lisible à gauche */
@media (min-width: 992px){
  .hero-bg-slide{
    background-position: 62% center !important;
  }
}

/* Focal point mobile : recentre */
@media (max-width: 991px){
  .hero-bg-slide{
    background-position: center center !important;
    filter: brightness(1.14) saturate(1.06) contrast(1.02) !important;
  }
}

/* Voile bleu éclairci (on garde la lisibilité du texte, mais on voit enfin les photos) */
.hero-bg-overlay{
  background:
    linear-gradient(90deg,
      rgba(2, 8, 24, .28) 0%,
      rgba(2, 12, 36, .18) 34%,
      rgba(2, 12, 36, .09) 62%,
      rgba(2, 12, 36, .04) 100%),
    linear-gradient(180deg,
      rgba(0,0,0,.02) 0%,
      rgba(0,0,0,.08) 100%) !important;
}

/* Légère amélioration de lisibilité texte sans re-noircir tout le hero */
.hero.hero--carousel .hero-content{
  text-shadow: 0 1px 1px rgba(0,0,0,.20);
}


/* =====================================================================
   V40 — Premium hero carousel + micro-animations (override final)
   ---------------------------------------------------------------------
   Ce bloc est placé en fin de fichier pour écraser proprement les styles
   historiques accumulés des versions précédentes.
   ===================================================================== */

/* HERO : rendu premium, plus lumineux, sans noyer les photos */
.hero.hero--carousel{
  position: relative;
  min-height: clamp(560px, 78vh, 760px) !important;
  isolation: isolate;
  overflow: clip;
}
.hero.hero--carousel::before{
  /* voile global très léger (on garde la photo visible) */
  background:
    linear-gradient(100deg, rgba(1,10,34,.34) 0%, rgba(1,14,44,.22) 34%, rgba(2,28,74,.14) 62%, rgba(0,70,135,.16) 100%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.18)) !important;
}
.hero.hero--carousel::after{
  content: "";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    radial-gradient(900px 340px at 18% 18%, rgba(0,153,255,.13), transparent 62%),
    radial-gradient(1100px 420px at 86% 82%, rgba(0,110,210,.12), transparent 70%);
}
.hero.hero--carousel .hero-grid{
  opacity: .06 !important;
  z-index: 1 !important;
}

/* Slides : vrai fondu + recadrage hero plein écran */
.hero-bg-carousel,
.hero-bg-track{ position:absolute; inset:0; z-index:0; }
.hero-bg-slide{
  position:absolute;
  inset:0;
  opacity:0 !important;
  transform:scale(1.02);
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  transition: opacity .95s cubic-bezier(.22,.61,.36,1), transform 7.2s ease-out !important;
  filter: brightness(1.07) saturate(1.06) contrast(1.02);
  will-change: opacity, transform;
}
.hero-bg-slide.ic-active{
  opacity:1 !important;
  transform:scale(1.00) !important;
  z-index:2;
}
.hero-bg-slide.ic-hidden{ opacity:0 !important; z-index:1; }
.hero-bg-slide.ic-enter{ animation: heroSlideFade .95s ease; }
@keyframes heroSlideFade{
  from { opacity:0; }
  to   { opacity:1; }
}
@keyframes heroKenBurns{
  from { transform:scale(1.04); }
  to   { transform:scale(1.00); }
}
.hero-bg-slide.ic-active{ animation: heroKenBurns 7.2s ease-out both; }

/* Overlay spécifique au carrousel (plus clair que les versions précédentes) */
.hero-bg-overlay{
  background:
    linear-gradient(90deg, rgba(2,10,34,.26) 0%, rgba(2,10,34,.18) 28%, rgba(2,14,42,.12) 50%, rgba(3,25,68,.12) 100%),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.16)) !important;
  z-index:1 !important;
}

/* Bloc texte premium (glass panel discret) */
.hero.hero--carousel .container{ position:relative; z-index:5 !important; }
.hero.hero--carousel .hero-content{
  position:relative;
  max-width: 760px !important;
  padding: 92px 0 64px !important;
}
.hero.hero--carousel .hero-content::before{
  content: "";
  position: absolute;
  inset: 64px -22px 10px -18px;
  border-radius: 20px;
  background: linear-gradient(160deg, rgba(7,20,58,.42), rgba(6,16,46,.20));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 50px rgba(1,8,28,.24);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: -1;
}
.hero.hero--carousel .badge{
  backdrop-filter: blur(6px);
  background: rgba(255,255,255,.16) !important;
  border-color: rgba(255,255,255,.28) !important;
}
.hero.hero--carousel h1,
.hero.hero--carousel .hero-text,
.hero.hero--carousel .hero-slogan .l1,
.hero.hero--carousel .hero-slogan .l2{
  text-shadow: 0 6px 20px rgba(0,0,0,.22) !important;
}
.hero.hero--carousel .hero-text{
  color: rgba(255,255,255,.96) !important;
  line-height: 1.55 !important;
}
.hero.hero--carousel .hero-slogan{
  background: rgba(4,13,38,.22) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  backdrop-filter: blur(4px);
}
.hero.hero--carousel .hero-slogan::before{
  background: linear-gradient(90deg, rgba(53,195,255,.95), rgba(0,112,176,.95)) !important;
  box-shadow: 0 0 18px rgba(53,195,255,.34);
}

/* Boutons hero + contrôles : style premium */
.hero.hero--carousel .btn,
.hero-carousel-btn,
.slider-btn,
.logo-tile,
.case-slide-inner,
.icon-card,
.step-card,
.stat-card,
.card{
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background-color .25s ease, opacity .25s ease;
}
.hero.hero--carousel .btn{
  position: relative;
  overflow: hidden;
}
.hero.hero--carousel .btn::after{
  content: "";
  position: absolute;
  top: -20%; bottom: -20%;
  left: -38%;
  width: 28%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  transform: rotate(14deg) translateX(0);
  opacity: .0;
  pointer-events: none;
}
.hero.hero--carousel .btn:hover::after,
.hero.hero--carousel .btn:focus-visible::after{
  opacity: 1;
  animation: premiumSheen .8s ease;
}
@keyframes premiumSheen{
  from { transform: rotate(14deg) translateX(-220%); }
  to   { transform: rotate(14deg) translateX(520%); }
}
.hero.hero--carousel .btn:hover{ transform: translateY(-2px); }
.hero.hero--carousel .btn.btn-primary{
  box-shadow: 0 14px 34px rgba(0,112,176,.32);
}
.hero.hero--carousel .btn.btn-outline{
  border-color: rgba(255,255,255,.55) !important;
  background: rgba(255,255,255,.08) !important;
}
.hero.hero--carousel .btn.btn-outline:hover{ background: rgba(255,255,255,.14) !important; }

/* Contrôles du carrousel (flèches + dots) */
.hero-carousel-btn{
  width: 46px !important;
  height: 46px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  background: rgba(4,13,38,.24) !important;
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
}
.hero-carousel-btn:hover,
.hero-carousel-btn:focus-visible{
  background: rgba(0,112,176,.75) !important;
  border-color: rgba(255,255,255,.44) !important;
  box-shadow: 0 16px 30px rgba(0,0,0,.24);
}
.hero-carousel-dots{
  bottom: 20px !important;
  display:flex;
  gap:10px;
  align-items:center;
}
.hero-carousel-dot{
  width: 9px !important;
  height: 9px !important;
  border-radius: 999px;
  background: rgba(255,255,255,.38) !important;
  border: 1px solid rgba(255,255,255,.18);
}
.hero-carousel-dot.active{
  width: 28px !important;
  background: rgba(255,255,255,.92) !important;
}

/* Barre de progression du hero */
.hero-carousel-progress{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 44px;
  width: min(440px, calc(100% - 140px));
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
  z-index: 6;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.hero-carousel-progress-bar{
  display:block;
  width:100%;
  height:100%;
  transform-origin: left center;
  transform: scaleX(0);
  background: linear-gradient(90deg, #35c3ff, #0b93dc 52%, rgba(255,255,255,.95));
  box-shadow: 0 0 18px rgba(53,195,255,.35);
  transition: transform .08s linear;
}
.hero-carousel-progress.is-paused .hero-carousel-progress-bar{ opacity:.8; }

/* Micro-animations premium globales (discrètes) */
:is(.logo-tile,.case-slide-inner,.icon-card,.step-card,.stat-card,.card){
  position: relative;
  overflow: hidden;
}
:is(.logo-tile,.case-slide-inner,.icon-card,.step-card,.stat-card,.card)::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.05) 36%, rgba(53,195,255,.10) 50%, transparent 70%);
  opacity: 0;
  transform: translateX(-40%);
  transition: opacity .25s ease;
  pointer-events: none;
}
:is(.logo-tile,.case-slide-inner,.icon-card,.step-card,.stat-card,.card):hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 34px rgba(3,14,42,.10);
}
:is(.logo-tile,.case-slide-inner,.icon-card,.step-card,.stat-card,.card):hover::after{
  opacity: 1;
  animation: cardSweep .85s ease;
}
@keyframes cardSweep{
  from { transform: translateX(-55%); }
  to   { transform: translateX(55%); }
}

/* Accents plus cohérents sur les tuiles (liseré bleu premium) */
.logo-tile,
.case-slide-inner,
.icon-card,
.step-card,
.stat-card,
.ops-framework-card{
  border-color: rgba(0,112,176,.14) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,252,255,.98)) !important;
}
.logo-tile::before,
.case-slide-inner::before,
.icon-card::before,
.step-card::before,
.stat-card::before,
.ops-framework-card::before{
  box-shadow: 0 0 14px rgba(0,112,176,.16);
}

/* Slider secteurs : plus compact, plus "premium" */
.case-slider{
  border-radius: 20px !important;
  border: 1px solid rgba(0,112,176,.12) !important;
  box-shadow: 0 16px 36px rgba(3,14,42,.06) !important;
  margin-top: 0 !important;
}
.case-slider-wrap{ margin-top: 14px !important; }
.slider-viewport{ margin-bottom: 10px !important; }
.case-slide-inner{ border-radius: 16px !important; }
.case-points{
  background: linear-gradient(180deg, #f7fbff, #f1f7ff) !important;
  border: 1px solid rgba(0,112,176,.10) !important;
}

/* Animation d'entrée du contenu hero (micro, non agressive) */
@media (prefers-reduced-motion: no-preference){
  .hero.hero--carousel .hero-content > *{
    opacity: 0;
    transform: translateY(10px);
    animation: heroItemIn .55s ease forwards;
  }
  .hero.hero--carousel .hero-content > *:nth-child(1){ animation-delay: .04s; }
  .hero.hero--carousel .hero-content > *:nth-child(2){ animation-delay: .10s; }
  .hero.hero--carousel .hero-content > *:nth-child(3){ animation-delay: .16s; }
  .hero.hero--carousel .hero-content > *:nth-child(4){ animation-delay: .22s; }
  .hero.hero--carousel .hero-content > *:nth-child(5){ animation-delay: .28s; }
  @keyframes heroItemIn{
    to { opacity:1; transform: translateY(0); }
  }
}

/* Mobile : on garde les photos visibles et le header clair */
@media (max-width: 900px){
  .hero.hero--carousel{ min-height: 660px !important; }
  .hero.hero--carousel .hero-content{ padding: 86px 0 72px !important; }
  .hero.hero--carousel .hero-content::before{ inset: 66px -10px 10px -10px; border-radius: 18px; }
  .hero-bg-slide{ background-position: center center !important; }
  .hero-carousel-btn{ display:none !important; }
  .hero-carousel-progress{ width: calc(100% - 46px); bottom: 40px; }
  .hero-carousel-dots{ bottom: 16px !important; }
}
@media (max-width: 640px){
  .hero.hero--carousel .hero-content{
    max-width: none !important;
    padding: 78px 0 76px !important;
  }
  .hero.hero--carousel .hero-content::before{
    inset: 58px -8px 12px -8px;
    background: linear-gradient(160deg, rgba(6,16,48,.38), rgba(6,16,46,.16));
  }
  .hero.hero--carousel h1{ max-width: none; font-size: clamp(2rem, 10.2vw, 3rem) !important; }
  .hero.hero--carousel .hero-text{ font-size: .98rem !important; }
  .hero-carousel-progress{ height: 3px; bottom: 38px; }
}
