/* ===========================
   RESET CSS MODERNO
   =========================== */

/* Remove margens e paddings padrões */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Define fonte base e suaviza a renderização */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  line-height: 1.5;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background-color: #fff;
  color: #000;
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: normal;
}

/* Remove estilos padrões de listas */
ul,
ol {
  list-style: none;
}

/* Remove decoração de links */
a {
  text-decoration: none;
  color: inherit;
}

/* Garante que imagens e vídeos se ajustem ao container */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Remove estilos padrões de botões e inputs */
button,
input,
select,
textarea {
  font: inherit;
  border: none;
  background: none;
  color: inherit;
  outline: none;
}

/* Ajusta títulos e parágrafos */
h1, h2, h3, h4, h5, h6, span {
  font-weight: inherit;
  font-size: inherit;
}

/* Garante que tabelas não tenham espaçamento inesperado */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Remove aspas automáticas em blockquotes */
blockquote::before,
blockquote::after {
  content: '';
}

/* Define o cursor padrão para botões */
button {
  cursor: pointer;
}

/* Remove aparência padrão em links dentro de botões */
button a {
  color: inherit;
}

/* Oculta elementos apenas visualmente, mantendo acessibilidade */
.visually-hidden {
  position: absolute ;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

body {
    background:#001112;
}


header {
    position: absolute;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 0;
}

header img {
    max-width: 25vw;
}

.whatsapp-fixed {
    position: fixed;
    bottom: 32px;
    right: 32px;
    z-index: 9;
}

.btn-whatsapp {
    background-color: #19721f;
    color: #fff;
    border-radius: 100%;
    transition: background-color .5s;
    width: 60px;
    height: 60px;
  line-height: 70px;
    position: relative;
    display: block;
    transform: none;
    z-index: 9;
    text-align: center;
  box-shadow:
            0 1px 2px rgba(0,0,0,0.07),
            0 2px 4px rgba(0,0,0,0.07),
            0 4px 8px rgba(0,0,0,0.07),
            0 8px 16px rgba(0,0,0,0.07),
            0 16px 32px rgba(0,0,0,0.07),
            0 32px 64px rgba(0,0,0,0.07);
}

.btn-whatsapp:hover {
  background-color: #19721f;
}

.whatsapp-fixed a.video-vemo-icon.btn-whatsapp svg {
    font-size: 32px;
    color: #fff;
    animation: sm-shake-animation linear 1.5s infinite;
    animation-delay: 3s;
  width:32px;
  fill:#FFF;
  top:7px;
  left:0px;
}

.rs-video .animate-border .video-vemo-icon:before {
    content: "";
    border: 2px solid #19721f;
    position: absolute;
    z-index: 0;
    left: 50%;
    top: 50%;
  opacity: 0;
    transform: translateX(-50%) translateY(-50%);
    display: block;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    animation: zoomBig 3.25s linear infinite;
    -webkit-animation-delay: 4s;
    animation-delay: 4s;
}

.rs-video .animate-border .video-vemo-icon:after {
    content: "";
    border: 2px solid #19721f;
    position: absolute;
  opacity: 0;
    z-index: 0;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    display: block;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    animation: zoomBig 3.25s linear infinite;
    -webkit-animation-delay: 3s;
    animation-delay: 3s;
}

.btn-whatsapp:after, .btn-whatsapp:before {
    border: 2px solid #19721f ;
    width: 130px;
    height: 130px;
}

.sm-red-dot {
    position: absolute;
    right: 4px;
    top: 4px;
  width: 12px; height: 12px;
  margin: 0 auto;
    background: red;
  transform: scale(0);
    border-radius: 50%;
  animation-name: notificationPoint;
animation-duration: 300ms;
  animation-fill-mode: forwards;
    animation-delay: 3s;
}

.quick-message {
    position: absolute;
    bottom: 4px;
    right: 88px;
    width: max-content;
    border-radius: 0;
  background: #393b39;
}

.line-up {
  opacity: 0;
    animation-name: anim-lineUp;
    animation-duration: 0.75s;
  animation-fill-mode: forwards;
    animation-delay: 5s;
}

.quick-message p {
  line-height: 40px;
  font-size: 15px;
  padding: 0px 16px 0px;
  height: 40px;
  position: relative;
  color: #fff;
  margin: 0;
}

.quick-message .seta-direita:before {
    display: inline-block;
    content: "";
    vertical-align: middle;
    margin-right: 10px;
    width: 0;
    height: 0;
    border-top: 20px solid transparent;
    border-bottom: 20px solid transparent;
    border-left: 20px solid #393b39;
    position: absolute;
    bottom: 0px;
    right: -30px;
}

#hover-message {
  display: none;
}

.whatsapp-fixed:hover #hover-message {
  display: block;
}

@keyframes zoomBig{
  0%{transform:translate(-50%,-50%) scale(.5);opacity:1;border-width:3px}
  40%{opacity:.5;border-width:2px}
  65%{border-width:1px}100%{transform:translate(-50%,-50%) scale(1);opacity:0;border-width:1px}}

@keyframes sm-shake-animation {
 0% {
  transform:rotate(0) scale(1) skew(0.017rad)
 }
 25% {
  transform:rotate(0) scale(1) skew(0.017rad)
 }
 35% {
  transform:rotate(-0.3rad) scale(1) skew(0.017rad)
 }
 45% {
  transform:rotate(0.3rad) scale(1) skew(0.017rad)
 }
 55% {
  transform:rotate(-0.3rad) scale(1) skew(0.017rad)
 }
 65% {
  transform:rotate(0.3rad) scale(1) skew(0.017rad)
 }
 75% {
  transform:rotate(0) scale(1) skew(0.017rad)
 }
 100% {
  transform:rotate(0) scale(1) skew(0.017rad)
 }
}

@keyframes notificationPoint {
  from {transform: scale(0)}
  to {transform: scale(1)}
}

@keyframes anim-lineUp {
  from {
    transform: translateY(100%);
  }
  to {
    opacity: 1;
    transform: translateY(0%);
  }
}

a.video-vemo-icon.btn-whatsapp {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Animação Fade-in */
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* Classe utilitária para aplicar o efeito */
.fade-in {
  animation: fade-in 1s ease-in forwards;
}

.z-2 {
    z-index: 2;
}

.z-3 {
    z-index: 3;
    
}

h1, h2, h3, h4, button {
      font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  color:#FFF;
  text-align: center;
}

.hero button {
    margin:0 auto;
    float: none;
}

.golden-btn {
   
  display: inline-block;
  outline: none;
   text-decoration: inherit;
  box-sizing: border-box;
  border: none;
  border-radius: .3em;
  height: 2.75em;
  line-height: 2.5em;
  text-transform: uppercase;
  padding: 0 1em;
  box-shadow: 0 3px 6px rgba(0,0,0,.16), 0 3px 6px rgba(110,80,20,.4),
              inset 0 -2px 5px 1px rgba(139,66,8,1),
              inset 0 -1px 1px 3px rgba(250,227,133,1);
  background-image: linear-gradient(160deg, #a54e07, #b47e11, #fef1a2, #bc881b, #a54e07);
  border: 1px solid #a55d07;
  color: rgb(120,50,5);
  text-shadow: 0 2px 2px rgba(250, 227, 133, 1);
  cursor: pointer;
  transition: all .2s ease-in-out;
  background-size: 100% 100%;
  background-position:center;
  font-weight: 900;
  color:#351f04;
 
}

.golden-btn {
    border-radius:6px;
}

.golden-btn:focus,
.golden-btn:hover {
  background-size: 150% 150%;
  box-shadow: 0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23),
                inset 0 -2px 5px 1px #b17d10,
                inset 0 -1px 1px 3px rgba(250,227,133,1);
  border: 1px solid rgba(165,93,7,.6);
  color: rgba(37, 20, 9, 0.8);
}
.golden-btn:active {
  box-shadow: 0 3px 6px rgba(0,0,0,.16), 0 3px 6px rgba(110,80,20,.4),
              inset 0 -2px 5px 1px #b17d10,
                inset 0 -1px 1px 3px rgba(250,227,133,1);
}




.pulse {
    -webkit-animation: pulse 1.5s infinite;
}

.pulse:hover {
    -webkit-animation: none;
}

@-webkit-keyframes pulse {
    0% {
        -moz-transform: scale(0.95);
        -ms-transform: scale(0.95);
        -webkit-transform: scale(0.95);
        transform: scale(0.95);
  box-shadow: 0 3px 6px rgba(0,0,0,.16), 0 3px 6px rgba(110,80,20,.4),
              inset 0 -2px 5px 1px #b17d10,
                inset 0 -1px 1px 3px rgba(250,227,133,1);
    }

    70% {
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -webkit-transform: scale(1);
        transform: scale(1);
  box-shadow: 0 3px 6px rgba(0,0,0,.16), 0 3px 6px rgba(110,80,20,.4),
              inset 0 -2px 5px 1px #b17d10,
                inset 0 -1px 1px 3px rgba(250,227,133,1);
    }

    100% {

  box-shadow: 0 3px 6px rgba(0,0,0,.16), 0 3px 6px rgba(110,80,20,.4),
              inset 0 -2px 5px 1px #b17d10,
                inset 0 -1px 1px 3px rgba(250,227,133,1);
    }
}

.d-flex {
    display: flex;
}

.a-ctr {
    align-items: center;
}

.j-ctr {
    justify-content: center;;
}

.f-wrap {
    flex-wrap: wrap;
}


.filhote {
    width: 100%;
}


.golden-btn {
      font-size: 20px;
      border-radius: 500px;
}

.hero .golden-btn {

        margin-top:-20vw!important;
        width:80vw;
        margin-bottom: 0!important;
}


.ltr-flt {
    max-width: 78vw;
    margin-bottom: -5vw;
    z-index: 1;
}

.filhote h3 {
    font-size: 5vw;
    line-height: 1.8;
}

.img-flt {
    max-width: 90vw;
    margin-bottom: -10vw;
    z-index: 1;
}

.filhote {
    background: url(../img/piso.jpg);
    background-repeat: no-repeat;
    background-position: bottom center;
    background-size:250vw;
    padding-top:100px;
    position: relative;
    overflow: hidden;
}

.filhote .golden-btn {
    margin-top:20px;
    margin-bottom: 30px;
}

.filhote:before {
    content:'';
    width: 60vw;
    height: 45vw;
    background: #a7ffbf;
    position: absolute;
    border-radius: 500vw;
    z-index: 0;
    top: 50vw;
    filter: blur(60px);
}


    /* ======== GALERIA MASONRY ======== */
    .gallery {
      columns: 4;               /* número de colunas no desktop */
      column-gap: 10px;
      padding:5vw 5vw;
    }

    .gallery img {
      width: 100%;
      margin-bottom: 10px;
      border-radius: 6px;
      cursor: pointer;
      transition: transform 0.3s ease;
    }

    .gallery img:hover {
      transform: scale(1.03);
    }

    /* Responsividade */
    @media (max-width: 1000px) {
      .gallery { columns: 3; }
    }
    @media (max-width: 700px) {
      .gallery { columns: 2; }
    }
    @media (max-width: 500px) {
      .gallery { columns: 2; }
    }

    /* ======== LIGHTBOX ======== */
    .lightbox {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, 0.9);
      justify-content: center;
      align-items: center;
      z-index: 9999;
    }

    .lightbox.active {
      display: flex;
    }

    .lightbox img {
      max-width: 90%;
      max-height: 90%;
      border-radius: 10px;
    }

    /* ======== CONTROLES ======== */
    .lightbox .close,
    .lightbox .prev,
    .lightbox .next {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      color: #fff;
      font-size: 2rem;
      cursor: pointer;
      user-select: none;
      background: rgba(0, 0, 0, 0.5);
      padding: 10px;
      border-radius: 10px;
      transition: background 0.3s;
    }

    .lightbox .close {
      top: 30px;
      right: 30px;
      transform: none;
      padding: 0;
      aspect-ratio: 1;
      display: flex;
      background:rgba(85, 6, 6, 0.534);
      width:50px;
      height: 50px;
      align-items: center;
      justify-content: center;
      padding: 0;
      margin:0;
      line-height: 1;
      font-size: 50px;

    }

    .lightbox .prev { left: 30px; }
    .lightbox .next { right: 30px; }

    .lightbox .prev:hover,
    .lightbox .next:hover,
    .lightbox .close:hover {
      background: rgba(255, 255, 255, 0.2);
    }


.galeria h2 {
    font-size: 7vw;
    line-height: 1.1;
    max-width: 80vw;
    margin: 0 auto 5vw;
}

.txt-zap {
    color:#FFF;
    text-align: center;
    width: 100%;
    font-size:2.5vw;
    display: block;
    margin-top:-15px;
    margin-bottom: 50px;
    letter-spacing: 0.2em;
    opacity: 0.5;
}


.entregue-com {
  padding: 0 12vw 12vw;
}


.entregue-com .item {
  margin:5vw 0;
}

.entregue-com h2 {
  font-size:7vw;
  max-width: 60vw;
  line-height: 1.0;
  margin: 0 auto;
}

.entregue-com h3 {
  font-size:6vw;
  margin-bottom:0.2em;
}

.entregue-com h3 span {
  font-size: 3vw;
  width: 100%;
  display: block;
}

.entregue-com svg {
  fill:#FFF;
  
}

.entregue-com svg {
    width:15vw;
    height:15vw;
    margin:0 auto 20px;
}
.entregue-com svg path {
    stroke: #b26d12;
}

.entregue-com .i-solido svg * {
  fill: #b26d12;
}
 
.i-pedigree svg {
  width: 20vw;
  height: 20vw;
}

.entregue-com p {
  color:#FFF;
  text-align: center;
  line-height: 1.4;
  font-size: 4vw;

}

.social h2 {
  font-size:7vw;
  max-width: 50vw;
  line-height: 1.0;
  margin: 0 auto 5vw;
}

.social {
    margin: 40px 0;
}

.social .item {
    width: 50px;
    background: #ffffff1a;
    padding: 13px;
    border-radius: 500px;
    margin: 0 10px;
}

.social .item svg path {
    fill: #FFF;
}

footer {
    background: #a7ffbf05;
    padding: 50px 10vw;
}

footer img {
    width: 40vw;
    margin: 0 auto 30px;
}

footer p {
    color: #FFF;
    font-size: 4vw;
    text-align: center;
    font-style: italic;
    max-width: 230px;
    margin: 0 auto;
}

footer button {
  margin:40px auto;
}

.filhote button {
    z-index: 5;
}

.filhote .golden-btn {
    z-index: 33;
    position: relative;
}


@media only screen and (min-width:1024px) {

    header img {
    max-width: 120px;
}

.hero .golden-btn {
    max-width:max-content;
    margin: 0 auto;
    display: block;
    padding: 3px 60px;
    margin-bottom: 15px;
}

span.txt-zap {
    display: block;
    font-size: 11px;
    margin: 10px 0 0 0;
}

.hero img, .hero picture {
    width: 100%;
    max-width: 100%;
}

.galeria h2 {
    font-size: 50px;
    max-width: 500px;
    margin: 0 auto;
}

.gallery {
    padding: 30px 0 30px;
}

.galeria {
    margin-top: -100px;
    z-index: 3;
    position: relative;
}

.filhote h3 {
    font-size: 50px;
}

.filhote {
}

.img-flt {
    width: 731px;
    margin: 0 auto;
    display: block;
    margin-bottom: -40px;
    margin-top: 40px;
}

.filhote button, .filhote button a {
    display: block;
    margin: 0 auto;
}

.filhote .grid {
    max-width: 800px;
}

.filhote:before {
    top: 300px;
    width: 240px;
    height: 130px;
    filter: blur(131px);
}

.filhote {
    background-size: 100%;
}

.filhote .golden-btn {
    display: block;
    margin: 0 200px;
    padding: 1px 50px;
}

.entregue-com {
    padding: 70px 0;
    max-width: 1200px;
    margin: 0 auto;
}

.entregue-com h2 {
    font-size: 50px;
    max-width: 430px;
}

.entregue-com .grid {
    align-items: flex-start;
    justify-content: center;
    flex-wrap: nowrap;
}

.entregue-com .grid .item {
    width: 25%;
    padding: 0 15px;
}

.i-pedigree svg {
    width: 60px;
    height: 60px;
}

.entregue-com svg {
    width: 50px;
    height: 50px;
}

.entregue-com h3 {
    font-size: 26px;
}

.entregue-com h3 span {
    font-size: 15px;
}

.entregue-com p {
    font-size: 16px;
}

.social h2 {
    font-size: 50px;
    max-width: 400px;
    margin: 0 auto 40px;
}

.social {
    margin-bottom: 150px;
}

.social .item {
    width: 60px;
    padding: 15px;
}

.social:before {
    content: '';
    width: 150px;
    height: 150px;
    background: #a7ffbf;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: 0 auto;
    z-index: -1;
    border-radius: 500px;
    filter: blur(100px);
}

.social {
    position: relative;
    align-items: center;
    justify-content: center;
}

footer .grid {
    max-width: 600px;
    margin: 0 auto;
}

footer .grid img {
    max-width: 190px;
    display: block;
    width: 190px;
}

footer .grid {
}

footer .grid p {
    width: 100%;
    margin: 0 auto;
    display: block;
    font-size: 14px;
    clear: both;
    max-width: 100%;
    margin: 0 auto 30px;
}

footer .golden-btn {
    display: block;
    margin: 0 auto;
}

.quick-message p {
    font-size: 13px!important;
}
header .grid {
    width: 64vw;
}



}

@media screen and (min-width:767px) {
   .hero button.golden-btn.pulse {
    margin-top: -229px!important;
}
}

.galeria img.fade-in.ltr-flt {
    margin: 0 auto;
    width: 100%;
    max-width: 90%;
    margin-bottom: 10px;
}

.galeria.gh2 h2 {
    max-width: 90%;
}

@media only screen and (min-width:767px) {
    .galeria img.fade-in.ltr-flt {
    margin: 0 auto;
    width: 100%;
    max-width: 800px;
    margin-bottom: 10px;
        margin-top: 20px;
}

.galeria.gh2 h2 {
    max-width: 800px;
}
}