* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'SF Pro Display', sans-serif; }

html {
  scroll-behavior: smooth;
}

.section {
    width: 100%;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}

.section picture img {
    width: 100%;
    height: auto;
    display: block;
}

.video {
  position: relative;
}

.video iframe { 
  position: absolute;
  width: 93%;
  margin: 0 auto;
  height: 100%;
  left: 0;
  right: 0;
}


.depoimentos .carousel {
  background-color: #e3ddd1;
}

.relatos .carousel {
  background-color: #f6e3dc;
  overflow: visible;
}
.relatos .swiper {
  overflow: visible;
}

.depoimentos .carousel .swiper-slide{
  background: #fff;
  box-shadow: 0px 6px 15px 0px rgba(0,0,0,0.19);
}

.relatos .carousel .swiper-slide{
  background: #f8eeec;
  box-shadow: 0px 2.04vw 11.3vw 0px rgba(213,130,119,0.45);
}

.relatos {
  overflow: hidden;
}

.carousel {
  position: relative;
  display: flex;
  padding: 0 0 7vw;
  overflow: hidden;
}

.carousel .swiper-button-next,
.carousel .swiper-button-prev { display: none; }

.carousel .swiper {
  height: calc(100% - 20px);
  width: 100%;
  padding: 10px 0;
  overflow: visible;
}

.carousel .swiper-slide{
  border-radius: 18px;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  width: 79vw;
}

.carousel .swiper-slide img{
  max-width: 100%;
}

.carousel .swiper-pagination-bullet-active { 
  background-color: rgb(228 113 113);
}

.carousel .swiper-pagination {
  bottom: -30px!important;
}

.carousel .swiper-button-next, 
.carousel .swiper-button-prev {
  color: rgb(228 113 113);
}

.faq {
  background-size: cover;
  width: 100%;
  padding-top: 6.5vw;
  padding-bottom: 14vw;
  background-color: #e0dcd0;
  position: relative;
  overflow: hidden;
  clip-path: polygon(0 0, 100% 0, 100% 95%, 50% 100%, 0 95%);
}

.faq-box {
  padding: 14vw 7.5% 9.7vw;
  position: relative;
  z-index: 2;
}

.faq:before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at left center, rgb(255 255 255 / 100%) 0%, rgb(255 255 255 / 50%) 30%, rgb(255 255 255 / 10%) 45%, #ffffff00 65%);
  background-size: 100% 295vw;
  background-position:0 -42vw;
  background-repeat: repeat-y;
  position: absolute;
}

.faq:after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at right center, rgb(255 255 255 / 100%) 0%, rgb(255 255 255 / 50%) 30%, rgb(255 255 255 / 10%) 45%, #ffffff00 65%);
  background-size: 100% 225vw;
  background-position: 0 0;
  background-repeat: repeat-y;
  position: absolute;
  top: 36%;
}

.faq .title {
  text-align: center;
  font-size: 24.5vw;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 9vw;
}

.accordion {
  overflow: hidden;
  margin-top: 6vw;
}

.tab {
  position: relative;
}

.tab:last-of-type {
  border-bottom: none;
}

.tab input {
  position: absolute;
  opacity: 0;
  z-index: -1;
}

.tab__label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  padding: 5vw 27vw 3.8vw 0;
  font-weight: 500;
  line-height: 1.22;
  position: relative;
  color: #201f1f;
  font-size: 4.07vw;
  border-bottom: 1px solid #000;
}

.tab__label::after {
  content: "\276F";
  position: absolute;
  right: 2vw;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1.6vw;
  height: 1.5vw;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(90deg);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.tab input:checked + .tab__label::after {
  transform: rotate(270deg);
}

.tab__content {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-0.5vw);
  transition:
    max-height 0.45s ease,
    opacity 0.3s ease,
    transform 0.3s ease;
  color: #201f1f;
  line-height: 1.315;
}

.tab__content-wrapper {
  padding: 3.5vw 0 5.5vw;
}

.tab input:checked ~ .tab__content {
  max-height: 200vh;
  opacity: 1;
  transform: translateY(0);
}

.tab__content p {
  margin: 0;
  padding: 0 0 1rem;
  font-size: 3.5vw;
  color: #363636;
  transition: padding 0.3s ease;
}


.investimento {
  background: #101010;
  padding-top: 22vw;
  margin-top: -22vw;
}

.sobre {
  padding-bottom: 5vw;
}

.sobre:after {
  content: '';
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  background: #000;
  height: 18.3vw;
  clip-path: polygon(0 0, 100% 0, 100% 0%, -13% 100%);
  position: relative;
  z-index: 2;
}


@media screen and (min-width: 1024px) {

  .depoimentos .carousel {
    padding-bottom: 0 0 2vw;
  }

  .carousel .swiper-slide{
    width: 23.65vw;
    border-radius: 36px;
  }

  .faq {
    padding-top: 11vw;
    padding-bottom: 9.4vw;
    clip-path: polygon(0 0, 100% 0, 100% 89.35%, 50% 100%, 0 89.35%);
    margin-top: -18.2vw;
  }

  .faq .title {
    font-size: 8.6vw;
    margin-bottom: 0.7vw;
  }

  .tab__label {
    font-size: 1.41vw;
    padding: 2.58vw 10vw 1.3vw 0;
  }

  .tab__content p {
    font-size: 1.3vw;
  }

  .faq-btn {
    display: none;
  }

  .accordion {
    width: 45.8vw;
    margin: 0 auto;
  }

  .faq-box {
    padding: .25vw 0 0;
  }

  .tab__content-wrapper {
    padding: 1.1vw .25vw 0 0;
  }

  .video iframe {
    width: 46.9%;
  }

  .sobre:after {
    height: 13.2vw;
  }

  .relatos .carousel .swiper-slide {
    box-shadow: 0px 2.04vw 6.3vw 0px rgba(213, 130, 119, 0.45); 
  }

}


.m-whatsapp {
    width: 60px;
    height: 60px;
    position: fixed;
    border-radius: 100%;
    text-decoration: none;
    bottom: 20px;
    right: 21px;
    z-index: 9999999;
    background: #49c33d;
    display: flex;
    align-items: center;
    justify-content: center;
    filter: drop-shadow(0px 2px 4px rgba(0, 0, 0, 0.4));
}