/* GANTRY5 DEVELOPMENT MODE ENABLED.
 *
 * WARNING: This file is automatically generated by Gantry5. Any modifications to this file will be lost!
 *
 * For more information on modifying CSS, please read:
 *
 * http://docs.gantry.org/gantry5/configure/styles
 * http://docs.gantry.org/gantry5/tutorials/adding-a-custom-style-sheet
 */

@charset "UTF-8";
h1, h2, h3 {
  font-family: "Quattrocento", serif;
}
h1 {
  font-size: 50px;
}
html {
  scroll-behavior: smooth;
}
.menu-principal {
  padding: 22px !important;
}
/* cores: ajuste à sua paleta */
.g-main-nav .g-menu-item-container {
  transition: background 0.25s ease, color 0.25s ease;
}
.g-main-nav .g-menu-item-container.is-active {
  background: #fff !important;
  color: #7a1c1c !important;
  font-weight: 700;
}
.nav-link {
  padding: 0rem 1rem;
}
:root {
  --nav-h: 22px;
}
#g-navigation, .nav-fixo {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1100;
}
/* empurra o conteúdo pra baixo do menu fixo */
#g-main {
  padding-top: var(--nav-h);
}
/* âncoras com offset */
[id^="link-"] {
  scroll-margin-top: var(--nav-h);
}
/* âncoras não ficarem escondidas atrás do menu */
[id^="link-"] {
  scroll-margin-top: var(--nav-h);
}
.tradutor {
  padding: 0px;
  margin: 15px 0 0 0;
}
.VIpgJd-ZVi9od-ORHb-OEVmcd {
  /* Corrige a posição da barra do tradutor ativado no topo do site */
  top: 60px !important;
}
.cabecalho {
  background-image: url('../../../../images/fotos/fotofachada.png') !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  /* cobre toda a div */
  width: 100%;
  height: 900px;
  position: relative;
}
.container-destaque {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  /* elementos um embaixo do outro */
  align-items: center;
  /* centraliza no eixo horizontal */
  gap: 20px;
  /* espaço entre a caixa e o botão */
}
.destaque-cabecalho {
  width: 400px;
  height: 200px;
  background-color: rgba(255, 255, 255, 0.7);
  text-align: center;
  font-weight: bold;
  color: #333;
  font-family: "Quattrocento Sans", sans-serif;
  display: flex;
  justify-content: center;
  /* centraliza na vertical */
  align-items: center;
  /* centraliza na horizontal */
  flex-direction: column;
  /* garante quebra de linha no texto */
}
.botao-reservar {
  display: inline-block;
  padding: 12px 30px;
  background-color: #654321;
  color: white;
  font-size: 14px;
  text-decoration: none;
  border-radius: 30px;
  transition: background-color 0.3s ease;
}
.botao-reservar:hover {
  background-color: #BA7930;
  color: white;
}
/* posiciona a logo no “vazio” à direita do herói */
.cabecalho {
  position: relative;
}
/* (você já tem) */
.logo-hero {
  position: absolute;
  top: 40%;
  /* ajuste fino vertical */
  right: 7%;
  /* ajuste fino horizontal */
  transform: translateY(-50%);
  z-index: 3;
}
.logo-hero img {
  display: block;
  width: clamp(120px, 12vw, 220px);
  /* responsivo */
  height: auto;
}
/* opcional: se precisar de contraste no fundo claro
.logo-hero{
  background: rgba(255,255,255,.75);
  padding: 10px 14px;
  border-radius: 10px;
}
*/
/* mobile: encosta embaixo à direita para não colidir com o título */
@media (max-width: 768px) {
  .logo-hero {
    top: auto;
    bottom: 16px;
    right: 16px;
    transform: none;
  }
  .logo-hero img {
    width: 120px;
  }
}
/* Seção: Sobre o imóvel */
.sobre-imovel {
  background-color: #fff;
  position: relative;
  width: 100%;
  min-height: 600px;
  /* garante altura mínima */
  padding: 100px 100px 30px;
  /* topo, laterais e um respiro no fundo */
  margin-bottom: 0px;
  /* separa do rodapé/ próxima seção */
  clear: both;
  /* previne sobreposição caso tenha floats acima */
}
/* Mantém o mesmo alinhamento lateral sem repetir regras */
.sobre-imovel #titulo-secao, .sobre-imovel #linha-secao, .sobre-imovel #lista-caracteristicas, .sobre-imovel #lista-itens-mobilia, .sobre-imovel #comentario-sobre-imovel {
  padding-left: 0;
  /* já temos padding na seção */
}
/* linha sob o título */
.sobre-imovel #linha-secao {
  margin-top: -25px;
}
/* espaçamento do primeiro bloco de lista */
.sobre-imovel #lista-caracteristicas {
  padding-top: 50px;
  padding-bottom: 50px;
}
/* Listas em colunas */
.sobre-imovel #lista-caracteristicas ul, .sobre-imovel #lista-itens-mobilia ul {
  columns: 2;
  -webkit-columns: 2;
  -moz-columns: 2;
  column-gap: 60px;
  /* espaço entre colunas */
  list-style-type: disc;
  padding-left: 20px;
  font-size: 18px;
}
/* evita quebrar um <li> no meio entre colunas */
.sobre-imovel li {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  -moz-column-break-inside: avoid;
}
/* centraliza o subtítulo final */
.sobre-imovel #comentario-sobre-imovel {
  text-align: center;
  padding-top: 20px;
}
/* responsivo: 1 coluna no mobile */
@media (max-width: 768px) {
  .sobre-imovel #lista-caracteristicas ul, .sobre-imovel #lista-itens-mobilia ul {
    columns: 1;
    -webkit-columns: 1;
    -moz-columns: 1;
  }
  .sobre-imovel {
    padding: 60px 20px 60px;
  }
}
/* GALERIA — coluna da direita (usar o ID para não afetar o slider da esquerda) */
#galeria-fotos {
  background: #303030;
  width: 100%;
  display: flex;
  /* chave do sucesso: flex + mesma altura do slider */
  flex-direction: column;
  justify-content: center;
  min-height: 900px;
  /* centraliza VERTICALMENTE o conteúdo */
  padding: 70px 24px;
  /* mesmo height do SmartSlider (base=900) */
  margin: 0;
  /* só laterais; sem topo/rodapé para centralizar mesmo */
  /* zera margens externas */
}
#galeria-fotos #linha-secao {
  margin-top: -25px;
}
#galeria-fotos h1, #galeria-fotos p {
  color: #fff;
}
#galeria-fotos p {
  font-size: 20px;
  margin-bottom: 24px;
}
#galeria-fotos .cta-reserva-galeria {
  margin-top: 0;
  text-align: left;
  /* o espaçamento vem do <p> acima */
  /* botão alinhado à esquerda */
}
#galeria-fotos .cta-reserva-galeria .botao-reservar {
  font-size: 15px;
  padding: 14px 34px;
}
/* Responsivo (se quiser afinar em telas menores) */
@media (max-width: 1199px) {
  #galeria-fotos {
    min-height: 700px;
  }
}
@media (max-width: 900px) {
  #galeria-fotos {
    min-height: auto;
    padding: 24px 16px;
  }
}
/* 1) Linha que contém o bloco do vídeo (#aluguel-exclusivo): aplica o fundo e equaliza altura */
.g-grid:has(> #aluguel-exclusivo) {
  background: #303030;
  /* fundo preto em toda a faixa */
  align-items: stretch;
  /* colunas com a MESMA altura */
  padding: 40px 24px;
  /* respiro da seção */
}
/* 2) Bloco de TEXTO (irmão do #aluguel-exclusivo): centraliza verticalmente */
.g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) {
  display: flex;
}
.g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) > .g-content {
  /* mesma “lógica” de altura do vídeo para funcionar o centering */
  min-height: clamp(700px, 85vh, 1100px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: transparent !important;
  /* garante que o preto venha da linha */
  color: #fff;
  /* tipografia branca por cima do fundo */
  padding: 0 0;
  /* ajuste fino de respiro interno */
}
/* 3) Tipografia e microestilos do bloco de texto */
.g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) h1 {
  margin: 0 0 10px;
  color: #fff;
  font-family: "Quattrocento", serif;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.1;
  font-size: clamp(28px, 3.2vw, 42px);
}
.g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) p {
  margin: 0;
  color: #fff;
  font-size: 18px;
}
.g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) .ax-linha {
  width: 72px;
  height: 2px;
  background: rgba(255, 255, 255, 0.35);
  margin: 6px 0 18px;
}
.g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) .ax-cta {
  margin-top: 22px;
  text-align: left;
}
/* 4) Coluna de VÍDEO (AllVideos): ocupa 100% da coluna e elimina faixas pretas */
#aluguel-exclusivo .avPlayerWrapper, #aluguel-exclusivo .avPlayerContainer, #aluguel-exclusivo .avPlayerBlock {
  position: relative;
  width: 100%;
  height: clamp(700px, 85vh, 1100px);
  /* altura no “mesmo compasso” do texto */
  overflow: hidden;
  /* corta o excedente ao cobrir */
  background: transparent;
  /* fundo vem da linha (.g-grid) */
}
#aluguel-exclusivo video.avPlayer {
  position: absolute;
  inset: 0;
  width: 100% !important;
  /* sobrepõe width/height inline do AllVideos */
  height: 100% !important;
  object-fit: cover;
  /* cobre a área (sem barras) */
  object-position: center;
  /* enquadramento no centro */
}
/* 5) Responsivo (empilha e alivia altura fixa) */
@media (max-width: 992px) {
  .g-grid:has(> #aluguel-exclusivo) {
    padding: 24px 16px;
  }
  .g-grid:has(> #aluguel-exclusivo) > .g-block:not(#aluguel-exclusivo) > .g-content {
    min-height: auto;
    /* no mobile, volta a altura natural */
    justify-content: flex-start;
    /* texto sobe pro topo */
  }
  #aluguel-exclusivo .avPlayerWrapper, #aluguel-exclusivo .avPlayerContainer, #aluguel-exclusivo .avPlayerBlock {
    height: 70vh;
    /* boa proporção em telas menores */
  }
}
/* Wrapper responsivo do mapa */
#mapa-cop30.map-wrap {
  /* Moderno */
  aspect-ratio: 1.7777777778;
  /* Fallback */
  position: relative;
  width: 100%;
  min-height: 420px;
  /* garante altura mínima */
  background: #1f1f1f;
  /* placeholder enquanto carrega */
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
}
#mapa-cop30 iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
/* CTAs abaixo do mapa */
.map-ctas {
  margin-top: 10px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.map-ctas a {
  display: inline-block;
  padding: 10px 16px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  background: #6b4a25;
  /* bronze do seu botão */
  color: #fff;
  transition: transform 0.12s ease, opacity 0.12s;
}
.map-ctas a:hover {
  transform: translateY(-1px);
  opacity: 0.95;
}
@media (max-width: 768px) {
  #mapa-cop30.map-wrap {
    min-height: 320px;
    aspect-ratio: 1.3333333333;
  }
  .map-ctas {
    flex-direction: column;
  }
}
.localizacao {
  padding: 50px 20px;
}
/* linha sob o título */
.localizacao #linha-secao {
  margin-top: -25px;
  margin-bottom: 40px;
}
.localizacao p {
  font-size: 18px;
}
/* Seção Contato */
.faleconosco {
  padding: 0px 20px;
}
.faleconosco #linha-secao {
  margin-top: -25px;
}
#contato-rapido {
  padding: 40px 24px;
  color: #fff;
}
/* Campos Convert Forms */
#contato-rapido input[type="text"], #contato-rapido input[type="tel"], #contato-rapido input[type="email"], #contato-rapido input[type="date"], #contato-rapido input[type="number"], #contato-rapido textarea, #contato-rapido select {
  border: 1px solid black;
  color: #fff;
  padding: 12px 14px;
  border-radius: 10px;
  width: 100%;
  outline: none;
}
#contato-rapido textarea {
  min-height: 120px;
  resize: vertical;
}
#contato-rapido .cf-submit, #contato-rapido .ax-whats-btn {
  display: inline-block;
  padding: 14px 28px;
  border-radius: 999px;
  background: #6b4a25;
  color: #fff;
  /* seu bronze */
  border: none;
  cursor: pointer;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.12s ease, opacity 0.12s;
}
#contato-rapido .ax-whats-btn {
  background: #1f7a1f;
  margin-left: 8px;
  /* verde WhatsApp */
}
#contato-rapido .cf-submit:hover, #contato-rapido .ax-whats-btn:hover {
  transform: translateY(-1px);
  opacity: 0.95;
}
/* Grid básico */
#contato-rapido .ax-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 992px) {
  #contato-rapido .ax-grid {
    grid-template-columns: 1fr;
  }
  #contato-rapido .ax-whats-btn {
    display: block;
    margin: 10px 0 0;
    text-align: center;
  }
}
/* ===== CONTATO – GRID: Título/linha em full, abaixo form + imagem ===== */
#faleconosco > .g-content.g-particle {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  /* ajuste a proporção conforme quiser */
  column-gap: 24px;
  row-gap: 12px;
  align-items: start;
  /* título no topo; imagem alinha via align-self */
}
/* Título e linha ocupam as 2 colunas */
#faleconosco #titulo-secao, #faleconosco #linha-secao {
  grid-column: 1 / -1;
}
/* Coluna ESQUERDA: formulário (Convert Forms) */
#faleconosco #contato-rapido {
  grid-column: 1;
}
/* Coluna DIREITA: imagens */
#faleconosco #whatsapp {
  grid-column: 2;
  display: flex;
  flex-direction: column;
  /* empilha uma embaixo da outra */
  align-items: center;
  gap: 16px;
  /* espaço entre as imagens */
}
/* Dimensão responsiva das imagens */
#faleconosco #whatsapp img {
  width: 540px;
  height: auto;
  max-width: 100%;
  display: block;
}
/* Responsivo */
@media (max-width: 992px) {
  #faleconosco #whatsapp {
    grid-column: 1;
    margin-top: 16px;
    justify-content: center;
  }
  #faleconosco #whatsapp img {
    width: clamp(220px, 70vw, 420px);
    margin-inline: auto;
  }
}
/*# sourceMappingURL=custom_15.css.map */