/* ===================================================
   PAGE FORMATIONS — STYLES SCOPÉS
   (pas de :root ni de border-radius)
   =================================================== */


/* ---------------------------------
   1️⃣ CONTAINER & BASE STRUCTURE
   --------------------------------- */
.page-formations .container{
  width: min(1100px, 92vw);
  margin-inline: auto;
}


/* ---------------------------------
   2️⃣ HERO (titre principal)
   --------------------------------- */
.page-formations .form-hero{
  background:#f7f6f3;
  padding:2.4rem 0;
  border-bottom:1px solid #ebe8e2;
}
.page-formations .form-overtitle{
  margin:0;
  color:#6b7a86;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:.9rem;
}
.page-formations .form-title{
  margin:.2rem 0 0;
  font-size:clamp(1.8rem,3vw,2.4rem);
  color:#264154;
}
.page-formations .form-intro{
  max-width:820px;
  margin-top:.5rem;
  color:#2d3a43;
}


/* ---------------------------------
   3️⃣ INTRO TEXTE AVANT CATÉGORIES
   --------------------------------- */
.page-formations .form-introtext{
  padding:1.4rem 0;
}
.page-formations .form-introtext .richtext p{
  color:#2d3a43;
  line-height:1.7;
  margin:.6rem 0;
}
.page-formations .form-categories{
  padding-bottom:4rem;
  display:flex;
  justify-content:center;
}


/* ---------------------------------
   4️⃣ INFORMATIONS GÉNÉRALES
   --------------------------------- */
.page-formations .form-infos{
  padding:1rem 0;
}
.page-formations .form-infos > h2{
  margin:0 0 .6rem;
  color:#264154;
  font-size:1.4rem;
}
.page-formations .info-block{
  background:#fff;
  border:1px solid #e8e6e2;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  margin:.9rem 0;
  padding:1rem;
}
.page-formations .info-block h3{
  margin:0 0 .4rem;
  color:#264154;
  font-size:1.15rem;
}
.page-formations .info-block .richtext p{
  color:#2d3a43;
  line-height:1.7;
  margin:.6rem 0;
}
.page-formations .info-block .richtext ul{
  margin:.5rem 0 .6rem .9rem;
}
.page-formations .info-block .richtext li{
  margin:.25rem 0;
  color:#2d3a43;
}


/* ---------------------------------
   5️⃣ GRILLE DES CATÉGORIES
   --------------------------------- */
.page-formations .form-categories{
  padding:2rem 0;
}
.page-formations .cards-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
@media (max-width:980px){
  .page-formations .cards-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .page-formations .cards-grid{ grid-template-columns:1fr; }
}


/* ---------------------------------
   6️⃣ CARDS CATÉGORIES
   --------------------------------- */
.page-formations .card{
  background:#fff;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .2s ease;
}
.page-formations .card:hover{
  transform:translateY(-3px);
}

/* Media des cartes : ratio fixe et uniformisé */
.page-formations .card__media{
  position:relative;
  display:block;
  aspect-ratio:16/10;
  block-size:clamp(180px, 23vw, 260px);
  background:#e9ecef;
  overflow:hidden;
}

/* Fallback pour anciens navigateurs */
@supports not (aspect-ratio: 1 / 1){
  .page-formations .card__media{
    block-size:260px;
  }
  .page-formations .cards-grid{ grid-auto-rows:1fr; }
}

/* Images internes */
.page-formations .card__media picture,
.page-formations .card__media img{
  display:block;
  width:100%;
  height:100%;
}
.page-formations .card__media img{
  position:absolute;
  inset:0;
  object-fit:cover;
  object-position:center;
}

/* Placeholder image */
.page-formations .card__placeholder{
  display:block;
  width:100%;
  height:100%;
  background:linear-gradient(135deg,#dfe6eb,#f3f6f8);
}

/* Corps de carte */
.page-formations .card__body{
  padding:1rem;
}
.page-formations .card__overtitle{
  margin:0 0 .25rem;
  color:#6b7a86;
  letter-spacing:.05em;
  text-transform:uppercase;
  font-size:.85rem;
}
.page-formations .card__title{
  margin:0 0 .3rem;
  font-size:1.2rem;
  color:#264154;
}
.page-formations .card__title a{
  color:inherit;
  text-decoration:none;
}
.page-formations .card__excerpt{
  margin:.2rem 0 .7rem;
  color:#2d3a43;
  line-height:1.6;
}

/* Meta */
.page-formations .card__meta{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  align-items:center;
}
.page-formations .meta-badge{
  background:#f1ece5;
  color:#264154;
  padding:.25rem .6rem;
  font-weight:700;
  font-size:.85rem;
}
.page-formations .meta-subcats{
  color:#6b7a86;
  font-size:.95rem;
}

/* Actions */
.page-formations .card__actions{
  margin-top:.9rem;
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
}


/* ---------------------------------
   7️⃣ BOUTONS LOCAUX
   --------------------------------- */
.page-formations .btn{
  display:inline-block;
  background:#264154;
  color:#fff;
  padding:.55rem .9rem;
  text-decoration:none;
  font-weight:600;
  border:1px solid transparent;
}
.page-formations .btn:hover{
  opacity:.95;
}
.page-formations .btn.btn-ghost{
  background:#fff;
  border:1px solid #e8e6e2;
  color:#264154;
}


/* ---------------------------------
   8️⃣ ÉTATS / REVEAL / UTILITAIRES
   --------------------------------- */
.page-formations [data-reveal]{
  opacity:0;
  transform:translateY(10px);
  transition:opacity .45s ease, transform .45s ease;
}
.page-formations [data-reveal].is-visible{
  opacity:1;
  transform:translateY(0);
}

.page-formations .no-results{
  background:#fff;
  border:1px solid #e8e6e2;
  padding:1rem;
}

.page-formations .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;
}
