/* ============================================================
   Team Maohi du 49 — feuille de style v4
   Langage visuel repris du landing-dons : papier crème,
   typo manuscrite (Permanent Marker / Anton / Caveat),
   pastilles "brush" organiques, feuilles flottantes,
   cartes blanches arrondies, ombres douces.
   Les couleurs de chaque asso pilotent --brand / --accent
   via .theme-team / .theme-manava / .theme-mixed.
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Identité — Team Maohi du 49 */
  --team-green:#3f7d5b;
  --team-green2:#356a4d;
  --team-green-l:#5a9b76;
  --team-red:#aa2526;
  --team-sand:#e7c98a;

  /* Identité — Manava Anjou VA'A */
  --manava-orange:#f29300;
  --manava-blue:#1f5fb0;
  --manava-blue2:#164a8c;
  --manava-yellow:#fae924;

  /* Socle papier (commun) */
  --paper:#f3ecdd;
  --paper2:#eae0cc;
  --paper3:#e2d6bd;
  --ink:#22384a;
  --muted:#5d6f74;
  --navy:#22384a;          /* sombre fixe (footer, bandeaux) */
  --navy2:#1a2c3a;

  --card-bg:#ffffff;
  --card-line:rgba(34,56,74,.07);
  --shadow:0 14px 40px rgba(34,56,74,.10);
  --shadow-lg:0 24px 58px rgba(34,56,74,.17);
  --leaf:#e2d6bd;

  --r:22px;            /* rayon carte */
  --r-sm:14px;
  --container:1040px;

  /* Polices */
  --f-body:'Montserrat',system-ui,-apple-system,sans-serif;
  --f-display:'Anton',Impact,sans-serif;     /* titres capitales */
  --f-hand:'Permanent Marker',cursive;        /* gros titre héros */
  --f-script:'Caveat',cursive;                /* étiquettes manuscrites */
}

:root[data-theme="dark"]{
  --paper:#141c16;
  --paper2:#1c2620;
  --paper3:#24302a;
  --ink:#eef3ea;
  --muted:#a4b4a6;
  --card-bg:#1d261f;
  --card-line:rgba(255,255,255,.08);
  --shadow:0 16px 44px rgba(0,0,0,.45);
  --shadow-lg:0 26px 60px rgba(0,0,0,.55);
  --leaf:rgba(255,255,255,.05);
}

/* --- Palettes par association ------------------------------- */
body.theme-team{
  --brand:var(--team-green);
  --brand-2:var(--team-green2);
  --brand-l:var(--team-green-l);
  --accent:var(--team-red);
  --brand-soft:#e6efe7;
  --hero-accent:var(--team-sand);
}
body.theme-manava{
  --brand:var(--manava-blue);
  --brand-2:var(--manava-blue2);
  --brand-l:#4a86c9;
  --accent:var(--manava-orange);
  --brand-soft:#e4eefa;
  --hero-accent:var(--manava-yellow);
}
body.theme-mixed{
  --brand:var(--team-green);
  --brand-2:var(--manava-blue);
  --brand-l:var(--team-green-l);
  --accent:var(--manava-orange);
  --brand-soft:#e6efe7;
  --hero-accent:var(--manava-yellow);
}
:root[data-theme="dark"] body.theme-team{--brand-soft:#22311f}
:root[data-theme="dark"] body.theme-manava{--brand-soft:#1b2c44}

/* --- Base -------------------------------------------------- */
html{scroll-behavior:smooth;scroll-padding-top:88px}
body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;position:relative;z-index:2}
main{position:relative;z-index:2}

h1,h2,h3,h4{font-family:var(--f-display);font-weight:400;letter-spacing:.5px;line-height:1.1;text-transform:uppercase}

/* Feuilles décoratives flottantes (injectées par script.js) */
.leaf{position:fixed;color:var(--leaf);opacity:.55;z-index:0;pointer-events:none;will-change:transform}
.leaf svg{display:block}

.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{
  left:1rem;top:1rem;z-index:100;background:#fff;color:var(--navy);
  padding:.8rem 1rem;border-radius:12px;box-shadow:var(--shadow);
}

/* --- Pastille "brush" (signature landing-dons) ------------- */
.brush-pill{
  display:inline-block;background:var(--accent);color:#fff;
  font-family:var(--f-display);letter-spacing:1.5px;text-transform:uppercase;
  padding:2px 26px;
  border-radius:40px 36px 44px 38px/40px 44px 36px 42px;
  transform:rotate(-1.4deg);
  box-shadow:0 8px 22px rgba(34,56,74,.22);
}

/* --- Navigation : crème translucide, douce ----------------- */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--card-line);
}
.nav-container{
  min-height:68px;display:flex;align-items:center;justify-content:space-between;
  gap:1rem;max-width:var(--container);margin:0 auto;padding:0 24px;
}
.nav-logo{display:flex;align-items:center;gap:.6rem;color:var(--ink);font-family:var(--f-display);font-size:1.2rem;letter-spacing:.5px;text-transform:uppercase;min-width:0}
.nav-logo-img{width:42px;height:42px;object-fit:contain;border-radius:50%;background:#fff;padding:3px;box-shadow:0 4px 12px rgba(34,56,74,.12)}
.logo-text{white-space:nowrap}
.logo-text strong{color:var(--brand)}
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none}
.nav-links a{
  color:var(--ink);padding:.5rem .8rem;border-radius:999px;
  font-size:.92rem;font-weight:600;transition:background .18s ease,color .18s ease;
}
.nav-links a:hover,.nav-links a:focus-visible,.nav-links a[aria-current="page"]{background:var(--brand-soft);color:var(--brand)}
.nav-cta{
  background:var(--brand)!important;color:#fff!important;
  font-family:var(--f-display);letter-spacing:1px;text-transform:uppercase;font-size:.86rem;
  box-shadow:0 8px 18px rgba(34,56,74,.18);
}
.nav-cta:hover,.nav-cta:focus-visible{filter:brightness(1.06)}
.nav-toggle{display:none;background:none;border:0;padding:.3rem;cursor:pointer}
.nav-toggle span{display:block;width:25px;height:3px;background:var(--ink);margin:5px 0;border-radius:99px}

.theme-toggle{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.46rem .8rem;border-radius:999px;
  border:2px solid var(--card-line);background:var(--card-bg);
  color:var(--ink);font:inherit;font-size:.86rem;font-weight:700;cursor:pointer;
  transition:background .18s ease,border-color .18s ease;
}
.theme-toggle:hover,.theme-toggle:focus-visible{background:var(--brand-soft);border-color:var(--brand)}
.theme-toggle-icon{font-size:1rem;line-height:1}

/* --- Hero : crème aéré, titre manuscrit -------------------- */
.hero{padding:120px 0 56px;text-align:center;position:relative}
.hero-overlay{display:none}
.hero-content{position:relative;z-index:2;max-width:900px;margin:0 auto;padding:0 24px}
.hero-logo{
  width:118px;margin:0 auto 1.1rem;border-radius:50%;padding:.4rem;background:#fff;
  box-shadow:0 14px 34px rgba(34,56,74,.16);
}
.hero-badge{
  display:inline-block;font-family:var(--f-script);font-size:1.5rem;font-weight:700;
  color:var(--brand);margin-bottom:.5rem;
}
.hero h1{
  font-family:var(--f-hand);font-weight:400;text-transform:none;letter-spacing:1px;
  color:var(--ink);font-size:clamp(2.6rem,9vw,5.4rem);line-height:.96;
  text-shadow:2px 3px 0 rgba(34,56,74,.07);margin-bottom:1rem;
}
.hero h1 .accent{
  display:inline-block;background:var(--accent);color:#fff;
  font-family:var(--f-display);letter-spacing:1.5px;text-transform:uppercase;
  font-size:.82em;padding:0 22px;margin-top:.2em;
  border-radius:40px 36px 44px 38px/40px 44px 36px 42px;
  transform:rotate(-1.4deg);box-shadow:0 8px 22px rgba(34,56,74,.2);
}
.hero-tagline{font-size:clamp(1.05rem,2.2vw,1.35rem);font-weight:600;color:var(--ink);max-width:720px;margin:0 auto .7rem}
.hero-desc{max-width:640px;margin:0 auto 1.7rem;color:var(--muted);font-size:1.02rem}
.hero-actions{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* --- Boutons ----------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  border-radius:14px;padding:.85rem 1.5rem;
  font-family:var(--f-display);letter-spacing:1px;text-transform:uppercase;font-size:1rem;
  border:2px solid transparent;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,filter .2s ease;
}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 12px 26px rgba(34,56,74,.22)}
.btn-primary:hover,.btn-primary:focus-visible{transform:translateY(-3px);box-shadow:0 18px 34px rgba(34,56,74,.28);filter:brightness(1.05)}
.btn-outline{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-outline:hover,.btn-outline:focus-visible{background:var(--ink);color:var(--paper);transform:translateY(-3px)}
.btn-outline-dark{border-color:var(--ink);color:var(--ink);background:var(--card-bg)}
.btn-outline-dark:hover,.btn-outline-dark:focus-visible{background:var(--ink);color:var(--paper);transform:translateY(-3px)}
.btn-lg{padding:1.05rem 1.8rem;font-size:1.12rem}

/* --- Sections & en-têtes ----------------------------------- */
.section{padding:64px 0}
.section-header{max-width:720px;margin:0 auto 2.4rem;text-align:center}
.section-tag{
  display:inline-block;font-family:var(--f-script);font-weight:700;
  font-size:1.7rem;color:var(--brand);text-transform:none;letter-spacing:0;
}
.section-header h2{font-size:clamp(1.7rem,4.4vw,2.6rem);margin-top:.2rem;color:var(--ink)}
.section-header p{color:var(--muted);margin-top:.7rem;font-size:1.02rem}
.lead{font-size:1.12rem;font-weight:500;color:var(--ink)}

/* --- Cartes : blanches, arrondies, ombre douce ------------- */
.card,.about-text,.about-focus,.mission-card,.event-card,.contact-card{
  background:var(--card-bg);border-radius:var(--r);padding:1.7rem;
  box-shadow:var(--shadow);border:1px solid var(--card-line);
}
.card:hover,.mission-card:hover,.event-card:hover,.contact-card:hover,
.about-focus:hover,.about-text:hover{
  transform:translateY(-8px);box-shadow:var(--shadow-lg);
  transition:transform .35s ease,box-shadow .35s ease;
}
.card h3,.about-focus h3,.mission-card h3,.event-card h3,.contact-card h3{
  margin-bottom:.5rem;font-size:1.3rem;color:var(--ink);letter-spacing:.5px;
}
.about-text p+p{margin-top:.9rem;color:var(--muted)}

.focus-list,.icon-list{list-style:none;display:grid;gap:.55rem}
.icon-list li,.focus-list li{display:flex;gap:.7rem;align-items:flex-start;padding:.5rem 0;border-bottom:1px solid var(--card-line);font-weight:500}
.icon-list li:last-child,.focus-list li:last-child{border-bottom:0;padding-bottom:0}
.icon-dot,.focus-icon{width:14px;height:14px;min-width:14px;margin-top:.4rem;flex-shrink:0;border-radius:50%;background:var(--accent);color:transparent}
.focus-icon{display:inline-block}

/* --- Bandeau statistiques : aplat de marque ---------------- */
.stats-bar,.stats{
  color:#fff;padding:40px 0;
  background:linear-gradient(120deg,var(--brand-2),var(--brand));
}
body.theme-mixed .stats-bar,body.theme-mixed .stats{background:linear-gradient(120deg,#356a4d,#1f5fb0)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:center}
.stat{padding:.5rem}
.stat-number{display:block;font-family:var(--f-display);font-size:2.4rem;line-height:1;color:var(--hero-accent)}
.stat-label{display:block;font-size:.86rem;opacity:.92;margin-top:.4rem;font-weight:600}

/* --- Missions / valeurs ------------------------------------ */
.missions{background:var(--paper2)}
.missions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.mission-icon-wrap,.badge-mini{
  display:inline-grid;place-items:center;width:58px;height:58px;border-radius:50%;
  background:radial-gradient(circle at 38% 30%,var(--brand-l),var(--brand-2));
  color:#fff;font-family:var(--f-display);font-size:1.5rem;
  margin-bottom:.9rem;box-shadow:0 8px 20px rgba(34,56,74,.2);
}
.mission-card p{color:var(--muted);font-size:.98rem}

.value-section{padding-top:22px}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.value-card h3{margin:.5rem 0 .55rem;font-size:1.25rem}
.value-card p{color:var(--muted)}
.value-kicker{display:inline-block;font-family:var(--f-script);font-weight:700;font-size:1.4rem;color:var(--accent);text-transform:none;letter-spacing:0}

/* --- Événements -------------------------------------------- */
.events{background:transparent}
.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.events-block+.events-block{margin-top:2.8rem}
.events-block-title{font-family:var(--f-display);font-size:1.5rem;color:var(--ink);margin-bottom:1.2rem;text-transform:uppercase;letter-spacing:.5px}
.events-empty{text-align:center;color:var(--muted);font-family:var(--f-script);font-size:1.5rem;padding:1.5rem 0}
.event-card{position:relative;overflow:hidden}
.event-tag,.event-type{
  display:inline-flex;font-family:var(--f-display);font-size:.78rem;letter-spacing:1px;
  text-transform:uppercase;padding:.32rem .8rem;border-radius:999px;
  background:var(--brand);color:#fff;margin-bottom:.85rem;
}
.event-tag.festival{background:var(--accent)}
.event-tag.portes-ouvertes{background:var(--brand)}
.event-meta{display:grid;gap:.28rem;font-size:.93rem;color:var(--muted);margin:.5rem 0 .85rem;font-weight:500}
.event-link,.text-link{display:inline-block;font-weight:700;color:var(--brand);border-bottom:2px solid transparent;transition:border-color .2s ease}
.event-link:hover,.event-link:focus-visible,.text-link:hover,.text-link:focus-visible{border-color:var(--brand)}

/* --- Spotlight / partenaires ------------------------------- */
.spotlight-section{padding-top:22px}
.spotlight-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.spotlight-card{position:relative}
.single-spotlight{grid-template-columns:1fr}
.spotlight-large{text-align:center;padding:2rem}

/* --- Contact ----------------------------------------------- */
.contact-intro{max-width:700px;margin:0 auto 1.9rem;text-align:center;color:var(--muted)}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.contact-card{text-align:center}
.contact-icon{
  display:inline-grid;place-items:center;min-width:54px;height:54px;padding:0 .6rem;border-radius:50%;
  background:radial-gradient(circle at 38% 30%,var(--brand-l),var(--brand-2));
  color:#fff;font-family:var(--f-display);font-size:1.15rem;margin-bottom:.7rem;box-shadow:0 8px 20px rgba(34,56,74,.18);
}
.contact-card a{color:var(--brand);font-weight:700;word-break:break-word}
.contact-cta{margin-top:1.8rem;text-align:center}

/* --- Bannières inclinées (signature) ----------------------- */
.engagement-section{padding-top:22px}
.engagement-banner{
  display:grid;grid-template-columns:1.1fr .9fr auto;gap:1.4rem;align-items:center;
  background:linear-gradient(100deg,var(--brand-2),var(--brand));color:#fff;
  border-radius:30px 26px 32px 28px;padding:2rem;box-shadow:0 18px 44px rgba(34,56,74,.25);
}
.engagement-banner h2{color:#fff}
.engagement-banner p{opacity:.95}
.engagement-banner .section-tag{color:var(--hero-accent)}
.cta-band{
  background:linear-gradient(100deg,var(--brand-2),var(--brand));color:#fff;
  border-radius:30px 26px 32px 28px;padding:2rem;margin-top:.6rem;
  transform:rotate(-.6deg);box-shadow:0 18px 44px rgba(34,56,74,.28);
}
.cta-band>*{transform:rotate(.6deg)}
.cta-band h3{font-size:1.7rem;color:#fff}
.cta-band p{opacity:.95;margin:.6rem 0 1rem;font-family:var(--f-script);font-size:1.3rem}

/* --- Hero d'accueil (grille) ------------------------------- */
.hero-home-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1.8rem;align-items:center;text-align:left}
.hero-home{text-align:left}
.hero-copy{max-width:600px}
.hero-home .hero-actions{justify-content:flex-start}
.hero-panel,.hero-panel.glass-card{
  background:var(--card-bg);border-radius:var(--r);box-shadow:var(--shadow-lg);
  border:1px solid var(--card-line);color:var(--ink);padding:1.8rem;
}
.hero-panel .hero-logo{margin:0 auto 1rem;box-shadow:0 10px 24px rgba(34,56,74,.14)}
.hero-panel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}
.hero-metric{padding:1.1rem;border-radius:var(--r-sm);background:var(--paper);text-align:center}
.hero-metric strong{display:block;font-family:var(--f-display);font-size:1.9rem;line-height:1;color:var(--brand)}
.hero-metric span{display:block;font-size:.86rem;color:var(--muted);margin-top:.35rem;font-weight:600}

/* --- Bande d'intro ----------------------------------------- */
.intro-strip{padding-top:30px;padding-bottom:20px}
.intro-strip-card{
  text-align:center;font-family:var(--f-script);font-weight:700;font-size:1.7rem;color:var(--ink);
  background:transparent;border:0;box-shadow:none;padding:.5rem 1rem;
}
.intro-strip-card:hover{transform:none;box-shadow:none}

/* --- Sous-grilles ------------------------------------------ */
.about-grid,.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:1.4rem;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.v2-split{align-items:stretch}
.elevated-card{height:100%}

/* --- Pages intérieures ------------------------------------- */
.page-hero .hero-content.narrow-hero{max-width:780px}
.page-intro-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:1.4rem}
.intro-card h2{margin:.4rem 0 .8rem;color:var(--ink)}
.info-card h3{margin-bottom:.6rem}
.compact-section{padding-top:24px}
.legal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.legal-card h2,.legal-card h3{margin-bottom:.55rem;color:var(--ink)}
.legal-card h3{margin-top:1rem}

/* --- Pied de page : navy chaleureux ------------------------ */
.footer{background:var(--navy);color:#fff;padding:50px 0 32px;margin-top:50px;position:relative}
.footer-top{display:flex;flex-wrap:wrap;gap:2rem 2.4rem;justify-content:space-between;padding-bottom:1.6rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand{flex:1 1 280px;max-width:360px}
.footer-col{flex:0 1 auto;min-width:150px}
.footer-brand p{color:#b9c6cd;margin-top:.6rem;font-size:.95rem}
.footer-logos{display:flex;gap:.7rem;margin-bottom:.7rem;flex-wrap:wrap}
.footer-logo{height:50px;width:auto;border-radius:50%;background:#fff;padding:4px}
.footer .logo-text{font-family:var(--f-display);font-size:1.3rem;text-transform:uppercase;display:inline-block}
.footer .logo-text strong{color:var(--brand-l)}
.footer h4{font-family:var(--f-display);font-size:1.05rem;letter-spacing:.5px;text-transform:uppercase;color:#fff;margin-bottom:.7rem}
.footer ul{list-style:none;display:grid;gap:.45rem}
.footer a{color:#cdd8dd;transition:color .2s ease}
.footer a:hover,.footer a:focus-visible{color:#fff}
.footer-contact{display:grid;gap:.45rem;font-size:.93rem;color:#cdd8dd}
.footer-contact .fc-row{display:flex;gap:.5rem;align-items:baseline}
.footer-contact .fc-ico{color:var(--brand-l)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:.8rem 1.4rem;flex-wrap:wrap;padding-top:1.2rem;font-size:.85rem;color:#8ea0a8}
.footer-legal{display:flex;gap:.4rem 1.2rem;flex-wrap:wrap}
.footer-legal a{color:#9fb1b9}
.footer-legal a:hover{color:#fff;text-decoration:underline}
.footer-motto{font-family:var(--f-script);font-size:1.3rem;color:var(--brand-l)}

/* --- Formulaire de contact (page contact) ------------------ */
.contact-form-wrap{max-width:600px;margin:0 auto}
.contact-form{
  background:var(--card-bg);border-radius:var(--r);padding:2rem;
  box-shadow:var(--shadow-lg);border:1px solid var(--card-line);text-align:left;
}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.84rem;color:var(--ink);margin-bottom:.45rem;letter-spacing:.2px}
.field input,.field textarea{
  width:100%;padding:.85rem 1rem;border:2px solid var(--paper2);border-radius:var(--r-sm);
  font-family:inherit;font-size:1rem;color:var(--ink);background:var(--paper);transition:.25s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brand);background:var(--card-bg);box-shadow:0 0 0 4px var(--brand-soft)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field-consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--muted);margin-bottom:1.1rem}
.field-consent input{width:18px;height:18px;margin-top:.15rem;flex-shrink:0;accent-color:var(--brand)}
.field-consent a{color:var(--brand);text-decoration:underline}
.form-submit{width:100%}
.form-note{font-size:.78rem;color:var(--muted);text-align:center;margin-top:1rem}
.form-success{display:none;text-align:center;padding:1.5rem .5rem}
.form-success.show{display:block;animation:pop .5s cubic-bezier(.2,1.3,.4,1)}
@keyframes pop{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:none}}
.form-success .ok{width:78px;height:78px;margin:0 auto 1.1rem;border-radius:50%;background:var(--brand);display:grid;place-items:center}
.form-success .ok svg{width:40px;height:40px;stroke:#fff;stroke-width:4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.form-success h3{font-size:1.5rem;color:var(--ink)}
.form-success p{color:var(--muted);margin-top:.5rem}
.contact-channels{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.4rem}
@media (max-width:620px){.field-row,.contact-channels{grid-template-columns:1fr}}

/* --- CTA mobile flottant ----------------------------------- */
.mobile-contact-cta{
  display:none;position:fixed;left:.8rem;right:.8rem;bottom:.8rem;z-index:60;
  background:var(--brand);color:#fff;text-align:center;padding:.9rem 1rem;border-radius:14px;
  font-family:var(--f-display);letter-spacing:1px;text-transform:uppercase;
  box-shadow:0 14px 30px rgba(34,56,74,.3);
}

/* --- Apparition au défilement ------------------------------ */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.revealed{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .leaf{display:none}
  *{scroll-behavior:auto!important}
}

:focus-visible{outline:3px solid var(--brand);outline-offset:3px}

/* --- Responsive -------------------------------------------- */
/* Nav hamburger dès 1024px (5 liens + thème + CTA = trop dense avant) */
@media (max-width:1024px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:68px 0 auto 0;background:var(--paper);
    display:grid;gap:.3rem;padding:.9rem 1.1rem 1.2rem;
    border-bottom:1px solid var(--card-line);box-shadow:var(--shadow);
    transform:translateY(-120%);transition:transform .25s cubic-bezier(.16,1,.3,1);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:.82rem 1rem}
}

@media (max-width:960px){
  .hero-home-grid,.about-grid,.grid-2,.grid-3,.missions-grid,.events-grid,
  .value-grid,.spotlight-grid,.page-intro-grid,.legal-grid,.stats-row,
  .contact-grid,.footer-top{grid-template-columns:1fr 1fr}
  .engagement-banner{grid-template-columns:1fr}
}

@media (max-width:768px){
  html{scroll-padding-top:78px}
  .hero-home-grid,.about-grid,.grid-2,.grid-3,.missions-grid,.events-grid,
  .value-grid,.spotlight-grid,.page-intro-grid,.legal-grid,.stats-row,
  .contact-grid,.footer-top,.footer-bottom{grid-template-columns:1fr;display:grid}
  .hero{padding-top:100px;padding-bottom:46px}
  .hero-home-grid,.hero-home{text-align:center}
  .hero-copy{max-width:none}
  .hero-home .hero-actions{justify-content:center}
  .hero-panel-grid{grid-template-columns:1fr 1fr}
  .hero-logo{width:100px}
  .section{padding:54px 0}
  .mobile-contact-cta{display:block}
  body{padding-bottom:78px}
}

@media (max-width:520px){
  .container,.nav-container,.hero-content{padding-left:18px;padding-right:18px}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
  .btn,.mobile-contact-cta{min-height:48px}
  .card,.about-text,.about-focus,.mission-card,.event-card,.contact-card{padding:1.3rem}
  .engagement-banner,.cta-band{padding:1.5rem}
  .hero-panel-grid{grid-template-columns:1fr 1fr}
}
