/* ============== VARIABLES ============== */
:root {
  --c-blue-900: #07346E;
  --c-blue-100: #0477BF;
  --c-white: #F5FBFE;
  --c-gold: #FDC514;

  --h1-size: 3rem;
  --h1-weight: 600;
  --h1-style: italic;
  --h1-color: var(--c-white);

  --h2-size: 2rem;
  --h2-weight: 600;
  --h2-style: italic;
  --h2-color: var(--c-blue-900);

  --h3-size: 1.5rem;
  --h3-weight: 600;
  --h3-style: italic;
  --h3-color: var(--c-blue-900);

  --p-size: 1rem;
  --p-weight: 400;
  --p-style: italic;
  --p-color: var(--c-blue-900);

  --panel-text-size: 0.65rem;
  --s-size: 0.85rem;
  --svg-size: 1rem;
  --cta-gap: 20px;

  --gutter: clamp(16px, 4vw, 48px);
  --line-w: 2px;
  --line-color: var(--c-white);
  --adminbar-h: var(--wp-admin--admin-bar--height, 32px);
  --header-offset: 0;
  --header-h: 0;
  --hero-h: min(88vh, 820px);

  --cuf-panel-w: 420px;
  --cuf-ease: cubic-bezier(.2,.7,.2,1);
  --line-bottom: 30px;

  --cuf-offcanvas-footer-h: 280px;
  --cuf-phare-max-w: 520px;

  --ha-panel-w: 280px;
  --ha-handle-w: 26px;
  --ha-top: 30vh;
}

/* ============== PRÉ-REGLAGES SECTIONS ============== */
.home .hero { --cut-top: calc(var(--header-offset) + var(--adminbar-h)); --cut-height: var(--header-h); }
.asso-banner { --bg-x: 55%; --bg-y: 38%; }
#educateurs { --title-bottom: clamp(11.7vh, 17.7%, 179px); --line-bottom: clamp(12vh, 18%, 180px); --gap-over-title: 100px; --edu-min: clamp(480px, 62vh, 860px); }
.cuf-temoignages { --title-bottom: clamp(11.7vh, 17.7%, 179px); --gap-over-title: 80px; }

/* ============== BASE & TYPO ============== */
* { box-sizing: border-box; }
body { margin: 0; padding: 0; background-color: var(--c-white); }
h1 { font-size: var(--h1-size); font-weight: var(--h1-weight); font-style: var(--h1-style); color: var(--h1-color); text-transform: uppercase; }
h2 { font-size: var(--h2-size); font-weight: var(--h2-weight); font-style: var(--h2-style); color: var(--h2-color); text-transform: uppercase; }
h3 { font-size: var(--h3-size); font-weight: var(--h3-weight); font-style: var(--h3-style); color: var(--h3-color); text-transform: uppercase; }
p, span, li, a, .cuf-shop__badge { font-size: var(--p-size); font-weight: var(--p-weight); font-style: var(--p-style); color: var(--p-color); text-transform: uppercase; }
.skip-link { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { position:fixed; left:1rem; top:1rem; width:auto; height:auto; padding:.5rem .75rem; background:#000; color:#fff; border-radius:.25rem; z-index:10000; }

/* Focus visible global: ne JAMAIS l’enlever */
:where(a,button,[role="button"],input,select,textarea):focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}


/* ============== HEADER + OFF-CANVAS MENU ============== */
.site-header { position: absolute; left: 0; right: 0; z-index: 1000; margin-top: 50px; background: rgba(255,255,255,0.7); padding: 5px 30px; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.admin-bar .site-header { top: calc(28px + var(--adminbar-h)); }
.header-content { display: flex; justify-content: space-between; align-items: center; }

.header-top-right { position: absolute; top: 10px; right: 40px; display: flex; gap: 10px; z-index: 1100; }
.admin-bar .header-top-right { top: calc(10px + var(--adminbar-h)); }
.header-top-right a { text-decoration: none; color: var(--c-white); }

.header-logo { font-size: var(--h2-size); }
.header-logo img { height: 50px; }
.header-logo a { display: flex; align-items: center; height: 100%; }
.header-right { display: flex; align-items: center; gap: 15px; }

.lang-dropdown { position: relative; }
.lang-toggle { display: inline-flex; flex-direction: row; align-items: center; gap: 6px; flex-wrap: nowrap; white-space: nowrap; padding: 5px; background: transparent; border: none; cursor: pointer; }
.lang-toggle > * { flex: 0 0 auto; }
.lang-toggle .lang-flag { display: inline-block; font-size: var(--svg-size); line-height: 1; vertical-align: middle; }
.lang-toggle i { line-height: 1; font-size: 1em; color: var(--c-blue-900); }
.lang-menu { position: absolute; top: 100%; right: 0; z-index: 999; display: none; padding: 5px 0; min-width: 40px; text-align: center; background-color: rgba(255,255,255,0.7); border-radius: 6px; box-shadow: 0 4px 12px rgba(0,0,0,.2); }
.lang-menu li { list-style: none; margin: 0; padding: 0; }
.lang-menu li a { display: flex; align-items: center; justify-content: center; width: 40px; height: 30px; margin: 1px 0; border-radius: 4px; text-decoration: none; }
.lang-menu li a:hover { background-color: var(--c-white); }
.lang-dropdown.is-open .lang-menu,
.lang-dropdown:focus-within .lang-menu { display: block; }

.burger-menu { display: flex; flex-direction: column; gap: 4px; cursor: pointer; }
.burger-menu span { width: 25px; height: 3px; background-color: var(--c-blue-900); transition: 0.3s; }

/* Intro overlay */
#intro-anim { position: fixed; inset: 0; background: #fff; z-index: 99999; display: grid; place-items: center; opacity: 1; pointer-events: none; }
#intro-anim .intro-inner { position: relative; width: 100%; height: 100%; }
#intro-logo { position: absolute; left: 50%; top: 50%; max-width: 40vw; transform: translate(-50%, -50%); will-change: transform, opacity; }
#intro-anim.is-done { opacity: 0; transition: opacity 250ms ease; }
#intro-welcome { position: absolute; left: 50%; top: calc(50% - clamp(150px, 15vw, 200px)); transform: translate(-50%, -50%); margin: 0; text-align: center; letter-spacing: .02em; opacity: 1; will-change: opacity, transform; }
#intro-welcome-en { position: absolute; left: 50%; top: calc(50% + clamp(150px, 15vw, 200px)); transform: translate(-50%, -50%); margin: 0; text-align: center; letter-spacing: .02em; opacity: 1; will-change: opacity, transform; }
#intro-welcome.fade-out, #intro-welcome-en.fade-out { transition: opacity 220ms ease, transform 220ms ease; opacity: 0; transform: translate(-50%, calc(-50% - 8px)); }

/* Off-canvas CUF */
.cuf-offcanvas { position: fixed; inset: 0 0 0 auto; width: 100vw; max-width: 100vw; height: 100dvh; background: var(--c-white); z-index: 1100; transform: translateX(100%); transition: transform .45s var(--cuf-ease); display: grid; grid-template-rows: auto 1fr auto; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.cuf-offcanvas-ornament { position: absolute; top: 30px; left: 0; right: 0; bottom: 0; pointer-events: none; opacity: .10; z-index: 1; background-image: url("assets/images/phare-bleu.png"); background-repeat: no-repeat; background-position: left top; background-size: 100% auto; }
.cuf-offcanvas-close { margin: 30px 30px 0 auto; background: transparent; border: 0; font-size: 1.25rem; cursor: pointer; position: relative; z-index: 2; }
.cuf-offcanvas-nav { padding: 2rem 2rem 0 2rem; position: relative; z-index: 2; }

.cuf-menu { list-style: none; margin: 0; padding: 0; }
.cuf-menu > li { margin-bottom: .5rem; }
.cuf-menu a { position: relative; display: flex; align-items: center; gap: 20px; text-decoration: none; padding: .5rem 3rem; color: var(--c-blue-900); transition: color .25s ease; z-index: 0; }
.cuf-menu-icon { flex: 0 0 auto; width: 28px; height: 28px; background-color: currentColor; -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat; -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain; }
.cuf-menu > li.menu-services .cuf-menu-icon { -webkit-mask-image: url("assets/icons/services.svg"); mask-image: url("assets/icons/services.svg"); }
.cuf-menu > li.menu-association .cuf-menu-icon { -webkit-mask-image: url("assets/icons/association.svg"); mask-image: url("assets/icons/association.svg"); }
.cuf-menu > li.menu-educateurs .cuf-menu-icon { -webkit-mask-image: url("assets/icons/educateurs.svg"); mask-image: url("assets/icons/educateurs.svg"); }
.cuf-menu > li.menu-temoignages .cuf-menu-icon { -webkit-mask-image: url("assets/icons/temoignages.svg"); mask-image: url("assets/icons/temoignages.svg"); }
.cuf-menu > li.menu-shop .cuf-menu-icon { -webkit-mask-image: url("assets/icons/shop.svg"); mask-image: url("assets/icons/shop.svg"); }
.cuf-menu > li.menu-galerie .cuf-menu-icon { -webkit-mask-image: url("assets/icons/galerie.svg"); mask-image: url("assets/icons/galerie.svg"); }

.cuf-menu a::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 0; background: var(--c-blue-900); transition: width .25s ease; z-index: -1; clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%); }
.cuf-menu a:hover span { color: var(--c-white) !important; }
.cuf-menu a:hover::before,
.cuf-menu .current-menu-item > a::before { width: 82%; }

.cuf-offcanvas-footer { position: relative; padding: 3rem 1.25rem 3rem; background: var(--c-blue-900); color: var(--c-white); overflow: hidden; z-index: 3; }
.cuf-offcanvas-footer::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 75px; background: var(--c-white); transform: skewY(-10deg); transform-origin: top left; }
.cuf-offcanvas-footer::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(to bottom, var(--c-white) 0, var(--c-white) 100%), linear-gradient(to right, var(--c-white), var(--c-white)); background-repeat: no-repeat, no-repeat; background-size: var(--line-w) 100%, 100% var(--line-w); background-position: left var(--gutter) top, left 0 bottom var(--line-bottom); }
.cuf-offcanvas-footer .cuf-brand { display: grid; place-items: center; }
.cuf-offcanvas-footer img { width: 70px; height: auto; padding-top: 1rem; }
.cuf-brand p { color: var(--c-white) !important; }
.cuf-socials { display: flex; gap: 1rem; justify-content: center; padding-bottom: 1rem; }
.cuf-socials a { color: var(--c-white); font-size: var(--svg-size); }

.cuf-offcanvas-backdrop { position: fixed; inset: 0; background: rgba(10,46,99,.45); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); z-index: 1000; opacity: 0; transition: opacity .35s var(--cuf-ease); }

.cuf-offcanvas.is-open { transform: translateX(0); }
.cuf-offcanvas-backdrop.is-visible { opacity: 1; }
html.cuf-no-scroll, body.cuf-no-scroll { overflow: hidden; }

/* ============== FOOTER ============== */
.site-footer { background-color: var(--c-blue-900); }
.footer-banner { position: relative; height: 280px; overflow: hidden; }
.footer-banner img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: left; z-index: 1; }
.footer-overlay { position: absolute; inset: 0; z-index: 2; padding: 150px 40px 40px 80px; box-sizing: border-box; display: flex; justify-content: space-between; align-items: flex-start; }
.footer-columns { width: 100%; display: flex; justify-content: space-between; }
.footer-title { position: absolute; top: 60px; right: 10px; z-index: 3; white-space: nowrap; color: var(--c-blue-900); font-family: 'Afacad', sans-serif; font-size: var(--h3-size); font-weight: var(--h2-weight); font-style: var(--h2-style); }

.footer-left ul { list-style: none; padding: 0; margin: 0; }
.footer-left li { font-size: var(--s-size); margin-bottom: 6px; }
.footer-left a { color: var(--c-white); text-decoration: none; }
.footer-left a:hover { text-decoration: underline; }

.footer-right { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.footer-contact-label { margin: 0; font-size: var(--s-size); }
.footer-socials { display: flex; gap: 10px; font-size: var(--p-size); }
.footer-socials a { color: var(--c-white); text-decoration: none; }

.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 10px 40px; border-top: 1px solid rgba(255,255,255,0.2); background-color: var(--c-blue-900); font-size: var(--s-size); }
.footer-bottom p { font-size: var(--s-size); color: var(--c-white); }

/* ============== PARTIES FLOTTANTES (top/call/helloasso) ============== */
#scrollTopBtn { position: fixed; bottom: 20px; right: 20px; z-index: 100; width: 48px; height: 48px; border: none; border-radius: 50%; background: var(--c-blue-900); color: var(--c-white); font-size: var(--h3-size); font-weight: bold; cursor: pointer; display: none; align-items: center; justify-content: center; box-shadow: 0 4px 8px rgba(0,0,0,0.3); transition: opacity 0.3s ease; }
#scrollTopBtn:hover { background: var(--c-blue-100); }

.button-call { position: fixed; bottom: 20px; left: 20px; z-index: 100; }
.call-cta { display: inline-flex; align-items: center; justify-content: center; column-gap: 0; width: 48px; height: 48px; border-radius: 999px; text-decoration: none; cursor: pointer; background: var(--c-blue-900); color: var(--c-white); backdrop-filter: blur(4px); transition: background .2s ease, width .25s ease, column-gap .2s ease; overflow: hidden; box-shadow: 0 4px 8px rgba(0,0,0,0.3); }
.call-cta:hover { background: var(--c-blue-100); }
.call-cta i { font-size: var(--svg-size); line-height: 1; color: var(--c-white); flex-shrink: 0; }
.call-cta .label { max-width: 0; opacity: 0; overflow: hidden; white-space: nowrap; transform: translateX(6px); transition: max-width .25s ease, opacity .18s ease, transform .25s ease; color: var(--c-white); margin-right: 12px; }
.call-cta:hover,
.call-cta.is-open { width: auto; padding: 0 15px; justify-content: flex-start; column-gap: .5rem; }
.call-cta:hover .label,
.call-cta.is-open .label { max-width: 220px; opacity: 1; transform: translateX(0); }

.helloasso-backdrop { position: fixed; inset: 0; background: rgba(10,46,99,.45); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); z-index: 1085; opacity: 0; transition: opacity .25s var(--cuf-ease); }
.helloasso-backdrop.is-visible { opacity: 1; }
.helloasso-offcanvas { position: fixed; top: var(--ha-top); right: -26px; width: min(var(--ha-panel-w), 92vw); height: 220px; border-radius: 10px 0 0 10px; background: var(--c-white); z-index: 1095; transform: translateX(calc(100% - var(--ha-handle-w))); transition: transform .35s var(--cuf-ease); padding: 1.5rem; display: grid; grid-template-rows: auto 1fr; }
.helloasso-offcanvas.is-open { transform: translateX(-26px); }
.helloasso-offcanvas::before { content: ""; position: absolute; inset: 0; background-image: url("assets/images/phare-blue.png"); background-repeat: no-repeat; background-position: left top; background-size: 350px auto; opacity: .10; pointer-events: none; z-index: 0; }
.helloasso-offcanvas > * { position: relative; z-index: 1; }
.helloasso-handle { position: absolute; left: calc(-1 * var(--ha-handle-w)); top: 40px; transform: translateY(-50%); width: var(--ha-handle-w); height: 46px; display: grid; place-items: center; padding: 0; border: 0; border-radius: 8px 0 0 8px; background: var(--c-white); cursor: pointer; z-index: 1; }
.helloasso-handle.is-hidden { opacity: 0; pointer-events: none; }
.helloasso-handle .chev { display: block; transform-origin: center; transition: transform .2s ease; }
.helloasso-offcanvas.is-open .helloasso-handle .chev { transform: scaleX(-1); }
.helloasso-title, .helloasso-sub, .helloasso-link { text-align: center; margin: 0 !important; }
.helloasso-sub { padding: 1rem 0; }
.helloasso-link { text-decoration: none; background-color: var(--c-blue-900); color: var(--c-white); padding: .5rem 0; }
html.cuf-no-scroll .helloasso-handle, body.cuf-no-scroll .helloasso-handle { display: none; }

/* ==== TITRES PAGES STATIQUES (CGU, Privacy, Accessibilité) ==== */
.page .entry__header {
  padding-top: clamp(150px, 12vh, 160px);
}

.page .entry__title {
  color: var(--c-blue-900);
  text-align: center;
  margin: 0px auto 40px auto;
  max-width: 90%;
  line-height: 1.2;
}

.page .entry__content { padding: 0 30px 30px 30px; }

/* ============== MEDIA QUERIES ============== */

/* --- MOBILE ≤640px --- */
@media (max-width: 640px) {
  .hero { --hero-h: min(80vw, 520px); }
  .asso-banner { --bg-x: 50%; --bg-y: 30%; }
  .cuf-temoignages { --title-bottom: clamp(5vh, 8%, 60px); --gap-over-title: 60px; }
  .site-header{ margin-top:35px !important; }
}

/* --- TABLET 641–1023px --- */
@media (min-width: 641px) and (max-width: 1023px) {
  :root {
    --h1-size: 4rem; --h1-weight: 700;
    --h2-size: 3rem; --h2-weight: 700;
    --h3-size: 1.8rem; --h3-weight: 700;
    --p-size: 1.2rem;
    --panel-text-size: 1.5rem;
  }
  .site-header{ margin-top:40px !important; }

  #educateurs { --title-bottom: calc(clamp(4vh, 6%, 80px) + 40px); --line-bottom: calc(var(--title-bottom) + 2px); --gap-over-title: 100px; --edu-min: clamp(360px, 60vh, 680px); }
  #intro-welcome { top: calc(50% - clamp(250px, 18vw, 320px)); }
  #intro-welcome-en { top: calc(50% + clamp(250px, 18vw, 320px)); }

  .cuf-offcanvas { width: var(--cuf-panel-w); max-width: min(80vw, var(--cuf-panel-w)); }
  .cuf-offcanvas-nav { padding: 3rem 2rem; }
  .cuf-menu > li { margin-bottom: 2rem; }
}

/* --- DESKTOP ≥1024px --- */
@media (min-width: 1024px) {
  :root {
    --h1-size: 5rem;
    --h2-size: 3.5rem;
    --h3-size: 2.2rem;
    --p-size: 1.5rem;
    --panel-text-size: 1.8rem;
  }

  #intro-welcome { top: calc(50% - clamp(260px, 20vw, 380px)); }
  #intro-welcome-en { top: calc(50% + clamp(260px, 20vw, 380px)); }

  .cuf-offcanvas { width: var(--cuf-panel-w); max-width: min(80vw, var(--cuf-panel-w)); }
  .cuf-offcanvas-nav { padding: 3rem 2rem; }
  .cuf-menu > li { margin-bottom: 2rem; }

  .helloasso-offcanvas { --ha-panel-w: 350px; height: 300px; }
}

/* --- RÉDUCTION MOUVEMENT --- */
@media (prefers-reduced-motion: reduce) {
  #intro-anim { display: none !important; }
  .cuf-offcanvas, .cuf-offcanvas-backdrop, .cuf-menu a, .cuf-menu a::before,
  .helloasso-offcanvas, .helloasso-backdrop, .helloasso-handle { transition: none !important; }
}
