/* ===============================
SECTION CARTES
=============================== */

.section-cartes .container{
  position: relative;
}

.section-cartes__inner{
  position: relative;
}

.section-cartes__inner.has-content-bg{
  border-radius: 24px;
  padding: clamp(24px, 4vw, 40px);
}

/* ===============================
GRILLE
=============================== */
/*.container.full .cartes-grid {
    max-width: 1400px;
    width: 85%;
}*/
.section-cartes__intro.is-center {
    max-width: 1200px;
    margin: 0 auto clamp(24px, 4vw, 36px) auto;
}
.section-cartes .cartes-grid{
  display: grid;
  gap: 12px;
  margin-inline: auto;
	width: min(1400px, 92%);
}

.section-cartes .cartes-grid.cols-3{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.section-cartes .cartes-grid.cols-4{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* ===============================
INTRO / FOOTER
=============================== */

.section-cartes__intro{
  margin-bottom: clamp(24px, 4vw, 36px);
}

.section-cartes__intro.is-center{
  text-align: center;
}

.section-cartes__intro.is-left{
  text-align: left;
}

.section-cartes__text p:last-child{
  margin-bottom: 0;
}

.section-cartes__footer{
  margin-top: clamp(24px, 4vw, 36px);
}

.section-cartes__footer.is-center{
  text-align: center;
}

.section-cartes__footer.is-left{
  text-align: left;
}

/* ===============================
CARTE
=============================== */

.section-cartes .carte-item{
  position: relative;
  min-height: 255px;
  padding: clamp(18px, 2vw, 24px);
  overflow: hidden;

  --card-text: var(--color-txt);
  --card-btn-text: var(--color-accent);
  --card-btn-bg: var(--color-main);
  --card-btn-hover-text: var(--color-main);
  --card-btn-hover-bg: var(--color-accent);
}

.section-cartes .carte-item__inner{
  position: relative;
  z-index: 2;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
}

.section-cartes .carte-item__title{
  font-weight: 500;
  margin: 0;
}

.carte-item__text{
  font-size: clamp(16px, 1.2vw, 18px);
  line-height: clamp(24px, 1.8vw, 28px);
  text-align: center;
}

.section-cartes .carte-item__text p:last-child{
  margin-bottom: 0;
}

.section-cartes .carte-item__btn{
  margin-top: 18px;
}

/* ===============================
IMAGES
=============================== */

.section-cartes .carte-item__icon{
  width: 100%;
  margin: 0 auto 18px;
}

.section-cartes .carte-item__icon img{
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
  border-radius: 18px;
  aspect-ratio: 1 / 1;
}

/* ===============================
COULEURS CONTENU SECTION
=============================== */

.section-cartes__inner.bg-dark-2{
  background: var(--color-main);
  color: #fff;
}

.section-cartes__inner.bg-light-2{
  background: var(--color-sec);
  color: #1C1F2A;
}

.section-cartes__inner.bg-accent-2{
  background: var(--color-accent);
  color: #fff;
}

.section-cartes__inner.bg-accent-light-2{
  background: var(--color-accent-light);
  color: #1C1F2A;
}

/* ===============================
COULEURS CARTE
=============================== */

.section-cartes .carte-item.bg-none{
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  --card-text: var(--color-txt);
  --card-btn-text: var(--color-accent);
  --card-btn-bg: var(--color-main);
  --card-btn-hover-text: var(--color-main);
  --card-btn-hover-bg: var(--color-accent);
}

.section-cartes .carte-item.bg-dark{
  background: var(--color-main);
  --card-text: #fff;
  --card-btn-text: #fff;
  --card-btn-bg: #fff;
  --card-btn-hover-text: var(--color-accent-light);
  --card-btn-hover-bg: var(--color-accent-light);
}

.section-cartes .carte-item.bg-light{
  background: var(--color-sec);
  --card-text: var(--color-txt);
  --card-btn-text: var(--color-accent);
  --card-btn-bg: var(--color-main);
  --card-btn-hover-text: var(--color-main);
  --card-btn-hover-bg: var(--color-accent);
}

.section-cartes .carte-item.bg-accent{
  background: var(--color-accent);
  --card-text: var(--color-txt);
  --card-btn-text: #fff;
  --card-btn-bg: #fff;
  --card-btn-hover-text: var(--color-main);
  --card-btn-hover-bg: var(--color-main);
}

.section-cartes .carte-item.bg-accent-light{
  background: var(--color-accent-light);
  --card-text: var(--color-txt);
  --card-btn-text: var(--color-accent);
  --card-btn-bg: var(--color-main);
  --card-btn-hover-text: var(--color-main);
  --card-btn-hover-bg: var(--color-accent);
}

/* Texte */
.section-cartes .carte-item,
.section-cartes .carte-item .carte-item__title,
.section-cartes .carte-item .carte-item__text,
.section-cartes .carte-item .carte-item__text p{
  color: var(--card-text);
}

/* ===============================
RADIUS CARTE
=============================== */

.section-cartes .carte-item.radius-all{
  border-radius: 18px;
}

.section-cartes{
  --radius-big: clamp(80px, 12vw, 130px);
}

.section-cartes .carte-item.radius-br{
  border-radius: 18px 18px var(--radius-big) 18px;
}

.section-cartes .carte-item.radius-tr{
  border-radius: 18px var(--radius-big) 18px 18px;
}

.section-cartes .carte-item.radius-tl{
  border-radius: var(--radius-big) 18px 18px 18px;
}

.section-cartes .carte-item.radius-bl{
  border-radius: 18px 18px 18px var(--radius-big);
}

/* ===============================
BOUTON CARTES
=============================== */

.section-cartes .carte-item .bt-s{
  color: var(--card-btn-text);
}

.section-cartes .carte-item .bt-s::after{
  background: var(--card-btn-bg);
}

.section-cartes .carte-item .bt-s:hover{
  color: var(--card-btn-hover-text);
}

.section-cartes .carte-item .bt-s:hover::after{
  background: var(--card-btn-hover-bg);
}

/* ===============================
RESPONSIVE
=============================== */

@media (max-width: 980px){

  .section-cartes .cartes-grid.cols-3,
  .section-cartes .cartes-grid.cols-4{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 760px;
  }

}

@media (max-width: 768px){

  .section-cartes__inner.has-content-bg{
    padding: 24px 18px;
  }

  .section-cartes .cartes-grid.cols-3,
  .section-cartes .cartes-grid.cols-4{
    grid-template-columns: 1fr;
    max-width: 520px;
  }

  .section-cartes .carte-item{
    min-height: auto;
  }


}