*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
img{max-width:100%;height:auto}
body{font-family:system-ui,-apple-system,'Segoe UI',sans-serif;font-size:17px;line-height:1.75;color:#020006;background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}
:root{
  --black:#020006;--teal:#7ac6cb;--teal-light:#b0dee0;--teal-dark:#4a9ea3;
  --lemon:#dfe382;--lemon-dark:#b8c050;--cement:#d5dfde;
  --gray:#f5f5f3;--gray-mid:#e8e8e5;--text-muted:#6b6b72;
  --radius:12px;--radius-lg:20px;--radius-xl:24px;--max-w:1120px;
}
h1,h2,h3,h4{font-family:'Work Sans',system-ui,sans-serif}
h1{font-size:clamp(2rem,4vw,3rem);font-weight:600;line-height:1.1;letter-spacing:-0.025em}
h2{font-size:clamp(1.4rem,2.4vw,2rem);font-weight:600;line-height:1.2;letter-spacing:-0.02em}
h3{font-size:1.1rem;font-weight:500}
p{line-height:1.75}
a{text-decoration:none}
.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
.section-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--teal-dark);margin-bottom:.75rem;display:block}

/* BUTTONS */
.btn-primary{background:var(--lemon);color:var(--black);border:none;padding:15px 30px;border-radius:50px;font-family:'Work Sans',sans-serif;font-size:15px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .2s,transform .15s}
.btn-primary:hover{background:var(--lemon-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(223,227,130,.4)}
.btn-outline{background:transparent;color:var(--black);border:1.5px solid rgba(2,0,6,.25);padding:13px 28px;border-radius:50px;font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:all .2s}
.btn-outline:hover{border-color:var(--black);background:rgba(2,0,6,.03)}
.btn-ghost{background:transparent;color:rgba(255,255,255,.7);border:1.5px solid rgba(255,255,255,.2);padding:13px 28px;border-radius:50px;font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.btn-ghost:hover{border-color:rgba(255,255,255,.5);color:#fff}
.btn-white{background:#fff;color:var(--black);border:none;padding:15px 32px;border-radius:50px;font-size:15px;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}

/* NAV */
nav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-mid)}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 2rem;height:66px;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--black);font-family:'Work Sans',sans-serif;font-weight:700;font-size:19px}
.logo-bracket{color:var(--teal-dark);font-size:24px}
.nav-links{display:flex;align-items:center;gap:.2rem;list-style:none}
.nav-links>li{position:relative}
.nav-links>li>a{font-size:14px;color:var(--text-muted);text-decoration:none;font-family:'Work Sans',sans-serif;font-weight:400;padding:8px 14px;border-radius:var(--radius);display:flex;align-items:center;gap:4px;transition:color .2s,background .2s;cursor:pointer}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--black);background:var(--gray)}
.nav-links>li>a svg{width:11px;height:11px;transition:transform .2s}
.nav-links>li:hover>a svg{transform:rotate(180deg)}
.nav-cta-item>a{background:var(--lemon)!important;color:var(--black)!important;font-weight:600!important;padding:9px 20px!important;border-radius:50px!important}
.nav-cta-item>a:hover{background:var(--lemon-dark)!important}
.dropdown{
  position:absolute;
  top:100%;
  left:0;
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius-xl);
  padding:1rem;
  padding-top:1.5rem;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
  z-index:300;
}
/* Pont invisible pour éviter le gap entre le lien et le dropdown */
.nav-links>li>.dropdown::before{
  content:'';
  position:absolute;
  top:-14px;
  left:0;
  right:0;
  height:14px;
}
.nav-links>li:hover>.dropdown{visibility:visible;opacity:1;pointer-events:auto;transform:translateY(0);max-width:50vw;width:max-content}
.dropdown-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;min-width:520px}
.dropdown-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:.25rem .75rem;margin-bottom:.25rem}
.dropdown-item{display:flex;align-items:flex-start;gap:.75rem;padding:.65rem .75rem;border-radius:var(--radius);text-decoration:none;color:var(--black);transition:background .15s}
.dropdown-item:hover{background:var(--gray)}
.dropdown-item-icon{width:34px;height:34px;border-radius:8px;background:var(--gray);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}
.dropdown-item-text strong{font-size:13px;font-weight:500;display:block;line-height:1.3}
.dropdown-item-text span{font-size:12px;color:var(--text-muted);line-height:1.4}

/* LABEL */
.label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--teal-dark);display:block;margin-bottom:.75rem}
.label-white{color:var(--teal-light)}

/* TAG PILL */
.tag{display:inline-flex;align-items:center;gap:.4rem;padding:6px 14px;border-radius:50px;font-size:12px;font-weight:600;border:1px solid}
.tag-teal{background:rgba(122,198,203,.1);color:var(--teal-dark);border-color:rgba(122,198,203,.3)}
.tag-lemon{background:rgba(223,227,130,.15);color:var(--teal-dark);border-color:rgba(223,227,130,.4)}
.tag-dark{background:rgba(2,0,6,.06);color:var(--black);border-color:rgba(2,0,6,.12)}

/* SECTIONS */
.section{padding:4.5rem 0}
.section-sm{padding:2.5rem 0}
.section-lg{padding:6rem 0}
.bg-gray{background:var(--gray)}
.bg-black{background:var(--black)}

/* CARDS */
.card{background:#fff;border-radius:var(--radius-xl);padding:2rem;border:1px solid var(--gray-mid);transition:box-shadow .3s,transform .3s}
.card:hover{box-shadow:0 16px 48px rgba(0,0,0,.1);transform:translateY(-3px)}
.card-dark{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:2rem}

/* STAT */
.stat-value{font-size:clamp(2.8rem,5vw,4rem);font-weight:700;color:var(--teal);line-height:1;font-family:'Work Sans',sans-serif}
.stat-label{font-size:14px;color:var(--text-muted);margin-top:.35rem;line-height:1.4}

/* CHECK LIST */
.check-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.check-list li{display:flex;align-items:flex-start;gap:.85rem;font-size:15px;line-height:1.6}
.check-list li::before{content:'';width:20px;height:20px;background:var(--teal-dark);border-radius:50%;flex-shrink:0;margin-top:.1rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='white'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");background-size:12px;background-repeat:no-repeat;background-position:center}

/* GRID */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split-wide{display:grid;grid-template-columns:1.2fr .8fr;gap:4rem;align-items:center}
.split-narrow{display:grid;grid-template-columns:.8fr 1.2fr;gap:4rem;align-items:center}
/* Prevent grid children from overflowing their column */
.split>*,.split-wide>*,.split-narrow>*,.grid-2>*,.grid-3>*,.grid-4>*{min-width:0}

/* DECORATIVE */
.teal-line{width:48px;height:3px;background:var(--teal);border-radius:2px;margin-bottom:1.5rem}
.number-badge{width:44px;height:44px;border-radius:12px;background:var(--black);color:var(--lemon);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0;font-family:'Work Sans',sans-serif}

/* STEP */
.step{display:flex;align-items:flex-start;gap:1.25rem;padding:1.75rem;background:#fff;border-radius:var(--radius-xl);border:1px solid var(--gray-mid)}

/* CTA DARK */
.cta-block{background:var(--black);border-radius:var(--radius-xl);padding:4rem;text-align:center;position:relative;overflow:hidden}
.cta-block::before{content:'';position:absolute;top:-40%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(122,198,203,.08),transparent 60%);pointer-events:none}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:.8}}
.anim-1{animation:fadeUp .6s ease both}
.anim-2{animation:fadeUp .6s ease .1s both}
.anim-3{animation:fadeUp .6s ease .2s both}

/* FOOTER */
.site-footer{background:var(--black);border-top:1px solid rgba(255,255,255,.07);padding:3.5rem 0 2rem}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.65);line-height:1.8;margin-top:.85rem}
.footer-col-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.55);margin-bottom:1.1rem}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.75);text-decoration:none;margin-bottom:.6rem;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{max-width:var(--max-w);margin:2.5rem auto 0;padding:1.5rem 2rem 0;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.55)}

/* RESPONSIVE */
@media(max-width:960px){.split,.split-wide,.split-narrow,.grid-2,.grid-3,.grid-4,.footer-inner{grid-template-columns:1fr}.dropdown-grid{min-width:280px;grid-template-columns:1fr}.section{padding:3rem 0}}
@media(max-width:600px){
  .section{padding:3rem 0}
  h1{font-size:2rem}
  [style*="font-size:10px"],[style*="font-size:11px"]{font-size:13px!important}
  .section-label{font-size:12px}
  .label{font-size:12px}
  .dropdown-section-title{font-size:12px}
}


/* ── HAMBURGER MOBILE ── */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--black);border-radius:2px;transition:all .25s}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-mobile{display:none;position:fixed;top:66px;left:0;right:0;bottom:0;background:#fff;z-index:150;overflow-y:auto;padding:1.5rem 2rem;border-top:1px solid var(--gray-mid)}
.nav-mobile.open{display:block}
.nav-mobile-item{display:block;font-family:'Work Sans',sans-serif;font-size:16px;font-weight:500;color:var(--black);text-decoration:none;padding:1rem 0;border-bottom:1px solid var(--gray-mid)}
.nav-mobile-item:last-child{border:none}
.nav-mobile-sub{display:block;font-size:14px;color:var(--text-muted);text-decoration:none;padding:.6rem 0 .6rem 1rem;border-bottom:1px solid var(--gray-mid)}
.nav-mobile-section{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:.75rem 0 .35rem;margin-top:.5rem}
.nav-mobile-cta{display:block;background:var(--lemon);color:var(--black);font-family:'Work Sans',sans-serif;font-size:15px;font-weight:600;text-decoration:none;padding:1rem 1.5rem;border-radius:50px;text-align:center;margin-top:1.5rem}
@media(max-width:900px){.nav-hamburger{display:flex}.nav-links{display:none!important}}


/* ── FIX MENU : éviter fermeture accidentelle ── */
.nav-links>li>.dropdown{
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  transform:translateY(4px);
  transition:opacity .15s ease, transform .15s ease, visibility 0s linear .15s;
  display:block !important;
}
.nav-links>li:hover>.dropdown{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
  transition:opacity .15s ease, transform .15s ease, visibility 0s linear 0s;
}


/* ── NAV PATCH (minimal) ── */
/* 1. Become a Partner : pas de retour à la ligne */
.nav-links>li>a{white-space:nowrap}
/* 2. Dropdown About : ancré à droite via CSS pur */
.nav-links>li:last-of-type .dropdown,
.nav-links>li:nth-last-child(3) .dropdown{
  left:auto;
  right:0;
}
/* 3. Mobile : cacher nav-links, afficher hamburger */
@media(max-width:960px){
  .nav-hamburger{display:flex!important}
  .nav-links>li>.dropdown,
  .nav-links>li:hover>.dropdown{
    display:none!important;
    visibility:hidden!important;
  }
}
/* ════════════════════════════════════════════════════
   RESPONSIVE — breakpoints harmonisés
   ════════════════════════════════════════════════════ */

/* ── Tablette (≤1024px) ── */
@media(max-width:1024px){
  .nav-links>li>a{padding:8px 8px;font-size:12.5px}
  .nav-cta-item>a{padding:8px 14px!important;font-size:12.5px!important}
  .container{padding:0 1.5rem}
  .hero-home{padding:3rem 0}
  .split,.split-wide,.split-narrow,.grid-split,.grid-split-l,.grid-split-r{gap:2.5rem}
}

/* ── Mobile large (≤768px) ── */
@media(max-width:768px){
  /* Layout : tout en colonne */
  .split,.split-wide,.split-narrow,
  .grid-hero,.grid-2,.grid-3,.grid-4,
  .grid-split,.grid-split-l,.grid-split-r,
  .grid-split-hero,.grid-msg,.grid-summary,
  .moments-grid,.offres-grid,.why-grid,
  .hero-split,.footer-inner{
    grid-template-columns:1fr!important;
    gap:1.5rem!important;
  }

  /* Typographie */
  h1{font-size:clamp(1.6rem,6vw,2.2rem)!important;line-height:1.2!important}
  h2{font-size:clamp(1.25rem,4.5vw,1.7rem)!important}
  h3{font-size:clamp(1.1rem,4vw,1.4rem)!important}

  /* Container */
  .container{padding:0 1.25rem!important}
  section{padding:3rem 0!important}

  /* Channels : chips passent en multi-lignes */
  .channels-bar > .container > div{flex-wrap:wrap!important;gap:.4rem!important}
  /* Logos : flex-wrap + gap réduit (gap:5rem est unique à cette section) */
  [style*="gap:5rem"]{flex-wrap:wrap!important;gap:2rem!important;justify-content:center!important}
  /* Hero homepage */
  .hero-home{min-height:auto!important;padding:3rem 0 2.5rem!important}
  .hero-h1{font-size:clamp(1.8rem,7vw,2.4rem)!important}
  .hero-sub{font-size:15px!important;max-width:100%!important}
  .hero-badge{font-size:12px!important;padding:5px 14px!important}

  /* Hero sous-pages */
  .cdp-hero,.auto-hero,.ch-hero,.reco-hero,.service-hero,
  .page-hero,.cas-hero,.partenaires-hero{
    padding:2.5rem 0!important
  }

  /* Boutons */
  .btn-primary,.btn-outline,.btn-ghost,.btn-white{
    width:100%;
    justify-content:center;
    text-align:center;
  }
  div[style*="display:flex"][style*="gap:1rem"]:not(.nav-inner):not(.nav-links){
    flex-direction:column!important;
    align-items:stretch!important;
  }

  /* Cards */
  .enjeu-card,.step-card,.moment-card,.why-card,
  .offre-card,.option-card,.pain-card{
    padding:1.25rem!important;
  }

  /* Footer */
  .footer-inner{grid-template-columns:1fr 1fr!important}
  .footer-bottom{flex-direction:column;gap:.35rem;text-align:center}

  /* Carte monde */
  #world-map-section img{border-radius:12px}
  .map-pin-label{display:none}

  /* Grids inline 1fr auto (hero cas + bloc solutions) → colonne unique */
  [style*="grid-template-columns:1fr auto"]{grid-template-columns:1fr!important;gap:1.5rem!important}

  /* Detail sections */
  .detail-section{grid-template-columns:1fr!important;gap:1.5rem!important;padding:1.5rem!important}
  .detail-visual{overflow-x:auto}

  /* Form */
  .form-row{grid-template-columns:1fr!important}
  .demo-page{grid-template-columns:1fr!important}
  .demo-left{padding:2rem 1.5rem!important;min-height:auto!important}
  .demo-right{padding:2rem 1.5rem!important}
}

/* ── Mobile petit (≤480px) ── */
@media(max-width:480px){
  .container{padding:0 1rem!important}
  .footer-inner{grid-template-columns:1fr!important}
  .footer-col-title{margin-top:1rem}
  section{padding:2.5rem 0!important}
  .hero-h1{font-size:clamp(1.6rem,8vw,2.2rem)!important}
  .btn-primary,.btn-outline{font-size:14px!important;padding:12px 20px!important}
  .nav-cta-item>a{font-size:12px!important;padding:7px 12px!important}
  /* Grille 2 colonnes sur petit mobile pour certains éléments */
  .grid-4{grid-template-columns:1fr 1fr!important}
  /* Diagramme Architecture Data */
  .detail-visual{padding:1rem!important}
  .detail-visual > div:first-child{gap:.4rem!important}
  .detail-visual > div:first-child > div:first-child,
  .detail-visual > div:first-child > div:last-child{min-width:0}
  .detail-visual > div:first-child > div:nth-child(2){width:60px!important;height:60px!important}
  .detail-visual > div:first-child > div > div{padding:.25rem .4rem!important;font-size:10px!important;word-break:break-word!important}
}
/* ── reCAPTCHA notice (hidden until API confirms load) ── */
.grecaptcha-badge{visibility:hidden!important}
.recaptcha-notice{display:none;font-size:11px;color:var(--text-muted);line-height:1.6;margin-top:.6rem;text-align:center}
.recaptcha-notice a{color:var(--text-muted);text-decoration:underline}
/* ════════════════════════════════════════════════════ */
/* ── SÉLECTEUR DE LANGUE ── */
.nav-lang-item{list-style:none}
.nav-lang-btn{background:none;border:1px solid var(--gray-mid);border-radius:50px;padding:5px 12px;font-size:13px;font-family:'Work Sans',sans-serif;font-weight:500;color:var(--black);cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .2s}
.nav-lang-btn:hover{background:var(--gray);border-color:var(--teal-light)}
.nav-lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--gray-mid);border-radius:var(--radius-lg);box-shadow:0 8px 24px rgba(0,0,0,.1);min-width:140px;padding:.5rem;z-index:300;display:none}
.nav-lang-item.open .nav-lang-dropdown{display:block}
.nav-lang-option{display:flex;align-items:center;gap:.5rem;padding:7px 12px;border-radius:8px;font-size:13px;color:var(--black);text-decoration:none;transition:background .15s}
.nav-lang-option:hover{background:var(--gray)}
.nav-lang-option.active{font-weight:600;color:var(--teal-dark)}
/* Fermer au clic extérieur */
@media(max-width:960px){.nav-lang-item{display:none}}
/* ── Code langue ── */
.lang-code{font-size:10px;font-weight:700;color:var(--teal-dark);background:rgba(122,198,203,.12);border:1px solid rgba(122,198,203,.25);border-radius:4px;padding:1px 5px;flex-shrink:0}
.nav-lang-option.active .lang-code{background:rgba(122,198,203,.2);border-color:var(--teal-dark)}
