  body {
    height: 100vh;
    /* Garante que o body ocupa 100% da altura da viewport */
  }
  .container-fluid {
    height: 100%;
    /* Garante que a div central ocupa 100% da altura do body */
  }
  .whatsapp {
    position: fixed;
    right: 20px;
    z-index: 99;
    bottom: 90px;
  }
  .content {
    min-height: calc(100vh - 70px - 70px);
    /* 56px para o header e 56px para o footer (ajuste conforme necessário) */
  }
  .b {
    border: 1px solid fuchsia;
  }
  .multiply {
    mix-blend-mode: multiply;
  }
  a,
  a:visited,
  button {
    color: #333;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  ul {
    font-family: 'Roboto', sans-serif;
    color: #666666;
    font-weight: 300;
    font-style: normal;
  }
  h4 {
    font-weight: 700;
  }
  li {
    font-size: 14px;
    list-style: none;
  }
  li ul li {
    font-size: 14px;
    list-style: disc;
  }
  p {
    margin: 0;
    color: #666666;
    font-family: 'Roboto', sans-serif;
    font-weight: 300;
    font-size: 16px;
  }
  .mmt-3 {
    margin-top: 0;
  }
  .lista-acomodacoes ul li {
    font-size: 14px;
    list-style: disc;
  }
  .navbar-brand {
    margin-bottom: -70px !important;
  }
  #home {
    /* background: url('./img/bg-home.jpg') center; */
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 100vh;
    padding-top: 70px;
  }
  .ho {
    width: 100%;
    height: calc(100vh - 70px - 70px);
  }
  #bg-vivenda {
    background: url('./img/01-1920.jpg') center center;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 100vh;
  }
  .bgv {
    background-size: contain;
    background-position: center top;
    background-repeat: no-repeat;
  }
  #vivenda {
    min-height: 100vh;
  }
  #txt-vivenda {
    padding-top: 140px;
  }
  #footer button,
  header button {
    border: 1px solid #666;
    background-color: white;
    box-shadow: 4px 4px 4px 0 rgba(0, 0, 0, 0.6);
    padding: 0 1.2rem;
    font-size: 16px;
    padding-top: 0.25rem;
    min-width: 200px;
  }
  #footer button:hover,
  header button:hover {
    background-color: #ccc;
  }
  .tresmeiazero {
    border: 1px solid #666;
    background-color: white;
    box-shadow: 4px 4px 4px 0 rgba(0, 0, 0, 0.6);
    border-radius: 50px;
  }
  .tresmeiazero:hover {
    opacity: .6;
  }
  .tresmeiazerono {
    box-shadow: 4px 4px 4px 0 rgba(0, 0, 0, 0.6);
    border-radius: 50px;
  }
  .tresmeiazerono:hover {
    opacity: .6;
  }
  footer {
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #icones img {
    max-width: 52px;
  }
  .navbar-brand {
    margin-right: 0 !important;
    text-align: center;
  }
  /* GALERIA */
  #carouselGaleria {
    overflow: hidden;
  }
  #carouselGaleria .carousel-item {
    height: calc(100vh - 61px);
    /* Ajuste a altura conforme necessário */
    background-size: cover;
    background-position: center;
  }
  #carouselGaleria .carousel-inner {
    transition: transform 0.5s ease-in-out;
  }
  #sectionGaleria .carousel-control-prev-icon {
    background-image: url('./icon2.svg');
    /* Substitua pela cor desejada */
  }
  #sectionGaleria .carousel-control-next-icon {
    background-image: url('./icon.svg');
    /* Substitua pela cor desejada */
  }
  /* FIM GALERIA */
  /* GALERIA */
  #carouselVivenda {
    overflow: hidden;
  }
  #carouselVivenda .carousel-item {
    height: calc(100vh - 61px);
    /* Ajuste a altura conforme necessário */
    background-size: cover;
    background-position: center;
  }
  #carouselVivenda .carousel-inner {
    transition: transform 0.5s ease-in-out;
  }
  #carouselVivenda .carousel-control-prev-icon {
    background-image: url('./icon2.svg');
    /* Substitua pela cor desejada */
  }
  #carouselVivenda .carousel-control-next-icon {
    background-image: url('./icon.svg');
    /* Substitua pela cor desejada */
  }
  .slidevivenda li {
    font-family: 'Roboto', sans-serif;
    color: #666;
    font-weight: 300;
    font-size: 24px;
    padding-bottom: 0.8rem;
  }
  ul.vivenda-mobile {
    padding-left: 0 !important;
  }
  .vivenda-mobile li {
    font-family: 'Roboto', sans-serif;
    color: #666;
    font-weight: 300;
    font-size: 16px !important;
    padding-bottom: 0.8rem;
  }
  /* FIM GALERIA */
  .mr-70 {
    padding-top: 140px;
  }
  ul.contato {
    list-style: none;
    padding-left: 0;
    margin: 0;
  }
  .list-item {
    padding-left: 0;
    font-family: 'Roboto', sans-serif !important;
    font-size: 1.25rem;
    font-weight: 300;
  }
  .list-item a {
    color: #666666 !important;
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    text-decoration: none;
  }
  /* acomodações */
  .box {
    position: relative;
    margin-bottom: 100px;
  }
  .barra {
    position: absolute;
    top: 0;
    background: rgba(255, 255, 255, 0.8);
    z-index: 2;
    width: 100%;
    padding: 10px 15px;
  }
  .barra h6 {
    text-transform: uppercase;
    margin-bottom: 0;
    font-size: 12px;
    font-weight: 700;
  }
  .grid-container {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 10px;
  }
  .grid-item {
    background-color: transparent !important;
    /* border: 1px solid fuchsia; */
    padding: 0px;
    text-align: center;
    background-size: cover !important;
    background-position: center !important;
    min-height: 250px;
    cursor: pointer;
  }
  .grid-item:hover {
    opacity: .5;
  }
  .h-lg-100 {
    min-height: 100vh;
  }
  .carousel-indicators button {
    width: 10px !important;
    height: 10px !important;
    border-radius: 100%;
  }
  .carousel-caption {
    position: absolute;
    right: 15%;
    bottom: 1.25rem;
    left: 15%;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    color: #fff;
    text-align: center;
    background-color: rgba(0, 0, 0, 0.8);
  }
  .bg {
    background-color: rgba(255, 255, 255, 0.97);
    padding: 2rem;
  }
  .bg p {
    font-family: 'Roboto', sans-serif;
    color: #000;
    font-weight: 300;
    font-size: 24px;
    padding-bottom: .8rem;
  }
  .flex-esp {
    align-items: center;
    justify-content: center;
  }
  /* Responsividade */
  @media (max-width: 600px) {
    .grid-container {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media (max-width: 390px) {
    /* .grid-container {
        grid-template-columns: repeat(1, 1fr);
    } */
    #footer button,
    header button {
      padding: 0 1rem;
      padding-top: 0.15rem;
      font-size: 9px !important;
      min-width: 120px;
    }
  }
  @media (max-width: 767px) {
    .mmt-3 {
      margin-top: 10px;
    }
    #footer button,
    header button {
      padding: 0 1rem;
      padding-top: 0.15rem;
      font-size: 11px;
      min-width: 120px;
    }
    p {
      margin: 0;
      color: #666666;
      font-family: 'Roboto', sans-serif;
      font-weight: 300;
      font-size: 16px;
    }
    #vivenda {
      min-height: 50vh;
    }
    #vivenda_txt {
      margin-top: 100px;
      padding: 50px 0;
    }
    #icones img {
      max-width: 36px;
    }
    #home {
      /* background: url('./img/a1.JPG') top center; */
      background-size: cover;
      background-repeat: no-repeat;
      min-height: 100vh;
      padding-top: 70px;
    }
    .h-lg-100 {
      min-height: fit-content;
      padding-top: 40px;
      padding-bottom: 40px;
    }
    .navbar-brand img {
      max-width: 70%;
    }
    .barra h6 {
      text-transform: uppercase;
      margin-bottom: 0;
      font-size: 8px;
      font-weight: 700;
    }
  }
  @media only screen and (min-width: 768px) and (max-width: 991px) {}
  @media only screen and (min-width: 992px) {}
  @media only screen and (orientation: landscape) {
    /* Estilos específicos para orientação landscape */
  }
  @media only screen and (orientation: portrait) {
    /* Estilos específicos para orientação portrait */
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2),
  only screen and (min-resolution: 192dpi) {
    /* Estilos para telas de alta resolução (Retina) */
  }
  @media only screen and (min-height: 200px) and (max-height: 420px) {
    .grid-item {
      background-color: transparent !important;
      padding: 0px;
      text-align: center;
      background-size: cover !important;
      background-position: center !important;
      min-height: 30px;
      cursor: pointer;
    }
    .barra h6 {
      font-size: 8px;
    }
    .navbar-brand a img {
      width: 76%;
    }
    .navbar-brand {
      margin-bottom: -12px !important;
    }
  }
  @media only screen and (min-height: 420px) and (max-height: 580px) {
    .grid-item {
      background-color: transparent !important;
      padding: 0px;
      text-align: center;
      background-size: cover !important;
      background-position: center !important;
      min-height: 100px;
      cursor: pointer;
    }
    .barra h6 {
      font-size: 10px;
    }
  }
  @media only screen and (min-height: 580px) and (max-height: 800px) {
    .grid-item {
      background-color: transparent !important;
      padding: 0px;
      text-align: center;
      background-size: cover !important;
      background-position: center !important;
      min-height: 150px;
      cursor: pointer;
    }
    .barra h6 {
      font-size: 10px;
    }
    .mt-esp {
      margin-top: 140px;
      margin-bottom: 70px;
    }
    .lista-acomodacoes ul li {
      font-size: 16px;
      list-style: disc;
    }
    .flex-esp {
      align-items: start;
      justify-content: center;
    }
  }