/* ============================================================
   PUMA — puma-main.css v3.0
   Fidèle pixel-pour-pixel à la maquette v5 finale
   Classes préfixées puma- pour éviter conflits avec risehand
   ============================================================ */

/* ── Variables ── */
:root {
  --puma-vert:        #07853F;
  --puma-vert-fonce:  #055c2b;
  --puma-vert-clair:  #0aa350;
  --puma-jaune:       #FAEB49;
  --puma-jaune-icon:  #f5ee71;
  --puma-rouge:       #E31B23;
  --puma-gris-clair:  #f4f6f8;
  --puma-gris:        #6b7280;
  --puma-radius:      12px;
}

/* ============================================================
   NEUTRALISATION HEADER RISEHAND
   Masquer tous les éléments du header parent risehand
   ============================================================ */
.header_wapper,
.risehand-header,
.header_main_area,
.sticky-header,
.risehand_sticky_header,
.page_header_default,
.mean-container,
.site-hamburger-btn,
.rs-menu-area,
#rs-side-menu,
.rs-side-menu-overlay,
.risehand_header,
.risehand_menu {
  display: none !important;
}

/* ============================================================
   TOPBAR V5 — bande verte supérieure
   ============================================================ */
.puma-topbar {
  background: var(--puma-vert-fonce);
  color: rgba(255,255,255,.9);
  font-family: 'Fira Sans', sans-serif;
  font-size: 13px;
  padding: 8px 0;
  position: relative;
  z-index: 1001;
}
.puma-topbar * { box-sizing: border-box; }
.puma-topbar-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.puma-topbar-left {
  display: flex;
  gap: 22px;
  align-items: center;
  flex-wrap: wrap;
}
.puma-topbar-contact {
  display: flex;
  align-items: center;
  gap: 7px;
  color: rgba(255,255,255,.9);
  text-decoration: none;
  transition: color .2s;
  white-space: nowrap;
}
.puma-topbar-contact:hover { color: var(--puma-jaune); }
.puma-topbar-contact img {
  height: 14px;
  width: auto;
  vertical-align: middle;
  display: inline-block;
  flex-shrink: 0;
}
.puma-topbar-right {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-shrink: 0;
}
.puma-topbar-social {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  transition: background .2s;
  text-decoration: none;
}
.puma-topbar-social:hover { background: rgba(255,255,255,.22); }
.puma-topbar-social img {
  height: 14px;
  width: auto;
  vertical-align: middle;
  display: inline-block;
}

/* ============================================================
   NAVBAR V5 — barre navigation blanche sticky
   ============================================================ */
.puma-navbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #ffffff;
  box-shadow: 0 2px 12px rgba(0,0,0,.08);
}
.puma-navbar * { box-sizing: border-box; }
.puma-navbar-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  /* Logo à gauche, nav juste après, bouton contact poussé à droite */
  justify-content: flex-start;
  gap: 0;
  height: 88px;        /* +16px : respiration logo et menu */
}
.puma-navbar-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
  padding: 8px 0;      /* espace vertical autour du logo */
}
.puma-navbar-logo img {
  height: 64px;        /* logo légèrement agrandi */
  width: auto;
  object-fit: contain;
  display: block;
}
.puma-navbar-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  /* Menu calé à droite — les items se regroupent vers la droite */
  justify-content: flex-end;
  padding-left: 24px;
}
.puma-navbar-nav a,
.puma-navbar-nav .puma-nav-item {
  text-decoration: none;
  color: #374151;
  font-size: 15px;           /* taille augmentée */
  font-weight: 700;          /* tous en gras */
  padding: 9px 16px;         /* padding augmenté */
  border-radius: 7px;
  letter-spacing: .02em;
  transition: color .2s, background .2s, box-shadow .2s;
  white-space: nowrap;
  display: inline-block;
}
.puma-navbar-nav a:hover,
.puma-navbar-nav .puma-nav-item:hover {
  color: var(--puma-vert);
  background: rgba(7,133,63,.08);
  box-shadow: inset 0 -2px 0 var(--puma-vert);
}
/* Item actif — cadre plus visible */
.puma-navbar-nav .puma-nav-current,
.puma-navbar-nav a.current-menu-item,
.puma-navbar-nav .current-menu-item > a {
  color: var(--puma-vert);
  background: rgba(7,133,63,.10);
  box-shadow: inset 0 -2px 0 var(--puma-vert);
}
/* current-menu-item WP (classe native) */
.puma-navbar-nav li.current-menu-item > a,
.puma-navbar-nav li.current_page_item > a {
  color: var(--puma-vert) !important;
  background: rgba(7,133,63,.10) !important;
  box-shadow: inset 0 -2px 0 var(--puma-vert) !important;
}
/* Neutraliser le gras "permanent" sur Accueil :
   WP ajoute current-menu-item à Accueil uniquement quand on est dessus.
   Si tout est font-weight:700, il n'y a plus de différence de graisse → OK */

/* ══ DROPDOWN SOUS-MENUS ══════════════════════════════════════════════════ */

/* Wrapper d'un item avec sous-menu */
.puma-nav-has-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
}

/* FIX HOVER GAP — pont invisible entre bouton et panneau (8px) */
.puma-nav-has-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 8px;
  background: transparent;
  z-index: 9998;
}

/* Bouton toggle — style IDENTIQUE aux autres items nav */
.puma-nav-toggle {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 15px;             /* aligné avec les autres items */
  font-weight: 700;            /* aligné avec les autres items */
  color: #374151 !important;
  padding: 9px 16px;           /* aligné avec les autres items */
  border-radius: 7px;
  letter-spacing: .02em;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: color .2s, background .2s, box-shadow .2s;
  white-space: nowrap;
  line-height: 1;
}
.puma-nav-toggle:hover,
.puma-nav-has-dropdown:hover .puma-nav-toggle {
  color: var(--puma-vert) !important;
  background: rgba(7,133,63,.08);
  box-shadow: inset 0 -2px 0 var(--puma-vert);
}
.puma-nav-has-dropdown.puma-dropdown-open .puma-nav-toggle {
  color: var(--puma-vert) !important;
  background: rgba(7,133,63,.10);
  box-shadow: inset 0 -2px 0 var(--puma-vert);
}

/* Icône caret — taille réduite 50% */
.puma-caret {
  flex-shrink: 0;
  width: 8px;
  height: 5px;
  margin-top: 1px;
  opacity: .6;
  transition: transform .22s ease;
}
.puma-nav-has-dropdown:hover .puma-caret,
.puma-nav-has-dropdown.puma-dropdown-open .puma-caret {
  transform: rotate(180deg);
  opacity: 1;
}

/* Panneau dropdown — top:100% (sans gap) + padding-top en compensation */
.puma-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 0 0 10px 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,.13);
  padding: 8px 0 8px;
  display: flex;
  flex-direction: column;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity .18s ease, visibility .18s ease, transform .18s ease;
  pointer-events: none;
}

/* Ouverture au survol (desktop) */
.puma-nav-has-dropdown:hover .puma-dropdown,
.puma-nav-has-dropdown.puma-dropdown-open .puma-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* ── Items niveau 1 (directs dans le dropdown) ── */
.puma-dropdown-item {
  display: block;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  color: #1f2937 !important;
  text-decoration: none !important;
  transition: background .15s, color .15s;
  white-space: nowrap;
  border-radius: 4px;
  margin: 1px 6px;
}
.puma-dropdown-item:hover,
.puma-dropdown-item:focus {
  background: rgba(7,133,63,.08) !important;
  color: var(--puma-vert) !important;
  outline: none;
}
.puma-dropdown-item.puma-dropdown-current {
  color: var(--puma-vert) !important;
  font-weight: 700;
  background: rgba(7,133,63,.07) !important;
}

/* ── Séparateur hr ── */
.puma-dropdown-hr {
  border: none;
  border-top: 1px solid rgba(0,0,0,.08);
  margin: 6px 0;
}

/* ── Groupe niveau 1 avec enfants ── */
.puma-dropdown-group {
  display: block;
}

/* Label du groupe : titre de section, pas cliquable ou lien distinct */
.puma-dropdown-group-label {
  display: block;
  padding: 8px 20px 5px;
  font-size: 10.5px;
  font-weight: 700;
  color: #9ca3af;                      /* gris clair — clairement secondaire */
  text-decoration: none !important;
  text-transform: uppercase;
  letter-spacing: .08em;
  cursor: default;
  white-space: nowrap;
  margin-top: 4px;
}
/* Si le label est un vrai lien, lui donner un hover discret */
a.puma-dropdown-group-label {
  cursor: pointer;
  color: #6b7280;
}
a.puma-dropdown-group-label:hover {
  color: var(--puma-vert) !important;
  background: none !important;
}

/* ── Conteneur des sous-items niveau 2 ── */
.puma-dropdown-sub {
  display: flex;
  flex-direction: column;
  /* Fond légèrement différent pour marquer la zone */
  background: rgba(0,0,0,.025);
  border-radius: 0 0 6px 6px;
  padding: 2px 0 6px;
  margin-bottom: 2px;
}

/* ── Items niveau 2 — clairement subordonnés ── */
.puma-dropdown-sub-item {
  display: block;
  /* Indentation : décalage à gauche pour marquer la hiérarchie */
  padding: 8px 16px 8px 32px;
  font-size: 13px;                     /* légèrement plus petit */
  font-weight: 500;                    /* moins gras que niveau 1 */
  color: #4b5563 !important;          /* gris moyen — moins contrasté */
  text-decoration: none !important;
  transition: background .15s, color .15s;
  white-space: nowrap;
  position: relative;
}
/* Puce visuelle à gauche */
.puma-dropdown-sub-item::before {
  content: '';
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #d1d5db;                /* gris clair au repos */
  transition: background .15s;
}
.puma-dropdown-sub-item:hover,
.puma-dropdown-sub-item:focus {
  background: rgba(7,133,63,.06) !important;
  color: var(--puma-vert) !important;
  outline: none;
}
.puma-dropdown-sub-item:hover::before,
.puma-dropdown-sub-item:focus::before {
  background: var(--puma-vert);        /* puce verte au survol */
}
.puma-dropdown-sub-item.puma-dropdown-current {
  color: var(--puma-vert) !important;
  font-weight: 600;
}
.puma-dropdown-sub-item.puma-dropdown-current::before {
  background: var(--puma-vert);
}
/* Bouton Contact — même style que tous les autres items */
.puma-btn-nav-contact,
.puma-navbar-nav .puma-btn-nav-contact,
.puma-navbar-nav a.puma-btn-nav-contact {
  background: none !important;
  color: #374151 !important;
  padding: 9px 16px !important;
  border-radius: 7px !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  transition: color .2s, background .2s, box-shadow .2s !important;
  margin-left: 0 !important;
}
.puma-btn-nav-contact:hover,
.puma-navbar-nav .puma-btn-nav-contact:hover,
.puma-navbar-nav a.puma-btn-nav-contact:hover {
  color: var(--puma-vert) !important;
  background: rgba(7,133,63,.08) !important;
  box-shadow: inset 0 -2px 0 var(--puma-vert) !important;
  transform: none !important;
}

/* ── Hamburger (mobile) ── */
.puma-navbar-burger {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 28px;
  height: 20px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}
.puma-navbar-burger span {
  display: block;
  width: 100%;
  height: 2px;
  background: #374151;
  border-radius: 2px;
  transition: all .3s;
}
.puma-navbar-burger.open span:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
}
.puma-navbar-burger.open span:nth-child(2) { opacity: 0; }
.puma-navbar-burger.open span:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
}

/* ── Correction boutons hero (arrows) ── */
.puma-hero-arrow {
  position: absolute;
  top: 50%;
  z-index: 3;
  transform: translateY(-50%);
  background: rgba(255,255,255,.18);
  border: 2px solid rgba(255,255,255,.4);
  color: white;
  font-size: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
  backdrop-filter: blur(4px);
  padding: 0;
  line-height: 1;
  flex-shrink: 0;
}
.puma-hero-arrow:hover {
  background: rgba(255,255,255,.3);
  border-color: white;
}
.puma-hero-arrow-left  { left: 20px; }
.puma-hero-arrow-right { right: 20px; }

/* ============================================================
   BANDEAU PARTENAIRES INSTITUTIONNELS (footer)
   ============================================================ */
.puma-footer-partenaires {
  background: #fff;
  padding: 56px 0 48px;
  border-top: 1px solid rgba(0,0,0,.07);
}
.puma-footer-partenaires-header {
  text-align: center;
  margin-bottom: 36px;
}
.puma-footer-partenaires-kicker {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--puma-vert);
  background: rgba(7,133,63,.09);
  padding: 4px 14px;
  border-radius: 20px;
  margin-bottom: 10px;
}
.puma-footer-partenaires-title {
  font-size: 26px;
  font-weight: 700;
  color: #111827;
  margin: 6px 0 14px;
}
.puma-footer-partenaires-title span {
  color: var(--puma-vert);
}
.puma-footer-partenaires-divider {
  width: 48px;
  height: 3px;
  background: linear-gradient(to right, var(--puma-vert), var(--puma-jaune));
  border-radius: 2px;
  margin: 0 auto;
}
/* Grille logos — 7 par ligne, 2 lignes max */
.puma-footer-partenaires-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 16px 20px;
}
.puma-footer-partenaire-item {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 10px;
  padding: 10px 20px;
  width: 148px;
  height: 68px;
  flex-shrink: 0;
  transition: border-color .2s, box-shadow .2s, transform .2s;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.puma-footer-partenaire-item:hover {
  border-color: var(--puma-vert);
  box-shadow: 0 4px 18px rgba(7,133,63,.12);
  transform: translateY(-2px);
}
.puma-footer-partenaire-item img {
  max-width: 110px;
  max-height: 42px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(15%);
  transition: filter .25s;
}
.puma-footer-partenaire-item:hover img { filter: grayscale(0%); }

/* ============================================================
   FOOTER PRINCIPAL
   ============================================================ */
.puma-footer {
  background: #275b30;
  color: rgba(255,255,255,.82);
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* Grille 4 colonnes */
.puma-footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: 40px 48px;
  padding: 56px 0 44px;
}

/* ─── Col 1 : marque ─── */
.puma-footer-col--brand {}
.puma-footer-logo-link { display: inline-block; margin-bottom: 18px; }
.puma-footer-logo {
  width: 160px;
  height: auto;
  display: block;
  filter: brightness(0) invert(1);  /* force blanc si logo coloré */
}
.puma-footer-desc {
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255,255,255,.65);
  margin: 0 0 20px;
  max-width: 280px;
}
.puma-footer-social {
  display: flex;
  gap: 10px;
}
.puma-footer-social-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.8);
  transition: background .2s, color .2s, transform .2s;
  text-decoration: none;
}
.puma-footer-social-btn:hover {
  background: var(--puma-vert);
  color: #fff;
  transform: translateY(-2px);
}

/* ─── Cols 2–4 ─── */
.puma-footer-col-title {
  font-size: 13.5px;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin: 0 0 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.puma-footer-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
.puma-footer-menu li { margin-bottom: 9px; }
.puma-footer-menu a {
  color: rgba(255,255,255,.65);
  font-size: 13px;
  text-decoration: none;
  transition: color .2s, padding-left .2s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.puma-footer-menu a::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--puma-jaune);
  opacity: 0;
  transition: opacity .2s;
  flex-shrink: 0;
}
.puma-footer-menu a:hover {
  color: #fff;
  padding-left: 6px;
}
.puma-footer-menu a:hover::before { opacity: 1; }

/* ─── Liste contact ─── */
.puma-footer-contact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 13px;
}
.puma-footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: rgba(255,255,255,.65);
  line-height: 1.5;
}
.puma-footer-contact-list svg {
  flex-shrink: 0;
  margin-top: 2px;
  stroke: var(--puma-jaune);
}
.puma-footer-contact-list a {
  color: rgba(255,255,255,.65);
  text-decoration: none;
  transition: color .2s;
}
.puma-footer-contact-list a:hover { color: #fff; }

/* ─── Bande inférieure ─── */
.puma-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.18);
}
.puma-footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  padding: 18px 0;
}
.puma-footer-copyright {
  font-size: 12px;
  color: rgba(255,255,255,.45);
}
.puma-footer-bottom-links {
  display: flex;
  gap: 20px;
}
.puma-footer-bottom-links a {
  font-size: 12px;
  color: rgba(255,255,255,.45);
  text-decoration: none;
  transition: color .2s;
}
.puma-footer-bottom-links a:hover { color: rgba(255,255,255,.8); }

/* ─── Badges ─── */
.puma-footer-badges {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.puma-footer-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: rgba(255,255,255,.4);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px;
  padding: 4px 10px;
  white-space: nowrap;
}
.puma-footer-badge svg { stroke: rgba(255,255,255,.5); flex-shrink: 0; }
.puma-footer-badge--republic {
  color: rgba(255,255,255,.55);
  background: rgba(7,133,63,.15);
  border-color: rgba(7,133,63,.3);
}

/* ============================================================
   RESPONSIVE — MOBILE
   ============================================================ */
@media (max-width: 900px) {
  .puma-topbar-left { display: none; }

  .puma-navbar-burger { display: flex; }

  .puma-navbar-nav {
    display: none;
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    background: #ffffff;
    flex-direction: column;
    align-items: stretch;
    padding: 12px 20px 20px;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    gap: 4px;
  }
  .puma-navbar-nav.open { display: flex; }
  .puma-navbar-nav a,
  .puma-navbar-nav .puma-nav-item {
    padding: 12px 16px;
    font-size: 15px;
    font-weight: 700;
    border-radius: 8px;
    box-shadow: none !important;   /* pas d'indicateur soulignement en mobile */
  }
  .puma-btn-nav-contact,
  .puma-navbar-nav .puma-btn-nav-contact {
    margin-left: 0 !important;
    text-align: left;
  }
  .puma-navbar { position: relative; }

  /* ── Dropdown en mode mobile : s'ouvre en accordéon ── */
  .puma-nav-has-dropdown {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }
  .puma-nav-toggle {
    width: 100%;
    justify-content: space-between;
    padding: 12px 16px;
    font-size: 15px;
    border-radius: 8px;
  }
  .puma-dropdown {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    border-left: 3px solid rgba(7,133,63,.25);
    border-radius: 0;
    background: rgba(7,133,63,.03);
    margin-left: 16px;
    padding: 4px 0;
    /* Caché par défaut en mobile, ouvert via .puma-dropdown-open */
    display: none;
    pointer-events: auto;
  }
  .puma-nav-has-dropdown:hover .puma-dropdown { display: none; } /* désactiver hover mobile */
  .puma-nav-has-dropdown.puma-dropdown-open .puma-dropdown { display: flex; }
  .puma-dropdown-item {
    padding: 10px 16px;
    font-size: 14px;
    margin: 1px 0;
  }
  /* Groupe + sous-items en mobile : accordéon emboîté */
  .puma-dropdown-group-label {
    padding: 8px 16px 4px;
  }
  .puma-dropdown-sub {
    background: rgba(0,0,0,.03);
    border-radius: 6px;
    margin: 0 8px 4px;
    padding: 2px 0 4px;
  }
  .puma-dropdown-sub-item {
    padding: 8px 12px 8px 28px;
    font-size: 13px;
  }
  .puma-dropdown-sub-item::before {
    left: 14px;
  }
}

@media (max-width: 600px) {
  .puma-topbar-inner { padding: 0 16px; }
  .puma-navbar-inner { padding: 0 16px; height: 60px; }
  .puma-navbar-logo img { height: 42px; }
}

/* ── Reset minimal (n'écrase pas risehand globalement) ── */
.puma-hero *, .puma-hero-actu-wrapper *,
.puma-section-chiffres *, .puma-section-axes *,
.puma-section-carte *, .puma-section-temoignages *,
.puma-section-partenaires *, .puma-container * {
  box-sizing: border-box;
}

/* ── Fix risehand overflow ── */
.page_wapper, .top_page_wapper { overflow: visible !important; }

/* ── Fix risehand couleurs parasites sur liens de navigation ── */
/* Risehand applique sa couleur d'accent (rouge/orange) sur .menu-item a, .navigation-menu a etc. */
.puma-navbar .menu-item > a,
.puma-navbar .menu-item > button,
.puma-navbar-nav a:not(.puma-btn-nav-contact),
.puma-navbar-nav .puma-nav-toggle {
  color: #374151 !important;
}
.puma-navbar .menu-item > a:hover,
.puma-navbar .menu-item > button:hover,
.puma-navbar-nav a:not(.puma-btn-nav-contact):hover {
  color: var(--puma-vert) !important;
}
/* Empêcher overflow:hidden sur la navbar (couperait les dropdowns) */
.puma-navbar,
.puma-navbar-inner,
.puma-navbar-nav {
  overflow: visible !important;
}

/* ── Typographie globale body ── */
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: #1a1a1a;
  overflow-x: hidden;
}

/* ============================================================
   CONTAINER
   ============================================================ */
.puma-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ============================================================
   SECTION HEADER COMMUN
   ============================================================ */
.puma-section-header {
  text-align: center;
  margin-bottom: 48px;
}
.puma-section-kicker {
  display: inline-block;
  background: rgba(7,133,63,.1);
  color: var(--puma-vert);
  font-weight: 700;
  font-size: 11.5px;
  padding: 5px 14px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
}
.puma-section-title {
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 800;
  color: #111;
  line-height: 1.2;
  margin-bottom: 14px;
}
.puma-section-title span { color: var(--puma-vert); }
.puma-section-desc {
  font-family: 'Fira Sans', sans-serif;
  color: var(--puma-gris);
  font-size: 16px;
  line-height: 1.7;
  max-width: 580px;
  margin: 0 auto;
}
.puma-section-divider {
  width: 56px;
  height: 4px;
  background: linear-gradient(90deg, var(--puma-vert), var(--puma-jaune));
  border-radius: 2px;
  margin: 16px auto 0;
}

/* ============================================================
   HERO BLOCK — hero compact + 3 cartes collées
   ============================================================ */

/* Wrapper global */
.puma-hero-block {
  position: relative;
  /* Héritage police unique — Plus Jakarta Sans partout dans ce bloc */
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* ── Hero slider compact ── */
.puma-hero {
  position: relative;
  height: 540px;
  min-height: 420px;
  overflow: hidden;
}
.puma-hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.1s ease;
}
.puma-hero-slide.active { opacity: 1; }

/* Overlay dégradé — lisibilité titre + transition vers les cartes */
.puma-hero-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.08) 0%,
    rgba(0,0,0,.30) 35%,
    rgba(0,0,0,.58) 75%,
    rgba(0,0,0,.72) 100%
  );
}

/* Contenu hero — aligné bas-gauche comme la maquette */
.puma-hero-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: 0 60px 130px;  /* espace pour les cartes overlay en bas */
  max-width: 760px;
}
.puma-hero-cat {
  display: inline-block;
  background: var(--puma-vert);
  color: white;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: 4px;
  margin-bottom: 12px;
}
.puma-hero-title {
  font-size: clamp(20px, 2.2vw, 30px); /* réduit : moins massif sur desktop */
  font-weight: 800;
  color: white;
  line-height: 1.2;
  margin-bottom: 20px;              /* plus d'espace avant CTA (pas d'extrait) */
  text-shadow: 0 2px 14px rgba(0,0,0,.38);
  /* font-family hérité du bloc parent */
}
/* .puma-hero-desc est masqué en PHP — règle conservée au cas où */
.puma-hero-desc {
  display: none; /* extrait supprimé — géré côté PHP aussi */
}
.puma-hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
/* Boutons hero — police héritée du .puma-hero-block, pas de font-family spécifique */
.btn-hero-primary {
  /* font-family héritée de .puma-hero-block */
  background: var(--puma-vert);
  color: white;
  font-weight: 700;
  font-size: 14px;
  padding: 11px 22px;
  border-radius: 7px;
  text-decoration: none;
  transition: background .2s, transform .2s;
  border: 2px solid var(--puma-vert);
  display: inline-block;
}
.btn-hero-primary:hover {
  background: var(--puma-vert-fonce);
  border-color: var(--puma-vert-fonce);
  transform: translateY(-1px);
  color: white;
  text-decoration: none;
}
.btn-hero-outline {
  /* font-family héritée de .puma-hero-block */
  background: transparent;
  color: white;
  font-weight: 700;
  font-size: 14px;
  padding: 11px 22px;
  border-radius: 7px;
  text-decoration: none;
  border: 2px solid rgba(255,255,255,.7);
  transition: background .2s, border-color .2s, transform .2s;
  display: inline-block;
}
.btn-hero-outline:hover {
  background: rgba(255,255,255,.12);
  border-color: white;
  transform: translateY(-1px);
  color: white;
  text-decoration: none;
}

/* Flèches */
.puma-hero-arrow {
  position: absolute;
  top: 50%;
  z-index: 3;
  transform: translateY(-50%);
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.4);
  color: white;
  font-size: 18px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
  backdrop-filter: blur(4px);
}
.puma-hero-arrow:hover {
  background: rgba(255,255,255,.28);
  border-color: white;
}
.puma-hero-arrow-left  { left: 16px; }
.puma-hero-arrow-right { right: 16px; }

/* Dots */
.puma-hero-dots {
  position: absolute;
  bottom: 16px;
  right: 24px;
  z-index: 3;
  display: flex;
  gap: 6px;
}
.puma-hero-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.40);
  cursor: pointer;
  transition: all .3s;
  border: none;
}
.puma-hero-dot.active {
  width: 22px;
  border-radius: 4px;
  background: white;
}

/* ── 3 cartes overlay : émergent du hero (z-index + margin négatif) ── */
.puma-hero-cards {
  position: relative;
  z-index: 5;
  margin-top: -110px;   /* remonte sur le hero */
  padding-bottom: 48px; /* espace entre les cartes et la section suivante */
  background: transparent;
}
.puma-hero-cards-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

/* Carte individuelle */
.puma-hcard {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  border-radius: 10px;
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
  background: #fff;
  box-shadow: 0 8px 32px rgba(0,0,0,.20);  /* ombre forte : visible sur fond image hero */
}
.puma-hcard:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 44px rgba(0,0,0,.20);
}

.puma-hcard-img {
  height: 160px;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}
.puma-hcard-img--placeholder {
  background: linear-gradient(135deg, #e8f5ee 0%, #c8e6d4 100%);
}

.puma-hcard-body {
  padding: 16px 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
/* Tags cartes — masqués (demande client) */
.puma-hcard-tag {
  display: none;
}
.puma-hcard-date {
  font-size: 11px;
  color: #9ca3af;
  /* font-family héritée du .puma-hero-block */
}
.puma-hcard-title {
  font-size: 14px;
  font-weight: 700;
  color: #1f2937;
  line-height: 1.4;
  margin: 0;
}
.puma-hcard-lire {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 600;
  color: var(--puma-vert);
  margin-top: auto;
  padding-top: 8px;
  text-decoration: none;
}
.puma-hcard:hover .puma-hcard-lire { text-decoration: underline; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .puma-hero { height: 420px; }
  .puma-hero-content { padding: 0 24px 150px; } /* espace pour cartes overlay */
  .puma-hero-title { font-size: 22px; }

  /* Cartes : annuler l'overlay, afficher normalement sous le hero */
  .puma-hero-cards {
    margin-top: 0;
    background: #f4f7f4;
    padding: 20px 0;
  }
  .puma-hero-cards-inner {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 0 16px;
  }
  .puma-hcard { flex-direction: row; }
  .puma-hcard-img { width: 110px; height: auto; min-height: 85px; flex-shrink: 0; border-radius: 0; }
  .puma-hcard-body { padding: 12px 14px; }
}
@media (max-width: 600px) {
  .puma-hero { height: 360px; min-height: 300px; }
  .puma-hero-content { padding: 0 16px 140px; }
  .puma-hero-ctas { flex-direction: column; gap: 8px; }
  .puma-hcard-img { width: 90px; }
}

/* ── Ancien wrapper (rétrocompat) — masqué si présent ── */
.puma-hero-actu-wrapper { display: none; }

/* ============================================================
   SECTION CHIFFRES — fond vert dégradé, glassmorphism
   ============================================================ */
.puma-section-chiffres {
  padding: 80px 0;
  background: linear-gradient(135deg, #0a2e1a 0%, #07853F 60%, #0d4a27 100%);
  position: relative;
  overflow: hidden;
}
.puma-section-chiffres::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(250,235,73,.06) 0%, transparent 55%);
  pointer-events: none;
}
.puma-section-chiffres .puma-section-kicker {
  background: rgba(250,235,73,.18);
  color: var(--puma-jaune);
}
.puma-section-chiffres .puma-section-title { color: white; }
.puma-section-chiffres .puma-section-desc  { color: rgba(255,255,255,.7); }
.puma-section-chiffres .puma-section-divider {
  background: linear-gradient(90deg, var(--puma-jaune), rgba(250,235,73,.3));
}

.puma-chiffres-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.puma-chiffre-card {
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--puma-radius);
  padding: 32px 24px;
  text-align: center;
  transition: all .3s;
}
.puma-chiffre-card:hover {
  background: rgba(255,255,255,.14);
  border-color: rgba(250,235,73,.35);
  transform: translateY(-4px);
}
.puma-chiffre-icon-img {
  height: 48px;
  width: auto;
  margin: 0 auto 12px;
  display: block;
  filter: brightness(0) invert(1);
  opacity: .85;
}
.puma-chiffre-number {
  font-size: clamp(34px, 4.5vw, 50px);
  font-weight: 800;
  color: var(--puma-jaune);
  line-height: 1;
  margin-bottom: 8px;
}
.puma-chiffre-suffix {
  font-size: 22px;
  color: white;
}
.puma-counter { color: var(--puma-jaune); }
.puma-chiffre-label {
  font-family: 'Fira Sans', sans-serif;
  color: rgba(255,255,255,.75);
  font-size: 13.5px;
  line-height: 1.5;
}

/* ============================================================
   SECTION AXES D'INTERVENTION
   ============================================================ */
.puma-section-axes {
  padding: 80px 0;
  background: var(--puma-gris-clair);
}
.puma-axes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.puma-axe-card {
  background: white;
  border-radius: var(--puma-radius);
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,.05);
  transition: all .3s;
}
.puma-axe-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 36px rgba(0,0,0,.1);
}
.puma-axe-card-top {
  height: 5px;
  background: linear-gradient(90deg, var(--puma-vert), var(--puma-vert-clair));
}
.puma-axe-top-2 {
  background: linear-gradient(90deg, #0aa350, var(--puma-jaune));
}
.puma-axe-top-3 {
  background: linear-gradient(90deg, #1a5c8a, #07853F);
}
.puma-axe-card-body { padding: 28px; }
.puma-axe-icon {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 18px;
}
.puma-axe-icon img {
  height: 80px;
  width: auto;
}
.puma-axe-title {
  font-size: 17px;
  font-weight: 700;
  color: #111;
  margin-bottom: 10px;
}
.puma-axe-desc {
  font-family: 'Fira Sans', sans-serif;
  color: var(--puma-gris);
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 16px;
}
.puma-axe-stat {
  color: var(--puma-vert);
  font-size: 13px;
  font-weight: 600;
}
.puma-axe-stat::before { content: '→ '; }

/* ============================================================
   SECTION CARTE INTERACTIVE
   ============================================================ */
.puma-section-carte {
  padding: 80px 0;
  background: white;
}
.puma-carte-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 48px;
  align-items: start;
}
.puma-carte-wrapper {
  background: linear-gradient(135deg, #f0f9f4, #e8f5ee);
  border-radius: 20px;
  padding: 24px;
  border: 1px solid rgba(7,133,63,.1);
  box-shadow: 0 4px 28px rgba(7,133,63,.08);
  position: relative;
}
.puma-carte-wrapper svg {
  width: 100%;
  height: auto;
  display: block;
}
.puma-carte-wrapper svg path {
  fill: #d1d5db;
  stroke: white;
  stroke-width: 1;
  transition: fill .25s, filter .25s;
  cursor: default;
}
.puma-carte-wrapper svg path.puma-region {
  fill: #a8d5b8;
  cursor: pointer;
}
.puma-carte-wrapper svg path.puma-region:hover,
.puma-carte-wrapper svg path.puma-region.hovered {
  fill: var(--puma-jaune);
  filter: drop-shadow(0 0 8px rgba(250,235,73,.5));
}
.puma-carte-wrapper svg path.puma-region.active {
  fill: var(--puma-vert);
  filter: drop-shadow(0 0 10px rgba(7,133,63,.45));
}

/* Tooltip */
.puma-carte-tooltip {
  position: absolute;
  background: rgba(5,92,43,.96);
  color: white;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 13px;
  pointer-events: none;
  opacity: 0;
  transition: opacity .2s;
  z-index: 100;
  min-width: 175px;
  box-shadow: 0 4px 20px rgba(0,0,0,.25);
  border: 1px solid rgba(250,235,73,.25);
}
.puma-carte-tooltip.visible { opacity: 1; }
.puma-carte-tooltip h4 {
  color: var(--puma-jaune);
  font-size: 13.5px;
  margin-bottom: 7px;
}
.tip-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 3px;
  font-size: 12.5px;
}
.tip-item span:last-child {
  font-weight: 700;
  color: var(--puma-jaune);
}

/* Légende */
.puma-carte-legende {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(7,133,63,.1);
}
.puma-legende-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  color: var(--puma-gris);
  font-family: 'Fira Sans', sans-serif;
}
.puma-legende-dot {
  width: 13px;
  height: 13px;
  border-radius: 3px;
  flex-shrink: 0;
}

/* Panneau régions */
.puma-carte-panel { position: sticky; top: 84px; align-self: flex-start; }
.puma-carte-panel-header {
  background: linear-gradient(135deg, var(--puma-vert), #0aa350);
  color: white;
  padding: 22px;
  border-radius: 14px 14px 0 0;
}
.puma-carte-panel-header h3 {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 3px;
  color: white;
}
.puma-carte-panel-header p {
  font-size: 12.5px;
  opacity: .8;
  font-family: 'Fira Sans', sans-serif;
  color: rgba(255,255,255,.85);
}
.puma-carte-panel-body {
  background: var(--puma-gris-clair);
  border-radius: 0 0 14px 14px;
  padding: 16px;
  /* pas de max-height ni overflow : toutes les régions visibles d'emblée */
}
.puma-region-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  background: white;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 8px;
  margin-bottom: 7px;
  cursor: pointer;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13.5px;
  font-weight: 500;
  color: #374151;
  transition: all .2s;
  text-align: left;
}
.puma-region-btn:hover,
.puma-region-btn.active,
.puma-region-btn.hovered {
  background: var(--puma-vert);
  color: white;
  border-color: var(--puma-vert);
  transform: translateX(4px);
}
.puma-region-km {
  font-size: 11.5px;
  opacity: .65;
  font-family: 'Fira Sans', sans-serif;
}
/* ─── Région item wrapper ─── */
.puma-region-item {
  margin-bottom: 6px;
}

/* ─── Bouton région : chevron à droite ─── */
.puma-region-btn-right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.puma-region-chevron {
  opacity: .55;
  transition: transform .25s ease;
  flex-shrink: 0;
}
.puma-region-item.open .puma-region-chevron {
  transform: rotate(180deg);
  opacity: 1;
}
.puma-region-item.open .puma-region-btn {
  background: var(--puma-vert);
  color: white;
  border-color: var(--puma-vert);
  border-radius: 8px 8px 0 0;
}
.puma-region-item.open .puma-region-btn .puma-region-km {
  color: rgba(255,255,255,.75);
}

/* ─── Panneau accordéon ─── */
.puma-accordion-panel {
  position: relative;
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease;
  background: linear-gradient(135deg, rgba(7,133,63,.06), rgba(250,235,73,.08));
  border: 1px solid rgba(7,133,63,.18);
  border-top: none;
  border-radius: 0 0 8px 8px;
  padding: 0 16px;
}
.puma-region-item.open .puma-accordion-panel {
  padding: 14px 16px 12px;
}

/* ─── Croix fermeture ─── */
.puma-accordion-close {
  position: absolute;
  top: 8px;
  right: 10px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: none;
  background: rgba(7,133,63,.12);
  color: var(--puma-vert);
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background .2s;
}
.puma-accordion-close:hover {
  background: var(--puma-vert);
  color: white;
}

/* ─── Description ─── */
.puma-accordion-desc {
  font-size: 12px;
  color: #4b5563;
  line-height: 1.55;
  margin: 0 0 12px 0;
  padding-bottom: 10px;
  padding-right: 22px;
  border-bottom: 1px solid rgba(7,133,63,.12);
}

/* ─── Stats en ligne ─── */
.puma-accordion-stats {
  display: flex;
  justify-content: space-between;
  gap: 6px;
}
.puma-accordion-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 11.5px;
  color: #6b7280;
}
.puma-accordion-stat strong {
  font-size: 13px;
  font-weight: 700;
  color: var(--puma-vert);
}

/* ============================================================
   SECTION TÉMOIGNAGES
   ============================================================ */
.puma-section-temoignages {
  padding: 80px 0;
  background: var(--puma-gris-clair);
}
.puma-temoignages-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.puma-temoignage-card {
  background: white;
  border-radius: 14px;
  padding: 28px;
  box-shadow: 0 2px 16px rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.06);
  transition: all .3s;
}
.puma-temoignage-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 32px rgba(0,0,0,.09);
}
.puma-stars {
  color: #facc15;
  font-size: 13px;
  margin-bottom: 8px;
}
.puma-temoignage-quote {
  font-size: 44px;
  color: var(--puma-vert);
  line-height: 1;
  margin-bottom: 6px;
  opacity: .22;
  font-family: Georgia, serif;
}
.puma-temoignage-text {
  font-family: 'Fira Sans', sans-serif;
  font-size: 14.5px;
  color: #374151;
  line-height: 1.75;
  font-style: italic;
  margin-bottom: 22px;
}
.puma-temoignage-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 18px;
  border-top: 1px solid rgba(0,0,0,.07);
}
.puma-temoignage-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.puma-temoignage-avatar-img {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.puma-temoignage-name {
  font-weight: 700;
  font-size: 13.5px;
  color: #111;
}
.puma-temoignage-role {
  font-size: 12px;
  color: var(--puma-gris);
  font-family: 'Fira Sans', sans-serif;
  margin-top: 2px;
}

/* ============================================================
   SECTION PARTENAIRES — carrousel infini
   ============================================================ */
.puma-section-partenaires {
  padding: 60px 0;
  background: white;
  border-top: 1px solid rgba(0,0,0,.06);
}
.puma-section-partenaires .puma-section-kicker {
  background: rgba(7,133,63,.1);
  color: var(--puma-vert);
}
.puma-partenaires-track-wrapper {
  overflow: hidden;
  position: relative;
  margin-top: 0;
}
.puma-partenaires-track-wrapper::before,
.puma-partenaires-track-wrapper::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
.puma-partenaires-track-wrapper::before {
  left: 0;
  background: linear-gradient(to right, white, transparent);
}
.puma-partenaires-track-wrapper::after {
  right: 0;
  background: linear-gradient(to left, white, transparent);
}
.puma-partenaires-track {
  display: flex;
  gap: 24px;
  align-items: center;
  width: max-content;
  animation: pumaScrollLogos 35s linear infinite;
}
.puma-partenaires-track:hover { animation-play-state: paused; }
@keyframes pumaScrollLogos {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.puma-partenaire-item {
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 10px;
  padding: 10px 20px;
  min-width: 140px;
  height: 64px;
  flex-shrink: 0;
  transition: all .25s;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
}
.puma-partenaire-item:hover {
  border-color: var(--puma-vert);
  box-shadow: 0 4px 18px rgba(7,133,63,.1);
  transform: scale(1.04);
}
.puma-partenaire-item img {
  max-height: 40px;
  max-width: 115px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(20%);
  transition: filter .25s;
}
.puma-partenaire-item:hover img { filter: grayscale(0%); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .puma-carte-layout { grid-template-columns: 1fr; }
  .puma-carte-panel  { position: static; }

  /* ── Footer responsive ── */
  .puma-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px 28px;
  }
  .puma-footer-col--brand {
    grid-column: 1 / -1;
  }
  .puma-footer-partenaires-grid {
    gap: 12px 14px;
  }
  .puma-footer-partenaire-item {
    width: 130px;
    height: 58px;
  }
  .puma-axes-grid, .puma-chiffres-grid, .puma-temoignages-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .puma-actu-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .puma-hero-title   { font-size: 32px; }
  .puma-hero-content { padding: 0 20px 80px; }
  .puma-hero-actu-wrapper { margin-top: -80px; padding: 0 16px; }
  .puma-axes-grid, .puma-chiffres-grid, .puma-temoignages-grid {
    grid-template-columns: 1fr;
  }
  .puma-container { padding: 0 16px; }
}

/* ══ PAGES STANDARD (page.php) ═══════════════════════════════════════════ */

.puma-page-hero {
  min-height: 220px;
  background: linear-gradient(135deg, var(--puma-vert) 0%, #056030 100%);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: flex-end;
  position: relative;
}
.puma-page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,.25) 0%, rgba(0,50,20,.65) 100%);
}
.puma-page-hero-inner {
  position: relative;
  z-index: 1;
  padding: 40px 60px;
  width: 100%;
}
.puma-page-title {
  color: #ffffff;
  font-size: 36px;
  font-weight: 800;
  margin: 0 0 10px;
  line-height: 1.2;
}
.puma-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: rgba(255,255,255,.8);
}
.puma-breadcrumb a {
  color: rgba(255,255,255,.8);
  text-decoration: none;
  transition: color .2s;
}
.puma-breadcrumb a:hover { color: #ffffff; }
.puma-breadcrumb span[aria-hidden] { opacity: .6; }

.puma-page-body {
  padding: 60px 0 80px;
  background: #f8faf8;
}
.puma-page-body-inner {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 60px;
  font-size: 16px;
  line-height: 1.8;
  color: #374151;
}
.puma-page-body-inner h2 { color: var(--puma-vert); font-size: 24px; margin-top: 40px; }
.puma-page-body-inner h3 { color: var(--puma-vert); font-size: 20px; margin-top: 30px; }
.puma-page-body-inner a  { color: var(--puma-vert); }

@media (max-width: 768px) {
  .puma-page-hero-inner { padding: 30px 20px; }
  .puma-page-title { font-size: 26px; }
  .puma-page-body-inner { padding: 0 20px; }
  /* ── Footer mobile ── */
  .puma-footer-grid {
    grid-template-columns: 1fr;
    padding: 36px 0 28px;
  }
  .puma-footer-col--brand { grid-column: auto; }
  .puma-footer-desc { max-width: 100%; }
  .puma-footer-bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .puma-footer-badges { display: none; }
  .puma-footer-partenaire-item { width: 110px; height: 52px; padding: 8px 12px; }
  .puma-footer-partenaires-title { font-size: 20px; }

}


/* ═══════════════════════════════════════════════════════════════
   ARCHIVE ACTUALITÉS — puma-archive-*
   ═══════════════════════════════════════════════════════════════ */

.puma-archive-wrapper {
    padding-top: 48px;
    padding-bottom: 64px;
}

/* ── Filtres catégories ── */
.puma-archive-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 36px;
}

.puma-filter-tag {
    display: inline-block;
    padding: 6px 16px;
    border: 1.5px solid var(--puma-vert);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    color: var(--puma-vert);
    text-decoration: none;
    transition: background .18s, color .18s;
    background: transparent;
}
.puma-filter-tag:hover,
.puma-filter-tag.active {
    background: var(--puma-vert);
    color: #fff;
}

/* ── Grille articles ── */
.puma-archive-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    margin-bottom: 48px;
}

/* ── Carte article ── */
.puma-article-card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .22s, transform .22s;
    border: 1px solid #f0f0f0;
}
.puma-article-card:hover {
    box-shadow: 0 8px 28px rgba(7,133,63,.14);
    transform: translateY(-3px);
}

.puma-article-card-img-wrap {
    display: block;
    overflow: hidden;
    aspect-ratio: 16/9;
    background: #f0f4f0;
}
.puma-article-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.puma-article-card:hover .puma-article-card-img {
    transform: scale(1.04);
}
.puma-article-card-img--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: #eaf5ee;
}

.puma-article-card-body {
    padding: 20px 22px 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.puma-article-card-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.puma-article-card-date {
    font-size: 12px;
    color: #9CA3AF;
    font-weight: 500;
}

.puma-article-card-cat {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #fff;
    background: var(--puma-vert);
    border-radius: 999px;
    padding: 2px 10px;
    text-decoration: none;
    transition: background .15s;
}
.puma-article-card-cat:hover {
    background: var(--puma-vert-dark, #055A2B);
}

.puma-article-card-title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    color: #1A2E1F;
    margin: 0 0 10px;
    flex: 1;
}
.puma-article-card-title a {
    color: inherit;
    text-decoration: none;
    transition: color .15s;
}
.puma-article-card-title a:hover {
    color: var(--puma-vert);
}

.puma-article-card-excerpt {
    font-size: 13.5px;
    color: #6B7280;
    line-height: 1.6;
    margin: 0 0 16px;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
}

.puma-article-card-lire {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--puma-vert);
    text-decoration: none;
    margin-top: auto;
    transition: gap .18s;
}
.puma-article-card-lire:hover {
    gap: 10px;
}

/* ── Pagination ── */
.puma-archive-pagination {
    display: flex;
    justify-content: center;
    margin-top: 16px;
}
.puma-archive-pagination .nav-links {
    display: flex;
    gap: 6px;
    align-items: center;
}
.puma-archive-pagination a,
.puma-archive-pagination .current {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: background .15s, color .15s;
}
.puma-archive-pagination a {
    color: var(--puma-vert);
    border: 1.5px solid #e5e7eb;
}
.puma-archive-pagination a:hover {
    background: var(--puma-vert);
    color: #fff;
    border-color: var(--puma-vert);
}
.puma-archive-pagination .current {
    background: var(--puma-vert);
    color: #fff;
    border: 1.5px solid var(--puma-vert);
}

/* ── État vide ── */
.puma-archive-empty {
    text-align: center;
    padding: 64px 20px;
    color: #6B7280;
}
.puma-archive-empty svg { margin-bottom: 20px; opacity: .5; }
.puma-archive-empty h2 { font-size: 22px; color: #1A2E1F; margin-bottom: 8px; }
.puma-archive-empty p  { margin-bottom: 24px; }

/* ── Responsive ── */
@media (max-width: 1024px) {
    .puma-archive-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .puma-archive-grid { grid-template-columns: 1fr; gap: 20px; }
    .puma-archive-filters { gap: 6px; }
    .puma-filter-tag { font-size: 12px; padding: 5px 12px; }
}


/* ═══════════════════════════════════════════════════════════════
   ARTICLE SINGLE — puma-single-*
   ═══════════════════════════════════════════════════════════════ */

/* Override layout Risehand : article centré, pleine largeur, sidebar masquée */
body.single-post #primary.content-area {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    padding: 0 !important;
}
body.single-post #secondary,
body.single-post .widget-area {
    display: none !important;
}
body.single-post .container > .row {
    display: block !important;
}
/* Masquer le titre & image du thème parent */
body.single-post .single_feature_image { display: none !important; }
body.single-post .blog_single_details_outer { background: none !important; padding: 0 !important; }
body.single-post .single_content_upper { padding: 0 !important; }

/* ── Wrapper article ── */
.puma-single-article {
    max-width: 820px;
    margin: 0 auto;
    padding: 0 20px 64px;
}

/* ── Image à la une ── */
.puma-single-hero-img {
    margin-bottom: 36px;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 24px rgba(0,0,0,.1);
    aspect-ratio: 16/7;
}
.puma-single-hero-img__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ── En-tête ── */
.puma-single-header {
    margin-bottom: 32px;
}

.puma-single-meta {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

.puma-single-cat-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #fff;
    background: var(--puma-vert);
    border-radius: 999px;
    padding: 4px 14px;
    text-decoration: none;
    transition: background .15s;
}
.puma-single-cat-badge:hover {
    background: #055A2B;
}

.puma-single-date,
.puma-single-read-time {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: #9CA3AF;
}

.puma-single-title {
    font-size: clamp(24px, 4vw, 36px);
    font-weight: 800;
    line-height: 1.25;
    color: #1A2E1F;
    margin: 0 0 14px;
    letter-spacing: -.01em;
}

.puma-single-author {
    font-size: 13px;
    color: #6B7280;
    display: flex;
    gap: 4px;
    margin-bottom: 20px;
}
.puma-single-author-name {
    font-weight: 600;
    color: #374151;
}

.puma-single-divider {
    height: 3px;
    width: 56px;
    background: linear-gradient(90deg, var(--puma-vert), var(--puma-jaune, #FAEB49));
    border-radius: 2px;
}

/* ── Contenu article ── */
.puma-single-content {
    font-size: 16px;
    line-height: 1.8;
    color: #374151;
    margin-bottom: 36px;
}
.puma-single-content h2 {
    font-size: 22px;
    font-weight: 700;
    color: #1A2E1F;
    margin: 32px 0 12px;
    padding-left: 14px;
    border-left: 4px solid var(--puma-vert);
}
.puma-single-content h3 {
    font-size: 18px;
    font-weight: 700;
    color: #1A2E1F;
    margin: 24px 0 8px;
}
.puma-single-content p  { margin: 0 0 18px; }
.puma-single-content ul,
.puma-single-content ol { padding-left: 24px; margin: 0 0 18px; }
.puma-single-content li { margin-bottom: 6px; }
.puma-single-content a  { color: var(--puma-vert); text-decoration: underline; }
.puma-single-content blockquote {
    margin: 28px 0;
    padding: 16px 20px;
    background: #eaf5ee;
    border-left: 4px solid var(--puma-vert);
    border-radius: 0 8px 8px 0;
    font-style: italic;
    color: #4B5563;
}
.puma-single-content img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 8px 0;
}
.puma-single-content figure { margin: 24px 0; }
.puma-single-content figcaption {
    font-size: 13px;
    color: #9CA3AF;
    text-align: center;
    margin-top: 6px;
}

/* ── Tags ── */
.puma-single-tags {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 32px;
    padding-bottom: 28px;
    border-bottom: 1px solid #f0f0f0;
}
.puma-single-tags-label {
    font-size: 13px;
    color: #9CA3AF;
    font-weight: 500;
}
.puma-single-tag-pill {
    font-size: 12px;
    padding: 4px 12px;
    border: 1.5px solid #e5e7eb;
    border-radius: 999px;
    color: #6B7280;
    text-decoration: none;
    transition: border-color .15s, color .15s;
}
.puma-single-tag-pill:hover {
    border-color: var(--puma-vert);
    color: var(--puma-vert);
}

/* ── Partage social ── */
.puma-single-share {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    padding: 24px 28px;
    margin-bottom: 36px;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.puma-single-share-label {
    font-size: 14px;
    font-weight: 700;
    color: #1A2E1F;
    white-space: nowrap;
    flex-shrink: 0;
}

.puma-single-share-btns {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.puma-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: 8px;
    font-size: 13.5px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: transform .15s, box-shadow .15s, background .15s;
}
.puma-share-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(0,0,0,.15);
}

.puma-share-btn--fb  { background: #1877F2; color: #fff; }
.puma-share-btn--tw  { background: #000; color: #fff; }
.puma-share-btn--li  { background: #0A66C2; color: #fff; }
.puma-share-btn--copy {
    background: #fff;
    color: #374151;
    border: 1.5px solid #e5e7eb;
}
.puma-share-btn--copied {
    background: #eaf5ee !important;
    color: var(--puma-vert) !important;
    border-color: var(--puma-vert) !important;
}

/* ── Navigation précédent/suivant ── */
.puma-single-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    border-top: 1px solid #f0f0f0;
    padding-top: 28px;
}
.puma-single-nav-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 16px 20px;
    border: 1.5px solid #e5e7eb;
    border-radius: 10px;
    text-decoration: none;
    color: inherit;
    transition: border-color .18s, box-shadow .18s;
}
.puma-single-nav-item:hover {
    border-color: var(--puma-vert);
    box-shadow: 0 2px 10px rgba(7,133,63,.1);
}
.puma-single-nav-next {
    text-align: right;
    margin-left: auto;
}
.puma-single-nav-direction {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--puma-vert);
}
.puma-single-nav-next .puma-single-nav-direction {
    justify-content: flex-end;
}
.puma-single-nav-title {
    font-size: 14px;
    font-weight: 600;
    color: #1A2E1F;
    line-height: 1.35;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
}

/* ── Responsive single ── */
@media (max-width: 768px) {
    .puma-single-article { padding: 0 16px 48px; }
    .puma-single-share   { flex-direction: column; gap: 14px; }
    .puma-single-nav     { grid-template-columns: 1fr; }
    .puma-single-nav-next { text-align: left; margin-left: 0; }
    .puma-single-nav-next .puma-single-nav-direction { justify-content: flex-start; }
    .puma-single-hero-img { border-radius: 0; margin-left: -16px; margin-right: -16px; }
}

/* Wrapper single — padding top pour compenser la navbar */
.puma-single-wrapper {
    padding-top: 40px;
}


/* ═══════════════════════════════════════════════════════════════
   PAGE ACTUALITÉS (home.php / archive.php) — OVERRIDES LAYOUT
   Masque la sidebar Risehand, pleine largeur, supprime bloc récents
   ═══════════════════════════════════════════════════════════════ */

/* Masquer la sidebar et le bloc "articles récents" du thème parent */
body.blog #secondary,
body.blog .widget-area,
body.blog .blog_siderbar,
body.archive #secondary,
body.archive .widget-area,
body.archive .blog_siderbar,
body.category #secondary,
body.category .widget-area {
    display: none !important;
}

/* Étendre le contenu principal sur toute la largeur */
body.blog #primary,
body.archive #primary,
body.category #primary {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    flex: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Supprimer le padding/margin du container parent Risehand */
body.blog .container,
body.archive .container,
body.category .container {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}
body.blog .container > .row,
body.archive .container > .row,
body.category .container > .row {
    margin: 0 !important;
    display: block !important;
}

/* Supprimer le style de blog par défaut Risehand (grille, cartes) */
body.blog .blog-style_default,
body.archive .blog-style_default,
body.category .blog-style_default,
body.blog .grid_layout,
body.archive .grid_layout,
body.category .grid_layout {
    display: none !important;
}

/* S'assurer que notre wrapper s'affiche bien */
body.blog .puma-archive-wrapper,
body.archive .puma-archive-wrapper,
body.category .puma-archive-wrapper {
    display: block !important;
}

/* Hero de la page archive — harmonisé avec les autres pages du site */
.puma-archive-hero {
    min-height: 260px;
    background: linear-gradient(135deg, #07853F 0%, #045C2B 60%, #033D1D 100%);
    /* column = le container prend toute la largeur, pas centré */
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    overflow: hidden;
}
.puma-archive-hero .puma-page-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: .18;
}
.puma-archive-hero .puma-page-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,.15) 0%, rgba(3,61,29,.75) 100%);
}
.puma-archive-hero .puma-page-hero-pattern {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(250,235,73,.07) 1px, transparent 1px);
    background-size: 28px 28px;
}
/* Container : aligné sur le navbar (max-width 1280px, margin auto, padding 32px) */
.puma-archive-hero .puma-container,
.puma-archive-hero .puma-page-hero-content,
.puma-archive-hero .puma-container.puma-page-hero-content {
    position: relative;
    z-index: 2;
    width: 100% !important;
    max-width: 1280px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 40px 32px 44px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
    box-sizing: border-box;
}
.puma-page-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,.65);
    margin-bottom: 12px;
    font-family: 'Fira Sans', sans-serif;
}
.puma-page-breadcrumb a {
    color: rgba(255,255,255,.65);
    text-decoration: none;
    transition: color .15s;
}
.puma-page-breadcrumb a:hover { color: #fff; }
.puma-page-breadcrumb .current { color: rgba(255,255,255,.9); }
.puma-page-hero-eyebrow {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #FAEB49;
    font-family: 'Fira Sans', sans-serif;
    margin-bottom: 10px;
}
.puma-page-hero-title {
    font-size: clamp(28px, 4vw, 44px);
    font-weight: 800;
    color: #fff;
    margin: 0 0 12px;
    line-height: 1.15;
    letter-spacing: -.01em;
    font-family: 'Plus Jakarta Sans', sans-serif;
}
.puma-page-hero-desc {
    font-size: 15px;
    color: rgba(255,255,255,.75);
    max-width: 560px;
    line-height: 1.6;
    margin: 0;
    font-family: 'Fira Sans', sans-serif;
}

/* Fond légèrement teinté pour la section contenu */
body.blog,
body.archive,
body.category {
    background-color: #f7f9f7;
}
.puma-archive-wrapper {
    background: #f7f9f7;
}

/* Responsive archive hero */
@media (max-width: 768px) {
    .puma-archive-hero { min-height: 200px; }
    .puma-archive-hero .puma-container { padding-top: 28px; padding-bottom: 28px; }
    .puma-page-hero-title { font-size: 26px; }
}


/* ═══════════════════════════════════════════════════════════════
   IMAGES — object-position: top global
   Évite que les têtes soient coupées sur toutes les images du site
   (cartes articles, single, régions, hero, etc.)
   ═══════════════════════════════════════════════════════════════ */

/* Toutes les images avec object-fit : calées en haut */
.puma-article-card-img,
.puma-single-hero-img__img,
.puma-hcard-img,
.puma-region-card img,
.single_feature_image img,
.image-box img,
.img_obj_fit_center img,
.wp-post-image,
.attachment-medium_large,
.attachment-large,
.attachment-770x400 {
    object-position: top center !important;
}

/* Images dans le contenu WP — laisser en auto (elles ne sont pas croppées) */
.puma-single-content img,
.post_single_content img,
.entry-content img {
    object-position: unset;
}


/* ═══════════════════════════════════════════════════════════════
   SECTION ÉQUIPE — page-apropos.php
   Charte : vert #07853F, jaune #FAEB49, rouge #E31B23
   ═══════════════════════════════════════════════════════════════ */

.puma-equipe-section {
    padding: 80px 0 90px;
    background: #f8faf9;
    border-top: 3px solid #07853F;
}

/* En-tête de section */
.puma-equipe-header {
    text-align: center;
    margin-bottom: 56px;
}
.puma-equipe-kicker {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #07853F;
    background: rgba(7,133,63,.08);
    padding: 4px 14px;
    border-radius: 20px;
    margin-bottom: 14px;
}
.puma-equipe-title {
    font-size: clamp(26px, 4vw, 36px);
    font-weight: 800;
    color: #1a2e1f;
    margin: 0 0 16px;
    line-height: 1.2;
}
.puma-equipe-title span {
    color: #07853F;
}
.puma-equipe-divider {
    width: 56px;
    height: 4px;
    background: linear-gradient(90deg, #07853F, #FAEB49);
    border-radius: 2px;
    margin: 0 auto;
}

/* Grille des membres */
.puma-equipe-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 32px;
}

/* Carte membre */
.puma-membre-card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(7,133,63,.08);
    transition: transform .25s ease, box-shadow .25s ease;
    text-align: center;
}
.puma-membre-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 32px rgba(7,133,63,.16);
}

/* Zone photo */
.puma-membre-photo-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: linear-gradient(135deg, #07853F 0%, #045c2b 100%);
}
.puma-membre-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform .35s ease;
}
.puma-membre-card:hover .puma-membre-photo {
    transform: scale(1.05);
}
.puma-membre-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(7,133,63,.45) 0%, transparent 55%);
    pointer-events: none;
}

/* Initiales (si pas de photo) */
.puma-membre-initiales {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    font-weight: 800;
    color: rgba(255,255,255,.9);
    background: linear-gradient(135deg, #07853F 0%, #045c2b 100%);
    letter-spacing: .04em;
}

/* Infos texte */
.puma-membre-info {
    padding: 18px 16px 22px;
}
.puma-membre-nom {
    font-size: 16px;
    font-weight: 700;
    color: #1a2e1f;
    margin: 0 0 6px;
    line-height: 1.3;
}
.puma-membre-poste {
    font-size: 13px;
    color: #07853F;
    font-weight: 600;
    margin: 0;
    line-height: 1.4;
    padding: 4px 12px;
    background: rgba(7,133,63,.07);
    border-radius: 20px;
    display: inline-block;
}

/* Responsive */
@media (max-width: 768px) {
    .puma-equipe-section { padding: 52px 0 60px; }
    .puma-equipe-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}
@media (max-width: 480px) {
    .puma-equipe-grid { grid-template-columns: 1fr; max-width: 280px; margin: 0 auto; }
}
