/* =========================================================================
   FAIRE PAYS — Design System
   Palette fidèle à l'affiche de campagne
   ========================================================================= */
:root{
  --navy:#1A3A6B;
  --navy-deep:#0D2240;
  --navy-soft:#2E6BAD;
  --orange:#E8822A;
  --orange-deep:#E0700B;
  --orange-soft:#FF914D;
  --cream:#F4F6F9;
  --cream-2:#E6ECF3;
  --paper:#FFFFFF;
  --lagoon:#2E6BAD;
  --lagoon-soft:#7fd0d8;
  --sunset:#F17421;
  --ink:#333333;
  --ink-soft:#666666;
  --line:rgba(26,58,107,.14);
  --white:#ffffff;
  --ok:#2f8f5b;

  --shadow-sm:0 2px 10px rgba(22,49,79,.07);
  --shadow:0 14px 40px rgba(22,49,79,.12);
  --shadow-lg:0 28px 70px rgba(22,49,79,.18);

  --serif:"Montserrat","Inter","Segoe UI",system-ui,sans-serif;   /* titres : Montserrat Bold (charte officielle) */
  --script:"Caveat","Segoe Script",cursive;                    /* slogans manuscrits */
  --sans:"Inter","Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;

  --wrap:1180px;
  --radius:18px;
  --radius-sm:12px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-wrap:pretty;            /* moins de lignes veuves/orphelines, coupures plus propres (titres = balance) */
}
p,li,.lead,blockquote,figcaption,.hero-sub{text-wrap:pretty}
html,body{overflow-x:clip}
html{scroll-padding-top:92px}
::selection{background:var(--orange);color:#fff}
img,svg{max-width:100%;display:block}
a{color:var(--navy);text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.1;color:var(--navy);margin:0 0 .5em;font-weight:700;letter-spacing:-.01em;text-wrap:balance}
h1{font-size:clamp(2.3rem,6vw,4.4rem)}
h2{font-size:clamp(1.8rem,4vw,2.9rem)}
h3{font-size:clamp(1.2rem,2.4vw,1.55rem)}
p{margin:0 0 1rem}
.wrap{width:min(var(--wrap),92%);margin-inline:auto}
section{position:relative}

/* Accent helpers */
.t-orange{color:var(--orange)}
.t-navy{color:var(--navy)}
.serif{font-family:var(--serif)}
.eyebrow{
  font:700 .8rem/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;
  color:var(--orange);display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--orange);display:inline-block}
.lead{font-size:clamp(1.05rem,2vw,1.28rem);color:var(--ink-soft)}
.script{font-family:var(--script);font-weight:700;color:var(--navy);line-height:1.1}

/* Buttons */
.btn{
  --bg:var(--orange);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--bg);color:var(--fg);
  font-weight:700;font-size:1rem;letter-spacing:.01em;
  padding:.9rem 1.6rem;border-radius:999px;border:2px solid var(--bg);
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;
  box-shadow:0 10px 24px rgba(221,107,51,.28);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(221,107,51,.36);background:var(--orange-deep);border-color:var(--orange-deep)}
.btn:active{transform:translateY(-1px)}
.btn--navy{--bg:var(--navy);box-shadow:0 10px 24px rgba(32,64,106,.28)}
.btn--navy:hover{background:var(--navy-deep);border-color:var(--navy-deep);box-shadow:0 16px 34px rgba(32,64,106,.36)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--navy);box-shadow:none}
.btn--ghost:hover{background:var(--navy);color:#fff}
.btn--lg{padding:1.05rem 2rem;font-size:1.08rem}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* =========================== HEADER ============================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
/* Le header garde la même forme au scroll (pas de rétrécissement) */
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.95rem 0}
.brand{display:flex;align-items:center;gap:.6rem}
.brand img{height:36px;width:auto}
.brand .em{height:38px}
.nav-links{display:flex;align-items:center;gap:.4rem;list-style:none;margin:0;padding:0}
.nav-links a{
  font-weight:600;font-size:.96rem;color:var(--navy);
  padding:.5rem .8rem;border-radius:999px;position:relative;transition:color .2s,background .2s;
}
.nav-links a::after{
  content:"";position:absolute;left:.8rem;right:.8rem;bottom:.32rem;height:2px;
  background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);
}
.nav-links a:hover{color:var(--orange-deep)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--orange-deep)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.brand-cta{padding:.42rem .95rem;font-size:.84rem;gap:.35rem;box-shadow:0 5px 14px rgba(32,64,106,.2)}
.brand-cta:hover{transform:translateY(-2px)}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;border-radius:12px}
.burger span{display:block;width:24px;height:2.4px;background:var(--navy);margin:5px auto;border-radius:2px;transition:.3s var(--ease)}
.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)}

@media (max-width:920px){
  /* Le backdrop-filter du header crée un bloc conteneur qui « piège » le menu
     position:fixed (il ne couvrait que la hauteur du header). On le retire en
     mobile pour que le menu off-canvas occupe bien tout l'écran. Fond rendu
     plus opaque pour compenser la perte du flou. */
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(255,255,255,.97)}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(82%,340px);min-height:100dvh;
    flex-direction:column;align-items:stretch;gap:.2rem;
    background:var(--paper);padding:6rem 1.4rem 2rem;
    transform:translateX(100%);transition:transform .35s var(--ease);
    box-shadow:var(--shadow-lg);z-index:55;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.1rem;padding:.85rem 1rem}
  .nav-links a::after{display:none}
  .burger{display:block;z-index:56}
  .nav-cta .btn:not(.brand-cta){display:none}
}

/* ============================ HERO ============================= */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 90% at 90% -10%, rgba(221,107,51,.10), transparent 55%),
    linear-gradient(180deg,var(--cream) 0%, var(--cream-2) 100%);
  padding:clamp(3rem,8vw,6.5rem) 0 clamp(3.5rem,9vw,7rem);
}
.hero::before{ /* navy triangle nod to the poster — subtle accent */
  content:"";position:absolute;left:0;top:0;width:24vw;max-width:340px;aspect-ratio:1/1;
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-deep) 100%);
  clip-path:polygon(0 0,0 100%,100% 0);opacity:.1;pointer-events:none;
}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.hero-kicker{color:var(--navy);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.82rem}
.hero-kicker b{color:var(--orange-deep)}
.hero h1{margin-top:.6rem;color:var(--navy)}
.hero h1 .x{color:var(--orange)}
.hero-sub{font-size:clamp(1.05rem,2.1vw,1.35rem);color:var(--ink-soft);max-width:34ch;margin:1.1rem 0 1.6rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.hero-signature{margin-top:1.6rem;font-family:var(--script);font-weight:700;font-size:1.95rem;line-height:1;color:var(--navy)}
.hero-signature .u{display:inline-block;padding-bottom:.45rem;border-bottom:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 18'%3E%3Cpath d='M5 11 C70 4 150 14 210 8 S285 6 296 9' fill='none' stroke='%23E8822A' stroke-width='6' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center bottom / 100% .55rem}

.hero-card{
  position:relative;background:var(--paper);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:1.8rem;border:1px solid var(--line);
}
.hero-card h3{color:var(--navy);margin-bottom:1rem}
.pillars-mini{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.pillars-mini li{display:flex;align-items:center;gap:.8rem;font-weight:700;color:var(--navy)}
.pillars-mini .dot{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  background:rgba(221,107,51,.12);color:var(--orange-deep);font-size:1.1rem}
.hero-card .quote{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--line);font-style:italic;color:var(--ink-soft)}

@media (max-width:820px){
  .hero .wrap{grid-template-columns:1fr}
  .hero::before{width:60vw;opacity:.85}
}

/* marquee slogan band */
.band{background:var(--navy);color:#fff;overflow:hidden;padding:.85rem 0}
.band .track{display:flex;gap:3rem;white-space:nowrap;width:max-content;animation:marquee 26s linear infinite}
.band span{font-family:var(--serif);font-weight:700;font-size:1.2rem;letter-spacing:.02em;display:inline-flex;align-items:center;gap:3rem}
.band span i{color:var(--orange-soft);font-style:normal}
.band .wv{width:42px;height:18px;display:inline-block;vertical-align:middle;margin:0 .25rem;flex:0 0 auto}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.band .track{animation:none}}

/* ========================= SECTIONS =========================== */
.section{padding:clamp(3.5rem,8vw,6rem) 0}
.section--paper{background:var(--paper)}
.section--navy{background:var(--navy);color:#fff}
.section--navy h2,.section--navy h3{color:#fff}
.section--navy .lead{color:rgba(255,255,255,.82)}
.section-head{max-width:62ch;margin-bottom:2.6rem}
.section-head.center{margin-inline:auto;text-align:center}

/* Pillars (4 principes) */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.pillar{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem 1.4rem;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
  position:relative;overflow:hidden;
}
.pillar::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.pillar:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}
.pillar:hover::before{transform:scaleX(1)}
.pillar .ic{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;background:rgba(221,107,51,.12);color:var(--orange-deep);margin-bottom:1rem}
.pillar .ic svg{width:30px;height:30px}
.pillar h3{color:var(--navy);margin-bottom:.45rem}
.pillar p{color:var(--ink-soft);font-size:.97rem;margin:0}
.section--navy .pillar{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14)}
.section--navy .pillar h3{color:#fff}
.section--navy .pillar p{color:rgba(255,255,255,.78)}
.section--navy .pillar .ic{background:rgba(221,107,51,.2);color:var(--orange-soft)}
@media (max-width:900px){.pillars{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.pillars{grid-template-columns:1fr}}

/* Stats / counters */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}
.stat .num{font-family:var(--serif);font-weight:700;font-size:clamp(2.2rem,5vw,3.4rem);color:var(--orange-soft);line-height:1}
.section--navy .stat .num{color:var(--orange-soft)}
.stat .lbl{font-weight:600;letter-spacing:.04em;font-size:.92rem;opacity:.9;margin-top:.4rem}
@media (max-width:640px){.stats{grid-template-columns:repeat(2,1fr);gap:1.6rem}}

/* Candidate / split feature */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,5vw,3.5rem);align-items:center}
.split>div{position:relative;z-index:2}   /* le contenu (ex. carte « Le scrutin ») passe toujours au-dessus des vagues décoratives */
.split.rev{grid-template-columns:1.1fr .9fr}
.portrait{
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  background:linear-gradient(160deg,var(--navy),var(--navy-deep));aspect-ratio:4/5;position:relative;
  display:grid;place-items:center;color:rgba(255,255,255,.9);text-align:center;padding:2rem;
}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;z-index:1}
.portrait .ph{font-family:var(--serif);font-size:1.4rem}
.portrait .ph small{display:block;opacity:.7;font-family:var(--sans);font-size:.85rem;margin-top:.5rem;font-style:normal}
.split .tag{display:inline-block;background:rgba(221,107,51,.12);color:var(--orange-deep);font-weight:700;padding:.3rem .8rem;border-radius:999px;font-size:.82rem;margin-bottom:1rem}
@media (max-width:780px){.split,.split.rev{grid-template-columns:1fr}}

/* Manifesto columns */
.manifesto{columns:2;column-gap:3rem}
.manifesto p strong{color:var(--navy)}
.manifesto p b.o{color:var(--orange-deep)}
@media (max-width:780px){.manifesto{columns:1}}
.callout{
  background:var(--cream-2);border-left:4px solid var(--orange);
  padding:1.2rem 1.4rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:1.4rem 0;
}
.checks{list-style:none;margin:1.2rem 0;padding:0;display:grid;gap:.7rem}
.checks li{display:flex;gap:.7rem;align-items:flex-start;font-weight:600;color:var(--navy)}
.checks .ck{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;font-size:.8rem;margin-top:2px}

/* Proposals grid */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .kx{font-family:var(--serif);font-size:1.9rem;color:var(--orange);font-weight:700;line-height:1}
#team-list .card{text-align:center}
.card .team-photo{width:140px;height:140px;border-radius:50%;background:var(--cream-2) center/cover no-repeat;border:4px solid var(--paper);box-shadow:var(--shadow-sm);margin:0 auto 1rem}
.card h3{margin:.7rem 0 .4rem}
.card p{color:var(--ink-soft);font-size:.96rem;margin:0}
.card .det{margin-top:.85rem;border-top:1px solid var(--line);padding-top:.6rem}
.card .det summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:.84rem;color:var(--orange-deep);transition:color .2s}
.card .det summary::-webkit-details-marker{display:none}
.card .det summary::after{content:"+";font-size:1.05rem;line-height:1;font-weight:700}
.card .det[open] summary::after{content:"–"}
.card .det summary:hover{color:var(--orange)}
.card .det p{margin:.6rem 0 0;font-size:.9rem;line-height:1.55}
@media (max-width:860px){.cards{grid-template-columns:1fr}}

/* ====================== SOCIAL WALL ========================== */
.social-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.8rem}
.chip{
  border:1.5px solid var(--line);background:var(--paper);color:var(--navy);
  font-weight:600;font-size:.9rem;padding:.5rem 1rem;border-radius:999px;cursor:pointer;
  transition:.2s var(--ease);display:inline-flex;align-items:center;gap:.4rem;
}
.chip:hover{border-color:var(--orange)}
.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.wall{columns:3;column-gap:1.2rem}
@media (max-width:900px){.wall{columns:2}}
@media (max-width:600px){.wall{columns:1}}
.post{
  break-inside:avoid;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  margin-bottom:1.2rem;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.post:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-head{display:flex;align-items:center;gap:.7rem;padding:1rem 1.1rem .6rem}
.post-av{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:700;flex:0 0 auto}
.post-meta b{display:block;font-size:.95rem;color:var(--navy)}
.post-meta span{font-size:.8rem;color:var(--ink-soft)}
.post-net{margin-left:auto;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:#fff;font-size:.8rem}
.net-facebook{background:#1877f2}.net-instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#bc1888)}
.net-x{background:#111}.net-youtube{background:#ff0000}.net-tiktok{background:#111}.net-linkedin{background:#0a66c2}
.post-media{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--navy),var(--orange));display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:1.1rem;text-align:center;padding:1rem}
.post-media.has-img{background-size:cover;background-position:center;background-repeat:no-repeat;padding:0;align-items:end;justify-items:stretch}
.post-media.has-img .post-cap{align-self:end;padding:1.6rem .95rem .7rem;background:linear-gradient(transparent,rgba(22,49,79,.85));font-size:.98rem;text-align:left;line-height:1.25;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.post-body{padding:.9rem 1.1rem 1.1rem}
.post-body p{font-size:.95rem;margin:0 0 .7rem}
.post-foot{display:flex;gap:1.1rem;color:var(--ink-soft);font-size:.85rem;font-weight:600}
.post-foot a{color:var(--orange-deep)}
.post-foot .sp{margin-left:auto}

/* Galerie « sur le terrain » */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.gphoto{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);grid-row:span 1;grid-column:span 1}
.gphoto--wide{grid-column:span 2}
.gphoto--tall{grid-row:span 2}
.gphoto img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.gphoto:hover img{transform:scale(1.06)}
.gphoto figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.5rem .9rem .7rem;color:#fff;font-family:var(--serif);font-size:1rem;line-height:1.2;background:linear-gradient(transparent,rgba(22,49,79,.85));text-shadow:0 1px 2px rgba(0,0,0,.4)}
@media (max-width:860px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}.gphoto--wide{grid-column:span 2}.gphoto--tall{grid-row:span 2}}
@media (max-width:520px){.gallery{grid-template-columns:1fr;grid-auto-rows:230px}.gphoto--wide,.gphoto--tall{grid-column:span 1;grid-row:span 1}}

/* Affiches des réunions (posters portrait) */
.posters{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.1rem}
.poster{display:block;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--paper);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.poster:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.poster img{width:100%;height:auto;display:block}
@media (max-width:520px){.posters{grid-template-columns:repeat(2,1fr);gap:.7rem}}

/* Trombinoscope (visages de l'équipe) */
.trombi{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.1rem}
.tcard{margin:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:4/5;background:var(--cream-2)}
.tcard img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .45s var(--ease)}
.tcard:hover img{transform:scale(1.05)}
@media (max-width:520px){.trombi{grid-template-columns:repeat(2,1fr);gap:.7rem}}

/* Bandeau photo équipe */
.team-banner{margin:0 0 2.4rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.team-banner img{width:100%;height:auto;display:block}

/* Bloc citation simple */
.quote-band{text-align:center;padding:clamp(2.2rem,5vw,3.6rem) 0}
.quote-band blockquote{max-width:30ch;margin:0 auto;font-family:var(--serif);font-weight:700;font-size:clamp(1.5rem,3.4vw,2.3rem);line-height:1.16;color:var(--navy)}
.quote-band blockquote .o{color:var(--orange-deep)}
.quote-band cite{display:block;margin-top:.9rem;font-style:normal;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;color:var(--orange-deep)}

/* Bandeau photo + citation (pleine largeur) */
.cta-photo{position:relative;overflow:hidden;color:#fff;text-align:center;padding:clamp(3.5rem,9vw,6.5rem) 1rem;background:var(--navy-deep)}
.cta-photo::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(22,49,79,.6),rgba(22,49,79,.82)),var(--bg) center 38%/cover no-repeat;pointer-events:none}
.cta-photo>.wrap{position:relative;z-index:2}
.cta-photo blockquote{max-width:26ch;margin:0 auto 1.5rem;font-family:var(--serif);font-weight:700;font-size:clamp(1.55rem,3.8vw,2.7rem);line-height:1.14;text-shadow:0 2px 14px rgba(0,0,0,.35)}
.cta-photo cite{display:block;margin:-.4rem 0 1.7rem;font-style:normal;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;color:#f0a877}

/* News list */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media (max-width:860px){.news-grid{grid-template-columns:1fr}}
.news{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.news:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.news .cover{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,var(--navy),var(--navy-soft)) center/cover no-repeat;display:grid;place-items:center;color:rgba(255,255,255,.85);font-family:var(--serif)}
.news .cover-play{width:58px;height:58px;border-radius:50%;background:rgba(221,107,51,.95);color:#fff;display:grid;place-items:center;font-size:1.2rem;padding-left:5px;box-shadow:0 8px 24px rgba(22,49,79,.4);transition:transform .3s var(--ease)}
.news:hover .cover-play{transform:scale(1.12)}
.news .body{padding:1.3rem;display:flex;flex-direction:column;flex:1}
.news .date{font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--orange-deep)}
.news h3{font-size:1.15rem;margin:.4rem 0 .6rem}
.news p{color:var(--ink-soft);font-size:.95rem;flex:1}
.news .more{font-weight:700;color:var(--navy);display:inline-flex;gap:.4rem;align-items:center}

/* ===================== FORMS ============================= */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.4rem,4vw,2.4rem);box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;color:var(--navy);margin-bottom:.4rem;font-size:.95rem}
.field input,.field textarea,.field select{
  width:100%;font:inherit;color:var(--ink);background:var(--white);
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.85rem 1rem;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 4px rgba(221,107,51,.14)}
.field textarea{min-height:130px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:560px){.grid-2{grid-template-columns:1fr}}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.88rem;color:var(--ink-soft);margin:.6rem 0 1.2rem}
.consent input{margin-top:.25rem;width:18px;height:18px;flex:0 0 auto;accent-color:var(--orange)}
.form-msg{display:none;padding:.9rem 1.1rem;border-radius:var(--radius-sm);font-weight:600;margin-bottom:1rem}
.form-msg.ok{display:block;background:rgba(47,143,91,.12);color:var(--ok);border:1px solid rgba(47,143,91,.3)}
.form-msg.err{display:block;background:rgba(196,84,31,.12);color:var(--orange-deep);border:1px solid rgba(196,84,31,.3)}

/* Newsletter band */
.nl{background:linear-gradient(135deg,var(--orange),var(--orange-deep));color:#fff;border-radius:var(--radius);padding:clamp(1.6rem,4vw,2.8rem);box-shadow:var(--shadow)}
.nl h2{color:#fff}
.nl .lead{color:rgba(255,255,255,.92)}
.nl form{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.2rem}
.nl input[type=email]{flex:1;min-width:220px;border:0;border-radius:999px;padding:.95rem 1.3rem;font:inherit}
.nl input[type=email]:focus{outline:3px solid rgba(255,255,255,.6)}
.nl .btn{background:var(--navy);border-color:var(--navy);box-shadow:none}
.nl .btn:hover{background:var(--navy-deep);border-color:var(--navy-deep)}
.nl .consent{color:rgba(255,255,255,.9)}
.nl .consent a{color:#fff;text-decoration:underline}
.nl .form-msg.ok{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.4)}

/* ====================== CTA strip ========================== */
.cta-strip{background:var(--navy);color:#fff;text-align:center;padding:clamp(3rem,7vw,5rem) 0}
.cta-strip h2{color:#fff}
.bigslogan{font-family:var(--serif);font-weight:700;line-height:1.05;font-size:clamp(2rem,6vw,4rem);letter-spacing:.01em}
.bigslogan .o{color:var(--orange)}
.cta-strip .actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.6rem}

/* ========================= FOOTER ========================== */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.82);padding:clamp(2.6rem,6vw,4rem) 0 1.4rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
.site-footer h4{color:#fff;font-family:var(--sans);font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.site-footer a{color:rgba(255,255,255,.8);display:block;padding:.25rem 0;transition:color .2s,transform .2s}
.site-footer a:hover{color:var(--orange-soft);transform:translateX(3px)}
.foot-brand img{height:30px;margin-bottom:1rem;filter:brightness(0) invert(1)}
.foot-brand p{font-size:.95rem;max-width:34ch}
.socials{display:flex;gap:.6rem;margin-top:1rem}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center;padding:0}
.socials a:hover{background:var(--orange);transform:translateY(-3px)}
.socials svg{width:18px;height:18px;fill:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:2.4rem;padding-top:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;opacity:.8}
.foot-bottom a{display:inline}
.site-footer .foot-info{display:block;padding:.25rem 0;color:rgba(255,255,255,.8);font-size:.95rem}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.foot-grid{grid-template-columns:1fr}}

/* ===================== Cookie banner ======================= */
.cookie{
  position:fixed;left:50%;transform:translateX(-50%) translateY(140%);
  bottom:18px;width:min(960px,94%);z-index:80;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:1.2rem 1.4rem;
  display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;transition:transform .5s var(--ease);
}
.cookie.show{transform:translateX(-50%) translateY(0)}
.cookie p{margin:0;font-size:.9rem;color:var(--ink-soft);flex:1;min-width:240px}
.cookie p b{color:var(--navy)}
.cookie .c-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie .btn{padding:.7rem 1.2rem;font-size:.92rem;box-shadow:none}

/* page hero (interior) */
.phero{background:var(--navy);color:#fff;padding:clamp(3rem,7vw,5rem) 0 clamp(2.6rem,6vw,4rem);position:relative;overflow:hidden}
/* fond paysage fondu pour les heros de page (voile navy, texte blanc lisible) — image via --phero-img */
.phero--bg::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(180deg, var(--pv-top,rgba(22,49,79,.70)) 0%, var(--pv-mid,rgba(22,49,79,.76)) 55%, var(--pv-bot,rgba(22,49,79,.90)) 100%),
    var(--phero-img) var(--phero-pos,center 42%)/cover no-repeat;
  filter:var(--phero-filter, blur(2px) saturate(.8));
}
.phero--bg>.wrap{position:relative;z-index:2}
.phero::after{content:"";position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(221,107,51,.35),transparent 70%)}
.phero h1{color:#fff;position:relative}
.phero .lead{color:rgba(255,255,255,.85);max-width:60ch;position:relative}
.crumbs{font-size:.85rem;color:rgba(255,255,255,.7);margin-bottom:1rem}
.crumbs a{color:rgba(255,255,255,.85)}

/* prose for legal pages */
.prose{max-width:75ch}
.prose h2{margin-top:2.2rem;font-size:1.5rem}
.prose h3{margin-top:1.5rem;font-size:1.15rem}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--orange-deep);text-decoration:underline}

/* ==================== Scroll reveal ======================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* countdown */
.countdown{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.4rem}
.cd-box{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:.8rem 1.1rem;text-align:center;min-width:78px}
.cd-box b{font-family:var(--serif);font-size:2rem;display:block;line-height:1;color:#fff}
.cd-box span{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;opacity:.8}

/* utility */
.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}
/* ---- Liste cliquable + fiche candidat (popup) ---- */
.roster .team-item{cursor:pointer;transition:background .15s}
.roster .team-item:hover,.roster .team-item:focus-visible{background:var(--cream-2)}
.roster .team-item .team-go{margin-left:auto;color:var(--orange);font-weight:700;font-size:1.25rem;opacity:.4;transition:opacity .15s,transform .15s}
.roster .team-item:hover .team-go,.roster .team-item:focus-visible .team-go{opacity:1;transform:translateX(3px)}
.fp-modal{position:fixed;inset:0;z-index:9000;display:none;place-items:center;padding:1.2rem;background:rgba(13,34,64,.55);backdrop-filter:blur(3px)}
.fp-modal.show{display:grid;animation:fpFadeIn .2s ease}
.fp-modal-card{position:relative;width:min(540px,100%);max-height:92vh;overflow:auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:heroPop .35s var(--ease)}
.fp-modal-x{position:absolute;top:.6rem;right:.6rem;z-index:3;width:38px;height:38px;border:0;border-radius:50%;background:rgba(255,255,255,.9);color:var(--navy);font-size:1.6rem;line-height:1;cursor:pointer;box-shadow:var(--shadow-sm)}
.fp-modal-x:hover{background:var(--orange);color:#fff}
.fp-modal-photo{width:100%;height:300px;background:var(--cream-2) center/cover no-repeat}
.fp-modal-photo--ph{display:grid;place-items:center;font:800 3rem var(--serif);color:#fff;background:linear-gradient(135deg,var(--navy),var(--navy-soft))}
.fp-modal-txt{padding:1.5rem 1.8rem 2rem}
.fp-modal-num{font:700 .74rem var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--orange-deep)}
.fp-modal-txt h3{font-size:1.55rem;margin:.25rem 0 .3rem;color:var(--navy)}
.fp-modal-txt h3 b{font-weight:800}
.fp-modal-role{color:var(--orange-deep);font-weight:600;margin:0 0 .9rem}
.fp-modal-bio{color:var(--ink-soft);margin:0}
@keyframes fpFadeIn{from{opacity:0}to{opacity:1}}
@media(max-width:560px){.fp-modal-photo{height:230px}}
@media(prefers-reduced-motion:reduce){.fp-modal.show,.fp-modal-card{animation:none}}
.center{text-align:center}
.mt-2{margin-top:2rem}.mt-1{margin-top:1rem}
.muted{color:var(--ink-soft)}
hr.soft{border:0;border-top:1px solid var(--line);margin:2.5rem 0}

/* =========================================================================
   ENHANCEMENTS — le plus beau & dynamique du Pacifique 🌊
   ========================================================================= */

/* --- Scroll progress bar --- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;
  background:linear-gradient(90deg,var(--orange),var(--sunset),var(--lagoon));
  box-shadow:0 0 12px rgba(221,107,51,.55);transition:width .08s linear}

/* --- Back to top --- */
.to-top{position:fixed;right:18px;bottom:18px;z-index:70;width:50px;height:50px;border-radius:50%;
  background:var(--navy);color:#fff;border:0;cursor:pointer;display:grid;place-items:center;
  box-shadow:var(--shadow);opacity:0;transform:translateY(20px) scale(.85);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{background:var(--orange);transform:translateY(-4px)}
.to-top svg{width:22px;height:22px}

/* --- Hero animated ambiance --- */
.hero{isolation:isolate}
.hero .wrap{z-index:3}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero-mesh{position:absolute;inset:-25%;
  background:
    radial-gradient(38% 48% at 14% 22%, rgba(221,107,51,.20), transparent 60%),
    radial-gradient(42% 52% at 86% 14%, rgba(32,64,106,.18), transparent 62%),
    radial-gradient(48% 58% at 72% 92%, rgba(47,159,176,.20), transparent 62%);
  filter:blur(8px);animation:meshFloat 20s ease-in-out infinite alternate}
@keyframes meshFloat{to{transform:translate3d(3%,-3%,0) scale(1.1)}}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;z-index:2;line-height:0;pointer-events:none}
.hero-wave svg{width:100%;height:clamp(50px,8vw,100px);display:block}

/* Hero variante bannière (affiche officielle) */
.hero--banner{padding-top:clamp(1.4rem,4vw,2.8rem);padding-bottom:clamp(3rem,7vw,5rem)}
/* fond d'écran lagon estompé (header accueil) */
.hero--banner::before{
  content:"";display:block;position:absolute;inset:-12px;z-index:0;
  width:auto;height:auto;max-width:none;aspect-ratio:auto;
  background:
    linear-gradient(180deg, rgba(244,246,249,.56) 0%, rgba(244,246,249,.66) 45%, rgba(244,246,249,.84) 74%, rgba(244,246,249,.95) 100%),
    url('../img/hero-bg-lagon.jpg?v=pano') center 45%/cover no-repeat;
  filter:blur(2px) saturate(.78);
  clip-path:none;opacity:1;
  pointer-events:none;
}
/* sur l'accueil, le fond lagon prime : on retire le voile "mesh" qui le délavait */
.hero--banner .hero-mesh{display:none}
.hero--banner .hero-sub{color:var(--navy);text-shadow:0 1px 10px rgba(244,246,249,.9)}
.hero--banner .wrap{display:grid;grid-template-columns:auto minmax(0,1fr);gap:clamp(1.4rem,4vw,3.4rem);align-items:center;text-align:left;max-width:1100px}
.hero-banner{margin:0;max-width:380px;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);border:1px solid var(--line);background:var(--paper);line-height:0}
.hero-banner img{width:100%;height:auto;display:block}
.hero--banner .hero-sub{max-width:44ch;margin:0 0 1.4rem;text-align:left}
.hero--banner .hero-actions{justify-content:flex-start}
.hero--banner .hero-signature{margin-top:1.4rem;text-align:left}
@media (max-width:820px){
  .hero--banner .wrap{grid-template-columns:1fr;justify-items:center;text-align:center}
  .hero-banner{margin:0 auto 1.3rem;max-width:330px}
  .hero--banner .hero-sub{max-width:60ch;text-align:center}
  .hero--banner .hero-actions{justify-content:center}
  .hero--banner .hero-signature{text-align:center}
}

/* parallax helpers */
.parallax{will-change:transform}

/* --- Section wave dividers (injectées sur les sections sombres) --- */
.wave-top{position:absolute;top:0;left:0;right:0;line-height:0;transform:translateY(-99%);pointer-events:none;z-index:1}
.wave-top svg{width:100%;height:clamp(40px,6vw,80px);display:block}
.section--navy,.cta-strip{overflow:visible}
.section--navy>.wrap,.cta-strip>.wrap{position:relative;z-index:2}

/* --- 3D tilt cards --- */
.tilt{transform-style:preserve-3d;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.tilt .ic,.tilt .kx,.tilt h3{transform:translateZ(28px)}

/* --- Hero entrance (staggered) --- */
@media (prefers-reduced-motion:no-preference){
  .hero h1,.hero .hero-kicker,.hero .hero-sub,.hero .hero-actions,.hero .hero-signature{
    opacity:0;animation:heroUp .9s var(--ease) forwards}
  .hero .hero-kicker{animation-delay:.05s}
  .hero h1{animation-delay:.15s}
  .hero .hero-sub{animation-delay:.32s}
  .hero .hero-actions{animation-delay:.46s}
  .hero .hero-signature{animation-delay:.6s}
  .hero .hero-card{opacity:0;animation:heroPop 1s var(--ease) .5s forwards}
}
@keyframes heroUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes heroPop{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:none}}

/* shimmering gradient on the hero accent word */
.hero h1 .x{background:linear-gradient(100deg,var(--orange),var(--sunset),var(--orange-deep),var(--orange));
  background-size:250% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shine 6s linear infinite}
@keyframes shine{to{background-position:250% 0}}

/* big slogan animated underline */
.bigslogan{position:relative}

/* marquee pause on hover */
.band:hover .track{animation-play-state:paused}

/* pillar glow on hover */
.pillar{will-change:transform}
.pillar .ic{transition:transform .35s var(--ease),background .3s}
.pillar:hover .ic{transform:translateZ(28px) rotate(-6deg) scale(1.08)}

/* portrait subtle sheen */
.portrait::after{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.12) 50%,transparent 60%);
  transform:translateX(-120%);transition:transform .9s var(--ease)}
.split:hover .portrait::after{transform:translateX(120%)}

/* nav brand hover */
.brand:hover img{filter:drop-shadow(0 3px 8px rgba(32,64,106,.25))}

/* footer araucaria horizon */
.foot-horizon{position:relative;line-height:0;margin-bottom:-1px;background:var(--navy-deep)}
.foot-horizon svg{width:100%;height:clamp(70px,10vw,130px);display:block}
.foot-horizon .fh-rip,.foot-horizon .fh-owave{transform-box:fill-box;transform-origin:center;will-change:transform,opacity}
.foot-horizon .fh-rip1{animation:fhDrift 7s ease-in-out infinite}
.foot-horizon .fh-rip2{animation:fhDrift 9.5s ease-in-out infinite reverse}
.foot-horizon .fh-owave{animation:fhSwell 11s ease-in-out infinite}
@keyframes fhDrift{0%,100%{transform:translateX(0);opacity:.45}50%{transform:translateX(20px);opacity:.7}}
@keyframes fhSwell{0%,100%{transform:translateX(0) translateY(0);opacity:.4}50%{transform:translateX(-24px) translateY(-3px);opacity:.65}}
@media (prefers-reduced-motion:reduce){.foot-horizon .fh-rip,.foot-horizon .fh-owave{animation:none}}

/* --- Rubans de vagues animés (hero-wave + séparateurs de sections) --- */
.fpw-rib{transform-box:fill-box;transform-origin:center;will-change:transform}
@media (prefers-reduced-motion:no-preference){
  .fpw-rib1{animation:fpwDrift 9s ease-in-out infinite}
  .fpw-rib2{animation:fpwDrift 13s ease-in-out infinite reverse}
}
@keyframes fpwDrift{0%,100%{transform:translateX(0)}50%{transform:translateX(-16px)}}

/* magnetic button micro-interaction (transform set via JS) */
.btn.magnetic{will-change:transform}

/* count-up cursor for stat */
.stat .num{font-variant-numeric:tabular-nums}

/* page-hero floating araucaria */
.phero .em-float{position:absolute;right:6%;top:50%;transform:translateY(-50%);opacity:.12;width:200px;z-index:0}
.phero .em-float svg{width:100%}

/* reveal scale variant */
.reveal.pop{transform:translateY(26px) scale(.98)}
.reveal.pop.in{transform:none}

/* --- Vidéo (façade RGPD) + revue de presse --- */
.media-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:1.6rem;align-items:start}
@media (max-width:880px){.media-grid{grid-template-columns:1fr}}
.video-embed{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  box-shadow:var(--shadow);background:linear-gradient(135deg,var(--navy),var(--navy-deep))}
.video-embed::before{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 70% at 50% 45%, rgba(221,107,51,.28), transparent 70%);opacity:.9}
/* Miniature YouTube (servie en local par yt-thumb.php, RGPD) */
.video-embed.has-thumb{background-image:var(--vthumb),linear-gradient(135deg,var(--navy),var(--navy-deep));background-size:cover;background-position:center}
.video-embed.has-thumb::before{background:linear-gradient(180deg,rgba(13,34,64,.20) 0%,rgba(13,34,64,0) 30%,rgba(13,34,64,0) 50%,rgba(13,34,64,.80) 100%);opacity:1}
.video-embed .poster{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.4rem 1.5rem;color:#fff;z-index:2;background:none}
.video-embed .poster .kk{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-soft)}
.video-embed .poster .ttl{font-family:var(--serif);font-size:clamp(1.2rem,2.4vw,1.7rem);line-height:1.15;margin-top:.3rem;max-width:26ch}
.video-embed .play{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);
  width:80px;height:80px;border-radius:50%;border:0;cursor:pointer;background:var(--orange);color:#fff;
  display:grid;place-items:center;box-shadow:0 12px 34px rgba(221,107,51,.55);transition:transform .3s var(--ease),background .25s;z-index:3}
.video-embed:hover .play{transform:translate(-50%,-50%) scale(1.1);background:var(--orange-deep)}
.video-embed .play svg{width:30px;height:30px;margin-left:5px}
.video-embed .play::after{content:"";position:absolute;inset:-10px;border-radius:50%;border:2px solid var(--orange-soft);opacity:.55;animation:vpulse 2.4s ease-out infinite}
@keyframes vpulse{to{transform:scale(1.55);opacity:0}}
.video-embed .badge{position:absolute;top:14px;left:14px;background:#ff0000;color:#fff;font-size:.7rem;font-weight:700;
  padding:.28rem .6rem;border-radius:6px;letter-spacing:.05em;z-index:3;display:inline-flex;align-items:center;gap:.35rem}
.video-embed .rgpd{position:absolute;top:14px;right:14px;background:rgba(0,0,0,.45);color:rgba(255,255,255,.92);
  font-size:.7rem;padding:.28rem .6rem;border-radius:6px;z-index:3}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:5}
.video-embed.is-playing .poster,.video-embed.is-playing .play,.video-embed.is-playing::before{display:none}

.press{display:grid;gap:1rem}
.press-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:block}
.press-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.press-card .src{display:flex;align-items:center;gap:.5rem;font-weight:700;color:var(--navy);font-size:.9rem}
.press-card .src .logo{background:var(--navy);color:#fff;font-size:.68rem;font-weight:700;padding:.18rem .45rem;border-radius:5px;letter-spacing:.04em}
.press-card .date{font-size:.78rem;color:var(--ink-soft);margin:.3rem 0 .5rem}
.press-card h3{font-size:1.1rem;margin:0 0 .5rem}
.press-card .quote{font-style:italic;color:var(--ink-soft);font-size:.95rem;border-left:3px solid var(--orange);padding-left:.8rem;margin:.6rem 0}
.press-card .more{font-weight:700;color:var(--orange-deep);display:inline-flex;gap:.35rem;align-items:center}
.press-card .more .arr{transition:transform .25s var(--ease)}
.press-card:hover .more .arr{transform:translateX(4px)}

/* ---- Carte interactive (Leaflet) ---- */
.fp-map{height:clamp(340px,54vh,480px);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);position:relative;z-index:0;background:var(--cream-2)}
.fp-map .leaflet-control-attribution{font-size:.65rem}
.fp-pin{width:32px;height:32px;border-radius:50%;background:var(--orange);color:#fff;border:2px solid #fff;
  box-shadow:0 3px 10px rgba(22,49,79,.45);display:flex;align-items:center;justify-content:center;font:700 13px/1 var(--sans)}
.fp-pin.past{background:var(--ink-soft)}
.leaflet-popup-content{font-family:var(--sans);font-size:.9rem;line-height:1.4;margin:.7rem .9rem}
.leaflet-popup-content b{font-family:var(--serif);color:var(--navy)}

/* ---- Agenda / événements ---- */
.event{display:flex;gap:1.2rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.4rem;margin-bottom:1rem;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.event:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.event.past{opacity:.55}
.event-date{flex:0 0 auto;width:66px;text-align:center;background:var(--navy);color:#fff;border-radius:14px;padding:.6rem .3rem;height:fit-content}
.event-date b{font-family:var(--serif);font-size:1.9rem;display:block;line-height:1}
.event-date span{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;opacity:.85}
.event.past .event-date{background:var(--ink-soft)}
.event-body{flex:1;min-width:0}
.event-type{display:inline-block;background:rgba(221,107,51,.12);color:var(--orange-deep);font-weight:700;font-size:.74rem;padding:.2rem .6rem;border-radius:99px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem}
.event-body h3{margin:.1rem 0 .3rem;font-size:1.2rem}
.event-meta{color:var(--ink-soft);font-size:.9rem;font-weight:600;margin:0 0 .5rem}
.event-body p{color:var(--ink-soft);font-size:.95rem;margin:0 0 .5rem}

/* ---- Texture grain papier (effet imprimé, subtil) ---- */
.section--navy::after,.cta-strip::after,.hero::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.07;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.section--navy>.wrap,.cta-strip>.wrap,.hero>.wrap{position:relative;z-index:2}

/* ---- Loader d'entrée ---- */
.fp-loader{position:fixed;inset:0;z-index:9999;background:radial-gradient(120% 100% at 50% 0%, var(--paper), var(--cream-2));
  display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.fp-loader.hidden{opacity:0;visibility:hidden}
.fp-loader-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.7rem;padding:1rem}
.fp-loader .em{width:96px;height:96px;animation:fpFloat 2.2s ease-in-out infinite}
@keyframes fpFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-9px) scale(1.04)}}
.fp-loader-logo{width:min(280px,72vw);height:auto;animation:fpFloat 2.6s ease-in-out infinite}
.fp-gate-logo{width:min(220px,62vw);height:auto;display:block;margin:0 auto .9rem}
.fp-loader-name{font-family:var(--serif);font-weight:700;font-size:clamp(1.5rem,5vw,2rem);letter-spacing:.04em;color:var(--orange);margin-top:.3rem}
.fp-loader-name b{color:var(--navy)}
.fp-loader-tag{font-family:var(--script);font-weight:700;color:var(--ink-soft);font-size:1.25rem;line-height:1}
.fp-loader-bar{width:170px;height:4px;border-radius:99px;background:rgba(32,64,106,.14);overflow:hidden;margin-top:.5rem;position:relative}
.fp-loader-bar span{position:absolute;left:0;top:0;height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--orange),var(--sunset),var(--lagoon));animation:fpFill 2.8s var(--ease) forwards}
@keyframes fpFill{0%{width:0}85%{width:92%}100%{width:100%}}

/* ---- Accessibilité : skip link + focus visible ---- */
.skip-link{position:fixed;top:-70px;left:12px;z-index:10001;background:var(--navy);color:#fff;
  padding:.7rem 1.1rem;border-radius:0 0 12px 12px;font-weight:700;text-decoration:none;transition:top .2s var(--ease)}
.skip-link:focus{top:0}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,
.video-embed:focus-visible,.chip:focus-visible,.burger:focus-visible{outline:3px solid var(--orange);outline-offset:2px;border-radius:6px}

/* ---- Bouton d'installation PWA ---- */
.pwa-install{position:fixed;left:18px;bottom:18px;z-index:65;display:none;align-items:center;gap:.5rem;
  background:var(--paper);color:var(--navy);border:1.5px solid var(--line);border-radius:99px;
  padding:.65rem 1.1rem;font:700 .9rem var(--sans);cursor:pointer;box-shadow:var(--shadow)}
.pwa-install.show{display:inline-flex;animation:heroPop .4s var(--ease)}
.pwa-install:hover{border-color:var(--orange);color:var(--orange-deep)}

/* ---- Gate d'accès (pré-lancement) ---- */
.fp-gate{position:fixed;inset:0;z-index:10000;padding:1.5rem;display:grid;place-items:center;
  background:radial-gradient(120% 90% at 50% -10%, rgba(221,107,51,.14), transparent 55%),linear-gradient(160deg,var(--cream),#DCE3EC)}
.fp-gate.hidden{opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.fp-gate-card{width:min(400px,100%);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:2.2rem;text-align:center;animation:heroPop .5s var(--ease)}
.fp-gate .em{width:66px;height:66px;margin:0 auto .8rem}
.fp-gate h2{color:var(--navy);font-size:1.4rem;margin:0 0 .3rem}
.fp-gate p{color:var(--ink-soft);font-size:.92rem;margin:0}
.fp-gate input{width:100%;text-align:center;font-size:1.3rem;letter-spacing:.35em;font-family:var(--sans);
  padding:.8rem;border:1.5px solid var(--line);border-radius:12px;margin:1.2rem 0 .4rem;background:#fff}
.fp-gate input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 4px rgba(221,107,51,.14)}
.fp-gate .err{color:var(--orange-deep);font-size:.85rem;min-height:1.3em;margin-bottom:.4rem;font-weight:600}

@media (prefers-reduced-motion:reduce){
  .fp-gate-card{animation:none}
  .fp-loader .em,.fp-loader-bar span{animation:none}
  .video-embed .play::after{animation:none}
  .hero-mesh,.hero h1 .x{animation:none}
  .hero h1,.hero .hero-kicker,.hero .hero-sub,.hero .hero-actions,.hero .hero-signature,.hero .hero-card{opacity:1;animation:none}
  .hero h1 .x{color:var(--orange);background:none;-webkit-text-fill-color:initial}
}
