@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap);

.s-explorar__header,
.s-hero {
  flex-direction: column;
  display: flex
}

.s-mapa__logo,
.s-participe__imagem,
.toast {
  transform: translateX(-50%)
}

.text,
.toast {
  white-space: nowrap
}

.s-explorar__item figure img,
.s-explorar__list li figure img,
.s-hero__fotos figure img,
.s-participe__fotos figure img,
.s-rota__item figure img {
  object-fit: cover;
  object-position: center
}

.s-passaporte__observacao>div>div:nth-child(odd),
.s-rota__observacao>div>div:nth-child(odd) {
  margin-right: 16px
}

.s-passaporte__observacao>div>div:nth-child(2n),
.s-rota__observacao>div>div:nth-child(2n) {
  margin-left: 16px
}

.s-passaporte__observacao>div>div>div:first-of-type,
.s-rota__observacao>div>div>div:first-of-type {
  width: 30px
}

.s-hero,
footer {
  padding-top: 120px
}

.footer__links a,
.pass-card__button a,
.s-estadia__btn,
.s-propriedades__list a,
.s-rota__btn {
  text-decoration: none
}

.footer__copyright,
.s-estadia__btn,
.text {
  text-transform: uppercase
}

.footer__signature{
  display: flex;
  justify-content: center;
  padding-bottom: 60px;
}

.footer__signature img {
  max-height: 30px;
}

*,
::after,
::before {
  margin: 0;
  padding: 0;
  box-sizing: border-box
}

:root {
  --font-serif: "Playfair Display", serif;
  --font-sans-serif: "Plus Jakarta Sans", sans-serif;
  --color-dark: #283a2c;
  --color-light: #F8FFD4;
  --color-clean: #EAF3EF
}

body {
  width: 100%;
  background-color: var(--color-dark);
  color: var(--color-light);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 300
}

.h1,
h2 {
  font-family: "Playfair Display", serif;
  font-weight: 300
}

p {
  margin-bottom: 0
}

.s-hero {
  position: relative;
  width: 100%;
  justify-content: center;
  align-items: center;
  background-color: #f1dcc0
}

.s-hero__turismo {
  margin-bottom: 44px
}

.s-hero__logo {
  max-width: 180px;
  margin-bottom: 60px
}

.h1,
.s-explorar__header h2,
.s-hero__descricao,
h2 {
  margin: 0 auto;
  text-align: center
}

.s-hero__descricao {
  font-size: 24px;
  letter-spacing: 1px;
  max-width: 620px;
  padding: 24px;
  border-radius: 24px;
  background-color: rgb(0, 0, 0, .25)
}

.modal-passaporte__footer button:hover,
.toast {
  background-color: #458653
}

.h1 {
  max-width: 992px;
  font-size: clamp(36px, 6vw, 52px)
}

h2 {
  font-size: clamp(36px, 6vw, 68px);
  font-family: var(--font-serif)
}


.navbar-brand img{
  max-height: 72px !important;
}

.s-hero__turismo img {
  max-width: 360px
}

.s-hero__fotos {
  display: flex;
  padding: 2rem
}

.s-hero__fotos figure {
  overflow: hidden;
  aspect-ratio: 4/3;
  padding: 1rem;
  background-color: #fff;
  border-radius: .5rem;
  position: absolute
}

.s-hero__fotos figure img {
  width: 100%;
  height: 100%;
  border-radius: .5rem
}

.color-dark {
  color: var(--color-dark)
}

.s-explorar {
  width: 100%;
  padding: 120px 0
}

.s-explorar__header {
  justify-content: center;
  align-items: center;
  margin-bottom: 60px
}

.s-explorar__header h2 {
  font-weight: 300;
  max-width: 992px;
  letter-spacing: 1px
}

.s-explorar__header i,
.s-passaporte__icone i {
  font-size: 60px;
  color: #8cc63f
}

.s-participe__icone i {
  color: #c13132;
  font-size: 60px
}

.modal-passaporte {
  max-width: 370px;
  border-radius: 36px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  font-weight: 500
}

.modal-passaporte__body {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center
}

.modal-passaporte__body img {
  padding: 12px;
  border: 12px solid #283a2c;
  border-radius: 16px;
  margin-top: 5px
}

.s-explorar__list li div:nth-child(2),
.toast {
  padding: 16px
}

.modal-separador {
  display: flex;
  justify-content: center;
  position: relative
}

.modal-separador::after {
  position: absolute;
  content: '';
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 1px;
  border-bottom: 1px dashed #bad8cb;
  background-color: transparent
}

.modal-separador span {
  background-color: #fff;
  position: relative;
  z-index: 9999;
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center
}

.modal-passaporte__header {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 24px;
  font-weight: 700
}

.modal-passaporte__footer {
  text-align: center
}

.modal-passaporte__footer button {
  background-color: #283a2c;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 24px;
  text-align: center;
  width: 100%;
  height: 62px;
  font-size: 20px;
  border: none;
  transition: .3s ease-in-out;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 700;
  margin-top: 5px
}

.hidden-text {
  position: absolute;
  left: -9999px
}

.toast {
  visibility: hidden;
  width: fit-content;
  color: #fff;
  text-align: center;
  border-radius: 24px;
  position: fixed;
  z-index: 99999999999;
  left: 50%;
  bottom: 30px;
  font-size: 17px;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, .5);
  font-weight: 700
}

.toast.show {
  visibility: visible;
  -webkit-animation: .5s fadein, .5s 2.5s fadeout;
  animation: .5s fadein, .5s 2.5s fadeout
}

@-webkit-keyframes fadein {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@-webkit-keyframes fadeout {
  from {
    opacity: 1
  }

  to {
    opacity: 0
  }
}

@keyframes fadein {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@keyframes fadeout {
  from {
    opacity: 1
  }

  to {
    opacity: 0
  }
}

.s-explorar__lista {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 60px
}

.s-explorar__item {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 16px;
  text-align: center
}

.s-explorar__item h3 {
  font-size: 24px;
  font-weight: 400;
  font-family: var(--font-serif);
  letter-spacing: 2px
}

.s-explorar__item p {
  font-size: 16px
}

.s-explorar__item>div:first-child {
  flex: 1
}

.s-explorar__item>div:nth-child(2) {
  flex: 2
}

.s-participe__fotos,
.s-rota__btn {
  display: flex;
  justify-content: center
}

.s-explorar__item figure {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: 999px
}

.s-participe__fotos figure,
.s-rota__item figure {
  aspect-ratio: 4/3;
  overflow: hidden
}

.s-explorar__item figure img {
  width: 100%;
  height: 100%
}

.--heartbeat {
  animation: 1.5s infinite heartbeat
}

@keyframes heartbeat {

  0%,
  100%,
  50% {
    transform: scale(1)
  }

  25% {
    transform: scale(1.3)
  }

  75% {
    transform: scale(1.15)
  }
}

.s-participe {
  background-color: #fff;
  width: 100%;
  padding: 5dvh 0 10dvh;
  position: relative
}

.s-participe h2 {
  color: var(--color-dark);
  max-width: 992px
}

.s-participe p {
  max-width: 992px;
  margin: 0 auto;
  color: #283a2c;
  font-size: 24px;
  font-family: var(--font-sans-serif)
}

.s-participe__imagem {
  position: absolute;
  left: 50%;
  top: 25%;
  rotate: -6deg;
  z-index: 0
}

.s-participe__imagem img {
  max-height: 300px
}

.s-participe__fotos {
  margin-top: 60px
}

.s-participe__fotos figure img {
  width: 100%;
  height: 100%
}

.s-explorar__timeline {
  position: relative;
  margin-top: 60px
}

.s-explorar__timeline .linha {
  width: 4px;
  height: 100%;
  background-color: #8baa00;
  position: absolute;
  left: 16px;
  top: 0
}

.s-explorar__list,
.s-propriedades__list {
  display: grid;
  gap: 30px;
  list-style: none;
  padding: 0
}

.s-explorar__list li {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px;
  background-color: rgb(255, 255, 255, .05);
  backdrop-filter: blur(20px);
  border-radius: 24px
}

.s-explorar__list li figure {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 24px
}

.s-explorar__list li figure img {
  width: 100%;
  height: 100%
}

.s-explorar__list li h3 {
  margin-bottom: 16px
}

@media screen and (min-width:992px) {
  .s-explorar__list {
    grid-template-columns: repeat(4, 1fr)
  }
}

.s-explorar__timeline__item {
  padding-left: 60px;
  position: relative;
  margin-bottom: 120px
}

.s-explorar__timeline__item::before {
  content: '';
  position: absolute;
  left: 2px;
  width: 32px;
  height: 32px;
  background-color: #8baa00;
  border-radius: 999px
}

.s-mapa {
  width: 100%;
  height: auto;
  position: relative;
  background-color: #8baa00;
  background: linear-gradient(to bottom, transparent 50%, #8baa00 50%)
}

.s-mapa__shape {
  width: 100%;
  height: auto
}

.s-mapa img {
  width: 100%;
  height: auto;
  margin-bottom: -9px
}

.s-mapa__logo {
  position: absolute;
  left: 50%;
  top: 100px
}

.s-mapa__logo img {
  max-width: 560px
}

.gradiente-verde {
  background: #283a2c;
  background: linear-gradient(0deg, #283a2c 0, #708c0c 58%, #8baa00 100%)
}

.chevron-container {
  position: relative;
  width: 24px;
  height: 24px
}

.chevron {
  position: absolute;
  width: 28px;
  height: 8px;
  opacity: 0;
  transform: scale3d(.5, .5, .5);
  animation: 3s ease-out infinite move
}

.chevron:first-child {
  animation: 3s ease-out 1s infinite move
}

.chevron:nth-child(2) {
  animation: 3s ease-out 2s infinite move
}

.chevron:after,
.chevron:before {
  content: ' ';
  position: absolute;
  top: 0;
  height: 100%;
  width: 51%;
  background: #fff
}

.chevron:before {
  left: 0;
  transform: skew(0deg, 30deg)
}

.chevron:after {
  right: 0;
  width: 50%;
  transform: skew(0deg, -30deg)
}

@keyframes move {
  25% {
    opacity: 1
  }

  33% {
    opacity: 1;
    transform: translateY(30px)
  }

  67% {
    opacity: 1;
    transform: translateY(40px)
  }

  100% {
    opacity: 0;
    transform: translateY(55px) scale3d(.5, .5, .5)
  }
}

.text {
  display: block;
  margin-top: 75px;
  margin-left: -30px;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 12px;
  color: #fff;
  opacity: .25;
  animation: 2s linear infinite alternate pulse
}

.s-propriedades__icone,
.s-rota__icone {
  font-size: 60px;
  color: #8cc63f;
  line-height: 1;
  width: 100%;
  text-align: center
}

@keyframes pulse {
  to {
    opacity: 1
  }
}

.s-propriedades {
  padding: 120px 0;
  background-color: #fff
}

.s-propriedades h2 {
  line-height: 1
}

.s-propriedades__icone {
  position: relative;
  z-index: 5
}

.s-rota__icone {
  z-index: 2
}

.s-rota__dia {
  font-size: 40px;
  font-weight: 700;
  position: absolute;
  line-height: 1;
  top: 0
}

.s-rota__dia>div:nth-child(3) {
  background-color: #458653;
  color: #fff;
  font-size: 24px;
  font-weight: 600;
  border-radius: 999px;
  line-height: 1.5;
  padding: 0 12px;
  width: fit-content;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 8px
}

.s-propriedades__list li figure {
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center
}

.s-propriedades h3 {
  font-size: 20px;
  margin-bottom: 24px;
  text-align: center;
  font-weight: 700
}

.s-propriedades__list a,
.s-propriedades__list li span {
  background-color: #8cc63f;
  border-radius: 50px;
  padding: 4px 16px;
  font-weight: 600;
  color: #283a2c
}

@media screen and (min-width:1170px) {
  .s-propriedades__list {
    grid-template-columns: repeat(5, 1fr)
  }
}

.s-rota {
  padding: 120px 0;
  min-height: 100dvh;
  position: relative
}

.s-rota::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background-color: rgb(40, 58, 44, .95);
  z-index: 0
}

.s-rota__content {
  max-width: 1170px;
  margin: 0 auto;
  position: relative;
  z-index: 1
}

.s-rota__item,
.s-rota__observacoes {
  margin-top: 120px
}

.s-rota__list {
  display: grid
}

figure {
  margin: 0
}

.s-rota__item {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  border-radius: 24px;
  padding: 8px;
  backdrop-filter: blur(5px);
  background-color: #fff;
  box-shadow: 0 8px 16px 0 rgba(0, 0, 0, .2);
  max-width: 520px;
  color: #283a2c
}

.s-rota__infos {
  padding: 32px;
  position: relative
}

.s-rota__btn {
  background-color: #8cc63f;
  color: #283a2c;
  font-size: 16px;
  font-weight: 500;
  padding: 0 8px 0 24px;
  height: 52px;
  border-radius: 24px;
  gap: 12px;
  align-items: center;
  width: fit-content
}

.s-rota__btn span,
.s-rota__logo {
  justify-content: center;
  transition: .3s ease-in-out;
  border-radius: 999px;
  display: flex
}

.s-rota__btn span {
  background-color: rgb(255, 255, 255, .85);
  color: #283a2c;
  width: 40px;
  height: 40px;
  align-items: center;
  font-size: 24px;
  rotate: -45deg
}

.s-rota__btn:hover span {
  rotate: 0deg
}

.s-rota__logo {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -75%);
  background-color: #fff;
  width: 120px;
  height: 120px;
  padding: 16px;
  align-items: center;
  z-index: 2
}

.s-rota__observacoes ul {
  display: grid;
  gap: 24px;
  place-items: center;
  background-color: rgb(231, 199, 151, .085);
  padding: 36px;
  max-width: 720px;
  margin: 0 auto;
  border-radius: 24px
}

.s-rota__observacoes ul li {
  width: 100%;
  font-weight: 200;
  font-size: 16px;
  letter-spacing: 1px;
  border-radius: 8px;
  display: flex;
  gap: 8px;
  line-height: 1.85;
  text-align: left
}

.s-rota__observacoes ul li>div {
  width: 40px
}

.s-rota__observacoes ul li i {
  line-height: .75
}

.s-rota__observacoes ul i {
  font-size: 44px;
  color: #ebee3a;
  line-height: 100%
}

.s-rota__observacoes__icone {
  background-color: #283a2c;
  width: 72px;
  height: 72px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 999px
}

.s-rota__observacao {
  background-color: transparent;
  backdrop-filter: blur(20px);
  border-radius: 36px;
  padding: 36px;
  position: relative;
  z-index: 2;
  margin: 80px auto 0;
  max-width: 820px;
  font-size: 18px
}

.s-rota__observacao>div:first-child {
  font-size: 20px;
  color: #ebee3a;
  display: flex;
  align-items: center;
  flex-direction: column;
  letter-spacing: 1px;
  font-weight: 700;
  margin-bottom: 16px
}

.s-rota__observacao>div:first-child i {
  font-size: 36px;
  color: #ebee3a
}

.s-rota__observacao>div:nth-child(2) {
  display: flex;
  flex-direction: column;
  gap: 4px
}

.s-rota__observacao>div:nth-child(2)>div {
  background-color: rgb(0, 0, 0, .25);
  padding: 16px 12px;
  border-radius: 24px;
  word-spacing: 2px;
  display: flex;
  gap: 4px
}

.s-rota__observacao>div>div>div>i {
  font-size: 40px;
  line-height: .765;
  color: #ebee3a
}

.s-rota__infos p {
  font-size: 20px
}

.s-rota__infos h3 {
  margin-bottom: 16px
}

.s-rota__logo img {
  max-width: 100%;
  transition: scale .3s ease-in-out
}

.s-rota__linha {
  display: flex;
  justify-content: start;
  position: relative
}

.s-rota__linha--direita {
  justify-content: end
}

.s-rota__item figure {
  border-radius: 24px;
  position: relative
}

.s-rota__item figure img {
  width: 100%;
  height: 100%;
  transition: scale .3s
}

.s-rota__item:hover figure img {
  scale: 1.15
}

.s-rota__item:hover .s-rota__logo img {
  scale: 1.2
}

.s-rota__timeline {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(0, -50%);
  width: 2
}

.s-rota__trilha1 {
  position: absolute;
  max-width: 260px;
  left: 50%;
  top: 35%;
  rotate: -55deg
}

.s-rota__trilha2 {
  position: absolute;
  max-width: 220px;
  left: 35%;
  top: 45%;
  transform: translateX(-85%);
  rotate: 30deg
}

.s-rota__trilha3 {
  position: absolute;
  max-width: 260px;
  left: 54%;
  top: 45%;
  transform: translateX(5%);
  rotate: -10deg
}

.s-rota__trilha4,
.s-rota__trilha5 {
  max-width: 580px;
  position: absolute
}

.s-rota__trilha4 {
  left: 50%;
  top: 78%;
  transform: translateX(-105%);
  rotate: 25deg
}

.s-rota__trilha5 {
  left: 40%;
  top: 58%;
  rotate: 62deg
}

.flip-horizontal {
  transform: scaleX(-1)
}

.s-rota__trilha6 {
  position: absolute;
  max-width: 280px;
  left: 24%;
  top: 45%;
  rotate: 15deg
}

.s-rota h2 {
  position: relative;
  z-index: 2
}

.s-rota__degustacao {
  font-size: 16px;
  padding: 0 16px;
  line-height: 2;
  background-color: #f8ffd4;
  color: #283a2c;
  border-radius: 999px;
  width: fit-content;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
  position: absolute;
  top: 0;
  transform: translateY(-50%);
  z-index: 9999;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1)
}

.s-rota__degustacao i {
  font-size: 2rem;
  line-height: 0
}

.s-passaporte {
  padding: 120px 0;
  background-color: var(--color-clean);
  color: #283a2c;
  font-size: 22px;
  font-weight: 200
}

.s-passaporte__asteriscos{
  width: auto;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.s-passaporte__asteriscos span{
  margin-right: 24px;
  background-color: #fff ;
  color: #283a2c;
  font-weight: 400;
  border-radius: 999px;
  font-size: 15px;
  padding: 0 12px;
  line-height: 2;
  width: fit-content;
}

.s-passaporte__content {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 36px
}

.s-passaporte__observacao {
  background-color: transparent;
  backdrop-filter: blur(20px);
  border-radius: 36px;
  padding: 36px;
  position: relative;
  z-index: 2;
  margin: 0 auto;
  max-width: 820px;
  font-size: 18px
}

.card-passaporte,
.pass-card {
  background-color: #fff;
  border-radius: 24px
}

.s-passaporte__observacao>div:first-child {
  font-size: 20px;
  color: #283a2c;
  display: flex;
  align-items: center;
  flex-direction: column;
  letter-spacing: 1px;
  font-weight: 700;
  margin-bottom: 16px
}

.s-passaporte__observacao>div:first-child i {
  font-size: 36px;
  color: #283a2c
}

.s-passaporte__observacao>div:nth-child(2) {
  display: flex;
  flex-direction: column;
  gap: 4px
}

.s-passaporte__observacao>div:nth-child(2)>div {
  background-color: rgb(140, 198, 63, .25);
  padding: 16px 12px;
  border-radius: 24px;
  word-spacing: 2px;
  display: flex;
  gap: 4px;
  font-weight: 400
}

.s-passaporte__observacao>div>div>div>i {
  font-size: 40px;
  line-height: .765;
  color: #283a2c
}

.s-passaporte__observacao a {
  color: #283a2c
}

.s-passaporte__observacao a:hover {
  color: #458653
}

._faq1-item__answer a:hover,
.footer__links a:hover,
.panel:checked~._faq1-item__question {
  color: #8cc63f
}

.card-list {
  display: flex;
  gap: 36px;
  justify-content: center
}

.card-passaporte {
  flex: 1;
  max-width: 320px;
  padding: 24px;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .25)
}

.pass-list {
  display: flex;
  gap: 24px;
  justify-content: center
}

.pass-card {
  flex: 1;
  width: 100%;
  max-width: 360px;
  display: flex;
  flex-direction: column;
  padding: 28px 36px;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1);
  letter-spacing: .5px
}

.pass-card:first-child .pass-card__button a,
.pass-card__titulo {
  background-color: #f8ffd4;
  color: #283a2c
}

@media only screen and (max-width:767.98px) {
  .pass-list {
    flex-direction: column;
    align-items: center
  }

  .pass-card {
    max-width: 80%
  }
}

.pass-card:first-child {
  background-color: #283a2c;
  color: #fff
}

.pass-card:first-child .pass-card__preco {
  border-bottom: 1px dotted #c9df5b
}

.pass-card__titulo {
  border-radius: 999px;
  padding: 0 16px;
  line-height: 1.5;
  width: fit-content;
  font-weight: 700;
  margin-bottom: 32px
}

.pass-card__descricao {
  font-size: 17px;
  font-weight: 400
}

.pass-card__lista {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px
}

.pass-card__lista>div {
  display: flex;
  gap: 8px;
  align-items: center
}

.footer__logo,
.pass-card__button a {
  justify-content: center;
  display: flex
}

.pass-card__lista i {
  color: #8cc63f;
  font-size: 18px;
  line-height: 0
}

.pass-card__preco {
  font-size: 40px;
  font-weight: 700;
  line-height: .8;
  margin-bottom: 20px;
  padding-bottom: 28px;
  border-bottom: 1px dotted #283a2c
}

.pass-card__preco span {
  font-size: 20px;
  font-weight: 400
}

.pass-card__button {
  display: flex;
  margin-top: auto;
  padding-top: 40px
}

.pass-card__button a {
  width: 100%;
  height: 72px;
  border-radius: 20px;
  background-color: #283a2c;
  color: #fff;
  font-weight: 700;
  align-items: center;
  gap: 8px;
  text-shadow: 1px 2px 4px rgba(0, 0, 0, .25)
}

.footer__content {
  display: flex;
  flex-direction: column;
  gap: 40px
}

.footer__paragraph {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  font-weight: 300;
  font-size: 18px;
  letter-spacing: 1px;
  line-height: 2
}

.footer__logo {
  align-items: center
}

.footer__logo img {
  max-width: 160px
}

.footer__social {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px
}

.footer__social a {
  background-color: #f8ffd4;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  transition: .3s ease-in-out
}

.footer__social a:hover {
  scale: .9;
  background-color: #8cc63f
}

.footer__social a:hover svg {
  scale: 1.4
}

.footer__social a svg {
  transition: .3s ease-in-out;
  width: 28px;
  fill: #283a2c
}

.footer__contact-infos {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px
}

.footer__contact-infos div {
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: 1px
}

.footer__contact-infos svg {
  width: 24px;
  fill: #8CC63F
}

.footer__links {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center
}

.footer__links a {
  color: #f8ffd4;
  letter-spacing: 1px;
  font-weight: 300;
  transition: .2s ease-in-out
}

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

  .footer__contact-infos,
  .footer__links {
    flex-direction: row;
    justify-content: center;
    gap: 24px
  }
}

.footer__copyright {
  font-weight: 300;
  letter-spacing: 2px;
  font-size: 12px;
  width: 70%;
  margin: 160px auto 20px auto;
  text-align: center;
  line-height: 2
}

@media (max-width:767.98px) {
  .s-rota__item {
    margin-top: 420px
  }

  .s-rota__trilha1 {
    left: 24%;
    top: 76%;
    rotate: -22deg
  }

  .s-rota__trilha2 {
    left: 90%;
    top: 86%
  }

  .s-rota__trilha3 {
    top: 96%;
    left: 10%;
    width: 200px;
    rotate: 3deg
  }

  .s-rota__trilha4 {
    top: 105%;
    left: 81%;
    width: 280px;
    rotate: -5deg
  }

  .s-rota__trilha5 {
    position: absolute;
    max-width: 280px;
    left: 100px;
    top: 111%;
    rotate: 96deg
  }
}

@keyframes pulseWhatsApp {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, .7)
  }

  70% {
    box-shadow: 0 0 0 20px rgba(37, 211, 102, 0)
  }

  100% {
    box-shadow: 0 0 0 0 rgba(37, 211, 102, 0)
  }
}

._button-whatsapp {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 64px;
  height: 64px;
  background-color: #25d366;
  color: #fff;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  animation: 2s infinite pulseWhatsApp
}

._button-whatsapp svg {
  fill: #fff;
  width: 52px;
  height: 52px
}

._faq1-section {
  background-color: var(--color-dark)
}

._faq1-header {
  flex: 1;
  color: #fff
}

._faq1-list {
  flex: 1;
  max-width: 992px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px
}

.faq-header {
  font-size: 42px;
  border-bottom: 1px dotted var(--color-primary);
  padding: 24px
}

._faq1-item__observacao {
  margin-top: 1rem;
  padding: .8rem 1.6rem;
  border-radius: .8rem;
  background-color: rgb(0, 0, 0, .15);
  font-size: 18px
}

._faq1-header__description {
  letter-spacing: 1px;
  flex: 1
}

._faq1-content {
  display: flex;
  flex-direction: column;
  gap: 3rem
}

@media(min-width:1200px) {
  ._faq1-content--half {
    flex-direction: row;
    gap: 10vw
  }
}

._faq1-item {
  padding: 1rem 2rem;
  position: relative;
  border-bottom: 2px dotted #25d366;
  background-color: rgb(37, 211, 102, .05);
  backdrop-filter: blur(555px);
  border-radius: 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: column
}

._faq1-item__question {
  font-size: clamp(1rem, 1.6rem, 1.6rem);
  width: 100%;
  position: relative;
  margin: 0;
  padding: 0 2.4rem 0 0;
  display: block;
  cursor: pointer;
  color: #f7f7f7;
  line-height: 1.5;
  font-weight: 700
}

._faq1-item__answer {
  font-size: 1.45rem;
  padding: 0;
  margin: 0;
  height: 0;
  overflow: hidden;
  z-index: -1;
  opacity: 0;
  -webkit-transition: .4s;
  -moz-transition: .4s;
  -o-transition: .4s;
  transition: .4s;
  font-weight: 300;
  line-height: 180%;
  letter-spacing: 1px;
  color: #fff
}

.panel:checked~._faq1-item__answer {
  height: auto;
  opacity: 1;
  padding: 1.2rem 0
}

.plus {
  position: absolute;
  right: 1rem;
  z-index: 0;
  top: .4rem;
  font-size: 42px;
  line-height: 1;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none;
  -webkit-transition: .2s;
  -moz-transition: .2s;
  -o-transition: .2s;
  transition: .2s;
  color: #f7f7f7;
  margin-left: auto
}

.s-estadia__btn,
.s-estadia__btn i {
  transition: .3s ease-in-out
}

.panel:checked~.plus {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg)
}

.panel {
  display: none
}

._faq1-item__answer a {
  text-decoration: none;
  color: #f1dcc0;
  font-weight: 700
}

.s-estadia,
.s-faq {
  padding: 120px 0
}

.s-estadia h3 {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.5;
  text-align: justify
}

.s-estadia__btn {
  background-color: #c9df5b;
  color: #283a2c;
  font-size: 16px;
  font-weight: 700;
  padding: 0 24px;
  height: 64px;
  border-radius: 24px;
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
  width: fit-content;
  letter-spacing: 1px
}

.s-estadia__btn:hover i {
  margin-left: 12px
}