/* ====== Design Tokens (Albino) ====== */
:root {
  --brand: #0B2A36;          /* azul principal */
  --brand-dark: #09212C;     /* azul profundo */
  --accent: #E7436A;         /* rosa do ícone */
  --accent-2: #FF6A7A;       /* gradiente/acento 2 */
  --text: #0E1A20;           /* texto escuro */
  --text-light: #FFFFFF;
  --muted: #6A7982;
  --bg: #F6F8FA;

  --radius: 14px;
  --shadow: 0 10px 30px rgba(0, 0, 0, .10);
  --max: 1200px;
}

/* ====== Base ====== */
* { box-sizing: border-box }
html, body { height: 100% }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block }
a { color: inherit; text-decoration: none }
.container { width: min(var(--max), 92%); margin-inline: auto }
.skip { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden }



/* ====== Header ====== */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, .65);
  backdrop-filter: saturate(160%) blur(8px);
  border-bottom: 1px solid rgba(0, 0, 0, .06);
}
.nav { display: flex; align-items: center; justify-content: space-between; padding: .7rem 0 }
.brand img {
  display: block;
  max-height: 60px;
  width: auto;
}
.menu { display: flex; align-items: center; gap: 1rem }
.menu a { padding: .5rem .6rem; border-radius: 8px }
.menu a:hover { background: rgba(0, 0, 0, .05) }
.hamb {
  display: none; gap: 5px; width: 42px; height: 42px; border-radius: 10px;
  background: var(--brand-dark); align-items: center; justify-content: center; border: 0
}
.hamb span { width: 20px; height: 2px; background: #fff; display: block }
@media (max-width: 900px) {
  .hamb { display: flex }
  .menu { display: none }
  .menu.open {
    display: flex; position: absolute; left: 0; right: 0; top: 60px; padding: 1rem;
    background: #fff; border-bottom: 1px solid rgba(0, 0, 0, .08); flex-direction: column; gap: .6rem
  }
}

/* ====== Buttons ====== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .6rem;
  padding: .9rem 1.2rem; border-radius: 10px; font-weight: 700; border: 1px solid transparent;
  transition: transform .12s ease, background .2s ease, border .2s ease, color .2s ease; cursor: pointer
}
.btn:focus-visible,
.menu a:focus-visible { outline: 3px solid rgba(231,67,106,.4); outline-offset: 2px; }
.btn-primary { background: var(--brand); color: var(--text-light) }
.btn-primary:hover { background: #083043 }                /* padrão */
.menu .btn-primary:hover {                                 /* cabeçalho vira rosa */
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  border-color: transparent;
}
.btn-outline { background: transparent; color: var(--text-light); border-color: rgba(255, 255, 255, .6) }
.btn-outline:hover {                                       /* agendar visita vira azul */
  border-color: var(--brand);
  background: var(--brand);
  color: #fff;
}


.btn-accent {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
}
.btn-accent:hover { filter: brightness(1.06) }
.cta-row { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center }

/* ====== Hero ====== */
.hero {
  color: #fff;
  background:
    linear-gradient(180deg, rgba(9, 33, 44, .55), rgba(9, 33, 44, .35)),
    url("hero-monte-cativo.webp") center/cover no-repeat;
}
.hero-wrap {
  display: grid; gap: 2rem; grid-template-columns: 1.05fr .95fr;
  padding: clamp(3rem, 7vw, 6rem) 0;
}
@media (max-width: 900px) { .hero-wrap { grid-template-columns: 1fr } }
.eyebrow { text-transform: uppercase; color: #B7C6CE; letter-spacing: .08em; font-weight: 600; font-size: .86rem }
.hero-title { font: 700 clamp(2.1rem, 4.6vw, 3.2rem)/1.06 Poppins, Inter, sans-serif; margin: .25rem 0 1rem }
.hero-subtitle { color: #E6EDF2; max-width: 46ch; margin: 0 0 1rem }
.hero-bullets { display: flex; flex-wrap: wrap; gap: .6rem; list-style: none; padding: 0; margin: 1rem 0 0 }
.hero-bullets li {
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .22);
  padding: .45rem .6rem; border-radius: 999px; font-weight: 600; font-size: .85rem
}
.hero-media { position: relative }
.hero-media img { max-width: 100%; border-radius: var(--radius) }
.badge {
  position: absolute; bottom: 12px; left: 12px;
  background: rgba(11, 42, 54, .9); border: 1px solid rgba(255, 255, 255, .18);
  padding: .4rem .6rem; border-radius: 999px; font-weight: 700; font-size: .82rem
}

/* ====== Features ====== */
.features { padding: clamp(2.6rem, 6vw, 4rem) 0; background: #fff }
.section-title { font: 700 clamp(1.4rem, 2.8vw, 2rem)/1.1 Poppins, Inter, sans-serif; color: var(--brand) }
.section-subtitle { color: var(--muted); margin: .3rem 0 1.8rem }
.features-grid { display: grid; gap: 1rem; grid-template-columns: repeat(3, 1fr) }
@media (max-width: 900px) { .features-grid { grid-template-columns: 1fr } }
.feature {
  background: #F9FBFC; border: 1px solid rgba(0, 0, 0, .06); border-radius: var(--radius); padding: 1.2rem; box-shadow: var(--shadow);
}
.feature img { width: 42px; height: auto; margin-bottom: .6rem }
.feature h3 { margin: .2rem 0 .4rem; color: var(--brand) }
.feature p { color: #3f4a51 }

/* ====== Form ====== */
.form-anchor { padding: clamp(2.6rem, 6vw, 4rem) 0 }
.form-card {
  background: #fff; border: 1px solid rgba(0, 0, 0, .08); border-radius: var(--radius); padding: 1.2rem; box-shadow: var(--shadow)
}
.grid { display: grid; gap: .8rem; grid-template-columns: 1fr 1fr }
@media (max-width: 900px) { .grid { grid-template-columns: 1fr } }
.field { display: grid; gap: .35rem }
.field span { font-weight: 600; color: #1a2a31 }
input, select {
  width: 100%; padding: .9rem 1rem; border-radius: 12px; border: 1px solid #d5dfe6; background: #fff; color: #14242c;
}
input:focus, select:focus { outline: 2px solid var(--brand); border-color: transparent }
.form-error { color: #b00020; font-weight: 600; margin-top: .3rem }
.form-help { color: #5b6a73; font-size: .9rem; margin-top: .6rem }

/* ====== Footer ====== */
.site-footer { background: #fff; border-top: 1px solid rgba(0, 0, 0, .08); color: #51626b; padding: 1.2rem 0 }
.foot-grid { display: flex; align-items: center; justify-content: space-between; gap: 1rem }
@media (max-width: 700px) { .foot-grid { flex-direction: column; text-align: center } }

/* ====== Animate on scroll ====== */
[data-animate] { opacity: 0; transform: translateY(8px); transition: opacity .6s ease, transform .6s ease }
[data-animate].in { opacity: 1; transform: none }

/* ====== Ajustes seção Destaques ====== */
.features {
  padding: clamp(2.6rem, 6vw, 4rem) 0;
  background: #fff;
  text-align: center; /* Centraliza título, subtítulo e botão */
}

.section-title {
  font: 700 clamp(1.4rem, 2.8vw, 2rem)/1.1 Poppins, Inter, sans-serif;
  color: var(--brand);
  margin-bottom: .4rem;
}

.section-subtitle {
  color: var(--muted);
  margin: 0 auto 1.8rem auto;
  max-width: 600px;
}

.features-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
  justify-items: center; /* Centraliza conteúdo nos cards */
}

@media (max-width: 900px) {
  .features-grid {
    grid-template-columns: 1fr;
  }
}

.feature {
  background: #F9FBFC;
  border: 1px solid rgba(0, 0, 0, .06);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow);
  text-align: center; /* Centraliza conteúdo do card */
}

.feature img {
  width: 42px;
  height: auto;
  margin: 0 auto 0.8rem auto; /* Centraliza ícone */
}

.feature h3 {
  margin: .2rem 0 .4rem;
  color: var(--brand);
}

.feature p {
  color: #3f4a51;
}

/* Botão centralizado */
.features-cta {
  margin-top: 2rem;
  display: flex;
  justify-content: center;
}

/* ====== Hover Premium nos Destaques ====== */
.feature {
  background: #F9FBFC;
  border: 1px solid rgba(0, 0, 0, .06);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow);
  text-align: center;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.feature img {
  width: 42px;
  height: auto;
  margin: 0 auto 0.8rem auto;
  transition: transform 0.25s ease;
}

.feature:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, .15);
  background: #ffffff;
}

.feature:hover img {
  transform: scale(1.08);
}

/* Botão fantasma (para fundo claro) */
.btn-ghost{
  background: transparent;
  color: var(--brand);
  border: 1.5px solid var(--brand);
}
.btn-ghost:hover{ background: var(--brand); color:#fff }

/* Layout do CTA duplo centralizado */
.features-cta{
  margin-top: 2rem;
  display: flex; justify-content: center; gap: .8rem; flex-wrap: wrap;
}

/* Modal de PDF */
.modal{
  position: fixed; inset: 0; display: none;
  background: rgba(0,0,0,.7); z-index: 1000;
}
.modal.open{ display: grid; place-items: center }
.modal-dialog{
  width: min(1000px, 92vw); height: min(80vh, 92vh);
  background: #fff; border-radius: 14px; overflow: hidden; position: relative;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
}
.modal-title{
  position:absolute; left:16px; top:10px; margin:0; font-weight:700; color:#0B2A36; z-index:1;
}
.modal-close{
  position:absolute; right:12px; top:8px; z-index:2;
  width:36px; height:36px; border-radius:10px; border:0; cursor:pointer;
  background:#0B2A36; color:#fff; font-size:22px; line-height:36px;
}
#pdfFrame{ width:100%; height:100%; border:0 }

/* ====== Unidades Disponíveis ====== */
.unidades{ padding: clamp(2.6rem,6vw,4rem) 0; background:#fff; text-align:center }
.unidades-grid{
  display:grid; gap:1.2rem;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1100px){ .unidades-grid{ grid-template-columns: repeat(2,1fr) } }
@media (max-width: 700px){ .unidades-grid{ grid-template-columns: 1fr } }

.unit-card{
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:20px; box-shadow: var(--shadow); overflow:hidden;
  transition: transform .2s ease, box-shadow .2s ease;
  text-align:left;
}
.unit-card:hover{ transform: translateY(-4px); box-shadow: 0 16px 32px rgba(0,0,0,.12) }

.unit-media{ display:block; position:relative; overflow:hidden }
.unit-media img{ width:100%; height:auto; display:block; aspect-ratio: 4/3; object-fit: cover }
.unit-media::after{ /* leve overlay para ler setas brancas se usar */
  content:''; position:absolute; inset:0; background: linear-gradient(to top, rgba(0,0,0,.08), rgba(0,0,0,0));
  pointer-events:none;
}

.unit-body{ padding:1rem 1rem 1.2rem 1rem }
.unit-title{ font:700 1.4rem/1.2 Poppins, Inter, sans-serif; color:var(--brand); margin:.2rem 0 .6rem }
.unit-type{
  font:700 .85rem/1 Poppins, Inter, sans-serif; color:#fff; background:var(--brand);
  padding:.25rem .5rem; border-radius:8px; margin-left:.35rem
}

.unit-meta{ list-style:none; display:flex; gap:1rem; align-items:center; margin:0; padding:0; color:#32444d }
.unit-meta li{ display:inline-flex; gap:.35rem; align-items:center; font-weight:700 }
.unit-meta svg{ opacity:.85 }

/* ====== Modal Galeria ====== */
.modal.gallery{
  position: fixed; inset:0; display:none; z-index:1000;
  background: rgba(0,0,0,.88);
}
.modal.gallery.open{ display:flex; align-items:center; justify-content:center; gap:.6rem }
.modal.gallery img{
  max-width: min(1200px, 92vw); max-height: 85vh; border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,.45)
}
.gallery-close{
  position:absolute; top:14px; right:16px; width:40px; height:40px;
  border:0; border-radius:10px; background:#0B2A36; color:#fff; font-size:24px; cursor:pointer
}
.gallery-nav{
  position:absolute; top:50%; transform: translateY(-50%);
  border:0; background: rgba(255,255,255,.15); color:#fff; font-size:28px;
  width:48px; height:48px; border-radius:999px; cursor:pointer
}
.gallery-nav.prev{ left:20px }
.gallery-nav.next{ right:20px }
.gallery-nav:hover{ background: rgba(255,255,255,.28) }

/* Botão WhatsApp */
.btn-whatsapp{
  background:#25D366;        /* cor oficial do WhatsApp */
  color:#fff;
  border:1px solid transparent;
}
.btn-whatsapp:hover{
  filter:brightness(0.95);
  transform:translateY(-1px);
}

/* ====== Localização ====== */
.localizacao{
  padding: clamp(2.6rem, 6vw, 4rem) 0;
  background:#f9f9f9;
}

.localizacao-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:2rem;
  align-items:center;
}

.localizacao-mapa img{
  width:100%;
  height:auto;
  display:block;
  border-radius:16px;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}

.localizacao-info{
  text-align:left;
}

.localizacao-info p{
  margin-bottom:1rem;
  color:#3f4a51;
  font-size:1.05rem;
  line-height:1.6;
}


.localizacao-info .btn {
  display: block;
  margin: 1.5rem auto 0; /* Centraliza só o botão */
  width: fit-content; /* Faz o botão ocupar apenas o tamanho do texto */
}

@media (max-width:900px){
  .localizacao-grid{
    grid-template-columns: 1fr;
  }
  .localizacao-info{
    text-align:center;
  }
}

/* ====== Formulário — versão premium ajustada ====== */
.formulario--premium {
  position: relative;
  padding: clamp(2.6rem, 6vw, 4rem) 0;
  background: linear-gradient(180deg, var(--brand) 0%, var(--brand-dark) 100%);
  color: #fff;
}

/* Removidas as linhas rosas e efeitos extras */
.formulario--premium::before,
.formulario--premium::after {
  content: none;
}

.formulario--premium .section-title {
  color: #fff;
  margin-bottom: 0.4rem;
  text-align: center;
}

.formulario--premium .section-subtitle {
  color: #E6EDF2;
  text-align: center;
  margin-bottom: 1.5rem;
}

.formulario--premium .form-card {
  background: #fff;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: var(--radius);
  padding: 1.2rem;
  box-shadow: 0 16px 40px rgba(0, 0, 0, .22);
  color: #14242c;
}

.formulario--premium .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.formulario--premium .field {
  display: flex;
  flex-direction: column;
}

.formulario--premium .consent {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  margin: 1rem 0;
}

.formulario--premium .consent input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
}

.formulario--premium .cta-row {
  text-align: center;
}

.formulario--premium .btn {
  background-color: var(--accent);
  color: #fff;
  border: none;
  padding: 0.8rem 1.6rem;
  font-size: 1rem;
  border-radius: var(--radius);
  cursor: pointer;
}

.formulario--premium .btn:hover {
  opacity: 0.9;
}

.honeypot {
    display: none !important;
}


/* ===== Base ===== */
*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
.container{ width:min(var(--max), 92%); margin-inline:auto }

/* ===== Header ===== */
.site-header{
  position: sticky; top:0; z-index:10;
  background: rgba(255,255,255,.7);
  backdrop-filter: saturate(160%) blur(8px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.nav{ display:flex; align-items:center; justify-content:space-between; padding:.7rem 0 }
.brand img{ max-height:60px; width:auto; display:block }

/* ===== Thank you card ===== */
.thankyou{
  display:grid; place-items:center;
  padding: clamp(3rem, 6vw, 5rem) 0;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(231,67,106,.08), transparent 55%),
    radial-gradient(900px 600px at 110% 0%, rgba(11,42,54,.10), transparent 55%);
}
.card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(1.2rem, 3.2vw, 2rem);
  text-align:center;
}
.icon-wrap{ display:flex; justify-content:center; margin-bottom:.6rem }
.title{
  font: 700 clamp(1.4rem, 2.8vw, 2rem)/1.1 Poppins, Inter, sans-serif;
  color: var(--brand);
  margin:.2rem 0 .4rem;
}
.lead{
  color:#3f4a51;
  font-size:1.05rem;
  line-height:1.6;
  margin:0 auto 1rem;
  max-width: 60ch;
}
.next-steps{ margin:1.2rem auto 1.4rem; text-align:left; max-width: 720px }
.next-steps h2{
  font: 700 1.05rem/1.2 Poppins, Inter, sans-serif;
  color: var(--brand);
  margin:0 0 .4rem;
}
.next-steps ul{
  margin:0; padding-left:1.1rem; color:#3f4a51; line-height:1.7;
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.9rem 1.2rem; border-radius:12px; font-weight:700;
  cursor:pointer;
  transition: transform .12s ease, background .2s ease, border .2s ease, color .2s ease;
}
.btn-primary{ background:var(--brand); color:#fff }
.btn-primary:hover{ background:#083043 }
.btn-ghost{ background:transparent; color:var(--brand); border-color:var(--brand) }
.btn-ghost:hover{ background:var(--brand); color:#fff }
.cta-row{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; margin-top:.4rem }

/* ===== Footer ===== */
.site-footer{ background:#fff; border-top:1px solid rgba(0,0,0,.08); color:#51626b; padding:1.2rem 0 }
.foot-grid{ display:flex; align-items:center; justify-content:space-between; gap:1rem }
@media (max-width: 700px){ .foot-grid{ flex-direction:column; text-align:center } }

/* ===== Animate on scroll ===== */
[data-animate]{ opacity:0; transform: translateY(8px); transition: opacity .6s ease, transform .6s ease }
[data-animate].in{ opacity:1; transform:none }

/* Botão WhatsApp flutuante */
.whatsapp-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999;
  background-color: #25D366;
  border-radius: 50%;
  padding: 12px;
  box-shadow: 0 4px 8px rgba(0,0,0,.2);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.whatsapp-float img {
  width: 40px;
  height: 40px;
  display: block;
}

.whatsapp-float:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 14px rgba(0,0,0,.3);
}

/* ===== Fix alinhamento de CTAs (sobrepõe o utilitário global .cta-row) ===== */
.hero .cta-row{
  justify-content: flex-start;     /* botões do HERO alinhados à esquerda */
}

.formulario .cta-row,
.formulario--premium .cta-row{
  justify-content: flex-start;     /* botão do formulário alinhado à esquerda */
}

/* Marca d'água automática para todas as imagens da galeria */
.galeria img {
  position: relative;
  z-index: 1;
}

/* Marca d'água nas capas das frações (cards) */
.unit-media{
  position: relative;
  display: block;
  overflow: hidden;
}

.unit-media::after{
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: clamp(120px, 18vw, 220px);
  height: clamp(120px, 18vw, 220px);
  transform: translate(-50%, -50%);   /* sem rotação */
  background: url('logo-equipa-azul.webp') center/contain no-repeat;
  opacity: .20;
  pointer-events: none;
  z-index: 2;
}

/* pequenos reforços anti‑download */
.unit-media img{
  -webkit-user-drag: none;
  user-select: none;
}

/* Marca d’água na galeria (modal aberta) */
.modal.gallery.open::after{
  content: "";
  position: fixed;
  top: 50%;
  left: 50%;
  width: clamp(140px, 22vw, 260px);
  height: clamp(140px, 22vw, 260px);
  transform: translate(-50%, -50%);
  background: url('logo-equipa-azul.webp') center/contain no-repeat;
  opacity: .18;
  pointer-events: none;
  z-index: 3;               /* fica acima da imagem */
}
/* garante que botões ficam por cima do overlay, se quiser */
.modal.gallery .gallery-close,
.modal.gallery .gallery-nav { z-index: 4; }

/* Pequeno respiro após o subtítulo quando não há bolachas */
.hero .cta-row { margin-top: .6rem; }

.hero-center {
  min-height: clamp(420px, 78vh, 720px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  text-align: center;
  padding: clamp(3rem, 7vw, 6rem) 0;
}

.hero .hero-logo {
  max-width: clamp(220px, 28vw, 380px);
  height: auto;
  margin-bottom: 1.5rem;
}

.hero .cta-row {
  justify-content: center;
}

.unit-title {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.unit-type {
  font-size: 0.78rem;
  font-weight: 600;
  background: rgba(0, 0, 0, 0.8); /* Fundo escuro */
  color: #fff; /* Texto branco */
  padding: 2px 6px;
  border-radius: 4px;
}

/* Ajuste mobile para centralizar melhor os botões na hero */
@media (max-width: 768px) {
  .hero-content {
    transform: translateY(-40px); /* Sobe todo o bloco (logo + botões) */
  }

  .hero-buttons {
    margin-top: 10px; /* Menos espaço entre logo e botões */
  }

  .hero {
    min-height: 80vh; /* Mantém altura equilibrada */
  }
}

/* === Unidades: 4 colunas no desktop === */
.unidades-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 1.6rem;
}

/* Tablet: 2 colunas */
@media (max-width: 1024px){
  .unidades-grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

/* Mobile: 1 coluna */
@media (max-width: 640px){
  .unidades-grid{
    grid-template-columns: 1fr;
  }
}

/* Botão pequeno (inline junto ao ZMPT) */
.btn-xs{
  font-size:.75rem;
  padding:.25rem .55rem;
  line-height:1;
  border-radius: .5rem;
  margin-left:.35rem;
}

/* Modal de plantas - reutiliza sua base .modal; estilos complementares */
.modal--planta .modal-dialog{
  max-width: min(1080px, 92vw);
  background: #0b1c23;   /* fundo do dialog */
  padding: .75rem;
}

.modal--planta .modal-content{
  background: transparent;
  box-shadow: none;
}

.planta-wrap{
  position: relative;
  overflow: hidden;
  border-radius: .6rem;
  background:#000;
}

.planta-wrap img{
  width:100%;
  height:auto;
  max-height: 80vh;
  object-fit: contain;
  transition: transform .25s ease;
  cursor: zoom-in;
  transform-origin: center center;
}

/* estado “zoomed” (toggle via JS) */
.planta-wrap img.zoomed{
  transform: scale(1.6);
  cursor: zoom-out;
}

/* botão close no canto */
.modal--planta .modal-close{
  position:absolute;
  top:.75rem; right:.75rem;
  z-index:5;
}

/* Título e código */
.unit-title {
  font-size: 0.95rem; /* menor que o atual */
  font-weight: 600;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

/* Código ZMPT */
.unit-type {
  font-size: 0.70rem;  /* menor */
  font-weight: 500;
  background: rgba(0,0,0,0.1);
  color: #fff; /* texto branco */
  padding: 2px 5px;
  border-radius: 4px;
}

/* Botão Ver planta */
.btn-planta {
  font-size: 0.68rem;   /* menor */
  padding: 2px 6px;
  margin-left: auto;    /* empurra para direita */
  background: #124359;  /* azul petróleo */
  color: #fff !important;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.2s ease;
}

.btn-planta:hover {
  background: #097697; /* azul mais claro no hover */
}

/* Área de informações */
.unit-info {
  font-size: 0.78rem; /* menor */
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3px 12px;
  margin-top: 8px;
}

/* Botão Ver planta */
.btn-planta {
  display: block;
  font-size: 0.75rem;
  padding: 5px 10px;
  margin: 12px auto 0;   /* centralizado abaixo das infos */
  background: #124359;   /* azul petróleo */
  color: #fff !important;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.2s ease;
  text-align: center;
}

.btn-planta:hover {
  background: #097697; /* azul mais claro no hover */
}
/* Área de informações */
.unit-info {
  font-size: 0.2rem; /* menor */
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3px 12px;
  margin-top: 8px;
}

/* Botão Ver planta */
.btn-planta {
  display: block;
  font-size: 0.75rem;
  padding: 5px 10px;
  margin: 12px auto 0;   /* centralizado abaixo das infos */
  background: #124359;   /* azul petróleo */
  color: #fff !important;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.2s ease;
  text-align: center;
}

.btn-planta:hover {
  background: #097697; /* azul mais claro no hover */
}

.unit-info span {
  font-size: 0.72rem !important;
  line-height: 1.2;
}

/* Modal de planta */
.planta-modal {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,.8);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

.planta-modal img {
  max-width: 90%;
  max-height: 80%;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0,0,0,.6);
}

/* Botões de navegação */
.planta-prev, .planta-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  color: #fff;
  background: rgba(0,0,0,.5);
  border: none;
  padding: 10px 15px;
  cursor: pointer;
  border-radius: 50%;
}
.planta-prev { left: 20px; }
.planta-next { right: 20px; }

.hero-subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  color: #fff;
  margin: 1rem 0 2rem;
  text-align: center;
  line-height: 1.5;
  max-width: 700px;
}

.hero-logo {
  margin-bottom: 0.5rem; /* antes devia estar maior */
}

.hero-subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  color: #fff;
  margin: 0.5rem 0 1.5rem; /* reduzido em cima e em baixo */
  text-align: center;
  line-height: 1.4;
  max-width: 700px;
}

/* === Fix: espaço logo ↔ texto no HERO === */
.hero-center{
  gap: .2rem;                           /* diminui o espaçamento vertical do container */
}

.hero .hero-logo{
  margin-bottom: .2rem !important;      /* vence a regra anterior mais específica */
}

.hero-subtitle{
  margin: .3rem 0 1rem !important;      /* um pouco menos de respiro abaixo do logo */
}

/* Consultor */
.consultor {
  padding: 60px 20px;
  background: #f9f9f9;
}

.consultor-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 40px;
  text-align: center;
}

.consultor-foto img {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0px 6px 16px rgba(0,0,0,0.15);
}

.consultor-info {
  max-width: 500px;
}

.consultor-nome {
  font-size: 1.2rem;
  font-weight: 600;
  margin: 15px 0;
  color: #07152A; /* cor institucional */
}

.consultor-social {
  display: flex;
  gap: 15px;
  justify-content: center;
  margin: 15px 0 25px;
}

.consultor-social img {
  width: 32px;
  height: 32px;
  transition: transform 0.2s;
}

.consultor-social img:hover {
  transform: scale(1.15);
}
