*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0F1A27;
  --navy-2:#183241;
  --navy-3:#1a3a4a;
  --navy-4:#1e4256;
  --gold:#d9b69f;
  --gold-lt:#e8cdb8;
  --white:#FFFFFF;
  --off:#F5F2ED;
  --muted:#C4D4DE;
  --border:rgba(217,182,159,0.25);
  --borders:rgba(217,182,159,0.08);
}
html,body{background:var(--navy);color:var(--white);font-family:'Raleway',Arial,sans-serif;font-weight:300;line-height:1.7;font-size:1.05rem;overflow-x:hidden}
/* ── NAV ── */
nav#main-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(15,26,39,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 40px;height:64px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:0}
.nav-logo-wrap{display:flex;align-items:center;gap:14px;text-decoration:none;cursor:pointer;flex-shrink:0}
.nav-logo-wrap span.nt{display:flex;flex-direction:column;gap:3px}
.nav-logo-wrap span.nt b{font-size:.83rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:#fff;font-family:'Raleway',Arial,sans-serif;line-height:1}
.nav-logo-wrap span.nt small{font-size:.85rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-family:'Raleway',Arial,sans-serif;line-height:1}
ul.nav-links{display:flex;gap:0;list-style:none;justify-content:center}
ul.nav-links a{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:22px 16px;display:block;transition:color .3s;font-family:'Raleway',Arial,sans-serif;cursor:pointer}
ul.nav-links a:hover,ul.nav-links a.active{color:var(--gold)}
.nav-rdv{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);background:var(--gold);border:1px solid var(--gold);padding:9px 18px;text-decoration:none;transition:all .3s;font-family:'Raleway',Arial,sans-serif;white-space:nowrap;font-weight:700}
.nav-rdv:hover{background:var(--gold-lt);border-color:var(--gold-lt)}
.nav-btns{display:flex;align-items:center;gap:8px}
.nav-cnx{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);background:transparent;border:1px solid var(--border);padding:9px 18px;text-decoration:none;transition:all .3s;font-family:'Raleway',Arial,sans-serif;white-space:nowrap;font-weight:600;cursor:pointer}
.nav-cnx:hover{border-color:var(--gold);color:var(--gold-lt)}
/* ── PAGES ── */
.page{display:none;padding-top:64px;min-height:100vh}
.page.active{display:block}
/* ── PAGE HEADER ── */
.ph{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 52px 52px;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.ph-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 90% at 50% 50%,rgba(217,182,159,.07) 0%,transparent 65%)}
.ph-grid{position:absolute;inset:0;pointer-events:none;opacity:.03;background-image:linear-gradient(var(--gold) 1px,transparent 1px),linear-gradient(90deg,var(--gold) 1px,transparent 1px);background-size:80px 80px}
.ptag{font-size:.83rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:block;position:relative;z-index:1}
.ph h1{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,4vw,3.2rem);font-weight:400;line-height:1.15;position:relative;z-index:1;max-width:680px}
.ph h1 em{font-style:italic;color:var(--gold)}
.ph-sub{font-size:.95rem;line-height:1.9;color:var(--muted);max-width:540px;margin-top:14px;font-weight:300;position:relative;z-index:1}
/* ── SECTIONS ── */
sec{display:block;padding:80px 52px}
sec h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;line-height:1.2;margin-bottom:0}
sec h2 em{font-style:italic;color:var(--gold)}
h3{font-family:'Raleway',Arial,sans-serif;font-weight:600;font-size:.98rem;letter-spacing:.04em}
.stag{font-size:.83rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:12px}
.sgold{width:36px;height:1px;background:var(--gold);margin:22px 0 28px}
/* ── BOUTONS ── */
.bg{display:inline-block;background:var(--gold);color:var(--navy);font-family:'Raleway',Arial,sans-serif;font-size:.95rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;padding:13px 32px;text-decoration:none;transition:background .3s;cursor:pointer;border:none;font-family:'Raleway',Arial,sans-serif}
.bg:hover{background:var(--gold-lt)}
.bo{display:inline-block;border:1px solid var(--gold);color:var(--gold);background:transparent;font-family:'Raleway',Arial,sans-serif;font-size:.95rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;padding:13px 28px;text-decoration:none;transition:all .3s;cursor:pointer}
.bo:hover{background:rgba(217,182,159,.08)}
.btn-sm{padding:7px 16px!important;font-size:.8rem!important;letter-spacing:.14em!important}
.modal-close-btn{position:absolute;top:12px;right:12px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(217,182,159,.12);border:1px solid rgba(217,182,159,.3);color:var(--gold);font-size:1.3rem;cursor:pointer;line-height:1;transition:background .2s,color .2s;border-radius:2px}
.modal-close-btn:hover{background:rgba(217,182,159,.25);color:var(--white)}
.bfilt-off{opacity:.45}
.bfilt-off:hover{opacity:.75}
/* ── CITATION ── */
.citation{font-family:'Playfair Display',serif;font-style:italic;font-size:1.2rem;color:var(--off);line-height:1.8;border-left:2px solid var(--gold);padding-left:20px}
.citation cite{display:block;font-size:.89rem;font-style:normal;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:14px;font-family:'Raleway',Arial,sans-serif}
/* ── FOOTER ── */
footer{background:var(--navy-2);border-top:1px solid var(--border);padding:32px 52px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.flogo{font-size:1.02rem;letter-spacing:.3em;text-transform:uppercase;color:var(--off);font-weight:500}
.flogo span{color:var(--gold)}
.fnav{display:flex;gap:24px;flex-wrap:wrap}
.fnav a{font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .3s;cursor:pointer}
.fnav a:hover{color:var(--gold)}
.fcp{font-size:.83rem;color:var(--muted);font-weight:300}
.fcp a{color:var(--muted);text-decoration:none}
.fcp a:hover{color:var(--gold)}
/* ═══════════════════════════════════════════════
   RESPONSIVE — TABLETTE + MOBILE
═══════════════════════════════════════════════ */

/* ── Touch : cursor et 3D désactivés via CSS ── */
@media(hover:none),(pointer:coarse){
  body,a,button,[onclick],[data-p]{cursor:auto!important}
  #trya-cursor{display:none!important}
}

/* ── TABLETTE ≤ 900px ── */
@media(max-width:900px){
  .grid2,.grid3,.grid4,.gridteam,.gridevents,.grid2cols{grid-template-columns:1fr!important}
  sec{padding:52px 28px}
  nav#main-nav{padding:0 20px}
  ul.nav-links{display:none}
  .ph{padding:48px 28px 40px}
  footer{flex-direction:column;gap:14px;text-align:center;padding:28px 24px}
  .fnav{justify-content:center}
  [style*="border-right:1px solid var(--border)"]{border-right:none!important;border-bottom:1px solid var(--border)!important}
  [style*="padding:40px 32px"]{padding:28px 22px!important}
  [style*="padding:32px 28px"]{padding:24px 20px!important}
  [style*="padding:32px;"]{padding:24px!important}
  [style*="padding:48px 40px"]{padding:32px 24px!important}
}

/* ── MOBILE ≤ 640px ── */
@media(max-width:640px){
  nav#main-nav{height:56px;padding:0 16px}
  .nav-logo-wrap span.nt b{font-size:.75rem;letter-spacing:.2em}
  .nav-logo-wrap span.nt small{font-size:.72rem;letter-spacing:.14em}
  .page{padding-top:56px}

  #p-index > sec:first-of-type{padding:72px 20px 52px;min-height:100svh;min-height:100vh}
  #p-index > sec:first-of-type h1{font-size:clamp(2rem,10vw,3rem)!important;margin-bottom:20px!important;letter-spacing:-.01em!important}
  #p-index > sec:first-of-type > div:nth-child(4) > div:nth-child(3) p:first-child{font-size:clamp(1rem,4.5vw,1.3rem)!important}
  #p-index > sec:first-of-type > div:nth-child(4) > div:nth-child(5){flex-direction:column!important;align-items:stretch!important}
  #p-index > sec:first-of-type .bg,
  #p-index > sec:first-of-type .bo{width:100%!important;text-align:center!important;box-sizing:border-box!important}
  #hero-canvas{display:block}

  sec{padding:40px 18px}
  .ph{padding:36px 18px 30px}
  .ph h1{font-size:clamp(1.5rem,6.5vw,2.4rem)!important}
  .ph-sub{font-size:.85rem!important}
  sec h2{font-size:clamp(1.3rem,5.5vw,1.9rem)!important}
  .stag{font-size:.68rem;letter-spacing:.2em}
  .ptag{font-size:.68rem;letter-spacing:.24em}
  .sgold{margin:14px 0 18px}
  .citation{font-size:.95rem}

  .bg,.bo{font-size:.78rem;padding:11px 20px;letter-spacing:.12em}

  footer{flex-direction:column;gap:12px;text-align:center;padding:24px 18px}
  .fnav{justify-content:center;gap:16px}
  .flogo{font-size:.88rem;letter-spacing:.22em}

  .modal-box{padding:28px 20px!important;width:calc(100vw - 24px)!important;max-width:none!important;margin:12px!important}
  .modal-overlay{align-items:flex-end!important}

  /* Conteneurs max-width : empêcher tout débordement horizontal */
  [style*="max-width:1060px"],[style*="max-width:860px"]{
    width:100%!important;box-sizing:border-box!important;overflow-x:hidden!important
  }

  /* Média — titres d'épisodes : autoriser le retour à la ligne sur mobile */
  #p-media div[style*="white-space:nowrap"],
  #p-suivons div[style*="white-space:nowrap"]{
    white-space:normal!important;
    overflow:visible!important;
    text-overflow:clip!important;
  }

  /* Média — épisodes : réduire padding et gap sur mobile */
  #p-media .ep-row{padding:14px 14px!important;gap:12px!important}
  #p-media .ep-row .ep-num{font-size:1rem!important}

  /* Média — podcast header : titre + boutons en colonne sur mobile */
  #p-media .podcast-header{flex-direction:column!important;align-items:flex-start!important}
  #p-media .podcast-btns{width:100%}
  #p-media .podcast-btns > *{flex:1!important;justify-content:center!important;box-sizing:border-box!important}

  /* Média — Rencontres header : "Voir la chaîne" séparé en bas sur mobile */
  .yt-section-header{flex-direction:column!important;align-items:flex-start!important;gap:12px!important}
  .yt-nav-arrows{width:100%!important;justify-content:flex-start!important}

  /* Slides YouTube : 88vw */
  .yt-slide{flex:0 0 88vw!important;width:88vw!important}
  [style*="padding:40px 32px"]{padding:22px 18px!important}
  [style*="padding:32px 28px"]{padding:20px 16px!important}
  [style*="padding:32px;"]{padding:20px!important}
  [style*="padding:48px 40px"]{padding:28px 18px!important}
  [style*="height:240px"]{height:180px!important}
  [style*="padding:52px 40px"]{padding:32px 18px!important}

  p,span{max-width:100%;word-break:break-word;overflow-wrap:break-word}
}
/* ── ANIMATIONS ── */
@keyframes wave{0%,100%{transform:scaleY(.6)}50%{transform:scaleY(1.3)}}
@keyframes breathe{0%,100%{opacity:.4}50%{opacity:.9}}
@keyframes scrollbar2{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
/* ── HOVER CSS pur ── */
div[style*="border-top:2px solid transparent"]{transition:background .3s,border-color .3s}
div[style*="border-top:2px solid transparent"]:hover{border-top-color:#d9b69f!important;background:#1C2E42!important}
a[style*="border-left"]{transition:background .3s,border-color .3s!important}
a[style*="border-left"]:hover{background:#1C2E42!important;border-left-color:#d9b69f!important}
div[style*="border-left:2px solid transparent"]{transition:border-color .3s}
div[style*="border-left:2px solid transparent"]:hover{border-left-color:#d9b69f!important}
.gridevents{transition:background .3s,border-color .3s}
.gridevents:hover{background:#152336!important;border-left-color:#d9b69f!important}
a[href*="youtube"]:hover,a[style*="border:1px solid transparent"]:hover{border-color:#d9b69f!important}

@media(max-width:780px){
  ul.nav-links{display:none!important}
  .nav-btns{display:none!important}
  #hamburger-btn{display:flex!important}
  nav#main-nav{padding:0 18px}
}
#hamburger-btn{display:none;flex-direction:column;gap:6px;cursor:pointer;padding:10px;flex-shrink:0;background:none;border:none;z-index:200;align-items:center;justify-content:center}
#hamburger-btn span{display:block;width:24px;height:2px;background:var(--gold)}
/* ── HAMBURGER → CROIX ── */
#hamburger-btn.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
#hamburger-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
#hamburger-btn.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
#hamburger-btn span{transition:transform .25s ease,opacity .2s ease}

#mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:rgba(15,26,39,.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:99;padding:8px 0 16px}
#mobile-menu a{display:block;font-size:.83rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);padding:14px 28px;text-decoration:none;font-family:'Raleway',sans-serif;border-left:2px solid transparent;transition:color .3s,border-color .3s}
#mobile-menu a:hover,#mobile-menu a.active-mobile{color:var(--gold);border-left-color:var(--gold)}
#mobile-menu .m-rdv{margin:12px 28px 0;display:inline-block;font-size:.86rem;letter-spacing:.18em;text-transform:uppercase;background:var(--gold);color:var(--navy);border:1px solid var(--gold);padding:10px 20px;text-decoration:none;font-weight:700;cursor:pointer;font-family:'Raleway',Arial,sans-serif;transition:background .3s,border-color .3s}
.billet-card:hover{border-left-color:var(--gold)!important;background:#1C2E42!important}

.grid2cols > div{transition:background .3s,border-top-color .3s}
.grid2cols > div:hover{background:#1C2E42!important;border-top-color:#d9b69f!important}

/* ── SCROLL ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideRight{from{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideLeft{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}
@keyframes countUp{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
@keyframes lineGrow{from{width:0}to{width:36px}}

.anim-fadeup{opacity:0}
.anim-fadein{opacity:0}
.anim-right{opacity:0}
.anim-left{opacity:0}
.anim-count{opacity:0}

.anim-fadeup.visible{animation:fadeUp 1.1s cubic-bezier(.22,.8,.44,1) forwards}
.anim-fadein.visible{animation:fadeIn 1.2s ease forwards}
.anim-right.visible{animation:slideRight 1.1s cubic-bezier(.22,.8,.44,1) forwards}
.anim-left.visible{animation:slideLeft 1.1s cubic-bezier(.22,.8,.44,1) forwards}
.anim-count.visible{animation:countUp .9s cubic-bezier(.22,.8,.44,1) forwards}

/* Stagger delays */
.delay-1{animation-delay:.15s!important}
.delay-2{animation-delay:.35s!important}
.delay-3{animation-delay:.55s!important}
.delay-4{animation-delay:.75s!important}
.delay-5{animation-delay:1s!important}
.delay-6{animation-delay:1.25s!important}
/* ── PAGE TRANSITION ── */
@keyframes pageEnter{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.page.page-entering{animation:pageEnter .6s cubic-bezier(.22,.8,.44,1) forwards}
/* ── GLOBAL PAGE SCROLL ANIMATIONS ── */
.page-anim{opacity:0}.page-anim.visible{animation:fadeUp 1.0s cubic-bezier(.22,.8,.44,1) forwards}
.page-anim-right{opacity:0}.page-anim-right.visible{animation:slideRight 1.0s cubic-bezier(.22,.8,.44,1) forwards}
.page-anim-left{opacity:0}.page-anim-left.visible{animation:slideLeft 1.0s cubic-bezier(.22,.8,.44,1) forwards}
.page-anim-fade{opacity:0}.page-anim-fade.visible{animation:fadeIn 1.2s ease forwards}

/* Gold line after stag */
.stag-line::after{content:'';display:block;height:1px;background:var(--gold);margin-top:10px;animation:lineGrow .6s ease forwards;animation-play-state:paused}
.stag-line.visible::after{animation-play-state:running}
/* ═══ GRAIN TEXTURE ═══ */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.028;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
background-repeat:repeat;background-size:180px 180px}

/* ═══ HERO AMBIENT GLOW PULSE ═══ */
@keyframes heroPulse{0%,100%{opacity:.07}50%{opacity:.13}}
#hero-glow{animation:heroPulse 6s ease-in-out infinite}

/* ═══ BOUTONS AMÉLIORÉS ═══ */
.bg{transition:background .28s,transform .22s,box-shadow .28s!important}
.bg:hover{background:var(--gold-lt)!important;transform:translateY(-2px);box-shadow:0 10px 28px rgba(217,182,159,.22)}
.bg:active{transform:translateY(0)}
.bo{transition:background-color .28s ease,color .28s,transform .22s,box-shadow .28s!important}
.bo:hover{background-color:var(--gold)!important;background-image:none!important;color:var(--navy)!important;border-color:var(--gold)!important;transform:translateY(-2px);box-shadow:0 10px 28px rgba(217,182,159,.18)}
.bo:active{transform:translateY(0)}

/* ═══ .SGOLD ANIMÉE ═══ */
.sgold{width:0!important;transition:width 1.1s cubic-bezier(.22,.8,.44,1) .3s!important}
.sgold.visible{width:36px!important}

/* ═══ .STAG LIGNE ANIMÉE ═══ */
.stag::after{content:'';display:block;height:1px;background:var(--gold);width:0;margin-top:9px;transition:width .9s ease .2s}
.stag.visible::after{width:28px}

/* ═══ PH REVEAL — révélation typographique ═══ */
.page .ph .ptag{opacity:0;transform:translateY(10px)}
.page.active .ph .ptag{animation:fadeUp .7s cubic-bezier(.22,.8,.44,1) .15s forwards}
.page .ph h1{opacity:0;transform:translateY(18px)}
.page.active .ph h1{animation:fadeUp .9s cubic-bezier(.22,.8,.44,1) .35s forwards}
.page .ph .ph-sub{opacity:0;transform:translateY(10px)}
.page.active .ph .ph-sub{animation:fadeUp .7s cubic-bezier(.22,.8,.44,1) .65s forwards}
.page:not(.active) .ph .ptag,.page:not(.active) .ph h1,.page:not(.active) .ph .ph-sub{animation:none!important;opacity:0;transform:translateY(10px)}

/* ═══ CARTES ÉQUIPE — hover glow ═══ */
.gridteam > div{transition:box-shadow .35s,border-color .35s!important}
.gridteam > div:hover{box-shadow:0 0 0 1px rgba(217,182,159,.18),0 16px 48px rgba(15,26,39,.55)!important;border-color:var(--gold)!important}
.tilt-card{transform-style:preserve-3d;will-change:transform;transition:transform .12s ease}

/* ═══ PARALLAX PH ═══ */
.ph-glow,.ph-grid{will-change:transform;transition:none}

/* ═══ CURSOR PERSONNALISÉ ═══ */
.cursor-active,.cursor-active a,.cursor-active button,.cursor-active [onclick],.cursor-active [data-p]{cursor:none!important}
#trya-cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--gold);
pointer-events:none;z-index:99999;transform:translate(-50%,-50%);
transition:width .18s ease,height .18s ease,background .18s ease,border .18s ease,opacity .15s ease;
mix-blend-mode:screen;opacity:.9;will-change:transform}
#trya-cursor.is-hover{width:26px;height:26px;background:transparent;border:1.5px solid var(--gold);opacity:.65}
#trya-cursor.is-click{transform:translate(-50%,-50%) scale(.7)!important}


/* Dropdown submenu */
.nav-has-sub:hover .nav-sub { display:block !important; }
.nav-sub li a:hover { color:var(--gold) !important; }
.nav-sub { margin-top:4px; }

/* Modal animation */
@keyframes modalIn{from{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
.modal-overlay{animation:overlayIn .25s ease forwards}
.modal-box{animation:modalIn .3s cubic-bezier(.22,.8,.44,1) forwards}

/* ═══ HERO CANVAS LAYER ═══ */
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}

/* ═══ HERO TEXT CASCADE REVEAL ═══ */
@keyframes heroSlide{from{opacity:0;transform:translateY(30px)}55%{opacity:1}to{opacity:1;transform:translateY(0)}}
@keyframes heroFadeIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
@keyframes heroButtons{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

#p-index > sec:first-of-type > div:nth-child(4) > span,
#p-index > sec:first-of-type h1,
#p-index > sec:first-of-type > div:nth-child(4) > div:nth-child(3),
#p-index > sec:first-of-type > div:nth-child(4) > div:nth-child(5),
#p-index > sec:first-of-type > div:nth-child(5){opacity:0}

#p-index > sec.hero-anim > div:nth-child(4) > span{animation:heroSlide .52s cubic-bezier(.18,.89,.44,1) .18s forwards}
#p-index > sec.hero-anim h1{animation:heroSlide .72s cubic-bezier(.18,.89,.44,1) .38s forwards}
#p-index > sec.hero-anim > div:nth-child(4) > div:nth-child(3){animation:heroFadeIn .6s cubic-bezier(.22,.8,.44,1) .7s forwards}
#p-index > sec.hero-anim > div:nth-child(4) > div:nth-child(5){animation:heroButtons .5s cubic-bezier(.22,.8,.44,1) .92s forwards}
#p-index > sec.hero-anim > div:nth-child(5){animation:heroFadeIn .55s ease 1.18s forwards}

#hero-grid{will-change:transform;transition:transform .06s linear}


/* ── Carrousel Mécénat ─────────────────────────────────────── */
.mec-cs-track {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: var(--navy-3);
  border-radius: 2px;
}
.mec-cs-slide {
  display: none;
  position: relative;
  width: 100%;
}
.mec-cs-slide.mec-cs-active {
  display: block;
  animation: mecFade .55s ease;
}
@keyframes mecFade {
  from { opacity: 0; transform: scale(1.012); }
  to   { opacity: 1; transform: scale(1); }
}
.mec-cs-slide img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 72vh;
  object-fit: contain;
  background: var(--navy-3);
}
.mec-cs-credit {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 14px 20px;
  background: linear-gradient(transparent, rgba(15,26,39,.75));
  font-size: .73rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  pointer-events: none;
}
.mec-cs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(217,182,159,.35);
  background: rgba(15,26,39,.7);
  color: var(--gold);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, border-color .2s;
  z-index: 10;
  backdrop-filter: blur(6px);
}
.mec-cs-arrow:hover {
  background: rgba(15,26,39,.95);
  border-color: var(--gold);
}
.mec-cs-prev { left: -24px; }
.mec-cs-next { right: -24px; }
.mec-cs-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 20px;
}
.mec-cs-dots {
  display: flex;
  gap: 8px;
}
.mec-cs-dot {
  width: 28px; height: 3px;
  border: none;
  border-radius: 2px;
  background: rgba(217,182,159,.25);
  cursor: pointer;
  transition: background .25s, width .25s;
  padding: 0;
}
.mec-cs-dot.mec-cs-dot-active {
  background: var(--gold);
  width: 44px;
}
.mec-cs-counter {
  font-size: .75rem;
  letter-spacing: .14em;
  color: var(--muted);
  font-family: 'Raleway', sans-serif;
  font-weight: 400;
}
@media (max-width: 768px) {
  .mec-cs-prev { left: 8px; }
  .mec-cs-next { right: 8px; }
  .mec-cs-arrow { width: 38px; height: 38px; }
}