/* ═══════════════════════════════
   DESIGN TOKENS
═══════════════════════════════ */
:root {
  --g0:#04200d; --g1:#0f5c28; --g2:#0f5c28; --g3:#1a8040;
  --g4:#2ea855; --g5:#5ec97e; --g6:#a8e4bc; --g7:#d6f2e2; --g8:#f0faf4;
  --cream:#faf8f3; --ivory:#f4f1ea;
  --stone:#6b7c72; --mist:#9aada2;
  --gold:#b8952a; --gold2:#d4b060; --gold3:#f0d080;
  --soil:#2c1f0f;
  --text:#111a14; --text2:#3a4e40; --text3:#6b7c72;
  --r:12px; --rl:20px; --rxl:32px;
  --disp:'Playfair Display',serif;
  --body:'DM Sans',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease2:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--body);color:var(--text);background:#fff;overflow-x:hidden}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--ivory)}
::-webkit-scrollbar-thumb{background:var(--g4);border-radius:2px}

/* ═══════════════════════════════
   NAV — v1 style (fond blanc permanent, hover scale+color)
═══════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  height:72px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5vw;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(26,122,60,0.08);
  transition:box-shadow .3s;
}
#nav.scrolled{box-shadow:0 4px 24px rgba(13,79,37,.1)}

/* Logo */
.nb{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.nb-logo{
  width:48px;height:48px;border-radius:50%;
  overflow:hidden;background:#fff;flex-shrink:0;
  box-shadow:0 2px 12px rgba(15,92,40,.15);
}
.nb-logo img{
  width:100%;height:100%;object-fit:contain;
  /* Remove black bg on logo.png */
  mix-blend-mode:multiply;
  filter:contrast(1.05) saturate(1.1);
}
.nb-text{display:flex;flex-direction:column;line-height:1.1}
.nb-name{font-family:var(--disp);font-size:20px;font-weight:700;color:var(--g2);letter-spacing:.04em}
.nb-sub{font-size:9px;font-weight:400;color:var(--mist);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}

/* Nav links — v1 hover: color + underline slide */
.nl{display:flex;align-items:center;gap:32px;list-style:none}
.nl a{
  font-size:14px;font-weight:500;color:var(--text2);
  text-decoration:none;position:relative;padding-bottom:3px;
  transition:color .2s;
}
.nl a::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--g2);border-radius:1px;
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s var(--ease);
}
.nl a:hover{color:var(--g2)}
.nl a:hover::after{transform:scaleX(1)}

.na{display:flex;align-items:center;gap:14px}
.lang{display:flex;gap:2px;background:var(--g8);border-radius:20px;padding:3px}
.lb{
  font-family:var(--body);font-size:12px;font-weight:600;
  padding:4px 12px;border:none;cursor:pointer;border-radius:16px;
  background:transparent;color:var(--g2);transition:all .2s;
}
.lb.on{background:var(--g2);color:#fff}
.ncta{
  font-family:var(--body);font-size:13px;font-weight:600;
  padding:10px 22px;background:var(--g2);color:#fff;
  border:none;border-radius:24px;text-decoration:none;
  transition:background .2s,transform .15s;cursor:pointer;
}
.ncta:hover{background:var(--g0);transform:translateY(-1px)}

.ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.ham span{display:block;width:22px;height:1.5px;background:var(--g2);border-radius:2px;transition:all .3s}
.ham.x span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.ham.x span:nth-child(2){opacity:0}
.ham.x span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mob-menu{
  display:none;position:fixed;inset:72px 0 0;
  background:#fff;z-index:899;
  flex-direction:column;padding:28px 5vw;overflow-y:auto;
}
.mob-menu.open{display:flex}
.mob-menu a{
  font-family:var(--disp);font-size:24px;font-weight:400;
  color:var(--text);text-decoration:none;
  padding:16px 0;border-bottom:1px solid rgba(15,92,40,.07);
  transition:color .2s,padding-left .2s;
}
.mob-menu a:hover{color:var(--g2);padding-left:8px}

/* ═══════════════════════════════
   HERO — full background image style
═══════════════════════════════ */
.hero{
  min-height:100vh;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
}
/* Layout plein écran : le content est positionné sur l'image */
.hero-fullbg{
  padding:0;
  background:none;
}
.hero-fullbg::before{display:none}

/* ── Image de fond ── */
.hero-bg-img{
  position:absolute;inset:0;
  z-index:0;
}
.hero-bg-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 30%;
  display:block;
  filter:saturate(1.08) brightness(0.88);
}
/* AA2 style: right border radius on the image container */
.hero-bg-rounded{
  border-bottom-right-radius:clamp(60px,8vw,120px);
  border-top-right-radius:clamp(60px,8vw,120px);
  overflow:hidden;
  right:0;left:0;
}
/* Overlay dégradé sombre pour lisibilité du texte */
.hero-bg-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    100deg,
    rgba(4,20,10,.72) 0%,
    rgba(4,20,10,.50) 45%,
    rgba(4,20,10,.18) 100%
  );
}
/* Trait déco blanc brossé en bas gauche (style CEMED) */
.hero-brush{
  position:absolute;
  bottom:0;left:0;right:0;
  height:90px;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 1440 90' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 90 Q200 30 500 60 Q800 90 1100 40 Q1300 10 1440 50 L1440 90 Z' fill='white' opacity='0.95'/%3E%3C/svg%3E") bottom center/cover no-repeat;
}

/* ── Contenu texte ── */
.hero-content{
  position:relative;z-index:2;
  padding:120px 5vw 130px;
  max-width:640px;
  animation:hIn .9s var(--ease2) both;
}
.hero-left{max-width:600px;animation:hIn .9s var(--ease2) both}

/* Badge version sombre (sur image) */
.hero-badge-dark{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(8px);
}
.hero-badge-dark span{color:#fff}
.badge-dot-white{background:#fff}

/* Titres et textes sur fond sombre */
.hero-h1-dark{
  font-family:var(--disp);
  font-size:clamp(40px,5.5vw,72px);
  font-weight:700;line-height:1.06;
  color:#fff;letter-spacing:-.02em;
  margin-bottom:24px;
  text-shadow:0 2px 24px rgba(0,0,0,.3);
}
.hero-h1-dark em{font-style:italic;color:var(--g5)}
.hero-p-dark{
  color:rgba(255,255,255,.82);
  font-size:clamp(15px,1.4vw,16px);
  font-weight:300;line-height:1.85;
  max-width:520px;margin-bottom:40px;
  text-shadow:0 1px 8px rgba(0,0,0,.2);
}

/* Bouton ghost blanc sur image */
.btn-ghost-white{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-size:15px;font-weight:500;
  color:#fff;text-decoration:none;
  padding:15px 0;
  border-bottom:1.5px solid rgba(255,255,255,.5);
  transition:gap .2s,border-color .2s;
}
.btn-ghost-white:hover{gap:14px;border-color:#fff}

/* Stats version blanc */
.hero-stats-dark{
  border-top:1px solid rgba(255,255,255,.2);
}
.stat-n-white{color:#fff}
.stat-l-white{color:rgba(255,255,255,.6)}

/* ── CECEDD Grand Titre ── */
.hero-brand-title{
  font-family:var(--disp);
  font-size:clamp(64px,9vw,130px);
  font-weight:700;
  color:rgba(255,255,255,.95);
  letter-spacing:-.02em;
  line-height:1;
  margin-bottom:8px;
  text-shadow:0 4px 40px rgba(0,0,0,.4);
}

/* ── Hero stats pills ── */
.hero-stats-pills{
  display:flex;align-items:center;gap:0;
  margin-top:36px;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:40px;
  padding:12px 28px;
  width:fit-content;
}
.hsp{display:flex;flex-direction:column;align-items:center;gap:2px;padding:0 20px}
.hsp-n{font-family:var(--disp);font-size:clamp(22px,2.5vw,32px);font-weight:700;color:#fff;line-height:1}
.hsp-n sup{font-size:.55em;vertical-align:super}
.hsp-l{font-size:10px;font-weight:500;color:rgba(255,255,255,.65);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}
.hsp-sep{width:1px;height:36px;background:rgba(255,255,255,.2)}

/* ── Hero AA1 floating cards (right side overlay) ── */
.hero-aa1{
  position:absolute;
  right:5vw;top:50%;
  transform:translateY(-50%);
  z-index:3;
  pointer-events:none;
}
@media(max-width:1000px){.hero-aa1{display:none}}

.hero-stats{
  display:flex;gap:clamp(28px,4vw,52px);
  margin-top:50px;padding-top:44px;
  border-top:1px solid rgba(15,92,40,.08);
}
.stat{display:flex;flex-direction:column;gap:3px}
.stat-n{
  font-family:var(--disp);
  font-size:clamp(30px,3.5vw,44px);
  font-weight:700;color:var(--g2);line-height:1;
}
.stat-l{font-size:11px;font-weight:500;color:var(--mist);letter-spacing:.1em;text-transform:uppercase}

/* Hero badge original (pages intérieures) */
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--g8);border:1px solid rgba(15,92,40,.12);
  border-radius:24px;padding:6px 16px;margin-bottom:28px;
}
.badge-dot{
  width:6px;height:6px;background:var(--g4);border-radius:50%;
  animation:pulseDot 2s infinite;
}
.hero-badge span{font-size:12px;font-weight:500;color:var(--g2);letter-spacing:.04em}
.hero-p{
  font-size:clamp(15px,1.4vw,15px);font-weight:280;line-height:1.85;
  color:var(--text2);max-width:490px;margin-bottom:38px;
}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-size:15px;font-weight:600;
  padding:15px 30px;background:var(--g2);color:#fff;
  border:none;border-radius:32px;text-decoration:none;cursor:pointer;
  transition:all .25s;box-shadow:0 6px 22px rgba(15,92,40,.26);
}
.btn-primary:hover{background:var(--g0);transform:translateY(-2px);box-shadow:0 10px 32px rgba(4,32,13,.3)}
.btn-primary .arr{transition:transform .2s}
.btn-primary:hover .arr{transform:translateX(4px)}
.btn-ghost2{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-size:15px;font-weight:500;
  color:var(--g2);text-decoration:none;
  padding:15px 0;border-bottom:1.5px solid rgba(15,92,40,.22);
  transition:gap .2s,border-color .2s;
}
.btn-ghost2:hover{gap:14px;border-color:var(--g2)}

/* Hero right (conservé pour compat) */
.hero-right{
  display:flex;align-items:center;justify-content:center;position:relative;
  animation:hRIn 1.1s var(--ease2) .2s both;
}
.hero-orb{position:relative;width:min(380px,44vw);height:min(380px,44vw)}
.orb-ring1{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(46,168,85,.15);animation:spin 24s linear infinite;}
.orb-ring1::before,.orb-ring1::after{content:'';position:absolute;border-radius:50%;}
.orb-ring1::before{width:10px;height:10px;background:var(--g4);top:-5px;left:50%;transform:translateX(-50%)}
.orb-ring1::after{width:6px;height:6px;background:var(--g6);bottom:-3px;left:50%;transform:translateX(-50%)}
.orb-ring2{position:absolute;inset:28px;border-radius:50%;border:1px dashed rgba(46,168,85,.1);animation:spin 36s linear infinite reverse;}
.orb-core{position:absolute;inset:56px;border-radius:50%;background:#fff;box-shadow:0 20px 70px rgba(4,32,13,.12);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.orb-core img{width:100%;height:100%;object-fit:cover;display:block;mix-blend-mode:normal;}
.fcard{position:absolute;background:#fff;border-radius:var(--r);padding:12px 15px;box-shadow:0 8px 32px rgba(0,0,0,.1);display:flex;align-items:center;gap:10px;white-space:nowrap;}
.fc1{bottom:5%;left:-10%;animation:floatY 4.2s ease-in-out infinite}
.fc2{top:8%;right:-6%;animation:floatY 5.1s ease-in-out 2s infinite}
.fci{width:34px;height:34px;flex-shrink:0;background:var(--g8);border-radius:9px;display:flex;align-items:center;justify-content:center;}
.fc-t{font-size:12px;font-weight:600;color:var(--text);display:block}
.fc-s{font-size:11px;color:var(--mist);display:block;margin-top:1px}

/* Hero img wrap (ancienne version) */
.hero-img-wrap{position:relative;width:min(430px,46vw);display:flex;align-items:center;justify-content:center;}
.hero-img-frame{position:relative;width:100%;aspect-ratio:4/5;border-radius:28px 28px 110px 28px;overflow:hidden;box-shadow:0 50px 120px rgba(4,32,13,.38),0 16px 48px rgba(4,32,13,.22);animation:heroImgFloat 7s ease-in-out infinite;}
.hero-img-frame::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,32,13,0) 45%,rgba(4,32,13,.5) 100%);pointer-events:none;z-index:1;}
.hero-main-img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.14) contrast(1.06);}
.hero-img-mini{position:absolute;bottom:-22px;left:-32px;width:126px;height:90px;border-radius:16px;overflow:hidden;border:3px solid rgba(255,255,255,.9);box-shadow:0 10px 36px rgba(4,32,13,.28);animation:floatY 5.8s ease-in-out 1.4s infinite;z-index:2;}
.hero-img-mini img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-img-wrap .fc1{bottom:14%;left:-16%;z-index:3}
.hero-img-wrap .fc2{top:8%;right:-12%;z-index:3}
@keyframes heroImgFloat{0%,100%{transform:translateY(0px)}30%{transform:translateY(-12px) rotate(.5deg)}65%{transform:translateY(-6px) rotate(-.3deg)}}

/* ═══════════════════════════════
   TICKER
═══════════════════════════════ */
.ticker{
  height:50px;background:var(--g1);
  display:flex;align-items:center;overflow:hidden;position:relative;
}
.ticker::before,.ticker::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:1;pointer-events:none;
}
.ticker::before{left:0;background:linear-gradient(to right,var(--g1),transparent)}
.ticker::after{right:0;background:linear-gradient(to left,var(--g1),transparent)}
.t-lbl{
  flex-shrink:0;font-size:10px;font-weight:600;
  color:rgba(255,255,255,.3);letter-spacing:.18em;text-transform:uppercase;
  padding:0 28px;border-right:1px solid rgba(255,255,255,.1);margin-right:28px;white-space:nowrap;
}
.t-inner{overflow:hidden;flex:1}
.t-track{display:flex;animation:tkScroll 22s linear infinite;will-change:transform}
.ti{
  font-size:12px;font-weight:500;color:rgba(255,255,255,.5);
  letter-spacing:.07em;text-transform:uppercase;
  padding:0 28px;border-right:1px solid rgba(255,255,255,.07);
  white-space:nowrap;display:flex;align-items:center;gap:9px;flex-shrink:0;
}

/* ═══════════════════════════════
   SECTIONS COMMUNES
═══════════════════════════════ */
.sec{padding:clamp(64px,9vw,120px) 5vw}
.sec-white{background:#fff}
.sec-ivory{background:var(--ivory)}
.sec-cream{background:var(--cream)}

.ey{
  display:inline-flex;align-items:center;gap:9px;
  font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--g3);margin-bottom:14px;
}
.ey::before{content:'';display:block;width:24px;height:1.5px;background:var(--g3);flex-shrink:0}
.ey-w{color:var(--g5)} .ey-w::before{background:var(--g5)}

.sh{
  font-family:var(--disp);
  font-size:clamp(28px,3.8vw,52px);
  font-weight:700;line-height:1.1;color:var(--text);letter-spacing:-.01em;
}
.sh em{font-style:italic;color:var(--g2)}
.sh-w{color:#fff}.sh-w em{color:var(--g5)}

.sb{font-size:16px;font-weight:300;line-height:1.9;color:var(--text2);max-width:540px;margin-top:14px}
.sb-w{color:rgba(255,255,255,.6)}

.rv{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease2),transform .7s var(--ease2)}
.rv-l{opacity:0;transform:translateX(-24px);transition:opacity .7s var(--ease2),transform .7s var(--ease2)}
.rv-r{opacity:0;transform:translateX(24px);transition:opacity .7s var(--ease2),transform .7s var(--ease2)}
.rv.in,.rv-l.in,.rv-r.in{opacity:1;transform:none}

/* ═══════════════════════════════
   ABOUT
═══════════════════════════════ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,100px);align-items:center}

.av-img-main{
  width:78%;aspect-ratio:3/4;border-radius:var(--rl);overflow:visible;
  position:relative;
}
/* L'image elle-même clippée dans un container interne */
.av-img-main > img, .av-img-main > .about-main-img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  border-radius:var(--rl);
  filter:saturate(1.12) contrast(1.05) brightness(1.02);
  position:relative;z-index:0;
}
.av-img-main::before{display:none}
.about-main-img{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:var(--rl)!important;}
/* Les blocs flottants (accent+quote) doivent être au-dessus */
.av-accent{z-index:2;position:absolute}
.av-quote{z-index:2;position:absolute}
.av-accent{
  position:absolute;bottom:-22px;right:-22px;
  width:min(172px,46%);background:var(--g2);border-radius:var(--rl);
  padding:26px 20px;color:#fff;box-shadow:0 16px 48px rgba(4,32,13,.22);
}
.av-acc-n{font-family:var(--disp);font-size:50px;font-weight:700;line-height:1}
.av-acc-l{font-size:12px;font-weight:300;opacity:.72;margin-top:4px;line-height:1.5}
.av-quote{
  position:absolute;top:20px;right:-6px;
  background:#fff;border-radius:var(--r);padding:15px 17px;
  box-shadow:0 8px 30px rgba(0,0,0,.1);width:min(195px,50%);
  border-left:3px solid var(--g4);
}
.av-quote p{font-size:12px;line-height:1.65;color:var(--text2);font-style:italic}
.av-quote cite{display:block;font-size:11px;font-weight:600;color:var(--g2);margin-top:7px;font-style:normal}

.ab-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.ab-chip{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--g8);border:1px solid rgba(15,92,40,.1);
  border-radius:20px;padding:6px 14px;
  font-size:12px;font-weight:500;color:var(--g2);transition:all .2s;
}
.ab-chip:hover{background:var(--g2);color:#fff;border-color:var(--g2)}

.mv-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}
.mv-card{
  background:var(--ivory);border:1px solid rgba(15,92,40,.07);
  border-radius:var(--r);padding:20px 18px;
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.mv-card:hover{border-color:rgba(15,92,40,.2);box-shadow:0 8px 30px rgba(15,92,40,.07);transform:translateY(-3px)}
.mv-ico{width:36px;height:36px;background:#fff;border:1px solid rgba(15,92,40,.09);border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.mv-ttl{font-family:var(--disp);font-size:16px;font-weight:700;color:var(--g1);margin-bottom:7px}
.mv-txt{font-size:13px;line-height:1.75;color:var(--stone)}

.vals{display:flex;flex-direction:column;gap:10px;margin-top:22px}
.val-row{display:flex;align-items:flex-start;gap:13px;padding:12px 14px;border-radius:var(--r);transition:background .2s}
.val-row:hover{background:var(--ivory)}
.vdot{width:6px;height:6px;flex-shrink:0;background:var(--g4);border-radius:50%;margin-top:8px}
.vtxt{font-size:14px;line-height:1.7;color:var(--text2)}
.vtxt b{color:var(--text);font-weight:600}

/* ═══════════════════════════════
   SERVICES — style A1.png :
   card avec icon cercle en haut au centre dépassant,
   fond clair arrondi, titre + description
═══════════════════════════════ */
.svc-sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:clamp(48px,6vw,72px);flex-wrap:wrap;gap:20px;
}
.btn-ghost3{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-size:14px;font-weight:500;
  color:var(--g2);text-decoration:none;
  padding:12px 0;border-bottom:1.5px solid rgba(15,92,40,.2);
  transition:gap .2s,border-color .2s;
}
.btn-ghost3:hover{gap:13px;border-color:var(--g2)}

.svc-grid-a1{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,3vw,36px);
  padding-top:40px;/* espace pour le cercle dépassant */
}
/* Carte style A1 */
.svc-a1{
  position:relative;
  background:var(--g8);
  border-radius:var(--rl);
  border:1px solid rgba(15,92,40,.07);
  padding:clamp(28px,3vw,40px) clamp(20px,2.5vw,32px) clamp(24px,2.5vw,32px);
  padding-top:clamp(48px,5vw,60px);
  transition:all .35s var(--ease2);
  cursor:default;margin-top:32px;
}
.svc-a1:hover{
  background:#fff;
  box-shadow:0 20px 60px rgba(4,32,13,.1);
  transform:translateY(-6px);border-color:rgba(15,92,40,.12);
}
/* Cercle icon dépassant en haut */
.svc-a1-ico{
  position:absolute;
  top:-32px;left:50%;transform:translateX(-50%);
  width:64px;height:64px;border-radius:50%;
  background:var(--g2);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(15,92,40,.3);
  transition:background .3s,transform .3s,box-shadow .3s;
}
.svc-a1:hover .svc-a1-ico{
  background:var(--g0);
  transform:translateX(-50%) translateY(-4px);
  box-shadow:0 14px 32px rgba(15,92,40,.36);
}
.svc-a1-n{
  font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--g4);
  text-transform:uppercase;margin-bottom:10px;text-align:center;
}
.svc-a1-ttl{
  font-family:var(--disp);font-size:clamp(17px,1.8vw,20px);
  font-weight:700;color:var(--text);line-height:1.25;
  margin-bottom:12px;text-align:center;
}
.svc-a1-dsc{
  font-size:13.5px;line-height:1.8;color:var(--stone);text-align:center;
}
/* Bottom accent */
.svc-a1::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--g3),var(--g5));
  border-radius:0 0 var(--rl) var(--rl);
  transform:scaleX(0);transition:transform .35s;
}
.svc-a1:hover::after{transform:scaleX(1)}

/* ═══════════════════════════════
   APPROCHE
═══════════════════════════════ */
.approach-wrap{background:var(--g1)}
.approach-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,90px);align-items:center}
.pillars{display:flex;flex-direction:column;gap:14px;margin-top:34px}
.pil{
  display:flex;align-items:flex-start;gap:18px;
  padding:20px 22px;background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.07);border-radius:var(--r);transition:all .25s;
}
.pil:hover{background:rgba(255,255,255,.06);border-color:rgba(94,201,126,.18)}
.pil-n{font-family:var(--disp);font-size:28px;font-weight:700;color:var(--g5);line-height:1;flex-shrink:0;width:32px}
.pil-h{font-size:14px;font-weight:600;color:#fff;margin-bottom:5px}
.pil-p{font-size:13px;line-height:1.75;color:rgba(255,255,255,.46)}
.atouts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.atout{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);padding:22px 18px;transition:all .25s}
.atout:hover{background:rgba(255,255,255,.07);border-color:rgba(94,201,126,.2)}
.atout-ico{width:40px;height:40px;background:rgba(255,255,255,.05);border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.atout-h{font-size:13px;font-weight:600;color:#fff;margin-bottom:6px}
.atout-p{font-size:12px;line-height:1.7;color:rgba(255,255,255,.42)}

/* ═══════════════════════════════
   ZONES
═══════════════════════════════ */
.zones-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,80px);align-items:start}
.zones-map-card{
  background:#fff;border-radius:var(--rxl);
  padding:clamp(28px,4vw,48px);text-align:center;
  border:1px solid rgba(15,92,40,.07);
  box-shadow:0 8px 48px rgba(15,92,40,.06);
}
.zi{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;background:#fff;
  border:1px solid rgba(15,92,40,.07);border-radius:var(--r);
  font-size:14px;color:var(--text);margin-bottom:9px;
  transition:all .25s;
}
.zi:hover{border-color:var(--g3);background:var(--g8);transform:translateX(5px);color:var(--g1)}
.zi-dot{width:8px;height:8px;flex-shrink:0;background:var(--g3);border-radius:50%}
.hq-box{
  display:flex;align-items:center;gap:13px;
  padding:16px 18px;background:var(--g8);
  border-radius:var(--r);border-left:3px solid var(--g3);margin-top:20px;
}
.hq-ico{width:36px;height:36px;flex-shrink:0;background:#fff;border-radius:9px;display:flex;align-items:center;justify-content:center}
.hq-txt{font-size:13px;color:var(--stone);line-height:1.55}.hq-txt b{color:var(--text)}

/* ═══════════════════════════════
   ÉVÉNEMENTS — style A2.png :
   card horizontale, image ronde à gauche dépassant,
   fond très clair, type + titre + meta
═══════════════════════════════ */
.evt-tabs{
  display:flex;gap:4px;background:rgba(15,92,40,.06);
  border-radius:24px;padding:4px;width:fit-content;margin-bottom:44px;
}
.etab{
  font-family:var(--body);font-size:13px;font-weight:500;
  padding:9px 22px;border:none;cursor:pointer;
  border-radius:20px;background:transparent;
  color:var(--stone);transition:all .25s;letter-spacing:.02em;
}
.etab.on{background:var(--g2);color:#fff;box-shadow:0 4px 14px rgba(15,92,40,.22)}

/* Upcoming – style A2.png exact */
.evt-list{display:flex;flex-direction:column;gap:18px}

.ev-card{
  display:flex;align-items:center;
  background:var(--ivory);
  border-radius:var(--rl);
  border:1px solid rgba(15,92,40,.07);
  padding:20px 24px 20px 0;
  transition:all .3s var(--ease);
  cursor:pointer;position:relative;overflow:visible;
}
.ev-card:hover{box-shadow:0 14px 48px rgba(4,32,13,.1);transform:translateY(-3px);border-color:rgba(15,92,40,.15);background:#fff}

/* Image ronde gauche dépassant */
.ev-img-wrap{
  flex-shrink:0;
  width:min(180px,26vw);height:min(130px,20vw);
  margin-left:-1px;border-radius:var(--rl);
  overflow:hidden;position:relative;
  box-shadow:0 4px 16px rgba(0,0,0,.12);
}
.ev-img-wrap img,
.ev-img-placeholder{
  width:100%;height:100%;object-fit:cover;display:block;
}
.ev-img-placeholder{
  display:flex;align-items:center;justify-content:center;
}

.ev-body{flex:1;padding:0 20px}
.ev-type{
  display:inline-block;font-size:10px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--g2);background:#fff;
  border:1px solid rgba(15,92,40,.12);
  border-radius:14px;padding:4px 12px;margin-bottom:10px;
}
.ev-ttl{
  font-family:var(--disp);font-size:clamp(16px,2vw,21px);
  font-weight:700;color:var(--text);margin-bottom:14px;line-height:1.2;
}
.ev-meta{display:flex;gap:clamp(18px,3vw,40px);flex-wrap:wrap}
.ev-m{display:flex;flex-direction:column;gap:2px}
.ev-ml{font-size:10px;font-weight:600;color:var(--mist);letter-spacing:.08em;text-transform:uppercase}
.ev-mv{font-size:14px;font-weight:600;color:var(--g2)}

.ev-arrow{flex-shrink:0;padding-right:4px}
.ev-arr{
  width:44px;height:44px;
  background:var(--g2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;border:none;cursor:pointer;
  box-shadow:0 4px 14px rgba(15,92,40,.26);
  transition:all .25s;
}
.ev-arr:hover,.ev-card:hover .ev-arr{background:var(--g0);transform:scale(1.08)}

/* Past — portrait carousel avec vraies images illustratives */
.past-wrap{position:relative;overflow:hidden}
.past-track{display:flex;gap:18px;transition:transform .6s var(--ease2);will-change:transform}

.evp{
  flex-shrink:0;width:min(240px,65vw);
  border-radius:var(--rl);overflow:hidden;position:relative;cursor:pointer;
  transition:transform .3s;
}
.evp:hover{transform:scale(1.03)}
.evp-img{
  width:100%;aspect-ratio:3/4;position:relative;
  overflow:hidden;
}
.evp-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s var(--ease2);
}
.evp:hover .evp-img img{transform:scale(1.06)}
.evp-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(4,32,13,.85) 0%,rgba(4,32,13,.25) 55%,transparent 100%);
}
.evp-date{
  position:absolute;top:14px;left:14px;
  background:var(--gold);color:var(--soil);
  border-radius:18px;padding:5px 14px;
  font-size:11px;font-weight:700;letter-spacing:.04em;
}
.evp-body{position:absolute;bottom:0;left:0;right:0;padding:18px}
.evp-type{font-size:10px;font-weight:700;color:var(--g5);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.evp-ttl{font-family:var(--disp);font-size:16px;font-weight:700;color:#fff;line-height:1.3}

.past-nav{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:28px}
.evp-btn{
  width:38px;height:38px;background:var(--ivory);
  border:1px solid rgba(15,92,40,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--g2);cursor:pointer;transition:all .2s;
}
.evp-btn:hover{background:var(--g2);color:#fff;border-color:var(--g2)}
.evp-dots{display:flex;gap:7px;align-items:center}
.evpd{
  width:7px;height:7px;background:rgba(15,92,40,.15);
  border-radius:50%;border:none;cursor:pointer;transition:all .2s;
}
.evpd.on{background:var(--g2);width:22px;border-radius:3px}

/* ═══════════════════════════════
   TÉMOIGNAGES — style A4.png :
   2 colonnes : gauche = grand card coloré + navigation,
   droite = titre + description
═══════════════════════════════ */
.temo-section{
  background:var(--cream);
}
.temo-inner{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(40px,7vw,80px);
  align-items:center;
}

/* Colonne gauche : card visible + contrôles */
.temo-left{}
.temo-slider-wrap{position:relative;overflow:hidden}

/* La card principale verte */
.temo-card-main{
  background:var(--g2);
  border-radius:var(--rl);
  padding:clamp(28px,3.5vw,44px);
  position:relative;overflow:hidden;
  min-height:340px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.temo-card-main::before{
  content:'"';
  position:absolute;top:-20px;right:20px;
  font-family:var(--disp);font-size:180px;font-weight:700;
  color:rgba(255,255,255,.06);line-height:1;pointer-events:none;user-select:none;
}
.temo-quote{
  font-family:var(--disp);font-size:clamp(15px,1.6vw,18px);
  font-style:italic;font-weight:400;
  line-height:1.7;color:rgba(255,255,255,.92);
  margin-bottom:28px;position:relative;z-index:1;
}

/* Author row : icon + texte */
.temo-author{
  display:flex;align-items:center;gap:14px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:20px;
}
.temo-icon{
  width:46px;height:46px;flex-shrink:0;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  border:1.5px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.temo-icon img{width:100%;height:100%;object-fit:cover}
.temo-icon svg{opacity:.7}
.temo-info{}
.temo-name{font-size:14px;font-weight:600;color:#fff}
.temo-role{font-size:12px;color:rgba(255,255,255,.6);margin-top:2px}
.temo-org{
  font-size:10px;font-weight:700;color:var(--g5);
  letter-spacing:.08em;text-transform:uppercase;margin-top:4px;
}

/* Petites cards indicatrices en bas */
.temo-dots-row{
  display:flex;align-items:center;gap:10px;margin-top:18px;
}
.temo-dot-btn{
  width:8px;height:8px;background:rgba(15,92,40,.18);
  border-radius:50%;cursor:pointer;border:none;transition:all .25s;
}
.temo-dot-btn.on{background:var(--g2);width:26px;border-radius:4px}
.temo-nav-btns{display:flex;gap:8px;margin-left:auto}
.temo-nb{
  width:38px;height:38px;border-radius:50%;
  background:#fff;border:1px solid rgba(15,92,40,.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--g2);cursor:pointer;transition:all .2s;
}
.temo-nb:hover{background:var(--g2);color:#fff;border-color:var(--g2)}

/* Colonne droite */
.temo-right{}
.temo-right-desc{
  font-size:14px;line-height:1.85;color:var(--stone);
  margin-top:16px;
}
/* Mini témoignages sur la droite */
.temo-mini-list{
  display:flex;flex-direction:column;gap:12px;margin-top:28px;
}
.temo-mini{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;background:#fff;
  border-radius:var(--r);border:1px solid rgba(15,92,40,.07);
  cursor:pointer;transition:all .25s;
}
.temo-mini.active,.temo-mini:hover{
  border-color:var(--g3);background:var(--g8);
}
.temo-mini-ico{
  width:40px;height:40px;flex-shrink:0;
  border-radius:50%;background:var(--g8);
  border:1.5px solid rgba(15,92,40,.1);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.temo-mini-ico img{width:100%;height:100%;object-fit:cover}
.temo-mini-n{font-size:13px;font-weight:600;color:var(--text)}
.temo-mini-r{font-size:11px;color:var(--mist);margin-top:2px}
/* Étoiles mini */
.temo-mini-stars{display:flex;gap:2px;margin-top:3px}
.tstar{width:10px;height:10px;fill:var(--gold)}

/* ═══════════════════════════════
   CONTACT — style A3.png :
   gauche texte + mini offre card,
   droite formulaire fond vert avec cercles décoratifs
═══════════════════════════════ */
.contact-outer{
  background:var(--cream);
}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:start;
}

/* Gauche : info + carte offre */
.contact-left{}
.contact-sub{font-size:15px;line-height:1.85;color:var(--stone);margin-top:14px;max-width:420px}
.ci-items{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.ci{
  display:flex;align-items:flex-start;gap:13px;
  padding:16px 18px;background:#fff;
  border-radius:var(--r);border:1px solid rgba(15,92,40,.08);
  transition:all .2s;
}
.ci:hover{border-color:rgba(15,92,40,.18);box-shadow:0 4px 16px rgba(15,92,40,.06)}
.ci-ico{
  width:38px;height:38px;flex-shrink:0;
  background:var(--g2);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.ci-lbl{font-size:10px;font-weight:700;color:var(--mist);letter-spacing:.1em;text-transform:uppercase}
.ci-val{font-size:14px;color:var(--text);margin-top:3px;line-height:1.5}

/* Droite : formulaire — fond vert avec cercles */
.contact-form-wrap{
  background:var(--g2);
  border-radius:var(--rl);
  padding:clamp(28px,4vw,44px);
  position:relative;overflow:hidden;
}
/* Cercles décoratifs fond comme A3 */
.contact-form-wrap::before{
  content:'';position:absolute;
  width:300px;height:300px;border-radius:50%;
  border:1px solid rgba(255,255,255,.08);
  top:-80px;right:-60px;
  pointer-events:none;
}
.contact-form-wrap::after{
  content:'';position:absolute;
  width:200px;height:200px;border-radius:50%;
  border:1px solid rgba(255,255,255,.06);
  bottom:-40px;right:30px;
  pointer-events:none;
}
.cf-circle{
  position:absolute;
  width:140px;height:140px;border-radius:50%;
  border:1px solid rgba(255,255,255,.05);
  bottom:60px;left:-40px;pointer-events:none;
}

.cf-h{font-family:var(--disp);font-size:22px;font-weight:700;color:#fff;margin-bottom:24px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cfg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;position:relative;z-index:1}
.cfg label{font-size:11px;font-weight:600;color:rgba(255,255,255,.6);letter-spacing:.06em;text-transform:uppercase}
.cfg input,.cfg select,.cfg textarea{
  font-family:var(--body);font-size:14px;
  padding:13px 16px;
  border:none;border-radius:24px;
  background:rgba(255,255,255,.15);
  color:#fff;outline:none;
  transition:background .2s,box-shadow .2s;
  -webkit-appearance:none;
}
.cfg input::placeholder,.cfg textarea::placeholder{color:rgba(255,255,255,.5)}
.cfg select{color:#fff}
.cfg select option{background:var(--g1);color:#fff}
.cfg input:focus,.cfg select:focus,.cfg textarea:focus{
  background:rgba(255,255,255,.22);
  box-shadow:0 0 0 2px rgba(255,255,255,.25);
}
.cfg textarea{resize:vertical;min-height:110px;border-radius:18px}
.btn-send{
  width:100%;font-family:var(--body);font-size:14px;font-weight:600;
  padding:15px;background:#fff;color:var(--g2);
  border:none;border-radius:28px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;
  letter-spacing:.02em;
  box-shadow:0 4px 18px rgba(0,0,0,.14);
  transition:all .25s;position:relative;z-index:1;
}
.btn-send:hover{background:var(--g8);transform:translateY(-1px);box-shadow:0 8px 26px rgba(0,0,0,.18)}

/* ═══════════════════════════════
   FOOTER — fond vert, border-radius top+bottom 20px,
   centré avec mx auto
═══════════════════════════════ */
.footer-outer{
  padding:0 5vw 28px;/* padding horizontal pour l'espace autour */
  background:var(--cream);
}
footer{
  background:var(--g2);
  color:#fff;
  border-radius:20px;
  padding:clamp(44px,7vw,80px) clamp(24px,4vw,52px) 28px;
  /* Border radius top et bottom */
  overflow:hidden;
}
.ft-grid{
  display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;
  gap:clamp(28px,5vw,52px);
  padding-bottom:44px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.ft-brand{}
.ft-logo{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.ft-logo-img{
  width:44px;height:44px;border-radius:50%;
  background:#fff;overflow:hidden;flex-shrink:0;
}
.ft-logo-img img{width:100%;mix-blend-mode:multiply;filter:contrast(1.05)}
.ft-logo-name{font-family:var(--disp);font-size:20px;font-weight:700;color:#fff;letter-spacing:.04em}
.ft-desc{font-size:13px;line-height:1.85;color:rgba(255,255,255,.55);max-width:265px}
.ft-socials{display:flex;gap:8px;margin-top:18px}
.fsoc{
  width:34px;height:34px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;font-size:12px;font-weight:700;color:rgba(255,255,255,.6);
  transition:all .2s;
}
.fsoc:hover{background:rgba(255,255,255,.2);color:#fff}
.ft-col h5{
  font-size:10px;font-weight:700;color:rgba(255,255,255,.4);
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px;
}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ft-col ul a{font-size:13px;color:rgba(255,255,255,.58);text-decoration:none;transition:color .2s}
.ft-col ul a:hover{color:#fff}
.ft-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:20px;font-size:12px;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:10px;
}
.ft-bottom a{color:rgba(255,255,255,.42);text-decoration:none;transition:color .2s}
.ft-bottom a:hover{color:#fff}

/* Back to top */
#btt{
  position:fixed;bottom:28px;right:28px;
  width:42px;height:42px;background:var(--g2);color:#fff;
  border:none;border-radius:11px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 5px 20px rgba(15,92,40,.28);
  opacity:0;transform:translateY(10px);
  transition:all .3s var(--ease);z-index:500;
}
#btt.show{opacity:1;transform:none}
#btt:hover{background:var(--g0);transform:translateY(-2px)}

/* ═══════════════════════════════
   KEYFRAMES
═══════════════════════════════ */
@keyframes hIn{from{opacity:0;transform:translateX(-28px)}to{opacity:1;transform:none}}
@keyframes hRIn{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes tkScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media(max-width:1100px){
  .svc-grid-a1{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-content{padding:100px 5vw 100px}
  .about-grid,.approach-grid,.zones-grid,.contact-grid,.temo-inner{grid-template-columns:1fr}
  .av-accent,.av-quote{display:none}
  .temo-mini-list{display:none}
  .ev-img-wrap{width:120px;height:100px}
}
@media(max-width:768px){
  .nl,.ncta{display:none}
  .ham{display:flex}
  .svc-grid-a1{grid-template-columns:1fr}
  .mv-pair,.atouts{grid-template-columns:1fr}
  .cf-row{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr}
  .ft-bottom{flex-direction:column;text-align:center}
  .hero-stats{flex-wrap:wrap;gap:24px}
  .ev-card{flex-direction:column;padding:0 0 20px}
  .ev-img-wrap{width:100%;height:160px;border-radius:var(--rl) var(--rl) 0 0;margin-left:0}
  .ev-body{padding:14px 18px}
  .ev-arrow{padding:0 18px;align-self:flex-end}
}
.hero-p {
  white-space: pre-line;
}