/* ═══════════════════════════════════════════════════════════════
   Entre Élèves — v3.1 (ESA-style nonprofit)
   Blue #417ca1 • Dark #003863 • Gold #bbaa5e • Inter + Playfair Display
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --blue:#417ca1;
  --blue-dark:#003863;
  --blue-mid:#215387;
  --blue-light:#5a92b5;
  --gold:#bbaa5e;
  --gold-dark:#9c8c48;

  --bg:#ffffff;
  --bg-soft:#f7f9fc;
  --bg-tint:#edf2f7;
  --bg-deep:#003863;

  --text:#2d3748;
  --text-soft:#4a5568;
  --text-muted:#718096;
  --line:#e2e8f0;
  --line-strong:#cbd5e0;

  --ff:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;
  --ff-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;
  --ff-serif:Georgia,serif;

  --shadow-sm:0 2px 8px rgba(0,0,0,.04);
  --shadow:0 15px 15px -10px rgba(0,0,0,.05);
  --shadow-lg:0 20px 40px -15px rgba(0,0,0,.1);
  --shadow-hover:0 15px 25px -7px rgba(0,0,0,.1);

  --radius:12px;
  --radius-lg:18px;
  --radius-pill:9999px;

  --container:1360px;
  --gutter:1.5rem;
  --section:5rem;

  --trs:.25s cubic-bezier(.4,0,.2,1);
  --trs-slow:.45s cubic-bezier(.22,1,.36,1);
  --trs-smooth:.3s cubic-bezier(.16,1,.3,1);
  --ease-bounce:cubic-bezier(.34,1.2,.64,1);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--blue-dark)}
body{
  font-family:var(--ff);
  font-size:18px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:clip;
}

img{max-width:100%;display:block;height:auto}
a{color:var(--blue);text-decoration:none;transition:color var(--trs)}
a:hover{color:var(--blue-dark)}
button{font-family:inherit;cursor:pointer;border:none;background:none}

::selection{background:var(--blue);color:#fff}

/* ─── Typography ─── */
h1,h2,h3,h4,h5,h6{
  font-family:var(--ff-display);
  font-weight:700;
  line-height:1.15;
  color:var(--blue-dark);
  letter-spacing:-.015em;
}
h1{font-size:clamp(2.1rem,5.2vw,3.6rem);font-weight:800;line-height:1.08;letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,3.6vw,2.5rem);font-weight:700;letter-spacing:-.015em}
h3{font-size:clamp(1.25rem,2.4vw,1.5rem)}
h4{font-size:1.15rem}
p{margin:0 0 1em;color:var(--text-soft)}
p:last-child{margin-bottom:0}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--blue);
  margin-bottom:1rem;
}
.eyebrow::before,.eyebrow::after{content:"";width:8px;height:8px;background:var(--gold);border-radius:50%;display:inline-block;flex-shrink:0}
.section-head .eyebrow{justify-content:center}
.section-head .eyebrow::before,.section-head .eyebrow::after{width:6px;height:6px}

/* ─── Container ─── */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.container-narrow{max-width:880px;margin:0 auto;padding:0 var(--gutter)}
.container-wide{max-width:1400px;margin:0 auto;padding:0 var(--gutter)}

/* ─── Sections ─── */
section{padding:var(--section) 0}
@media (max-width:768px){section{padding:3rem 0}}

.section-head{text-align:center;max-width:720px;margin:0 auto 3.5rem}
.section-head .eyebrow{justify-content:center}
.section-head h2{margin-bottom:1rem}
.section-head p{font-size:1.1rem;color:var(--text-soft)}

.section-soft{background:var(--bg-soft)}
.section-dark{background:var(--blue-dark);color:#fff}
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-dark .eyebrow{color:var(--gold)}
.section-dark p{color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════════════════════════════
   TOP BAR
   ═══════════════════════════════════════════════════════════════ */
.topbar{
  background:var(--blue-dark);
  color:rgba(255,255,255,.9);
  font-size:.82rem;
  padding:.6rem 0;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.topbar-left{display:flex;gap:1.5rem;flex-wrap:wrap}
.topbar-left span{display:inline-flex;align-items:center;gap:.4rem}
.topbar-left svg{opacity:.7}
.topbar-right{display:flex;gap:1rem;align-items:center}
.topbar-right a{color:rgba(255,255,255,.9)}
.topbar-right a:hover{color:var(--gold)}
@media (max-width:768px){.topbar{display:none}}

/* ═══════════════════════════════════════════════════════════════
   HEADER / NAV
   ═══════════════════════════════════════════════════════════════ */
.header{
  background:#fff;
  position:sticky;top:0;z-index:100;
  box-shadow:0 1px 0 var(--line);
  transition:all var(--trs);
}
.header.scrolled{box-shadow:0 4px 20px -8px rgba(0,56,99,.15)}
.nav{
  max-width:100%;
  padding:.6rem 2.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.header.scrolled .nav{padding:.6rem 2.5rem}

.nav-brand{display:flex;align-items:center;gap:.85rem;color:var(--blue-dark);flex-shrink:0}
.nav-brand:hover{color:var(--blue)}
.nav-brand img{height:46px;width:auto;transition:none}
.header.scrolled .nav-brand img{height:46px}
.nav-brand-text{display:flex;flex-direction:column;line-height:1.15}
.nav-brand-name{font-weight:800;font-size:1.2rem;letter-spacing:-.01em;color:var(--blue-dark)}
.nav-brand-tag{font-size:.68rem;font-weight:600;color:var(--text-muted);margin-top:2px;letter-spacing:.02em}

.nav-links{display:flex;gap:.2rem;list-style:none;align-items:center}
.nav-links li{display:flex;align-items:center}
.nav-links a{
  font-size:.78rem;font-weight:600;line-height:1;
  color:var(--text-soft);
  padding:.5rem .6rem;
  border-radius:8px;
  transition:all var(--trs);
  position:relative;
  white-space:nowrap;
}
.nav-links a:hover{color:var(--blue);background:var(--bg-tint)}
.nav-links a:hover{background:var(--bg-tint);color:var(--blue)}
.nav-links a.active{color:var(--blue)}
.nav-links a.active::after{
  content:"";position:absolute;left:.9rem;right:.9rem;bottom:-2px;
  height:2px;background:var(--gold);
}

.nav-cta{display:flex;gap:.5rem;align-items:center;flex-shrink:0}
.nav-cta .btn-sm{padding:.55rem 1.2rem;font-size:.75rem}

.burger{display:none;flex-direction:column;gap:5px;padding:.5rem;cursor:pointer;background:none;border:none}
.burger span{width:24px;height:2px;background:var(--blue-dark);transition:all var(--trs);border-radius:2px}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-mobile{display:none}
@media (max-width:1340px){
  .nav-links,.nav-cta .btn-outline{display:none}
  .burger{display:flex}
  .nav-mobile.open{
    display:block;position:fixed;top:74px;left:0;right:0;bottom:0;
    background:#fff;padding:2rem var(--gutter);
    overflow-y:auto;z-index:99;
  }
  .nav-mobile ul{list-style:none;display:flex;flex-direction:column;gap:.25rem}
  .nav-mobile a{
    display:block;padding:1rem 0;
    font-size:1.15rem;font-weight:600;
    color:var(--blue-dark);
    border-bottom:1px solid var(--line);
  }
  .nav-mobile .btn{margin-top:1.5rem;width:100%;justify-content:center}
}

/* ═══════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.95rem 2rem;
  font-family:inherit;font-size:.92rem;font-weight:700;
  border-radius:var(--radius-pill);
  text-transform:uppercase;letter-spacing:.06em;
  transition:background-color .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease,filter .18s ease;
  cursor:pointer;border:none;
  white-space:nowrap;text-align:center;line-height:1;
}
.btn:active{filter:brightness(.94)}
.btn svg{width:16px;height:16px;flex-shrink:0}

.btn-primary{
  background:var(--blue);color:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.06);
}
.btn-primary:hover{
  background:var(--blue-mid);color:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.08),0 4px 12px -2px rgba(0,56,99,.18);
}

.btn-gold{
  background:var(--gold);color:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.06);
}
.btn-gold:hover{
  background:var(--gold-dark);color:#fff;
  box-shadow:0 1px 2px rgba(0,0,0,.08),0 4px 12px -2px rgba(156,140,72,.22);
}

.btn-outline{
  background:transparent;color:var(--blue-dark);
  border:2px solid var(--blue-dark);
  padding:calc(.95rem - 2px) calc(2rem - 2px);
}
.btn-outline:hover{
  background:var(--blue-dark);color:#fff;
  border-color:var(--blue-dark);
  box-shadow:0 4px 12px -2px rgba(0,56,99,.18);
}

.btn-outline-white{
  background:transparent;color:#fff;
  border:2px solid #fff;
  padding:calc(.95rem - 2px) calc(2rem - 2px);
}
.btn-outline-white:hover{
  background:#fff;color:var(--blue-dark);
  box-shadow:0 4px 12px -2px rgba(0,0,0,.18);
}

.btn-sm{padding:.65rem 1.4rem;font-size:.8rem}
.btn-outline.btn-sm{padding:calc(.65rem - 2px) calc(1.4rem - 2px)}
.btn-lg{padding:1.2rem 2.6rem;font-size:1rem}

/* ═══════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;align-items:center;
  color:#fff;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(0,56,99,.92) 0%,rgba(0,56,99,.78) 45%,rgba(65,124,161,.55) 100%);
}
.hero-inner{
  position:relative;z-index:1;
  max-width:var(--container);margin:0 auto;
  padding:5rem var(--gutter);
  width:100%;
}
.hero-content{max-width:720px}
.hero .eyebrow{color:var(--gold)}
.hero .eyebrow::before{background:var(--gold)}
.hero h1{color:#fff;margin-bottom:1.5rem}
.hero-tag{
  font-size:1.35rem;font-weight:500;
  color:rgba(255,255,255,.92);
  line-height:1.45;margin-bottom:2.5rem;
  max-width:620px;
}
.hero-tag strong{font-weight:700;color:#fff}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-stats{
  display:flex;gap:2.5rem;flex-wrap:wrap;
  padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.15);
}
.hero-stat-num{font-size:2.2rem;font-weight:800;color:var(--gold);letter-spacing:-.02em;line-height:1}
.hero-stat-lbl{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.75);margin-top:.3rem}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);
  font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  animation:bounce 2s ease-in-out infinite;
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* Subpage hero */
.subhero{
  position:relative;
  padding:5rem 0 4rem;
  background:var(--blue-dark);color:#fff;
  overflow:hidden;
}
.subhero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:.35;
}
.subhero-inner{position:relative;z-index:1;max-width:var(--container);margin:0 auto;padding:0 var(--gutter);text-align:center}
.subhero h1{color:#fff;margin-bottom:1rem}
.subhero p{color:rgba(255,255,255,.85);font-size:1.15rem;max-width:640px;margin:0 auto}
.breadcrumb{
  display:flex;justify-content:center;gap:.5rem;
  font-size:.82rem;color:rgba(255,255,255,.65);
  margin-bottom:1.5rem;
}
.breadcrumb a{color:rgba(255,255,255,.7)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:rgba(255,255,255,.4)}

/* ═══════════════════════════════════════════════════════════════
   STATS GRID
   ═══════════════════════════════════════════════════════════════ */
.stats{
  background:var(--bg-soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.stats-grid{
  max-width:var(--container);margin:0 auto;
  padding:0 var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
}
.stat{text-align:center;padding:2rem 1rem;position:relative}
.stat:not(:last-child)::after{
  content:"";position:absolute;right:0;top:20%;bottom:20%;
  width:1px;background:var(--line);
}
.stat-num{
  font-size:clamp(2.4rem,4vw,3.4rem);
  font-weight:800;color:var(--blue);
  line-height:1;letter-spacing:-.03em;
  margin-bottom:.5rem;
}
.stat-label{
  font-size:.88rem;font-weight:600;
  color:var(--text-soft);
  text-transform:uppercase;letter-spacing:.05em;
}
.stat-desc{font-size:.82rem;color:var(--text-muted);margin-top:.3rem}
@media (max-width:768px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .stat:not(:last-child)::after{display:none}
}

/* ═══════════════════════════════════════════════════════════════
   MISSION / INTRO SPLIT
   ═══════════════════════════════════════════════════════════════ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split.reverse{direction:rtl}
.split.reverse>*{direction:ltr}
.split-img{
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;
  background:var(--bg-tint);
}
.split-img img{width:100%;height:100%;object-fit:cover}
.split h2{margin-bottom:1.2rem}
.split p{font-size:1.05rem;margin-bottom:1.2rem}
.split-signature{
  display:flex;align-items:center;gap:1rem;
  margin-top:2rem;padding-top:1.5rem;
  border-top:1px solid var(--line);
}
.split-signature-name{font-weight:700;color:var(--blue-dark);font-size:.95rem}
.split-signature-role{font-size:.82rem;color:var(--text-muted)}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:2.5rem}.split.reverse{direction:ltr}}

/* ═══════════════════════════════════════════════════════════════
   PILLARS (Approche)
   ═══════════════════════════════════════════════════════════════ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.pillars.pillars-4{grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media (max-width:1024px){.pillars.pillars-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.pillars.pillars-4{grid-template-columns:1fr}}
.pillar{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:2.5rem 2rem;
  box-shadow:var(--shadow-sm);
  transition:all var(--trs);
}
.pillar:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-hover);
  border-color:var(--blue);
}
.pillar-icon{
  width:64px;height:64px;
  background:var(--bg-tint);color:var(--blue);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.5rem;
  transition:all var(--trs);
}
.pillar:hover .pillar-icon{background:var(--blue);color:#fff}
.pillar-icon svg{width:30px;height:30px}
.pillar h3{color:var(--blue-dark);margin-bottom:.75rem}
.pillar p{font-size:.95rem;margin-bottom:1rem}
.pillar-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.85rem;font-weight:700;
  color:var(--blue);text-transform:uppercase;letter-spacing:.06em;
}
.pillar-link:hover{color:var(--blue-dark)}
.pillar-link svg{width:14px;height:14px;transition:transform var(--trs)}
.pillar-link:hover svg{transform:translateX(3px)}
@media (max-width:900px){.pillars{grid-template-columns:1fr;gap:1.2rem}}

/* ═══════════════════════════════════════════════════════════════
   FEATURE CARDS
   ═══════════════════════════════════════════════════════════════ */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.feature{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:all var(--trs);
}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.feature-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-tint)}
.feature-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--trs-slow)}
.feature:hover .feature-img img{transform:scale(1.05)}
.feature-body{padding:2rem}
.feature-tag{
  display:inline-block;
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--gold);margin-bottom:.75rem;
}
.feature h3{margin-bottom:.75rem}
.feature p{font-size:.95rem}
@media (max-width:768px){.features{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════════════ */
.testimonials-slider{
  display:flex;gap:1.5rem;
  overflow-x:auto;scroll-snap-type:x mandatory;
  padding:1rem .5rem 2rem;
  scrollbar-width:none;
}
.testimonials-slider::-webkit-scrollbar{display:none}
.testi{
  flex:0 0 min(380px,85vw);
  scroll-snap-align:center;
  background:#fff;
  border-radius:var(--radius-lg);
  padding:2.5rem 2rem;
  box-shadow:var(--shadow);
  position:relative;
  display:flex;flex-direction:column;
}
.testi-quote-mark{
  position:absolute;top:1rem;right:1.5rem;
  font-family:Georgia,serif;font-size:4.5rem;line-height:1;
  color:var(--bg-tint);font-weight:700;
}
.testi-text{
  font-size:1.02rem;line-height:1.65;color:var(--text);
  margin-bottom:1.5rem;flex-grow:1;font-style:italic;
}
.testi-author{display:flex;align-items:center;gap:.85rem;margin-top:auto;padding-top:1.2rem;border-top:1px solid var(--line)}
.testi-avatar{
  width:48px;height:48px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.05rem;flex-shrink:0;
}
.testi-name{font-weight:700;color:var(--blue-dark);font-size:.92rem}
.testi-role{font-size:.78rem;color:var(--text-muted);margin-top:2px}

.slider-dots{
  display:flex;justify-content:center;gap:.5rem;margin-top:1rem;
}
.slider-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--line-strong);
  transition:all var(--trs);
  cursor:pointer;border:none;padding:0;
}
.slider-dot.active{background:var(--blue);transform:scale(1.3)}

/* ═══════════════════════════════════════════════════════════════
   IMPACT BAND
   ═══════════════════════════════════════════════════════════════ */
.impact-band{
  background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue-mid) 100%);
  color:#fff;
  position:relative;overflow:hidden;
}
.impact-band::before{
  content:"";position:absolute;top:-50%;right:-10%;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(187,170,94,.15) 0%,transparent 70%);
  pointer-events:none;
}
.impact-band::after{
  content:"";position:absolute;bottom:-40%;left:-5%;
  width:440px;height:440px;border-radius:50%;
  background:radial-gradient(circle,rgba(65,124,161,.25) 0%,transparent 70%);
  pointer-events:none;
}
.impact-band .container{position:relative;z-index:1}
.impact-band h2,.impact-band .eyebrow{color:#fff}
.impact-band .eyebrow{color:var(--gold)}
.impact-band p{color:rgba(255,255,255,.82)}
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-top:3rem}
.impact-item{text-align:center;padding:1rem}
.impact-num{font-size:clamp(2.4rem,4vw,3.4rem);font-weight:800;color:var(--gold);line-height:1;letter-spacing:-.02em;margin-bottom:.5rem}
.impact-lbl{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.7)}
@media (max-width:900px){.impact-grid{grid-template-columns:1fr;gap:1.5rem}}

/* ═══════════════════════════════════════════════════════════════
   CALL-TO-ACTION BAND
   ═══════════════════════════════════════════════════════════════ */
.cta-band{
  padding:var(--section) 0;
  background:var(--bg-soft);
  text-align:center;
}
.cta-band h2{margin-bottom:1rem}
.cta-band p{font-size:1.15rem;max-width:620px;margin:0 auto 2rem}
.cta-band-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.cta-image-band{
  padding:var(--section) 0;
  position:relative;
  color:#fff;
  overflow:hidden;
}
.cta-image-band-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
}
.cta-image-band-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(0,56,99,.9),rgba(65,124,161,.7));
}
.cta-image-band .container{position:relative;z-index:1;text-align:center}
.cta-image-band h2{color:#fff}
.cta-image-band p{color:rgba(255,255,255,.88);max-width:640px;margin:0 auto 2rem;font-size:1.15rem}

/* ═══════════════════════════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════════════════════════ */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.team-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:all var(--trs);
}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.team-photo{aspect-ratio:3/4;overflow:hidden;background:var(--bg-tint)}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform var(--trs-slow)}
.team-card:hover .team-photo img{transform:scale(1.04)}
.team-info{padding:1.5rem 1.8rem 2rem;text-align:center}
.team-name{font-weight:800;color:var(--blue-dark);font-size:1.15rem;margin-bottom:.3rem}
.team-role{color:var(--blue);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}
.team-bio{font-size:.88rem;color:var(--text-soft);line-height:1.55}
@media (max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.team-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   PARTNERS
   ═══════════════════════════════════════════════════════════════ */
.partners{padding:3rem 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.partners-title{text-align:center;font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:2rem}
.partners-logos{
  display:flex;gap:4rem;
  align-items:center;justify-content:center;
  flex-wrap:wrap;
  opacity:.7;
}
.partners-logos span{
  font-family:Georgia,serif;font-style:italic;font-weight:600;
  color:var(--blue-dark);font-size:1.3rem;
  transition:opacity var(--trs);
}
.partners-logos span:hover{opacity:1}

/* ═══════════════════════════════════════════════════════════════
   NEWS / ACTUALITÉS
   ═══════════════════════════════════════════════════════════════ */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.news-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  display:flex;flex-direction:column;
  transition:all var(--trs);
}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.news-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg-tint)}
.news-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--trs-slow)}
.news-card:hover .news-img img{transform:scale(1.05)}
.news-body{padding:1.75rem;display:flex;flex-direction:column;flex-grow:1}
.news-date{font-size:.75rem;color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}
.news-title{color:var(--blue-dark);font-size:1.15rem;font-weight:700;margin-bottom:.6rem;line-height:1.35}
.news-excerpt{font-size:.9rem;color:var(--text-soft);margin-bottom:1rem;flex-grow:1}
.news-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.8rem;font-weight:700;color:var(--blue);
  text-transform:uppercase;letter-spacing:.06em;
}
.news-link svg{width:14px;height:14px;transition:transform var(--trs)}
.news-card:hover .news-link svg{transform:translateX(3px)}
@media (max-width:900px){.news-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   FORMS
   ═══════════════════════════════════════════════════════════════ */
.form{max-width:680px;margin:0 auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media (max-width:600px){.form-row{grid-template-columns:1fr}}
.fg{margin-bottom:1.25rem}
.fg label{
  display:block;font-size:.85rem;font-weight:700;
  color:var(--blue-dark);
  margin-bottom:.5rem;
}
.fg label .req{color:#e53e3e;margin-left:2px}
.fg input,.fg textarea,.fg select{
  width:100%;padding:.95rem 1.1rem;
  font-family:inherit;font-size:1rem;color:var(--text);
  background:#fff;
  border:1.5px solid var(--line-strong);
  border-radius:var(--radius);
  outline:none;
  transition:all var(--trs);
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(65,124,161,.12);
}
.fg textarea{resize:vertical;min-height:140px;line-height:1.55}
.fg .help{display:block;margin-top:.4rem;font-size:.8rem;color:var(--text-muted)}
.chk{display:flex;gap:.7rem;align-items:flex-start;margin:1.25rem 0;cursor:pointer}
.chk input{width:18px;height:18px;accent-color:var(--blue);margin-top:3px;flex-shrink:0}
.chk span{font-size:.88rem;color:var(--text-soft);line-height:1.5}

.form-card{
  background:#fff;
  padding:2.5rem;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  border:1px solid var(--line);
}
.form-card h3{color:var(--blue-dark);margin-bottom:1.5rem;font-size:1.35rem}
.form-actions{margin-top:1.5rem}
.form-actions .btn{width:100%;justify-content:center;padding:1.1rem}

.amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-bottom:1rem}
@media (max-width:600px){.amounts{grid-template-columns:repeat(2,1fr)}}
.amount{
  padding:1.1rem .5rem;
  text-align:center;
  background:#fff;border:2px solid var(--line);
  border-radius:var(--radius);
  font-weight:700;font-size:1.2rem;color:var(--blue-dark);
  cursor:pointer;transition:all var(--trs);
}
.amount:hover{border-color:var(--blue-light);transform:translateY(-2px)}
.amount.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.amount-after{font-size:.72rem;font-weight:500;color:var(--text-muted);display:block;margin-top:3px;text-transform:none;letter-spacing:0}
.amount.active .amount-after{color:rgba(255,255,255,.85)}
.amount-impact{font-size:.68rem;color:var(--blue);font-weight:600;display:block;margin-top:4px}
.amount.active .amount-impact{color:rgba(255,255,255,.9)}

/* Donation amount cards (new) */
.don-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}
@media (max-width:768px){.don-cards{grid-template-columns:repeat(2,1fr)}}
.don-card{
  background:#fff;border:2px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem 1.2rem;text-align:center;cursor:pointer;
  transition:all var(--trs);position:relative;
}
.don-card:hover{border-color:var(--blue-light);transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.don-card.active{border-color:var(--blue);background:linear-gradient(135deg,rgba(65,124,161,.06),rgba(0,56,99,.04));box-shadow:0 12px 32px rgba(65,124,161,.2)}
.don-amount{font-size:2.8rem;font-weight:800;color:var(--blue-dark);line-height:1;margin-bottom:.5rem}
.don-card.active .don-amount{color:var(--blue)}
.don-real{font-size:.78rem;color:var(--text-muted);font-weight:600;margin-bottom:.5rem}
.don-real strong{color:var(--blue);font-weight:700}
.don-desc{font-size:.75rem;color:var(--text-soft);font-weight:500;line-height:1.4}
.don-card.active .don-desc{color:var(--blue-mid)}

/* Tax banner */
.tax-banner{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#fff;border-radius:var(--radius-lg);
  padding:1.5rem 2rem;text-align:center;margin-bottom:2.5rem;
  box-shadow:0 8px 24px rgba(187,170,94,.3);
}
.tax-banner h3{font-size:1.4rem;font-weight:800;margin-bottom:.3rem;color:#fff}
.tax-banner p{font-size:.88rem;color:rgba(255,255,255,.9);margin:0}

/* Video placeholder */
.video-placeholder{
  position:relative;
  aspect-ratio:16/9;
  max-width:900px;margin:0 auto;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--blue-dark);
  box-shadow:var(--shadow-lg);
  cursor:pointer;
  transition:all var(--trs);
}
.video-placeholder:hover{transform:scale(1.01);box-shadow:0 32px 80px rgba(0,56,99,.35)}
.video-placeholder-img{width:100%;height:100%;object-fit:cover;opacity:.5;transition:opacity var(--trs)}
.video-placeholder:hover .video-placeholder-img{opacity:.6}
.video-placeholder-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;
}
.video-play{
  width:80px;height:80px;
  background:rgba(255,255,255,.95);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 32px rgba(0,0,0,.3);
  transition:all var(--trs);
}
.video-placeholder:hover .video-play{transform:scale(1.1);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.video-play svg{width:32px;height:32px;margin-left:4px}
.video-label{color:#fff;font-size:.88rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.video-coming{color:rgba(255,255,255,.7);font-size:.78rem}

/* Steps section (3 simple steps) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
@media (max-width:768px){.steps{grid-template-columns:1fr;gap:1.5rem}}
.step{text-align:center;position:relative}
.step-num{
  width:56px;height:56px;margin:0 auto 1rem;
  background:var(--blue);color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;font-weight:800;
  box-shadow:0 8px 24px rgba(65,124,161,.3);
}
.step h3{font-size:1.1rem;margin-bottom:.4rem}
.step p{font-size:.88rem;color:var(--text-soft)}
.step:not(:last-child)::after{
  content:"→";position:absolute;
  right:-1.2rem;top:28px;
  font-size:1.5rem;color:var(--line-strong);font-weight:700;
}
@media (max-width:768px){.step:not(:last-child)::after{display:none}}

/* Recruit counter badge */
.recruit-badge{
  display:inline-flex;align-items:center;gap:.6rem;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-pill);
  padding:.5rem 1.2rem;
  margin-bottom:1.5rem;
}
.recruit-badge-bar{
  width:80px;height:6px;
  background:rgba(255,255,255,.2);
  border-radius:var(--radius-pill);overflow:hidden;
}
.recruit-badge-fill{height:100%;background:var(--gold);border-radius:var(--radius-pill);width:10%}
.recruit-badge-text{font-size:.75rem;font-weight:600;color:rgba(255,255,255,.9)}

.info-box{
  background:var(--bg-soft);
  border-left:3px solid var(--blue);
  padding:1.2rem 1.5rem;
  border-radius:0 var(--radius) var(--radius) 0;
  margin-bottom:2rem;
}
.info-box h4{color:var(--blue-dark);margin-bottom:.4rem;font-size:.95rem}
.info-box p{font-size:.88rem;margin-bottom:0;color:var(--text-soft)}

.success-box,.error-box{
  padding:1rem 1.3rem;border-radius:var(--radius);
  margin-bottom:1.5rem;font-size:.9rem;font-weight:500;
  display:none;
}
.success-box{background:#f0fdf4;border:1px solid #86efac;color:#14532d}
.error-box{background:#fef2f2;border:1px solid #fca5a5;color:#7f1d1d}
.success-box.show,.error-box.show{display:block}

/* ═══════════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════════ */
.faq{max-width:820px;margin:0 auto}
.faq-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  margin-bottom:.85rem;
  overflow:hidden;
  transition:all var(--trs);
}
.faq-item.open{border-color:var(--blue);box-shadow:var(--shadow)}
.faq-q{
  width:100%;
  padding:1.3rem 1.75rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  background:#fff;
  font-family:inherit;font-size:1.02rem;font-weight:700;
  color:var(--blue-dark);
  text-align:left;cursor:pointer;border:none;
}
.faq-q:hover{color:var(--blue)}
.faq-toggle{
  flex-shrink:0;
  width:28px;height:28px;
  background:var(--bg-tint);color:var(--blue);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:700;
  transition:all var(--trs);
}
.faq-item.open .faq-toggle{background:var(--blue);color:#fff;transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  padding:0 1.75rem;
  transition:all var(--trs);
}
.faq-item.open .faq-a{max-height:500px;padding:0 1.75rem 1.5rem}
.faq-a p{font-size:.95rem;margin:0;line-height:1.65}

/* ═══════════════════════════════════════════════════════════════
   TIMELINE
   ═══════════════════════════════════════════════════════════════ */
.timeline{max-width:800px;margin:0 auto;position:relative;padding-left:3rem}
.timeline::before{
  content:"";position:absolute;
  left:14px;top:10px;bottom:10px;
  width:2px;background:var(--line-strong);
}
.timeline-item{position:relative;padding-bottom:2.5rem}
.timeline-item:last-child{padding-bottom:0}
.timeline-item::before{
  content:"";position:absolute;
  left:-3rem;top:6px;
  width:30px;height:30px;
  background:var(--blue);
  border:4px solid #fff;
  border-radius:50%;
  box-shadow:0 0 0 2px var(--blue);
}
.timeline-year{font-size:.78rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem}
.timeline-item h3{font-size:1.15rem;margin-bottom:.5rem}
.timeline-item p{font-size:.95rem;margin:0}

/* ═══════════════════════════════════════════════════════════════
   MANIFESTO
   ═══════════════════════════════════════════════════════════════ */
.manifesto-list{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem}
.manifesto-item{padding:1.5rem 0;border-top:2px solid var(--blue)}
.manifesto-num{font-size:.78rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.14em;margin-bottom:.5rem}
.manifesto-item h3{font-size:1.3rem;margin-bottom:.5rem}
.manifesto-item p{font-size:.95rem}
@media (max-width:800px){.manifesto-list{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   CONTACT INFO CARDS
   ═══════════════════════════════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:2fr 1fr;gap:3rem}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info{display:flex;flex-direction:column;gap:1.2rem}
.contact-card{
  background:#fff;
  border:1px solid var(--line);
  border-left:3px solid var(--blue);
  border-radius:var(--radius);
  padding:1.5rem;
  display:flex;gap:1rem;align-items:flex-start;
  transition:all var(--trs);
}
.contact-card:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.contact-card-icon{
  width:44px;height:46px;flex-shrink:0;
  background:var(--bg-tint);color:var(--blue);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.contact-card h4{color:var(--blue-dark);font-size:.95rem;margin-bottom:.25rem}
.contact-card p{font-size:.9rem;margin:0}

/* ═══════════════════════════════════════════════════════════════
   PRESS KIT
   ═══════════════════════════════════════════════════════════════ */
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.press-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.5rem;
  text-align:center;
  transition:all var(--trs);
}
.press-item:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue)}
.press-icon{
  width:56px;height:56px;margin:0 auto 1rem;
  background:var(--bg-tint);color:var(--blue);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
}
.press-item h4{font-size:1rem;color:var(--blue-dark);margin-bottom:.4rem}
.press-item p{font-size:.82rem;margin-bottom:1rem}
@media (max-width:900px){.press-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.press-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   STORY BLOCKS (Impact)
   ═══════════════════════════════════════════════════════════════ */
.story{
  display:grid;grid-template-columns:1fr 1.3fr;gap:3rem;
  align-items:center;
  margin-bottom:5rem;
}
.story.reverse{direction:rtl}
.story.reverse>*{direction:ltr}
.story:last-child{margin-bottom:0}
.story-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.story-img img{width:100%;height:100%;object-fit:cover}
.story-quote{
  font-size:1.35rem;line-height:1.45;
  color:var(--blue-dark);font-style:italic;
  margin-bottom:1.5rem;padding-left:1.5rem;
  border-left:3px solid var(--gold);
}
.story-meta{
  display:flex;align-items:center;gap:1rem;
  padding-top:1.5rem;border-top:1px solid var(--line);
  margin-top:1.5rem;
}
.story-meta-name{font-weight:700;color:var(--blue-dark)}
.story-meta-detail{font-size:.85rem;color:var(--text-muted)}
@media (max-width:900px){.story{grid-template-columns:1fr;gap:2rem}.story.reverse{direction:ltr}}

/* Transparency bars */
.transparency{max-width:760px;margin:3rem auto 0}
.t-row{margin-bottom:1.5rem}
.t-row-head{display:flex;justify-content:space-between;margin-bottom:.5rem}
.t-label{font-weight:700;color:var(--blue-dark);font-size:.92rem}
.t-value{font-weight:700;color:var(--blue);font-size:.92rem}
.t-bar{height:12px;background:var(--bg-tint);border-radius:var(--radius-pill);overflow:hidden}
.t-fill{
  height:100%;background:linear-gradient(90deg,var(--blue),var(--blue-light));
  border-radius:var(--radius-pill);
  transition:width 1s cubic-bezier(.4,0,.2,1);
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.footer{background:var(--blue-dark);color:rgba(255,255,255,.75);padding:4rem 0 0}
.footer-grid{
  max-width:var(--container);margin:0 auto;padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap:3rem;
  padding-bottom:3rem;
}
.footer-brand img{height:56px;width:auto;margin-bottom:1rem;filter:brightness(0) invert(1)}
.footer-brand p{color:rgba(255,255,255,.65);font-size:.9rem;line-height:1.6;margin-bottom:1.25rem}
.footer-social{display:flex;gap:.6rem}
.footer-social a{
  width:38px;height:38px;
  background:rgba(255,255,255,.08);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  transition:all var(--trs);
}
.footer-social a:hover{background:var(--gold);transform:translateY(-2px);color:#fff}
.footer h4{color:#fff;font-size:.95rem;font-weight:700;margin-bottom:1.2rem;text-transform:uppercase;letter-spacing:.06em}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-links a{color:rgba(255,255,255,.7);font-size:.92rem;transition:all var(--trs)}
.footer-links a:hover{color:var(--gold);padding-left:4px}
.footer-contact{font-size:.88rem;line-height:1.65;color:rgba(255,255,255,.7)}
.footer-contact strong{color:#fff}
.footer-bottom{
  max-width:var(--container);margin:0 auto;padding:1.5rem var(--gutter);
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;
  font-size:.8rem;color:rgba(255,255,255,.55);
  flex-wrap:wrap;gap:1rem;
}
.footer-bottom a{color:rgba(255,255,255,.7)}
.footer-bottom a:hover{color:var(--gold)}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:600px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}}

/* ═══════════════════════════════════════════════════════════════
   REVEAL
   ═══════════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-scroll,.slider-dot{animation:none}
}

/* ═══════════════════════════════════════════════════════════
   ENHANCED HOVER EFFECTS
   ═══════════════════════════════════════════════════════════ */
/* Buttons — shine pseudo removed (caused reversing flash on un-hover) */

/* Nav links — animated underline */
.nav-links a::after{
  content:"";position:absolute;left:.9rem;right:.9rem;bottom:-2px;
  height:2px;background:var(--gold);
  transform:scaleX(0);transform-origin:right;
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}

/* Card glow on hover */
.pillar:hover,.feature:hover,.team-card:hover,.news-card:hover,.press-item:hover,.contact-card:hover{
  box-shadow:0 20px 50px -16px rgba(65,124,161,.3),0 0 0 1px var(--blue);
}

/* Image zoom on hover */
.feature-img img,.team-photo img,.news-img img,.split-img img,.story-img img{
  transition:transform .65s cubic-bezier(.4,0,.2,1);
}
.feature:hover .feature-img img,.team-card:hover .team-photo img,.news-card:hover .news-img img{
  transform:scale(1.08);
}

/* FAQ toggle spin */
.faq-toggle{transition:all .35s cubic-bezier(.34,1.56,.64,1)}

/* Footer links arrow on hover */
.footer-links a{position:relative;padding-left:0;transition:all .3s}
.footer-links a:hover{padding-left:8px}
.footer-links a::before{content:"→ ";opacity:0;transition:opacity .3s}
.footer-links a:hover::before{opacity:1}

/* ═══════════════════════════════════════════════════════════
   STAGGERED REVEAL ANIMATIONS
   ═══════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Stagger children in grids */
.pillars .pillar.reveal:nth-child(2){transition-delay:.1s}
.pillars .pillar.reveal:nth-child(3){transition-delay:.2s}
.pillars .pillar.reveal:nth-child(4){transition-delay:.3s}
.features .feature.reveal:nth-child(2){transition-delay:.1s}
.features .feature.reveal:nth-child(3){transition-delay:.2s}
.features .feature.reveal:nth-child(4){transition-delay:.3s}
.team-grid .team-card.reveal:nth-child(2){transition-delay:.12s}
.team-grid .team-card.reveal:nth-child(3){transition-delay:.24s}
.news-grid .news-card.reveal:nth-child(2){transition-delay:.1s}
.news-grid .news-card.reveal:nth-child(3){transition-delay:.2s}
.stats-grid .stat.reveal:nth-child(2){transition-delay:.08s}
.stats-grid .stat.reveal:nth-child(3){transition-delay:.16s}
.stats-grid .stat.reveal:nth-child(4){transition-delay:.24s}
.impact-grid .impact-item.reveal:nth-child(2){transition-delay:.12s}
.impact-grid .impact-item.reveal:nth-child(3){transition-delay:.24s}
.manifesto-list .manifesto-item.reveal:nth-child(2){transition-delay:.08s}
.manifesto-list .manifesto-item.reveal:nth-child(3){transition-delay:.16s}
.manifesto-list .manifesto-item.reveal:nth-child(4){transition-delay:.24s}
.manifesto-list .manifesto-item.reveal:nth-child(5){transition-delay:.32s}
.manifesto-list .manifesto-item.reveal:nth-child(6){transition-delay:.4s}

/* Hero text entrance */
.hero-content .eyebrow{opacity:0;animation:heroFade .8s .2s ease forwards}
.hero-content h1{opacity:0;animation:heroFade .8s .4s ease forwards}
.hero-tag{opacity:0;animation:heroFade .8s .6s ease forwards}
.hero-actions{opacity:0;animation:heroFade .8s .8s ease forwards}
.hero-stats{opacity:0;animation:heroFade .8s 1s ease forwards}
@keyframes heroFade{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Stat number count-up effect */
.stat-num,.impact-num,.hero-stat-num{transition:all .6s cubic-bezier(.4,0,.2,1)}

/* Team card initials — pulse glow */
.team-avatar{transition:all var(--trs)}
.team-card:hover .team-avatar{transform:scale(1.08);box-shadow:0 0 24px rgba(65,124,161,.4)}

/* ═══════════════════════════════════════════════════════════
   TEAM CARDS WITHOUT PHOTOS (initials-based)
   ═══════════════════════════════════════════════════════════ */
.team-avatar{
  width:120px;height:120px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;font-weight:800;color:#fff;
  margin:2rem auto 1.2rem;
  box-shadow:0 12px 32px rgba(0,56,99,.2);
}
.team-avatar.av-blue{background:linear-gradient(135deg,var(--blue),var(--blue-mid))}
.team-avatar.av-gold{background:linear-gradient(135deg,var(--gold),var(--gold-dark))}
.team-avatar.av-dark{background:linear-gradient(135deg,var(--blue-dark),var(--blue-mid))}
.team-avatar.av-teal{background:linear-gradient(135deg,#0d9488,#14b8a6)}

/* Founder badge (applied equally to all co-founders) */
.team-card.cofondateur{
  border:2px solid var(--blue);
  position:relative;
}
.team-card.cofondateur .team-avatar{box-shadow:0 12px 32px rgba(0,56,99,.3)}

/* ─── Utilities ─── */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.mb-2{margin-bottom:2rem}
.mb-3{margin-bottom:3rem}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* ═══════════════════════════════════════════════════════════
   SCROLL PROGRESS BAR (top of viewport)
   ═══════════════════════════════════════════════════════════ */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;
  background:transparent;pointer-events:none;
}
.scroll-progress-fill{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--gold),var(--blue),var(--gold));
  background-size:200% 100%;
  animation:progressGradient 3s linear infinite;
  transition:width .15s linear;
  box-shadow:0 0 10px var(--gold),0 0 5px var(--blue);
}
@keyframes progressGradient{0%{background-position:0% 0}100%{background-position:200% 0}}

/* ═══════════════════════════════════════════════════════════
   HERO GRADIENT ANIMATION + FLOATING ORBS
   ═══════════════════════════════════════════════════════════ */
.hero-bg::after{
  background:linear-gradient(120deg,
    rgba(0,56,99,.94) 0%,
    rgba(0,56,99,.82) 30%,
    rgba(33,83,135,.7) 60%,
    rgba(65,124,161,.55) 100%
  );
  background-size:300% 300%;
  animation:gradientShift 12s ease-in-out infinite;
}
@keyframes gradientShift{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

.hero-orb{
  position:absolute;border-radius:50%;
  pointer-events:none;
  filter:blur(80px);opacity:.35;
  z-index:0;
}
.hero-orb.orb-1{
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(187,170,94,.6),transparent 70%);
  top:-10%;right:-5%;
  animation:orbFloat1 18s ease-in-out infinite;
}
.hero-orb.orb-2{
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(65,124,161,.5),transparent 70%);
  bottom:-15%;left:10%;
  animation:orbFloat2 22s ease-in-out infinite;
}
.hero-orb.orb-3{
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(187,170,94,.4),transparent 70%);
  top:40%;left:60%;
  animation:orbFloat3 15s ease-in-out infinite;
}
@keyframes orbFloat1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-40px,30px) scale(1.15)}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-40px) scale(.9)}}
@keyframes orbFloat3{0%,100%{transform:translate(0,0)}50%{transform:translate(-25px,20px)}}

/* ═══════════════════════════════════════════════════════════
   ESA-STYLE FLIP CARD ANIMATION (scroll-triggered)
   ═══════════════════════════════════════════════════════════ */
.flip-card{
  opacity:0;
  transform:rotateY(-8deg) translateY(20px);
  transform-style:preserve-3d;
  transition:opacity .6s ease-out,transform .6s ease-out;
}
.flip-card.active{
  opacity:1;
  transform:rotateY(0) translateY(0);
}
/* Stagger flip cards */
.flip-card:nth-child(2){transition-delay:.12s}
.flip-card:nth-child(3){transition-delay:.24s}
.flip-card:nth-child(4){transition-delay:.36s}

/* ═══════════════════════════════════════════════════════════
   REVEAL DIRECTION VARIANTS
   ═══════════════════════════════════════════════════════════ */
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .7s ease,transform .7s cubic-bezier(.4,0,.2,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity .7s ease,transform .7s cubic-bezier(.4,0,.2,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.85);transition:opacity .7s ease,transform .7s cubic-bezier(.34,1.56,.64,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.reveal-up{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s cubic-bezier(.4,0,.2,1)}
.reveal-up.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════════════════
   IMAGE CLIP-PATH REVEAL
   ═══════════════════════════════════════════════════════════ */
.img-reveal{clip-path:inset(0 100% 0 0);transition:clip-path 1s cubic-bezier(.4,0,.2,1)}
.img-reveal.visible{clip-path:inset(0 0 0 0)}
.img-reveal-right{clip-path:inset(0 0 0 100%);transition:clip-path 1s cubic-bezier(.4,0,.2,1)}
.img-reveal-right.visible{clip-path:inset(0 0 0 0)}

/* ═══════════════════════════════════════════════════════════
   3D TILT ON CARDS (JS adds inline transform)
   ═══════════════════════════════════════════════════════════ */
.tilt-card{
  transition:transform .3s ease,box-shadow .3s ease;
  transform-style:preserve-3d;
  will-change:transform;
}
.tilt-card:hover{
  box-shadow:0 25px 60px -16px rgba(0,56,99,.35),0 0 0 1px rgba(65,124,161,.3);
}

/* ═══════════════════════════════════════════════════════════
   COUNTER ANIMATION (tabular nums + transition)
   ═══════════════════════════════════════════════════════════ */
.count-up{
  font-variant-numeric:tabular-nums;
  display:inline-block;
}

/* ═══════════════════════════════════════════════════════════
   SVG WAVE SECTION DIVIDERS
   ═══════════════════════════════════════════════════════════ */
.wave-top,.wave-bottom{
  position:relative;overflow:hidden;
}
.wave-top::before{
  content:"";position:absolute;top:-1px;left:0;right:0;height:60px;z-index:2;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23ffffff' d='M0,40 C360,80 720,0 1080,40 C1260,60 1380,30 1440,40 L1440,0 L0,0 Z'/%3E%3C/svg%3E") no-repeat center/cover;
}
.wave-bottom::after{
  content:"";position:absolute;bottom:-1px;left:0;right:0;height:60px;z-index:2;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23ffffff' d='M0,20 C360,-20 720,60 1080,20 C1260,0 1380,30 1440,20 L1440,60 L0,60 Z'/%3E%3C/svg%3E") no-repeat center/cover;
}
/* Wave into soft bg */
.wave-into-soft::after{
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23f7f9fc' d='M0,20 C360,-20 720,60 1080,20 C1260,0 1380,30 1440,20 L1440,60 L0,60 Z'/%3E%3C/svg%3E") no-repeat center/cover;
}
/* Wave from dark into white */
.wave-from-dark::before{
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23003863' d='M0,40 C360,80 720,0 1080,40 C1260,60 1380,30 1440,40 L1440,0 L0,0 Z'/%3E%3C/svg%3E") no-repeat center/cover;
}

/* ═══════════════════════════════════════════════════════════
   BUTTON RIPPLE EFFECT (JS injects .ripple span)
   ═══════════════════════════════════════════════════════════ */
.btn{position:relative;overflow:hidden}
.btn .ripple{
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,.35);
  transform:scale(0);
  animation:rippleAnim .6s ease-out forwards;
  pointer-events:none;
}
@keyframes rippleAnim{
  to{transform:scale(4);opacity:0}
}

/* ═══════════════════════════════════════════════════════════
   IMPACT BAND FLOATING ORBS
   ═══════════════════════════════════════════════════════════ */
.impact-band .hero-orb.orb-1{
  background:radial-gradient(circle,rgba(187,170,94,.25),transparent 70%);
  width:500px;height:500px;top:-30%;right:-10%;
}
.impact-band .hero-orb.orb-2{
  background:radial-gradient(circle,rgba(65,124,161,.3),transparent 70%);
  width:380px;height:380px;bottom:-25%;left:-5%;
}

/* ═══════════════════════════════════════════════════════════
   PARALLAX HERO (JS sets translateY)
   ═══════════════════════════════════════════════════════════ */
.parallax-bg{
  will-change:transform;
  transition:transform .1s linear;
}

/* ═══════════════════════════════════════════════════════════
   CTA BAND GRADIENT ANIMATION
   ═══════════════════════════════════════════════════════════ */
.cta-image-band-bg::after{
  background:linear-gradient(120deg,rgba(0,56,99,.92),rgba(33,83,135,.75),rgba(65,124,161,.65));
  background-size:200% 200%;
  animation:gradientShift 10s ease-in-out infinite;
}

/* ═══════════════════════════════════════════════════════════
   HOVER GLOW PULSE ON STAT NUMBERS
   ═══════════════════════════════════════════════════════════ */
.stat:hover .stat-num{color:var(--blue-dark);text-shadow:0 0 20px rgba(65,124,161,.25)}
.impact-item:hover .impact-num{text-shadow:0 0 24px rgba(187,170,94,.5)}

/* ═══════════════════════════════════════════════════════════
   REDUCED MOTION
   ═══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-left,.reveal-right,.reveal-scale,.reveal-up{opacity:1;transform:none;transition:none}
  .hero-content .eyebrow,.hero-content h1,.hero-tag,.hero-actions,.hero-stats{opacity:1;animation:none}
  .hero-bg::after,.cta-image-band-bg::after{animation:none}
  .hero-orb{display:none}
  .img-reveal,.img-reveal-right{clip-path:none}
  .scroll-progress{display:none}
  .btn .ripple{display:none}
}

/* ═══════════════════════════════════════════════════════════
   CHATBOT WIDGET
   ═══════════════════════════════════════════════════════════ */
.chatbot-toggle{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:56px;height:56px;border-radius:50%;
  background:var(--blue);color:#fff;border:none;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,56,99,.3);
  cursor:pointer;transition:all .25s;
}
.chatbot-toggle:hover{transform:scale(1.08);box-shadow:0 12px 32px rgba(0,56,99,.4)}
.chatbot-toggle svg{width:26px;height:26px}
.chatbot-toggle.open{background:var(--blue-dark);transform:rotate(90deg)}

.chatbot-window{
  position:fixed;bottom:92px;right:24px;z-index:89;
  width:380px;max-width:calc(100vw - 48px);
  height:520px;max-height:calc(100vh - 120px);
  background:#fff;border-radius:16px;
  box-shadow:0 20px 60px rgba(0,56,99,.25);
  border:1px solid var(--line);
  display:none;flex-direction:column;
  overflow:hidden;
  animation:chatIn .3s cubic-bezier(.34,1.56,.64,1);
}
.chatbot-window.open{display:flex}
@keyframes chatIn{from{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:none}}

.chatbot-header{
  background:var(--blue-dark);color:#fff;
  padding:1rem 1.2rem;
  display:flex;align-items:center;gap:.75rem;
}
.chatbot-header-dot{width:8px;height:8px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981}
.chatbot-header h4{font-size:.92rem;font-weight:700;flex:1}
.chatbot-header-close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;padding:4px}
.chatbot-header-close:hover{color:#fff}

.chatbot-body{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}
.chatbot-msg{
  max-width:85%;padding:.75rem 1rem;border-radius:12px;
  font-size:.88rem;line-height:1.5;
}
.chatbot-msg.bot{
  background:var(--bg-tint);color:var(--text);
  align-self:flex-start;border-bottom-left-radius:4px;
}
.chatbot-msg.user{
  background:var(--blue);color:#fff;
  align-self:flex-end;border-bottom-right-radius:4px;
}
.chatbot-quick{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.chatbot-quick button{
  background:#fff;border:1.5px solid var(--line);
  border-radius:99px;padding:.45rem .9rem;
  font-size:.78rem;font-weight:600;color:var(--blue);
  cursor:pointer;transition:all .2s;font-family:inherit;
}
.chatbot-quick button:hover{background:var(--bg-tint);border-color:var(--blue)}

.chatbot-input{
  display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--line);
}
.chatbot-input input{
  flex:1;border:1.5px solid var(--line);border-radius:99px;
  padding:.55rem 1rem;font-family:inherit;font-size:.85rem;
  outline:none;transition:border .2s;
}
.chatbot-input input:focus{border-color:var(--blue)}
.chatbot-input button{
  width:38px;height:38px;border-radius:50%;
  background:var(--blue);color:#fff;border:none;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;flex-shrink:0;
}
.chatbot-input button:hover{background:var(--blue-mid)}

/* ═══════════════════════════════════════════════════════════
   FOOTER LOGO FIX (override filter for colored logo)
   ═══════════════════════════════════════════════════════════ */
.footer-brand img{filter:none!important;height:72px!important}

/* ═══════════════════════════════════════════════════════════
   DONATION PAGE: BUTTON DIRECTLY UNDER AMOUNT CARDS
   ═══════════════════════════════════════════════════════════ */
.don-section{max-width:680px;margin:0 auto}
.don-section .don-cards{margin-bottom:1.5rem}
.don-inline-form{
  display:flex;gap:1rem;align-items:center;
  max-width:680px;margin:0 auto 1rem;
  flex-wrap:wrap;
}
.don-inline-form .fg{flex:1;min-width:120px;margin-bottom:0}
.don-inline-form .btn{flex-shrink:0;white-space:nowrap}
.don-total{
  text-align:center;max-width:680px;margin:0 auto 2rem;
  font-size:.88rem;color:var(--text-soft);
}
.don-total strong{color:var(--blue);font-weight:700}

/* ═══════════════════════════════════════════════════════════
   INSCRIPTION: TAB-BASED FORM SEPARATION
   ═══════════════════════════════════════════════════════════ */
.inscription-tabs{
  display:flex;gap:0;background:var(--bg-tint);
  border-radius:12px;padding:5px;margin-bottom:2.5rem;
  max-width:500px;margin-left:auto;margin-right:auto;
}
.inscription-tab{
  flex:1;padding:1rem;border:none;background:none;
  font-family:inherit;font-size:.95rem;font-weight:700;
  color:var(--text-muted);border-radius:10px;
  cursor:pointer;transition:all .25s;text-align:center;
}
.inscription-tab.active{
  background:#fff;color:var(--blue-dark);
  box-shadow:0 2px 12px rgba(0,0,0,.08);
}
.inscription-tab:hover:not(.active){color:var(--blue)}
.inscription-panel{display:none}
.inscription-panel.active{display:block;animation:tabFade .3s ease}
@keyframes tabFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════════════════════════════
   CONTACT: MODERN FORM DESIGN
   ═══════════════════════════════════════════════════════════ */
.contact-modern{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  align-items:start;
}
@media(max-width:900px){.contact-modern{grid-template-columns:1fr}}
.contact-form-card{
  background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  padding:2.5rem;border:1px solid var(--line);
  position:relative;overflow:hidden;
}
.contact-form-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--blue),var(--gold));
}
.contact-sidebar{display:flex;flex-direction:column;gap:1.2rem}
.contact-sidebar-card{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.5rem;
  display:flex;gap:1rem;align-items:flex-start;
  transition:all .25s;
}
.contact-sidebar-card:hover{
  border-color:var(--blue);transform:translateX(4px);
  box-shadow:var(--shadow);
}
.contact-sidebar-icon{
  width:44px;height:44px;flex-shrink:0;
  background:var(--blue);color:#fff;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}

/* ═══════════════════════════════════════════════════════════
   CHATBOX: ADD "NOUS REJOINDRE" BUTTON + AGENT CONTACT
   ═══════════════════════════════════════════════════════════ */
.chatbot-actions{
  display:flex;gap:.5rem;padding:.5rem 1rem;
  border-top:1px solid var(--line);
}
.chatbot-actions a,.chatbot-actions button{
  flex:1;padding:.5rem;
  border-radius:8px;border:1.5px solid var(--line);
  background:#fff;color:var(--blue);
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;text-align:center;
  cursor:pointer;transition:all .2s;
  text-decoration:none;display:block;
  font-family:inherit;
}
.chatbot-actions a:hover,.chatbot-actions button:hover{
  background:var(--blue);color:#fff;border-color:var(--blue);
}

/* ═══════════════════════════════════════════════════════════════
   v3.1 — Enhanced motion & micro-interactions
   ═══════════════════════════════════════════════════════════════ */

/* Keyframes */
@keyframes ee-fade-up{
  from{opacity:0;transform:translateY(28px)}
  to  {opacity:1;transform:translateY(0)}
}
@keyframes ee-fade-in{
  from{opacity:0}to{opacity:1}
}
@keyframes ee-float-orb{
  0%,100%{transform:translate(0,0) scale(1)}
  33%   {transform:translate(18px,-22px) scale(1.04)}
  66%   {transform:translate(-14px,12px) scale(.97)}
}
@keyframes ee-gradient-shift{
  0%,100%{background-position:0% 50%}
  50%    {background-position:100% 50%}
}
@keyframes ee-shimmer{
  0%{background-position:-200% 0}
  100%{background-position:200% 0}
}
@keyframes ee-pulse-ring{
  0%  {box-shadow:0 0 0 0 rgba(65,124,161,.45)}
  70% {box-shadow:0 0 0 16px rgba(65,124,161,0)}
  100%{box-shadow:0 0 0 0 rgba(65,124,161,0)}
}
@keyframes ee-underline-in{
  from{transform:scaleX(0)}to{transform:scaleX(1)}
}

/* Scroll-reveal (wired by app.js via IntersectionObserver, see below) */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.24s}
.reveal-delay-4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn::before,.btn-outline::after,.btn-outline-white::after{display:none}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* Orbs — softer float instead of static */
.hero-orb{animation:ee-float-orb 14s ease-in-out infinite}
.hero-orb.orb-2{animation-duration:18s;animation-delay:-6s}
.hero-orb.orb-3{animation-duration:22s;animation-delay:-12s}

/* Nav links — animated underline */
.nav-links a{position:relative}
.nav-links a::after{
  content:"";position:absolute;left:12px;right:12px;bottom:4px;height:2px;
  background:linear-gradient(90deg,var(--blue),var(--gold));
  border-radius:2px;
  transform:scaleX(0);transform-origin:left center;
  transition:transform var(--trs-smooth);
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}

/* Cards — richer hover (pillar / feature / team / news / don-card) */
.pillar,.feature,.team-card,.news-card,.don-card{
  transition:transform var(--trs-smooth),box-shadow var(--trs-smooth),border-color var(--trs-smooth) !important;
  will-change:transform;
}
.pillar:hover,
.feature:hover,
.team-card:hover,
.news-card:hover,
.don-card:hover{
  transform:translateY(-8px) scale(1.012);
  box-shadow:
    0 32px 60px -24px rgba(0,56,99,.28),
    0 12px 24px -14px rgba(0,56,99,.18),
    0 0 0 1px rgba(65,124,161,.12);
}

/* Pillar icon — pop + rotate micro */
.pillar-icon{transition:background var(--trs-smooth),color var(--trs-smooth),transform var(--trs) var(--ease-bounce)}
.pillar:hover .pillar-icon{transform:rotate(-6deg) scale(1.12)}

/* Images inside cards — slower, smoother zoom */
.feature-img img,.news-img img,.team-photo img{
  transition:transform 1.1s cubic-bezier(.22,1,.36,1),filter .6s ease !important;
  filter:saturate(.92);
}
.feature:hover .feature-img img,
.news-card:hover .news-img img,
.team-card:hover .team-photo img{
  transform:scale(1.08);
  filter:saturate(1.05);
}

/* Video placeholder play-button — pulsating ring on idle */
.video-placeholder .video-play{animation:ee-pulse-ring 2.6s ease-out infinite}
.video-placeholder:hover .video-play{animation:none}

/* Amount chips (dons) — soft lift */
.amount{transition:transform var(--trs-smooth),border-color var(--trs-smooth),background var(--trs-smooth),box-shadow var(--trs-smooth)}
.amount:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 24px -10px rgba(65,124,161,.3);
}
.amount.active,.amount:focus-visible{
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  color:#fff;border-color:transparent;
  box-shadow:0 14px 28px -12px rgba(0,56,99,.45);
}

/* Links — subtle animated underline where text-only */
.pillar-link,.news-link,.breadcrumb a,.topbar-right a{
  position:relative;display:inline-flex;align-items:center;gap:.35rem;
}
.pillar-link::after,.news-link::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:currentColor;opacity:.6;
  transform:scaleX(0);transform-origin:left center;
  transition:transform var(--trs-smooth);
}
.pillar-link:hover::after,.news-link:hover::after{transform:scaleX(1)}

/* Gold-accent gradient headline utility */
.headline-shine{
  background:linear-gradient(90deg,var(--blue-dark) 0%,var(--blue) 35%,var(--gold) 55%,var(--blue) 75%,var(--blue-dark) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:ee-gradient-shift 8s ease-in-out infinite;
}

/* Focus — accessible, stylish */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--blue);
  outline-offset:3px;
  border-radius:6px;
}

/* Logo — subtle brand wiggle on hover */
/* nav-brand logo kept static (no resize/wiggle) */

/* Burger to X morph */
.burger span{transition:transform var(--trs-smooth),opacity var(--trs-smooth)}
.burger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0;transform:scaleX(.3)}
.burger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Scroll progress — smoother */
.scroll-progress-fill{background:linear-gradient(90deg,var(--blue),var(--gold),var(--blue-mid))!important;background-size:200% 100%;animation:ee-gradient-shift 6s ease-in-out infinite}


/* ═══════════════════════════════════════════════════════════════
   NAV REFRESH — logo prominence + brand separation
   ═══════════════════════════════════════════════════════════════ */
.nav{padding:.55rem 2.5rem;gap:1.25rem}
.nav-brand{gap:.95rem;padding:.15rem .35rem .15rem 0;position:relative}
.nav-brand::after{
  content:"";position:absolute;right:-.85rem;top:50%;transform:translateY(-50%);
  width:1px;height:34px;background:linear-gradient(to bottom,transparent,var(--line) 20%,var(--line) 80%,transparent);
}
.nav-brand img,
.header.scrolled .nav-brand img{
  height:54px;width:54px;
  padding:5px;
  background:radial-gradient(circle at 30% 25%,#fff 0,#f5f8fc 70%,#eaf0f8 100%);
  border-radius:14px;
  box-shadow:0 2px 6px -2px rgba(0,56,99,.18),0 0 0 1px rgba(0,56,99,.06),inset 0 1px 0 rgba(255,255,255,.8);
  transition:transform .35s ease,box-shadow .35s ease;
}
.nav-brand:hover img{
  transform:translateY(-1px) scale(1.03);
  box-shadow:0 6px 16px -4px rgba(0,56,99,.28),0 0 0 1px rgba(0,56,99,.1),inset 0 1px 0 rgba(255,255,255,.9);
}
.nav-brand-name{font-size:1.28rem;font-weight:800;letter-spacing:-.015em;background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav-brand-tag{font-size:.7rem;color:var(--gold,#c9a227);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-top:3px}
@media (max-width:1200px){
  .nav-brand::after{display:none}
  .nav-brand img,.header.scrolled .nav-brand img{height:46px;width:46px}
}
@media (max-width:600px){
  .nav-brand-tag{display:none}
  .nav-brand-name{font-size:1.1rem}
}

/* ═══════════════════════════════════════════════════════════════
   CHAT WIDGET v2 — premium 21st.dev-inspired
   ═══════════════════════════════════════════════════════════════ */
#chatbot-toggle{
  position:fixed!important;bottom:24px;right:24px;z-index:9999;
  width:62px!important;height:62px!important;border-radius:50%!important;
  background:linear-gradient(135deg,#003863 0%,#417ca1 60%,#5a9fc7 100%)!important;
  color:#fff!important;border:none!important;cursor:pointer;
  display:flex!important;align-items:center;justify-content:center;
  box-shadow:0 10px 30px -8px rgba(0,56,99,.55),0 0 0 4px rgba(255,255,255,.7),inset 0 1px 0 rgba(255,255,255,.3)!important;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease!important;
}
#chatbot-toggle::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  background:linear-gradient(135deg,#003863,#bbaa5e);
  z-index:-1;opacity:0;transition:opacity .35s;
}
#chatbot-toggle::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:0 0 0 0 rgba(65,124,161,.6);
  animation:eeChatPulse 2.4s ease-out infinite;
}
@keyframes eeChatPulse{
  0%{box-shadow:0 0 0 0 rgba(65,124,161,.55)}
  70%{box-shadow:0 0 0 18px rgba(65,124,161,0)}
  100%{box-shadow:0 0 0 0 rgba(65,124,161,0)}
}
#chatbot-toggle:hover{transform:translateY(-3px) scale(1.06)!important}
#chatbot-toggle:hover::before{opacity:1}
#chatbot-toggle.open{
  background:linear-gradient(135deg,#1a1f2e,#003863)!important;
  transform:rotate(180deg) scale(.92)!important;
}
#chatbot-toggle.open::after{animation:none}

#chatbot-window{
  position:fixed!important;bottom:100px;right:24px;z-index:9998;
  width:380px;max-width:calc(100vw - 32px);
  height:560px;max-height:calc(100vh - 140px);
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border-radius:22px;
  border:1px solid rgba(0,56,99,.08);
  box-shadow:0 30px 60px -20px rgba(0,56,99,.35),0 12px 24px -8px rgba(0,56,99,.18),0 0 0 1px rgba(255,255,255,.6) inset;
  display:none;flex-direction:column;overflow:hidden;
  transform:translateY(20px) scale(.96);opacity:0;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;
}
#chatbot-window.open{display:flex;animation:eeChatSlide .4s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes eeChatSlide{to{transform:translateY(0) scale(1);opacity:1}}

.chatbot-header{
  background:linear-gradient(135deg,#003863 0%,#1a4d7a 50%,#417ca1 100%);
  color:#fff;padding:18px 18px 16px;
  display:flex;align-items:center;gap:12px;
  position:relative;overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.chatbot-header::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 0%,rgba(187,170,94,.25) 0%,transparent 60%),radial-gradient(circle at 80% 100%,rgba(90,159,199,.3) 0%,transparent 50%);
  pointer-events:none;
}
.chatbot-header > *{position:relative;z-index:1}
.chatbot-header-dot{
  width:10px;height:10px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.25),0 0 12px #22c55e;
  animation:eeChatDot 2s ease-in-out infinite;flex-shrink:0;
}
@keyframes eeChatDot{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.chatbot-header h4{
  font-size:1rem;font-weight:700;flex:1;letter-spacing:-.01em;margin:0;line-height:1.2;
}
.chatbot-header h4::after{
  content:"En ligne · répond en ~1h";display:block;
  font-size:.68rem;font-weight:500;color:rgba(255,255,255,.7);
  letter-spacing:.01em;margin-top:2px;
}
.chatbot-header button{
  background:rgba(255,255,255,.1)!important;border:1px solid rgba(255,255,255,.15)!important;
  color:rgba(255,255,255,.85)!important;cursor:pointer;
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;padding:0!important;
  transition:all .2s ease;
}
.chatbot-header button:hover{background:rgba(255,255,255,.18)!important;color:#fff!important}

.chatbot-body{
  flex:1;overflow-y:auto;padding:20px 18px;
  display:flex;flex-direction:column;gap:10px;
  background:linear-gradient(180deg,#f8fafc 0%,#fff 100%);
  scroll-behavior:smooth;
}
.chatbot-body::-webkit-scrollbar{width:6px}
.chatbot-body::-webkit-scrollbar-thumb{background:rgba(0,56,99,.15);border-radius:3px}

.chatbot-msg{
  max-width:82%;padding:11px 15px;font-size:.875rem;line-height:1.5;
  border-radius:18px;
  animation:eeChatMsg .35s cubic-bezier(.34,1.56,.64,1) both;
  word-wrap:break-word;
}
@keyframes eeChatMsg{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}

.chatbot-msg.bot{
  align-self:flex-start;
  background:#fff;color:#1a2332;
  border:1px solid rgba(0,56,99,.08);
  border-bottom-left-radius:6px;
  box-shadow:0 1px 3px rgba(0,56,99,.06),0 4px 12px -4px rgba(0,56,99,.08);
}
.chatbot-msg.user{
  align-self:flex-end;
  background:linear-gradient(135deg,#003863 0%,#417ca1 100%);
  color:#fff;
  border-bottom-right-radius:6px;
  box-shadow:0 4px 12px -4px rgba(0,56,99,.4);
}

.chatbot-quick{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.chatbot-quick button{
  background:#fff;color:#003863;
  border:1.5px solid rgba(0,56,99,.15);
  padding:8px 14px;border-radius:99px;
  font-size:.78rem;font-weight:600;font-family:inherit;
  cursor:pointer;transition:all .2s ease;
  white-space:nowrap;
}
.chatbot-quick button:hover{
  border-color:#bbaa5e;background:rgba(187,170,94,.08);
  color:#003863;transform:translateY(-1px);
  box-shadow:0 4px 10px -2px rgba(187,170,94,.25);
}

/* Agent typing indicator (3 pulsing dots) */
@keyframes eeTyping{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}

/* Input area injected by JS — restyle */
#chat-input-area{
  border-top:1px solid rgba(0,56,99,.08)!important;
  background:#fff!important;padding:12px 14px!important;margin:0!important;
  position:sticky!important;bottom:0;
}
#chat-msg-input{
  flex:1;padding:11px 16px!important;
  border:1.5px solid rgba(0,56,99,.12)!important;border-radius:99px!important;
  font-size:.85rem!important;font-family:inherit!important;outline:none;
  transition:border-color .2s,box-shadow .2s;
  background:#f8fafc!important;
}
#chat-msg-input:focus{border-color:#417ca1!important;background:#fff!important;box-shadow:0 0 0 4px rgba(65,124,161,.12)!important}
#chat-input-area button{
  width:40px!important;height:40px!important;border-radius:50%!important;
  background:linear-gradient(135deg,#003863,#417ca1)!important;
  color:#fff!important;border:none!important;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 4px 12px -2px rgba(0,56,99,.35)!important;
  transition:transform .2s ease,box-shadow .2s ease;
}
#chat-input-area button:hover{transform:scale(1.08);box-shadow:0 6px 18px -2px rgba(0,56,99,.45)!important}

@media (max-width:480px){
  #chatbot-window{bottom:92px;right:12px;left:12px;width:auto;max-width:none;height:calc(100vh - 120px)}
  #chatbot-toggle{bottom:18px;right:18px;width:56px!important;height:56px!important}
}

/* ═══════════════════════════════════════════════════════════════
   CHAT WIDGET v3 — overrides: in-flex toggle + richer conversation
   ═══════════════════════════════════════════════════════════════ */

/* Toggle stays inside #float-btns next to "Nous rejoindre" — undo fixed positioning */
#chatbot-toggle{
  position:relative!important;bottom:auto!important;right:auto!important;
  width:56px!important;height:56px!important;flex-shrink:0;
}
#float-btns{bottom:28px!important;right:28px!important}

/* Chat window anchored above the float-btns row */
#chatbot-window{bottom:96px!important;right:28px!important}
@media (max-width:480px){
  #chatbot-window{bottom:96px!important;right:12px!important;left:12px!important;width:auto;max-width:none}
  #float-btns{bottom:18px!important;right:18px!important;flex-wrap:wrap;justify-content:flex-end}
}

/* ── Header avatar + improved status ── */
.chatbot-header{padding:16px 16px 14px!important;gap:11px!important}
.chatbot-header-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:#fff url('/ee/logo-icon.png') center/76% no-repeat;
  box-shadow:0 4px 12px rgba(0,0,0,.18),0 0 0 2px rgba(255,255,255,.5);
  position:relative;
}
.chatbot-header-avatar::after{
  content:"";position:absolute;bottom:-1px;right:-1px;
  width:11px;height:11px;border-radius:50%;background:#22c55e;
  border:2px solid #003863;
  box-shadow:0 0 8px #22c55e;
  animation:eeChatDot 2s ease-in-out infinite;
}
.chatbot-header-dot{display:none!important} /* replaced by avatar's dot */
.chatbot-header h4{font-size:.95rem!important}
.chatbot-header h4::after{content:"En ligne · répond en ~1h"!important}

/* ── Bubbles with avatars ── */
.chatbot-msg{position:relative;max-width:78%!important}
.chatbot-msg.bot{margin-left:38px}
.chatbot-msg.bot::before{
  content:"";position:absolute;left:-38px;top:0;width:30px;height:30px;border-radius:50%;
  background:#fff url('/ee/logo-icon.png') center/76% no-repeat;
  box-shadow:0 2px 6px rgba(0,56,99,.15),0 0 0 1px rgba(0,56,99,.08);
}
.chatbot-msg.user::after{
  content:"";position:absolute;right:-32px;top:4px;width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg,#bbaa5e,#9c8c48);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M20 21v-2a4 4 0 00-4-4H8a4 4 0 00-4 4v2'/><circle cx='12' cy='7' r='4'/></svg>");
  background-size:62%;background-position:center;background-repeat:no-repeat;
  background-color:#9c8c48;
  box-shadow:0 2px 6px rgba(187,170,94,.4);
}
.chatbot-msg.user{margin-right:32px}

/* "Agent" label badge inside agent messages */
.chatbot-msg.bot strong{
  display:inline-flex!important;align-items:center;gap:4px;
  font-size:.62rem!important;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:#003863!important;background:rgba(187,170,94,.15);
  padding:2px 8px;border-radius:99px;margin-bottom:6px!important;
}
.chatbot-msg.bot strong::before{
  content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 4px #22c55e;
}

/* ── Quick chips with icons ── */
.chatbot-quick{gap:8px!important;margin-top:14px!important}
.chatbot-quick button{
  padding:10px 14px 10px 12px!important;
  display:inline-flex!important;align-items:center;gap:7px;
  font-size:.78rem!important;
}
.chatbot-quick button::before{
  content:"";width:18px;height:18px;flex-shrink:0;display:inline-block;
  background-repeat:no-repeat;background-position:center;background-size:contain;
  opacity:.85;transition:transform .25s ease;
}
.chatbot-quick button:hover::before{transform:rotate(-8deg) scale(1.15)}
.chatbot-quick button:nth-child(1)::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23003863' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M9 11l3 3L22 4'/><path d='M21 12v7a2 2 0 01-2 2H5a2 2 0 01-2-2V5a2 2 0 012-2h11'/></svg>");
}
.chatbot-quick button:nth-child(2)::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23003863' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M22 10v6M2 10l10-5 10 5-10 5z'/><path d='M6 12v5c3 3 9 3 12 0v-5'/></svg>");
}
.chatbot-quick button:nth-child(3)::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23003863' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='3'/><path d='M19.4 15a1.65 1.65 0 00.33 1.82l.06.06a2 2 0 01-2.83 2.83l-.06-.06a1.65 1.65 0 00-1.82-.33 1.65 1.65 0 00-1 1.51V21a2 2 0 01-4 0v-.09A1.65 1.65 0 009 19.4a1.65 1.65 0 00-1.82.33l-.06.06a2 2 0 01-2.83-2.83l.06-.06a1.65 1.65 0 00.33-1.82 1.65 1.65 0 00-1.51-1H3a2 2 0 010-4h.09A1.65 1.65 0 004.6 9a1.65 1.65 0 00-.33-1.82l-.06-.06a2 2 0 012.83-2.83l.06.06a1.65 1.65 0 001.82.33H9a1.65 1.65 0 001-1.51V3a2 2 0 014 0v.09a1.65 1.65 0 001 1.51 1.65 1.65 0 001.82-.33l.06-.06a2 2 0 012.83 2.83l-.06.06a1.65 1.65 0 00-.33 1.82V9a1.65 1.65 0 001.51 1H21a2 2 0 010 4h-.09a1.65 1.65 0 00-1.51 1z'/></svg>");
}
.chatbot-quick button:nth-child(4)::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23003863' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 14v-3a9 9 0 0118 0v3'/><path d='M21 14a2 2 0 01-2 2h-1v-5h1a2 2 0 012 2zM3 14a2 2 0 002 2h1v-5H5a2 2 0 00-2 2zM21 16v1a4 4 0 01-4 4h-3'/><circle cx='13' cy='21' r='1'/></svg>");
}
.chatbot-quick button:nth-child(4){
  background:linear-gradient(135deg,rgba(187,170,94,.12),rgba(187,170,94,.05))!important;
  border-color:rgba(187,170,94,.4)!important;
}

/* ── Body subtle pattern + cleaner spacing ── */
.chatbot-body{
  padding:18px 16px 22px!important;gap:14px!important;
  background-image:
    radial-gradient(circle at 20% 10%,rgba(65,124,161,.04) 0,transparent 40%),
    radial-gradient(circle at 90% 90%,rgba(187,170,94,.05) 0,transparent 40%),
    linear-gradient(180deg,#f8fafc 0%,#fff 100%)!important;
}

/* ── Send button with icon shimmer + active state ── */
#chat-input-area button:active{transform:scale(.94)!important}
#chat-input-area button svg{transition:transform .25s ease}
#chat-input-area button:hover svg{transform:translate(2px,-2px) rotate(8deg)}

/* ── Form (name + email) prettify ── */
.chatbot-body input[id^="chat-name"],.chatbot-body input[id^="chat-email"]{
  border-radius:10px!important;border-color:rgba(0,56,99,.12)!important;
  transition:border-color .2s,box-shadow .2s;
}
.chatbot-body input[id^="chat-name"]:focus,.chatbot-body input[id^="chat-email"]:focus{
  border-color:#417ca1!important;box-shadow:0 0 0 3px rgba(65,124,161,.12)!important;outline:none;
}

/* ── Open-state shake hint on first load (subtle) ── */
@keyframes eeToggleHint{
  0%,90%,100%{transform:none}
  92%{transform:rotate(-8deg)}
  94%{transform:rotate(8deg)}
  96%{transform:rotate(-4deg)}
  98%{transform:rotate(4deg)}
}
#chatbot-toggle:not(.open){animation:eeToggleHint 5s ease-in-out 3s infinite}
#chatbot-toggle:hover{animation:none!important}

/* ── Chat header — force white title, remove subtitle ── */
.chatbot-header h4{color:#fff!important}
.chatbot-header h4::after{content:none!important;display:none!important}

/* ═══════════════════════════════════════════════════════════════
   CHAT v4 — agent form + animated input mount
   ═══════════════════════════════════════════════════════════════ */
#chat-input-area.mounted{transform:translateY(0);opacity:1}
#chat-msg-input{
  flex:1;padding:10px 16px!important;
  border:1.5px solid rgba(0,56,99,.12)!important;border-radius:18px!important;
  font-size:.85rem!important;font-family:inherit!important;
  background:#f8fafc!important;color:#1a2332;outline:none;
  resize:none;line-height:1.4;max-height:120px;min-height:42px;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
#chat-msg-input:focus{border-color:#417ca1!important;background:#fff!important;box-shadow:0 0 0 3px rgba(65,124,161,.14)!important}
#chat-input-area button{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,#003863,#417ca1)!important;
  color:#fff!important;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  align-self:flex-end;
  box-shadow:0 4px 12px -2px rgba(0,56,99,.4);
  transition:transform .2s,box-shadow .2s;
}
#chat-input-area button:hover{transform:scale(1.08) rotate(-4deg)}
#chat-input-area button:active{transform:scale(.94)}

/* ── chatfix5 — force input visibility, fallback if .mounted not added ── */
#chat-input-area{
  transform:none!important;opacity:1!important;
  animation:cafSlide .4s cubic-bezier(.34,1.56,.64,1) both;
}

/* ── chatfix6 — flex layout fix: body must shrink, input must stay visible ── */
.chatbot-body{min-height:0!important;flex:1 1 0%!important}
#chat-input-area{flex-shrink:0!important;flex-grow:0!important}
#chatbot-window{flex-direction:column!important}

/* ═══════════════════════════════════════════════════════════════
   CHAT v5 — agent message premium look
   ═══════════════════════════════════════════════════════════════ */
.chatbot-msg.bot.agent{
  background:linear-gradient(135deg,#fff 0%,#f8f6ed 100%)!important;
  border:1px solid rgba(187,170,94,.35)!important;
  border-left:3px solid #bbaa5e!important;
  border-bottom-left-radius:6px;
  box-shadow:0 2px 6px rgba(187,170,94,.15),0 8px 20px -6px rgba(187,170,94,.2)!important;
  padding:13px 16px 13px 14px!important;
  position:relative;
  margin-left:42px!important;
}
/* Override the generic bot avatar (logo) with a gold "agent" headset avatar */
.chatbot-msg.bot.agent::before{
  content:""!important;
  position:absolute!important;left:-42px!important;top:0!important;
  width:34px!important;height:34px!important;border-radius:50%!important;
  background:linear-gradient(135deg,#bbaa5e 0%,#9c8c48 100%)!important;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 14v-3a9 9 0 0118 0v3'/><path d='M21 14a2 2 0 01-2 2h-1v-5h1a2 2 0 012 2zM3 14a2 2 0 002 2h1v-5H5a2 2 0 00-2 2zM21 16v1a4 4 0 01-4 4h-3'/><circle cx='13' cy='21' r='1'/></svg>")!important;
  background-size:60%!important;background-position:center!important;background-repeat:no-repeat!important;
  background-color:#9c8c48!important;
  box-shadow:0 4px 12px rgba(187,170,94,.45),0 0 0 2px #fff,0 0 0 3px rgba(187,170,94,.25)!important;
}
/* "Agent" label badge restyled for agent context */
.chatbot-msg.bot.agent strong{
  display:flex!important;align-items:center;gap:6px;
  font-size:.65rem!important;font-weight:800!important;letter-spacing:.1em!important;
  text-transform:uppercase;
  color:#9c8c48!important;
  background:transparent!important;
  padding:0!important;margin:0 0 8px 0!important;
  border-radius:0!important;
  border-bottom:1px solid rgba(187,170,94,.2);
  padding-bottom:6px!important;
}
.chatbot-msg.bot.agent strong::before{
  content:"";display:inline-block;
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  box-shadow:0 0 0 2px rgba(34,197,94,.2);
  flex-shrink:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white' stroke='none'><path d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>");
  background-size:70%;background-position:center;background-repeat:no-repeat;
}
.chatbot-msg.bot.agent strong::after{
  content:"Entre Élèves · Équipe";
  font-size:.6rem;color:#94a3b8;font-weight:600;letter-spacing:.04em;text-transform:none;
  margin-left:auto;
}
/* Subtle entrance flash for agent messages */
@keyframes eeAgentArrive{
  0%{opacity:0;transform:translateY(8px) scale(.96);box-shadow:0 0 0 0 rgba(187,170,94,0)}
  60%{box-shadow:0 0 0 6px rgba(187,170,94,.2),0 8px 20px -6px rgba(187,170,94,.25)}
  100%{opacity:1;transform:none;box-shadow:0 2px 6px rgba(187,170,94,.15),0 8px 20px -6px rgba(187,170,94,.2)}
}
.chatbot-msg.bot.agent{animation:eeAgentArrive .55s cubic-bezier(.34,1.56,.64,1) both!important}

/* Restore initial CTA badge style only for non-agent bot KB intros */
.chatbot-msg.bot:not(.agent) strong{
  display:inline-flex!important;align-items:center;gap:4px;
  font-size:.62rem!important;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:#003863!important;background:rgba(187,170,94,.15);
  padding:2px 8px;border-radius:99px;margin-bottom:6px!important;
}

/* ── Override inline display:none on .open (anti-FOUC fix) ── */
#chatbot-window.open{display:flex!important}

/* ── Disable browser default :invalid red border on untouched required fields ── */
input:invalid,textarea:invalid,select:invalid{box-shadow:none!important;outline:none!important;border-color:inherit!important}
input:user-invalid,textarea:user-invalid,select:user-invalid{
  border-color:#dc2626!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important;
}

/* ═══════════════════════════════════════════════════════════════
   NEWS — premium hover + full-card clickable link
   ═══════════════════════════════════════════════════════════════ */
.news-card{position:relative;cursor:pointer}
/* Make the entire card clickable via the existing news-link */
.news-link::before{
  content:"";position:absolute;inset:0;z-index:1;
}
.news-link{
  position:relative;z-index:2;
  padding:.55rem 1.1rem .55rem 1rem;border-radius:99px;
  background:linear-gradient(135deg,#003863,#417ca1);
  color:#fff!important;
  align-self:flex-start;
  box-shadow:0 4px 12px -2px rgba(0,56,99,.3);
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  overflow:hidden;
}
.news-link::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,#bbaa5e,#9c8c48);
  transform:translateX(-101%);transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.news-link:hover{
  transform:translateY(-2px) scale(1.03);
  box-shadow:0 8px 18px -4px rgba(187,170,94,.45);
  letter-spacing:.08em;
}
.news-link:hover::after{transform:translateX(0)}
.news-link svg{width:14px;height:14px;transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.news-card:hover .news-link svg,.news-link:hover svg{transform:translateX(5px)}
.news-card:hover .news-link{
  transform:translateY(-2px);
  box-shadow:0 8px 18px -4px rgba(187,170,94,.45);
}
.news-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px -12px rgba(0,56,99,.25)}

/* ── HERO v3 — pills replace fake stats ── */
.hero-stats{display:none!important}
.hero-pills{
  display:flex;flex-wrap:wrap;gap:.5rem;
  padding:1.25rem 0 0 1.25rem;
  margin-top:.5rem;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:99px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  font-size:.86rem;color:rgba(255,255,255,.92);font-weight:500;
  transition:all .25s;
}
.hero-pill:hover{background:rgba(187,170,94,.15);border-color:rgba(187,170,94,.45);transform:translateY(-2px)}
.hero-pill strong{color:var(--gold);font-weight:800}
.hero-pill-ic{width:16px;height:16px;color:var(--gold);flex-shrink:0}
@media (max-width:600px){
  .hero-pills{padding-left:.75rem;gap:.4rem}
  .hero-pill{padding:7px 12px;font-size:.78rem}
}

/* ── HERO v4 — kill all the padding-left mess, align everything flush left ── */
.hero-title,.hero-tag,.hero-actions,.hero-pills,.hero-stats{padding-left:0!important}
.hero-tag{border-left:none!important;max-width:580px}
.hero-title::before{display:none!important}
.hero-eyebrow{margin-bottom:1.5rem!important}
.hero-title{margin-bottom:1.25rem!important}
.hero-tag{margin-bottom:2.25rem!important}
.hero-actions{margin-bottom:2.5rem!important}
.hero-pills{margin-top:0!important}






/* ═══════════════════════════════════════════════════════════════════════
   MOBILE PERFECT v1 — Comprehensive responsive fixes (audit-driven)
   Append-only. Targets: iPhone SE (375), iPhone Plus (414), tablet (768).
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── 1. Prevent iOS auto-zoom on form fields (need ≥16px) ─── */
@media (max-width: 768px) {
  input:not([type="checkbox"]):not([type="radio"]),
  select, textarea,
  .dm-field input,
  #chat-msg-input,
  .chatbot-input input,
  .auth-input-wrap input {
    font-size: 16px !important;
  }
}

/* ─── 2. Touch targets ≥44px on small interactive elements ─── */
@media (max-width: 768px) {
  .btn-sm { min-height: 40px; padding: .65rem 1.2rem !important; }
  .faq-toggle, .chatbot-header-close, .footer-social a,
  .news-link-arrow, .nav-cta .btn { min-width: 44px; min-height: 44px; }
  .slider-dot { width: 14px !important; height: 14px !important; }
  .chatbot-quick button { min-height: 40px !important; }
}

/* ─── 3. Float-btns + chatbot — clear viewport bottom ─── */
@media (max-width: 600px) {
  #float-btns {
    bottom: 14px !important; right: 12px !important; left: auto !important;
    gap: 8px !important; flex-wrap: nowrap !important;
    justify-content: flex-end !important;
  }
  #float-btns > a {
    padding: 10px 14px !important;
    font-size: .78rem !important;
  }
  #float-btns > a svg { width: 14px; height: 14px; }
  #chatbot-toggle {
    width: 50px !important; height: 50px !important;
  }
  #chatbot-toggle svg { width: 22px; height: 22px; }
}

/* ─── 4. Hero — kill <br>, scale tag, use small viewport (svh) ─── */
@media (max-width: 600px) {
  .hero { min-height: 88svh !important; min-height: 88vh; }
  .hero-title br { display: none !important; }
  .hero-tag { font-size: 1.05rem !important; line-height: 1.5 !important; }
  .hero-actions {
    gap: .75rem !important;
    flex-direction: column !important;
  }
  .hero-actions .btn-lg {
    flex: 1 1 100% !important;
    justify-content: center !important;
    width: 100%;
  }
  .hero-pills { gap: .35rem !important; }
  .hero-pill { font-size: .76rem !important; padding: 6px 11px !important; }
}

/* ─── 5. Stats grid — single column on tiny screens ─── */
@media (max-width: 420px) {
  .stats-grid { grid-template-columns: 1fr !important; gap: 0 !important; }
  .stat-num { font-size: 2.4rem !important; }
}

/* ─── 6. Equipe team-grid — kill the inline 2-col on small screens ─── */
@media (max-width: 600px) {
  .team-grid[style] { grid-template-columns: 1fr !important; max-width: 100% !important; }
  .team-avatar { width: 96px !important; height: 96px !important; font-size: 2rem !important; }
}

/* ─── 7. Mobile nav offset — match actual header height ─── */
@media (max-width: 1200px) {
  .nav-mobile.open { top: 78px !important; }
  .nav-mobile.is-open { top: 78px !important; display: block !important; }
}
@media (max-width: 600px) {
  .nav { padding: .45rem 1rem !important; gap: .75rem !important; }
  .nav-brand img,
  .header.scrolled .nav-brand img {
    height: 40px !important; width: 40px !important; padding: 3px !important;
  }
  .nav-brand-name { font-size: 1rem !important; }
  .nav-brand::after { display: none !important; }
  .nav-mobile.open, .nav-mobile.is-open { top: 64px !important; }
}

/* ─── 8. Forms / cards / articles — reduce inner padding ─── */
@media (max-width: 600px) {
  .form-card, .contact-form-card { padding: 1.5rem !important; }
  .article-body-wrap { padding: 2rem var(--gutter) 3rem !important; }
  .article-body p, .article-body ul, .article-body ol { font-size: 1rem !important; }
  .article-hero-inner { padding-bottom: 2rem !important; }
  .article-title { font-size: clamp(1.6rem, 6vw, 2rem) !important; }
  .timeline { padding-left: 2rem !important; }
  .timeline-item::before { left: -2rem !important; width: 20px !important; height: 20px !important; }
}

/* ─── 9. Tablet 2-col fallback (currently jumps 3→1) ─── */
@media (max-width: 900px) and (min-width: 601px) {
  .news-grid, .dx-grid, .press-grid, .pillars {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .impact-grid, .feature-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ─── 10. Don-inline-form — stack on small screens ─── */
@media (max-width: 500px) {
  .don-inline-form {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .don-inline-form .btn {
    width: 100% !important;
    justify-content: center !important;
    white-space: normal !important;
  }
}

/* ─── 11. Generic safety nets ─── */
img, iframe, video { max-width: 100% !important; height: auto; }
@media (max-width: 768px) {
  pre, code { word-wrap: break-word; overflow-x: auto; max-width: 100%; }
  table:not(.no-mobile) { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  /* Prevent any element from forcing horizontal scroll */
  .container, .hero-inner, .section, section { max-width: 100vw; }
  body { overflow-x: hidden !important; }
}

/* ─── 12. Subhero — better mobile padding ─── */
@media (max-width: 600px) {
  .subhero { padding: 3.5rem 0 2.5rem !important; }
  .subhero h1 { font-size: clamp(1.8rem, 6vw, 2.4rem) !important; }
  .subhero p { font-size: 1rem !important; }
}

/* ─── 13. Footer — better stacking ─── */
@media (max-width: 600px) {
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .footer-brand { text-align: center; }
  .footer-social { justify-content: center !important; }
}

/* ─── 14. Section-head titles ─── */
@media (max-width: 600px) {
  .section-head h2 {
    font-size: clamp(1.6rem, 6vw, 2.2rem) !important;
    line-height: 1.2 !important;
  }
  .section-head p { font-size: .98rem !important; }
}

/* ─── 15. Chat window — full-screen on tiny mobile ─── */
@media (max-width: 480px) {
  #chatbot-window {
    bottom: 80px !important;
    right: 8px !important; left: 8px !important;
    width: auto !important; max-width: none !important;
    height: calc(100vh - 110px) !important; max-height: calc(100vh - 110px) !important;
    border-radius: 18px !important;
  }
}

/* ─── 16. Burger menu — works with both .open and .is-open ─── */
.burger.is-open span:nth-child(1),
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.is-open span:nth-child(2),
.burger.open span:nth-child(2) { opacity: 0; }
.burger.is-open span:nth-child(3),
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-mobile.is-open, .nav-mobile.open {
  display: block !important;
}

/* ─── 17. Modal/lightbox sizing on mobile ─── */
@media (max-width: 600px) {
  .modal, .modal-content {
    width: 95vw !important;
    max-width: 95vw !important;
    max-height: 92vh !important;
    margin: 4vh auto !important;
  }
}

/* ─── 18. Sticky header — z-index fix ─── */
.header { z-index: 100 !important; }
#chatbot-window { z-index: 99 !important; }
#float-btns { z-index: 90 !important; }
.nav-mobile { z-index: 99 !important; }

/* ─── 19. Tap highlight color uniform ─── */
* {
  -webkit-tap-highlight-color: rgba(0, 56, 99, 0.1);
}

/* ─── 20. Smooth momentum scrolling on iOS ─── */
* { -webkit-overflow-scrolling: touch; }

/* ═══════════════════════════════════════════════════════════════
   VIEWPORT-FIT GUARANTEE — last-resort safety net
   Prevents ANY element from forcing horizontal overflow on mobile
   ═══════════════════════════════════════════════════════════════ */
html, body {
  max-width: 100vw;
  overflow-x: clip;
  overflow-x: hidden; /* fallback for older browsers */
}
@supports (overflow-x: clip) {
  html, body { overflow-x: clip !important; }
}
@media (max-width: 768px) {
  /* Force every direct child of body and main containers to stay in viewport */
  body > *, .container, section, header, footer, main, nav {
    max-width: 100vw !important;
    box-sizing: border-box;
  }
  /* Hero, articles, and any wide block — stay inside */
  .hero, .subhero, .article-hero, .cta-image-band {
    max-width: 100vw !important;
    overflow-x: hidden;
  }
  /* Tables — make them scrollable rather than overflow */
  table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }
  /* Pre + code — wrap or scroll, never overflow */
  pre, code {
    max-width: 100%;
    overflow-x: auto;
    word-wrap: break-word;
  }
  /* Any embed (iframe, video, img) — never wider than viewport */
  iframe, video, embed, object {
    max-width: 100% !important;
    width: 100% !important;
    height: auto;
  }
  /* Long text URLs — wrap */
  a, p, span, div { word-wrap: break-word; overflow-wrap: break-word; }
}


/* ═══════════════════════════════════════════════════════════════
   MOBILE FIXES v2 — sticky header restore, pillars, chat window
   ═══════════════════════════════════════════════════════════════ */

/* ─── Sticky header — explicit guarantee, override any overflow:hidden parent ─── */
.header {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%;
  background: #fff;
}
@media (max-width: 600px) {
  .header { position: sticky !important; top: 0 !important; }
  /* Keep margin/padding clean on very small screens */
}

/* ─── Pillars grid: stack on mobile, override inline style ─── */
@media (max-width: 700px) {
  .pillars[style], .pillars {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
    gap: 1rem !important;
  }
  .pillar {
    padding: 2rem 1.5rem !important;
  }
}

/* ─── Chat window — consolidated mobile sizing (override conflicting rules) ─── */
@media (max-width: 600px) {
  #chatbot-window {
    bottom: 80px !important;
    right: 8px !important;
    left: 8px !important;
    width: auto !important;
    max-width: none !important;
    height: calc(100vh - 110px) !important;
    max-height: calc(100vh - 110px) !important;
    border-radius: 18px !important;
  }
  /* Ensure body of chat scrolls properly */
  .chatbot-body {
    flex: 1 1 0% !important;
    min-height: 0 !important;
    overflow-y: auto !important;
  }
  #chat-input-area {
    flex-shrink: 0 !important;
    padding: 10px 12px !important;
  }
}
@media (max-width: 380px) {
  #chatbot-window {
    bottom: 76px !important;
    right: 6px !important;
    left: 6px !important;
    border-radius: 14px !important;
  }
  .chatbot-header {
    padding: 12px 14px !important;
  }
  .chatbot-header h4 {
    font-size: 14px !important;
  }
}

/* ─── Inscription page specifically — make sure both buttons fit ─── */
.pillar a.btn,
.pillar .btn {
  width: 100%;
  justify-content: center;
}
@media (max-width: 700px) {
  .pillar h3 { font-size: 1.2rem !important; }
  .pillar p { font-size: .95rem !important; }
  .pillar a.btn, .pillar .btn { font-size: .82rem !important; padding: .8rem 1rem !important; }
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER + FLOAT-BTNS — make webget band visible
   ═══════════════════════════════════════════════════════════════ */
/* Raise float-btns higher + add bottom padding so footer credits show */
#float-btns {
  bottom: 80px !important;
  right: 28px !important;
}
/* Add bottom space so the last footer line clears the floating buttons */
.footer { padding-bottom: 60px !important; }
.footer-bottom { padding-bottom: 1rem; }

@media (max-width: 600px) {
  #float-btns {
    bottom: 100px !important;
    right: 12px !important;
  }
  .footer { padding-bottom: 120px !important; }
}

/* Chat window also raises */
#chatbot-window {
  bottom: 152px !important;
}
@media (max-width: 600px) {
  #chatbot-window {
    bottom: 168px !important;
  }
}
@media (max-width: 480px) {
  #chatbot-window {
    bottom: 160px !important;
    height: calc(100vh - 190px) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SSO PANEL — Force document file cards in dark mode (.ddv-file etc.)
   ═══════════════════════════════════════════════════════════════ */
[data-theme="dark"] .ddv-cat {
  background: var(--bg-tint) !important;
}
[data-theme="dark"] .ddv-file {
  background: var(--card) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}
[data-theme="dark"] .ddv-file:hover {
  background: var(--card-hover, var(--bg-tint)) !important;
  border-color: var(--blue) !important;
}
[data-theme="dark"] .ddv-file-name { color: var(--text) !important; }
[data-theme="dark"] .ddv-file-tech { color: var(--text-muted) !important; }
[data-theme="dark"] .ddv-cat-title { color: var(--text) !important; }
[data-theme="dark"] .ddv-cat-count {
  background: var(--bg-tint) !important;
  border-color: var(--border) !important;
  color: var(--text-secondary) !important;
}
[data-theme="dark"] .ddv-act {
  background: var(--bg-tint) !important;
  border-color: var(--border) !important;
  color: var(--text-muted) !important;
}
[data-theme="dark"] .ddv-act:hover {
  background: var(--card) !important;
  border-color: var(--blue) !important;
  color: var(--blue-light) !important;
}
[data-theme="dark"] .ddv-file-ext {
  background: var(--card) !important;
}
[data-theme="dark"] .ddv-section-count {
  background: var(--blue-50) !important;
  color: var(--blue-light) !important;
}
[data-theme="dark"] .ddv-section-title { color: var(--text) !important; }
[data-theme="dark"] .ddv-empty {
  background: var(--bg-tint) !important;
  color: var(--text-muted) !important;
}
[data-theme="dark"] .ddv-info-block {
  background: var(--bg-tint) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .ddv-info-block-label {
  color: var(--text-muted) !important;
}
[data-theme="dark"] .ddv-action-btn {
  background: var(--card) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}
[data-theme="dark"] .ddv-action-btn:hover {
  background: var(--bg-tint) !important;
  border-color: var(--blue) !important;
}
[data-theme="dark"] .ddv-action-btn.active {
  background: var(--blue-50) !important;
  color: var(--blue-light) !important;
  border-color: var(--blue) !important;
}
[data-theme="dark"] .ddv-action-btn.green {
  background: rgba(52,211,153,.12) !important;
  border-color: rgba(52,211,153,.3) !important;
  color: #6ee7b7 !important;
}
[data-theme="dark"] .ddv-action-btn.red {
  background: rgba(248,113,113,.12) !important;
  border-color: rgba(248,113,113,.3) !important;
  color: #fca5a5 !important;
}


/* ═══════════════════════════════════════════════════════════════
   NAV MOBILE — ensure header + burger stay accessible at all times
   ═══════════════════════════════════════════════════════════════ */
.nav-mobile, .nav-mobile.open, .nav-mobile.is-open {
  z-index: 90 !important;
}
.header {
  z-index: 110 !important;
  position: sticky !important;
  top: 0 !important;
}
@media (max-width: 1200px) {
  /* Burger always visible above nav-mobile */
  .burger {
    z-index: 120 !important;
    position: relative;
  }
  /* Open state: nav-mobile starts BELOW header */
  .nav-mobile.open, .nav-mobile.is-open {
    position: fixed !important;
    top: var(--header-h, 78px) !important;
    left: 0 !important; right: 0 !important; bottom: 0 !important;
    background: #fff;
    padding: 2rem var(--gutter);
    overflow-y: auto;
    display: block !important;
    animation: navMobSlide .25s cubic-bezier(.4,0,.2,1);
  }
  @keyframes navMobSlide {
    from { opacity: 0; transform: translateY(-12px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}
@media (max-width: 600px) {
  .nav-mobile.open, .nav-mobile.is-open {
    top: 64px !important;
  }
}

/* Better burger animation: visible X when open */
.burger.open span,
.burger.is-open span {
  background: var(--blue-dark) !important;
}

/* Body scroll-lock when menu open — keep header visible */
body.nav-locked { position: relative; }
body.nav-locked .header { position: sticky !important; }


/* ════════════════════════════════════════════════════════════════
   TESTIMONIALS · 3-column auto-scroll marquee (Entre Élèves)
   ════════════════════════════════════════════════════════════════ */
.tm-section{padding:var(--section) 0}
.tm-grid{
  display:flex;gap:1.5rem;justify-content:center;margin-top:3rem;
  max-height:720px;overflow:hidden;
  -webkit-mask-image:linear-gradient(to bottom,transparent 0%,#000 18%,#000 82%,transparent 100%);
          mask-image:linear-gradient(to bottom,transparent 0%,#000 18%,#000 82%,transparent 100%);
}
.tm-col{flex:1 1 0;max-width:340px;min-width:0}
.tm-col-md,.tm-col-lg{display:none}
.tm-track{
  display:flex;flex-direction:column;gap:1.25rem;
  animation:tm-scroll var(--tm-dur,30s) linear infinite;
  will-change:transform;
}
@keyframes tm-scroll{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.tm-grid:hover .tm-track{animation-play-state:paused}
.tm-card{
  background:#fff;border:1px solid var(--line);
  border-radius:24px;padding:1.75rem 1.65rem;
  box-shadow:0 8px 24px -8px rgba(0,56,99,.08);
}
.tm-text{
  color:var(--blue-dark);font-size:.97rem;line-height:1.6;
  margin:0 0 1.1rem;letter-spacing:-.005em;
}
.tm-meta{display:flex;align-items:center;gap:.7rem}
.tm-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-dark),var(--blue));
  color:#fff;font-weight:700;font-size:.78rem;
  display:flex;align-items:center;justify-content:center;letter-spacing:.02em;
}
.tm-name{font-weight:700;color:var(--blue-dark);font-size:.85rem;line-height:1.25;letter-spacing:-.005em}
.tm-role{font-size:.74rem;color:var(--text-muted);line-height:1.25;opacity:.7;margin-top:1px}
@media (min-width:768px){.tm-col-md{display:block}}
@media (min-width:1024px){.tm-col-lg{display:block}}
@media (max-width:600px){.tm-grid{max-height:560px;gap:0}}
@media (prefers-reduced-motion:reduce){.tm-track{animation:none}.tm-grid{max-height:none;mask-image:none;-webkit-mask-image:none}}

/* Photo variant + stars */
.tm-avatar.tm-avatar-img{background:none;object-fit:cover;display:block;border:2px solid rgba(187,170,94,.25)}
.tm-stars{display:flex;gap:2px;margin:0 0 .85rem;align-items:center}
.tm-stars svg{display:block}


/* ════════════════════════════════════════════════════════════════
   CHATBOT MOBILE — final cadrage (override toutes règles précédentes)
   Utilise dvh (dynamic viewport) pour la barre URL mobile
   et env(safe-area-inset-*) pour les encoches iPhone
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  #chatbot-window {
    position: fixed !important;
    bottom: calc(170px + env(safe-area-inset-bottom, 0px)) !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    max-height: calc(100dvh - 250px - env(safe-area-inset-bottom, 0px)) !important;
    border-radius: 20px !important;
  }
  #float-btns {
    bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
    right: 12px !important;
    left: auto !important;
  }
  /* Body scrollable, input fixe en bas du chat */
  .chatbot-body {
    flex: 1 1 0% !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  #chat-input-area, .chatbot-footer, .chatbot-input-area {
    flex-shrink: 0 !important;
    padding: 10px 12px !important;
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  }
}
@media (max-width: 480px) {
  #chatbot-window {
    bottom: calc(150px + env(safe-area-inset-bottom, 0px)) !important;
    left: 8px !important;
    right: 8px !important;
    border-radius: 16px !important;
    max-height: calc(100dvh - 220px - env(safe-area-inset-bottom, 0px)) !important;
  }
}
@media (max-width: 380px) {
  #chatbot-window {
    bottom: calc(140px + env(safe-area-inset-bottom, 0px)) !important;
    left: 6px !important;
    right: 6px !important;
    border-radius: 14px !important;
  }
  .chatbot-header { padding: 12px 14px !important; }
}


/* ════════════════════════════════════════════════════════════════
   MOBILE POLISH — passe globale (taille typo, paddings, debords)
   ════════════════════════════════════════════════════════════════ */

/* Évite tout débordement horizontal sur smartphone */
@media (max-width: 768px) {
  html, body { overflow-x: clip; }
  img, video, iframe { max-width: 100%; height: auto; }

  /* Conteneurs : padding latéral plus généreux */
  .container { padding-left: 1rem; padding-right: 1rem; }

  /* Section-head : titres et lead resserrés */
  .section-head h2 { font-size: clamp(1.4rem, 5vw, 2rem) !important; line-height: 1.2; }
  .section-head p { font-size: .95rem; line-height: 1.55; }

  /* Hero typographie */
  .hero h1, .amb-hero h1, .etab-hero h1 {
    font-size: clamp(1.7rem, 6.5vw, 2.4rem) !important;
    line-height: 1.1;
  }
  .hero .hero-tag,
  .amb-hero .hero-tag,
  .etab-hero .hero-tag { font-size: .98rem; line-height: 1.55; }
  .hero-actions, .amb-hero .hero-actions, .etab-hero .hero-actions {
    flex-direction: column; align-items: stretch;
  }
  .hero-actions .btn, .amb-hero .hero-actions .btn, .etab-hero .hero-actions .btn {
    width: 100%; justify-content: center;
  }

  /* Ambassadeur — perks: stack centré + suppression rotation */
  .amb-perk { transform: none !important; rotate: none !important; }
  .amb-perks { max-width: 100% !important; }

  /* Établissements — stats card adapté */
  .etab-stats-card { padding: 1.5rem 1.25rem !important; }
  .etab-stats-card h3 { font-size: .95rem !important; }
  .etab-stat-row { padding: .65rem 0 !important; gap: .65rem !important; }
  .etab-stat-ico { width: 36px !important; height: 36px !important; }

  /* Bento établissements : feat card padding réduit */
  .etab-bento-card { padding: 1.4rem 1.3rem !important; }
  .etab-bento-card.feat h3 { font-size: 1.2rem !important; }

  /* Security callout : icon + texte vertical */
  .etab-security { padding: 1.6rem 1.3rem !important; gap: 1.25rem !important; }
  .etab-security-ico { width: 52px !important; height: 52px !important; }

  /* Steps : centrés sur 1 colonne */
  .amb-steps, .etab-steps { gap: 1.5rem !important; }

  /* CTA bandeau */
  .amb-cpe, .etab-cta { padding: 2.25rem 1.4rem !important; border-radius: 18px !important; }
  .amb-cpe-text h2, .etab-cta h2 { font-size: clamp(1.4rem, 5.5vw, 1.85rem) !important; }
  .amb-cpe-inner { gap: 1.75rem !important; }
  .amb-cpe-form { padding: 1.25rem !important; }
  .etab-cta-btns { flex-direction: column !important; }
  .etab-cta-btns .btn { width: 100% !important; }

  /* Compare blocks ambassadeur */
  .amb-compare-col { padding: 1.5rem 1.25rem 1.25rem !important; }
  .amb-compare-head h3 { font-size: 1.1rem !important; }
  .amb-compare-list li { font-size: .9rem !important; }

  /* FAQ : padding réduit */
  .amb-faq-item, .etab-faq-item { padding: 1rem 1.2rem !important; }
  .amb-faq-item summary, .etab-faq-item summary { font-size: .95rem !important; }

  /* Bento row : single column si encore en 2 cols sous 768 */
  .etab-bento-row { grid-template-columns: 1fr !important; }

  /* Article hero (pages détail actualité) */
  .article-hero { min-height: 260px !important; max-height: 340px !important; height: 50vh !important; }
  .article-hero-inner { padding-bottom: 2rem !important; padding-left: 1rem !important; padding-right: 1rem !important; }
  .article-title { font-size: clamp(1.4rem, 6vw, 2rem) !important; line-height: 1.15 !important; }
  .article-body-wrap { padding: 2rem 1rem 3rem !important; }
  .article-body p, .article-body ul, .article-body ol { font-size: .98rem !important; }
  .article-body h2 { font-size: 1.25rem !important; margin: 2rem 0 .85rem !important; }
  .article-body p.lead { font-size: 1.05rem !important; margin-bottom: 1.5rem !important; }

  /* Espace card login centrée */
  .card, .form-card-modern { padding: 1.5rem 1.25rem !important; }

  /* Footer mobile : 1 colonne, plus de gap */
  .footer-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .footer-bottom { flex-direction: column !important; gap: .5rem !important; text-align: center !important; }

  /* Boutons par défaut un peu plus grands au touch */
  .btn-lg { padding: .95rem 1.4rem !important; font-size: .92rem !important; }
}

/* Très petits écrans (< 380px) */
@media (max-width: 380px) {
  .container { padding-left: .75rem; padding-right: .75rem; }
  .hero h1, .amb-hero h1, .etab-hero h1 { font-size: 1.5rem !important; }
  .section-head h2 { font-size: 1.25rem !important; }
}
