
    /* ════════════════════════════════════════════════════════
       UTILITAIRES
    ════════════════════════════════════════════════════════ */
    .pad { padding: 6rem 0; }
    .pad-sm { padding: 4rem 0; }
    .bg-creme  { background: var(--creme); }
   
    /* Eyebrow — label décoratif au-dessus des titres */
    .eyebrow {
      display: inline-block;
      font-family: var(--f-corps);
      font-size: .7rem;
      font-weight: 600;
      letter-spacing: .3em;
      text-transform: uppercase;
      color: var(--or);
      margin-bottom: .75rem;
    }

    /* Ligne dorée décorative */
    .ligne-or-c { margin: 0 auto .85rem; }

    /* Titre section */
    .titre-section {
      font-family: var(--f-titre);
      font-size: clamp(2rem, 4.5vw, 3.2rem);
      font-weight: 700;
      color: var(--gris-fonce);
      line-height: 1.15;
    }
    .titre-section span { color: var(--vert); }
    .titre-section--blanc { color: var(--blanc); }

    /* Sous-titre section */
    .sous-section {
      font-family: var(--f-sous);
      font-style: italic;
      font-size: clamp(1.05rem, 2vw, 1.3rem);
      color: var(--gris-txt);
    }
    .sous-section--blanc { color: rgba(255,255,255,.68); }

    /* Citation / pull quote */
    .pull-quote {
      font-family: var(--f-sous);
      font-style: italic;
      font-size: clamp(1.2rem, 2.5vw, 1.7rem);
      color: var(--vert-fonce);
      border-left: 4px solid var(--or);
      padding: 1rem 1.8rem;
      background: var(--or-clair);
      line-height: 1.6;
    }

    /* Séparateur décoratif */
    .sep {
      display: flex; align-items: center; gap: 1.2rem;
      margin: 2.5rem 0;
    }
    .sep::before, .sep::after {
      content: ''; flex: 1; height: 1px;
      background: linear-gradient(90deg, transparent, var(--gris-bord), transparent);
    }
    .sep i { color: var(--or); font-size: 1rem; }

    
    /* ════════════════════════════════════════════════════════
       ANIMATIONS D'ENTRÉE
    ════════════════════════════════════════════════════════ */
    .reveal { opacity: 0; transform: translateY(32px); transition: opacity .75s ease, transform .75s ease; }
    .reveal.visible { opacity: 1; transform: translateY(0); }
    .reveal-left { opacity: 0; transform: translateX(-32px); transition: opacity .75s ease, transform .75s ease; }
    .reveal-left.visible { opacity: 1; transform: translateX(0); }
    .reveal-right { opacity: 0; transform: translateX(32px); transition: opacity .75s ease, transform .75s ease; }
    .reveal-right.visible { opacity: 1; transform: translateX(0); }



/* ════════════════════════════════════════════════════════
       HERO
    ════════════════════════════════════════════════════════ */
    #hero {
      position: relative; height: 85vh; min-height: 560px;
      display: flex; align-items: flex-end; overflow: hidden;
    }
    .hero-bg {
      position: absolute; inset: 0;
      background-image: url('https://images.unsplash.com/photo-1566073771259-6a8506099945?w=1920&q=88&auto=format&fit=crop');
      background-size: cover; background-position: center 40%;
      animation: zoomHero 16s ease-out forwards;
    }
    @keyframes zoomHero { from{transform:scale(1.06)} to{transform:scale(1)} }
    .hero-ov {
      position: absolute; inset: 0;
      background: linear-gradient(0deg, rgba(0,25,0,.85) 0%, rgba(0,30,0,.4) 55%, rgba(0,20,0,.18) 100%);
    }
    /* Bande décorative verticale gauche */
    .hero-deco {
      position: absolute; left: 0; top: 0; bottom: 0; width: 5px;
      background: linear-gradient(180deg, transparent, var(--or) 40%, transparent);
      opacity: 0; animation: fadeIn .8s 1.4s forwards;
    }
    @keyframes fadeIn { to { opacity: 1; } }

    .hero-bc { position: absolute; top: 0; left: 0; right: 0; padding-top: 7rem; z-index: 2; }
    .hero-bc .breadcrumb { background: none; padding: 0; margin: 0; font-size: .76rem; }
    .hero-bc .breadcrumb-item a { color: rgba(255,255,255,.65); transition: color .3s; }
    .hero-bc .breadcrumb-item a:hover { color: var(--or); }
    .hero-bc .breadcrumb-item.active { color: var(--or); }
    .hero-bc .breadcrumb-item+.breadcrumb-item::before { color: rgba(255,255,255,.38); }

    .hero-cnt { position: relative; z-index: 2; color: var(--blanc); padding-bottom: 5rem; width: 100%; }
    .hero-eyebrow { font-family: var(--f-corps); font-size: .7rem; letter-spacing: .32em; text-transform: uppercase; color: var(--or); margin-bottom: .9rem; opacity: 0; animation: slideUp .9s .3s forwards; }
    .hero-h1      { font-size: clamp(2.4rem, 6vw, 4.2rem); font-weight: 700; line-height: 1.08; margin-bottom: .8rem; opacity: 0; animation: slideUp .9s .5s forwards; }
    .hero-sub     { font-family: var(--f-sous); font-style: italic; font-size: clamp(1.05rem, 2.2vw, 1.6rem); color: rgba(255,255,255,.8); margin-bottom: 2.2rem; opacity: 0; animation: slideUp .9s .7s forwards; }
    .hero-btns    { display: flex; gap: 1rem; flex-wrap: wrap; opacity: 0; animation: slideUp .9s .9s forwards; }
    @keyframes slideUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }

    /* Défilement indicateur */
    .scroll-hint {
      position: absolute; bottom: 2.2rem; left: 50%; transform: translateX(-50%);
      z-index: 2; display: flex; flex-direction: column; align-items: center; gap: .35rem;
      color: rgba(255,255,255,.55); font-size: .65rem; letter-spacing: .22em; text-transform: uppercase;
      animation: bounce 2s infinite;
    }
    .scroll-hint i { color: var(--or); font-size: 1rem; }
    @keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(7px)} }

    /* ════════════════════════════════════════════════════════
       CHIFFRES CLÉS (bande sous hero)
    ════════════════════════════════════════════════════════ */
    .chiffres-band {
      background: var(--gris-fonce);
      border-top: 3px solid var(--or);
    }
    .chiffre-item { text-align: center; padding: 1.7rem 1rem; border-right: 1px solid rgba(255,255,255,.1); }
    .chiffre-item:last-child { border-right: none; }
    .chiffre-num  { font-family: var(--f-titre); font-size: 2rem; font-weight: 700; color: var(--or); display: block; line-height: 1; }
    .chiffre-lbl  { font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-top: .25rem; display: block; }

    /* ════════════════════════════════════════════════════════
       SECTION HISTOIRE
    ════════════════════════════════════════════════════════ */
    #histoire .img-histoire {
      position: relative;
    }
    #histoire .img-histoire img {
      width: 100%; height: 520px; object-fit: cover;
      transition: transform .7s;
    }
    #histoire .img-histoire:hover img { transform: scale(1.03); }
    #histoire .img-histoire { overflow: hidden; }

    /* Cadre décoratif derrière l'image */
    #histoire .img-frame {
      position: absolute; bottom: -18px; right: -18px;
      width: 180px; height: 180px;
      border: 3px solid var(--or);
      z-index: -1;
    }
    /* Badge "Fondé en" */
    #histoire .img-annee {
      position: absolute; top: 1.5rem; left: 1.5rem;
      background: linear-gradient(135deg, var(--vert), var(--vert-fonce));
      color: var(--blanc); padding: 1rem 1.4rem;
    }
    #histoire .img-annee .an-num { font-family: var(--f-titre); font-size: 1.8rem; font-weight: 700; display: block; line-height: 1; }
    #histoire .img-annee .an-txt { font-size: .63rem; letter-spacing: .12em; text-transform: uppercase; opacity: .8; }

    #histoire .texte-histoire p { font-size: .95rem; color: var(--gris-txt); margin-bottom: 1.1rem; }
    #histoire .texte-histoire p:last-of-type { margin-bottom: 0; }

    /* Timeline décorative */
    .timeline-histoire {
      margin-top: 2.5rem;
    }
    .tl-evt {
      display: flex; gap: 1.2rem; margin-bottom: 1.4rem;
      align-items: flex-start;
    }
    .tl-evt:last-child { margin-bottom: 0; }
    .tl-dot {
      width: 42px; height: 42px; flex-shrink: 0;
      background: linear-gradient(135deg, var(--or), var(--or-fonce));
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: var(--blanc); font-size: .85rem;
    }
    .tl-txt strong { display: block; font-family: var(--f-titre); font-size: .95rem; color: var(--gris-fonce); margin-bottom: .2rem; }
    .tl-txt p { font-size: .83rem; color: var(--gris-txt); line-height: 1.7; margin: 0; }

    /* ════════════════════════════════════════════════════════
       SECTION VISION
    ════════════════════════════════════════════════════════ */
    #vision {
      background: linear-gradient(160deg, #0d1e0d 0%, #1b2e1b 65%, #0a160a 100%);
      position: relative; overflow: hidden;
    }
    #vision::before {
      content: ''; position: absolute; inset: 0;
      background:
        radial-gradient(circle at 80% 20%, rgba(212,175,55,.12) 0%, transparent 55%),
        radial-gradient(circle at 15% 80%, rgba(0,128,0,.18) 0%, transparent 50%);
      pointer-events: none;
    }
    /* Motif de fond subtil */
    #vision::after {
      content: '"'; font-family: var(--f-titre);
      font-size: 26rem; color: rgba(255,255,255,.03);
      position: absolute; top: -4rem; right: -3rem; line-height: 1;
      pointer-events: none;
    }

    .vision-card {
      background: rgba(255,255,255,.05);
      border: 1px solid rgba(255,255,255,.1);
      border-top: 3px solid var(--or);
      padding: 2.2rem 1.8rem;
      height: 100%;
      transition: var(--tr);
    }
    .vision-card:hover {
      background: rgba(255,255,255,.09);
      border-color: rgba(212,175,55,.4);
      transform: translateY(-5px);
    }
    .vision-card .vc-icon {
      width: 58px; height: 58px;
      background: rgba(212,175,55,.15);
      border: 1px solid rgba(212,175,55,.35);
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: var(--or); font-size: 1.4rem;
      margin-bottom: 1.3rem; transition: var(--tr);
    }
    .vision-card:hover .vc-icon { background: var(--or); color: var(--blanc); }
    .vision-card .vc-titre { font-family: var(--f-titre); font-size: 1.15rem; font-weight: 700; color: var(--blanc); margin-bottom: .6rem; }
    .vision-card .vc-desc { font-size: .85rem; color: rgba(255,255,255,.62); line-height: 1.8; }

    /* ════════════════════════════════════════════════════════
       SECTION POURQUOI
    ════════════════════════════════════════════════════════ */
    #pourquoi { background: var(--creme); }

    .arg-item {
      display: flex; gap: 1.4rem;
      padding: 1.8rem;
      background: var(--blanc);
      border-left: 3px solid transparent;
      transition: var(--tr); height: 100%;
    }
    .arg-item:hover {
      border-left-color: var(--or);
      box-shadow: 0 6px 28px rgba(0,0,0,.07);
      transform: translateX(4px);
    }
    .arg-num {
      font-family: var(--f-titre); font-size: 2.8rem; font-weight: 700;
      color: var(--vert-clair); line-height: 1; flex-shrink: 0; min-width: 48px;
      transition: var(--tr);
    }
    .arg-item:hover .arg-num { color: var(--or-clair); }
    .arg-titre { font-family: var(--f-titre); font-size: 1.05rem; font-weight: 700; color: var(--gris-fonce); margin-bottom: .4rem; }
    .arg-desc  { font-size: .84rem; color: var(--gris-txt); line-height: 1.8; margin: 0; }

    /* ════════════════════════════════════════════════════════
       SECTION CITATION INTERSTITIELLE
    ════════════════════════════════════════════════════════ */
    .interstitiel {
      background: linear-gradient(135deg, var(--vert), var(--vert-fonce));
      padding: 5rem 0; text-align: center; position: relative; overflow: hidden;
    }
    .interstitiel::before {
      content: ''; position: absolute; inset: 0;
      background:
        radial-gradient(circle at 20% 50%, rgba(255,255,255,.06) 0%, transparent 55%),
        radial-gradient(circle at 80% 50%, rgba(212,175,55,.12) 0%, transparent 55%);
      pointer-events: none;
    }
    .interstitiel .cit-txt {
      font-family: var(--f-sous); font-style: italic;
      font-size: clamp(1.3rem, 3vw, 2rem); font-weight: 400;
      color: var(--blanc); line-height: 1.55; position: relative; z-index: 1;
    }
    .interstitiel .cit-auteur {
      font-family: var(--f-corps); font-size: .72rem; letter-spacing: .2em;
      text-transform: uppercase; color: var(--or); margin-top: 1.2rem;
      position: relative; z-index: 1;
    }
    .interstitiel .cit-icon {
      font-size: 3.5rem; color: rgba(212,175,55,.3);
      display: block; margin-bottom: 1.5rem; position: relative; z-index: 1;
    }

    /* ════════════════════════════════════════════════════════
       SECTION ÉQUIPE
    ════════════════════════════════════════════════════════ */
    #equipe { background: var(--blanc); }

    .equipe-card {
      text-align: center;
      height: 100%;
    }
    .equipe-card .ec-photo {
      position: relative; overflow: hidden; margin-bottom: 1.5rem;
    }
    .equipe-card .ec-photo img {
      width: 100%; height: 320px; object-fit: cover; object-position: center top;
      transition: transform .6s;
    }
    .equipe-card:hover .ec-photo img { transform: scale(1.05); }
    .equipe-card .ec-badge {
      position: absolute; bottom: 0; left: 0; right: 0;
      background: linear-gradient(0deg, rgba(0,30,0,.85) 0%, transparent 100%);
      padding: 1.5rem 1rem .8rem;
      text-align: left;
    }
    .equipe-card .ec-poste {
      font-family: var(--f-corps); font-size: .65rem; font-weight: 600;
      letter-spacing: .18em; text-transform: uppercase; color: var(--or); display: block;
    }
    .equipe-card .ec-nom { font-family: var(--f-titre); font-size: 1.2rem; font-weight: 700; color: var(--blanc); }
    .equipe-card .ec-desc { font-size: .85rem; color: var(--gris-txt); line-height: 1.75; padding: 0 .5rem; }
    .equipe-card .ec-lien {
      display: inline-flex; align-items: center; gap: .45rem;
      font-size: .75rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
      color: var(--vert); margin-top: .8rem; transition: color .3s;
    }
    .equipe-card .ec-lien:hover { color: var(--or); }

    /* Carte "rejoindre" */
    .equipe-rejoindre {
      background: linear-gradient(135deg, var(--vert-clair), var(--or-clair));
      border: 2px dashed var(--gris-bord); height: 100%;
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      padding: 2.5rem 2rem; text-align: center; transition: var(--tr);
    }
    .equipe-rejoindre:hover { border-color: var(--or); box-shadow: var(--ombre); }
    .equipe-rejoindre .er-icon { font-size: 2.5rem; color: var(--or); margin-bottom: 1rem; }
    .equipe-rejoindre h4 { font-family: var(--f-titre); font-size: 1.1rem; color: var(--gris-fonce); margin-bottom: .5rem; }
    .equipe-rejoindre p { font-size: .84rem; color: var(--gris-txt); }

    /* ════════════════════════════════════════════════════════
       SECTION GALERIE
    ════════════════════════════════════════════════════════ */
    #galerie { background: var(--gris-clair); }

    .galerie-mosaic {
      display: grid;
      grid-template-columns: repeat(12, 1fr);
      grid-template-rows: 240px 240px;
      gap: 8px;
    }
    /* Disposition asymétrique */
    .gm-1  { grid-column: 1 / 6;  grid-row: 1 / 3; }   /* Grande gauche */
    .gm-2  { grid-column: 6 / 9;  grid-row: 1; }        /* Milieu haut-gauche */
    .gm-3  { grid-column: 9 / 13; grid-row: 1; }        /* Milieu haut-droite */
    .gm-4  { grid-column: 6 / 10; grid-row: 2; }        /* Milieu bas-gauche */
    .gm-5  { grid-column: 10/ 13; grid-row: 2; }        /* Milieu bas-droite */

    .gm-item { position: relative; overflow: hidden; cursor: pointer; }
    .gm-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s; }
    .gm-item:hover img { transform: scale(1.08); }
    .gm-ov {
      position: absolute; inset: 0;
      background: linear-gradient(135deg, rgba(0,80,0,.55), rgba(0,30,0,.35));
      display: flex; align-items: flex-end; padding: 1.1rem;
      opacity: 0; transition: opacity .33s;
    }
    .gm-item:hover .gm-ov { opacity: 1; }
    .gm-caption { color: var(--blanc); font-family: var(--f-titre); font-size: .9rem; font-style: italic; }
    .gm-zoom {
      position: absolute; top: .8rem; right: .8rem;
      width: 34px; height: 34px; background: rgba(255,255,255,.2); backdrop-filter: blur(4px);
      border-radius: 50%; display: flex; align-items: center; justify-content: center;
      color: var(--blanc); font-size: .8rem; opacity: 0; transition: opacity .3s;
    }
    .gm-item:hover .gm-zoom { opacity: 1; }

    @media(max-width:767px){
      .galerie-mosaic { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
      .gm-1,.gm-2,.gm-3,.gm-4,.gm-5 { grid-column: auto; grid-row: auto; }
      .gm-1 { grid-column: 1 / 3; height: 240px; }
      .gm-item { height: 190px; }
    }

    /* ════════════════════════════════════════════════════════
       CTA BANDE FINALE
    ════════════════════════════════════════════════════════ */
    .cta-finale {
      background: linear-gradient(135deg, var(--or), var(--or-fonce));
      padding: 4rem 0; position: relative; overflow: hidden;
    }
    .cta-finale::before {
      content: ''; position: absolute; inset: 0;
      background: radial-gradient(circle at 75% 50%, rgba(255,255,255,.12) 0%, transparent 60%);
    }
    .cta-finale .cta-titre { font-family: var(--f-titre); font-size: clamp(1.5rem,3vw,2.4rem); font-weight: 700; color: var(--blanc); }
    .cta-finale .cta-sous  { font-family: var(--f-sous); font-style: italic; color: rgba(255,255,255,.8); font-size: 1.15rem; }
