  :root{
    --navy:#03326c; --cyan:#44bdd4; --gris:#717e86; --txt:#575756;
    --vert:#2eb190; --magenta:#e50067; --orange:#f59d24;
    --cyan-d:#0c79a8;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:'Rubik',sans-serif;color:var(--txt);-webkit-font-smoothing:antialiased}

  section{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;padding:7rem 1.5rem}
  .ph{text-align:center;max-width:46rem}
  .ph .num{font-weight:700;letter-spacing:.25em;font-size:.85rem;text-transform:uppercase;display:block;margin-bottom:1rem}
  .ph h2{font-weight:800;letter-spacing:-.02em;line-height:1.1;font-size:clamp(2rem,4.6vw,3.6rem)}
  .ph .note{margin-top:1.2rem;font-size:.95rem;opacity:.55;font-weight:500}


  /* ============ Réveils au scroll ============ */
  h1,h2,h3,h4,.b366-title,.intro-366,.pull blockquote,.catch{text-wrap:balance}
  .rev{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
  .rev.in{opacity:1;transform:none}

  /* ============ HERO ============ */
  .hero{display:block;min-height:0;height:195vh;padding:0}
  .hero-stage{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;padding:7rem 1.5rem}
  .hero .hero-inner{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:68rem}
  .hero-logo,.surtitre{will-change:transform}
  .catch{opacity:0;will-change:opacity,transform}
  @media (prefers-reduced-motion:reduce){
    .hero{height:auto;min-height:100vh}
    .hero-stage{position:static;height:auto;min-height:100vh}
    .catch{opacity:1!important}
    .hero-logo,.surtitre{transform:none!important}
  }
  .hero-logo{width:clamp(150px,18vw,230px);height:auto;margin-bottom:clamp(1.8rem,4vh,3rem)}
  .surtitre{display:inline-block;font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:clamp(.8rem,1.3vw,1rem);margin-top:clamp(1.6rem,3.5vh,2.4rem);color:var(--navy);background:var(--cyan);padding:.7em 1.6em;border-radius:999px}
  .catch{font-weight:800;line-height:1.18;letter-spacing:-.02em;font-size:clamp(2.1rem,5.4vw,4.3rem);max-width:18ch;color:#fff}
  .hl{position:relative;z-index:0;white-space:nowrap}
  .hl::before{content:"";position:absolute;z-index:-1;left:.10em;right:-.18em;top:.60em;height:.5em;background:rgba(255,255,255,.18);
    transform:scaleX(0);transform-origin:left;transition:transform .8s cubic-bezier(.25,.8,.25,1)}
  body.loaded .hl::before{transform:scaleX(1)}
  .catch .hl:nth-of-type(1)::before{transition-delay:.45s}
  .catch .hl:nth-of-type(2)::before{transition-delay:.7s}
  .catch .hl:nth-of-type(3)::before{transition-delay:.95s}
  .catch .hl:nth-of-type(1)::before{background:rgba(46,177,144,.55)}
  .catch .hl:nth-of-type(2)::before{background:rgba(245,157,36,.55)}
  .catch .hl:nth-of-type(3)::before{background:rgba(229,0,103,.5)}
  .scroll-cue{position:absolute;left:50%;bottom:2.6rem;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;text-decoration:none;color:rgba(255,255,255,.9);transition:color .25s}
  .scroll-cue .label{font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase}
  body:not(.bg-dark) .scroll-cue{color:var(--navy)}
  .mouse{width:26px;height:42px;border:2px solid currentColor;border-radius:999px;position:relative;opacity:.85}
  .mouse::after{content:"";position:absolute;left:50%;top:7px;width:5px;height:5px;border-radius:50%;background:currentColor;transform:translateX(-50%);animation:drop 1.8s ease-in-out infinite}
  @keyframes drop{0%{opacity:0;top:7px}25%{opacity:1}65%{opacity:1}100%{opacity:0;top:22px}}

  /* ============ NAV ============ */
  .nav{position:fixed;top:1.2rem;right:1.2rem;z-index:60;display:flex;align-items:center;gap:.7rem}
  .pill{display:flex;align-items:center;justify-content:center;height:58px;padding:0 1.7rem;border-radius:999px;background:#fff;box-shadow:0 10px 34px rgba(3,50,108,.18);
        opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .35s,transform .35s}
  body.show-pill .pill{opacity:1;transform:none;pointer-events:auto}
  .brand img{height:32px;width:auto;display:block}
  .burger{border:none;cursor:pointer;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;
          box-shadow:0 10px 34px rgba(3,50,108,.28);transition:transform .2s;background:#fff;color:var(--navy)}
  .burger:hover{transform:scale(1.06)}
  .burger .ic{display:block;width:20px;height:3px;border-radius:3px;background:currentColor;position:relative;transition:background .2s}
  .burger .ic::before,.burger .ic::after{content:"";position:absolute;left:0;width:20px;height:3px;border-radius:3px;background:currentColor;transition:transform .25s,top .25s}
  .burger .ic::before{top:-7px}.burger .ic::after{top:7px}
  body.menu-open .burger{background:#fff !important;color:var(--navy) !important}
  body.menu-open .burger .ic{background:transparent}
  body.menu-open .burger .ic::before{top:0;transform:rotate(45deg)}
  body.menu-open .burger .ic::after{top:0;transform:rotate(-45deg)}

  /* ============ MENU OVERLAY ============ */
  .menu{position:fixed;inset:0;z-index:55;background:rgba(2,31,68,.97);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
  body.menu-open .menu{opacity:1;pointer-events:auto}
  .menu ul{list-style:none;text-align:center;display:flex;flex-direction:column;gap:clamp(.5rem,1.8vh,1.1rem)}
  .menu a{color:#fff;text-decoration:none;font-weight:700;font-size:clamp(1.3rem,3.2vh,2rem);letter-spacing:-.01em;transition:color .2s}
  .menu a:hover{color:var(--cyan)}
  .menu .num{display:inline-block;width:2ch;margin-right:.6rem;font-size:.55em;font-weight:600;color:var(--cyan);vertical-align:.35em;letter-spacing:.05em}

  /* ============ PROGRESSION ============ */
  .progress{position:fixed;left:0;right:0;bottom:0;height:6px;z-index:40;background:rgba(3,50,108,.08)}
  body.bg-dark .progress{background:rgba(255,255,255,.12)}
  .progress i{display:block;height:100%;width:0%;border-radius:0 3px 3px 0;background:var(--cyan)}

    .back-top{position:fixed;right:1.6rem;bottom:1.6rem;z-index:60;width:52px;height:52px;border:none;border-radius:50%;
    background:var(--navy);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
    box-shadow:0 10px 28px rgba(3,50,108,.34);opacity:0;visibility:hidden;transform:translateY(12px);
    transition:opacity .3s,transform .3s,background .25s}
  .back-top.show{opacity:1;visibility:visible;transform:translateY(0)}
  .back-top:hover{background:var(--cyan-d);transform:translateY(-2px)}
  @media (prefers-reduced-motion:reduce){.back-top{transition:opacity .2s}}
  footer{background:#021f44;color:rgba(255,255,255,.75);text-align:left;padding:3.5rem 1.5rem;font-size:.9rem}

  /* ╔════════ SECTION 01 — ÉDITORIAL ════════╗ */
  .edito{display:block;padding:7.5rem 1.5rem 6.5rem}
  .wrap{max-width:72rem;margin:0 auto}
  .eyebrow{display:flex;align-items:center;gap:.8rem;font-weight:700;letter-spacing:.22em;font-size:.85rem;text-transform:uppercase;color:var(--cyan);margin-bottom:1.1rem}
  .eyebrow::before{content:"";width:2.4rem;height:4px;background:currentColor;flex:none}
  .edito h2{font-weight:800;letter-spacing:-.02em;line-height:1.12;font-size:clamp(1.9rem,3.8vw,3.1rem);color:var(--cyan)}
  .hl2{position:relative;z-index:0;white-space:nowrap}
  .hl2::before{content:"";position:absolute;z-index:-1;left:.10em;right:-.18em;top:.60em;height:.5em;background:rgba(68,189,212,.25);
    transform:scaleX(0);transform-origin:left;transition:transform .7s cubic-bezier(.25,.8,.25,1) .3s}
  .rev.in .hl2::before,.rev.in .hl2::before{transform:scaleX(1)}
  h2.rev.in .hl2::before{transform:scaleX(1)}
  .edito h3{font-weight:800;letter-spacing:-.015em;line-height:1.15;font-size:clamp(1.5rem,2.9vw,2.3rem);color:var(--navy)}
  .edito p{line-height:1.75;color:var(--navy);font-weight:500}

  /* ── Bloc 1 : texte + illustration sticky ── */
  .intro-zone{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;margin-top:2rem}
  .edito .lead{font-size:clamp(1.02rem,1.5vw,1.2rem);line-height:1.7;color:var(--navy);font-weight:500}
  .edito .lead b{color:var(--navy);font-weight:800}
  .dashlist{list-style:none;margin:1.4rem 0 0}
  .dashlist li{position:relative;padding-left:1.9rem;margin-bottom:.4rem;font-weight:500;color:var(--navy);font-size:1.02rem;line-height:1.45}
  .dashlist li b{font-weight:800}
  .dashlist li::before{content:"";position:absolute;left:0;top:.66em;width:1.05rem;height:2px;background:var(--cyan)}
  .illu-col{align-self:center;margin-top:-3.5rem}
  .illu-col img{width:100%;height:auto;display:block}

  /* ── Bloc 2 : citation libre + grande vidéo ── */
  .pull{margin:8.5rem auto 5rem;position:relative;max-width:90%;text-align:center}
  .pull blockquote{position:relative;font-weight:800;font-size:clamp(1.45rem,3vw,2.3rem);line-height:1.4;letter-spacing:-.015em;margin:0;
    background:linear-gradient(90deg,var(--cyan) 0%,var(--cyan) 30%,var(--navy) 70%,var(--navy) 100%);
    background-size:300% 100%;background-position:100% 0;
    -webkit-background-clip:text;background-clip:text;color:transparent}
  .pull .qm{position:absolute;font-size:6rem;font-weight:800;color:var(--cyan);opacity:.55;line-height:1;font-family:Georgia,serif;pointer-events:none}
  .pull .qm.a{left:-1.2rem;top:-2.6rem}
  .pull .qm.b{right:-1.2rem;bottom:-3.4rem;transform:rotate(180deg)}
  .video-wrap{max-width:56rem;margin:0 auto}
  .video{position:relative;aspect-ratio:16/9;border-radius:26px;overflow:hidden;box-shadow:0 22px 50px rgba(3,50,108,.20);background:#03326c;cursor:pointer}
  .video img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
  .video .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.94);color:var(--navy);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(2,21,48,.35)}
  .video-cap{margin-top:.9rem;font-size:.85rem;color:var(--navy);opacity:.7;font-weight:500;text-align:center}

  /* ── Bloc 3 : 366 + triptyque resserré ── */
  .bloc3{margin-top:6.5rem;padding:0 clamp(0rem,6vw,5rem)}
  .edito .b366-title{font-weight:800;letter-spacing:-.02em;color:var(--navy);font-size:clamp(1.5rem,2.9vw,2.3rem);text-align:center;line-height:1.2}
  .b366-title b{font-weight:800}
  .intro-366{font-size:clamp(1.02rem,1.5vw,1.2rem);line-height:1.7;color:var(--navy);font-weight:500;text-align:center;max-width:46rem;margin:.5rem auto 0}
  .intro-366 b{color:var(--navy);font-weight:800}
  .tri{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.2rem}
  .tri article{background:#fff;border-radius:22px;padding:1.7rem 1.6rem;line-height:1.55;transition:transform .3s ease,box-shadow .3s ease}
  .tri h4{font-size:1.15rem;font-weight:800;position:relative;padding-bottom:.95rem;margin-bottom:1.15rem}
  .tri h4::after{content:"";position:absolute;left:0;bottom:0;width:2.3rem;height:2px;background:currentColor}
  .tri p{font-size:.98rem;font-weight:600;color:var(--navy)}
  .t-tot h4{color:var(--vert)}
  .t-pres h4{color:#e08a06}
  .t-eff h4{color:var(--magenta)}
  .tri article{box-shadow:0 10px 30px rgba(3,50,108,.08)}
  .tri article:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 16px 38px rgba(3,50,108,.13)}

  /* ── Bloc 4 : édito 2 colonnes ── */
  .letter2{margin-top:6.5rem}
  .lcols{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 3.2rem}

  .lcols p{margin-bottom:1.15em;font-size:1.01rem}
  .sign{display:flex;gap:1.2rem 2.6rem;margin-top:2rem;flex-wrap:wrap}
  .sig-card{display:flex;align-items:center;gap:1rem}
  .sig-card .av{display:block;padding:3px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--navy));box-shadow:0 6px 18px rgba(3,50,108,.18)}
  .sig-card img{width:62px;height:62px;border-radius:50%;display:block;border:3px solid #fff}
  .sig-card .ph-avatar{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid #fff;background:#d9f0f7;color:var(--cyan-d);font-weight:800;font-size:1.25rem;letter-spacing:.02em}
  .sig-card b{display:block;color:var(--navy);font-weight:800;font-size:1.05rem;line-height:1.25}
  .sig-card span{display:block;font-size:.85rem;color:var(--cyan-d);font-weight:700}

  @media (max-width:1023px){
    .intro-zone{grid-template-columns:1fr;gap:2rem}
    .illu-col{position:static;max-width:24rem;margin:0 auto}
    .tri{grid-template-columns:1fr}
    .bloc3{padding:0}
    .lcols{grid-template-columns:1fr;gap:0}

  }


  /* ╔════════ SECTION 02 — RÉTRO 2025 ════════╗ */
  .retro{display:block;padding:7.5rem 1.5rem 6.5rem}
  .retro .eyebrow{color:var(--navy)}
  .retro h2{font-weight:800;letter-spacing:-.02em;line-height:1.12;font-size:clamp(1.9rem,3.8vw,3.1rem);color:var(--navy)}
  .retro .lead{margin-top:1.4rem;font-size:clamp(1.02rem,1.5vw,1.2rem);line-height:1.7;color:var(--navy);font-weight:500;max-width:62ch}
  .retro h3{font-weight:800;letter-spacing:-.015em;line-height:1.15;font-size:clamp(1.4rem,2.6vw,2rem);color:var(--navy)}
  .retro p{line-height:1.75;color:var(--navy);font-weight:500}

  .reperes-intro{margin-top:3.5rem;font-weight:700;color:var(--navy);font-size:1.05rem}

  /* mur de chiffres */
  .stats-hero{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:1.6rem}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;margin-top:1.3rem}
  .stat{background:#fff;border-radius:22px;padding:1.5rem 1.4rem;box-shadow:0 10px 30px rgba(3,50,108,.07);transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;gap:.35rem}
  .stat:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 38px rgba(3,50,108,.12)}
  .stat .n{font-weight:800;letter-spacing:-.02em;line-height:1;font-size:clamp(1.9rem,3.4vw,2.9rem);font-variant-numeric:tabular-nums}
  .stats-hero .stat .n{font-size:clamp(2.4rem,4.4vw,3.8rem)}
  .stat .l{font-weight:700;color:var(--navy);line-height:1.35;font-size:.96rem}
  .stat .badge{align-self:flex-start;margin-top:.3rem;font-size:.74rem;font-weight:800;letter-spacing:.02em;padding:.32em .8em;border-radius:999px}
  .c-cyan .n{color:var(--cyan-d)}   .c-cyan .badge{background:#dcf2f8;color:var(--cyan-d)}
  .c-vert .n{color:var(--vert)}     .c-vert .badge{background:#d9f3ea;color:#1d8a6f}
  .c-orange .n{color:#e08a06}       .c-orange .badge{background:#fdecd0;color:#c97a0a}
  .c-magenta .n{color:var(--magenta)} .c-magenta .badge{background:#fbdcea;color:#c2055a}
  .c-navy .n{color:var(--navy)}     .c-navy .badge{background:#e2e9f3;color:var(--navy)}
  .s-dark{background:var(--navy)}
  .s-dark .n{color:#fff} .s-dark .l{color:#fff}

  .stats-after{margin:3.2rem auto 0;text-align:center;text-wrap:balance;font-weight:600;color:var(--navy);font-size:clamp(.98rem,1.35vw,1.12rem);line-height:1.65;max-width:48rem}

  /* consolidation */
  .conso{margin-top:5.5rem;display:grid;grid-template-columns:4fr 6fr;gap:2rem;align-items:start;max-width:80%;margin-left:auto;margin-right:auto}
  .conso-title{font-size:clamp(1.7rem,3.2vw,2.6rem)!important;line-height:1.15}
  .picolist{list-style:none}
  .picolist li{display:flex;gap:1.1rem;align-items:flex-start;margin-bottom:1.3rem}
  .picolist .pico{flex:none;width:46px;height:46px;border-radius:50%;background:var(--cyan);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(68,189,212,.35)}
  .picolist p{margin:0;line-height:1.6;font-size:1rem}
  .picolist b{font-weight:800;color:var(--cyan-d)}
  .conso-after{margin:3.5rem auto 0;text-align:center;text-wrap:balance;font-weight:700;color:var(--navy);font-size:clamp(1.05rem,1.7vw,1.3rem);line-height:1.6;max-width:52rem;position:relative;padding-top:1.6rem}
  .conso-after::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:2.6rem;height:4px;border-radius:2px;background:var(--cyan)}

  /* certification */
  .certif{margin-top:5.5rem;background:#ddf0f8;border-radius:26px;box-shadow:0 14px 40px rgba(3,50,108,.09);padding:clamp(1.8rem,4vw,3rem)}
  .certif-head{display:flex;align-items:center;gap:1.1rem;margin-bottom:1.2rem;flex-wrap:wrap}
  .certif-head h3{margin:0;flex:1;min-width:16rem}
  .certif-ico{flex:none;width:56px;height:56px;border-radius:50%;background:var(--cyan);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(68,189,212,.4)}
  .afnor{flex:none;background:#fff;border-radius:14px;padding:.7rem 1.1rem;font-weight:800;color:var(--navy);font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;line-height:1.3;text-align:center;box-shadow:0 6px 18px rgba(3,50,108,.10)}
  .afnor b{display:block;color:var(--cyan-d);font-size:.74rem;letter-spacing:.12em}

  .certif > p{max-width:72ch}
  .tiroir{margin-top:1.6rem;border-top:2px solid rgba(3,50,108,.10);padding-top:1.2rem}
  .tiroir button{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;background:none;border:none;cursor:pointer;font-family:'Rubik';font-size:1.02rem;font-weight:800;color:var(--cyan-d);text-align:left;padding:.2rem 0}
  .tiroir button .chev{flex:none;width:34px;height:34px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;transition:transform .3s}
  .tiroir button .chev svg{display:block}
  .tiroir.open button .chev{transform:rotate(180deg)}
  .tiroir .panel{max-height:0;overflow:hidden;transition:max-height .35s ease}
  .tiroir.open .panel{max-height:30rem}
  .tiroir .panel p{padding:1rem 0 .4rem;opacity:.85}

  /* temps forts */
  .tforts{margin-top:5.5rem}
  .tf-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem;margin-top:1.8rem}
  .tf{background:#fff;border-radius:22px;padding:1.4rem 1.3rem;box-shadow:0 10px 30px rgba(3,50,108,.07);transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;gap:.4rem}
  .tf:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 16px 38px rgba(3,50,108,.12)}
  .tf .n{font-weight:800;line-height:1;font-size:clamp(2rem,3vw,2.7rem);font-variant-numeric:tabular-nums}
  .tf .l{font-weight:800;color:var(--navy);line-height:1.3;font-size:.95rem}
  .tf .d{font-weight:500;color:var(--navy);opacity:.75;font-size:.83rem;line-height:1.45}

  /* temps forts : rail dans le colonage, scroll libre sans flèches */
  .tf-rail{display:flex;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
    margin-top:1.8rem;padding-bottom:1.4rem;scrollbar-width:thin;scrollbar-color:rgba(3,50,108,.22) transparent}
  .tf-rail::-webkit-scrollbar{height:6px}
  .tf-rail::-webkit-scrollbar-thumb{background:rgba(3,50,108,.22);border-radius:3px}
  .tf-rail .tf{flex:0 0 clamp(248px,30%,300px);scroll-snap-align:start;padding:1.7rem 1.6rem}
  .tf-rail .tf .l,.tf-rail .tf .d{color:#fff}
  .tf-rail .tf .n{color:#fff!important}
  .tf-rail .tf.c-cyan{background:var(--cyan)}
  .tf-rail .tf.c-vert{background:var(--vert)}
  .tf-rail .tf.c-orange{background:var(--orange)}
  .tf-rail .tf.c-magenta{background:var(--magenta)}
  .tf-rail .tf.c-navy{background:var(--navy)}
  .tf-rail .tf .d{opacity:.92}
  .tf-rail .tf .n{font-size:clamp(2.3rem,3.2vw,3rem)}
  @media (prefers-reduced-motion:reduce){.tf-rail{scroll-behavior:auto}}

  @media (max-width:1099px){
    .stats-grid{grid-template-columns:repeat(2,1fr)}
    .tf-grid{grid-template-columns:repeat(2,1fr)}
    .camps{grid-template-columns:1fr}
  }
  @media (max-width:1023px){
    .stats-hero{grid-template-columns:1fr 1fr}
    .conso{grid-template-columns:1fr;gap:1.6rem}
  }
  @media (max-width:560px){
    .stats-hero,.stats-grid,.tf-grid{grid-template-columns:1fr}
  }


  /* bandes photos rétro */
  .photobands{margin-top:5.5rem;overflow:hidden;padding:3.5rem 0 1.5rem}
  .pb-solo{margin:4.5rem 0 4rem;padding:2.2rem 0;width:100vw;margin-left:calc(50% - 50vw)}
  .pb3{transform:rotate(-2.4deg)}
  .pband{width:130vw;margin-left:-15vw;will-change:transform}
  .pb1{transform:rotate(-3deg)}
  .pb2{transform:rotate(2.4deg);margin-top:1.6rem}
  .ptrack{display:flex;gap:1.1rem;align-items:center}
  .ptrack img{height:clamp(120px,16vw,200px);width:auto;border-radius:18px;box-shadow:0 14px 34px rgba(3,50,108,.16);flex:none}

  /* ╔════════ SECTION 03 — AGIR PLUS TÔT ════════╗ */
  .s3{display:block;padding:7.5rem 1.5rem 6.5rem}
  .s3 .eyebrow{color:var(--vert);justify-content:center}
  .s3 h2{font-weight:800;letter-spacing:-.02em;line-height:1.12;font-size:clamp(1.9rem,3.8vw,3.1rem);color:var(--vert);text-align:center}
  .s3 .hl2::before{background:rgba(46,177,144,.22)}
  .s3 h3{font-weight:800;letter-spacing:-.015em;line-height:1.15;font-size:clamp(1.7rem,3.2vw,2.6rem);color:var(--navy)}
  .s3 .outils-title{font-size:clamp(1.25rem,2.2vw,1.7rem)}
  .s3 h4{font-weight:800;color:var(--navy);font-size:1.12rem}
  .s3 p{line-height:1.75;color:var(--navy);font-weight:500}
  .s3 .lead{margin-top:1.4rem;font-size:clamp(1.02rem,1.5vw,1.2rem);line-height:1.7;max-width:62ch}
  .s3 .lead b,.s3 p b{font-weight:800}
  .s3 .dashlist li::before{background:var(--vert)}
  .s3 .picolist .pico{background:var(--vert);box-shadow:0 8px 20px rgba(46,177,144,.35)}
  .s3 .picolist b{color:#1d8a6f}

  .s3-blk{margin-top:7.5rem}
  .deploy-head{display:grid;grid-template-columns:2fr 3fr;gap:3rem;align-items:center;margin-bottom:.5rem}
  .deploy-head h3{font-size:clamp(1.55rem,2.6vw,2.15rem)}
  .deploy-head .lead{margin-top:0;font-size:clamp(.96rem,1.25vw,1.08rem);max-width:none}
  .struct-grid{display:grid;grid-template-columns:7fr 5fr;gap:3rem;align-items:center}
  .exergue-stat{background:#fff;border-radius:26px;box-shadow:0 14px 40px rgba(3,50,108,.10);padding:clamp(1.8rem,3vw,2.6rem);display:flex;flex-direction:column;gap:.5rem;text-align:center;align-items:center}
  .exergue-stat .ico{width:56px;height:56px;border-radius:50%;background:var(--vert);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(46,177,144,.4);margin-bottom:.4rem}
  .exergue-stat .n{font-weight:800;letter-spacing:-.02em;line-height:1;font-size:clamp(3rem,5.5vw,4.6rem);color:var(--vert);font-variant-numeric:tabular-nums}
  .exergue-stat .l{font-weight:800;color:var(--navy);line-height:1.35;font-size:clamp(1.15rem,1.8vw,1.4rem);text-wrap:balance}
  .exergue-stat .s{font-weight:600;color:var(--navy);opacity:.7;font-size:.92rem}
  .exergue-stat .badge{margin-top:.5rem;font-size:.8rem;font-weight:800;padding:.45em 1em;border-radius:999px;background:#d9f3ea;color:#1d8a6f}
  .outils-title{margin-top:6rem;text-align:center;text-wrap:balance;max-width:46rem;margin-left:auto;margin-right:auto}

  /* deux outils : DUERP + fiche entreprise */
  .outils{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:1.6rem;align-items:stretch}
  .outil{background:#fff;border-radius:26px;box-shadow:0 12px 36px rgba(3,50,108,.08);padding:clamp(1.6rem,3vw,2.4rem);display:flex;flex-direction:column}
  .outil .deco{flex:1;display:flex;align-items:center;justify-content:center;padding:1.4rem 0 .6rem;color:#bfe9da}
  .outil .tiroir{margin-top:auto}
  .outil h4{position:relative;padding-bottom:.95rem;margin-bottom:1.1rem;color:var(--vert)}
  .outil h4::after{content:"";position:absolute;left:0;bottom:0;width:2.3rem;height:2px;background:currentColor}
  .outil h4 .big{display:block;font-size:1.6rem;letter-spacing:-.01em}
  .outil h4 .sub{display:block;margin-top:.3rem;font-size:1.02rem;color:var(--navy);font-weight:800;line-height:1.35}
  .outil p{font-size:.99rem;margin-bottom:.9rem}
  .chips{display:flex;gap:1rem;flex-wrap:wrap;margin:1.2rem 0}
  .chip{background:#e4f6f0;border-radius:16px;padding:.9rem 1.2rem;min-width:9rem}
  .chip .pre{display:block;font-size:.75rem;font-weight:700;color:var(--navy);opacity:.55;text-transform:uppercase;letter-spacing:.06em}
  .chip .n{display:block;font-weight:800;font-size:1.7rem;color:var(--vert);line-height:1.1;font-variant-numeric:tabular-nums}
  .chip .l{font-weight:700;color:var(--navy);font-size:.85rem;line-height:1.3}
  .temoin{margin-top:1.2rem;border-left:4px solid var(--vert);padding:.4rem 0 .4rem 1.1rem;font-style:italic;color:var(--navy);opacity:.75;font-weight:500}

  /* campagnes */
  .camps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:1.6rem;align-items:stretch}
  .camp.flip{position:relative;height:24rem;perspective:1400px;background:none;box-shadow:none;cursor:pointer;outline-offset:4px}
  .flip-inner{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.35,.9,.3,1)}
  .camp.flip:hover .flip-inner,.camp.flip.flipped .flip-inner,.camp.flip:focus-visible .flip-inner{transform:rotateY(180deg)}
  .face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;background:#fff;border-radius:26px;box-shadow:0 12px 36px rgba(3,50,108,.10);overflow:hidden;display:flex;flex-direction:column}
  .face.front{align-items:center;justify-content:center;text-align:center;gap:1rem;padding:1.6rem}
  .face.front h4{color:var(--vert);font-size:1.35rem;line-height:1.25;margin:0}
  .face.front h4 small{display:block;margin-top:.3rem;font-size:.85rem;color:var(--navy);font-weight:700}
  .face.back{transform:rotateY(180deg);align-items:flex-start;justify-content:center;text-align:left;padding:clamp(1.4rem,2.2vw,2rem)}
  .face.back h5{font-weight:800;color:var(--navy);font-size:.98rem;margin:0 0 .5rem}
  .face.back h5 + .dashlist{margin-bottom:1.1rem}
  .face.back .dashlist{margin:0}
  .face.back .dashlist li{font-size:.93rem;margin-bottom:.4rem}
  .camp-illu{width:100%;display:flex;align-items:center;justify-content:center}
  .camp-illu img{width:74%;max-width:260px;height:auto}
  .flip-cue{position:absolute;bottom:1.1rem;right:1.1rem;width:34px;height:34px;border-radius:50%;background:#e4f6f0;color:var(--vert);display:flex;align-items:center;justify-content:center}
  @media (prefers-reduced-motion:reduce){
    .flip-inner{transition:none}
  }
  .media-ph{position:relative;aspect-ratio:16/9;border-radius:16px;background:repeating-linear-gradient(45deg,#e4f6f0,#e4f6f0 14px,#d8f1e8 14px,#d8f1e8 28px);display:flex;align-items:center;justify-content:center}
  .media-ph .play{width:58px;height:58px;border-radius:50%;background:#fff;color:var(--vert);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(3,50,108,.15)}


  .btp-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:.6rem}
  .btp-cols h5{font-weight:800;color:var(--navy);font-size:1rem;margin-bottom:.7rem}

  /* focus BTP */
  .focus-btp{margin-top:0;background:var(--vert);border-radius:26px;padding:clamp(1.8rem,4vw,3rem);box-shadow:0 14px 40px rgba(46,177,144,.30)}
  .focus-btp h4,.focus-btp p,.focus-btp .dashlist li{color:#fff}
  .focus-btp .dashlist li::before{background:#fff}
  .fb-ico{background:#fff!important;box-shadow:0 8px 22px rgba(2,40,30,.25)!important}
  .focus-btp h4{font-size:clamp(1.3rem,2.2vw,1.7rem);color:#fff;margin:0;flex:1}
  .focus-btp .certif-head{margin-bottom:1rem}
  .fb-ico{flex:none;width:56px;height:56px;border-radius:50%;background:var(--vert);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(46,177,144,.4)}
  .focus-btp p{font-size:.99rem}
  .focus-btp .dashlist{margin:1.4rem 0 0;border-left:3px solid #fff;padding-left:1.4rem}
  .focus-btp .dashlist li{font-size:.97rem;font-weight:500;padding-left:0;margin-bottom:.7rem}
  .focus-btp .dashlist li::before{display:none}
  .s3 .cfa-title{color:var(--vert);font-size:clamp(1.25rem,2.2vw,1.7rem);font-weight:800;line-height:1.2;margin-bottom:1rem}
  .cfa-zone{margin:6rem auto 0;width:80%;display:grid;grid-template-columns:6fr 6fr;gap:3rem;align-items:center}
  .cfa-zone .cfa{font-weight:600;font-size:clamp(.98rem,1.4vw,1.1rem);line-height:1.7}
  .cfa-zone .media-ph{border-radius:22px;box-shadow:0 16px 40px rgba(3,50,108,.12)}

  /* culture prévention */
  .culture-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem 3.5rem;align-items:start;margin-top:2rem}
  .culture-left .lead{margin-top:0}
  .objectif-panel{margin:5rem auto 0;width:80%;background:#d2f0e3;border-radius:26px;padding:clamp(2rem,4vw,3rem);text-align:center;box-shadow:0 14px 40px rgba(3,50,108,.07)}
  .objectif2{text-wrap:balance;font-weight:600;color:var(--navy);font-size:clamp(1.05rem,1.7vw,1.3rem);line-height:1.6;max-width:46rem;margin:0 auto}
  .objectif2 b{font-weight:800}
  .objectif-panel .tiroir{border-top:0;padding-top:0;margin-top:1.6rem}
  .objectif-panel .tiroir button{justify-content:center}
  .objectif-panel .btn-pill{display:inline-flex;align-items:center;gap:.8rem;background:#fff;border-radius:999px;padding:.8rem 1.6rem;box-shadow:0 8px 24px rgba(3,50,108,.10);transition:transform .25s}
  .objectif-panel .tiroir button:hover .btn-pill{transform:translateY(-2px)}
  .objectif-panel .panel p{max-width:52rem;margin:0 auto}

  /* agir concrètement */
  .concret{margin-top:2.4rem;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
  .s3 .rencontre-title{color:var(--navy);font-size:clamp(1.25rem,2.2vw,1.7rem);font-weight:800;line-height:1.2;margin-bottom:1.1rem}
  .temoin2{margin:4.5rem auto 0;max-width:44rem;text-align:center;position:relative;padding-top:1.6rem}
  .temoin2::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:2.6rem;height:4px;border-radius:2px;background:var(--vert)}
  .temoin2 blockquote{font-style:italic;font-weight:600;color:var(--navy);line-height:1.65;font-size:clamp(1.08rem,1.7vw,1.3rem);margin:0;text-wrap:balance}
  .temoin2 figcaption{margin-top:1.1rem}
  .temoin2 figcaption b{display:block;color:var(--navy);font-weight:800;font-size:1rem}
  .temoin2 figcaption span{font-size:.85rem;color:#1d8a6f;font-weight:700}
  .pull .pq{position:relative}
  .concret h3{margin-bottom:1.3rem}
  .pull figcaption{margin-top:1.6rem;font-style:normal}
  .pull figcaption b{display:block;color:var(--navy);font-weight:800;font-size:1rem}
  .pull figcaption span{font-size:.85rem;color:#1d8a6f;font-weight:700}

  .s3 .pull{margin:6.5rem auto 1.5rem}
  .s3 .pull blockquote{background:linear-gradient(90deg,var(--vert) 0%,var(--vert) 30%,var(--navy) 70%,var(--navy) 100%);background-size:300% 100%;background-position:100% 0;-webkit-background-clip:text;background-clip:text}
  .s3 .pull .qm{color:var(--vert)}
  .s3 .tiroir button{color:#1d8a6f}
  .s3 .tiroir button .chev{background:#e4f6f0}
  .s3 .tiroir{border-top-color:rgba(46,177,144,.25)}

  /* ╔════════ SECTION 04 — AGIR PLUS PRÈS ════════╗ */
  .s4 .eyebrow,.s4 h2{color:#e58a00}
  .s4 .hl2::before{background:rgba(245,157,36,.26)}
  .s4 .dashlist li::before{background:var(--orange)}
  .s4 .exergue-stat .ico{background:var(--orange);box-shadow:0 8px 22px rgba(245,157,36,.4)}
  .s4 .exergue-stat .n{color:#e58a00}
  .s4 .exergue-stat .badge{background:#fdeed3;color:#b06a05}
  .s4 .chip{background:#fff;box-shadow:0 8px 22px rgba(3,50,108,.06)}
  .s4 .chip .n{color:#e58a00}
  .s4 .tiroir button{color:#b06a05}
  .s4 .tiroir button .chev{background:#fdeed3}
  .s4 .tiroir{border-top-color:rgba(245,157,36,.30)}
  .s4 .media-ph{background:repeating-linear-gradient(45deg,#fdeed3,#fdeed3 14px,#fbe4c4 14px,#fbe4c4 28px)}
  .s4 .media-ph .play{color:#e58a00}
  .s4 .objectif-panel{background:#fce6c0}
  .s4 .focus-btp{background:var(--orange);box-shadow:0 14px 40px rgba(245,157,36,.30)}
  .s4 .fb-ico{box-shadow:0 8px 22px rgba(120,70,5,.22)!important}
  .s4 .cfa-title,.s4 .rencontre-title{color:#e58a00}
  .s4 .pull blockquote{background:linear-gradient(90deg,#e58a00 0%,#e58a00 30%,var(--navy) 70%,var(--navy) 100%);background-size:300% 100%;background-position:100% 0;-webkit-background-clip:text;background-clip:text}
  .s4 .pull .qm{color:var(--orange)}
  .s4 .picolist .pico{background:var(--orange);box-shadow:0 8px 20px rgba(245,157,36,.35)}
  .s4 .picolist b{color:#b06a05}

  .dims{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.2rem}
  .dim{border-radius:26px;box-shadow:0 14px 38px rgba(245,157,36,.22);padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start;color:#fff}
  .dim.d1{background:#b06a05}.dim.d2{background:#e58a00}.dim.d3{background:var(--orange)}
  .dim .pico{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}
  .dim h4{color:#fff;font-size:1.12rem;line-height:1.3;margin:0;font-weight:800}
  .dim p{font-size:.99rem;margin:0;color:rgba(255,255,255,.95);font-weight:600}

  .stat-band{margin-top:2.6rem;background:#fff;border-radius:26px;box-shadow:0 14px 40px rgba(3,50,108,.10);padding:clamp(1.6rem,3vw,2.4rem) clamp(1.8rem,3.5vw,3rem);display:grid;grid-template-columns:auto 1fr;gap:2.4rem;align-items:center}
  .stat-band .big{font-weight:800;font-size:clamp(3rem,5.5vw,4.6rem);color:#e58a00;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
  .stat-band p{margin:0;font-size:clamp(1rem,1.5vw,1.18rem);font-weight:600}
  .stat-band p b{font-weight:800}

  .centres-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.4rem}
  .travaux{display:grid;grid-template-columns:7fr 5fr;gap:3rem;align-items:center;margin-top:4.5rem}
  .photos4{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .photos4 .ph-img{aspect-ratio:4/3;border-radius:16px;background:repeating-linear-gradient(45deg,#fdeed3,#fdeed3 14px,#fbe4c4 14px,#fbe4c4 28px);box-shadow:0 10px 26px rgba(3,50,108,.08)}

  .encart{margin-top:2.2rem;background:#fff;border-left:6px solid var(--orange);border-radius:14px;padding:1.2rem 1.6rem;box-shadow:0 10px 28px rgba(3,50,108,.07)}
  .encart p{margin:0;font-size:1rem}

  .vis2{columns:2;column-gap:3rem}
  .vis2 li{break-inside:avoid}
  .tiroir .panel .dashlist{padding:1rem 0 .6rem;margin-top:0}

  .secteurs{margin:3.2rem auto 0;width:100%;max-width:72rem}
  .secteurs figcaption{margin-bottom:.4rem}
  .secteurs .sect-title{display:block;color:var(--navy);font-size:clamp(1.3rem,2.1vw,1.7rem);font-weight:800;line-height:1.2}
  .secteurs .sect-sub{display:block;font-weight:600;color:var(--navy);opacity:.7;margin-top:.25rem;font-size:1.02rem}
    .s4 .chips-stack{display:flex;flex-direction:column;gap:.9rem}
  .s4 .chips-stack .chip{width:100%}
  .s4 .chips-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
  .s4 .chips-row .chip{width:auto}
  .s4 .band187{margin-top:2.8rem;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.4rem 1.4rem;text-align:center;padding:1.6rem 2.2rem}
  .s4 .band187 .ico{margin-bottom:0}
  .s4 .band187 .n{font-size:clamp(2.6rem,5vw,4rem)}
  .s4 .band187 .l{font-size:1.05rem}
  @media (max-width:1023px){.s4 .band187{flex-direction:column}}
  .sect-bubbles{display:block;width:100%;max-width:none;height:auto;margin:1.4rem auto 0;overflow:visible}
  .sect-bubbles .sbub{opacity:0;transform-box:fill-box;transform-origin:center;transform:scale(.4)}
  .rev.in .sect-bubbles .sbub{animation:bubIn .6s cubic-bezier(.34,1.4,.5,1) forwards;animation-delay:var(--d)}
  .sect-bubbles .slbl{opacity:0}
  .rev.in .sect-bubbles .slbl{animation:lblIn .5s ease forwards;animation-delay:.5s}
  @keyframes bubIn{to{opacity:1;transform:scale(1)}}
  @keyframes lblIn{to{opacity:1}}
  @media (prefers-reduced-motion:reduce){
    .sect-bubbles .sbub,.sect-bubbles .slbl{opacity:1!important;transform:none!important;animation:none!important}
  }
  .lien-centres{display:inline-flex;align-items:center;gap:.7rem;background:#fff;border-radius:999px;padding:.8rem 1.5rem;font-weight:800;color:#b06a05;box-shadow:0 8px 24px rgba(3,50,108,.10);text-decoration:none;transition:transform .25s}
  .lien-centres:hover{transform:translateY(-2px)}

  .pills{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem}
  .pills-center{justify-content:center}
  .pill{background:#fff;border-radius:999px;padding:.55em 1.15em;font-weight:700;font-size:.92rem;color:#b06a05;box-shadow:0 6px 18px rgba(3,50,108,.07)}

  /* ╔════════ SECTION 05 — AGIR PLUS EFFICACEMENT ════════╗ */
  .s5 .eyebrow,.s5 h2{color:var(--magenta)}
  .s5 .hl2::before{background:rgba(229,0,103,.13)}
  .s5 .dashlist li::before{background:var(--magenta)}
  .s5 .exergue-stat .ico{background:var(--magenta);box-shadow:0 8px 22px rgba(229,0,103,.35)}
  .s5 .exergue-stat .n{color:var(--magenta)}
  .s5 .exergue-stat .badge{background:#fbdce9;color:#c2055a}
  .s5 .chip{background:#fff;box-shadow:0 8px 22px rgba(3,50,108,.06)}
  .s5 .chip .n{color:var(--magenta)}
  .s5 .tiroir button{color:#c2055a}
  .s5 .tiroir button .chev{background:#fbdce9}
  .s5 .tiroir{border-top-color:rgba(229,0,103,.25)}
  .s5 .media-ph{background:repeating-linear-gradient(45deg,#fbdce9,#fbdce9 14px,#f8cfe0 14px,#f8cfe0 28px)}
  .s5 .media-ph .play{color:var(--magenta)}
  .s5 .objectif-panel{background:#f9d3e3}
  .s5 .focus-btp{background:var(--magenta);box-shadow:0 14px 40px rgba(229,0,103,.28)}
  .s5 .fb-ico{box-shadow:0 8px 22px rgba(90,0,40,.22)!important}
  .s5 .cfa-title,.s5 .rencontre-title,.s5 .outil h4{color:var(--magenta)}
  .s5 .focus-btp h5{color:#fff}
  .s5 .focus-btp .chips{margin-bottom:0}
  .s5 .focus-btp .chip{background:#fff;box-shadow:0 8px 22px rgba(90,0,40,.18)}
  .s5 .focus-btp .chip .pre{color:#fff;opacity:.8}
  .s5 .pull blockquote{background:linear-gradient(90deg,var(--magenta) 0%,var(--magenta) 30%,var(--navy) 70%,var(--navy) 100%);background-size:300% 100%;background-position:100% 0;-webkit-background-clip:text;background-clip:text}
  .s5 .pull .qm{color:var(--magenta)}

  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2.2rem}
  .step{background:#fff;border-radius:26px;box-shadow:0 12px 36px rgba(3,50,108,.08);padding:1.8rem 1.7rem}
  .step .num{width:44px;height:44px;border-radius:50%;background:var(--magenta);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:1.15rem;box-shadow:0 8px 20px rgba(229,0,103,.35);margin-bottom:1.1rem}
  .step p{font-size:.99rem;margin:0}

  .events{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2rem;align-items:stretch}
  .talk{margin-bottom:1.2rem;font-size:.96rem}
  .talk:last-child{margin-bottom:0}
  .talk .who{display:block;margin-top:.4rem;font-size:.85rem;font-weight:700;color:#c2055a}

  /* ╔════════ SECTION 06 — NOS ÉQUIPES ════════╗ */
  .s6 .eyebrow{color:var(--cyan)}
  .s6 h2{color:var(--cyan)}
  .s6 .hl2::before{background:rgba(68,189,212,.25)}
  .s6 .dashlist li::before{background:var(--cyan)}
  .s6 .exergue-stat .ico{background:var(--cyan);box-shadow:0 8px 22px rgba(68,189,212,.4)}
  .s6 .exergue-stat .n{color:var(--cyan-d)}
  .s6 .exergue-stat .badge{background:#d9f0f7;color:var(--cyan-d)}
  .s6 .chip{background:#fff;box-shadow:0 8px 22px rgba(3,50,108,.06)}
  .s6 .chip .n{color:var(--cyan-d)}
  .s6 .tiroir button{color:var(--cyan-d)}
  .s6 .tiroir button .chev{background:#d9f0f7}
  .s6 .tiroir{border-top-color:rgba(68,189,212,.35)}
  .s6 .objectif-panel{background:#d3edf5}
  .s6 .cfa-title,.s6 .rencontre-title{color:var(--cyan-d)}
  .effectifs{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:1.8rem;align-items:stretch}
  .effectifs .chip{min-width:0;display:flex;flex-direction:column;align-items:center;text-align:center}
  .portraits{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.2rem}
  .portrait{aspect-ratio:3/4;border-radius:20px;background:repeating-linear-gradient(45deg,#d9f0f7,#d9f0f7 14px,#cdeaf3 14px,#cdeaf3 28px);box-shadow:0 12px 30px rgba(3,50,108,.10);display:flex;align-items:flex-end;justify-content:center;padding:1rem}
  .portrait span{font-weight:700;font-size:.85rem;color:var(--cyan-d);background:#fff;border-radius:999px;padding:.4em 1em;box-shadow:0 6px 16px rgba(3,50,108,.10)}

  /* ╔════════ SECTION 07 — POUR DEMAIN ════════╗ */
  .s7 .eyebrow{color:var(--navy)}
  .s7 h2{color:var(--navy)}
  .s7 .hl2::before{background:rgba(3,50,108,.10)}
  .s7 .dashlist li::before{background:var(--navy)}
  .s7 .tiroir button{color:var(--navy)}
  .s7 .tiroir button .chev{background:#dde5f1}
  .s7 .tiroir{border-top-color:rgba(3,50,108,.18)}
  .s7 .objectif-panel{background:#dbe3f2}
  .s7 .outil h4{color:var(--navy)}
  .enjeu-large{margin-top:2.2rem}
  .enjeu-large .btp-cols{margin-top:1rem}
  .enjeux2{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:1.4rem;align-items:stretch}

  /* ╔════════ SECTION 08 — CONCLUSION (dark) ════════╗ */
  .s8{display:block;padding:8.5rem 1.5rem 7.5rem;color:#fff}
  .s8 .eyebrow{color:var(--cyan);justify-content:center}
  .s8 h2{font-weight:800;color:#fff;text-align:center;font-size:var(--fs-h2);letter-spacing:-.02em;line-height:1.18;max-width:56rem;margin:0 auto}
  .s8 .hl:nth-of-type(1)::before{background:rgba(46,177,144,.55)}
  .s8 .hl:nth-of-type(2)::before{background:rgba(245,157,36,.55)}
  .s8 .hl:nth-of-type(3)::before{background:rgba(229,0,103,.5)}
  .s8 p{color:rgba(255,255,255,.92);font-weight:500;line-height:1.78}
  .s8 .lead{font-size:clamp(1.05rem,1.6vw,1.25rem)}
  .s8 .lead b,.s8 p b{font-weight:800;color:#fff}
  .missions{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin:2.2rem auto 0;max-width:64rem}
  .mission{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:26px;padding:1.8rem 1.6rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
  .mission .pico{flex:none;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center}
  .mission p{margin:0;font-weight:700;color:#fff;line-height:1.5}
  .s8 .final{margin:5.5rem auto 0;text-align:center;font-weight:800;font-size:clamp(1.35rem,2.7vw,2.1rem);line-height:1.5;letter-spacing:-.015em;color:#fff;max-width:54rem;text-wrap:balance}

  /* ╔════════ FOOTER ════════╗ */
  footer .foot-wrap{max-width:72rem;margin:0 auto;text-align:left}
  .foot-top{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
  .foot-id{display:flex;align-items:center;gap:1.1rem}
  .foot-logo{flex:none;width:62px;height:62px;border-radius:18px;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.18)}
  .foot-logo img{width:44px;height:auto;display:block}
  .foot-title{margin:0;font-weight:600;font-size:1.4rem;color:#fff;line-height:1.2}
  .foot-sub{margin:.3rem 0 0;font-weight:500;font-size:.95rem;color:rgba(255,255,255,.7)}
  .foot-social{display:flex;gap:.9rem}
  .foot-social a{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .25s,transform .25s}
  .foot-social a:hover{background:rgba(255,255,255,.22);transform:translateY(-2px);text-decoration:none}
  .foot-sep{height:1px;background:rgba(255,255,255,.16);margin:2.2rem 0 1.6rem}
  .foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
  .foot-copy{margin:0;font-size:.92rem;color:rgba(255,255,255,.55)}
  .foot-tag{margin:0;font-size:.95rem;color:var(--cyan);font-weight:600}
  
  
  footer .foot-tag a,footer .foot-copy a{color:var(--cyan);font-weight:700;text-decoration:none}
  footer a:hover{text-decoration:underline}
  

  @media (max-width:1023px){
    .dims,.centres-stats,.travaux{grid-template-columns:1fr}
    .stat-band{grid-template-columns:1fr;text-align:center;justify-items:center}
    .vis2{columns:1}
    .steps,.events,.enjeux2,.missions{grid-template-columns:1fr}
  }

  @media (max-width:1023px){
    .outils,.camps,.culture-grid,.concret,.struct-grid,.deploy-head{grid-template-columns:1fr}
    .cfa-zone{grid-template-columns:1fr}
  }

  @media (prefers-reduced-motion:reduce){.pband{transform:none!important}}

  /* ── échelle typographique harmonisée ── */
  :root{--fs-h2:clamp(2rem,3.8vw,3.05rem);--fs-h3:clamp(1.6rem,2.9vw,2.3rem);--fs-h4:clamp(1.22rem,2vw,1.55rem)}
  .edito h2,.retro h2,.s3 h2{font-size:var(--fs-h2)!important}
  .retro h3,.s3 h3,.conso-title{font-size:var(--fs-h3)!important}
  .deploy-head h3{font-size:clamp(1.55rem,2.6vw,2.1rem)!important}
  .s3 .outils-title,.s3 .cfa-title,.s3 .rencontre-title,.certif h3,.focus-btp h4{font-size:var(--fs-h4)!important}

  @media (prefers-reduced-motion:reduce){
    .mouse::after{animation:none}html{scroll-behavior:auto}
    .rev{opacity:1;transform:none;transition:none}
  }

  /* ╔════════════════════════════════════════════════════════╗
     ║  CORRECTIF RESPONSIVE — supprime le scroll horizontal   ║
     ║  (tablette & mobile)                                     ║
     ╚════════════════════════════════════════════════════════╝ */

  /* Garde-fou global : rien ne peut dépasser la largeur de l'écran.
     overflow-x:clip (et NON hidden) -> bloque le scroll horizontal sans
     casser position:sticky du hero (hidden crée un conteneur de scroll). */
  html,body{max-width:100%;overflow-x:clip}
  img,svg,video,iframe{max-width:100%}

  /* ---- Tablette (≤ 1023px) ---- */
  @media (max-width:1023px){
    /* sections : padding latéral réduit pour gagner de la place */
    section,.edito,.retro,.s3,.s8{padding-left:1.2rem;padding-right:1.2rem}

    /* grilles oubliées qui restaient en plusieurs colonnes */
    .effectifs{grid-template-columns:repeat(2,1fr)}
    .portraits{grid-template-columns:repeat(2,1fr)}
    .s4 .chips-row{grid-template-columns:repeat(2,1fr)}

    /* blocs en largeur fixe -> pleine largeur */
    .conso,.cfa-zone,.objectif-panel{width:auto;max-width:100%}

    /* struct-grid : !important pour battre le style inline (5fr 7fr, ~ligne 1220) */
    .struct-grid{grid-template-columns:1fr!important}
  }

  /* ---- Mobile (≤ 640px) ---- */
  @media (max-width:640px){
    section,.edito,.retro,.s3,.s8{padding-left:1rem;padding-right:1rem}

    /* on autorise les phrases surlignées à passer à la ligne */
    .hl,.hl2{white-space:normal}

    /* tout passe sur une seule colonne */
    .effectifs,.portraits,.s4 .chips-row,.photos4,.btp-cols{grid-template-columns:1fr}

    /* les puces "chip" ne forcent plus une largeur mini trop grande */
    .chip{min-width:0}

    /* guillemets décoratifs ramenés dans le cadre */
    .pull{max-width:100%}
    .pull .qm{font-size:3.4rem}
    .pull .qm.a{left:-.2rem;top:-1.8rem}
    .pull .qm.b{right:-.2rem;bottom:-2.4rem}

    /* bandes photos inclinées : on limite la casse sur mobile */
    .pband{width:160vw;margin-left:-30vw}

    /* mobile : on masque la pastille logo à gauche du burger (gain de place) */
    .nav .pill{display:none}
  }
