/* ======== Base / Tokens ======== */
:root{
  --bg:#ffffff;
  --ink:#0f1c2a;           /* texto principal */
  --muted:#576071;         /* texto secundário */
  --primary:#1f3b57;       /* azul escuro */
  --primary-2:#163046;     /* mais escuro para hover */
  --accent:#27ae60;        /* verde dos badges */
  --card:#fff;
  --br:20px;               /* border-radius padrão */
  --br-lg:28px;
  --shadow:0 10px 24px rgba(0,0,0,.06);
    --footer-bg:#0f1c2a;
  --footer-ink:#ffffff;
  --footer-muted:rgba(255,255,255,.85);
  --footer-sep:rgba(255,255,255,.12);
  --accent:#27ae60;
  --font-base: 'Noto Sans', sans-serif;
  --font-title: 'Poppins', sans-serif;
}

body {
  font-family: var(--font-base);
  font-weight: 400;
}
html, body {
  overflow-x: hidden;
}

h1, h2, h3, h4, .hero h1, .card__title {
  font-family: var(--font-title);
  font-weight: 700;
  letter-spacing: -0.02em;
}
*{ box-sizing:border-box }
html,body{ margin:0; padding:0 }
body{ 
    font:16px/1.5 "Noto Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial; 
  color:var(--ink);
  background:var(--bg);
}
img{ max-width:100%; height:auto; display:block }

.feed{
    background: radial-gradient(1200px 400px at -10% 10%, #b5c6dc 0, rgba(40, 72, 110, .75) 80%, #a0b1c3 100%);
    color: #fff;
    margin-bottom: 2px;
}
.feed .more {
    text-align: right;
    margin-top: 16px;
}
.feed .more a {
    font-weight: 700;
    color: #ffffff;
}
#sb_instagram .sbi_photo img {
    border-radius: 20px;
}
/* ======== Layout ======== */
.container{ max-width:1200px; margin:0 auto; padding:24px }
.cols{ display:grid; grid-template-columns:1fr 1fr; gap:32px }
.grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px }
@media (max-width: 1100px){ .grid,.grid-4{ grid-template-columns:repeat(3,1fr) } }
@media (max-width: 900px){ .cols{ grid-template-columns:1fr } .grid,.grid-3,.grid-4{ grid-template-columns:1fr } }

/* ======== Header (blur + pill CTA) ======== */
.site-header{
position: fixed;
    top: 0;
    z-index: 50;
    backdrop-filter: saturate(180%) blur(5px);
    background: rgba(15, 28, 42, .5);
    width: 100%;
    padding: 14px;
    box-shadow: 0 16px 40px rgba(0, 0, 0, .35);
}
.nav {
  display: flex;
  align-items: center;
  justify-content: flex-start; /* agora o alinhamento é à esquerda */
  gap: 32px;
  padding: 4px 24px;
}

.logo img {
  display: block;
  height: auto;
  width: 110px;
}

.menu {
    
  display: flex;
  gap: 50px;
  list-style: none;
  margin: 0;
  padding: 0;
  margin-left: 50px;
}

.menu a {
    color: #ffffff;
    text-decoration: none;
    font-weight: 600;
    transition: .3s;
    opacity: .8;
    font-family: var(--font-title);
    padding: 5px;
}

.menu a:hover { opacity: 1;     border-bottom: solid 3px;}

/* mantém o botão à direita */
.btn-whats {
  margin-left: auto; 
  background: #3b537d;
  color: #fff;
  text-decoration: none;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 300;
    transition: .3s;
    font-size: 1rem;
}
.btn-whats i{ font-size: 1.3rem; margin-right: 10px;}
.btn-whats:hover { background: #1b3b52; }

.hero--empre-div{
    padding-top: 0px !important;
    padding-bottom: 0px !important;
    color: var(--ink);
    
}

/* ======== Hero ======== */
.hero{
  position:relative; min-height:79vh; display:flex; align-items:flex-end;overflow:hidden;
  background:#223 center/cover no-repeat;
  color:#fff; 
}
.hero-bg{
  position:absolute; inset:-12% -8% -12% -8%;
  background-size:cover; background-position:center;
  will-change:transform;
}

.hero::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, #ffffff00 20%, #00000054 100%);;
 
}
.hero .container{ position:relative; z-index:1; padding-top:80px; padding-bottom:48px;     width: 90%; }
.hero h1{
  margin:0; font-size:clamp(28px,5vw,44px); line-height:1.15; font-weight:800;
  text-shadow:0 6px 24px rgba(0,0,0,.35);
}

.hero__cta {
  margin-top: 24px;
}

.hero__cta .btn {
  display: inline-block;
  background: var(--primary);
  color: #fff;
    padding: 9px 23px;
    border-radius: 50px;
    font-weight: 300;
  text-decoration: none;
  transition: background .25s ease;
}

.hero__cta .btn:hover {
  background: var(--primary-2);
}


/* ======== Vídeo do Empreendimento ======== */
.emp-video {     padding: 30px;     background: #e7ecf1; }
.emp-video h2 { margin: 0 0 16px; }

.video-wrap{
  position: relative;
  aspect-ratio: 16 / 9;
   border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
.video-wrap iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0; display:block;
}

/* visível por padrão (sem JS/AOS) */
#empre-grid > article {
  opacity: 1;
  transform: none;
  transition: opacity .48s ease, transform .48s ease;
}

/* quando JS marca o container para stagger */
#empre-grid.stagger > article {
  opacity: 0;
  transform: translateY(18px);
}
#empre-grid.stagger > article.is-revealed {
  opacity: 1;
  transform: translateY(0);
}
/* ======== Benefícios (3 boxes) ======== */

.beneficios .card{
  background:#3c537d; border:1px solid #ABC5FF; border-radius:0;
  color: white;
  border-right: none;
  padding-bottom: 32px;
  padding:34px; padding-top:48px; box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.beneficios .card h3{ margin:0 0 6px; font-size:18px }
.beneficios .card p{ margin:0; color:white; }

/* ======== Cards de Empreendimentos ======== */
.card{
  border:1px solid #e9eef3; border-radius:var(--br); background:var(--card);
  overflow:hidden; transition: box-shadow .2s ease; /* sem transform aqui */
}
.card.aos-animate{ transition: transform .2s ease, box-shadow .2s ease; } /* volta o hover suave após a animação */
.card__ano{
        margin: 0;
    font-weight: 200;
    font-size: 14px;
}
.card .fa-solid{
    font-size: 30px;
    margin-bottom: 20px;
}
.card:hover{ transform:translateY(-2px); box-shadow:var(--shadow) }
.card__media{ position:relative }
.card__media img{ width:100%; height:auto }
.badge-status{
  position:absolute; left:12px; top:12px; padding:6px 10px;
  background:var(--accent); color:#fff; border-radius:999px;
  font-size:.78rem; font-weight:700; letter-spacing:.2px;
}
.card__body{ padding:14px }
.card__title{ margin:0 0 6px; font-size:18px }
.card__meta{
  display:flex; flex-wrap:wrap; gap:10px;
  list-style:none; margin:6px 0 0; padding:0; color:var(--muted); font-size:.92rem;
}
.more{ margin-top:14px }
.more a{ color:var(--primary); text-decoration:none; font-weight:700 }
.more a:hover{ text-decoration:underline }

/* ======== Seção Institucional (gradiente) ======== */
.sobre{
  margin-top:48px; margin-bottom:0px; padding:48px 24px;
  background:radial-gradient(1200px 400px at -10% 10%, #5a7aa1 0, rgba(40,72,110,.75) 40%, #0f1c2a 100%);
  color:#fff;  overflow:hidden;
}
.sobre h2{ margin:0 0 10px; font-size:clamp(22px,3.2vw,36px) }
.sobre p{ color:#e7eef6 }
.sobre .thumb-demo img{
  border-radius:var(--br); box-shadow:0 16px 40px rgba(0,0,0,.35); object-fit:cover;
}

/* ======== Contato  Empreendimento======== */
.contato_emp{ margin-top: 0;
    margin-bottom: 0;
    background: #e7ecf1;}
.contato_emp h3{ margin-top:0; font-size:22px }
.contato_emp .cols > div:first-child{
  padding:24px; 
}

.contato_emp h4{
    margin-left: 19px;
}
.contato_emp button{
    margin: 19px;
}

/* ======== Contato ======== */
.contato{ margin-top: 0;
    margin-bottom: 0;
    background: url(/wp-content/uploads/2025/10/bg_2_cns.png);
    background-position: center;}
.contato h3{ margin-top:0; font-size:22px }
.contato .cols > div:first-child{
  padding:24px; 
}
.i_contato{
        animation-timing-function: 
linear;
    background-color: gradient(1200px 400px at -10% 10%, #5a7aa1 0, rgba(40, 72, 110, .75) 40%, #0f1c2a 100%);
    float: left;
    width: 36px;
    height: 36px;
    color: white;
    align-items: center;
    border-radius: 100%;
    display: flex
;
    justify-content: center;
    background: #0f6628;
    background: linear-gradient(132deg, rgba(15, 102, 40, 1) 0%, rgba(87, 199, 133, 1) 50%, rgba(163, 237, 83, 1) 100%);
    margin: 10px;
}
.ii_contato{
        animation-timing-function: 
linear;
    background-color: gradient(1200px 400px at -10% 10%, #5a7aa1 0, rgba(40, 72, 110, .75) 40%, #0f1c2a 100%);
    float: left;
    width: 36px;
    height: 36px;
    color: white;
    align-items: center;
    border-radius: 100%;
    display: flex
;
    justify-content: center;
    background: #576071;
    background: linear-gradient(132deg, #5a5a5a 0%, #949494 50%, #949494 100%);
    margin: 10px;
}
.b_contato p{ line-height: 1.4;}
.b_contato small{ font-size: 11px;}
.ok{
  background:#e6ffed; border:1px solid #b2f5c2; padding:10px 12px; border-radius:12px; margin-bottom:12px
}
.row{ display:grid; grid-template-columns:1fr 1fr; gap:12px }
input, textarea{
  width: 100%;
    padding: 12px 14px;
    border: 1px solid #dbe3ea;
    border-radius: 8px;
    outline: none;
    background: #fff;
    color: var(--ink);
    margin: 11px 15px;
}
.contato h4{
    margin-left: 19px;
}
.contato button{
    margin: 19px;
}
input:focus, textarea:focus{ border-color:#b9cfe2; box-shadow:0 0 0 3px rgba(31,59,87,.12) }
button{
  width:100%; padding:12px 16px; border:0; border-radius:14px; background:var(--primary);
  color:#fff; font-weight:700; cursor:pointer; letter-spacing:.2px
}
button:hover{ background:var(--primary-2) }


/* ======== Notícias ======== */
/* visível por padrão (fallback sem JS) */
.news-card{
  background:#fff; border-radius:16px; box-shadow:0 10px 24px rgba(0,0,0,.06);
  overflow:hidden; transition:transform .28s ease, box-shadow .28s ease, opacity .48s ease, translate .48s ease;
  opacity:1; translate:0 0;
}

.noticia-single .container.narrow {
  max-width: 780px;
  margin: 0 auto;
}

.news-article {
  margin-bottom: 4rem;
}

.news-header {
  margin-bottom: 1.5rem;
  text-align: center;
}

.news-title {
  font-size: 2rem;
  margin-bottom: .5rem;
}

.news-meta {
  font-size: .9rem;
  color: #ffffff;
}

.news-thumb {
  margin: 2rem 0;
}

.news-thumb img {
  width: 100%;
  height: auto;
  border-radius: var(--br);
  box-shadow: var(--shadow);
}

.news-content {
  line-height: 1.8;
  font-size: 1.05rem;
  color: var(--ink);
}

.news-footer .btn {
  display: inline-block;
  margin-top: 2rem;
  padding: .8rem 1.6rem;
  background: var(--primary);
  color: #fff;
  border-radius: var(--br);
  text-decoration: none;
  transition: background .3s ease;
}

.news-footer .btn:hover {
  background: var(--primary-2);
}

/* quando JS preparar o stagger */
.noticias-grid.stagger .news-card{ opacity:0; translate:0 18px; }
.noticias-grid.stagger .news-card.is-revealed{ opacity:1; translate:0 0; }
.noticias {
    background: url(https://construtoranovoseculo.com.br/wp-content/uploads/2025/10/bg_noticias.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    padding: 48px 0;
}
.noticias h2{ margin: 0 0 16px; }
.noticias .card img{ aspect-ratio: 16/9; object-fit:cover }
.noticias .meta{ color:var(--muted); font-size:.9rem }
.noticias-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(260px, 1fr));
  gap: 24px;
  overflow: visible;
}

/* ======== Mapa (iframe) ======== */
.emp-mapa { margin: 48px 0; }
.emp-mapa h2 { margin: 0 0 16px; }

.map-wrap{
  position: relative;
  aspect-ratio: 16/7;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  background:#e6eef6;
}
.map-wrap iframe{
  position:absolute; inset:0; width:100%; height:100%; border:0;
}


/* mobile: scroll-snap carrossel */
@media (max-width: 980px){
  .noticias-grid{
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 80%;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
  }
  .news-card{ scroll-snap-align: start; }
}

.news-card{
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  overflow: hidden;
  transition: transform .28s ease, box-shadow .28s ease, opacity .48s ease, translate .48s ease;
  opacity: 0; translate: 0 18px; /* base p/ reveal */
}
.news-card.is-revealed{ opacity:1; translate: 0 0; }

.news-card__link{ display:block; color: inherit; text-decoration:none; height:100%; }

.news-card__thumb{
  position: relative;
  height: 170px;
  overflow: hidden;
}
.news-card__thumb img{
  width:100%; height:100%; object-fit: cover; display:block;
}
.news-card__overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgb(243 249 255 / 0%) 50%, rgb(255 255 255) 100%);
}
.news-card__badge{
  position:absolute; left:12px; bottom:12px;
  background:#27ae60; color:#fff;
  font-size:.875rem; line-height:1;
  padding:8px 12px; border-radius:999px;
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
}

.news-card__title{
  font: 700 1.05rem/1.35 "Noto Sans", sans-serif;
  margin: 14px 16px 8px;
  color: var(--ink, #0f1c2a);
}
.news-card__meta{
  display:flex; justify-content:flex-end; gap:8px;
  font: 400 .925rem/1.2 "Noto Sans", sans-serif;
  color: var(--muted, #576071);
  margin: 0 16px 14px;
}

/* hover (desktop) */
@media (hover:hover){
  .news-card:hover{
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(0,0,0,.08);
  }
}

/* link "veja mais" alinhado à direita */
.noticias .more{ text-align:right; margin-top: 16px; }
.noticias .more a{ font-weight:700; color: var(--primary, #1f3b57); }
/* ======== Footer ======== */
.site-footer{
  background:#0f1c2a; color:#fff; padding-top:32px; padding-bottom:32px
}
.site-footer .cols{ align-items:start }
.site-footer a{ color:#fff; opacity:.9; text-decoration:none }
.site-footer a:hover{ opacity:1 }

/* ======== Helper: título de seção ======== */
.container > h2{
  font-size:clamp(22px,3vw,30px);
  margin:28px 0 16px 0;
}

/* ======== Ajustes finos ======== */
.hero + .beneficios{ gap:0; margin-top: 0px !important; padding: 0;     margin: 0; max-width: 100% }



.single-emp-hero{ min-height: 46vh; display:flex; align-items:flex-end; color:#fff; position:relative }
.single-emp-hero::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.0),rgba(0,0,0,.55)); }
.single-emp-hero .container{ position:relative; z-index:1; padding:40px 24px }
.glide__slide img{ width:100%; height:auto; border-radius:16px }

/* ===== SINGLE EMPREENDIMENTO ===== */
.emp-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:24px;
  align-items:center; padding-top:24px;
  background: #e8ecf1;
   border-radius: 280px 28px 28px 28px;
    margin-top: 100px;
    
}


.emp-left{ position:relative;  padding:28px 24px }
.emp-badge {
    display: inline-block;
    color: #fff;
    font-weight: 700;
    font-size: .85rem;
    padding: 6px 12px;
    border-radius: 999px;
    margin-bottom: 10px;
    width: fit-content;
}
.emp-logo-title{ display:flex; flex-direction:column; gap:8px }
 .emp-logo {
    width: 200px;
    height: auto;
    margin: auto;
    margin-bottom: 30px;
} 
.emp-title{ margin:0; font-size:clamp(26px,3.6vw,34px) }
.emp-sub{ margin:0; color:#576071 }
.emp-addr{ display:flex; align-items:center; gap:8px; color:#1f3b57; font-weight:600; margin-top:12px }

.emp-hero img{ width: auto;
    /* height: auto; */
    max-height: 560px; border-radius:20px; box-shadow:0 12px 32px rgba(0,0,0,.12) }

.emp-specs .mini-spec{
  border:1px solid #e9eef3; border-radius:16px; padding:16px; background:#fff; box-shadow: 0 10px 24px rgba(0, 0, 0, .06);
}
.mini-spec i{margin-bottom:25px};
.mini-title{ color:#576071; font-weight:700; font-size:.9rem }
.mini-val{ font-weight:800 }

.emp-desc h2{ margin-bottom:8px }
.emp-desc .descricao ul{ padding-left:18px }

.emp-infra {
  position: relative;
  overflow: hidden;
  color: var(--ink);
  padding: 80px 0;
  background: var(--bg);
}


.emp-infra{ position:relative; color:#fff;  }
.emp-infra-bg{ position:absolute; inset:-12vh 0; overflow:hidden; } /* bleed pra não aparecer borda ao mover */
.emp-infra-bg img{
  width:100%; height:100%; object-fit:cover; filter:brightness(.6);
  transform: translate3d(0,var(--pary,0),0); /* NOVO: permite mover no eixo Y */
  will-change: transform;                     /* NOVO: melhora a performance */
}
.emp-infra > .container{ position:relative; z-index:1; padding:42px 24px }
.emp-infra h2{ margin:0 0 10px }

.infra-list{ list-style:disc; padding-left:20px; display:grid; gap:6px }
.infra-list li{ text-shadow:0 2px 8px rgba(0,0,0,.35) }

.emp-plantas{ margin-top:12px }

.emp-strip{ background:#fff; padding:18px 0 28px }
.strip-scroll{ display:flex; gap:10px; overflow-x:auto; scrollbar-width:thin }
.strip-item img{ border-radius:10px; box-shadow:0 6px 16px rgba(0,0,0,.15) }

@media (max-width: 980px){
    /* Aplica em cada bloco */
.emp-grid__text { grid-area: text; }
.emp-grid__img { grid-area: img; }
.emp-grid__n1 { grid-area: n1; }
.emp-grid__n2 { grid-area: n2; }
.emp-logo {
    width: 100px;
}
.emp-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "text"
      "img"
      "n1"
      "n2";
border-radius: 0;
        padding-top: 60px !important;
        margin-top: 0;
   }
  .emp-left{ order:2 }
  .emp-hero{ order:1 }
}
/* Hero da listagem */
.hero--empre{
    margin-bottom: 8px;
    padding: 100px 24px 60px;
    color: #fff;
    min-height: 410px;
    max-width: unset;
    background-size: cover;
}
.hero--empre::after{
    background: linear-gradient(180deg, #ffffff00 50%, #ffffff 100%);
}
.hero--empre h1{ margin:0; font-size:clamp(28px,4.6vw,40px); text-shadow:unset; }


/* Card ajustes para listagem */
.card__title{ margin:8px 0 2px }
.card__title-link{ text-decoration:none; color:inherit }
.card__title-link:hover{ text-decoration:underline }
.card__loc{ margin:0; color:#6b7280; font-size:.92rem }

/* Badges por fase */
.badge--pre{     background: #ffffff;
    color: #121259; }   /* Pré Lançamento */
.badge--obra{ background:#007cba;  color: white; }  /* Em Construção */
.badge--ok{     background: #1f3b57;
    color: white; }    /* Entregue */

/* Paginação */
.pager{ margin:24px 0; display:flex; justify-content:center }
.pager .pagination{ display:flex; gap:6px; list-style:none }
.pager a, .pager span{
  display:inline-block; padding:8px 12px; border-radius:10px;
  border:1px solid #e5e7eb; color:#1f2937; text-decoration:none
}
.pager .current{ background:#1f3b57; color:#fff; border-color:#1f3b57 }

/* === Card com background (sem corte) === */
.card--bg{ transition: box-shadow .2s ease; }                 /* sem transform aqui */
.card--bg.aos-animate{ transition: transform .2s ease, box-shadow .2s ease; } 
.card--bg{
    position: relative;
    height: 400px;
    border-radius: var(--br);
    overflow: hidden;
    background-color: #0b1118;
    background-image: var(--card-bg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
   /* transition: transform .2s ease, box-shadow .2s ease;*/
}
.card--bg:hover{ transform:translateY(-2px); box-shadow:var(--shadow) }

/* overlay escuro por cima da imagem */
.card--bg::before{
  content:"";
  position:absolute; inset:0;
  background: rgba(0,0,0,.45);    /* escurece a imagem */
  transition: background .25s ease;
}
.card--bg:hover::before{ background: rgba(0,0,0,.15); } /* hover clareia */

/* link cobrindo todo o card */
.card__link{ position:absolute; inset:0; z-index:3; }

/* badge no topo-esquerda */
.card .badge-status{
  position:absolute; left:12px; top:12px; z-index:4;
  padding:6px 10px; border-radius:999px;  font-weight:700; font-size:.78rem;
}

/* textos sobre a imagem */
.card__overlay{
  position:absolute; left:14px; right:14px; bottom:12px; z-index:4;
  color:#fff; text-shadow:0 2px 10px rgba(0,0,0,.6);
}
.card__title--white{ color:#fff; margin:0 0 2px; font-size:18px;     margin-bottom: 10px; }
.card__loc--white{ color:#eef3f9; margin:0; font-size:.72rem }
.card__loc--white i{ 
    font-size: .92rem !important;
    margin-right: 10px;
    margin-bottom: 5px !important;
    width: 20px;
    
}

/* Parallax de background (apenas o fundo mexe) */
.parallax {
  position: relative;
  overflow: hidden;           /* esconde a sobra do bg */
  isolation: isolate;         /* evita z-index estranhos */
}

/* o fundo mora no ::before e é quem se move */
.parallax::before {
  content: "";
  position: absolute;
  inset: -12%;               /* bg maior p/ não mostrar bordas ao mover */
  background-image: var(--bg, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: translate3d(0, var(--py, 0px), 0);
  will-change: transform;
  z-index: -1;
}

/* acessibilidade: sem parallax se o usuário prefere menos movimento */
@media (prefers-reduced-motion: reduce) {
  .parallax::before { transform: none !important; }
}

.grid[data-aos="fade-up"] .item {
  opacity: 0;
  transform: translateY(40px);
  transition: all .6s ease;
}
.grid[data-aos="fade-up"].aos-animate .item {
  opacity: 1;
  transform: none;
}
.grid[data-aos="fade-up"].aos-animate .item:nth-child(1){ transition-delay: .1s; }
.grid[data-aos="fade-up"].aos-animate .item:nth-child(2){ transition-delay: .25s; }
.grid[data-aos="fade-up"].aos-animate .item:nth-child(3){ transition-delay: .4s; }
.grid[data-aos="fade-up"].aos-animate .item:nth-child(4){ transition-delay: .55s; }


/* ========== CARROSSEL DE PLANTAS E GALERIA ========== */

@media (max-width: 980px){
  .slide-card img{ height: 180px; }
}
/* mesmo visual nas duas */
.swiper-scrollbar{display:none;}
.emp-plantas h2, .emp-galeria h2 { margin-bottom: 10px; }

.plantas-swiper, .galeria-swiper { position: relative; --gap: 18px; }

/* cada slide ocupa uma “coluna” fixa; o Swiper cuida do restante */
.plantas-swiper .swiper-slide,
.galeria-swiper .swiper-slide { height: auto; }

.slide-card{
  position: relative; overflow: hidden;
  border-radius: 16px; background:#fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  cursor: zoom-in; transition: transform .3s ease, box-shadow .3s ease;
}

/* wrappers de card (plantas e galeria) */
.thumb-card, .slide-card{
  position:relative; overflow:hidden; border-radius:16px;
  background:#fff; box-shadow:0 10px 24px rgba(0,0,0,.06); cursor:zoom-in;
}

/* fade da imagem dentro do modal */
.lightbox-img{
  opacity: 0;
  transition: opacity .28s ease;   /* ajuste o tempo se quiser */
}
.lightbox-img.is-visible{
  opacity: 1;
}


/* imagem das thumbs (força proporção e recorte igual) */
.thumb-card > .slide-img,
.slide-card > .slide-img{
  display:block;
  width:100%;
  height:auto;                 /* reseta atributos HTML height/width */
  aspect-ratio: 16 / 9;        /* proporção padronizada */
  object-fit: cover;           /* recorta sem distorcer */
  object-position: center;
  transition: transform .3s ease;
}
.thumb-card:hover > .slide-img,
.slide-card:hover > .slide-img{ transform: scale(1.03); }

@media (max-width:980px){
  .thumb-card > .slide-img,
  .slide-card > .slide-img{ aspect-ratio: 4 / 3; } /* opcional no mobile */
}
/* (opção alternativa: em vez de height fixa, use proporção)
.slide-card img{ aspect-ratio: 16 / 9; width:100%; height:auto; object-fit:cover; }
*/

.slide-card:hover img{ transform: scale(1.03); }

/* botões sobre o swiper (garante que aparecem) */
.galeria-swiper .swiper-button-prev,
.galeria-swiper .swiper-button-next,
.plantas-swiper .swiper-button-prev,
.plantas-swiper .swiper-button-next{
  width:46px;height:46px;border-radius:50%;
  background:rgba(15,28,42,.6);color:#fff;transition:.3s;
  z-index: 5;
}
.galeria-swiper .swiper-button-prev:hover,
.galeria-swiper .swiper-button-next:hover,
.plantas-swiper .swiper-button-prev:hover,
.plantas-swiper .swiper-button-next:hover{ background:rgba(15,28,42,.9); }
.galeria-swiper .swiper-button-prev:after,
.galeria-swiper .swiper-button-next:after,
.plantas-swiper .swiper-button-prev:after,
.plantas-swiper .swiper-button-next:after{ font-size:18px; }

@media (max-width: 980px){
  .slide-card img{ height: 180px; }
}
/* --- Correção visual para as PLANTAS --- */

/* remove o fundo duplo e suaviza a sombra */
.emp-plantas .slide-card {
  background: transparent;
  box-shadow: 0 6px 16px rgba(0,0,0,.04);
}

/* imagem sem excesso de contraste */
.emp-plantas .slide-img {
  background: #fff;
  border-radius: 12px;
  aspect-ratio: 4 / 3;      /* plantas tendem a ser mais retangulares */
  object-fit: contain;      /* mostra o desenho completo, sem corte */
  object-position: center;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
  transition: transform .3s ease, box-shadow .3s ease;
}

/* hover sutil */
.emp-plantas .slide-card:hover .slide-img {
  transform: scale(1.02);
  box-shadow: 0 4px 16px rgba(0,0,0,.08);
}

/* ========== MODAL (LIGHTBOX) ========== */
.lightbox-modal {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.9);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  opacity: 0; visibility: hidden;
  transition: opacity .3s ease;
}
.lightbox-modal.active { opacity: 1; visibility: visible; }

.lightbox-content {
  position: relative;
  max-width: 90%;
  max-height: 90%;
}
.lightbox-content img {
  display: block;
      max-height: 75vh;
  width: 100%; height: auto;
  border-radius: 8px;
  box-shadow: 0 10px 40px rgba(0,0,0,.5);
}

.lightbox-close,
.lightbox-prev,
.lightbox-next {
  position: absolute; top: 50%;
  transform: translateY(-50%);
  color: #fff; background: rgba(0,0,0,.5);
  border: none; font-size: 24px; cursor: pointer;
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.lightbox-close { top: 24px; right: 24px; transform:none; font-size:28px; }
.lightbox-prev { left: -60px; }
.lightbox-next { right: -60px; }
.lightbox-prev:hover, .lightbox-next:hover, .lightbox-close:hover {
  background: rgba(255,255,255,.2);
}
@media (max-width:800px){
  .lightbox-prev { left: 8px; }
  .lightbox-next { right: 8px; }
}

/* bloco principal */
.site-footer{ background:var(--footer-bg); color:var(--footer-ink); }
.site-footer .container{ max-width:1200px; margin:0 auto; padding:48px 24px; }

.footer-top{
  display:grid;
  grid-template-columns: 1.2fr .9fr .6fr;
  gap:48px;
  align-items:start;
}

/* brand + texto */
.footer-brand .custom-logo{ max-height:48px; width:auto; margin-bottom:18px; }
.footer-brand .brand-fallback{
  display:inline-block; background:#fff; color:#0f1c2a; font-weight:800;
  padding:6px 14px; border-radius:999px; letter-spacing:.5px;
}
.footer-desc{

  color:var(--footer-muted); margin:14px 0 0;
}

/* navegação */
.footer-nav h3,
.footer-social h3{ font:600 1.6rem/1.2 "Noto Sans",sans-serif; margin:0 0 18px; }

.menu-footer,
.menu-footer ul{ list-style:none; margin:0; padding:0; }
.menu-footer li{ margin:10px 0; }
.menu-footer a{
  color:var(--footer-ink);
  text-decoration:none;
  display:inline-flex; align-items:center; gap:10px;
  transition:opacity .2s ease, transform .2s ease;
}
.menu-footer a::before{
  content:""; 
      width: 9px;
    height: 9px;
    flex: 0 0 9px;
  border-right:2px solid var(--footer-ink);
  border-bottom:2px solid var(--footer-ink);
  transform:rotate(-45deg); opacity:.4;
  border-radius: 3px;
}
@media (hover:hover){
  .menu-footer a:hover{ opacity:.85; transform:translateX(2px); }
}

/* social */
.social-list{ list-style:none; display:flex; gap:14px; margin:6px 0 0; padding:0; }
.social-btn{
  --size:42px;
  width:var(--size); height:var(--size);
  display:grid; place-items:center;
  border-radius:999px;
  color:var(--footer-ink,#fff);
  border:1.5px solid rgba(255,255,255,.35);
  background: transparent;
  transition: transform .15s ease, border-color .2s ease, background .2s ease, color .2s ease;
  outline: none;
}
.social-btn i{ font-size:18px; line-height:1; }

/* hover/focus */
@media (hover:hover){
  .social-btn:hover{
    background: var(--footer-ink,#fff);
    color: var(--footer-bg,#0f1c2a);
    transform: translateY(-2px);
    border-color: transparent;
  }
}
.social-btn:focus-visible{
  box-shadow: 0 0 0 3px rgba(255,255,255,.35);
}

/* opção de cor da marca (se quiser) */
/*
.social-btn[href*="instagram"] { border-color:#d62976 }
.social-btn[href*="facebook"]  { border-color:#1877f2 }
.social-btn[href*="linkedin"]  { border-color:#0a66c2 }
.social-btn[href*="youtube"]   { border-color:#ff0000 }
*/


/* subfooter */
.site-subfooter{ border-top:1px solid var(--footer-sep); }
.site-subfooter .subgrid{
  display:grid; grid-template-columns: 1fr auto; gap:24px;
  padding:18px 24px 28px;
}
.site-subfooter .copy{ margin:0; color:var(--footer-muted); font-size:.95rem; }
.site-subfooter .address{ margin:0; color:var(--footer-muted); font-size:.95rem; }

/* responsivo */
@media (max-width: 980px){
  .footer-top{ grid-template-columns: 1fr; gap:28px; }
  .menu{ display: none;} .btn-whats{ display: none;} .some{ display: none;}
  .site-subfooter .subgrid{ grid-template-columns: 1fr; text-align:left; }
  .logo img {    width: 100px;}
  .nav {    padding: 4px 24px !important; }
}
/* ============================= */
/* MENU MOBILE - v2 refinado     */
/* ============================= */
.menu-mobile {
  display: none;
}

.menu-toggle {
    border: none;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    z-index: 1001;
    padding: 15px 5px;
    padding-top: 1px;
    background: none !important;
}

.menu-toggle span {
  display: block;
    margin-top: 5px;
    height: 2px;
    width: 30px;
    background: #ffffff;
    border-radius: 2px;
  transition: all .3s ease;
}

.menu-toggle.active span:nth-child(1) {
  transform: rotate(45deg) translate(6px, 6px); margin-top: 5px;    background: #245e9f;
}
.menu-toggle.active span:nth-child(2) {
  opacity: 0;
}
.menu-toggle.active span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);margin-top: 8px;    background: #245e9f;
}

.menu-drawer {
  position: fixed;
  top: 0;
  right: -100%;
  width: 80%;
  height: 100vh;
  background: #eff2f6;
  box-shadow: -2px 0 20px rgba(0,0,0,.1);
  padding: 100px 21px 30px;
  transition: right .35s ease;
  z-index: 1000;
  overflow-y: auto;
}
.btn-whats-m {
    margin-left: auto;
    background: #3b537d;
    color: #fff;
    text-decoration: none;
    padding: 10px 16px;
    border-radius: 999px;
    position: absolute;
    bottom: 20px;
      font-weight: 300;
    transition: .3s;
    font-size: 1rem;
}
.btn-whats-b {
    position: fixed;
    color: white;
    font-size: 2rem;
    bottom: 20px;
    right: 20px;
    background: #0cb133;
    padding: 2px 14px;
    border-radius: 222px;
    box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
}
.btn-whats-m i{ font-size: 1.3rem; margin-right: 10px;}
.menu-drawer.open {
  right: 0;
}

.menu-mobile-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.menu-mobile-list li {
    margin-bottom: 15px;
    background: white;
    padding: 9px 16px;
    border-radius: 27px;
}

.menu-mobile-list a {
  color: var(--ink);
    font-size: 1rem;
    font-weight: 200;
  text-decoration: none;
  transition: color .25s ease;
}

.menu-mobile-list a:hover {
  color: var(--primary);
}

/* Overlay */
.menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,.3);
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease;
  z-index: 55;
}
.menu-overlay.visible {
  opacity: 1;
  visibility: visible;
}

@media (max-width: 980px) {
  .menu-mobile { 
      top: 20px;
      display: flex;
        position: fixed;
        align-items: center;
        right: 14px;
        z-index:60;
  }
  .site-nav, .menu-desktop { display: none !important; }
  .container {
    padding: 14px;
  }
  body{
      font-size: 13px;
  }
  .site-header {    padding: 9px;}
  .b_contato{min-height: 50px;text-decoration: none;}
  .i_contato, .ii_contato{margin: 6px;  margin-left: 0px;}
  .contato{   background: #e9f0ff; }
  .contato .container{padding-right: 0;}
  .contato .cols > div:first-child {   padding: 1px;}
  .row {  grid-template-columns: 1fr;gap: 0;}
  input, textarea {   margin: 11px 0px;width:calc( 100% - 14px );}
  .contato button {
    margin: 19px 0; width:calc( 100% - 14px );
}
  
  
}

@media (max-width: 768px){
  [data-aos="fade-left"],
  [data-aos="fade-right"] {
    transform: none !important;
    opacity: 1 !important;
  }
}

