/* ==================================================
   PAGE PRÉPA — styles strictement scopés (optimisés)
   ================================================== */


/* -------------------------
   1) Hero & sections
   ------------------------- */
.prepa-hero { 
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: linear-gradient(180deg,#f9f9f7 0%, #fff 100%);
  padding: 56px 16px 40px;
}

.prepa-intro,
.prepa-objectifs,
.prepa-bloc {
  padding: 28px 16px;
}
.prepa-bloc--dp {
  background: linear-gradient(180deg,rgba(210,156,44,.06), transparent 60%);
}
.prepa-bloc--composition {
  background: linear-gradient(180deg,rgba(38,65,84,.06), transparent 60%);
}

.prepa-hero .prepa-title {
  color: #264154;
  font-size: clamp(1.9rem,3vw,2.6rem);
  font-weight: 800;
  margin: .2rem 0 .25rem;
}

.prepa-hero .prepa-subtitle {
  color: #2d3a43;
  max-width: 880px;
  margin: 0 auto;
}


/* -------------------------
   2) Intro texte long
   ------------------------- */
.prepa-intro .narrow {
  max-width: 880px;
  margin: 0 auto;
}
.prepa-intro .richtext {
  color: #2d3a43;
  line-height: 1.65;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}


/* -------------------------
   3) Objectifs & checklist
   ------------------------- */
.prepa-objectifs .container {
  max-width: 1100px;
  margin: 0 auto;
}
.prepa-objectifs .grid-obj {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: flex-start;
  max-width: 880px;
  margin: 0 auto;
  border-top: 1px solid #e9e6e2;
  padding-top: 14px;
}
.prepa-objectifs .h-section {
  margin: 0 0 .35rem;
  font-size: 1.14rem;
  color: #264154;
  font-weight: 800;
}
.prepa-objectifs .muted {
  color: #2d3a43;
}
.prepa-objectifs .col-legend {
  flex: 1 1 260px;
  min-width: 260px;
}
.prepa-objectifs .col-list {
  flex: 1 1 360px;
  min-width: 300px;
}

/* Liste avec puces dorées type front-page */
.prepa-objectifs .checklist {
  margin: .3rem 0 0;
  padding: 0;
  list-style: none;
  color: #2d3a43;
}
.prepa-objectifs .checklist li {
  position: relative;
  margin: .28rem 0;
  padding-left: 1.4rem;
}
/* petit rond doré */
.prepa-objectifs .checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .6em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #d6a743;   /* doré, ajuste si besoin */
  box-shadow: 0 0 0 3px rgba(214,167,67,0.18);
  transform: translateY(-50%);
}


/* -------------------------
   4) En-têtes des blocs
   ------------------------- */
.prepa-bloc .container {
  max-width: 1100px;
  margin: 0 auto;
}
.prepa-bloc .bloc-head {
  display: flex;
  align-items: baseline;
  gap: .5rem;
  margin-bottom: .4rem;
}
.prepa-bloc .h-section {
  margin: 0;
  font-size: 1.14rem;
  color: #264154;
  font-weight: 800;
}
.prepa-bloc .hours {
  color: #264154;
  font-weight: 700;
  opacity: .9;
}


/* -------------------------
   5) Bloc “Composition”
   ------------------------- */
.prepa-bloc--composition .narrow {
  max-width: 880px;
  margin: 0 auto 8px;
}
.prepa-bloc--composition .richtext {
  color: #1f2a33;
  line-height: 1.65;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}


/* -------------------------
   6) Modules — cards grid
   ------------------------- */

.sr-only {
  margin-top: 3rem;
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 3rem;
}
@media (max-width:980px){
  .cards-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .cards-grid{ grid-template-columns:1fr; }
}
.card {
  background: #fff;
  box-shadow: 0 8px 25px rgba(0,0,0,.07);
  overflow: clip;
  display: flex;
  flex-direction: column;
  transition: transform .2s ease;
}
.card:hover {
  transform: translateY(-3px);
}
.card__media {
  display: block;
  aspect-ratio: 16/10;
  background: #e9ecef;
  overflow: hidden;
}
.card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.card__body {
  padding: 1rem;
}
.card__title {
  margin: 0 0 .35rem;
  font-size: 1.15rem;
  color: #264154;
}
.card__title a {
  color: inherit;
  text-decoration: none;
}
.card__meta {
  display: flex;
  gap: .8rem;
  flex-wrap: wrap;
  font-size: .95rem;
  color: #2d3a43;
  margin: .1rem 0 .2rem;
}
.card__meta .meta {
  display: inline-block;
}
.card__meta .meta strong {
  font-weight: 700;
}
.card__link {
  align-self: flex-start;
  margin-top: .6rem;
  display: inline-block;
  background: #f1ece5;
  color: #264154;
  padding: .55rem .9rem;
  text-decoration: none;
  font-weight: 600;
  border: 0;
  cursor: pointer;
}
.card__link:hover {
  opacity: .9;
}


/* -------------------------
   7) Section finale financement
   ------------------------- */
.container.tax-financement {
  padding: 2rem 0 2.6rem;
}
.tax-financement__box {
  background: linear-gradient(180deg,#ffffff,#faf8f5);
  border: 1px solid #ece7e0;
  box-shadow: 0 8px 25px rgba(0,0,0,.07);
  padding: 1.2rem 1.2rem;
}
@media (min-width:860px){
  .tax-financement__box{ padding:1.6rem 1.8rem; }
}
.tax-financement__title {
  margin: .1rem 0 .6rem;
  font-size: clamp(1.25rem,2.4vw,1.6rem);
  color: #264154;
}
.tax-financement__text {
  color: #2d3a43;
  max-width: 900px;
  line-height: 1.65;
}
.tax-financement__text p{
  margin: .45rem 0;
}
.tax-financement__cta {
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  margin-top:.9rem;
}

.btn-ghost {
  background:#264154;
}
.btn-ghost:hover {
  color: #d6a743;
  background: #264154;
}
