/* Personnalisé Wordpress */

/* général */

h2 {
  font-family: var(--font-family-title);
  font-weight: 500;
  color: var(--color-text);
  text-transform: uppercase;
  text-align: center;
  line-height: 3rem;
}

main {
  padding-top: 0px!important;
}

/* Header Scroll Effect - Réduction du header au scroll */
header {
  position: sticky;
  top: 0;
  z-index: 1000;
  transition: all 0.3s ease-in-out;
  background-color: var(--color-background-secondary);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

header.header-scrolled {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

header.header-scrolled .blocPreHeader {
  display: none;
}

header.header-scrolled .blocMobileHeader {
  width: auto;
  height: 10vh;
  margin: 0.5rem;
  padding: 10px 0;
  transition: all 0.3s ease-in-out;
}

header.header-scrolled .blocMobileHeader .main-navigation {
  margin: 0!important;
}

header.header-scrolled .blocMobileHeader .logo {
  flex-shrink: 0;
  width: auto;
}

header.header-scrolled .blocMobileHeader .logo img {
  max-height: 50px;
  transition: all 0.3s ease-in-out;
}

header.header-scrolled .blocMobileHeader .wrapper {
  transition: all 0.3s ease-in-out;
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding: 0 1rem;
}

.blocPreHeader {
  overflow: hidden;
}

.blocMobileHeader {
  transition: all 0.3s ease-in-out;
}

.blocMobileHeader .logo img {
  transition: all 0.3s ease-in-out;
}

/* Prendre Rendez-Vous */
.section_prendre_rendez_vous {
  background-image: linear-gradient(
      180deg,
      rgba(12, 55, 75, 0.8) 0%,
      rgba(12, 55, 75, 0.8) 100%
    ),
    url(https://staging.jesto.lets-preprod.com/wp-content/uploads/2019/07/banner-about-title.jpg) !important;
  padding: 3%;
  color: var(--color-text-tertiary);
  background-size: cover;

  display: flex;
  flex-direction: column;
  justify-content: space-around;
}

.section-prendre-rendez-vous {
  display: flex;
  justify-content: space-around;
}

.prendre_rendez_vous {
  width: 600px;
}
.titre_prendre_rendez_vous {
  font-size: 4rem;
  text-align: left;
  max-width: 525px;
  margin-bottom: 40px;
  font-family: var(--font-family-title);
}
.description_prendre_rendez_vous {
  font-size: 16px;
  font-family: var(--font-family-primary);
}
.info_prendrerdv {
  font-size: 16px;
  margin-bottom: 30px;
  font-family: var(--font-family-primary);
}

.bouton_prendre_rendez_vousdiv {
  background: #fff 0% 0% no-repeat padding-box;
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 14px !important;
  height: 51px;
  margin-right: 25px;
  transition: all ease-in 0.2s;
  border: 1px solid #fff;
  max-width: 293px;

  font-family: var(--font-family-primary);
}

.bouton_prendre_rendez_vousdiv a {
  font-family: var(--font-family-primary);
  letter-spacing: 0;
  color: var(--color-text) !important;
  width: 100%;
  cursor: pointer;
  text-align: center !important;
  padding: 15px !important;
  font-size: 15px;
}

/* Prendre Rendez-Vous Formulaire */
.prendre_rendez_vous_formulaire {
  background: var(--color-background-secondary);
  padding: 25px 25px 0px 25px;
  border-radius: 15px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  max-width: 400px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.form-group {
  position: relative;
}

.form-group.full-width {
  grid-column: 1 / -1;
}

/* Cache les labels par défaut */
.prendre_rendez_vous_formulaire label {
  display: none;
}

/* Style général des champs */
.wpcf7-form-control:not(.wpcf7-submit) {
  width: 100%;
  padding: 10px 15px;
  border: none;
  border-radius: 8px;
  background: #f5f5f5;
  font-size: 14px;
  font-style: italic;
  color: #333;
  transition: all 0.3s ease;
}

/* Style spécifique des selects */
.wpcf7-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 15px center;
  padding-right: 35px !important;
}

/* Style spécifique du textarea */
.wpcf7-textarea {
  border-radius: 8px;
  height: 100px;
  resize: vertical;
}

/* Placeholders */
.wpcf7-form-control::placeholder {
  color: #666;
  font-style: italic;
  opacity: 1;
}

/* Focus states */
.wpcf7-form-control:focus {
  outline: none;
  background: var(--color-background-secondary);
  box-shadow: 0 0 0 2px #0c374b;
}

/* Bouton Submit */
.wpcf7-submit {
  background: linear-gradient(90deg, #0c374b 0%, #362988 100%) !important;
  color: var(--color-text-tertiary) !important;
  font-size: 15px !important;
  font-weight: normal !important;
  padding: 14px !important;
  height: 51px !important;
  border: none !important;
  border-radius: 25px !important;
  cursor: pointer !important;
  transition: all ease-in 0.2s !important;
  width: 100% !important;
  max-width: 293px !important;
  margin: 0 auto !important;
  display: block !important;
  font-family: var(--font-family-primary) !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

.wpcf7-submit:hover {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 4px 15px rgba(54, 41, 136, 0.2);
}

/* Messages d'erreur */
.wpcf7-not-valid-tip {
  color: #dc3232;
  font-size: 12px;
  margin-top: 4px;
  padding-left: 15px;
}

.wpcf7-response-output {
  margin: 15px 0 0 !important;
  padding: 12px 15px !important;
  border-radius: 8px;
  text-align: center;
  border-color: #dc3232 !important;
  font-size: 14px;
  color: black;
}

/* Responsive */
@media screen and (max-width: 768px) {
  .prendre_rendez_vous_formulaire {
    padding: 20px;
    margin: 0 15px;
  }

  .form-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .wpcf7-submit {
    width: 100%;
    max-width: none;
  }
}

/* Ajustements pour petits écrans */
@media screen and (max-width: 480px) {
  .prendre_rendez_vous_formulaire {
    padding: 15px;
  }

  .wpcf7-form-control:not(.wpcf7-submit) {
    padding: 10px 15px;
    font-size: 14px;
  }
}

/* Bloc Image Info */
.section_bloc_image_info {
  width: 80%;
  max-width: 1200px;
  margin: auto;
  position: relative;
  padding: 27px 0;
}
.bloc_image_info_content h2 {
  font-family: var(--font-family-primary);
  letter-spacing: 0;
  text-transform: inherit;
  text-align: left;
  color: black;
  max-width: 538px;
  margin-bottom: 20px;
  font-weight: bolder;
}
.texteagauche {
  text-align: left !important;
}
.sous_titre_bloc_image_info {
  font-weight: bolder;
  text-align: center;
}
.bloc_image_info {
  display: flex;
}
.bloc_image_info_content {
  width: 57.8%;
  margin-right: 5.5%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.bloc_image_info_image {
  width: 36.7%;
  display: flex;
  align-items: center;
}
.bloc_image_info_content p {
  font-family: "OpenSansRegular", sans-serif;
  font-size: 16px;
  color: black;
}
.section_bloc_image_info .imageagauche {
  flex-direction: row-reverse;
}
.imageagauche .bloc_image_info_content {
  margin-right: 0;
  margin-left: 5.5%;
}
.bloc_image_info_image img {
  border-radius: 10px;
  box-shadow: 20px 20px 60px #bebebe, -0px 0px 60px #ffffff;
}
.bouton_bloc_image_info a {
  color: var(--color-text);
  max-width: 236px;
  height: 58px;
  border: 2px solid var(--color-primary);
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: all ease-in 0.2s;
  font-size: 18px;
}
.bouton_bloc_image_info a:hover {
  background: var(--color-background-primary);
  color: var(--color-text-tertiary);
}
.bouton_bloc_image_info {
  margin-top: 20px;
}

/* Avantages */
.titre_avantages {
  text-align: center;
  font-size: 3rem;
  margin-bottom: 30px;
}

.section_avantages {
  background: var(--color-background-secondary);
  padding: 40px 0;
}

.container_global_avantages {
  width: 80%;
  max-width: 1200px;
  margin: auto;
  padding: 40px 0;
}

.container_avantages {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 100px;
  align-items: flex-start;
}

.element_avantages {
  width: 100%;
  max-width: 280px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--color-background-primary);
  border-radius: 2rem;
  height: -webkit-fill-available;
  padding: 15px;
  color: var(--color-text-tertiary);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3), 0 5px 15px rgba(0, 0, 0, 0.2);
}

.element_avantages .chiffres_avantages {
  font-size: 50px;
  font-weight: 700;
}
.element_avantages .texte_avantages {
  font-size: 20px;
  max-width: 250px;
  font-weight: 400;
}

section.bloc-demarches .title {
  margin-bottom: 30px;
}
section.bloc-demarches .demarches .demarche.have_content_2 {
  cursor: pointer;
}
section.bloc-demarches .demarches .demarche .logo {
  text-align: center;
  margin-bottom: 30px;
}
section.bloc-demarches .demarches .demarche .logo img {
  height: 100px;
  object-fit: cover;
}

@media (min-width: 992px) {
  section.bloc-demarches .demarches .demarche {
    -webkit-box-shadow: 5px 5px 10px 0px rgba(0, 0, 0, 0.1);
    box-shadow: 5px 5px 10px 0px rgba(0, 0, 0, 0.1);
  }

  footer .footer-mid {
    padding: 40px 0 15px;
  }
}

section.bloc-demarches .demarches .demarche {
  padding: 40px 15px 55px;
  text-align: center;
  -webkit-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);
  height: auto;
  position: relative;
  background: white;
  -webkit-transition: all 0.4s ease-in-out;
  transition: all 0.4s ease-in-out;
}
section.bloc-demarches .bloc-items-demarches .d-flex {
  width: 280px;
}
section.bloc-demarches .bloc-items-demarches {
  gap: 30px !important;
  flex-wrap: wrap !important;
  justify-content: center;
}

section.bloc-demarches .demarches .demarche .title {
  text-align: center;
  font-family: "MontserratRegular", sans-serif;
  color: var(--color-text);
  font-size: 2rem;
  margin-bottom: 30px;
  text-transform: uppercase;
}
section.bloc-demarches .demarches .demarche .content-visible,
section.bloc-demarches .demarches .demarche .content-collapse {
  text-align: left;
  font-size: 1.4rem;
  color: var(--color-text);
  font-family: "OpenSansRegular", sans-serif;
}
section.bloc-demarches .demarches .demarche .content-collapse {
  max-height: 1px;
  -webkit-transition: all 0.4s ease-in-out;
  transition: all 0.4s ease-in-out;
  overflow: hidden;
}
section.bloc-demarches .demarches .demarche .content-visible,
section.bloc-demarches .demarches .demarche .content-collapse {
  text-align: left;
  font-size: 1.4rem;
  color: var(--color-text);
  font-family: "OpenSansRegular", sans-serif;
}
section.bloc-demarches .demarches .demarche i {
  font-size: 3rem;
  color: var(--color-text);
  position: absolute;
  bottom: 10px;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}
section.bloc-demarches .demarches .demarche .content-collapse.open {
  max-height: 200px;
}
section.bloc-demarches .title strong {
  display: block;
}
section.bloc-demarches .title {
  margin-top: 30px;
}

/*-- SECTION INTERVENTION --*/
.section_intervention {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.container_intervention {
  display: flex;
  flex-wrap: wrap;
  max-width: 1100px;
  margin: 40px 0 90px 15%;
}
.intervention img {
  width: 20px;
  height: fit-content;
}
.intervention {
  display: flex;
  align-items: center;
  flex-basis: 33.33%;
  gap: 10px;
}
.titre_intervention {
  text-align: center;
  font-size: 2.8em;
  margin-top: 90px;
  margin-bottom: 30px;
}
.separator {
  width: 165px;
  background-color: var(--rouge);
  height: 1px;
}

.btn_intervention a {
  color: var(--color-text);
  max-width: 236px;
  height: 58px;
  border: 2px solid var(--color-text);
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: all ease-in 0.2s;
  font-size: 18px;
  padding: 0 40px;
  margin-bottom: 60px;
}
.btn_intervention a:hover {
  background: var(--color-background-primary);
  color: var(--color-text-tertiary);
}
.intervention a {
  color: black;
  font-size: 2em;
}

.bloc_image_info_content ul li {
  text-align: left;
  padding-left: 3% !important;
  font-size: 16px;
  padding-top: 1%;
  padding-bottom: 1%;
}

.section_bloc_image_info .sous_titre_bloc_image_info {
  text-align: left;
}

.section_prendre_rendez_vous {
  margin-bottom: 0;
}

/* Avis Client */
.section-avis-client {
  width: 80%;
  max-width: 1200px;
  margin: 3rem auto;
  position: relative;
  padding: 27px 0;
}

.titre-section-avis {
  text-align: center;
  font-size: 3rem;
  margin-bottom: 30px;
}

.texte_temoignage_principal {
  font-size: 1.5rem;
}

.swiper-slide-avis-client {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.testimonial-content {
  width: 90%;
  background-color: var(--color-background-primary);
  color: var(--color-text-tertiary);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4rem;
  padding: 2rem;
  border-radius: 1rem;
}

.info_temoignage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.image-section {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  overflow: hidden;
}

.image-section img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Articles */
.section-articles {
  width: 80%;
  max-width: 1200px;
  margin: auto;
  position: relative;
  padding: 27px 0;
}

.container_articles {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
}

.articles-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  padding: 1rem 0;
}

.article-item {
  display: flex;
  flex-direction: column;
  border-radius: 8px;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.article-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

.article-item img {
  height: 30vh;
  object-fit: cover;
  border-radius: 8px 8px 0 0;
}

.bloc-content {
  height: -webkit-fill-available;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-content: space-between;
  gap: 1rem;
  padding: 20px;
}

.bloc-content .article-link {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-decoration: none;
  color: var(--color-text);
}

.single-blog-excerpt-home {
  font-size: 1.5rem;
}

.article-title-home {
  font-size: 2rem;
  color: var(--color-text);
}

.btn-read-more-container .btn-read-more {
  background-color: var(--color-background-primary);
  font-size: 1.5rem;
  color: var(--color-text-tertiary);
  padding: 10px;
  border-radius: 8px;
}

/* Services */

.section-offers {
  background: var(--color-background-primary);
  padding: 40px 20px;
}

.offer-link {
  background-color: var(--color-background-secondary);
  text-decoration: none;
  color: var(--color-text) !important;
  border-radius: 1rem;
  box-shadow: 0 0 10px 0 rgba(255, 255, 255, 0.3);
  border-top: 4px solid var(--color-secondary);
}

.offer-link:hover {
  transform: translateY(-10px);
  transition: all 0.3s ease-in-out;
}

.titre-section-offers {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.titre-section-offers h2 {
  text-align: center;
}

.titre-section-offers h2 {
  color: var(--color-text-tertiary);
}

.titre-section-offers h2::before {
  content: "";
  display: none;
}

.titre-section-offers p {
  text-align: center;
  font-size: 1.5rem;
  color: var(--color-text-tertiary);
}

.offers-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4rem;
  padding: 3rem 15rem;
}

.offers-container.offers-4 {
  grid-template-columns: repeat(2, 1fr);
}

.offer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
}

.offer-link {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
  padding: 2rem;
}

.offer-icon {
  width: 80px;
  height: 80px;
  border-radius: 20%;
  overflow: hidden;
}

.offer p {
  font-size: 1.5rem;
}

.offer-content {
  width: 100%;
}
.offer-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.btn-read-more-offer {
  background-color: var(--color-background-primary);
  font-size: 1.5rem;
  color: var(--color-text-tertiary);
  padding: 10px;
  border-radius: 8px;
  cursor: pointer;
}

/* Bloc Texte */

.section-bloc-texte {
  background-color: #0c374b;
  color: white;
  padding: 80px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.titre-section-bloc-texte {
  text-align: center;
}

.titre-section-bloc-texte h2 {
  color: white;
}

.titre-section-bloc-texte h2::before {
  content: "";
  display: none;
}

.sous-titre-section-bloc-texte {
  font-size: 2rem;
}

.content-bloc-texte {
  width: 80%;
  max-width: 1200px;
  margin: 3rem auto;
  font-size: 1.5rem;
}

/* FAQ Accordion*/

.section-faq {
  width: 80%;
  max-width: 1200px;
  margin: auto;
  position: relative;
  padding: 27px 0;
}

.titre-section-faq {
  margin-bottom: 30px;
}

.liste-de-questions {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.question-accordion {
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  overflow: hidden;
  transition: all 0.3s ease;
}

.question-accordion:hover {
  border-color: #ccc;
}

.question-header {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px;
  background: var(--color-background-primary);
  color: var(--color-text-tertiary);
  border: 2px solid var(--color-primary);
  cursor: pointer;
  text-align: left;
  transition: background-color 0.3s ease;
}

.question-header:hover {
  border: 2px solid var(--color-secondary);
}

.question-header .title {
  margin: 0;
  flex: 1;
  font-size: 2rem;
  font-weight: 300;
}

.accordion-icon {
  font-size: 2.5rem;
  font-weight: bold;
  transition: transform 0.3s ease;
  flex-shrink: 0;
  margin-left: 15px;
}

.question-header[aria-expanded="true"] .accordion-icon {
  transform: rotate(45deg);
}

.question-content {
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease, opacity 0.3s ease;
}

.question-content[aria-hidden="true"] {
  max-height: 0;
  padding: 0;
  opacity: 0;
}

.question-content[aria-hidden="false"] {
  max-height: 2000px;
  padding: 20px;
  opacity: 1;
}

.question-content .reponse {
  line-height: 1.6;
  font-size: 1.5rem;
}

.question-content .reponse {
  margin: 0 0 15px 0;
}

.question-content .reponse p:last-child {
  margin-bottom: 0;
}

/* Shortcode */

.section-shortcode {
  width: 80%;
  max-width: 1200px;
  margin: auto;
  position: relative;
  padding: 27px 0;
}


/* Pages Solutions */

/* Breadcrumbs */

.section-breadcrumbs {
  width: 90%;
  margin: auto;
  position: relative;
  padding: 15px 0;
}

#breadcrumbs a {
  color: var(--color-text-tertiary);
}

#breadcrumbs a:hover {
  color: var(--color-secondary);
}

#breadcrumbs span:not(.breadcrumb_last):not(:last-child)::after {
  content: "";
  display: inline-block;
  background-image: url(https://staging.jesto2026.lets-preprod.com/wp-content/uploads/2025/12/dot-breadcrumb.svg);
  background-size: 24px;
  background-position: center;
  background-repeat: no-repeat;
  width: 10px;
  height: 10px;
  margin: 0 5px;
  vertical-align: middle;
}

/* Maillage */

.section-maillage {
  width: 80%;
  max-width: 1200px;
  margin: auto;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  padding: 27px 0;
}

.contenu-maillage {
  width: fit-content;
  display: grid;
  justify-items: center;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
}

.item-maillage-container {
  border: 1px solid var(--color-primary);
  border-radius: 1rem;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  padding: 1rem;
  transition: all 0.3s ease-in-out;
}

.item-maillage-container:hover {
  transform: translateY(-10px);
  transition: all 0.3s ease-in-out;
}

.item-maillage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 20px;
}

.item-maillage-image {
  width: 100px;
  height: 100px;
  object-fit: cover;
}

.item-maillage h3 {
  text-align: center;
  color: var(--color-text);
}



/* Menu Desktop - Styles pour le sous-menu */

/* Responsive Styles */
/* Tablette (768px à 1024px) */
@media screen and (max-width: 1024px) {

  /* Header */
  header.header-scrolled .blocMobileHeader {
    height: 7vh;
  }

  header #site-navigation .menu-header-container ul {
    padding: 0;
    display: block;
    overflow: initial;
    width: max-content;
  }

  /* Prendre Rendez-Vous */
  .section_prendre_rendez_vous {
    flex-direction: row;
    align-items: center;
    padding: 40px 20px;
  }

  .prendre_rendez_vous {
    width: 100%;
    max-width: 600px;
    margin-bottom: 30px;
  }

  .titre_prendre_rendez_vous {
    font-size: 3rem;
    margin: 0 auto 30px;
  }

  /* Bloc Image Info */
  .section_bloc_image_info {
    width: 90%;
  }

  .bloc_image_info {
    flex-direction: column !important;
  }

  .bloc_image_info_content,
  .bloc_image_info_image {
    width: 100% !important;
    margin: 0 0 30px 0 !important;
  }

  /* Avantages */

  .container_avantages {
    gap: 50px;
  }

  .element_avantages {
    max-width: 40%;
  }

  .titre_avantages {
    font-size: 2.5rem;
  }

  /* Avis Client */
  .section-avis-client {
    width: 93%;
    margin: 0rem auto;
  }

  .testimonial-content {
    min-height: 20vh;
  }

  /* Articles */
  .section-articles {
    padding: 1.25rem 0;
    width: 93%;
  }

  .articles-container {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

  .articles-container .article-item:nth-child(3) {
    display: none;
  }

  /* Services */
  .offers-container {
    grid-template-columns: repeat(2, 1fr);
    padding: 3rem 5rem;
  }

  /* Maillage */

  .item-maillage-container {
    padding: 0rem;
  }

  .item-maillage-image {
    width: 70px;
    height: 70px;
  }

  .item-maillage h3 {
    text-align: center;
  }
}

/* Règles pour desktop uniquement - le menu reste visible au scroll */
@media screen and (min-width: 993px) {
  header.header-scrolled .blocMobileHeader .main-navigation {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    margin: 0 auto;
  }

  header.header-scrolled .blocMobileHeader .main-navigation .menu-header-container {
    width: 100%;
    display: flex;
    justify-content: center;
  }

  header.header-scrolled .blocMobileHeader .main-navigation .menu-header-container ul {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    padding: 0;
    width: 100%;
  }
}

@media screen and (max-width: 992px) {
  /* Bouton toggle mobile */
  .mobile-menu-toggle.active .icon-bar:nth-child(1) {
    transform: rotate(45deg) translate(8px, 8px);
  }

  .mobile-menu-toggle.active .icon-bar:nth-child(2) {
    opacity: 0;
  }

  .mobile-menu-toggle.active .icon-bar:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
  }

  /* Header mobile */

  header #site-navigation .menu-header-container ul li.menu-item-has-children ul.sub-menu.open {
    max-height: 500px!important;
    margin-bottom: 30px !important;
  }

  .blocMobileHeader .wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 20px;
  }

  .blocMobileHeader .logo {
    flex-shrink: 0;
  }

  .blocMobileHeader .logo img {
    max-height: 50px;
    width: auto;
  }

  .main-navigation {
    display: none;
    position: fixed;
    top: 80px!important;
    left: -3%;
    width: 100vw;
    height: 100vh;
    overflow-y: auto;
    padding: 80px 0 20px 0;
    border-radius: 0px!important;
    box-sizing: border-box;
  }

  .main-navigation.open {
    display: block;
  }

  /* S'assurer que le menu reste caché au scroll sur mobile/tablette, même avec header-scrolled */
  header.header-scrolled .blocMobileHeader .main-navigation {
    display: none !important;
  }

  header.header-scrolled .blocMobileHeader .main-navigation.open {
    display: block !important;
  }

  /* S'assurer que le header et l'icône restent visibles au-dessus du menu */
  .blocMobileHeader {
    position: relative;
    z-index: 10001;
    background-color: #ffffff;
  }

  .blocMobileHeader .wrapper {
    position: relative;
    z-index: 10002;
  }

  .main-navigation .menu-header-container {
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
  }

  .main-navigation .menu-header-container ul {
    display: flex;
    flex-direction: column;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
  }

  .main-navigation .menu-header-container ul li {
    width: 100%;
    border-bottom: 1px solid rgba(12, 55, 75, 0.1);
  }

  .main-navigation .menu-header-container ul li a {
    display: block;
    padding: 15px 20px;
    color: var(--color-text);
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    transition: all 0.3s ease;
  }

  .main-navigation .menu-header-container ul li a:hover {
    background-color: rgba(12, 55, 75, 0.05);
    color: var(--color-text-secondary);
  }

  .open-sub-menu ul.sub-menu.open {
    display: flex !important;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background-color: rgba(12, 55, 75, 0.03);
  }

  .open-sub-menu ul.sub-menu.open li {
    border-bottom: 1px solid rgba(12, 55, 75, 0.05);
  }

  .open-sub-menu ul.sub-menu.open li a {
    padding: 12px 40px !important;
    font-size: 14px;
    position: relative;
    z-index: 10003 !important;
    pointer-events: auto !important;
  }

  .main-navigation .menu-header-container ul li.current-menu-item a,
  .main-navigation .menu-header-container ul li.current-page-item a {
    color: var(--color-text-secondary) !important;
    z-index: 1 !important;
  }

  .main-navigation .menu-header-container ul li.current-menu-item,
  .main-navigation .menu-header-container ul li.current-page-item {
    z-index: 1 !important;
  }

  .open-sub-menu ul.sub-menu.open {
    position: relative;
    z-index: 10002 !important;
  }

  header #site-navigation .menu-header-container ul {
    width: 100%;
  }
}

/* Mobile (moins de 768px) */
@media screen and (max-width: 767px) {

  /* header mobile */
  .main-navigation {
    top: 79px!important;
    left: -6%!important;
  }

  /* Prendre Rendez-Vous */
  .titre_prendre_rendez_vous {
    font-size: 2.2rem;
  }

  .description_prendre_rendez_vous,
  .info_prendrerdv {
    font-size: 14px;
  }

  .bouton_prendre_rendez_vousdiv {
    max-width: 100%;
    margin-right: 0;
  }

  /* Bloc Image Info */
  .section_bloc_image_info {
    width: 95%;
    padding: 15px 24px;
  }

  .bloc_image_info_content h2 {
    font-size: 1.8rem;
    text-align: center;
  }

  .bloc_image_info_content p {
    font-size: 14px;
    text-align: center;
  }

  .bouton_bloc_image_info {
    display: flex;
    justify-content: center;
  }

  .bouton_bloc_image_info a {
    width: 100%;
    max-width: 100%;
    font-size: 16px;
  }

  /* Avantages */
  .section_avantages {
    padding: 40px 0;
  }

  .titre_avantages {
    font-size: 2rem;
    margin-bottom: 20px;
  }

  .container_avantages {
    gap: 30px;
  }

  .element_avantages .chiffres_avantages {
    font-size: 50px;
  }

  .element_avantages .texte_avantages {
    font-size: 16px;
  }

  /* Services */

  .offers-container {
    grid-template-columns: repeat(2, 1fr);
  }

  /* FAQ */
  .section-faq {
    width: 90%;
  }
}


/* Très petits écrans (moins de 480px) */
@media screen and (max-width: 480px) {
  /* Prendre Rendez-Vous */

  .section_prendre_rendez_vous {
    flex-direction: column;
  }

  .titre_prendre_rendez_vous {
    font-size: 1.8rem;
  }

  .element_avantages .chiffres_avantages {
    font-size: 40px;
  }

  .element_avantages .texte_avantages {
    font-size: 14px;
    max-width: 200px;
  }

  .bloc_image_info_content h2 {
    font-size: 1.5rem;
  }

  /* Avantages */
  .element_avantages {
    max-width: 100%;
    height: 132px;
  }

  /* Articles */
  .articles-container {
    grid-template-columns: repeat(1, 1fr);
  }

  .btn-read-more-container .btn-read-more {
    font-size: 1.3rem;
  }

  .articles-container .article-item:nth-child(2) {
    display: none;
  }

  /* Services */
  .offers-container {
    grid-template-columns: repeat(1, 1fr);
    padding: 3rem 1rem;
  }

  .offers-container.offers-4 {
    grid-template-columns: repeat(1, 1fr);
  }

  /* FAQ */

  .question-header .title {
    font-size: 14px;
  }

  /* Maillage */

  .contenu-maillage {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }

  .item-maillage {
    flex-direction: row;
    padding: 15px;
  }

  .item-maillage-image {
    width: 30px;
    height: 30px;
  }
  

}

/* Démarches Responsive */
@media screen and (max-width: 1024px) {
  .bloc-demarches .container.bis {
    padding: 0 20px;
  }

  .bloc-items-demarches {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
  }

  .bloc-demarches .d-flex {
    width: calc(50% - 10px);
  }
}

@media screen and (max-width: 767px) {
  .bloc-demarches .d-flex {
    width: 100%;
  }

  .demarche {
    padding: 20px;
  }

  .demarche .title {
    font-size: 1.2rem;
    margin: 10px 0;
  }

  .demarche .logo img {
    max-width: 60px;
  }

  .content-visible,
  .content-collapse {
    font-size: 14px;
  }
  .container_intervention {
    display: flex;
    flex-wrap: wrap;
    margin: 40px 0 40px 30px;
  }
  .intervention {
    flex-basis: 50%;
  }
}

