/* ═══════════════════════════════════════════════════════════════════════════
   Jumjuma – Trainings  ·  v4.0.0  ·  Yaben
   Responsive mobile-first  ·  WCAG 2.1 AA  ·  Variables CSS dynamiques
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── 1. NEUTRALISATION THÈME ───────────────────────────────────────────── */
.epnf-catalogue, .epnf-catalogue *,
.epnf-form-wrapper, .epnf-form-wrapper * {
  text-align:      left   !important;
  hyphens:         manual !important;
  word-break:      normal !important;
  overflow-wrap:   break-word !important;
  -webkit-hyphens: manual !important;
  box-sizing:      border-box !important;
}
/* Exceptions centrage */
.epnf-bandeau__titre,
.epnf-fiche__num,
.epnf-btn--submit,
.epnf-submit-area,
.epnf-confirmation__titre,
.epnf-pratique__icon,
.epnf-form-contact,
.epnf-catalogue__vide { text-align: center !important; }

/* ── 2. VARIABLES — Valeurs par défaut (écrasées par class-apparence.php) ── */
:root {
  /* Catalogue — Conteneur Principal */
  --jt-cat_width: 90%;
  --jt-cat_margin_x: 5%;
  --jt-cat_margin_top: 1.5rem;
  --jt-cat_margin_bottom: 2rem;
  --jt-cat_padding: 0;
  --jt-cat_bg: transparent;
  --jt-cat_border_radius: 0;
  --jt-cat_font_size: 1rem;
  /* Catalogue — Conteneur Secondaire */
  --jt-cat_container_bg: #ffffff;
  --jt-cat_container_border: 1.5px solid rgba(15,61,94,.12);
  --jt-cat_container_radius: 12px;
  --jt-cat_container_shadow: 0 4px 20px rgba(15,61,94,.08);
  --jt-cat_container_overflow: hidden;
  /* Catalogue — Bandeau */
  --jt-bandeau_bg: linear-gradient(135deg, #0f3d5e 0%, #1a5276 60%, #1e6090 100%);
  --jt-bandeau_padding: 1rem 1.5rem;
  --jt-bandeau_titre_color: #ffffff;
  --jt-bandeau_titre_size: 1.3rem;
  --jt-bandeau_annee_size: .82rem;
  /* Catalogue — Filtres */
  --jt-filtre_bg: #ffffff;
  --jt-filtre_bg_actif: #0f3d5e;
  --jt-filtre_text_color: #334155;
  --jt-filtre_text_actif: #ffffff;
  --jt-filtre_border: 1.5px solid #cbd5e1;
  --jt-filtre_border_actif: 1.5px solid #0f3d5e;
  --jt-filtre_radius: 20px;
  --jt-filtre_size: .82rem;
  --jt-filtre_padding: .5rem .85rem;
  /* Catalogue — Grille */
  --jt-grille_cols: 2;
  --jt-grille_gap: .85rem;
  --jt-grille_padding: .85rem;
  /* Catalogue — Fiche (Premier Plan) */
  --jt-fiche_bg: #ffffff;
  --jt-fiche_border: 1.5px solid rgba(15,61,94,.12);
  --jt-fiche_border_hover: 1.5px solid #0f3d5e;
  --jt-fiche_radius: 12px;
  --jt-fiche_shadow: 0 3px 14px rgba(15,61,94,.06);
  --jt-fiche_shadow_hover: 0 8px 26px rgba(15,61,94,.14);
  --jt-fiche_body_padding: .85rem 1rem;
  --jt-fiche_titre_size: .92rem;
  --jt-fiche_titre_color: #1a1a1a;
  --jt-fiche_titre_weight: 700;
  --jt-fiche_desc_size: .8rem;
  --jt-fiche_desc_color: #595959;
  --jt-fiche_meta_size: .78rem;
  --jt-fiche_meta_color: #595959;
  /* Catalogue — CTA bas */
  --jt-cta_bg: #e7f0fa;
  --jt-cta_border: 1.5px solid #b9d9ee;
  --jt-cta_radius: 12px;
  --jt-cta_text_size: 1rem;
  --jt-cta_text_color: #0f3d5e;
  /* Catalogue — Infos pratiques */
  --jt-pratique_bg: #ffffff;
  --jt-pratique_padding: 1.4rem 1.5rem;
  --jt-pratique_titre_size: 1.05rem;
  --jt-pratique_titre_color: #0f3d5e;
  --jt-pratique_text_size: .82rem;
  --jt-pratique_text_color: #334155;
  --jt-pratique_icon_size: 1.3rem;
  --jt-pratique_cols: 4;
  /* Formulaire — Conteneur Principal */
  --jt-form_width: 90%;
  --jt-form_max_width: 760px;
  --jt-form_margin_x: 5%;
  --jt-form_margin_top: 1.5rem;
  --jt-form_margin_bottom: 2rem;
  --jt-form_padding: 0 15px;
  /* Formulaire — Conteneur Secondaire */
  --jt-form_card_bg: #ffffff;
  --jt-form_card_border: 1.5px solid rgba(15,61,94,.12);
  --jt-form_card_radius: 14px;
  --jt-form_card_shadow: 0 6px 32px rgba(15,61,94,.1);
  /* Formulaire — Header */
  --jt-form_header_bg: linear-gradient(135deg, #0f3d5e 0%, #1a5276 60%, #206090 100%);
  --jt-form_header_padding: 1.4rem 1.5rem 1.5rem;
  --jt-form_header_titre_color: #ffffff;
  --jt-form_header_titre_size: 1.4rem;
  --jt-form_header_soustitre_color: rgba(231,240,250,.88);
  --jt-form_header_soustitre_size: .9rem;
  /* Formulaire — Avertissement */
  --jt-avert_bg: #fef9ec;
  --jt-avert_border: 1.5px solid #fde68a;
  --jt-avert_titre_size: 1.1rem;
  --jt-avert_titre_color: #0f3d5e;
  --jt-avert_text_size: .84rem;
  --jt-avert_text_color: #334155;
  /* Formulaire — Fieldset (Premier Plan) */
  --jt-fieldset_bg: #e7f0fa;
  --jt-fieldset_border: 1.5px solid rgba(15,61,94,.12);
  --jt-fieldset_radius: 12px;
  --jt-fieldset_padding: 0 1.1rem 1.15rem;
  --jt-fieldset_legend_size: .94rem;
  --jt-fieldset_legend_color: #0f3d5e;
  --jt-fieldset_legend_weight: 800;
  /* Formulaire — Labels */
  --jt-label_size: .92rem;
  --jt-label_weight: 700;
  --jt-label_color: #000000;
  /* Formulaire — Inputs */
  --jt-input_bg: #ffffff;
  --jt-input_border: 1.5px solid #cbd5e1;
  --jt-input_radius: 7px;
  --jt-input_text_size: 1rem;
  --jt-input_text_color: #000000;
  --jt-input_padding: .68rem .95rem;
  --jt-input_focus_border: 1.5px solid #d97706;
  --jt-input_focus_shadow: 0 0 0 3px rgba(217,119,6,.3);
  /* Formulaire — Bouton Submit */
  --jt-submit_bg: linear-gradient(135deg, #1a5276, #0f3d5e);
  --jt-submit_color: #ffffff;
  --jt-submit_radius: 12px;
  --jt-submit_size: 1.05rem;
  --jt-submit_width: 35%;
  --jt-submit_padding: 1rem 2rem;
  --jt-submit_shadow: 0 6px 20px rgba(15,61,94,.3);
  /* Formulaire — Bouton Reset */
  --jt-reset_bg: transparent;
  --jt-reset_color: #595959;
  --jt-reset_border: 1.5px solid #cbd5e1;
  --jt-reset_radius: 12px;
  --jt-reset_size: .9rem;
  --jt-reset_width: 35%;
  /* Formulaire — Confirmation succès */
  --jt-success_bg: #e8f4fd;
  --jt-success_border: 2.5px solid #7ec8e3;
  --jt-success_radius: 16px;
  --jt-success_titre_color: #0f3d5e;
  --jt-success_titre_size: 1.6rem;
  --jt-success_text_size: 1.1rem;
  --jt-success_details_bg: #ffffff;
  --jt-success_details_border: 1.5px solid #b9d9ee;
  --jt-success_padding: 2.5rem 2rem;
  /* Formulaire — Contact */
  --jt-contact_bg: #f0f7fc;
  --jt-contact_border: 1.5px solid #b9d9ee;
  --jt-contact_radius: 8px;
  --jt-contact_text_size: 1.05rem;
  --jt-contact_text_color: #334155;
  --jt-contact_icon_size: 18px;
  /* Global — Couleurs */
  --jt-color_blue: #0f3d5e;
  --jt-color_blue_hover: #0a2e47;
  --jt-color_blue_mid: #1a5276;
  --jt-color_sky: #e7f0fa;
  --jt-color_sky_border: #b9d9ee;
  --jt-color_cream: #fef9ec;
  --jt-color_cream_hover: #fdefc5;
  --jt-color_cream_text: #1a3a00;
  --jt-color_text: #1a1a1a;
  --jt-color_sub: #334155;
  --jt-color_muted: #595959;
  --jt-color_focus: #d97706;
  --jt-color_ok: #166534;
  --jt-color_err: #991b1b;
  /* Global — Typographie */
  --jt-font_family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  --jt-base_radius: 12px;
  --jt-touch_target: 44px;
  --jt-focus-ring: 3px solid var(--jt-color_focus);

  /* Catalogue — Layout / Alignement */
  --jt-bandeau_align: left;
  --jt-filtre_align: flex-start;
  --jt-fiche_titre_align: left;
  --jt-fiche_meta_align: flex-start;
  --jt-fiche_actions_align: flex-start;
  --jt-cta_align: space-between;
  --jt-cta_btn_align: flex-end;
  --jt-pratique_align: flex-start;

  /* Formulaire — Layout / Alignement */
  --jt-header_align: left;
  --jt-avert_align: left;
  --jt-fieldset_legend_align: left;
  --jt-label_align: left;
  --jt-submit_align: flex-start;
  --jt-submit_gap: .6rem;
  --jt-success_align: center;
  --jt-contact_align: left;
  --jt-contact_icon_align: flex-start;
}

/* ── 3. UTILITAIRES & ACCESSIBILITÉ ────────────────────────────────────── */
.sr-only {
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.sr-only.focusable:focus {
  position:static;width:auto;height:auto;overflow:visible;
  clip:auto;white-space:normal;margin:inherit;padding:inherit;
}
.epnf-hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* Skip link */
.epnf-skip-link {
  position:absolute;
  top:-100%;
  left:1rem;
  background:var(--jt-color_blue);
  color:#fff !important;
  padding:.75rem 1.25rem;
  border-radius:0 0 8px 8px;
  font-weight:800;
  font-size:.95rem;
  z-index:9999;
  text-decoration:none !important;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.epnf-skip-link:focus {
  top:0;
  color:#fff !important;
  outline:var(--jt-focus-ring);
  outline-offset:2px;
}

/* Focus visible global */
.epnf-catalogue :focus-visible,
.epnf-form-wrapper :focus-visible {
  outline: var(--jt-focus-ring) !important;
  outline-offset: 2px !important;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .epnf-catalogue, .epnf-catalogue *,
  .epnf-form-wrapper, .epnf-form-wrapper * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .epnf-fiche:hover { transform: none !important; }
  .epnf-btn--cta:hover { transform: none !important; }
  .epnf-btn--inscris:hover { transform: none !important; }
  .epnf-btn--submit:hover { transform: none !important; }
}


/* ════════════════════════════════════════════════════════════════════════════
   CATALOGUE
   ════════════════════════════════════════════════════════════════════════════ */
.epnf-catalogue {
  font-family: var(--jt-font_family) !important;
  width: 100% !important;
  max-width: var(--jt-cat_width) !important;
  margin-left: var(--jt-cat_margin_x) !important;
  margin-right: var(--jt-cat_margin_x) !important;
  margin-top: var(--jt-cat_margin_top) !important;
  margin-bottom: var(--jt-cat_margin_bottom) !important;
  padding: var(--jt-cat_padding) !important;
  background: var(--jt-cat_bg) !important;
  border-radius: var(--jt-cat_border_radius) !important;
  font-size: var(--jt-cat_font_size) !important;
}

/* ── Stats avec icônes et calcul automatique ───────────────────────────── */
.epnf-fiche__stats {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 0.25rem 0.4rem !important;
  padding: 0.6rem 0.75rem !important;
  background: #f8fafc !important;
  border-radius: 8px !important;
  margin-top: 0.75rem !important;
  font-size: 0.82rem !important;
  overflow-x: auto !important;
  white-space: nowrap !important;
}

.epnf-stat {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.2rem !important;
  flex-shrink: 0 !important;
}

.epnf-stat__icon {
  font-size: 0.9rem;
}

.epnf-stat__label {
  color: #64748b !important;
  font-size: 0.75rem !important;
}

.epnf-stat__value {
  font-weight: 700 !important;
  color: #0f3d5e !important;
  font-size: 0.8rem !important;
}

.epnf-stat__value--ok {
  color: #16a34a !important;
}

.epnf-stat__value--complet {
  color: #dc2626 !important;
}

.epnf-stat__sep {
  color: #cbd5e1 !important;
  font-weight: 300 !important;
  margin: 0 0.15rem;
  flex-shrink: 0 !important;
}

@media (max-width: 600px) {
  .epnf-fiche__stats {
    font-size: 0.75rem !important;
    gap: 0.2rem 0.3rem !important;
    padding: 0.5rem 0.6rem !important;
  }
  
  .epnf-stat__label {
    font-size: 0.7rem !important;
  }
  
  .epnf-stat__value {
    font-size: 0.75rem !important;
  }
  
  .epnf-stat__icon {
    font-size: 0.8rem;
  }
}

/* ─── EN-TÊTE CATALOGUE (Logo + Titre) ───────────────────────────────── */
.epnf-catalogue__header {
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  margin-bottom: 1.5rem !important;
  padding: 0 0.5rem !important;
}
.epnf-catalogue__logo {
  width: 80px !important;
  height: auto !important;
  border-radius: 8px !important;
  box-shadow: 0 2px 8px rgba(15,61,94,.15) !important;
  flex-shrink: 0 !important;
}
.epnf-catalogue__title {
  font-size: var(--cat-title-size, 1.8rem) !important;
  font-weight: 800 !important;
  color: var(--cat-title-color, #0f3d5e) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}

/* Responsive mobile */
@media (max-width: 600px) {
  .epnf-catalogue__header {
    flex-direction: column !important;
    text-align: center !important;
    gap: 0.75rem !important;
  }
  .epnf-catalogue__logo {
    width: 60px !important;
  }
  .epnf-catalogue__title {
    font-size: 1.4rem !important;
  }
}

/* ─── CONTENEUR VISUEL DU CATALOGUE ──────────────────────────────────── */
.epnf-catalogue__container {
  background: var(--jt-cat_container_bg) !important;
  border: var(--jt-cat_container_border) !important;
  border-radius: var(--jt-cat_container_radius) !important;
  overflow: var(--jt-cat_container_overflow) !important;
  box-shadow: var(--jt-cat_container_shadow) !important;
}
.epnf-catalogue__container::before {
  content: '';
  display: block;
  height: 5px;
  background: linear-gradient(90deg, var(--jt-color_blue), var(--jt-color_blue_mid), #1e6090);
}

/* ─── BANDEAU ──────────────────────────────────────────────────────────── */
.epnf-bandeau {
  background: var(--jt-bandeau_bg) !important;
  padding: var(--jt-bandeau_padding) !important;
  border-radius: var(--jt-cat_container_radius) var(--jt-cat_container_radius) 0 0 !important;
  margin: 0 !important;
  border: none !important;
  position: relative;
  overflow: hidden;
}
.epnf-bandeau::before {
  content: '';
  position: absolute;
  right: -30px; top: -30px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: rgba(231,240,250,.07);
  pointer-events: none;
}
.epnf-bandeau__inner {
  display: flex !important;
  align-items: center !important;
  gap: .7rem !important;
  position: relative;
  z-index: 1;
  justify-content: var(--jt-bandeau_align);
}
.epnf-bandeau__icon {
  font-size: 1.6rem !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  padding-right: .7rem !important;
  border-right: 2px solid rgba(255,255,255,.3) !important;
}
body .epnf-bandeau__titre,
.epnf-bandeau__titre {
  color: var(--jt-bandeau_titre_color) !important;
  font-size: var(--jt-bandeau_titre_size) !important;
  font-weight: 900 !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
  text-decoration: none !important;
}
.epnf-bandeau__annee {
  color: rgba(231,240,250,.75) !important;
  font-size: var(--jt-bandeau_annee_size) !important;
  margin-left: auto !important;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ─── FILTRES ──────────────────────────────────────────────────────────── */
.epnf-filtres {
  display: flex;
  gap: .45rem;
  flex-wrap: wrap;
  justify-content: var(--jt-filtre_align);
  margin: 0 0 1rem;
  padding: .65rem .85rem;
  background: #f8fafc;
  border: none;
  border-bottom: 1.5px solid rgba(15,61,94,.1);
}
.epnf-filtre {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .3rem;
  padding: var(--jt-filtre_padding) !important;
  min-height: var(--jt-touch_target);
  border: var(--jt-filtre_border) !important;
  border-radius: var(--jt-filtre_radius) !important;
  background: var(--jt-filtre_bg) !important;
  color: var(--jt-filtre_text_color) !important;
  font-size: var(--jt-filtre_size) !important;
  font-weight: 600 !important;
  font-family: var(--jt-font_family) !important;
  cursor: pointer;
  transition: background 150ms, color 150ms, border-color 150ms;
  white-space: nowrap;
}
.epnf-filtre:hover {
  border-color: var(--jt-color_blue) !important;
  background: var(--jt-color_sky) !important;
  color: var(--jt-color_blue) !important;
}
.epnf-filtre--actif {
  background: var(--jt-filtre_bg_actif) !important;
  color: var(--jt-filtre_text_actif) !important;
  border-color: var(--jt-filtre_border_actif) !important;
}
.epnf-filtre__icon { font-size: .9rem; }

/* ─── GRILLE FORMATIONS ────────────────────────────────────────────────── */
.epnf-grille {
  display: grid;
  grid-template-columns: repeat(var(--jt-grille_cols), 1fr);
  gap: var(--jt-grille_gap);
  list-style: none !important;
  margin: 0 !important;
  padding: var(--jt-grille_padding) !important;
  width: 100% !important;
}

/* Fiche formation */
.epnf-fiche {
  display: flex;
  align-items: stretch;
  background: #f0f9ff !important;
  border: 2px solid #0f3d5e !important;
  border-radius: var(--jt-fiche_radius) !important;
  overflow: hidden !important;
  box-shadow: 0 4px 12px rgba(15, 61, 94, 0.25) !important;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
  min-width: 0;
}
.epnf-fiche:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 6px 20px rgba(15, 61, 94, 0.35) !important;
  border-color: #1a5276 !important;
  background: #e0f2fe !important;
}
.epnf-fiche--complet { border-color: #d97706 !important; background: #fef3c7 !important; box-shadow: 0 4px 12px rgba(217, 119, 6, 0.25) !important; }
.epnf-fiche--complet:hover { border-color: #b45309 !important; background: #fde68a !important; box-shadow: 0 6px 20px rgba(217, 119, 6, 0.35) !important; }
.epnf-fiche--hidden { display: none !important; }

/* Barre accent gauche */
.epnf-fiche__accent {
  width: 6px;
  flex-shrink: 0;
  background: linear-gradient(180deg, var(--jt-color_blue), var(--jt-color_blue_mid));
}
.epnf-fiche--complet .epnf-fiche__accent {
  background: linear-gradient(180deg, #fbbf24, #d97706);
}

/* Corps de la fiche */
.epnf-fiche__body {
  flex: 1 !important;
  min-width: 0 !important;
  padding: var(--jt-fiche_body_padding) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: .3rem !important;
}

/* Numéro + titre */
.epnf-fiche__top {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
}
.epnf-fiche__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  background: var(--jt-color_blue);
  color: #ffffff !important;
  font-size: .65rem !important;
  font-weight: 900 !important;
  border-radius: 6px;
  flex-shrink: 0;
  line-height: 1;
}

body .epnf-fiche__titre,
.epnf-fiche__titre {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.3 !important;
  border: none !important;
  background: none !important;
  text-align: var(--jt-fiche_titre_align);
}
body .epnf-fiche__titre a,
.epnf-fiche__titre a {
  color: #0f3d5e !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  text-decoration-skip-ink: auto;
}
.epnf-fiche__titre a:hover { color: #1e40af !important; text-decoration: none !important; }
.epnf-fiche__titre a:focus-visible { outline: 3px solid #0f3d5e !important; outline-offset: 3px !important; border-radius: 3px; }

/* Description */
.epnf-fiche__desc {
  font-size: 0.8rem !important;
  color: var(--jt-fiche_desc_color) !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}

/* Métadonnées */
.epnf-fiche__meta {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  justify-content: var(--jt-fiche_meta_align);
  margin-top: .15rem;
}
.epnf-meta {
  font-size: 0.75rem !important;
  color: #1e293b !important;
  font-weight: 500 !important;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: .15rem;
}
.epnf-meta--places { color: var(--jt-color_ok) !important; font-weight: 600 !important; }
.epnf-meta--complet { color: #b45309 !important; }

/* Actions */
.epnf-fiche__actions {
  display: flex;
  align-items: center;
  gap: .7rem;
  margin-top: .35rem;
  flex-wrap: wrap;
  justify-content: var(--jt-fiche_actions_align);
}
.epnf-fiche__link {
  font-size: .75rem !important;
  font-weight: 600 !important;
  color: #0f3d5e !important;
  text-decoration: none !important;
  padding: .25rem 0;
}
.epnf-fiche__link:hover { color: #1e40af !important; text-decoration: none !important; background: rgba(15, 61, 94, 0.08) !important; border-radius: 4px !important; padding: .25rem .5rem !important; }
.epnf-fiche__link:focus-visible { outline: var(--jt-focus-ring) !important; outline-offset: 2px; border-radius: 3px; }

/* ─── CTA BAS ──────────────────────────────────────────────────────────── */
.epnf-cta-bas {
  display: flex;
  align-items: center;
  justify-content: var(--jt-cta_align);
  gap: 1rem;
  flex-wrap: wrap;
  margin: 0 .85rem .85rem !important;
  padding: 1.1rem 1.4rem;
  background: var(--jt-cta_bg) !important;
  border: var(--jt-cta_border) !important;
  border-radius: var(--jt-cta_radius);
}
.epnf-cta-bas__btn-wrap {
  display: flex;
  justify-content: var(--jt-cta_btn_align);
}
.epnf-cta-bas__text strong {
  display: block;
  font-size: var(--jt-cta_text_size) !important;
  color: var(--jt-cta_text_color) !important;
  margin-bottom: .1rem;
}
.epnf-cta-bas__text span {
  font-size: .88rem !important;
  color: var(--jt-color_sub) !important;
}

/* ─── VIDE ─────────────────────────────────────────────────────────────── */
.epnf-catalogue__vide {
  padding: 3rem;
  background: var(--jt-color_sky);
  border-radius: var(--jt-base_radius);
  border: 1.5px dashed var(--jt-color_sky_border);
  color: var(--jt-color_muted) !important;
}
.epnf-vide__icon { font-size: 2.5rem; display: block; margin-bottom: .5rem; }

/* ─── INFOS PRATIQUES ──────────────────────────────────────────────────── */
.epnf-pratique {
  background: var(--jt-pratique_bg) !important;
  border-top: 1.5px solid rgba(15,61,94,.1) !important;
  border-radius: 0 !important;
  padding: var(--jt-pratique_padding) !important;
  box-shadow: none !important;
  margin: 0 !important;
}
.epnf-pratique__titre {
  font-size: var(--jt-pratique_titre_size) !important;
  font-weight: 800 !important;
  color: var(--jt-pratique_titre_color) !important;
  margin: 0 0 1rem !important;
  padding-bottom: .5rem;
  border-bottom: 2px solid var(--jt-color_sky);
}
.epnf-pratique__grille {
  display: grid;
  grid-template-columns: repeat(var(--jt-pratique_cols), 1fr);
  gap: 1rem;
  justify-items: var(--jt-pratique_align);
}
.epnf-pratique__item {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
}
.epnf-pratique__icon {
  font-size: var(--jt-pratique_icon_size);
  flex-shrink: 0;
  margin-top: .15rem;
}
.epnf-pratique__item strong {
  display: block;
  font-size: .85rem !important;
  color: var(--jt-color_blue) !important;
  font-weight: 800 !important;
  margin-bottom: .15rem;
}
.epnf-pratique__item p {
  font-size: var(--jt-pratique_text_size) !important;
  color: var(--jt-pratique_text_color) !important;
  line-height: 1.45 !important;
  margin: 0 !important;
}
.epnf-pratique__item a {
  color: var(--jt-color_blue) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}
.epnf-pratique__item a:focus-visible { outline: var(--jt-focus-ring) !important; outline-offset: 2px; border-radius: 3px; }


/* ════════════════════════════════════════════════════════════════════════════
   BOUTONS (communs catalogue + formulaire)
   ════════════════════════════════════════════════════════════════════════════ */
.epnf-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .35rem;
  border-radius: 7px;
  font-family: var(--jt-font_family) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background 150ms, color 150ms, box-shadow 200ms, transform 100ms;
  white-space: nowrap !important;
  line-height: 1.3 !important;
  min-height: var(--jt-touch_target);
  padding-top: .55rem !important;
  padding-bottom: .55rem !important;
}
.epnf-btn:focus-visible { outline: var(--jt-focus-ring) !important; outline-offset: 3px; }

/* "Je m'inscris" : crème */
a.epnf-btn--inscris, .epnf-btn--inscris,
a.epnf-btn--inscris:link, a.epnf-btn--inscris:visited {
  background: var(--jt-color_cream) !important;
  color: var(--jt-color_cream_text) !important;
  border-color: rgba(15,61,94,.25) !important;
  font-size: .82rem !important;
  padding: .55rem .9rem !important;
  text-decoration: none !important;
}
a.epnf-btn--inscris:hover, .epnf-btn--inscris:hover {
  background: var(--jt-color_cream_hover) !important;
  color: var(--jt-color_cream_text) !important;
  transform: translateY(-1px);
}

/* Liste attente */
.epnf-btn--attente {
  background: #fef9c3 !important;
  color: #713f12 !important;
  border-color: #fde68a !important;
}
.epnf-btn--attente:hover { background: #fdefc5 !important; }

/* Secondaire */
a.epnf-btn--secondary, .epnf-btn--secondary,
a.epnf-btn--secondary:link, a.epnf-btn--secondary:visited {
  background: #ffffff !important;
  color: var(--jt-color_blue) !important;
  border-color: var(--jt-color_blue) !important;
  font-size: .9rem !important;
  padding: .55rem 1.1rem !important;
  text-decoration: none !important;
}
a.epnf-btn--secondary:hover, .epnf-btn--secondary:hover { background: var(--jt-color_sky) !important; }

/* Retour au catalogue */
a.epnf-btn--retour, .epnf-btn--retour,
a.epnf-btn--retour:link, a.epnf-btn--retour:visited {
  background: transparent !important;
  color: var(--jt-color_blue) !important;
  border: none !important;
  font-size: .9rem !important;
  font-weight: 700 !important;
  padding: .35rem 0 !important;
  text-decoration: none !important;
  min-height: 40px;
  display: inline-flex !important;
  align-items: center !important;
  gap: .3rem;
}
a.epnf-btn--retour:hover, .epnf-btn--retour:hover { text-decoration: none !important; }

/* CTA */
.epnf-btn--cta {
  background: linear-gradient(135deg, var(--jt-color_cream), var(--jt-color_cream_hover)) !important;
  color: var(--jt-color_cream_text) !important;
  border: 2px solid rgba(15,61,94,.2) !important;
  font-size: .95rem !important;
  font-weight: 800 !important;
  padding: .7rem 1.5rem !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  box-shadow: 0 4px 14px rgba(15,61,94,.15);
}
.epnf-btn--cta:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(15,61,94,.35); }
.epnf-btn--cta:focus-visible { outline-offset: 4px; }


/* ════════════════════════════════════════════════════════════════════════════
   FORMULAIRE D'INSCRIPTION
   ════════════════════════════════════════════════════════════════════════════ */
.epnf-form-wrapper {
  font-family: var(--jt-font_family) !important;
  max-width: var(--jt-form_width) !important;
  margin-left: var(--jt-form_margin_x) !important;
  margin-right: var(--jt-form_margin_x) !important;
  margin-top: var(--jt-form_margin_top) !important;
  margin-bottom: var(--jt-form_margin_bottom) !important;
  padding: var(--jt-form_padding) !important;
}

.epnf-form-retour { margin-bottom: .75rem; }

/* ═══════════════════════════════════════════════════════════════════════
   MESSAGE DE SUCCÈS
   ═══════════════════════════════════════════════════════════════════════ */
.epnf-success {
  background: var(--jt-success_bg) !important;
  border: var(--jt-success_border) !important;
  border-radius: var(--jt-success_radius) !important;
  padding: var(--jt-success_padding) !important;
  text-align: var(--jt-success_align) !important;
  box-shadow: 0 8px 30px rgba(15,61,94,.1) !important;
}
.epnf-success__icon { display: flex !important; justify-content: center !important; margin-bottom: 1rem; }
.epnf-success__icon svg { animation: epnf-check-pop 400ms ease-out; }
@keyframes epnf-check-pop {
  0%   { transform: scale(0.3); opacity: 0; }
  60%  { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(1); }
}
.epnf-success__titre {
  color: var(--jt-success_titre_color) !important;
  font-size: var(--jt-success_titre_size) !important;
  font-weight: 900 !important;
  margin: 0 0 1rem !important;
  line-height: 1.3 !important;
}
.epnf-success__msg {
  font-size: var(--jt-success_text_size) !important;
  color: #1e293b !important;
  line-height: 1.7 !important;
  margin: 0 0 1.5rem !important;
  max-width: 520px;
  margin-left: auto !important;
  margin-right: auto !important;
}
.epnf-success__attente {
  background: #fef9c3 !important;
  border: 1.5px solid #fde68a !important;
  border-radius: 8px !important;
  padding: .8rem 1rem !important;
  margin: 0 auto 1.5rem !important;
  max-width: 520px;
}
.epnf-success__attente p { margin: 0 !important; color: #713f12 !important; font-size: .95rem !important; font-weight: 600 !important; }
.epnf-success__details {
  background: var(--jt-success_details_bg) !important;
  border: var(--jt-success_details_border) !important;
  border-radius: 10px !important;
  padding: 1rem 1.2rem !important;
  max-width: 520px;
  margin: 0 auto 1.5rem !important;
  text-align: left !important;
}
.epnf-success__detail-row {
  display: flex !important;
  align-items: center !important;
  gap: .6rem !important;
  margin-bottom: .6rem !important;
  font-size: 1.05rem !important;
  color: #1e293b !important;
  line-height: 1.6 !important;
}
.epnf-success__detail-row:last-child { margin-bottom: 0 !important; }
.epnf-success__detail-icon { flex-shrink: 0; font-size: 1.25rem; }
.epnf-success__details a { color: var(--jt-color_blue) !important; font-weight: 700 !important; text-decoration: none !important; }
.epnf-success__line {
  font-size: 1.05rem !important;
  color: #1e293b !important;
  line-height: 1.7 !important;
  margin: 0 0 .5rem !important;
  display: flex !important;
  align-items: center !important;
  gap: .5rem !important;
  flex-wrap: wrap !important;
}
.epnf-success__line:last-child { margin-bottom: 0 !important; }
.epnf-success__sep {
  color: #94a3b8 !important;
  font-weight: 400 !important;
  margin: 0 .2rem !important;
}
.epnf-success__detail-icon svg { vertical-align: middle; }
.epnf-success__retour { margin-top: 1.5rem; padding-top: 1.2rem; border-top: 1px solid #b9d9ee !important; }

/* ═══════════════════════════════════════════════════════════════════════
   MESSAGE D'ERREUR (même style que succès : fond bleu ciel clair)
   ═══════════════════════════════════════════════════════════════════════ */
.epnf-error {
  background: var(--jt-success_bg) !important;
  border: var(--jt-success_border) !important;
  border-radius: var(--jt-success_radius) !important;
  padding: var(--jt-success_padding) !important;
  text-align: center !important;
  box-shadow: 0 8px 30px rgba(15,61,94,.1) !important;
}
.epnf-error__icon { display: flex !important; justify-content: center !important; margin-bottom: 1rem; }
.epnf-error__icon svg { animation: epnf-error-shake 400ms ease-out; }
@keyframes epnf-error-shake {
  0%   { transform: scale(0.3); opacity: 0; }
  40%  { transform: scale(1.1) rotate(-3deg); opacity: 1; }
  60%  { transform: scale(1) rotate(2deg); }
  80%  { transform: rotate(-1deg); }
  100% { transform: rotate(0deg); }
}
.epnf-error__titre {
  color: var(--jt-success_titre_color) !important;
  font-size: var(--jt-success_titre_size) !important;
  font-weight: 900 !important;
  margin: 0 0 .6rem !important;
  line-height: 1.3 !important;
}
.epnf-error__msg {
  font-size: var(--jt-success_text_size) !important;
  color: #1e293b !important;
  line-height: 1.7 !important;
  margin: 0 0 1.2rem !important;
  max-width: 520px;
  margin-left: auto !important;
  margin-right: auto !important;
}
.epnf-error__details {
  background: #ffffff !important;
  border: 1.5px solid #b9d9ee !important;
  border-radius: 10px !important;
  padding: 1rem 1.2rem !important;
  max-width: 520px;
  margin: 0 auto 1.2rem !important;
  text-align: left !important;
}
.epnf-error__details ul {
  margin: 0 !important;
  padding-left: 0 !important;
  list-style: none !important;
}
.epnf-error__details li {
  display: flex !important;
  align-items: flex-start !important;
  gap: .5rem;
  margin-bottom: .5rem !important;
  font-size: 1.02rem !important;
  color: #1e293b !important;
  line-height: 1.55 !important;
}
.epnf-error__details li:last-child { margin-bottom: 0 !important; }
.epnf-error__detail-icon { flex-shrink: 0; font-size: 1.1rem; margin-top: .05rem; }
.epnf-error__contact {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #b9d9ee !important;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
.epnf-error__detail-row {
  display: flex !important;
  align-items: center !important;
  gap: .5rem;
  margin-bottom: .4rem !important;
  font-size: 1.05rem !important;
  color: #1e293b !important;
  line-height: 1.6 !important;
  justify-content: center;
}
.epnf-error__detail-row:last-child { margin-bottom: 0 !important; }
.epnf-error__detail-row a {
  color: var(--jt-color_blue) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}

/* Carte formulaire */
.epnf-form-card {
  background: var(--jt-form_card_bg);
  border-radius: var(--jt-form_card_radius);
  box-shadow: var(--jt-form_card_shadow);
  overflow: hidden;
  border: var(--jt-form_card_border);
}

/* Header formulaire */
.epnf-form-card__header {
  background: var(--jt-form_header_bg) !important;
  padding: var(--jt-form_header_padding);
  position: relative;
  overflow: hidden;
}
.epnf-form-card__header::before {
  content: '';
  position: absolute;
  right: -30px; top: -30px;
  width: 130px; height: 130px;
  border-radius: 50%;
  background: rgba(231,240,250,.08);
}
.epnf-form-card__header::after {
  content: '';
  position: absolute;
  right: 50px; bottom: -25px;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(231,240,250,.05);
}
.epnf-form-card__header-inner { display: flex; align-items: center; gap: .75rem; position: relative; z-index: 1; justify-content: var(--jt-header_align); }
.epnf-form-card__icon { font-size: 1.8rem; flex-shrink: 0; padding-right: .75rem; border-right: 2px solid rgba(255,255,255,.3); }

body .epnf-form-card__header .epnf-form-card__titre,
.epnf-form-card__titre {
  color: var(--jt-form_header_titre_color) !important;
  margin: 0 0 .3rem !important;
  font-size: var(--jt-form_header_titre_size) !important;
  font-weight: 900 !important;
  position: relative;
  background: none !important;
  border: none !important;
}
body .epnf-form-card__header .epnf-form-card__sous-titre,
.epnf-form-card__sous-titre {
  color: var(--jt-form_header_soustitre_color) !important;
  margin: 0 !important;
  font-size: var(--jt-form_header_soustitre_size) !important;
  position: relative;
}
.epnf-form-card__sous-titre abbr[title] { color: #fde68a !important; text-decoration: none; font-weight: 800; cursor: help; border-bottom: 1px dotted #fde68a; }

/* Avertissement */
.epnf-form-avertissement {
  background: var(--jt-avert_bg);
  border-bottom: var(--jt-avert_border);
  padding: .85rem 1.2rem;
  text-align: var(--jt-avert_align);
}
.epnf-form-avertissement p { margin: 0 0 .4rem !important; font-size: var(--jt-avert_titre_size) !important; color: var(--jt-avert_titre_color) !important; font-weight: 800 !important; }
.epnf-form-avertissement ul { margin: .3rem 0 0 !important; padding-left: 1.15rem; font-size: var(--jt-avert_text_size) !important; color: var(--jt-avert_text_color) !important; line-height: 1.55; }
.epnf-form-avertissement li { margin-bottom: .2rem; }

/* Formulaire */
.epnf-form { padding: 1.5rem; }
.epnf-fieldset {
  border: var(--jt-fieldset_border) !important;
  border-radius: var(--jt-fieldset_radius) !important;
  padding: var(--jt-fieldset_padding) !important;
  margin: 0 0 1.2rem !important;
  background: var(--jt-fieldset_bg) !important;
  overflow: hidden !important;
}
.epnf-fieldset:focus-within { border-color: rgba(15,61,94,.35); box-shadow: 0 2px 8px rgba(15,61,94,.07); }
.epnf-fieldset__legend {
  font-weight: var(--jt-fieldset_legend_weight) !important;
  font-size: var(--jt-fieldset_legend_size) !important;
  color: var(--jt-fieldset_legend_color) !important;
  padding: .65rem .5rem .4rem !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(15,61,94,.1) !important;
  background: transparent !important;
  display: block !important;
  text-align: var(--jt-fieldset_legend_align);
}
.epnf-fieldset--rgpd { background: #eef4fb !important; border-color: var(--jt-color_sky_border) !important; }
.epnf-fieldset--rgpd .epnf-fieldset__legend { background: transparent !important; }

.epnf-field { margin-bottom: .9rem; }
.epnf-field:last-child { margin-bottom: 0; }
.epnf-field--civilite .epnf-fieldset--radio { border: none; padding: 0; margin: 0; background: transparent; }
.epnf-field--age .epnf-field__help { display: inline !important; margin-left: .3rem !important; }
.epnf-field--cp .epnf-input--short { max-width: 130px; }
.epnf-field--checkbox .epnf-checkbox-label { margin-top: .25rem; }
.epnf-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; margin-bottom: .9rem; }

.epnf-label {
  display: block !important;
  font-weight: var(--jt-label_weight) !important;
  font-size: var(--jt-label_size) !important;
  color: var(--jt-label_color) !important;
  margin-bottom: .38rem !important;
  text-align: var(--jt-label_align);
}
.epnf-label abbr[title] { color: var(--jt-color_blue) !important; text-decoration: none; cursor: help; font-weight: 800; border-bottom: none; }
.epnf-facultatif { font-weight: 400 !important; font-size: .8rem !important; color: var(--jt-color_muted) !important; margin-left: 4px; }

.epnf-input, .epnf-select {
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: var(--jt-input_padding) !important;
  font-size: var(--jt-input_text_size) !important;
  font-family: var(--jt-font_family) !important;
  color: var(--jt-input_text_color) !important;
  background: var(--jt-input_bg) !important;
  border: var(--jt-input_border) !important;
  border-radius: var(--jt-input_radius) !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  min-height: var(--jt-touch_target);
  transition: border-color 150ms, box-shadow 150ms;
}
.epnf-input:focus, .epnf-select:focus {
  border-color: var(--jt-color_focus) !important;
  box-shadow: var(--jt-input_focus_shadow) !important;
  outline: none !important;
}
.epnf-input[aria-invalid="true"],
.epnf-select[aria-invalid="true"] {
  border-color: var(--jt-color_err) !important;
  box-shadow: 0 0 0 3px rgba(185,28,28,.2) !important;
}
.epnf-input--short { max-width: 130px; }
.epnf-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24'%3E%3Cpath fill='%230f3d5e' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right .8rem center !important;
  padding-right: 2.75rem !important;
  cursor: pointer;
}
.epnf-field__help { display: block !important; font-size: .8rem !important; color: var(--jt-color_muted) !important; margin-top: .28rem !important; line-height: 1.4 !important; }
.epnf-field__error { display: block; font-size: .82rem; color: var(--jt-color_err); margin-top: .25rem; font-weight: 600; min-height: 0; }
.epnf-field__error:empty { display: none; }

/* Résumé erreurs JS */
.epnf-js-errors {
  background: #fef2f2 !important;
  border: 1.5px solid #fecaca !important;
  border-radius: 8px !important;
  padding: 1rem 1.2rem !important;
  margin-bottom: 1.2rem !important;
}
.epnf-js-errors ul { list-style: disc !important; }
.epnf-js-errors li { margin-bottom: .2rem; }

.epnf-radio-group { display: flex !important; gap: .55rem; flex-wrap: wrap; margin-top: .38rem; }
.epnf-radio-label {
  display: flex !important;
  align-items: center !important;
  gap: .4rem;
  font-size: .93rem !important;
  font-weight: 500 !important;
  color: var(--jt-color_sub) !important;
  cursor: pointer;
  padding: .48rem .85rem !important;
  min-height: var(--jt-touch_target);
  border: var(--jt-input_border) !important;
  border-radius: var(--jt-input_radius) !important;
  background: var(--jt-input_bg) !important;
  transition: border-color 150ms, background 150ms;
  user-select: none;
}
.epnf-radio-label:hover { border-color: var(--jt-color_blue) !important; background: var(--jt-color_sky) !important; }
.epnf-radio-label:has(input:checked) { border-color: var(--jt-color_blue) !important; background: var(--jt-color_sky) !important; color: var(--jt-color_blue) !important; font-weight: 700 !important; }
.epnf-radio-label:has(input:focus-visible) { outline: var(--jt-focus-ring) !important; outline-offset: 2px; }
.epnf-radio-label input[type="radio"] { accent-color: var(--jt-color_blue); width: 1.1rem; height: 1.1rem; cursor: pointer; flex-shrink: 0; }

.epnf-rgpd-text { background: #ffffff !important; border: 1px solid var(--jt-color_sky_border) !important; border-radius: 7px; padding: .8rem 1rem; margin-bottom: .8rem; font-size: .87rem !important; color: var(--jt-color_sub) !important; line-height: 1.55 !important; text-align: justify !important; }
.epnf-rgpd-text p { margin: .3rem 0 !important; word-break: normal !important; overflow-wrap: break-word !important; }
.epnf-checkbox-label {
  display: flex !important;
  align-items: flex-start !important;
  gap: .6rem;
  cursor: pointer;
  font-size: .93rem !important;
  color: var(--jt-color_sub) !important;
  line-height: 1.55 !important;
  min-height: var(--jt-touch_target);
  padding: .4rem 0;
}
.epnf-checkbox-label input[type="checkbox"] { accent-color: var(--jt-color_blue); width: 1.3rem; height: 1.3rem; flex-shrink: 0; margin-top: .05rem; cursor: pointer; }
.epnf-checkbox-label a { color: var(--jt-color_blue) !important; font-weight: 700 !important; text-decoration: underline !important; text-decoration-skip-ink: auto; }
.epnf-checkbox-label a:focus-visible { outline: var(--jt-focus-ring) !important; outline-offset: 2px; border-radius: 3px; }

/* Info formation pré-sélectionnée */
.epnf-formation-info { background: #ffffff; border: 1px solid var(--jt-color_sky_border); border-radius: 7px; padding: .75rem 1rem; margin-top: .6rem; }
.epnf-formation-info__desc { font-size: .85rem !important; color: var(--jt-color_sub) !important; line-height: 1.5 !important; margin: 0 0 .4rem !important; }
.epnf-formation-info__meta { display: flex; gap: .6rem; flex-wrap: wrap; font-size: .8rem !important; color: var(--jt-color_muted) !important; }
.epnf-formation-info__link { display: inline-flex; align-items: center; margin-top: .3rem; font-size: .8rem !important; font-weight: 600 !important; color: var(--jt-color_blue) !important; text-decoration: none !important; padding: .35rem 0; min-height: var(--jt-touch_target); }
.epnf-formation-info__link:hover { text-decoration: underline !important; }
.epnf-formation-info__link:focus-visible { outline: var(--jt-focus-ring) !important; outline-offset: 2px; border-radius: 3px; }

.epnf-submit-area { padding-top: .5rem; display: flex; flex-wrap: wrap; gap: var(--jt-submit_gap); justify-content: var(--jt-submit_align); }
.epnf-btn--submit {
  background: var(--jt-submit_bg) !important;
  color: var(--jt-submit_color) !important;
  border: none !important;
  font-size: var(--jt-submit_size) !important;
  font-weight: 800 !important;
  padding: var(--jt-submit_padding) !important;
  border-radius: var(--jt-submit_radius) !important;
  cursor: pointer;
  width: var(--jt-submit_width);
  min-width: 180px;
  min-height: 52px;
  justify-content: center !important;
  box-shadow: var(--jt-submit_shadow);
}
.epnf-btn--submit:hover { background: linear-gradient(135deg,#0f3d5e,#0a2e47) !important; transform: translateY(-2px); }

.epnf-btn--reset {
  background: var(--jt-reset_bg) !important;
  color: var(--jt-reset_color) !important;
  border: var(--jt-reset_border) !important;
  font-size: var(--jt-reset_size) !important;
  font-weight: 600 !important;
  padding: .6rem 1.5rem !important;
  border-radius: var(--jt-reset_radius) !important;
  width: var(--jt-reset_width);
  min-width: 140px;
  cursor: pointer;
}
.epnf-btn--reset:hover { background: #f8fafc !important; color: var(--jt-color_err) !important; border-color: #fca5a5 !important; }
.epnf-submit-info { font-size: .78rem !important; color: var(--jt-color_muted) !important; margin: .65rem 0 0 !important; line-height: 1.5 !important; flex-basis: 100%; }

/* Contact sous formulaire */
.epnf-form-contact {
  margin-top: 1.25rem;
  padding: 1rem 1.2rem;
  background: var(--jt-contact_bg);
  border-radius: var(--jt-contact_radius);
  border: var(--jt-contact_border);
  text-align: var(--jt-contact_align);
}
.epnf-form-contact p { margin: 0 0 .4rem !important; font-size: var(--jt-contact_text_size) !important; color: var(--jt-contact_text_color) !important; line-height: 1.6 !important; }
.epnf-form-contact p:last-child { margin-bottom: 0 !important; }
.epnf-form-contact a { color: var(--jt-color_blue) !important; font-weight: 700 !important; text-decoration: underline !important; text-decoration-skip-ink: auto; padding: .15rem 0; }
.epnf-form-contact a:focus-visible { outline: var(--jt-focus-ring) !important; outline-offset: 2px; border-radius: 3px; }
.epnf-contact-icon { display: inline-flex; align-items: center; gap: .35rem; margin-right: .3rem; justify-content: var(--jt-contact_icon_align); }
.epnf-contact-icon svg { width: var(--jt-contact_icon_size); height: var(--jt-contact_icon_size); flex-shrink: 0; vertical-align: middle; }


/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Les variables CSS changent via class-apparence.php
   Les media queries ci-dessous gèrent uniquement les changements
   structurels (flex-direction, grid, etc.) pas les variables.
   ════════════════════════════════════════════════════════════════════════════ */

@media (max-width: 680px) {
  .epnf-fiche__meta { gap: .4rem; }
  .epnf-fiche__actions { flex-direction: column; align-items: stretch; }
  .epnf-fiche__actions .epnf-btn--inscris { width: 100% !important; }
}

@media (max-width: 600px) {
  .epnf-cta-bas { flex-direction: column; padding: 1rem 15px; }
  .epnf-cta-bas .epnf-btn--cta { width: 100% !important; }
  .epnf-field-row { grid-template-columns: 1fr !important; gap: .6rem; }
  .epnf-input--short { max-width: 100% !important; }
  .epnf-radio-group { gap: .4rem; }
}

@media (min-width: 1200px) {
  .epnf-catalogue {
    max-width: 1100px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .epnf-form-wrapper {
    max-width: var(--jt-form_max_width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
