@import url('https://fonts.googleapis.com/css?family=Lato:300|Playfair+Display:900');


body, h1, h2, h3, h4, h5, h6, p, a, li {
  font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
}


body {
  margin: 0;
  width: 100%;
  font-weight: 400;
   font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
 }

p {
  font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 300; 
  
}

 .invt {
  max-width: 800px;
  margin: 40px auto;
  padding: 20px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgb(16, 141, 72);

}

.invt h1 {
  color: #000;
  font-size: 1.8em;
  margin-bottom: 15px;
}

.invt p {
  font-size: 1.1em;

  color: #000;
  text-align: left;

}













  h1 {
    text-align: center;
    color: white;
  }
  h2 {
    color: rgb(16, 141, 72);
    text-align: center;
  }
  p {
    margin: 0 0 20px;
    text-align: center;
  }
  .section {
    margin: 50px 0;
  }
  .section h2 {
    margin-bottom: 20px;
  }
  @media(max-width:400px){
    .tcontainer {
      padding: 0 10px;
    }
  }


  /* Conteneur global */
.about-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  color: #333;
  background: #fff;
}

/* En-tête */
.about-container header {
  text-align: center;
  margin-bottom: 2rem;
}

.about-container h1 {
  font-size: 2.5rem;
  letter-spacing: 1px;
}

/* Contenu principal en Flexbox */
.content-wrapper {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
  padding: 2rem;
  border-radius: 8px;
  background: #f9f9f9;
}

/* Section image */
.image-wrapper {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}

.image-wrapper img {
  width: 100%;
  max-width: 500px;
  height: auto;
  border-radius: 8px;
  object-fit: cover;
}




/* Section texte */
.text-wrapper {
  flex: 2;
  line-height: 1.6;
}

.text-wrapper h2 {
  font-size: 1.8rem;
  margin-bottom: 1rem;
  color:  rgb(16, 141, 72);
}

.text-wrapper p {
  font-size: 1rem;
  text-align: justify;
}

/* Responsive */
@media screen and (max-width: 768px) {
  .content-wrapper {
    flex-direction: column;
    padding: 1.5rem;
  }
  .image-wrapper, .text-wrapper {
    flex: unset;
    width: 100%;
  }
  .text-wrapper h2 {
    font-size: 1.6rem;
  }
}















  :root {
    --mainWhite: #f2fdff;
    --mainBlue: #3e92cc;
  }
  .max-height {
    min-height: 100vh;
  }
  body {
    background: var(--mainWhite);
  }
  .img-container {
    min-height: 40vh;
    background: url("../img/contBcg-0.jpeg") center/cover no-repeat;
    border: 0.5rem solid rgb(16, 141, 72);
    border-radius: 0.5rem;
    position: relative;
    background-size: 400px 400px;
    margin-left: 30%;
  }

  .img-containerto {
    min-height: 40vh;
    background: url("../img/contBcg-0.jpeg") center/cover no-repeat;
    border: 0.5rem solid rgb(16, 141, 72);
    border-radius: 0.5rem;
    position: relative;
    background-size: 400px 400px;
    margin-left: 30%;
  }

  .img-containerte {
    min-height: 40vh;
    background: url("../img/contBcg-0.jpeg") center/cover no-repeat;
    border: 0.5rem solid rgb(16, 141, 72);
    border-radius: 0.5rem;
    position: relative;
    background-size: 400px 400px;
    margin-left: 30%;
  }
  @media screen and (min-width: 768px) {
    .img-container {
      min-height: 40vh;
      max-width: 50vh;
    }

    .img-containerto {
      min-height: 40vh;
      max-width: 50vh;
    }

    .img-containerte {
      min-height: 40vh;
      max-width: 50vh;
    }
    
  }
  
  .btn-left {
    position: absolute;
    top: 50%;
    left: 0;
    background: rgb(16, 141, 72);
    color: var(--mainWhite) !important;
    transform: translate(-50%, -50%);
    border: 0.2rem solid rgb(16, 141, 72);
    font-size: 1.2rem;
  }
  .btn-left:hover {
    border-color: rgb(16, 141, 72);
    background: var(--mainWhite);
    color: rgb(16, 141, 72) !important;
  }
  .btn-right {
    position: absolute;
    top: 50%;
    right: 0;
    background: rgb(16, 141, 72);
    color: var(--mainWhite) !important;
    font-size: 1.2rem;
    transform: translate(50%, -50%);
    border: 0.2rem solid rgb(16, 141, 72);
  }
  .btn-right:hover {
    border-color: rgb(16, 141, 72);
    background: rgb(16, 141, 72);
    color: rgb(16, 141, 72) !important;
  }
  

  



/* Navigation */
nav {
  background-color: white;
  color: rgb(16, 141, 72);
  display: flex;
  width: 100%;
  height: 15vh;
  justify-content: space-around;
  align-items: center;
  font-size: 1rem;
  position: fixed;
  z-index: 10;
}


nav .logo {
  display: flex;
  justify-content: center;
  align-items: center;

}

nav .logo  {
  width: 180px;
  height: 70px;
  margin: 1rem 1rem 1rem 0.5rem;
}

nav .logo p {
  font-size: clamp(1rem, 0.8vw + 0.5rem, 2rem);
  ;
}

nav ul {
  color: black;
  width: 50%;
  margin-left: auto;
  display: flex;
  justify-content: space-around;
  align-self: center;
}

nav ul li {
  list-style: none;
}

nav ul li a {
  text-decoration: none;
  color: rgb(16, 141, 72);
  font-size: 20px;
}

nav ul li a:hover {
  /* color: var(--primary-bg-color); */
  color: rgb(16, 141, 72);}

nav .hamburger {
  cursor: pointer;
  display: none;
}

nav .hamburger .line {
  background-color: rgb(16, 141, 72);
  width: 30px;
  height: 4px;
  margin: 5px;
}


nav .mode svg {
  color: rgb(16, 141, 72);}

nav ul.open {
  clip-path: polygon(0 0, 0 100%, 100% 100%, 100% 0);
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 100%, 100% 0);
}



h1{
  color: rgb(16, 141, 72);
}

/* Responsive pour tablettes et mobiles */
@media (max-width: 768px) {
  .nav-links {
      display: none;
      flex-direction: column;
      position: absolute;
      top: 60px;
      right: 0;
      background-color: rgb(16, 141, 72);
      width: 100%;
      text-align: center;
  }

  .nav-links.active {
      display: flex;
  }

  .nav-links li {
      padding: 10px 0;
  }

  .burger {
      display: block;
  }
}

@media (max-width: 450px) {
  .navbar {
      padding: 10px 15px;
  }

  .logo {
      font-size: 1.2rem;
  }

  .burger {
      font-size: 1.8rem;
  }
}

@media (max-width: 350px) {
  .logo {
      font-size: 1rem;
  }

  .burger {
      font-size: 1.6rem;
  }
}

/* Style du logo */
.logo {
  width: 80px; /* Taille par défaut */
  height: 60px; /* Conserver les proportions */
  display: flex; /* Empêche les marges indésirables */
  transition: transform 0.3s ease-in-out;

}

/* Effet au survol */
.logo:hover {
  transform: scale(1.1); /* Agrandissement léger */
}

/* Responsive pour tablettes */
@media (max-width: 768px) {
  .logo {
    width: 70px;
    height: 55px;
  }
}

/* Responsive pour mobiles */
@media (max-width: 450px) {
  .logo {
    width: 60px;
    height: 50px;
  }
}

/* Responsive pour très petits écrans */
@media (max-width: 350px) {
  .logo {
    width: 50px;
    height: 45px;
  }
}




.produit .contenu .box .text{
  text-align: center;
  font-weight: 300px;
  color: #fff;
  text-transform: uppercase;
}

.produit .contenu .box .text h3{
  font-weight: 300;
  color: #000;
}


span{
  color: #000;
     
 }
 
 /*partie produit*/
 
 .titre{
     display: flex;
     width: 100%;
     justify-content: center;
     align-items: center;
     flex-direction: column;
 
 }
 
 .produit .contenu{
     display: flex;
     justify-content: center;
     flex-wrap: wrap;
     margin-top: 10px;
     background-color:white;
     background-size: cover;
 }
 
 .produit .contenu .box{
     width: 350px;
     margin: 5px;
     border: 20px solid #fff; 
     box-shadow: 20px 25px 10px rgba(0, 0, 0, 0.8);
 }
 
 .produit .contenu .box .imbox{
     position: relative;
     width: 100%;
     height: 300px;
 }
 
 .produit .contenu .box .imbox img{
     position: relative;
     top: 0;
     left: 0;
     width: 100%;
     height: 300px;
     object-fit: cover;
 }
 
 .produit .contenu .dr{
     color: #000;
     text-align: left;
 }


 .tm {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 80vh; /* Ajuste la hauteur selon tes besoins */
  background-color: #f4f4f4; /* Fond léger pour contraste */
  padding: 20px;
}

.tent {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 80%; /* Ajuste la largeur selon tes besoins */
  max-width: 600px; /* Limite la taille max */
  padding: 15px;
  border-radius: 10px; /* Arrondi les bords */
  background: white; /* Fond blanc */
  box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.2); /* Ombre pour effet pro */
}

.tent img {
  max-width: 100%; /* Empêche le dépassement */
  height: auto; /* Maintient les proportions */
  object-fit: cover; /* S'assure que l'image remplit bien le cadre */
  border-radius: 8px; /* Arrondi les bords */
}

/* Responsive Design */
@media (max-width: 768px) {
  .tent {
      width: 90%;
  }
}

@media (max-width: 450px) {
  .tent {
      width: 100%;
      padding: 10px;
  }
  .services p {
    font-size: 2px;
  }
}


@media (max-width: 450px) {
  .services {
    grid-template-columns: repeat(2, 1fr); /* 2 colonnes */
  }
  .service-card {
    padding: 10px;
    min-width: 150px;
    height: auto;
  }
}

/* Écrans inférieurs à 400px */
@media (max-width: 400px) {
  .services {
    grid-template-columns: repeat(1, 1fr); /* 1 colonne */
  }
  .service-card {
    padding: 8px;
    min-width: 140px;
  }
}

/* Écrans inférieurs à 350px */
@media (max-width: 350px) {
  .services {
    grid-template-columns: repeat(1, 1fr);
  }
  .service-card {
    padding: 5px;
    min-width: 130px;
  }
}

/* Écrans inférieurs à 300px */
@media (max-width: 300px) {
  .services {
    grid-template-columns: repeat(1, 1fr);
  }
  .service-card {
    padding: 5px;
    min-width: 120px;
  }
}




.services {
  padding: 20px;
  display: grid;
  grid-template-columns: repeat(3, 1fr); 
  gap: 20px;
  margin-top: 20px;
  height: 350px;
}
@media (max-width: 450px) {
  .services {
    grid-template-columns: 1fr; /* Une seule colonne pour un affichage vertical */
    height: auto; /* Laisse la hauteur s'adapter au contenu */
  }
}

@media (max-width: 780px) {
  .services {
    grid-template-columns: 1fr; /* Une seule colonne pour un affichage vertical */
    height: auto; /* Laisse la hauteur s'adapter au contenu */
  }
}
.services h2 {
  color: #000;
  font-size: 24px;
  text-transform: uppercase;
  text-align: center;
}

.service-card {
  background-color: white;
  border-radius: 10px;
  padding: 20px;
  display: block;
  align-items: center;
  gap: 15px;
  width: 550px;  
  height: 300px;
  overflow-y: auto;
  /* Retire le margin: 20px auto pour éviter le centrage et respecter le grid */
  margin: 0;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}


.service-card1 {
  background-color: white;
  border-radius: 10px;
  padding: 20px;
  display: block;
  align-items: center;
  gap: 15px;
  width: 350px;  
  height: 300px;
  overflow-y: auto;
  /* Retire le margin: 20px auto pour éviter le centrage et respecter le grid */
  margin: 0;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}



.icon-container h1 {
  color: #000;
  text-align: left;

}

.elh {
  display: flex;
  justify-content: center;
  align-items: center;
} 

h2 {
  margin: 0;
}

.services .icon {
  font-size: 24px;
  color: white;
}

.service-content {
  text-align: left;
  flex: 1;
}

.services h3 {
  color: #000;
  font-size: 20px;
  margin: 0;
}

.services p {
    font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: #000; /* Couleur sombre pour une meilleure lisibilité */
  font-size: 16px;
  line-height: 1.6;
  text-align: left;
}

.text h1{
  color: #000;
}



/* Conteneur global */
.valeurs {
  display: flex;
  justify-content: space-between; /* Ou space-around / center selon la mise en page désirée */
  align-items: flex-start;       /* Aligne les éléments en haut */
  flex-wrap: wrap;              /* Permet le passage sur plusieurs lignes si besoin */
  max-width: 1200px;            /* Ajuste selon ta grille */
  margin: 0 auto;               /* Centre le conteneur si tu le souhaites */
  padding: 2rem 1rem;
  background-color: #fff;       /* Couleur de fond, modifie si besoin */
}

/* Chaque bloc de valeur */
.valeur {
  flex: 1 1 220px;              /* Largeur minimale et flexible */
  margin: 1rem;
  text-align: center;           /* Centre le titre, l'icône et le texte */
  padding: 1rem;
}

/* Icône + numéro dans un même bloc */
.valeur-icon {
  position: relative;           /* Permet de positionner le numéro par-dessus */
  display: inline-block;
  width: 70px; 
  height: 70px;
  border: 2px solid  rgb(16, 141, 72);    /* Cercle rouge autour de l’icône */
  border-radius: 50%;
  margin-bottom: 1rem;
  /* Centrer l'icône à l'intérieur */
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Le numéro dans le petit rond rouge */
.valeur-numero {
  position: absolute;
  bottom: -10px;                /* Ajuste selon le rendu souhaité */
  right: -10px;
  background-color:  rgb(16, 141, 72);
  color: #fff;
  font-weight: bold;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

/* Titres (h3) */
.valeur h3 {
  font-size: 1.2rem;
  color: #0a0a0a;               /* Un noir/gris foncé */
  margin-bottom: 0.5rem;
  font-weight: 600;
}

/* Paragraphe */
.valeur p {
  color: #555;
  line-height: 1.6;
  margin: 0 auto;
  max-width: 250px;             /* Pour limiter la largeur du texte */

}



/* À partir de 1600px */
@media (min-width: 1600px) {
  .valeurs {
    max-width: 1600px;
    padding: 3rem 2rem;
  }

  .valeur {
    flex: 1 1 280px;
    margin: 1.5rem;
    padding: 1.5rem;
  }

  .valeur-icon {
    width: 90px;
    height: 90px;
  }

  .valeur-numero {
    width: 42px;
    height: 42px;
    font-size: 1rem;
  }

  .valeur h3 {
    font-size: 1.4rem;
  }

  .valeur p {
    font-size: 1.05rem;
    max-width: 300px;
  }
}

/* À partir de 2000px */
@media (min-width: 2000px) {
  .valeurs {
    max-width: 1900px;
    padding: 4rem 3rem;
  }

  .valeur {
    flex: 1 1 320px;
    margin: 2rem;
    padding: 2rem;
  }

  .valeur-icon {
    width: 110px;
    height: 110px;
  }

  .valeur-numero {
    width: 50px;
    height: 50px;
    font-size: 1.2rem;
  }

  .valeur h3 {
    font-size: 1.6rem;
  }

  .valeur p {
    font-size: 1.15rem;
    max-width: 350px;
  }
}





.vercel {
  padding: 20px;
  /* Ajout du grid pour 3 colonnes */
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 colonnes */
  gap: 20px; /* Espace entre les cartes */
}

@media (max-width: 780px) {
  .vercel {
    grid-template-columns: 1fr; /* Une seule colonne pour un affichage vertical */
    height: auto; /* Laisse la hauteur s'adapter au contenu */
  }
}

.vercel h2 {
  color: rgb(16, 141, 72);
  font-size: 24px;
  text-transform: uppercase;
  text-align: center;
}



.icon-container1 {
  background-color: rgb(16, 141, 72);
  border-radius: 50%;
  width: 50px;
  height: 50px;
  display: flex;
}



@media (max-width: 780px) {
  .vercel {
    grid-template-columns: 1fr; /* Une seule colonne pour un affichage vertical */
    height: auto; /* Laisse la hauteur s'adapter au contenu */
  }
}

.elh {
  display: flex;
  justify-content: center;
  align-items: center;
} 

h2 {
  margin: 0;
}

.vercel .icon {
  font-size: 24px;
  color: white;
}

.service-content {
  text-align: left;
  flex: 1;
}

.vercel h3 {
  color: #000;
  font-size: 20px;
  margin: 0;
}

.vercel p {
  color: white;
  font-size: 14px;
  line-height: 1.5;
}

.inv {
  max-width: 800px;
  margin: 40px auto;
  padding: 20px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgb(16, 141, 72);
  text-align: center;
}

.inv h1 {
  color: #000;
  font-size: 1.8em;
  margin-bottom: 15px;
  
}

.inv p {
  font-size: 1.1em;
  line-height: 1.6;
  color: #000;
  text-align: left;
}

.inv p::before {

  font-size: 1.2em;
}

@media (max-width: 768px) {
  .inv {
      max-width: 90%;
      padding: 15px;
  }

  .inv h1 {
      font-size: 1.5em;
  }

  .inv p {
      font-size: 1em;
  }
}







@media (max-width: 550px) {


  .infolink {
    grid-template-columns: 1fr;
  }

 


    nav{
      height: 12vh;
      position: fixed;
    }
    nav ul {
      position: absolute;
      top: 0;
      background-color: rgba(0, 0, 0, 0.7);
      flex-direction: column;
      align-items: center;
      width: 100%;
      height: 50vh;
      clip-path: polygon(100% 0, 100% 100%, 100% 100%, 100% 0);
      transition: all 1s ease-out;
    }
  
    nav .hamburger {
      display: block;
      z-index: 200;
      /* position: absolute;
      top: 50%;
      right: 5%;
      transform: translate(-5%, -50%); */
      cursor: pointer;
    }




}

@media (max-width: 450px){
  .service-card1{
    width: 250px;
  }

   .service-card{
    width: 250px;
  }
}







/* Définir la section du carrousel (nommée 'kimo') */
.kimo {
  margin: 50px 0; /* Espace de 50px en haut et en bas pour séparer des autres sections */
  position: relative; /* Position relative pour pouvoir gérer son contenu interne si besoin */
  width: 100%; /* Prend toute la largeur disponible */
  height: 90vh; /* Prend toute la hauteur de la fenêtre (viewport height) */
  overflow: hidden; /* Masque le contenu qui dépasse la zone visible */
}



/* Conteneur d'animation hauteur */
.ani{
  display: flex;
  justify-content: center;
  align-items: center;
  height: 80vh;


}

#defiler{
  width: auto;
  overflow: hidden;
  border: 2px solid rgb(16, 141, 72);
}
/* Bande d'images en mouvement effet temp d'anima */
.fil{
  display: flex;
  height: 80vh;
  width: 100%;
  animation-duration: 20s;
  animation-name: test1;
  animation-iteration-count: infinite;
}

/* Style des images postion des image*/
.fil img {
  width:auto; /* Chaque image prend toute la largeur de l'écran */
  height: 100%; /* Chaque image prend toute la hauteur de l'écran */
  object-fit: cover; /* Évite la déformation des images */
}

/* Animation de défilement */
@keyframes test1 {
  0% { transform: translateX(0); }
    13.33% { transform: translateX(0); }
    16.66% { transform: translateX(-350px); }
    
    16.66% { transform: translateX(-350px); }
    30% { transform: translateX(-350px); }
    33.33% { transform: translateX(-700px); }
    
    33.33% { transform: translateX(-700px); }
    46.66% { transform: translateX(-700px); }
    50% { transform: translateX(-1050px); }
    
    50% { transform: translateX(-1050px); }
    63.33% { transform: translateX(-1050px); }
    66.66% { transform: translateX(-1400px); }
    
    66.66% { transform: translateX(-1400px); }
    80% { transform: translateX(-1400px); }
    83.33% { transform: translateX(-1750px); }
    
    83.33% { transform: translateX(-1750px); }
    96.66% { transform: translateX(-1750px); }
    100% { transform: translateX(-1750px); }
  }




