/* ============================================================
   BOOST IA ACADEMY — Design System
   Type: Inter
   Palette: light corporate, green #0A714E accent
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --green:#0A714E;
  --green-700:#085C40;
  --green-800:#06402D;
  --green-900:#042C1F;
  --green-ink:#03241A;
  --green-tint:#EDF4F0;
  --green-tint-2:#E0ECE5;
  --green-soft:#F4F8F6;

  --ink:#0B130F;
  --ink-2:#26312B;
  --muted:#5C665F;
  --muted-2:#8A938C;
  --line:#E5E9E6;
  --line-2:#EEF1EF;
  --surface:#ffffff;
  --surface-2:#F0F3F1;
  --white:#FFFFFF;

  --shadow-sm:0 1px 2px rgba(6,40,28,.05), 0 2px 8px rgba(6,40,28,.04);
  --shadow-md:0 8px 30px rgba(6,40,28,.08), 0 2px 8px rgba(6,40,28,.04);
  --shadow-lg:0 24px 60px rgba(6,40,28,.14), 0 8px 24px rgba(6,40,28,.08);
  --shadow-green:0 18px 50px rgba(10,113,78,.30);

  --r-sm:10px;
  --r:16px;
  --r-lg:22px;
  --r-xl:30px;

  /* Container */
  --maxw:1280px;
  --pad:clamp(20px, 2.5vw, 32px);

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --font:"Inter", system-ui, sans-serif;
  --mono:"Inter", ui-monospace, monospace;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--white);
  line-height:1.8;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
::selection{background:var(--green);color:#fff}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:120px;position:relative}
.section--tight{padding-block:clamp(48px,5vw,72px)}

/* ---------- Type helpers ---------- */
.eyebrow{
  font-family:var(--font);
  font-size:13px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--green);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:26px;height:1.5px;
  background:var(--green);
  display:inline-block;
}
.eyebrow--center{justify-content:center}
.eyebrow--light{color:#7FD9B4}
.eyebrow--light::before{background:#7FD9B4}

/* Base headings */
h1,h2,h3,h4{line-height:1.1;letter-spacing:-.02em;font-weight:700;color:var(--ink)}
h3{font-weight:600;line-height:1.3}

/* Utility type classes */
.h-display{font-size:clamp(38px,3.3vw+20px,68px);font-weight:700;letter-spacing:-.03em;line-height:1.1}
.h1{font-size:clamp(38px,3.3vw+20px,68px);font-weight:700;letter-spacing:-.03em;line-height:1.1}
.h2{font-size:clamp(30px,1.55vw+18px,44px);font-weight:700;letter-spacing:-.025em;line-height:1.15}
.h3{font-size:clamp(22px,1.5vw,24px);font-weight:600;letter-spacing:-.015em;line-height:1.3}
.lead{font-size:18px;color:var(--muted);line-height:1.8;font-weight:400}
.small-text{font-size:16px;line-height:1.7}
.section-head{max-width:720px}
.section-head .h2{margin-top:0}
.section-head .lead{margin-top:24px}
.center{text-align:center;margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:600;font-size:16px;letter-spacing:-.01em;
  padding:15px 26px;border-radius:999px;
  transition:transform .4s var(--ease-out), box-shadow .4s var(--ease-out), background .25s, color .25s;
  white-space:nowrap;position:relative;
}
.btn svg{width:18px;height:18px;transition:transform .4s var(--ease-out)}
.btn--primary{background:var(--green);color:#fff;box-shadow:var(--shadow-green)}
.btn--primary:hover{transform:translateY(-2px);background:var(--green-700);box-shadow:0 22px 56px rgba(10,113,78,.40)}
.btn--primary:hover svg{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--ghost:hover svg{transform:translateX(4px)}
.btn--light{background:#fff;color:var(--green-ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn--onlight-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn--onlight-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn--sm{padding:12px 20px;font-size:15px}
.btn--block{width:100%;justify-content:center}

.link-arrow{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;font-size:15px;color:var(--green);
  transition:gap .3s var(--ease-out);
}
.link-arrow svg{width:17px;height:17px;transition:transform .3s var(--ease-out)}
.link-arrow:hover{gap:12px}
.link-arrow:hover svg{transform:translateX(3px)}

/* ---------- Icon tiles ---------- */
.icon-tile{
  width:52px;height:52px;border-radius:14px;
  display:grid;place-items:center;flex:none;
  background:var(--green-tint);color:var(--green);
  transition:background .35s var(--ease), color .35s, transform .45s var(--ease-out);
}
.icon-tile svg{width:24px;height:24px;stroke-width:1.6}
.icon-tile--lg{width:60px;height:60px;border-radius:16px}
.icon-tile--lg svg{width:27px;height:27px}

/* ============================================================
   HEADER + MEGA MENU (eco.com inspired)
   ============================================================ */
/* ── Header shell — hero-section-5 style ── */
.header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  padding:0;
  background:#fff;
  box-shadow:0 1px 0 rgba(0,0,0,.08);
}

/* Inner container: plein largeur, pas de pill */
.header .nav-inner{
  width:100%;max-width:none;margin-inline:auto;
  border-radius:0;
  background:transparent;
}

/* Nav row */
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px clamp(20px,4vw,56px);
  max-width:1400px;margin-inline:auto;
  transition:padding .3s var(--ease-out);
}
.header.is-scrolled .nav{padding:12px clamp(20px,4vw,56px)}

/* CTA buttons */
.btn--nav-solid{
  background:var(--green);color:#fff;
  padding:9px 18px;border-radius:8px;font-weight:600;font-size:14px;
  white-space:nowrap;
  transition:transform .3s var(--ease-out), background .2s, box-shadow .3s;
  box-shadow:0 4px 14px rgba(10,113,78,.25);
}
.btn--nav-solid:hover{transform:translateY(-1px);background:var(--green-700);box-shadow:0 6px 18px rgba(10,113,78,.35)}
.btn--nav-outline{
  background:transparent;color:var(--ink-2);border:1.5px solid var(--line);
  padding:8px 16px;border-radius:8px;font-weight:600;font-size:14px;
  white-space:nowrap;
  transition:transform .3s var(--ease-out), border-color .2s, background .2s;
}
.btn--nav-outline:hover{transform:translateY(-1px);border-color:var(--ink);background:var(--surface)}

.brand{display:flex;align-items:center;gap:11px;font-weight:700;font-size:19px;letter-spacing:-.02em;z-index:2;white-space:nowrap}
.brand-logo{ height:64px;width:auto;display:block; }
.footer .brand-logo{ height:56px; filter:brightness(0) invert(1); }
.brand b{font-weight:700}
.brand .brand-sub{color:var(--green);font-weight:700}

.nav-center{display:flex;align-items:center;gap:2px}
.nav-item{position:relative}
.nav-item[data-mega].open::after,
.nav-item[data-mega-sites].open::after,
.nav-item[data-mega-about].open::after{
  content:'';position:absolute;bottom:-18px;left:-40px;right:-40px;height:18px;
}
.nav-link{
  display:inline-flex;align-items:center;gap:5px;
  padding:8px 14px;
  font-weight:500;font-size:15px;color:var(--muted);
  transition:color .2s;white-space:nowrap;
}
.nav-link:hover{color:var(--ink)}
.nav-link svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.nav-item.open .nav-link{color:var(--ink)}
.nav-item.open .nav-link .chev{transform:rotate(180deg)}

.nav-cta{display:flex;align-items:center;gap:10px;z-index:2}

/* Burger — animated Menu ↔ X (two overlaid icons) */
.burger{
  display:none;position:relative;width:36px;height:36px;
  border-radius:8px;border:none;
  background:transparent;cursor:pointer;
  place-items:center;flex:none;
}
.burger-icon,.burger-close{
  position:absolute;inset:0;display:grid;place-items:center;
  width:18px;height:18px;margin:auto;
  transition:opacity .2s var(--ease), transform .3s var(--ease);
}
.burger-close{opacity:0;transform:rotate(-180deg) scale(0)}
body.menu-open .burger .burger-icon{opacity:0;transform:rotate(180deg) scale(0)}
body.menu-open .burger .burger-close{opacity:1;transform:rotate(0) scale(1)}
body.menu-open .burger{border-color:var(--ink)}


/* Mega panel */
.mega{
  position:fixed;left:50%;top:82px;transform:translateX(-50%) translateY(-12px);
  width:min(1180px, calc(100vw - 32px));
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(26px);
  -webkit-backdrop-filter:saturate(180%) blur(26px);
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
  padding:14px;
  display:grid;grid-template-columns:300px 1fr;gap:14px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .35s var(--ease), transform .45s var(--ease-out), visibility .35s;
  z-index:99;
}
.nav-item.open .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega::before{content:'';position:absolute;top:-14px;left:0;right:0;height:14px;}
.mega--sites{ width:min(640px, calc(100vw - 32px)); }
.mega-grid.mega-grid--sites{ grid-template-columns:1fr; gap:4px; align-content:center; }
.mega--about{ width:min(480px, calc(100vw - 32px)); grid-template-columns:1fr; }
.mega-grid.mega-grid--about{ grid-template-columns:1fr; gap:4px; }

.mega-feature{
  background:linear-gradient(165deg,var(--green-800),var(--green-ink));
  border-radius:var(--r-lg);
  padding:26px;color:#fff;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.mega-feature::after{
  content:"";position:absolute;right:-40px;bottom:-40px;
  width:180px;height:180px;border-radius:50%;
  background:radial-gradient(circle,rgba(127,217,180,.28),transparent 70%);
}
.mega-feature .eyebrow{color:#7FD9B4;margin-bottom:14px}
.mega-feature .eyebrow::before{background:#7FD9B4}
.mega-feature h4{color:#fff;font-size:24px;letter-spacing:-.02em;line-height:1.06}
.mega-feature p{color:rgba(255,255,255,.72);font-size:14.5px;margin-top:12px;line-height:1.55;position:relative}
.mega-price{margin-top:auto;padding-top:22px;position:relative}
.mega-price .pr-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.mega-price .pr-val{font-size:22px;font-weight:600;letter-spacing:-.02em;margin-top:4px}
.mega-feature .btn{margin-top:18px;position:relative}

.mega-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  align-content:start;
}
.mega-cell{
  display:flex;gap:13px;align-items:flex-start;
  padding:13px 14px;border-radius:14px;
  transition:background .25s var(--ease);
}
.mega-cell:hover{background:var(--green-soft)}
.mega-cell .icon-tile{width:42px;height:42px;border-radius:11px}
.mega-cell .icon-tile svg{width:20px;height:20px}
.mega-cell:hover .icon-tile{background:var(--green);color:#fff}
.mega-cell .mc-body{min-width:0}
.mega-cell .mc-title{font-weight:600;font-size:15px;letter-spacing:-.01em;display:flex;align-items:center;gap:6px}
.mega-cell .mc-sub{font-size:12.5px;color:var(--muted);line-height:1.4;margin-top:2px}
.mega-cell .mc-title .go{width:14px;height:14px;opacity:0;transform:translateX(-4px);transition:.3s var(--ease);color:var(--green)}
.mega-cell:hover .mc-title .go{opacity:1;transform:translateX(0)}

/* Mobile nav */

/* Mobile drawer — dropdown card style (hero-section-5) */
.mobile-drawer{
  position:fixed;inset:auto clamp(12px,3vw,24px) auto;
  top:76px;
  max-height:calc(100dvh - 96px);
  z-index:90;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 24px 60px rgba(6,40,28,.14), 0 4px 16px rgba(6,40,28,.07);
  padding:20px;
  transform:translateY(-10px) scale(.97);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s var(--ease), transform .3s var(--ease-out), visibility .25s;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
body.menu-open .mobile-drawer{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0) scale(1)}
.m-link{display:flex;align-items:center;justify-content:space-between;padding:12px 8px;font-size:16px;font-weight:500;color:var(--muted);border-radius:10px;transition:color .2s,background .2s;width:100%;text-align:left}
.m-link:hover,.m-toggle.open{color:var(--ink);background:var(--surface)}
.m-chevron{width:18px;height:18px;flex:none;transition:transform .25s;color:var(--muted-2)}
.m-toggle.open .m-chevron{transform:rotate(180deg)}
/* Sous-menus repliés par défaut */
.m-sub{padding:0 0 8px 8px;display:grid;gap:2px;overflow:hidden;max-height:0;opacity:0;transition:max-height .3s ease, opacity .25s ease}
.m-sub.open{max-height:400px;opacity:1}
.m-sub a{display:flex;align-items:center;gap:8px;padding:8px 8px;color:var(--muted);font-size:14px;border-radius:8px;transition:color .2s,background .2s}
.m-sub a:hover{color:var(--ink);background:var(--surface)}
.m-sub a svg{width:15px;height:15px;color:var(--green)}
.m-divider{height:1px;background:var(--line);margin:8px 0}
.m-cta-row{display:flex;flex-direction:column;gap:8px;padding-top:4px}

/* ============================================================
   HERO — hero-section-5 style (full-bleed image + text overlay)
   ============================================================ */
.hero5{
  position:relative;
  min-height:90svh;
  display:flex;align-items:center;
  overflow:hidden;
  padding-bottom:0;
}
.hero5-bg{
  position:absolute;inset:0;
  border-radius:0;
  overflow:hidden;
  z-index:0;
  background:#03241A;
}

/* Blobs animés */
/* 4 orbes aurora — animations décalées, ultra-smooth */
.hero5-orb{
  position:absolute;
  border-radius:50%;
  pointer-events:none;
}
.hero5-orb-1{
  width:90vw;height:90vw;max-width:1100px;max-height:1100px;
  background:radial-gradient(circle at 40% 40%, rgba(10,113,78,.65) 0%, transparent 65%);
  top:-30%;left:-20%;
  filter:blur(70px);
  animation:orb1 14s ease-in-out infinite alternate;
}
.hero5-orb-2{
  width:60vw;height:60vw;max-width:750px;max-height:750px;
  background:radial-gradient(circle at 60% 60%, rgba(127,217,180,.40) 0%, transparent 60%);
  top:10%;right:-15%;
  filter:blur(90px);
  animation:orb2 18s ease-in-out infinite alternate;
}
.hero5-orb-3{
  width:50vw;height:50vw;max-width:640px;max-height:640px;
  background:radial-gradient(circle at 50% 50%, rgba(6,64,45,.80) 0%, transparent 65%);
  bottom:-20%;left:20%;
  filter:blur(60px);
  animation:orb3 11s ease-in-out infinite alternate;
}
.hero5-orb-4{
  width:35vw;height:35vw;max-width:450px;max-height:450px;
  background:radial-gradient(circle at 50% 50%, rgba(4,44,31,.90) 0%, transparent 70%);
  bottom:5%;right:5%;
  filter:blur(50px);
  animation:orb4 22s ease-in-out infinite alternate;
}

@keyframes orb1{
  0%  {transform:translate(0,0) scale(1)}
  50% {transform:translate(6vw,5vh) scale(1.08)}
  100%{transform:translate(-3vw,9vh) scale(.95)}
}
@keyframes orb2{
  0%  {transform:translate(0,0) scale(1)}
  40% {transform:translate(-8vw,3vh) scale(1.12)}
  100%{transform:translate(4vw,-6vh) scale(.9)}
}
@keyframes orb3{
  0%  {transform:translate(0,0) scale(1)}
  60% {transform:translate(5vw,-4vh) scale(1.1)}
  100%{transform:translate(-6vw,3vh) scale(.97)}
}
@keyframes orb4{
  0%  {transform:translate(0,0) scale(1)}
  50% {transform:translate(-4vw,6vh) scale(1.15)}
  100%{transform:translate(7vw,-3vh) scale(.92)}
}

/* Fondu bas vers le blanc */
.hero5::after{
  content:'';
  position:absolute;
  bottom:-2rem;left:0;
  width:110%;height:130px;
  background:linear-gradient(to bottom, transparent, var(--surface) 80%);
  filter:blur(14px);
  z-index:11;
  pointer-events:none;
}

/* Hero textes toujours blancs */
.hero5-title,.hero5-sub{color:#fff}
.hero5-title em{color:#7FD9B4}
.hero5-content{
  position:relative;z-index:10;
  width:100%;max-width:var(--maxw);
  margin-inline:auto;
  padding:clamp(80px,14vw,200px) var(--pad) clamp(56px,7vw,96px);
}

/* Version centrée (homepage + formation) */
.hero5-content--center{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
}

/* Padding haut réduit — même niveau que formation */
.hero5-content--high{
  padding-top:clamp(56px,8vw,110px);
}

.hero5-title{
  font-size:clamp(38px,5.8vw,78px);
  font-weight:600;letter-spacing:-.035em;line-height:1.03;
  color:#fff;max-width:820px;
}

/* Titre petit — 2 lignes exactes */
.hero5-title--sm{
  font-size:clamp(26px,3vw,42px);
  line-height:1.2;
  max-width:90vw;
}

.hero5-title em{
  font-style:normal;
  color:#7FD9B4;
}
.hero5-sub{
  margin-top:22px;
  font-size:clamp(16px,1.4vw,20px);
  color:rgba(255,255,255,.75);
  max-width:560px;line-height:1.6;
}
.hero5-actions{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:36px;justify-content:center;
}

/* Bouton ghost blanc */
.hero5-btn-ghost{
  color:#fff;border-color:rgba(255,255,255,.4);
}
.hero5-btn-ghost:hover{
  background:rgba(255,255,255,.1);border-color:#fff;
}

/* Fondu bas homepage */
.hero5-fade{
  position:absolute;
  bottom:0;left:0;
  width:100%;
  height:80px;
  background:linear-gradient(to bottom,
    rgba(255,255,255,0)   0%,
    rgba(255,255,255,.01) 10%,
    rgba(255,255,255,.04) 20%,
    rgba(255,255,255,.09) 30%,
    rgba(255,255,255,.17) 40%,
    rgba(255,255,255,.29) 50%,
    rgba(255,255,255,.45) 60%,
    rgba(255,255,255,.63) 70%,
    rgba(255,255,255,.80) 80%,
    rgba(255,255,255,.93) 90%,
    rgba(255,255,255,1)   100%
  );
  z-index:12;
  pointer-events:none;
}

/* Désactive l'ancien ::after (remplacé par .hero5-fade) */
.hero5::after{ display:none; }

/* white ghost button on dark hero (legacy) */
.hero5-actions .btn--ghost{
  color:#fff;border-color:rgba(255,255,255,.4);
}
.hero5-actions .btn--ghost:hover{
  background:rgba(255,255,255,.1);border-color:#fff;
}

/* ============================================================
   SERVICES — stacking cards (eco.com style)
   ============================================================ */
.bwe-section{
  padding-top:clamp(40px,5vw,64px);
}

/* Heading — sticky dans la section */
.bwe-heading-wrap{
  position:sticky;
  top:100px;
  z-index:10;
  padding-left:clamp(16px,4vw,64px);
  margin-bottom:clamp(32px,4vw,56px);
  pointer-events:none;
}
.bwe-section-title{
  font-size:clamp(28px,4vw,56px);
  font-weight:700;
  letter-spacing:-.03em;
  line-height:1.05;
  color:var(--ink);
}

.bwe-section-sub{font-size:clamp(15px,1.2vw,17px);color:var(--muted);line-height:1.65;margin-top:16px;max-width:560px;}
/* Stack container — padding-bottom must be >= last card height so title is pushed only once card fully clears */
.bwe-stack{
  padding-bottom:clamp(40px,8vw,80px);
  padding-left:clamp(16px,4vw,64px);
  padding-right:clamp(16px,4vw,64px);
  max-width:1260px;
  margin-inline:auto;
}

/* Each sticky card — même fond vert animé que le hero */
.bwe-card{
  position:sticky;
  top:var(--bwe-card-top, 220px);
  z-index:var(--card-z,1);
  background:#03241A;
  border-radius:clamp(16px,2vw,24px);
  margin-top:clamp(16px,2.5vw,24px);
  will-change:transform;
  border:1px solid rgba(255,255,255,.07);
  overflow:hidden;
}
/* Orbes animés dans chaque carte */
.bwe-card::before,.bwe-card::after{
  content:'';
  position:absolute;
  border-radius:50%;
  pointer-events:none;
}
.bwe-card::before{
  width:70%;aspect-ratio:1;
  background:radial-gradient(circle, rgba(10,113,78,.55) 0%, transparent 65%);
  top:-40%;left:-15%;
  filter:blur(48px);
  animation:orb1 14s ease-in-out infinite alternate;
}
.bwe-card::after{
  width:50%;aspect-ratio:1;
  background:radial-gradient(circle, rgba(127,217,180,.30) 0%, transparent 60%);
  bottom:-30%;right:-10%;
  filter:blur(40px);
  animation:orb2 18s ease-in-out infinite alternate;
}

/* Inner grid: content left, image right — au-dessus des orbes */
.bwe-card-inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:clamp(24px,3vw,48px);
  padding:clamp(20px,2.5vw,32px);
}
.bwe-card-inner--reverse .bwe-content{order:2}
.bwe-card-inner--reverse .bwe-img{order:1}

/* Content side */
.bwe-content{
  display:flex;flex-direction:column;justify-content:center;
}
.bwe-num{
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:#7FD9B4;display:block;margin-bottom:18px;
}
.bwe-title{
  font-size:clamp(20px,2vw,28px);
  font-weight:600;letter-spacing:-.02em;line-height:1.12;
  color:#fff;
}
.bwe-text{
  font-size:clamp(13.5px,1vw,15px);
  color:rgba(255,255,255,.82);
  line-height:1.65;margin-top:14px;
}

/* Image side — floating, padded, not full-bleed */
.bwe-img{
  border-radius:clamp(10px,1.5vw,16px);
  overflow:hidden;
  aspect-ratio:16/8;
  background:rgba(255,255,255,.06);
}
.bwe-img img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}

/* Button — dark card style */
.bwe-btn{
  display:inline-flex;align-items:center;gap:12px;
  margin-top:28px;align-self:flex-start;
  padding:10px 14px 10px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.07);
  font-weight:600;font-size:14px;color:#fff;
  overflow:hidden;
  transition:border-color .25s,background .25s;
}
.bwe-btn:hover{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.12)}
.bwe-btn>span:first-child{white-space:nowrap}

.bwe-btn-track{
  width:28px;height:28px;border-radius:8px;
  background:var(--green);
  display:grid;place-items:center;
  overflow:hidden;flex:none;position:relative;
  transition:background .25s;
}
.bwe-btn:hover .bwe-btn-track{background:var(--green-700)}
.bwe-btn-track svg{
  width:13px;height:13px;color:#fff;
  position:absolute;
  transition:transform .28s var(--ease-out),opacity .22s;
}
.bwe-btn-track svg:first-child{transform:translateX(0);opacity:1}
.bwe-btn:hover .bwe-btn-track svg:first-child{transform:translateX(130%);opacity:0}
.bwe-btn-track svg:last-child{transform:translateX(-130%);opacity:0}
.bwe-btn:hover .bwe-btn-track svg:last-child{transform:translateX(0);opacity:1}

@media(max-width:860px){
  .bwe-card-inner{grid-template-columns:1fr;gap:20px}
  .bwe-card-inner--reverse .bwe-content{order:0}
  .bwe-card-inner--reverse .bwe-img{order:0}
  .bwe-content{padding-right:0}
}

/* ============================================================
   HERO (old — kept for inner pages that may reference .hero)
   ============================================================ */
.hero{position:relative;padding-top:148px;padding-bottom:clamp(60px,8vw,110px);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1;pointer-events:none}
.hero-bg .blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5}
.hero-bg .b1{width:560px;height:560px;top:-180px;right:-120px;background:radial-gradient(circle,rgba(10,113,78,.20),transparent 65%)}
.hero-bg .b2{width:480px;height:480px;bottom:-220px;left:-160px;background:radial-gradient(circle,rgba(10,113,78,.12),transparent 65%)}
.hero-bg .grid-lines{position:absolute;inset:0;background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);background-size:62px 62px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);opacity:.6}

.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,64px);align-items:center}
.hero-copy{max-width:620px}
.hero h1{margin-top:24px}
.hero .lead{margin-top:26px;max-width:540px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.hero-trust{display:flex;align-items:center;gap:22px;margin-top:40px;flex-wrap:wrap}
.hero-trust .stat{display:flex;flex-direction:column}
.hero-trust .stat .n{font-size:26px;font-weight:600;letter-spacing:-.02em;font-feature-settings:"tnum"}
.hero-trust .stat .l{font-size:13px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em}
.hero-trust .divider{width:1px;height:36px;background:var(--line)}

/* hero visual */
.hero-visual{position:relative}
.hero-frame{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/4.4}
.float-card{
  position:absolute;background:rgba(255,255,255,.9);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-md);padding:14px 16px;
  display:flex;align-items:center;gap:12px;
}
.float-card .icon-tile{width:42px;height:42px;border-radius:11px}
.float-card .icon-tile svg{width:20px;height:20px}
.float-card .fc-n{font-size:21px;font-weight:600;letter-spacing:-.02em;line-height:1;font-feature-settings:"tnum"}
.float-card .fc-l{font-size:12px;color:var(--muted);margin-top:3px}
.fc-1{top:8%;left:-8%}
.fc-2{bottom:12%;right:-6%}
.fc-3{bottom:-4%;left:14%}

/* placeholder */
.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg,#EAF0EC,#EAF0EC 11px,#E2EAE5 11px,#E2EAE5 22px);
  display:grid;place-items:center;color:var(--muted);
}
.ph-tag{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--green-700);background:rgba(255,255,255,.92);
  padding:8px 14px;border-radius:999px;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}

/* ---------- Logo band (hero-section-5 style) ---------- */
/* ── Logos3 — titre à gauche + carousel sur la même ligne ── */
.logos3{
  padding-block: clamp(20px,3vw,32px);
  background:var(--white);
  overflow:hidden;
}
.logos3-inner{
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--pad);
  display:flex;
  align-items:center;
  gap:clamp(24px,4vw,48px);
}
.logos3-heading{
  flex:none;
  width:clamp(140px,18vw,200px);
}
.logos3-heading h2{
  font-size:clamp(12px,1.1vw,14px);
  font-weight:600;
  color:var(--muted);
  line-height:1.4;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.logos3-track-wrap{
  flex:1;
  position:relative;
  overflow:hidden;
}
.logos3-track{
  display:flex;
  align-items:center;
  gap:clamp(32px,5vw,64px);
  width:max-content;
  animation:logos3-scroll 34s linear infinite;
}
.logos3-track:hover{ animation-play-state:paused }
.logos3-item{
  display:flex;
  align-items:center;
  justify-content:center;
  flex:none;
}
.logos3-item img{
  height:auto;
  max-height:24px;
  width:auto;
  opacity:.45;
  filter:grayscale(1);
  transition:opacity .3s, filter .3s;
}
.logos3-item img:hover{ opacity:.85; filter:grayscale(0); }
/* Fallback texte si logo non disponible */
.logos3-name{
  font-size:15px;
  font-weight:700;
  color:var(--ink);
  opacity:.4;
  white-space:nowrap;
  letter-spacing:-.01em;
  transition:opacity .3s;
}
.logos3-item:hover .logos3-name{ opacity:.8; }
@keyframes logos3-scroll{ to{ transform:translateX(-50%); } }

/* Gradient fades sur les bords du carousel */
.logos3-fade{
  position:absolute;top:0;bottom:0;width:clamp(32px,5vw,80px);pointer-events:none;z-index:2;
}
.logos3-fade--l{
  left:0;
  background:linear-gradient(to right, var(--white) 0%, transparent 100%);
}
.logos3-fade--r{
  right:0;
  background:linear-gradient(to left, var(--white) 0%, transparent 100%);
}
@media(max-width:640px){
  .logos3-heading{ display:none; }
}

/* Keep old marquee keyframe for backward compat */
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   EXPERTISE CARDS
   ============================================================ */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.xcard{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:32px;
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out), border-color .4s;
}
.xcard::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(165deg,var(--green-soft),transparent 55%);
  opacity:0;transition:opacity .5s var(--ease);z-index:0;
}
.xcard>*{position:relative;z-index:1}
.xcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--green-tint-2)}
.xcard:hover::before{opacity:1}
.xcard:hover .icon-tile{background:var(--green);color:#fff;transform:rotate(-6deg)}
.xcard .xnum{position:absolute;top:28px;right:30px;font-family:var(--mono);font-size:13px;color:var(--muted-2);z-index:1}
.xcard h3{margin-top:24px}
.xcard p{color:var(--muted);margin-top:14px;font-size:15.5px;flex:1}
.xcard .xfeat{margin:20px 0 24px;display:grid;gap:9px}
.xcard .xfeat li{display:flex;align-items:center;gap:9px;font-size:14.5px;color:var(--ink-2)}
.xcard .xfeat li svg{width:17px;height:17px;color:var(--green);flex:none}
.xcard .link-arrow{margin-top:auto}

/* ============================================================
   ABOUT
   ============================================================ */
/* ============================================================
   QUI SOMMES-NOUS — About3
   ============================================================ */

/* Header 2-col */
.a3-header{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(24px,4vw,60px);
  align-items:start;
  margin-bottom:clamp(32px,4vw,56px);
}
.a3-title{
  font-size:clamp(30px,4vw,48px);
  font-weight:700;letter-spacing:-.02em;line-height:1.15;
  color:var(--ink);
}
.a3-desc{
  font-size:clamp(15px,1.2vw,17px);
  line-height:1.7;
  color:var(--muted);
  padding-top:6px;
}

/* Grille images */
.a3-grid{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:clamp(16px,2vw,28px);
  align-items:stretch;
}
.a3-img-main{
  width:100%;height:100%;
  max-height:580px;
  object-fit:cover;
  border-radius:clamp(12px,1.5vw,20px);
}
.a3-sidebar{
  display:flex;flex-direction:column;gap:clamp(16px,2vw,28px);
}

/* Breakout card */
.a3-breakout{
  display:flex;flex-direction:column;gap:20px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:clamp(12px,1.5vw,20px);
  padding:clamp(24px,2.5vw,36px);
}
.a3-breakout-logo{
  display:flex;align-items:center;gap:12px;
}
.a3-breakout-brand{
  font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.01em;
}
.a3-breakout-title{
  font-size:clamp(15px,1.1vw,17px);font-weight:600;color:var(--ink);line-height:1.4;
  margin:0 0 6px;
}
.a3-breakout-text{
  font-size:14px;color:var(--muted);line-height:1.6;margin:0;
}
.a3-breakout-btn{
  align-self:flex-start;
  margin-top:4px;
  font-size:14px;
  padding:10px 20px;
}

.a3-img-secondary{
  width:100%;
  flex:1 1 0;
  min-height:160px;
  max-height:220px;
  object-fit:cover;
  border-radius:clamp(12px,1.5vw,20px);
}

/* Outils */
.a3-tools{
  margin-top:clamp(48px,6vw,80px);
  text-align:center;
}
.a3-tools-title{
  font-size:14px;color:var(--muted);font-weight:500;letter-spacing:.03em;text-transform:uppercase;
  margin-bottom:24px;
}
.a3-tools-list{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:center;
}
.a3-tool-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  font-size:14px;font-weight:500;color:var(--ink-2);
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.a3-tool-chip:hover{
  border-color:var(--green);
  box-shadow:0 0 0 3px var(--green-tint);
  transform:translateY(-2px);
}
.a3-tool-chip svg{ color:var(--green); flex:none; }

/* Achievements */
.a3-achievements{
  position:relative;overflow:hidden;
  margin-top:clamp(48px,6vw,80px);
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:clamp(16px,2vw,24px);
  padding:clamp(36px,5vw,64px);
}
.a3-ach-head{
  display:flex;flex-direction:column;gap:12px;
  max-width:540px;
  margin-bottom:clamp(32px,4vw,52px);
}
.a3-ach-title{
  font-size:clamp(22px,2.5vw,34px);
  font-weight:700;letter-spacing:-.02em;line-height:1.2;
  color:var(--ink);
}
.a3-ach-desc{
  font-size:clamp(14px,1.1vw,16px);color:var(--muted);line-height:1.65;
}
.a3-ach-stats{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:32px;
  text-align:center;
}
.a3-stat{
  display:flex;flex-direction:column;gap:10px;
  min-width:120px;
}
.a3-stat-label{
  font-size:clamp(13px,1vw,15px);color:var(--muted);
}
.a3-stat-value{
  font-size:clamp(36px,4.5vw,52px);
  font-weight:700;letter-spacing:-.03em;
  color:var(--ink);line-height:1;
}

/* Décoration grille (coin haut-droit) */
.a3-grid-deco{
  pointer-events:none;
  position:absolute;top:-1px;right:1px;z-index:1;
  width:55%;height:100%;
  background-image:
    linear-gradient(to right, var(--muted) 1px, transparent 1px),
    linear-gradient(to bottom, var(--muted) 1px, transparent 1px);
  background-size:80px 80px;
  opacity:.1;
  mask-image:linear-gradient(to bottom right, #000, transparent 60%, transparent);
  -webkit-mask-image:linear-gradient(to bottom right, #000, transparent 60%, transparent);
  display:none;
}
@media(min-width:768px){ .a3-grid-deco{ display:block; } }

/* Responsive */
@media(max-width:900px){
  .a3-header{ grid-template-columns:1fr; }
  .a3-grid{ grid-template-columns:1fr; }
  .a3-img-main{ max-height:380px; }
  .a3-sidebar{ flex-direction:row; }
  .a3-img-secondary{ max-height:none; min-height:180px; }
  .a3-ach-stats{ justify-content:flex-start; }
}
@media(max-width:600px){
  .a3-sidebar{ flex-direction:column; }
  .a3-ach-stats{ flex-direction:column;align-items:center; }
}

/* ============================================================
   APPROACH (steps)
   ============================================================ */
.approach{background:var(--green-ink);color:#fff;position:relative;overflow:hidden}
.approach::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:70px 70px;
  mask-image:radial-gradient(ellipse 70% 70% at 80% 0%,#000,transparent 70%);
}
.approach .container{position:relative}
.approach .h2{color:#fff}
.approach .lead{color:rgba(255,255,255,.66)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px;position:relative}
.step{padding:30px 26px 30px 0;position:relative}
.step:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}
.step{padding-left:26px}
.step:first-child{padding-left:0}
.step-line{position:absolute;top:0;left:0;height:2px;background:linear-gradient(90deg,#7FD9B4,var(--green));width:0;transition:width 1.2s var(--ease-out)}
.steps.in .step-line{width:100%}
.step .s-num{font-family:var(--mono);font-size:14px;color:#7FD9B4;letter-spacing:.1em}
.step .s-dot{width:13px;height:13px;border-radius:50%;background:var(--green);border:3px solid var(--green-ink);box-shadow:0 0 0 2px #7FD9B4;margin:18px 0 22px}
.step h3{color:#fff;font-size:21px}
.step p{color:rgba(255,255,255,.6);font-size:14.5px;margin-top:10px}

/* ============================================================
   WHY US (6 blocks)
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.why-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:28px;transition:transform .45s var(--ease-out), box-shadow .45s var(--ease-out), border-color .4s;
}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--green-tint-2)}
.why-card:hover .icon-tile{transform:translateY(-3px)}
.why-card h3{font-size:19px;margin-top:20px}
.why-card p{color:var(--muted);font-size:14.5px;margin-top:10px}

/* ============================================================
   ENGAGEMENTS (split)
   ============================================================ */
/* ============================================================
   TÉMOIGNAGES — colonnes défilantes
   ============================================================ */
.testi-section{ background:var(--surface); overflow:hidden; }

.testi-header{
  display:flex; flex-direction:column; align-items:center;
  text-align:center; max-width:560px; margin-inline:auto;
  margin-bottom:clamp(40px,5vw,64px);
}
.testi-lead{
  margin-top:16px; font-size:clamp(15px,1.3vw,17px);
  color:var(--muted); line-height:1.65; max-width:420px;
}

/* Wrapper 3 colonnes avec masque fondu haut/bas */
.testi-columns{
  display:flex; gap:24px; justify-content:center;
  max-height:740px; overflow:hidden;
  mask-image:linear-gradient(to bottom, transparent 0%, #000 10%, #000 90%, transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 10%, #000 90%, transparent 100%);
}

.testi-col{ flex:0 0 280px; overflow:hidden; }
.testi-col--md{ display:none; }
.testi-col--lg{ display:none; }

/* Track animé — translateY calculé via JS */
.testi-track{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:20px;
}

/* Animation défilement continu */
@keyframes scroll-up{ to{ transform:translateY(-50%); } }
.testi-track{ animation:scroll-up var(--testi-dur,15s) linear infinite; }
.testi-track:hover{ animation-play-state:paused; }

/* Carte individuelle */
.testi-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:28px 26px;
  box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease-out), box-shadow .25s;
}
.testi-card:hover{
  transform:translateY(-6px) scale(1.02);
  box-shadow:var(--shadow-md);
}
.testi-card blockquote{ margin:0; padding:0; }
.testi-card p{
  font-size:14.5px; line-height:1.65; color:var(--ink-2);
  margin:0;
}
.testi-card footer{
  display:flex; align-items:center; gap:12px;
  margin-top:20px;
}
.testi-card img{
  width:40px; height:40px; border-radius:50%; object-fit:cover;
  border:2px solid var(--line);
  flex:none;
}
.testi-card cite{
  font-style:normal; font-weight:600; font-size:14px;
  color:var(--ink); display:block; line-height:1.3;
}
.testi-card .testi-role{
  font-size:12.5px; color:var(--muted); margin-top:2px;
}

@media(min-width:768px){
  .testi-col{ flex:0 0 300px; }
  .testi-col--md{ display:block; }
}
@media(min-width:1024px){
  .testi-col{ flex:0 0 320px; }
  .testi-col--lg{ display:block; }
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.faq-col-left{position:sticky;top:120px}
.faq-badge{
  display:inline-flex;align-items:center;
  border:1px solid var(--line);border-radius:999px;
  padding:4px 14px;font-size:12px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink);
}
.faq-lead{color:var(--muted);font-size:16px;line-height:1.65;margin-top:16px;max-width:420px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 0;text-align:left;font-size:16px;font-weight:500;
  letter-spacing:-.01em;color:var(--ink);transition:color .2s;
}
.faq-q:hover{color:var(--green)}
.faq-chevron{
  width:16px;height:16px;flex:none;color:var(--muted);
  transition:transform .3s var(--ease);
}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 24px 20px 0;color:var(--muted);font-size:15px;line-height:1.65}

/* ============================================================
   CTA FINAL
   ============================================================ */
/* CTA11 — carte centrée style shadcn */
.cta11-wrap{display:flex;align-items:center;justify-content:center}
.cta11-card{
  display:flex;flex-direction:column;align-items:center;
  position:relative;overflow:hidden;
  background:#03241A;
  border:1px solid rgba(255,255,255,.07);
  border-radius:clamp(16px,2vw,24px);
  padding:clamp(40px,6vw,80px) clamp(32px,6vw,100px);
  text-align:center;
  max-width:1100px;width:100%;
}
/* Fond Ethereal Shadows */
.cta11-etheral{
  position:absolute;inset:-60px;
  filter:url(#etheral-filter) blur(4px);
  pointer-events:none;z-index:0;
}
.cta11-etheral-inner{
  width:100%;height:100%;
  background-color:rgba(10,113,78,1);
  mask-image:url('https://framerusercontent.com/images/ceBGguIpUU8luwByxuQz79t7To.png');
  mask-size:cover;mask-repeat:no-repeat;mask-position:center;
  -webkit-mask-image:url('https://framerusercontent.com/images/ceBGguIpUU8luwByxuQz79t7To.png');
  -webkit-mask-size:cover;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;
}
.cta11-card > *:not(.cta11-etheral){position:relative;z-index:1}
.cta11-title{
  font-size:clamp(24px,3.5vw,42px);
  font-weight:700;letter-spacing:-.02em;line-height:1.15;
  max-width:680px;color:#fff;
}
.cta11-desc{
  color:rgba(255,255,255,.80);font-size:clamp(15px,1.2vw,18px);
  line-height:1.65;max-width:560px;
  margin-top:clamp(12px,1.5vw,20px);
  margin-bottom:clamp(24px,3vw,40px);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:rgba(255,255,255,.7);padding-top:clamp(60px,8vw,96px)}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .brand{color:#fff;margin-bottom:20px}
.footer-about{font-size:14.5px;line-height:1.65;max-width:340px}
.footer-soc{display:flex;gap:10px;margin-top:24px}
.footer-soc a{width:40px;height:40px;border-radius:11px;border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;color:#fff;transition:.3s var(--ease)}
.footer-soc a:hover{background:var(--green);border-color:var(--green);transform:translateY(-3px)}
.footer-soc svg{width:18px;height:18px}
.footer-col h5{color:#fff;font-size:13px;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.footer-col a{display:block;padding:7px 0;font-size:14.5px;transition:color .25s, padding-left .25s}
.footer-col a:hover{color:#fff;padding-left:4px}
.footer-certs{display:flex;gap:12px;margin-top:18px;align-items:center}
.footer-qualiopi-logo{height:auto;max-width:140px;display:block;background:#fff;border-radius:8px;padding:8px 12px}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:26px 0;flex-wrap:wrap}
.footer-bottom .legal{display:flex;gap:24px;flex-wrap:wrap}
.footer-bottom a{font-size:13.5px}
.footer-bottom .cop{font-size:13.5px;color:rgba(255,255,255,.45)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out), transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   INNER PAGES
   ============================================================ */
.page-hero{position:relative;padding-top:148px;padding-bottom:clamp(48px,6vw,80px);overflow:hidden}
.page-hero .hero-bg .b1{width:520px;height:520px;top:-200px;right:-100px}
.page-hero--dark{background:var(--green-ink);color:#fff}
.page-hero--dark .breadcrumb a,.page-hero--dark .breadcrumb span{color:rgba(255,255,255,.6)}
.page-hero--dark .breadcrumb a:hover{color:#fff}
.page-hero--dark h1{color:#fff}
.page-hero--dark .lead{color:rgba(255,255,255,.72)}
.breadcrumb{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--muted);font-family:var(--mono);letter-spacing:.02em}
.breadcrumb a{color:var(--muted);transition:color .2s}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb .sep{opacity:.5}
.page-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,64px);align-items:center;margin-top:30px}
.page-hero-copy h1{margin-top:20px}
.page-hero-copy .lead{margin-top:22px;max-width:560px}
.page-hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:32px}
.page-hero-visual .ph{aspect-ratio:4/3.4;border-radius:var(--r-xl);border:1px solid var(--line)}
.page-hero--dark .page-hero-visual .ph{border-color:rgba(255,255,255,.12);background:repeating-linear-gradient(135deg,#0a3528,#0a3528 11px,#0d3e2f 11px,#0d3e2f 22px)}
.page-hero--dark .ph-tag{background:rgba(4,44,31,.9);color:#7FD9B4;border-color:rgba(127,217,180,.25)}

/* Stat band */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:40px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg)}
.stat-band .sb{display:flex;flex-direction:column;gap:6px;align-items:center;text-align:center}
.stat-band .sb-n{font-size:clamp(32px,3.6vw,46px);font-weight:600;letter-spacing:-.03em;color:var(--green);line-height:1;font-feature-settings:"tnum"}
.stat-band .sb-l{font-size:14.5px;color:var(--muted)}
.stat-band--dark{background:var(--green-ink);border-color:transparent}
.stat-band--dark .sb-n{color:#7FD9B4}
.stat-band--dark .sb-l{color:rgba(255,255,255,.66)}

/* Feature rows (alternating) */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.feature-row + .feature-row{margin-top:clamp(56px,7vw,104px)}
.feature-row.reverse .fr-media{order:2}
.fr-media .ph{aspect-ratio:4/3.2;border-radius:var(--r-xl);border:1px solid var(--line)}
.fr-screenshot{width:100%;height:auto;border-radius:var(--r-xl);border:1px solid var(--line);box-shadow:0 16px 48px rgba(6,40,28,.1);display:block}
.fr-copy h3{margin-top:18px}
.fr-copy p{color:var(--muted);margin-top:16px;font-size:16px}
.fr-list{margin-top:24px;display:grid;gap:12px}
.fr-list li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--ink-2)}
.fr-list li svg{width:20px;height:20px;color:var(--green);flex:none;margin-top:2px}

/* Use-case grid */
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.uc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;transition:transform .45s var(--ease-out), box-shadow .45s, border-color .4s}
.uc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--green-tint-2)}
.uc-card:hover .icon-tile{background:var(--green);color:#fff}
.uc-card h3{font-size:18px;margin-top:18px}
.uc-card p{color:var(--muted);font-size:14.5px;margin-top:9px}
.uc-card .uc-tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-top:14px;display:block}

/* Process list (numbered) */
.proc{display:grid;gap:14px;margin-top:48px}
.proc-item{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 28px;transition:border-color .35s, box-shadow .35s}
.proc-item:hover{border-color:var(--green-tint-2);box-shadow:var(--shadow-sm)}
.proc-num{font-family:var(--mono);font-size:15px;font-weight:700;color:#fff;background:var(--green);width:44px;height:44px;border-radius:12px;display:grid;place-items:center;flex:none}
.proc-item h3{font-size:19px}
.proc-item p{color:var(--muted);font-size:15px;margin-top:7px}

/* ── Method grid (stepper style colonnes) ── */
.method-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  overflow:hidden;
  margin-top:clamp(40px,5vw,56px);
}
.method-col{
  display:flex;flex-direction:column;justify-content:space-between;
  padding:clamp(24px,3vw,40px) clamp(20px,2.5vw,32px);
  min-height:220px;
  border-right:1px solid var(--line);
  background:#fff;
  transition:background .3s;
}
.method-col:last-child{ border-right:none; }
.method-col--active{ background:var(--green-soft); }
.method-col:hover{ background:var(--green-soft); }
.method-num{
  font-family:var(--mono);
  font-size:clamp(32px,4vw,52px);
  font-weight:700;
  color:var(--green);
  opacity:.35;
  line-height:1;
  align-self:flex-end;
}
.method-col--active .method-num{ opacity:.6; }
.method-title{
  font-size:clamp(14px,1.2vw,16px);
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.01em;
  line-height:1.35;
  margin-bottom:8px;
}
.method-desc{
  font-size:13.5px;
  color:var(--muted);
  line-height:1.6;
}

@media(max-width:720px){
  .method-grid{ grid-template-columns:1fr 1fr; }
  .method-col:nth-child(2){ border-right:none; }
  .method-col:nth-child(1),.method-col:nth-child(2){ border-bottom:1px solid var(--line); }
}
@media(max-width:480px){
  .method-grid{ grid-template-columns:1fr; }
  .method-col{ border-right:none;border-bottom:1px solid var(--line); }
  .method-col:last-child{ border-bottom:none; }
}

/* Pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px;align-items:stretch}
.price-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;display:flex;flex-direction:column;transition:transform .45s var(--ease-out), box-shadow .45s, border-color .4s}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.price-card.featured{background:linear-gradient(165deg,var(--green-800),var(--green-ink));color:#fff;border-color:transparent;box-shadow:var(--shadow-green)}
.price-card.featured .pc-name,.price-card.featured .pc-price,.price-card.featured .pc-feat li{color:#fff}
.price-card.featured .pc-feat li svg{color:#7FD9B4}
.price-card.featured .pc-desc{color:rgba(255,255,255,.7)}
.pc-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:#7FD9B4;color:var(--green-ink);font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:7px 16px;border-radius:999px}
.pc-name{font-size:16px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:700}
.pc-price{font-size:40px;font-weight:600;letter-spacing:-.03em;margin-top:18px;line-height:1}
.pc-price small{font-size:16px;font-weight:400;color:var(--muted)}
.price-card.featured .pc-price small{color:rgba(255,255,255,.7)}
.pc-desc{font-size:14.5px;color:var(--muted);margin-top:12px;min-height:42px}
.pc-feat{margin:24px 0 28px;display:grid;gap:12px;flex:1}
.pc-feat li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--ink-2)}
.pc-feat li svg{width:18px;height:18px;color:var(--green);flex:none;margin-top:2px}
.price-note{text-align:center;margin-top:28px;font-size:14px;color:var(--muted)}

/* Sector cross-links */
.sector-links{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:48px}
.sector-chip{display:flex;align-items:center;gap:12px;padding:16px 18px;background:#fff;border:1px solid var(--line);border-radius:14px;transition:transform .35s var(--ease-out), box-shadow .35s, border-color .35s}
.sector-chip:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:var(--green-tint-2)}
.sector-chip:hover .icon-tile{background:var(--green);color:#fff}
.sector-chip .icon-tile{width:38px;height:38px;border-radius:10px}
.sector-chip .icon-tile svg{width:19px;height:19px}
.sector-chip span.sc-name{font-weight:600;font-size:14.5px;letter-spacing:-.01em}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(32px,5vw,64px);align-items:start}
.contact-info{display:grid;gap:14px}
.ci-item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 24px}
.ci-item .icon-tile{width:46px;height:46px;border-radius:12px}
.ci-item h4{font-size:16px;font-weight:600}
.ci-item p,.ci-item a{font-size:14.5px;color:var(--muted);margin-top:4px;display:block}
.ci-item a:hover{color:var(--green)}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(28px,4vw,42px);box-shadow:var(--shadow-md)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-size:13.5px;font-weight:600;color:var(--ink-2)}
.field label .req{color:var(--green)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:15px;color:var(--ink);
  padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;background:var(--surface);
  transition:border-color .25s, background .25s, box-shadow .25s;width:100%;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 4px var(--green-tint)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.form-consent{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--muted);margin-bottom:22px}
.form-consent input{width:18px;height:18px;margin-top:2px;accent-color:var(--green);flex:none}
.form-success{display:none;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:50px 30px}
.form-success .fs-icon{width:64px;height:64px;border-radius:50%;background:var(--green-tint);color:var(--green);display:grid;place-items:center}
.form-success .fs-icon svg{width:32px;height:32px;stroke-width:2.2}
.form-success h3{font-size:24px}
.form-success p{color:var(--muted)}

/* CTA simple inline variant uses .cta-band */

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .mega{grid-template-columns:1fr;width:min(760px,calc(100vw - 32px))}
  .mega-feature{flex-direction:row;align-items:center;gap:24px}
  .mega-feature .mega-price{margin-top:0;padding-top:0}
  .mega-feature .btn{margin-top:0}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-visual{max-width:520px}
  .faq-grid{grid-template-columns:1fr;gap:36px}
  .faq-col-left{position:static}
  .page-hero-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .feature-row{grid-template-columns:1fr;gap:24px}
  .feature-row .fr-copy{order:1}
  .feature-row .fr-media{order:2}
  .feature-row.reverse .fr-media{order:2}
}
@media (max-width:900px){
  .nav-center{display:none}
  .btn--nav-outline,.btn--nav-solid{display:none}
  .burger{display:grid}
  .cards-3{grid-template-columns:1fr;gap:18px}
  .why-grid{grid-template-columns:1fr 1fr}
  .uc-grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr;gap:32px}
  .stat-band{grid-template-columns:1fr 1fr;gap:28px}
  .sector-links{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:8px}
  .step{border-right:none !important;padding-left:22px;padding-right:22px}
  .step-line{display:none}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
}
@media (max-width:620px){
  body{font-size:16px;line-height:1.7}
  .section{padding-block:72px}
  .brand-logo{height:44px}
  .nav{padding:10px 16px}
  .nav-cta .btn--primary{display:none}
  .why-grid{grid-template-columns:1fr}
  .uc-grid{grid-template-columns:1fr}
  .stat-band{grid-template-columns:1fr 1fr}
  .sector-links{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .hero-trust .divider{display:none}
  .footer-top{grid-template-columns:1fr}
  .float-card{transform:scale(.86)}
  .fc-1{left:-2%}.fc-2{right:-2%}
}

/* ============================================================
   FORMATION IA — page-specific styles
   ============================================================ */

/* Hero Formation — centré, même fond que homepage */
.fi-hero-section{
  min-height:90svh;
  align-items:center; /* centre verticalement */
}

/* Surcharge : contenu centré */
.fi-hero-content{
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
  padding-bottom:clamp(56px,7vw,96px);
}

.fi-hero-eyebrow{
  display:inline-block;
  font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(127,217,180,.85);
  margin-bottom:24px;
}

.fi-hero-title{
  font-size:clamp(26px,3vw,42px);
  font-weight:600;letter-spacing:-.03em;line-height:1.2;
  color:#fff;
  max-width:90vw;
  text-align:center;
}
.fi-hero-title em{ font-style:normal; color:#7FD9B4; }
.fi-hero-btn{
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.fi-hero-btn:hover{
  background:rgba(255,255,255,.1);
  border-color:#fff;
}

.fi-hero-section .hero5-sub{
  max-width:600px;
  text-align:center;
  margin-inline:auto;
}

.fi-hero-section .hero5-actions{
  justify-content:center;
}

/* Fondu bas : transparent → blanc — courbe ease-in pour éviter les bandes */
.fi-hero-fade{
  position:absolute;
  bottom:0;left:0;
  width:100%;
  height:80px;
  background:linear-gradient(to bottom,
    rgba(255,255,255,0)   0%,
    rgba(255,255,255,.01) 10%,
    rgba(255,255,255,.04) 20%,
    rgba(255,255,255,.09) 30%,
    rgba(255,255,255,.17) 40%,
    rgba(255,255,255,.29) 50%,
    rgba(255,255,255,.45) 60%,
    rgba(255,255,255,.63) 70%,
    rgba(255,255,255,.80) 80%,
    rgba(255,255,255,.93) 90%,
    rgba(255,255,255,1)   100%
  );
  z-index:12;
  pointer-events:none;
}

/* Désactive le ::after du hero5 sur cette page (remplacé par fi-hero-fade) */
.fi-hero-section::after{ display:none; }

/* Section surface alternée */
.section--surface{ background:var(--surface); }

/* ── PlaceCard — carte formation avec carousel ── */
.plcard{
  margin-top:clamp(32px,4vw,52px);
  max-width:380px;
  border-radius:20px;
  border:1px solid var(--line);
  background:var(--white);
  overflow:hidden;
  box-shadow:0 4px 24px rgba(15,23,42,.07), 0 0 0 1px rgba(0,0,0,.03);
  cursor:pointer;
  transition:transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s cubic-bezier(.22,1,.36,1);
}
.plcard:hover{
  transform:scale(1.03) translateY(-4px);
  box-shadow:0 20px 48px -8px rgba(15,23,42,.15), 0 0 0 1px rgba(0,0,0,.06);
}

/* Carousel */
.plcard-carousel{
  position:relative;
  height:240px;
  overflow:hidden;
}
.plcard-track{
  display:flex;
  height:100%;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.plcard-slide{
  flex:0 0 100%;
  width:100%;height:100%;
  object-fit:cover;display:block;
}

/* Nav buttons (visibles au hover) */
.plcard-nav{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 8px;
  opacity:0;
  transition:opacity .2s;
}
.plcard-carousel:hover .plcard-nav{ opacity:1; }
.plcard-btn{
  width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.35);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  transition:background .2s, transform .2s;
  backdrop-filter:blur(4px);
}
.plcard-btn:hover{ background:rgba(0,0,0,.55); transform:scale(1.1); }

/* Badges haut gauche */
.plcard-top-left{
  position:absolute;top:12px;left:12px;
  display:flex;gap:6px;
}
.plcard-badge{
  padding:3px 10px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border-radius:999px;
  font-size:11.5px;font-weight:600;
  color:var(--ink);
  border:1px solid rgba(255,255,255,.5);
}
.plcard-rating{
  display:inline-flex;align-items:center;gap:5px;
}

/* Rating haut droit */
.plcard-top-right{
  position:absolute;top:12px;right:12px;
}

/* Pagination dots */
.plcard-dots{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;align-items:center;
}
.plcard-dot{
  height:6px;width:6px;border-radius:999px;
  background:rgba(255,255,255,.5);
  border:none;cursor:pointer;padding:0;
  transition:width .25s ease, background .25s ease;
}
.plcard-dot.active{
  width:16px;
  background:#fff;
}

/* Corps de la carte */
.plcard-body{
  padding:20px;
  display:flex;flex-direction:column;gap:10px;
}
.plcard-row{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
}
.plcard-title{
  font-size:19px;font-weight:700;letter-spacing:-.02em;
  color:var(--ink);line-height:1.2;margin:0;
}
.plcard-top-badge{
  flex:none;
  font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:6px;
  background:var(--green-tint);
  color:var(--green-700);
  border:1px solid var(--green-tint-2);
}
.plcard-sub{
  font-size:13.5px;color:var(--muted);margin:0;
}
.plcard-desc{
  font-size:13.5px;color:var(--muted);line-height:1.6;margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.plcard-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:8px;border-top:1px solid var(--line);
  margin-top:4px;
}
.plcard-price{
  font-size:17px;font-weight:700;color:var(--ink);margin:0;
}
.plcard-price span{
  font-size:13px;font-weight:400;color:var(--muted);
}
.plcard-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;padding:9px 18px;
}

/* ── Indicateurs qualité — rectangle pleine largeur ── */
.fi-iq-band{
  margin-top:clamp(24px,3vw,40px);
  background:#fff;
  border:1px solid var(--line);
  border-radius:clamp(14px,1.5vw,20px);
  padding:clamp(28px,3vw,44px) clamp(28px,4vw,56px);
  box-shadow:var(--shadow-sm);
  display:grid;
  grid-template-columns:1fr auto;
  gap:clamp(24px,3vw,48px);
  align-items:center;
}
.fi-iq-title{
  font-size:clamp(16px,1.5vw,20px);
  font-weight:700;letter-spacing:-.01em;color:var(--ink);
  margin:0 0 8px;
}
.fi-iq-desc{
  font-size:13.5px;color:var(--muted);line-height:1.6;
  max-width:360px;margin:0;
}
.fi-iq-stats{
  display:flex;align-items:center;gap:0;
  flex-shrink:0;
}
.fi-iq-stat{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  text-align:center;
  padding:0 clamp(20px,3vw,44px);
}
.fi-iq-divider{
  width:1px;height:60px;
  background:var(--line);flex:none;
}
.fi-iq-value{
  font-size:clamp(32px,4vw,48px);
  font-weight:700;letter-spacing:-.03em;
  color:var(--green);line-height:1;
}
.fi-iq-label{
  font-size:13px;font-weight:600;color:var(--ink);
  margin-top:4px;
}
.fi-iq-date{
  font-size:11px;color:var(--muted);
  font-style:italic;margin-top:2px;
}

/* ── Programme ── */
.fi-prog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2vw,28px);
  margin-top:clamp(32px,4vw,52px);
}
.fi-day{
  background:#fff;
  border:1px solid var(--line);
  border-radius:clamp(12px,1.5vw,20px);
  overflow:hidden;
}
.fi-day-head{
  background:var(--green-ink);
  padding:clamp(20px,2vw,28px) clamp(20px,2vw,28px) clamp(16px,1.5vw,20px);
}
.fi-day-num{
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--green-tint);display:block;margin-bottom:8px;
}
.fi-day-title{
  font-size:clamp(15px,1.3vw,18px);font-weight:700;
  color:#fff;line-height:1.3;margin:0;
}
.fi-day-list{
  list-style:none;margin:0;padding:clamp(20px,2vw,28px);
  display:flex;flex-direction:column;gap:10px;
}
.fi-day-list li{
  font-size:14px;color:var(--ink-2);line-height:1.5;
  padding-left:18px;position:relative;
}
.fi-day-list li::before{
  content:'';position:absolute;left:0;top:7px;
  width:6px;height:6px;border-radius:50%;
  background:var(--green);flex:none;
}

/* ── Compétences ── */
.fi-skills-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);align-items:start;
}
.fi-skills-copy .h2{ margin:0; }
.fi-skills-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:14px;
}
.fi-skills-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:clamp(14px,1.1vw,16px);color:var(--ink-2);line-height:1.5;
}
.fi-skills-list svg{
  width:18px;height:18px;color:var(--green);
  flex:none;margin-top:2px;
}

/* ── Outils ── */
/* Qualiopi section */
.fi-qualiopi-grid{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(32px,5vw,64px);
  align-items:center;
}
.fi-qualiopi-logo{
  display:flex;align-items:center;justify-content:center;
  background:var(--white);
  border:1.5px solid var(--line);
  border-radius:var(--r-lg);
  padding:36px 48px;
}
.fi-qualiopi-logo img{
  max-width:220px;width:100%;height:auto;
}
.fi-qualiopi-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.fi-qualiopi-item{
  background:var(--surface-2);
  border-radius:var(--r);
  padding:28px;
  border:1px solid var(--line);
}
.fi-qualiopi-item h3{
  font-size:17px;font-weight:600;color:var(--ink);margin-bottom:10px;
}
.fi-qualiopi-item p{
  font-size:16px;color:var(--muted);line-height:1.7;
}
@media(max-width:860px){
  .fi-qualiopi-grid{grid-template-columns:1fr}
  .fi-qualiopi-cards{grid-template-columns:1fr}
}

.fi-tools-grid{
  display:flex;flex-wrap:wrap;gap:16px;
  margin-top:clamp(28px,3vw,44px);
  justify-content:center;
}
.fi-tool{
  display:flex;align-items:center;gap:10px;
  padding:14px 28px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  font-size:16px;font-weight:600;color:var(--ink);
  transition:border-color .2s,box-shadow .2s,transform .2s;
}
.fi-tool:hover{
  border-color:var(--green);
  box-shadow:0 0 0 3px var(--green-tint);
  transform:translateY(-2px);
}
.fi-tool-icon{ color:var(--green);font-size:14px; }

/* ── Publics ── */
.fi-pub-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(14px,2vw,24px);
  margin-top:clamp(32px,4vw,52px);
}
.fi-pub{
  background:#fff;border:1px solid var(--line);
  border-radius:clamp(12px,1.5vw,18px);
  padding:clamp(20px,2vw,28px);
  transition:transform .3s var(--ease-out),box-shadow .3s,border-color .3s;
}
.fi-pub:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-sm);
  border-color:var(--green-tint-2);
}
.fi-pub h3{ font-size:16px;font-weight:700;margin:14px 0 8px;color:var(--ink); }
.fi-pub p{ font-size:14px;color:var(--muted);line-height:1.55;margin:0; }

/* ── Process steps (horizontal) ── */
/* ── Process steps (horizontal) ── */
.process-steps{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:0;
  margin-top:clamp(40px,5vw,56px);
  position:relative;
}
.process-step{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  position:relative;
  padding:0 clamp(8px,1.5vw,20px);
}
.process-step:not(:last-child)::after{
  content:'';
  position:absolute;
  top:23px;
  left:calc(50% + 28px);
  right:calc(-50% + 28px);
  height:2px;
  background:linear-gradient(to right, var(--green), rgba(27,94,60,.15));
}
.process-num{
  width:48px;height:48px;
  border-radius:50%;
  border:2px solid var(--green);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;letter-spacing:.04em;
  color:var(--green);
  font-family:'Space Mono',monospace;
  flex-shrink:0;
  background:#fff;
  position:relative;
  z-index:1;
}
.process-body{
  margin-top:18px;
}
.process-title{
  font-size:clamp(14px,1.3vw,16px);
  font-weight:700;letter-spacing:-.02em;
  color:var(--ink);
  margin:0 0 8px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.process-desc{
  font-size:13.5px;color:var(--muted);line-height:1.6;margin:0;
}
@media(max-width:768px){
  .process-steps{ grid-template-columns:1fr; gap:clamp(24px,4vw,40px); }
  .process-step{ align-items:flex-start; text-align:left; }
  .process-step:not(:last-child)::after{ display:none; }
}

/* ── Outils compatibles ── */
.tools-header{
  max-width:640px;
  margin-bottom:clamp(32px,4vw,48px);
}
.tools-label{
  font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--green);margin:0 0 12px;
}
.tools-grid{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.tool-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 20px;
  border:1.5px solid var(--line);
  border-radius:100px;
  background:#fff;
  font-size:14.5px;font-weight:600;color:var(--ink);
  box-shadow:var(--shadow-sm);
  transition:border-color .2s, box-shadow .2s, transform .15s;
}
.tool-chip svg{
  width:18px;height:18px;
  stroke:var(--green);flex-shrink:0;
}
.tool-chip:hover{
  border-color:var(--green);
  box-shadow:0 4px 16px rgba(27,94,60,.1);
  transform:translateY(-2px);
}

/* ── Pain cards (défis secteur) ── */
.pains-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2vw,24px);
  margin-top:clamp(32px,4vw,48px);
}
.pain-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:clamp(14px,1.5vw,20px);
  padding:clamp(24px,3vw,36px);
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:12px;
  transition:box-shadow .2s, transform .2s;
}
.pain-card:hover{
  box-shadow:var(--shadow-md);
  transform:translateY(-3px);
}
.pain-num{
  font-size:13px;font-weight:700;letter-spacing:.06em;
  color:var(--green);
  font-family:'Space Mono',monospace;
}
.pain-title{
  font-size:clamp(16px,1.5vw,18px);
  font-weight:700;letter-spacing:-.02em;
  color:var(--ink);margin:0;
}
.pain-desc{
  font-size:14.5px;color:var(--muted);line-height:1.65;margin:0;
}
@media(max-width:768px){
  .pains-grid{ grid-template-columns:1fr; }
}

/* ── FAQ formation (pleine largeur) ── */
.fi-faq{
  max-width:780px;margin-inline:auto;
  margin-top:clamp(28px,3vw,44px);
}

/* ── Sticky cards stack (section pourquoi) ── */
.fi-stack-section{ background:#fff !important; }
.fi-stack-section .fi-scard{ background:#fff !important; }

.fi-stack-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:start;
}

/* Colonne gauche — sticky */
.fi-stack-left{
  position:sticky;
  top:clamp(110px,12vh,140px);

}
.fi-stack-left .eyebrow{ display:inline-block; margin-bottom:4px; }

/* Colonne droite — scroll container */
.fi-stack-right{
  padding-block:clamp(16px,2vw,32px);
  /* perspective pour l'effet z */
  perspective:1000px;
}

/* Carte sticky individuelle */
.fi-scard{
  position:sticky;

  top:calc(120px + var(--sy, 0px));
  z-index:var(--si, 1);

  background:#fff;
  border:1px solid var(--line);
  border-radius:clamp(14px,1.5vw,20px);
  padding:clamp(24px,2.5vw,36px);
  margin-bottom:clamp(16px,2vw,24px);

  box-shadow:0 4px 24px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.04);
  transform:translateZ(calc(var(--sz, 0) * 1px));
  backface-visibility:hidden;

  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-rows:auto auto;
  gap:12px 20px;
  align-items:start;
  transition:box-shadow .3s ease;
}
.fi-scard:hover{
  box-shadow:0 12px 36px rgba(10,113,78,.10), 0 0 0 1px rgba(10,113,78,.08);
}

/* Numéro (haut droit) */
.fi-scard-num{
  grid-column:2;grid-row:1;
  justify-self:end;
  font-size:22px;font-weight:700;
  color:var(--green);
  font-family:var(--mono);
  letter-spacing:-.02em;
  line-height:1;
}

/* Icône (haut gauche) */
.fi-scard-icon{
  grid-column:1;grid-row:1 / 3;
  align-self:start;
  width:44px;height:44px;
  border-radius:12px;
  background:var(--green-tint);
  display:flex;align-items:center;justify-content:center;
  flex:none;
  color:var(--green);
}
.fi-scard-icon svg{ width:22px;height:22px; }

.fi-scard-title{
  grid-column:2;grid-row:1;
  align-self:end;
  font-size:clamp(17px,1.5vw,21px);
  font-weight:700;letter-spacing:-.02em;
  color:var(--ink);margin:0;
  padding-right:40px; /* espace pour le numéro */
}

.fi-scard-desc{
  grid-column:1 / 3;grid-row:2;
  font-size:clamp(14px,1.1vw,16px);
  color:var(--muted);line-height:1.65;margin:0;
  padding-top:4px;
}
.fi-scard-link{
  grid-column:1 / 3;
  margin-top:16px;
  font-size:14px;font-weight:600;
  color:var(--green);
  text-decoration:none;
  transition:opacity .2s;
}
.fi-scard-link:hover{ opacity:.7; }

/* ── Responsive Formation ── */
@media(max-width:960px){
  .fi-prog-grid{ grid-template-columns:1fr; }
  .fi-pub-grid{ grid-template-columns:repeat(2,1fr); }
  .fi-skills-wrap{ grid-template-columns:1fr; }
  .fi-iq-band{ grid-template-columns:1fr; }
  .fi-iq-stats{ justify-content:center; }
  .fi-stack-layout{ grid-template-columns:1fr; }
  .fi-stack-left{ position:static; }
}
@media(max-width:600px){
  .fi-pub-grid{ grid-template-columns:1fr; }
  .fi-iq-stats{ flex-direction:column; }
  .fi-iq-divider{ width:80%;height:1px; }
  .fi-iq-stat{ padding:16px 0; }
  .gbcard{ max-width:100%; }
}
