/* =========================================================
   CARDS GRID SYSTEM LOCKED
   Validé : grille responsive commune type Airbnb
   Desktop large: 6 colonnes
   Desktop: 5 colonnes
   Laptop/tablette: 4/3 colonnes
   Mobile: 2 colonnes
   Petit mobile: 1 colonne si nécessaire

   Ne pas modifier sans validation explicite.
   Source principale pour toutes les cartes du site.
   ========================================================= */

/*
  SOURCE DE VÉRITÉ — CARTES CAMPING LISTE

  Format validé : Airbnb-like compact.
  Utilisé par :
  - Accueil / Campings recommandés
  - Accueil / Destinations populaires
  - Page campings

  Règles importantes :
  - Ne pas remplacer par une grille globale en 1fr sur desktop.
  - Ne pas modifier les largeurs sans validation.
  - Ne pas modifier le mobile 2 colonnes sans validation.
  - Ne pas ajouter de max-width différent par section.
  - Ne pas grouper ces règles avec d’autres composants.
  - Ne pas modifier ce bloc lors de corrections hors cartes camping.

  Toute nouvelle liste de campings doit réutiliser ce format.
*/

/* ==========================================================
   CARDS LIST — Structure commune .tmc-card-*
   ========================================================== */

:root {
  --tmc-list-card-gap-x: 22px;
  --tmc-list-card-gap-y: 28px;
}

/* ── Section commune ── */
.tmc-card-section,
.tmc-card-section-inner,
.cards-list-section,
.camping-cards-section,
.campings-list-section,
.cmp-results,
.cmp-results-section,
.home-cards-section,
.home-page .recommended-section,
.home-page .home-featured,
.popular-section,
.favorites-section,
.favorites-page {
  width: min(1320px, calc(100% - 48px)) !important;
  max-width: 1320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}

.tmc-card-section-inner {
  padding: 0 24px !important;
}

.tmc-section-heading {
  margin-bottom: 24px !important;
}

.tmc-section-kicker {
  margin: 0 0 6px !important;
}

/* ── Grille unifiée (source de vérité) ── */
.tmc-card-grid,
.cards-grid,
.camping-cards-grid,
.campings-grid,
.home-campings-grid,
.home-cards-grid,
.cmp-grid,
.favorite-cards-grid,
.favorites-campings-grid,
.account-fav-grid,
.recommended-cards-grid,
.popular-cards-grid,
.home-page .recommended-section .campings-grid,
.home-page .recommended-section .home-campings-grid,
.home-page .home-featured .campings-grid,
.home-page .home-featured .home-campings-grid,
.campings-page-v2 .tmc-card-grid,
.campings-page-v2 .home-campings-grid {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 30px 20px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  align-items: start !important;
  justify-content: stretch !important;
}

/* ── Cartes ── */
.tmc-card-grid .camping-card,
.tmc-card-grid .home-camping-card,
.home-page .recommended-section .campings-grid .camping-card,
.home-page .home-featured .home-campings-grid .camping-card,
.campings-page-v2 .tmc-card-grid .camping-card,
.campings-page-v2 .tmc-card-grid .home-camping-card,
.campings-page-v2 .home-campings-grid .camping-card,
.campings-page-v2 .home-campings-grid .home-camping-card,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-card,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .home-camping-card,
.home-page .recommended-section .campings-grid .home-camping-card,
.home-page .home-featured .home-campings-grid .home-camping-card {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.tmc-card-grid .camping-card-image-wrap,
.home-page .recommended-section .campings-grid .camping-card-image-wrap,
.home-page .home-featured .home-campings-grid .camping-card-image-wrap,
.campings-page-v2 .tmc-card-grid .camping-card-image-wrap,
.campings-page-v2 .home-campings-grid .camping-card-image-wrap,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-card-image-wrap {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}

.tmc-card-grid img,
.tmc-card-image,
.card-image,
.camping-card-image,
.cmp-card-image,
.home-card-image,
.favorites-campings-grid img,
.account-fav-grid img,
.home-page .recommended-section .campings-grid img,
.home-page .home-featured .home-campings-grid img,
.campings-page-v2 .tmc-card-grid img,
.campings-page-v2 .home-campings-grid img,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 16px;
}

.tmc-card-grid .camping-card-body,
.home-page .recommended-section .campings-grid .camping-card-body,
.home-page .home-featured .home-campings-grid .camping-card-body,
.campings-page-v2 .tmc-card-grid .camping-card-body,
.campings-page-v2 .home-campings-grid .camping-card-body,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-card-body {
  padding: 6px 0 0 !important;
}

.tmc-card-grid h3,
.tmc-card-grid .camping-card-body h3,
.home-page .recommended-section .campings-grid h3,
.home-page .recommended-section .campings-grid .camping-card-body h3,
.home-page .home-featured .home-campings-grid h3,
.home-page .home-featured .home-campings-grid .camping-card-body h3,
.campings-page-v2 .camping-card-body h3,
.campings-page-v2 .tmc-card-grid h3,
.campings-page-v2 .home-campings-grid h3,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid h3,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-card-body h3 {
  font-size: 0.92rem !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  margin: 0 0 2px !important;
  min-height: 0 !important;
}

.tmc-card-grid .camping-location,
.home-page .recommended-section .campings-grid .camping-location,
.home-page .home-featured .home-campings-grid .camping-location,
.campings-page-v2 .camping-card-body .camping-location,
.campings-page-v2 .camping-location,
.campings-page-v2 .tmc-card-grid .camping-location,
.campings-page-v2 .home-campings-grid .camping-location,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-location {
  font-size: 0.82rem !important;
  line-height: 1.25 !important;
  font-weight: 500 !important;
  color: #6B7170 !important;
  margin-top: 0 !important;
  margin-bottom: 2px !important;
}

.tmc-card-grid .camping-price,
.home-page .recommended-section .campings-grid .camping-price,
.home-page .home-featured .home-campings-grid .camping-price,
.campings-page-v2 .tmc-card-grid .camping-price,
.campings-page-v2 .home-campings-grid .camping-price,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-price {
  font-size: 0.84rem !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
  margin: 0 !important;
}

.tmc-card-grid .camping-smart-tags,
.home-page .recommended-section .campings-grid .camping-smart-tags,
.home-page .home-featured .home-campings-grid .camping-smart-tags,
.campings-page-v2 .cmp-container .home-page .home-featured .home-campings-grid .camping-smart-tags {
  display: none !important;
}

.tmc-card-grid .fav-btn,
.tmc-card-grid .home-card-favorite,
.home-page .recommended-section .campings-grid .fav-btn,
.home-page .home-featured .home-campings-grid .fav-btn,
.campings-page-v2 .tmc-card-grid .fav-btn,
.campings-page-v2 .home-campings-grid .fav-btn,
.home-page .recommended-section .campings-grid .home-card-favorite,
.home-page .home-featured .home-campings-grid .home-card-favorite,
.campings-page-v2 .tmc-card-grid .home-card-favorite,
.campings-page-v2 .home-campings-grid .home-card-favorite {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  min-height: 36px !important;
  top: 10px !important;
  right: 10px !important;
}

.tmc-card-grid .fav-btn svg,
.tmc-card-grid .home-card-favorite svg,
.home-page .recommended-section .campings-grid .fav-btn svg,
.home-page .home-featured .home-campings-grid .fav-btn svg,
.campings-page-v2 .tmc-card-grid .fav-btn svg,
.campings-page-v2 .home-campings-grid .fav-btn svg {
  width: 20px !important;
  height: 20px !important;
}

@media (max-width: 1439px) {
  .tmc-card-grid,
  .cards-grid,
  .camping-cards-grid,
  .campings-grid,
  .home-campings-grid,
  .home-cards-grid,
  .cmp-grid,
  .favorite-cards-grid,
  .favorites-campings-grid,
  .account-fav-grid,
  .recommended-cards-grid,
  .popular-cards-grid,
  .home-page .recommended-section .campings-grid,
  .home-page .recommended-section .home-campings-grid,
  .home-page .home-featured .campings-grid,
  .home-page .home-featured .home-campings-grid,
  .campings-page-v2 .tmc-card-grid,
  .campings-page-v2 .home-campings-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1199px) {
  .tmc-card-grid,
  .cards-grid,
  .camping-cards-grid,
  .campings-grid,
  .home-campings-grid,
  .home-cards-grid,
  .cmp-grid,
  .favorite-cards-grid,
  .favorites-campings-grid,
  .account-fav-grid,
  .recommended-cards-grid,
  .popular-cards-grid,
  .home-page .recommended-section .campings-grid,
  .home-page .recommended-section .home-campings-grid,
  .home-page .home-featured .campings-grid,
  .home-page .home-featured .home-campings-grid,
  .campings-page-v2 .tmc-card-grid,
  .campings-page-v2 .home-campings-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 28px 18px !important;
  }
}

@media (max-width: 991px) {
  .tmc-card-grid,
  .cards-grid,
  .camping-cards-grid,
  .campings-grid,
  .home-campings-grid,
  .home-cards-grid,
  .cmp-grid,
  .favorite-cards-grid,
  .favorites-campings-grid,
  .account-fav-grid,
  .recommended-cards-grid,
  .popular-cards-grid,
  .home-page .recommended-section .campings-grid,
  .home-page .recommended-section .home-campings-grid,
  .home-page .home-featured .campings-grid,
  .home-page .home-featured .home-campings-grid,
  .campings-page-v2 .tmc-card-grid,
  .campings-page-v2 .home-campings-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 26px 16px !important;
  }
}

@media (max-width: 767px) {
  .tmc-card-grid,
  .cards-grid,
  .camping-cards-grid,
  .campings-grid,
  .home-campings-grid,
  .home-cards-grid,
  .cmp-grid,
  .favorite-cards-grid,
  .favorites-campings-grid,
  .account-fav-grid,
  .recommended-cards-grid,
  .popular-cards-grid,
  .home-page .recommended-section .campings-grid,
  .home-page .recommended-section .home-campings-grid,
  .home-page .home-featured .campings-grid,
  .home-page .home-featured .home-campings-grid,
  .campings-page-v2 .tmc-card-grid,
  .campings-page-v2 .home-campings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 26px 14px !important;
    overflow-x: hidden !important;
  }

  .tmc-card-grid h3,
  .tmc-card-grid .camping-card-body h3,
  .home-page .recommended-section .campings-grid h3,
  .home-page .home-featured .home-campings-grid h3,
  .campings-page-v2 .tmc-card-grid h3,
  .campings-page-v2 .home-campings-grid h3 {
    font-size: 0.88rem !important;
  }
}

@media (max-width: 360px) {
  .tmc-card-grid,
  .cards-grid,
  .camping-cards-grid,
  .campings-grid,
  .home-campings-grid,
  .home-cards-grid,
  .cmp-grid,
  .favorite-cards-grid,
  .favorites-campings-grid,
  .account-fav-grid,
  .recommended-cards-grid,
  .popular-cards-grid,
  .home-page .recommended-section .campings-grid,
  .home-page .recommended-section .home-campings-grid,
  .home-page .home-featured .campings-grid,
  .home-page .home-featured .home-campings-grid,
  .campings-page-v2 .tmc-card-grid,
  .campings-page-v2 .home-campings-grid {
    grid-template-columns: 1fr !important;
    gap: 22px 0 !important;
  }
}

@media (max-width: 768px) {
  .tmc-card-section,
  .tmc-card-section-inner,
  .cards-list-section,
  .camping-cards-section,
  .campings-list-section,
  .cmp-results,
  .cmp-results-section,
  .home-cards-section,
  .home-page .recommended-section,
  .home-page .home-featured,
  .popular-section,
  .favorites-section,
  .favorites-page,
  .cmp-list,
  .cmp-grid-wrapper,
  .cards-list-wrapper {
    width: calc(100% - 20px) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-bottom: 120px !important;
  }

  .tmc-card-section-inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .tmc-card-grid .fav-btn,
  .tmc-card-grid .home-card-favorite,
  .home-page .recommended-section .campings-grid .fav-btn,
  .home-page .home-featured .home-campings-grid .fav-btn,
  .campings-page-v2 .tmc-card-grid .fav-btn,
  .campings-page-v2 .home-campings-grid .fav-btn,
  .home-page .recommended-section .campings-grid .home-card-favorite,
  .home-page .home-featured .home-campings-grid .home-card-favorite,
  .campings-page-v2 .tmc-card-grid .home-card-favorite,
  .campings-page-v2 .home-campings-grid .home-card-favorite,
  .favorite-btn,
  .card-favorite,
  .camping-card-favorite,
  .cmp-card-favorite {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    top: 8px !important;
    right: 8px !important;
  }

  .tmc-card-grid .fav-btn svg,
  .tmc-card-grid .home-card-favorite svg,
  .home-page .recommended-section .campings-grid .fav-btn svg,
  .home-page .home-featured .home-campings-grid .fav-btn svg,
  .campings-page-v2 .tmc-card-grid .fav-btn svg,
  .campings-page-v2 .home-campings-grid .fav-btn svg,
  .favorite-btn svg,
  .card-favorite svg,
  .camping-card-favorite svg,
  .cmp-card-favorite svg {
    width: 18px !important;
    height: 18px !important;
  }
}
