html{
    scroll-behavior: smooth;
}
body {
    font-family: 'Catamaran', 'Source Sans Pro', sans-serif;
    font-optical-sizing: auto;
    margin: 0;
    color: #002c3f;
    height: 100vh;
    overflow-x: hidden;
    padding: 0 3.7rem;
}


@media (max-width: 768px) {
    * {
        box-sizing: border-box;
    }
    body {
        padding: 0 0;
    }
}





.header {
    box-sizing: border-box;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .9rem 7rem .1rem 7.7rem;
    background-color: rgba(255, 255, 255, 0.096);
    backdrop-filter: blur(11px);
    z-index: 1000;
}


.logo { 
    all: unset;
    font-size: 2.01rem;
    font-weight: 900;
    cursor: pointer;
    font-style: italic;
}



.hamburger {
    cursor: pointer;
    position: relative;
}
.hamburger input {
    display: none;
}
.hamburger svg {
    height: 3em;
    transition: transform 600ms cubic-bezier(0.4, 0, 0.2, 1);
}

.line {
    fill: none;
    stroke: rgb(0, 0, 0);
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 3;
    transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1),
                stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1);
}
.line-top-bottom {
    stroke-dasharray: 12 63;
}
.hamburger input:checked + svg {
    transform: rotate(-45deg);
}
.hamburger input:checked + svg .line-top-bottom {
    stroke-dasharray: 20 300;
    stroke-dashoffset: -32.42;
}


.dropdown-menu {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    background-color: white;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    width: max-content;
    min-width: 123px;
    max-width: 150px;
    padding: 5px 0;
    z-index: 1001;
    text-align: center;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
    transform: translateY(-10px);
}

.hamburger input:checked ~ .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.dropdown-menu ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.dropdown-menu li {
    padding: 8px 15px;
    transition: 
        background-color 0.3s ease, 
        font-weight 0.3s ease;
}

.dropdown-menu li:hover {
    font-weight: 600;
    background-color: rgba(0,0,0,0.05);
}

.dropdown-menu a {
    text-decoration: none;
    color: black;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dropdown-menu li:first-child {
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
}

.dropdown-menu li:last-child {
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}
  

@media (max-width: 600px) {
    .header {
        padding: 1.2rem 1.3rem .4rem 1.5rem;
    }

    .logo {
        font-size: 1.58rem;
    }

    .hamburger svg {
        /* The size of the SVG defines the overall size */
        height: 2.3em;
        /* Define the transition for transforming the SVG */
        transition: transform 600ms cubic-bezier(0.4, 0, 0.2, 1);
      }
}








.section1 {
    display: flex;
    max-width: 1700px;
    flex-direction: row;
    align-items: center;
    width: 100%;
    margin: 0 auto;
    margin-top: 10vh;
    padding: 20px;
    transition: all 0.3s ease; /* Transition fluide pour les changements de contenu */
    box-sizing: border-box;
    background-color: #ffffff;
    
}

@media (max-width: 768px) {
    .section1 {
        flex-direction: column;
        padding: 1px;
        max-width: 100%;
    }
}




.content{
    flex: 2;
    padding: 10px;
    max-width: 100%; /* Largeur maximale pour la partie gauche */
}


#heroh1 {
    font-size: 4rem;
    font-weight: 900;
    position: relative;
    padding-left: 2.5rem;
  }
  
  #containermorph {
    position: absolute;
    display: inline-block;
    filter: url(#threshold) blur(0.6px);
    margin-left: 1.2rem;
  }
  
  #text1, #text2 {
    position: absolute;
    display: inline-block;
  }


#second_txt_heroh1 {

    width: 100%;
    font-size: 1.4rem;
    font-weight: 400;
    margin: -11rem 0 0 2.5rem ;
}
.highlight {
    font-style: normal;
    border-radius: 1em 0 1em 0;
    text-shadow: 1px 1px 1px #fff;
    background-image: 
      linear-gradient(-100deg, 
        rgba(255,250,150,0.15),
        rgba(159, 253, 166, 0.747) 100%, 
        rgba(255,250,150,0.25)
      );
  }
  .highlight2 {
    background: #03a33965;
  }

.btnhero {
    display: none;
}

@media (min-width: 1600px) {
    #heroh1 {
        margin-right: 1rem;
    }
}

@media (max-width: 768px) {
    #heroh1 {
        text-align: center;
        padding: 0 .7rem;
        font-size: 2.2rem;
        width: 100%;
        display: block;
      }
      
      #containermorph {
        display: block;
        position: relative;
        margin: 0rem auto;
        width: 100%;
        text-align: center;
      }
      
      #text1, #text2 {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
      }
      
      #second_txt_heroh1 {
        text-align: center;
        font-size: 1.12rem;
        font-weight: 300;
        margin: -7rem 0 0 0;
        width: 100%;
        padding: 0 3rem;
      }

      .btnhero{
        display: block;
        opacity: 1;
        width:77%;
        color: #fff;
        text-align: center;
        background-color: #00a359;
        border-bottom-style: none;
        text-decoration: none;
        border-radius: 10px;
        padding: 1rem .7rem;
        margin: auto;
        margin-top: 3.3rem;
        margin-bottom: 2.2rem;
        font-size: 1.1rem;
        font-weight: 600;
    }
    #heroarrow{
        margin-left: 7.7px;
    }
}



.image-1{
    max-width: 100%;
    width:654px;
    margin: 2.3rem 0 -0.777rem 0;
}


.grille_carac {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 30px;
    width: 100%;
}

.grille_item {
    display: flex;
    padding: 10px;
    align-items: center;
}

.grille_item svg {
    min-width: 64px;
    height: 64px;
    margin-right: 13.5px;
    margin-bottom: 7px;
}

.grille_item p {
    margin-left: 6px ;
    font-size: 16px;
    color: #333;
    position: relative; /* Pour le positionnement absolu du span */
    font-weight: 500;
}

.grille_item p span{
    position: absolute;
    right: 0;
    top: 2.8rem;
    color: red;
    font-weight: 500;
}

.grille_item p span.barre::after {
    content: "";
    position: absolute;
    left: -5px; /* Déborde de 5px à gauche */
    right: -5px; /* Déborde de 5px à droite */
    top: 53%; /* Centré verticalement */
    height: 1.3px; /* Épaisseur de la barre */
    background-color: red; /* Couleur de la barre */
    z-index: 1; /* S'assure que la barre passe au-dessus du texte */
}

/* Responsive adjustments */
@media (max-width: 992px) {
    .grille_carac {
        grid-template-columns: 1fr;
        max-width: 100%;  
        grid-gap: 0;
    }

    .grille_item p span{
        top: 3.3rem;
    }
}

@media (max-width: 576px) {
    .grille_item {
        padding: 7.7px;
        padding-right: 10px;
    }
    
    .grille_item svg {
        margin-right: 0;
        margin-bottom: 8.2px;
    }
}























.checkout {
    flex: 1;
    padding: 20px;
    max-width: 100%; /* Largeur maximale pour la partie droite */
    padding-bottom: 12.3rem;
    transition: transform 0.3s ease-out; /* Pour une animation fluide */
}

media (min-width: 1600px) {
    .checkout {
        margin-right: 3.777rem;
    }
}

@media (max-width: 768px) {
    .checkout {
        padding-bottom: 0;
        transform: none !important;
        margin-top: 0 !important;
    }
}

.commandez {
    text-align: center;
    font-weight: bold;
    font-size: 2.777rem;
}

.progress__container {
    max-width: 23rem;
    margin: 20px auto;
    background: #eee;
    height: 20px;
    border-radius: 10px;
    overflow: hidden;
}

.progress__bar {
    width: 0%;
    height: 100%;
    background: #03c46de1;
    transition: width 0.5s ease;
}

.checkout-wrapper {
    max-width: 25rem;
    margin: auto;
    background: white;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 30px 100px rgba(0,44,63,0.3);
    overflow-y: auto; 
}

@media (max-width: 768px) {
    .checkout-wrapper {
        max-width: 100%; /* Utilise toute la largeur disponible */
        min-width: 90vw; /* Empêche que ce soit trop petit */
        padding: 15px; /* Réduit légèrement le padding */
        border-radius: 6px;
    }
}


.checkout-step {
    display: flex;
    flex-direction: column;
    padding: 8px;
}

h2 {
    color: #444;
    font-size: 1.51rem;
}

.inputContainer {
    margin-bottom: 20px;
  }
  
  .form__input {
    width: 100%;
    padding-top: 10px;
    padding-bottom: 5px;
    font-size: 14px;
    background-color: transparent;
    border: none;
    outline: none;
  }
  
  .inputLabel {
    font-size: 1rem;
    color: rgb(47, 75, 87);
    transition: transform 0.3s ease, color 0.3s ease;
  }

  
  .inputUnderline {
    width: 95%;
    height: 1px;
    background-color: #29292993;
  }

/* Styles pour les champs de formulaire avec autofill */
input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus, 
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 1000px white inset !important; /* Fond blanc */
    -webkit-text-fill-color: #333 !important; /* Couleur du texte */
    transition: background-color 5000s ease-in-out 0s; /* Désactive l'animation du fond */
}




  .next {
    width: fit-content;
    display: flex;
    flex-direction: column;
    padding: 1rem 1.23rem;
    border: none;
    font-weight: bold;
    border-radius: 30px;
    cursor: pointer;
    font-size: 1.33rem;
    background-image: linear-gradient(to right, #16A085 0%, #ffd119de  51%, #16A085  100%);
    background-size: 300%;
    background-position: left center;
    transition: background 0.3s ease;
    color: #fff;
    margin: auto auto; /* Ajout d'une marge fixe pour centrer le bouton */
    margin-top: 1.1rem;
}
  
.next:hover {
    background-size: 320%;
    background-position: right center;
}
  
  
.next div{
    display: flex;
    flex-direction: row;
}

#arrownext{
    font-size: 1.8rem;
    margin-right: 10px;
    margin-top: -1.9px;
}

.next span{
    font-size: .88rem;
    margin-top: 5px; 
    color: #ffffffce;
}


/* Styles pour les écrans mobiles */
@media (max-width: 768px) {
    .next {
        font-size: 1rem; /* Taille de police réduite */
        border-radius: 22px;
    }

    .next div {
        flex-direction: row; /* Disposition en ligne pour le contenu interne */
    }

    #arrownext {
        font-size: 1.3rem; /* Taille de la flèche réduite */
        margin-right: 7.7px;
    }

    .next span {
        font-size: 0.73rem; /* Taille de police réduite */
        margin-top: 2px; /* Ajustement de la marge */
        margin-left: auto;
    }
}



/* Ajout d'une classe d'erreur pour rendre l'underline rouge */
.inputUnderline.error {
    background-color: red;
}

#next_error_message{
    margin: auto;
    margin-top: 15px;
}


.prev{
    all: unset; /* Supprime tous les styles de bouton par défaut */
    cursor: pointer;
    display: inline-block;
    padding: 2px; /* Optionnel, juste pour le confort du clic */
    color: #555;
    margin: auto;
}

.prev i{
    font-size: .8rem;
    margin-right: 7px;
    margin-bottom: 4px;
}
    
.prev:hover {
        opacity: 0.6; 
    }





hr{
    opacity: 0.5;
    stroke: rgb(216, 223, 226);
    stroke-linecap: round;
    margin:1.8rem 0 ;
}

.hr11{
    margin:5px 0;
}


.titre_checkboxes {
    display: flex;
    justify-content: space-between; /* Écarte les enfants */
    align-items: center; /* Centre verticalement */
    width: 100%; /* S'assurer qu'il prend toute la largeur */
    margin-bottom: -24px;
}



/* From Uiverse.io by vishnupprajapat */
.checkbox-wrapper-46 input[type="checkbox"] {
    display: none;
    visibility: hidden;
}

.checkbox-wrapper-46 .cbx {
    margin: auto;
    -webkit-user-select: none;
    user-select: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    margin-bottom: 10px; /* Espacement entre les checkboxes */
}

.checkbox-wrapper-46 .cbx span {
    display: inline-block;
    vertical-align: middle;
    transform: translate3d(0, 0, 0);
}

.checkbox-wrapper-46 .cbx span:first-child {
    position: relative;
    width: 18px;
    height: 18px;
    border-radius: 3px;
    transform: scale(1);
    vertical-align: middle;
    border: 1px solid #9098a9;
    transition: all 0.2s ease;
}

.checkbox-wrapper-46 .cbx span:first-child svg {
    position: absolute;
    top: 3px;
    left: 2px;
    fill: none;
    stroke: #ffffff;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 16px;
    stroke-dashoffset: 16px;
    transition: all 0.3s ease;
    transition-delay: 0.1s;
    transform: translate3d(0, 0, 0);
}

.checkbox-wrapper-46 .cbx span:first-child:before {
    content: "";
    width: 100%;
    height: 100%;
    background: #28b847;
    display: block;
    transform: scale(0);
    opacity: 1;
    border-radius: 50%;
}

/* texte */
.checkbox-wrapper-46 .type_boutique {
    padding-left: 7.7px;
    font-size: 1rem; 
    margin:1.77px
}

@media (max-width: 768px) {
    .checkbox-wrapper-46 .type_boutique {
        font-size: .98rem; 
    }
}

.checkbox-wrapper-46 .cbx:hover span:first-child {
    border-color: #50ec6a;
}

.checkbox-wrapper-46 .inp-cbx:checked + .cbx span:first-child {
    background: #50ec6a;
    border-color: #50ec91;
    animation: wave-46 0.4s ease;
}

.checkbox-wrapper-46 .inp-cbx:checked + .cbx span:first-child svg {
    stroke-dashoffset: 0;
}

.checkbox-wrapper-46 .inp-cbx:checked + .cbx span:first-child:before {
    transform: scale(2.2);
    opacity: 0;
    transition: all 0.6s ease;
}

@keyframes wave-46 {
    50% {
        transform: scale(0.9);
    }
}



/* Styles pour les prix */
.checkbox-wrapper-46 .cbx .price {
    margin-left: auto; /* Pousse le prix à droite */
    font-size: 1rem;
    color: #00a35a;
    font-weight: bold;
}





#product-list{
    list-style-type: none; /* Supprime les puces des listes */
    padding-left: 0; /* Supprime l'indentation */
    margin: 0; /* Supprime les marges par défaut */
    min-height: 10px; /* Ajuste cette valeur selon la hauteur de ta liste d'éléments */
    transition: min-height 0.3s ease-out; /* Ajoute une transition pour un effet plus fluide */
}


#product-list li {
    display: flex;
    justify-content: space-between; /* Sépare le nom et le prix */
    font-size: 0.88rem;
    margin: 7.77px 0;
}

#product-list li:last-child {
    border-bottom: none;
}

.product-name {
    margin-right: auto; /* Espacement entre le nom et le prix */
}

.product-price {
    font-weight: bold;
    color: #00a35a;
    margin-left: auto; /* Espacement entre le nom et le prix */
}


#total{
    display: flex;
    justify-content: space-between; /* Écarte les enfants */
    align-items: center; /* Centre verticalement */
    width: 100%; /* S'assurer qu'il prend toute la largeur */
    margin-top: -20px;
}



.final_paie{
    display: flex;
    flex-direction: row;
    justify-content: space-around;

}

.paiement_btn{
    display: flex;
    flex-direction: column;
}

#submit-button {
    width: fit-content;
    display: flex;
    flex-direction: row;
    padding: 1.23rem 1.77rem;
    padding-top: 1.26rem;
    border: none;
    font-weight: bold;
    border-radius: 30px;
    cursor: pointer;
    font-size: 1.3rem;
    background-image: linear-gradient(to right, #2ed34a 0%, #ffcc00de  51%, #319e88bb  100%);
    background-size: 280%;
    background-position: left center;
    transition: background 0.3s ease;
    color: #fff;
    margin: auto auto; /* Ajout d'une marge fixe pour centrer le bouton */
    margin-top: 1.1rem;
}
  
#submit-button:hover {
    transform: scale(1.05);
    transition: all 0.3s ease;
}

#submit-button i{
    font-size: 1.8rem;
    margin-right: 14px;
    margin-top: -1.9px;
}

/* Styles pour les écrans mobiles */
@media (max-width: 768px) {
    #submit-button {
        font-size: 1.1rem;
    }
    #submit-button i{
        font-size: 1.2rem;
        margin-right: 11px;
    }
}


.safe_pay{
    color: #444444cc;
    font-size: .77rem;
    margin: auto;
    margin-top: 1.77px;
}

#payment-message{
    margin: auto;
    margin-top: 1.23rem;
}


#card-element {
    border: 1px solid #ddd;
    padding: 12px;
    border-radius: 8px;
    background-color: #f4f4f4;
    margin-bottom: 36px;
}


.promo{
    margin: 1.5rem 5.1px;
}


.promo form {
    display: grid;
    grid-template-columns: 1fr 80px;
    gap: 10px;
    padding: 0px;
    margin-top:3px ;
  }
  
  #promo_code {
    width: auto;
    height: 36px;
    padding: 0 0 0 12px;
    border-radius: 5px;
    outline: none;
    border: .1px solid #918f8fdc; /* Dark gray */
    color: #ffffff; /* White text */
    transition: all 0.3s cubic-bezier(0.15, 0.83, 0.66, 1);
    color: #000000; 
  }
  
  #promo_code:focus {
    border: 1px solid transparent;
    box-shadow: 0px 0px 0px .9px #3d3c3cd7; /* Light gray focus */
  }
  
  .promo form button {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 10px 18px;
    gap: 10px;
    width: 100%;
    height: 36px;
    color: #ffffff;
    background: #00a359 ; /* Medium gray button */
    box-shadow:
      0px 0.5px 0.5px #555555,
      0px 1px 0.5px rgba(239, 239, 239, 0.5);
    border-radius: 5px;
    border: 0;
    font-weight: 600;
    font-size: 12px;
    line-height: 15px;
    transition: all 0.3s cubic-bezier(0.15, 0.83, 0.66, 1);
  }
  

#hr15{
    margin-top: 2rem;
}



#loader-container {
    position: fixed;
    z-index: 1234;
    left: 50%;
    top: 50%;
    width: 100vw;
    height: 100vh;
    z-index: 5000;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .loader {
    border: 4px solid rgb(31, 99, 57);
    border-left-color: transparent;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    animation: spin89345 1s linear infinite;
  }

  @keyframes spin89345 {
    0% {
      transform: rotate(0deg);
    }
    100% {
      transform: rotate(360deg);
    }
  }



  .popup {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 82vw;
    max-width: 370px;
    background: white;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
    border-radius: 10px;
    text-align: center;
    padding: 20px;
}

.close {
    position: absolute;
    top: 5px;
    right: 5px;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.171);
    background-color: rgb(255, 255, 255);
    border-radius: 50%;
    width: 25px;
    height: 25px;
    border: none;
    color: rgb(155, 28, 28);
    font-weight: 500;
    cursor: pointer;
}
.popup-content div{
    font-size: .87rem;
    font-weight: 500;
}
.popup-content div p{
    margin-top: .7rem;
    font-size: .82rem;
    color: #7c887e;
    font-weight: 400;
}

.overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5); /* Assombrit l'arrière-plan */
    z-index: 999; /* Juste en dessous du popup */
}

/* Afficher l'overlay lorsque le popup est affiché */
.popup.active,
.overlay.active {
    display: block;
}


.image {
    display: flex;
    margin-left: auto;
    margin-right: auto;
    background-color: #e2feee;
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    width: 3rem;
    height: 3rem;
    border-radius: 9999px;
    animation: animate .6s linear alternate-reverse infinite;
    transition: .6s ease;
  }
  
  .image svg {
    color: #0afa2a;
    width: 2rem;
    height: 2rem;
  }




  #stripe_img{
    max-width: 100%;
    margin: 1.2rem auto;
    width: 88%;
    display: block;
}










.section2 {
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 20px;
    text-align: center;
}
  
@media (max-width: 768px) {
    .section2 {
        padding-top: 22px;
    }
}

.titreprocess {
    text-align: center;
    margin-bottom: 3.3rem;
}

.titreprocess h2{
    color: #002c3f;
    font-weight: bold;
    font-size: 2.7rem;
    margin-bottom: .5rem;
}
.titreprocess h3{
    font-size: 1.777rem;
    margin: 0;
    color: #042c3dc4;
}


  
.process-container {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
}
  
  .process-step {
    flex: 0 0 250px;
    margin: 0 10px;
    text-align: center;
  }
  
  .icon-container {
    width: 100px;
    height: 100px;
    border-radius: 12px;
    margin: 0 auto 20px;
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    font-size: 28px;
    transition: 0.5s;
  }
  .icon-container:hover {
    transform: translateY(-7px);
}
  

  .icon-container img{
    max-width: 77%;
    color: white;
  }
  
  .green {
    background-color: rgba(0,163,89,0.1);
    color: white;
  }
  
  .process-step h3 {
    font-size: 1.2rem;
    margin-bottom: 12px;
    font-weight: 600;
  }
  
  .process-step p {
    font-size: .94rem;
    line-height: 1.5;
    color: #585858;
  }
  
  .process-connection {
    display: flex;
    align-items: center;
    width: 100px;
    margin-top: 40px;
  }
  
  .line {
    flex-grow: 1;
    height: 2px;
    background: repeating-linear-gradient(to right, 
      #ddd 0px, 
      #ddd 5px, 
      transparent 5px, 
      transparent 10px);
  }
  
  .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    background-color: rgb(95, 184, 144);
  }
  .greener{
    background-color: rgba(29, 139, 40, 0.918);
  }
  
  @media (max-width: 768px) {
    .process-container {
      flex-direction: column;
      align-items: center;
    }
    
    .process-step {
      margin-bottom: 30px;
    }
    
    .process-connection {
      transform: rotate(90deg);
      margin: 0 0 50px 0;
      width: 60px;
    }
  }







  

  .cta1 {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: inherit;
    font-weight: 600;
    font-size: 1.2rem;
    cursor: pointer;
    color: #ffffff;
    background: linear-gradient(to right, #27c27f, #50be8f,#3cba92);
    border: none;
    border-radius: 16px;
    letter-spacing: 0.05em;
    padding: 0.8em 1.3em;
    margin: 2.8rem auto 0;
    transition: transform 0.3s ease-in-out;
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.219);
}


.cta1 div {
    display: flex;
    flex-direction: row;
    align-items: center;
    transition: transform 0.5s cubic-bezier(0.76, 0, 0.24, 1);
}

.cta1:hover div {
    transform: translateX(4px);
}

.cta1 svg {
    margin-right: 4px;
    transform: rotate(30deg);
    transition: transform 0.5s cubic-bezier(0.76, 0, 0.24, 1);
}

.cta1:hover svg {
    transform: translateY(-0.7px) translateX(6px) rotate(91deg);
}

/* Styles pour les écrans mobiles */
@media (max-width: 768px) {
    .cta1 {
        font-size: 0.95rem;
        padding: 1rem 1.3rem;
        margin: .7rem auto;
        border-radius: 12px;
    }

}










.section3{
    margin-top: 5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 5rem;
}
@media (max-width: 768px) {
    .section3 {
        margin-top: .777rem;
        margin-bottom: 3rem;
    }
}


.h2sec3{
    width: 100vw;
    color: #002c3f;
    font-weight: bold;
    font-size: 3rem;
    text-align: center; /* Assure que le texte est centré sur mobile */

    background-image: url(/static/images/cropped-line.png);
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    padding: 2rem 0; /* Augmente la hauteur du background */

}@media (max-width: 768px) {
    .h2sec3 {
        padding: unset; 
        background-size: 100% 100%;
    }
}



.slider {
    background: white;
    height: 22rem; 
    margin: 3rem auto 0;
    overflow: hidden;
    position: relative;
    width: 100%; 
    max-width: 1200px;
}

.slider::before, .slider::after {
    background: linear-gradient(to right, #fff 0%, rgba(255, 255, 255, 0) 100%);
    content: "";
    height: 100%;
    position: absolute;
    width: 100px;
    z-index: 2;
}

.slider::after {
    right: 0;
    top: 0;
    transform: rotateZ(180deg);
}

.slider::before {
    left: 0;
    top: 0;
}

.slider .slide-track {
    will-change: transform;
    display: flex;
    gap: 2rem; 
    width: calc(410px * 16 + 2rem * 15); /* Ajustement pour la nouvelle largeur */
    animation: scroll 20s linear infinite;
}

.slider .slide {
    width: 410px; /* Nouvelle largeur */
    object-fit: cover;
    border-radius: 12px; 
    transition: 0.4s; 
}

.slider .slide:hover {
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.377);
}

@keyframes scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(calc(-410px * 8 - 2rem * 8)); /* Ajustement pour éviter l’accoup */
    }
}



@media (max-width: 768px) {
    .slider {
        height: 16rem; /* Réduction de la hauteur sur mobile */
    }

    .slider::before, .slider::after {
        width: 28px; /* Réduction du dégradé */
    }

    .slider .slide-track {
        width: calc(80vw * 16 + 1rem * 15); /* Ajustement dynamique */
    }

    .slider .slide {
        width: 80vw; /* Largeur responsive */
    }

    @keyframes scroll {
        0% {
            transform: translateX(0);
        }
        100% {
            transform: translateX(calc(-80vw * 8 - 1rem * 8)); /* Ajustement dynamique */
        }
    }
}



.ctaexemples{
    margin: 1rem auto 7.7rem;
}

.highlight3 {
    background: rgba(7, 165, 15, 0.562);
}


.h2avis{
    font-size: 3rem;
    font-weight: 700;
    margin: 0px;
    letter-spacing: -1.4px;
    text-align: center;
    line-height: 72px;
    box-sizing: border-box;
    max-width: 1000px;
}

.h22avis{
    font-size: 2rem;
    font-weight: 700;
    margin: 2.8rem auto 4rem;
}
@media (max-width: 768px) {
    .h2avis{
        font-size: 1.777rem;
        line-height: unset;
        margin: -2.5rem 2rem 0;
    }
    .h22avis{
        font-size: 1.3rem;
        margin: 2.8rem 1.3rem;
    }

}

.avis_container {
    width: 82%;
    margin: 1rem auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.avis_ligne {
    display: flex;
    flex-wrap: wrap; /* Allow wrapping on smaller screens */
    gap: 1.7rem;
    justify-content: center; /* Center items when they wrap */
}

.avis_card {
    width: 100%; /* Full width on mobile */
    max-width: 500px; /* Maintain maximum width */
    height: auto; /* Allow height to adjust to content */
    display: flex;
    flex-direction: column;
    background-color: #fbfaf9;
    border-radius: 30px;
    border: solid 1.777px #ececece1;
    overflow: hidden;
    box-shadow: 0 8px 20px rgba(15, 51, 0, 0.116);
    box-sizing: border-box;
    margin-bottom: 1rem; /* Add space between cards when wrapped */
}

@media screen and (min-width: 768px) {
    .avis_ligne {
        flex-wrap: nowrap; /* Back to inline on larger screens */
    }

    .avis_card {
        width: 500px; /* Original width on larger screens */
        height: 500px; /* Original height on larger screens */
    }
}

@media (max-width: 768px) {
    .avis_ligne {
        gap: 0;
    }
    .avis_container{
        width: 91%;
        margin: 1rem 0;
    }
}


.avis_card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#img9 {
    object-fit: unset;
}

.card_txtavis {
    padding: 25px;
    display: flex;
    justify-content: space-between;
}

.avis_titre {
    display: flex;
    flex-direction: column;
    position: relative;
}

.guillemets {
    position: absolute;
    color: #007f2a;
    font-size: 5rem;
    top: -1rem;
}

.avis_titre h3 {
    margin-top: 3rem;
    font-size: 1.777rem;
    color: #21232a;
    font-weight: 600;
}

.avis_txt p {
    font-size: 0.876rem;
    color: #585858c5;
    line-height: 1.6;
    margin-bottom: 20px;
}

.avis_profil {
    display: flex;
    align-items: center;
}

.avis_profil img {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    margin-right: 15px;
    background-color: #f0f0f0;
}

.etoiles {
    color: #ffc107;
    font-size: 20px;
}

.avis_profil h5 {
    margin: -6px 2.3px 0;
    color: #585858;
    font-weight: 500;
}

.ctaavis{
    margin-top: -1rem;
    margin-bottom: 2rem;
    transform: scale(1.2);
}

.showoff {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1200px;
    margin: -1rem auto 5.5rem;
    padding: 0 20px;
}

.showoff-item {
    border-radius: 15px;
    overflow: hidden;
    height: 321px;
    width: 100%; /* Modifié pour s'adapter à la grille */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
}

.showoff-item:hover {
    transform: scale(1.017);
}

.showoff-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Version Carousel Mobile */
@media screen and (max-width: 768px) {
    .showoff {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 15px;
        padding: 0 15px 20px;
        margin: -1rem auto 3rem;
        -webkit-overflow-scrolling: touch; /* Pour un défilement fluide sur iOS */
        scrollbar-width: none; /* Masquer la scrollbar sur Firefox */
    }

    .showoff::-webkit-scrollbar {
        display: none; /* Masquer la scrollbar sur Chrome/Safari */
    }

    .showoff-item {
        scroll-snap-align: center;
        flex: 0 0 85%; /* 85% de la largeur du viewport */
        min-width: 85%; /* Empêche le rétrécissement */
        margin: 0 5px; /* Espacement entre les éléments */
    }

    /* Indicateurs de défilement (optionnel) */
    .carousel-indicators {
        display: flex;
        justify-content: center;
        gap: 8px;
        margin-top: 15px;
    }

    .indicator {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: rgba(0, 0, 0, 0.2);
        transition: all 0.3s ease;
    }

    .indicator.active {
        background: rgba(0, 0, 0, 0.6);
        transform: scale(1.2);
    }
}

/* Version tablette (optionnel) */
@media screen and (min-width: 769px) and (max-width: 1024px) {
    .showoff {
        grid-template-columns: repeat(2, 1fr);
    }
}














.faq-section-wrapper {
    margin: 0 -3.7rem;
    padding: 0;
    overflow-x: hidden;
    max-width: 100vw;
}
.faq-section {
    padding: 5rem 1.2rem 3.777rem;
    font-family: 'THICCCBOI', sans-serif;
    box-sizing: border-box;
    background-color: rgb(36, 49, 40);
    color: white;
    position: relative;
    width: 100%;
}

.faq-container {
    display: grid;
    grid-template-columns: 1fr;
    gap: 7.77rem;
    align-items: start;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.titreetc {
    max-width: 100%;
}

.faq-title {
    width: auto;
    white-space: nowrap; /* Force le texte à rester sur une seule ligne */
    font-size: clamp(2rem, 5vw, 3rem); /* Taille responsive */
    color: white;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1.25rem;
}

.faq-subtitle {
    font-size: clamp(1rem, 1.5vw, 1.125rem);
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.6;
    margin-bottom: 2rem;
}

.faq-link {
    color: rgb(33, 198, 121);
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    transition: all 0.3s ease;
}

.faq-link:hover {
    opacity: 0.8;
}

.faq-link svg {
    margin-left: 0.5rem;
    margin-bottom: 0.1rem;
    transition: transform 0.3s ease;
}

.faq-link:hover svg {
    transform: translateX(4px);
}

.faq-questions {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.faq-item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding-bottom: 1.5rem;
    transition: all 0.3s ease;
}

.faq-item:last-child {
    border-bottom: none;
}

.faq-question {
    font-size: clamp(1.125rem, 2vw, 1.25rem);
    font-weight: 600;
    color: white;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    padding: 0.5rem 0;
    transition: all 0.3s ease;
}

.faq-question:hover {
    color: rgb(33, 198, 121);
}

.faq-toggle {
    font-size: 1.5rem;
    color: rgb(33, 198, 121);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 1.5rem;
    text-align: center;
}

.faq-item[open] .faq-toggle {
    transform: rotate(45deg);
}

.faq-answer {
    font-size: clamp(0.875rem, 1.5vw, 1rem);
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.6;
    padding-top: 0.5rem;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), padding 0.3s ease;
}

.faq-item[open] .faq-answer {
    max-height: 500px; /* Valeur suffisamment grande */
    padding-top: 1rem;
}

.faq-decoration-right {
    position: absolute;
    width: 150px;
    height: auto;
    top: 0;
    right: 0;
    z-index: 0;
    opacity: 0.3;
}

.faq-decoration-left {
    position: absolute;
    width: 150px;
    height: auto;
    bottom: 0;
    left: 0;
    z-index: 0;
    opacity: 0.3;
}

/* Media Queries pour le responsive */
@media (min-width: 768px) {
    .faq-section {
        padding: 6rem 3rem 3.777rem;
    }
    
    .faq-container {
        grid-template-columns: 1fr 2fr;
    }
    
    .faq-decoration-right,
    .faq-decoration-left {
        width: 250px;
    }
}

@media (min-width: 1024px) {
    .faq-section {
        padding: 8rem 4rem 5rem;
    }
    
    .faq-decoration-right,
    .faq-decoration-left {
        width: 300px;
    }
}



@media (max-width: 767px) {
    .faq-section-wrapper {
        margin: 0; /* Supprimer les marges négatives sur mobile */
    }
    .faq-container {
        gap: 2.2rem;
    }

    .titreetc {
        margin-bottom: 2rem;
        text-align: center;
    }
}











.site-footer {
    background-color: white;
    text-align: center;
    margin: auto;
    padding: 2.3rem 7px 1.5rem;
    color: #333;
    width: 77%;
}



.about h4 {
    margin-bottom: 15px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.about p {
    font-size: 0.6rem;
    line-height: 1.2;
    color: #666666ea;
}

@media (max-width: 767px) {
    .site-footer {
        margin: 0; 
        padding: 0;
        width: 100%;
    }
    .about p{
        font-size: .51rem;
        line-height: .9;
    }
}

.divider{
    margin-top: 1rem;
    width: 150% ;
    height: auto;
    position: relative;
    margin-left: -7.7rem;
}@media (max-width: 767px) {
    .divider{
        width: 100%;
        margin: 0;
    }
}

.copyright {
    background-color: white;
    text-align: center;
    padding: 15px;
    font-size: 0.8rem;
    color: #666;
    border-top: .7px solid #00a35a36;
}
