/*
------ 
------ 
------ 
BANNER 
------ 
------ 
------ 
*/
.banner {
  position: relative;
  padding-top: 130px;
}
.banner .wrapper {
  display: grid;
  grid-template-columns: 70% 30%;
}
/* 
------ 
------ 
------ 
SLIDER
------ 
------ 
------ 
*/
.bannerSlider {
  order: 1;
}
.banner_box {
  order: 2;
}
.bannerSlider .slick-list {
  height: 600px;
}
@media (max-width:1400px) {
  .banner .wrapper {
    grid-template-columns: 60% 40%;
  }
}
@media (max-width:1200px) {
  .banner .wrapper {
    grid-template-columns: 60% 40%;
  }
}
@media (max-width:700px) {
  .banner .wrapper {
    grid-template-columns: 100%;
  }
  .bannerSlider {
    display: none;
  }
  .banner_box {
    order: 1;
  }
}
/* slider boutons verts et gris */
.bannerSlider-img {
  height: 600px;
  object-fit: cover;
  width: auto;
  border-radius: 40px;
  margin-right: 20px;
}
@media (max-width:700px) {
  .bannerSlider-img {
    height: 400px;
  }
}
.bannerSlider .slick-dots, .gallerySlider .slick-dots {
  font-size: 0;
  line-height: 0;
  text-align: center;
  padding-top: 40px;
  height: 55px;
}
.bannerSlider .slick-dots li, .gallerySlider .slick-dots li {
  display: inline-block;
  vertical-align: center;
  padding: 0 10px;
}
.bannerSlider .slick-dots button {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background-color: lightgrey;
  transition: all ease-in-out 400ms;
  padding: 0;
  font-size: 0;
}
.bannerSlider .slick-dots li.slick-active button {
  background: var(--main-green-color);
  width: 15px;
  height: 15px;
  border-radius: 50%;
}
/* 
------ 
------ 
------ 
BOX marron - background gradient pattern 
------ 
------ 
------ 
*/
.banner_box {
  position: relative;
  text-align: center;
  color: #fff;
  width: calc(100% + 150px);
  height: 60%;
  background: linear-gradient(61deg, rgba(71, 56, 50, 1) 0%, rgba(41, 32, 29, 1) 94%);
  border-radius: 20px;
  top: 40%;
  left: -40%;
}
/* afficher le pattern uniquement à partir de 1000px */
@media (min-width: 1000px) {
  .banner_box::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url('../images/pattern.webp');
    background-repeat: repeat;
    background-size: 60%;
    border-radius: 20px;
    z-index: 0;
  }
}
.banner_logo {
  height: 300px;
  width: 100%;
  background-image: url(../images/treegarden_vertical_logo_white.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  position: absolute;
  margin-bottom: 30px;
  top: -237px;
  left: 0;
  z-index: 1;
}
.banner_content {
  position: relative;
  z-index: 1;
  padding: 40px 70px;
  text-align: center;
}
.banner_box img {
  display: none;
}
/* Puces sous-logo */
.wrapper_large .sous_logo {
  margin-top: 70px;
  z-index: 1;
  position: relative;
}
.wrapper_large .sous_logo > li {
  display: inline-block;
}
.wrapper_large .sous_logo li::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  margin: 0 5px;
  background: url('../images/feuille_cta.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
.wrapper_large .sous_logo li:last-child::after {
  display: none;
}
/* textes bannière */
.banner_text .site-titre {
  font-size: 30px;
  line-height: 38px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 30px;
}
/* bouton devis gratuit */
.banner_text .devis {
  display: inline-block;
}
/* 
------ 
Affichage 1000px
------ 
*/
@media (max-width: 1000px) {
  .banner_content {
    padding: 40px 30px;
  }
  .banner_text .site-titre {
    font-size: 20px;
    line-height: 30px;
  }
  .banner_box {
    left: -50%;
    height: 60%;
  }
  .bannerSlider-img {
    height: 540px;
  }
  .bannerSlider .slick-dots, .gallerySlider .slick-dots {
    position: absolute;
    bottom: 0;
    left: 40%;
    transform: translateX(-40%);
    padding-top: 10px;
  }
}
/* 
------ 
banner_box Affichage 700px
------ 
*/
@media (max-width: 700px) {
  .banner .wrapper {
    justify-items: center;
    margin-bottom: 160px;
  }
  .banner_box {
    width: 70%;
    position: relative;
    top: 120px;
    left: 0;
    height: auto;
  }
  .banner_logo {
    height: 180px;
    width: 100%;
    background-image: url("../images/treegarden_vertical_logo.svg");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    margin-bottom: 0px;
    top: -220px;
    left: 0;
    z-index: 900;
  }
  .banner_content {
    padding: 25px 20px 35px 20px;
  }
  .wrapper_large .sous_logo {
    margin-top: 0;
    position: absolute;
    top: -30px;
    color: black;
    width: 100%;
  }
  .banner_text .site-titre {
    font-size: 20px;
    line-height: 32px;
    margin-bottom: 10px;
  }
  .banner_box img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    position: relative;
    top: 0;
    left: 0;
    border-radius: 20px 20px 0 0;
  }
}
/* 
------ 
banner_box Affichage 700px 
------
*/
@media (max-width: 700px) {
  .banner_box {
    width: 100vw;
    border-radius: 0;
    position: relative;
    top: 120px;
    left: 0;
  }
  .banner_box img {
    width: 100vw;
    border-radius: 0;
  }
}
/* 
------ 
------ 
------ 
SECTION - Services principaux 
------ 
------ 
------ 
*/
/* grid setup & img */
.services-principaux {
  display: flex;
  flex-direction: column;
  gap: 100px;
}
@media (max-width: 1000px) {
  .services-principaux {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }
}
.services-principaux .container {
  display: grid;
  grid-template-columns: 1fr 50%;
  grid-column-gap: 60px;
  align-items: center;
  justify-items: center;
}
@media (max-width:1000px) {
  .wrapper.services-principaux {
    padding-bottom: 45px;
  }
  .services-principaux .container {
    grid-template-columns: 100%;
    grid-gap: 20px;
  }
}
.services-principaux.img {
  width: 100%;
  position: relative;
}
.services-principaux .before-after img {
  width: 100%;
  border-radius: 20px;
  position: relative;
}
.services-principaux .photo img {
  width: 100%;
  max-height: 450px;
  object-fit: cover;
  display: block;
  position: relative;
  z-index: 10;
  border-radius: 20px;
}
.services-principaux .img::after {
  content: url('../images/feuille_background.svg');
  z-index: -1;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%) translateX(-50%);
}
.services-principaux .container.row-2 {
  position: relative;
}
.services-principaux .container.row-2::after {
  content: url('../images/feuille_background.svg');
  z-index: -1;
  position: absolute;
  transform: translateY(-50%) translateX(-50%);
  top: 35%;
  right: -5%;
  transform: scale(-1);
  rotate: -50deg;
}
@media (max-width: 1000px) {
  .services-principaux .container.row-2::after {
    top: 50%;
  }
}
@media (max-width: 700px) {
  .services-principaux .photo img {
    border-radius: 10px;
  }
  .services-principaux .container.row-2::after {
    display: none;
  }
  .services-principaux .img::after {
    display: none;
  }
}
.services-principaux.buttons-espace-vert {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
}
/* boutons-espace-vert */
.services-principaux.buttons-espace-vert a {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 30px;
  background: url('../images/icons/chevron-right.svg') calc(100% - 30px) center no-repeat var(--light-green-color);
  padding: 0 30px;
  border-radius: 50px;
  position: relative;
  font: 600 16px / 60px "Hanken Grotesk";
  letter-spacing: 0.8px;
}
.services-principaux.buttons-espace-vert a img {
  width: 30px;
  height: 30px;
  border-radius: 0px;
}
@media (max-width: 700px) {
  .services-principaux.buttons-espace-vert a {
    font: 600 14px / 50px "Hanken Grotesk";
  }
}
.buttons-espace-vert a {
  color: var(--main-brown-color);
}
.buttons-espace-vert a:hover {
  color: var(--main-green-color);
}
/* carousel et bouton avant après */
.services-principaux.before-after {
  width: 80%;
  display: flex;
  justify-content: center;
  position: relative;
}
@media (max-width: 1000px) {
  .services-principaux.before-after {
    margin-bottom: 30px;
  }
}
.services-principaux.before-after img {
  object-fit: cover;
  border-radius: 10px;
}
/* ---------- SECTION - Autres Services ---------- */
/* grid setup */
.autres-services {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 60px;
  align-items: flex-start;
}
@media (max-width: 1000px) {
  .autres-services {
    display: grid;
    grid-template-columns: 1fr;
    grid-column-gap: 40px;
    align-items: flex-start;
    grid-gap: 40px;
  }
}
.autres-services .container {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.autres-services img {
  object-fit: cover;
  width: 100%;
  height: auto;
  border-radius: 20px;
}
@media (max-width: 1000px) {
  .autres-services img {
    height: 100%;
    border-radius: 10px;
  }
}
/* ---------- SECTION - Entrepreneur de jardins ---------- */
/* grid setup */
.entrepreneur-jardins.container {
  margin-top: 20px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 60px;
  align-items: center;
}
@media (max-width:1000px) {
  .entrepreneur-jardins.container {
    display: grid;
    grid-template-columns: 1fr;
    grid-column-gap: 40px;
    align-items: center;
    grid-gap: 40px;
  }
}
.entrepreneur-jardins ul li {
  margin: 10px 0;
  color: var(--main-green-color);
  font: 400 20px / 28px "Hanken Grotesk";
  position: relative;
  margin-left: 50px;
}
@media (max-width: 1000px) {
  .entrepreneur-jardins ul li {
    font-size: 16px;
    margin-left: 40px;
  }
}
.entrepreneur-jardins ul li::before {
  content: "";
  background-image: url('../images/feuille_cta.svg');
  background-repeat: no-repeat;
  background-size: contain;
  height: 15px;
  width: 15px;
  position: absolute;
  top: 10px;
  left: -30px;
}
/* ---------- SECTION - Avis google ---------- */
.review-box {
  position: relative;
  height: auto;
  padding: 60px 100px;
  background: linear-gradient(61deg, rgba(71, 56, 50, 1) 0%, rgba(41, 32, 29, 1) 94%);
  border-radius: 20px;
  color: #fff;
}
@media (max-width:1000px) {
  .review-box {
    padding: 30px;
  }
}
.review-box::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('../images/pattern.webp');
  background-repeat: repeat;
  background-size: 40%;
  border-radius: 20px;
  z-index: 0;
}
@media (max-width: 1000px) {
  .review-box::after {
    background-size: 100%;
  }
}
.review-content {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 70%;
  align-content: center;
  grid-column-gap: 60px;
  z-index: 1;
}
@media (max-width:1000px) {
  .review-content {
    display: flex;
    flex-direction: column;
    gap: 30px;
    align-items: center;
  }
}
.review-content .google-note {
  display: flex;
  justify-content: flex-end;
  align-self: center;
}
.review-content .google-note img {
  width: 160px;
  height: auto;
  object-fit: cover;
}
@media (max-width: 1000px) {
  .review-content .google-note img {
    width: 100px;
  }
}
.google-note .content {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
}
.google-note .content .notation {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
.google-note .content img {
  width: 70%;
}
.google-note .content .notation img {
  width: 70%;
}
.google-note .content .notation p {
  font-size: 32px;
  font-weight: 500;
}
@media (max-width: 1000px) {
  .google-note .content img {
    width: 60%;
  }
  .google-note .content .notation p {
    font-size: 25px;
    font-weight: 500;
  }
}
@media (max-width: 700px) {
  .google-note .content {
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: center;
    align-items: center;
  }
  .google-note .content .notation img {
    width: 100%;
  }
  .google-note .content img {
    width: 60%;
  }
  .google-note .content .notation p {
    font-size: 26px;
    font-weight: 500;
  }
}
/* review - carousel */
.reviewSlider {
  width: 500px;
  justify-self: center;
  align-items: center;
  display: flex;
  gap: 20px;
  height: 250px;
}
@media (max-width: 700px) {
  .reviewSlider {
    width: 100%;
    height: auto;
  }
}
@media (max-width: 700px) {
  .reviewSlider {
    gap: 10px;
  }
}
/* boutons */
.reviewSlider button {
  font-size: 0;
  line-height: 0;
  text-align: center;
}
.reviewSlider .slick-prev, .reviewSlider .slick-next {
  cursor: pointer;
}
.reviewSlider .slick-prev {
  width: 20px;
  height: 30px;
  border: none;
  background: url('../images/icons/chevron-left-green.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 2;
}
.reviewSlider .slick-next {
  width: 20px;
  height: 30px;
  border: none;
  background: url('../images/icons/chevron-right-green.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 2;
}
/* style texte */
.reviewSlide-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0 20px;
}
@media (max-width: 1000px) {
  .reviewSlide-content {
    padding: 0 10px;
    gap: 5px;
  }
}
.reviewSlide-author {
  display: flex;
  justify-content: flex-end;
}
.reviewSlide-author span {
  font: 700 italic 16px / 28px "Hanken Grotesk";
  opacity: 0.7;
}
@media (max-width: 1000px) {
  .reviewSlide-author span {
    font-size: 14px;
  }
}