/* ==========================================================================
   IMOBILIÁRIA BASE — Folha de estilo principal
   Mobile-first. Rebrandeável por cliente via CSS variables (:root).
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Design tokens / Variáveis de marca
   Troque estes valores para rebrandear o tema por cliente.
   -------------------------------------------------------------------------- */
:root {
  /* ---- Paleta preto + dourado ---- */
  --cor-fundo: #0E0E0E;           /* Preto (base) */
  --cor-fundo-alt: #1E1B16;       /* Seções alternadas (cinza-quente, mais separado da base) */
  --cor-card: #26231D;            /* Superfície de cartão (elevada, nitidamente mais clara) */
  --cor-texto: #F2EFE7;           /* Creme (corpo) */
  --cor-texto-suave: #ACA79D;     /* Creme dessaturado (secundário, AA no preto) */
  --cor-suave: rgba(242, 239, 231, 0.10);
  --cor-borda: #38342C;           /* Bordas sutis, mais visíveis */

  /* Acentos */
  --cor-acento: #C9A24B;          /* Dourado — acento/CTA/ações, nunca corpo */
  --cor-acento-escura: #A9863A;
  --cor-acento-clara: #E0C079;
  --cor-verde: #1F6F4F;           /* Verde — apenas toque mínimo em detalhes */
  --cor-primaria: var(--cor-acento);        /* Ação principal = dourado */
  --cor-primaria-escura: var(--cor-acento-escura);

  /* Aliases retrocompatíveis (regras existentes usam --cor-secundaria) */
  --cor-secundaria: var(--cor-acento);
  --cor-secundaria-escura: var(--cor-acento-escura);

  /* Apoio */
  --cor-whatsapp: #25d366;
  --cor-whatsapp-escura: #1da851;
  --cor-sucesso: #3B7A45;
  --cor-erro: #e06a62;

  /* Tipografia */
  --fonte-titulo: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --fonte-texto: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Espaçamento e formas */
  --raio: 14px;
  --raio-sm: 8px;
  --sombra: 0 10px 30px rgba(0, 0, 0, 0.38);
  --sombra-forte: 0 26px 64px rgba(0, 0, 0, 0.55);
  --container: 1220px;
  --gap: 1.75rem;
  --transicao: 0.25s cubic-bezier(.4, 0, .2, 1);
  --transicao-lenta: 0.6s cubic-bezier(.16, 1, .3, 1);

  /* Header */
  --header-h: 88px;
  --header-h-scrolled: 64px;

  /* ---- Profundidade / camadas (evita o "preto chapado") ---- */
  --cor-fundo-fim: #090908;                      /* base do gradiente vertical do body */
  --glow-dourado: rgba(201, 162, 75, 0.14);      /* brilho ambiente quente (mais presente) */
  --glow-verde: rgba(31, 111, 79, 0.07);         /* toque frio mínimo */
  --realce-topo: rgba(242, 239, 231, 0.09);      /* luz de 1px no topo das superfícies */
  --hairline: rgba(242, 239, 231, 0.10);         /* costura entre camadas */
  --linha-ouro: rgba(201, 162, 75, 0.22);        /* costura dourada de destaque */
  --grad-card: linear-gradient(180deg, #2D2922 0%, #211E18 100%);   /* superfície iluminada por cima */
  --grad-alt: linear-gradient(180deg, #221F19 0%, #151310 100%);    /* painel de seção alternada */
}

/* --------------------------------------------------------------------------
   2. Reset leve / base
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--fonte-texto);
  font-size: 16px;
  line-height: 1.7;
  color: var(--cor-texto);
  background:
    radial-gradient(125% 80% at 50% -8%, var(--glow-dourado), transparent 55%),
    radial-gradient(85% 65% at 100% 102%, var(--glow-verde), transparent 60%),
    linear-gradient(180deg, var(--cor-fundo) 0%, var(--cor-fundo-fim) 100%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Grão sutil sobre tudo — quebra o banding e o "pretão liso", sem custo de markup */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0.05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1, h2, h3, h4 {
  font-family: var(--fonte-titulo);
  line-height: 1.12;
  color: var(--cor-texto);
  margin: 0 0 0.5em;
  font-weight: 700;
  letter-spacing: -0.01em;
}

h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
h2 { font-size: clamp(1.9rem, 4vw, 2.9rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.6rem); }

/* Texto de olho/eyebrow acima dos títulos de seção */
.eyebrow {
  font-family: var(--fonte-texto);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cor-acento);
  display: inline-block;
  margin-bottom: 0.75rem;
}

p { margin: 0 0 1rem; }

a { color: var(--cor-acento-clara); text-decoration: none; transition: color var(--transicao); }
a:hover { color: var(--cor-texto); }

img { max-width: 100%; height: auto; display: block; }

ul { margin: 0 0 1rem; padding-left: 1.2rem; }

/* --------------------------------------------------------------------------
   3. Layout / utilitários
   -------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 1.25rem;
}

.secao { padding: clamp(2.5rem, 6vw, 5rem) 0; }

/* Seção alternada = painel elevado com gradiente, costuras e brilho ambiente */
/* Seção alternada = leve variação de tom que ESVAECE nas bordas (sem blocos
   nem costuras), pra uma seção fluir suavemente na outra. */
.secao--alt {
  position: relative;
  background: transparent;
}
.secao--alt::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    linear-gradient(180deg, transparent 0%, rgba(242, 239, 231, 0.028) 24%, rgba(242, 239, 231, 0.028) 76%, transparent 100%),
    radial-gradient(90% 80% at 12% 50%, rgba(201, 162, 75, 0.06), transparent 62%);
}
.secao--alt > .container { position: relative; z-index: 1; }

/* Superfícies elevadas: gradiente sutil + luz de 1px no topo (lit-from-above) */
.card,
.dif-card,
.depo-card,
.prova-numeros,
.selec-card,
.planta,
.tour-card,
.investir-card,
.emp-form,
.emp-info__card,
.dif-check,
.lazer-card,
.insight-card,
.filtros {
  background-image: var(--grad-card);
  box-shadow: var(--sombra), inset 0 1px 0 var(--realce-topo);
}

.secao__cabecalho {
  max-width: 680px;
  margin: 0 auto 3rem;
  text-align: center;
}
.secao__titulo { text-align: center; margin-bottom: 0.4rem; }
.secao__subtitulo {
  text-align: center;
  color: var(--cor-texto-suave);
  max-width: 620px;
  margin: 0 auto;
  font-size: 1.05rem;
}
.secao__cta { text-align: center; margin-top: 3rem; }

.text-center { text-align: center; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* --------------------------------------------------------------------------
   Movimento — base do reveal on scroll + respeito a prefers-reduced-motion
   -------------------------------------------------------------------------- */
/* Só esconde quando há JS (classe .js no <html>); sem JS, tudo visível. */
.js [data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity var(--transicao-lenta), transform var(--transicao-lenta);
  will-change: opacity, transform;
}
.js [data-reveal].is-visible {
  opacity: 1;
  transform: none;
}
/* Atraso escalonado para filhos revelados em sequência. */
[data-reveal-delay="1"] { transition-delay: 0.08s; }
[data-reveal-delay="2"] { transition-delay: 0.16s; }
[data-reveal-delay="3"] { transition-delay: 0.24s; }
[data-reveal-delay="4"] { transition-delay: 0.32s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .hero__bg { transform: none !important; }
  .card:hover .card__media img { transform: none !important; }
  .card:hover { transform: none !important; }
}

/* --------------------------------------------------------------------------
   4. Botões
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  font-family: var(--fonte-titulo);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  padding: 0.95rem 1.6rem;
  border: 2px solid transparent;
  border-radius: var(--raio-sm);
  cursor: pointer;
  transition: all var(--transicao);
  text-align: center;
}

.btn:hover { transform: translateY(-2px); box-shadow: var(--sombra); }
.btn:active { transform: translateY(0); }
.btn:focus-visible { outline: 3px solid var(--cor-acento); outline-offset: 3px; }

.btn--primario { background: var(--cor-acento); color: #161514; }
.btn--primario:hover { background: var(--cor-acento-escura); color: #161514; }

/* CTA dourado — acento principal, com leve micro-scale no hover */
.btn--secundario { background: var(--cor-acento); color: #1c1c1c; box-shadow: 0 6px 18px rgba(201, 162, 75, 0.32); }
.btn--secundario:hover { background: var(--cor-acento-escura); color: #1c1c1c; transform: translateY(-2px) scale(1.02); box-shadow: 0 10px 26px rgba(201, 162, 75, 0.4); }

.btn--contorno { background: transparent; border-color: rgba(255,255,255,0.7); color: #fff; }
.btn--contorno:hover { background: #fff; color: #161514; }

.btn--whatsapp { background: var(--cor-whatsapp); color: #fff; }
.btn--whatsapp:hover { background: var(--cor-whatsapp-escura); color: #fff; }

.btn--bloco { width: 100%; }

/* --------------------------------------------------------------------------
   5. Cabeçalho / navegação
   -------------------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--cor-fundo);            /* sólido por padrão (páginas sem hero) */
  border-bottom: 1px solid var(--cor-borda);
  transition: background var(--transicao), border-color var(--transicao), box-shadow var(--transicao);
}
.site-header.is-scrolled {
  box-shadow: 0 6px 30px rgba(0, 0, 0, 0.4);
}

/* --- Header transparente sobre o hero (apenas front-page, no topo) --- */
.header--transparent {
  background: transparent;
  border-bottom-color: transparent;
}
.header--transparent .site-header__inner { position: relative; z-index: 1; }
/* Scrim: preto translúcido no topo desbotando p/ transparente — legibilidade
   do logo/links sobre qualquer foto do hero. */
.header--transparent::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; height: 150px;
  background: linear-gradient(180deg, rgba(0,0,0,0.62) 0%, rgba(0,0,0,0.28) 45%, transparent 100%);
  pointer-events: none; z-index: 0;
  opacity: 1; transition: opacity var(--transicao);
}
/* Ao rolar, vira sólido escuro (e o scrim some). */
.header--transparent.is-scrolled {
  background: var(--cor-fundo);
  border-bottom-color: var(--cor-borda);
  box-shadow: 0 6px 30px rgba(0, 0, 0, 0.4);
}
.header--transparent.is-scrolled::before { opacity: 0; }

/* Front-page: puxa o conteúdo (hero) para baixo do header transparente,
   de modo que a imagem do hero apareça atrás do header. */
.home .site-main { margin-top: calc(-1 * var(--header-h)); }
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: var(--header-h);
  transition: min-height var(--transicao);
}
.site-header.is-scrolled .site-header__inner {
  min-height: var(--header-h-scrolled);
}
.site-branding .site-title {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: clamp(1.35rem, 2.2vw, 1.6rem);
  color: var(--cor-texto);
  margin: 0;
  line-height: 1.05;
  letter-spacing: -0.01em;
}
.site-branding .site-description {
  font-size: 0.76rem;
  color: var(--cor-texto-suave);
  margin: 0;
  letter-spacing: 0.02em;
}
.site-branding a { color: inherit; transition: color var(--transicao); }
.site-header.is-scrolled .site-branding .site-title { font-size: 1.3rem; }

/* Navegação */
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-sm);
  cursor: pointer;
}
.nav-toggle span {
  display: block; height: 2px; width: 22px; margin-inline: auto;
  background: var(--cor-texto); transition: var(--transicao);
}

.main-nav { display: none; }
.main-nav.is-open { display: block; }
.main-nav ul {
  list-style: none; margin: 0; padding: 1rem 0 0;
  display: flex; flex-direction: column; gap: 0.25rem;
}
.main-nav a {
  display: block; padding: 0.6rem 0.25rem; font-weight: 500;
  color: var(--cor-texto); position: relative;
  transition: color var(--transicao);
}
.main-nav a:hover, .main-nav .current-menu-item > a { color: var(--cor-acento-clara); }

@media (max-width: 859px) {
  .main-nav.is-open {
    position: absolute; left: 0; right: 0; top: 100%;
    background: var(--cor-fundo-alt); border-bottom: 1px solid var(--cor-borda);
    padding: 0.5rem 1.25rem 1.25rem; box-shadow: var(--sombra);
  }
}

@media (min-width: 860px) {
  .nav-toggle { display: none; }
  .main-nav { display: block !important; }
  .main-nav ul { flex-direction: row; align-items: center; padding: 0; gap: 1.75rem; }
  .main-nav a { padding: 0.25rem 0; }
  /* Sublinhado dourado animado (desktop) */
  .main-nav a::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
    height: 2px; background: var(--cor-acento);
    transform: scaleX(0); transform-origin: left;
    transition: transform var(--transicao);
  }
  .main-nav a:hover::after,
  .main-nav .current-menu-item > a::after { transform: scaleX(1); }
}

/* --------------------------------------------------------------------------
   6. Hero (home)
   -------------------------------------------------------------------------- */
.hero {
  position: relative;
  color: #fff;
  overflow: hidden;
  min-height: clamp(560px, 88vh, 920px);
  display: flex;
  align-items: center;
  background: var(--cor-fundo);
}
/* Camada de imagem (alvo do parallax) — maior que o hero para ter folga. */
.hero__bg {
  position: absolute;
  inset: -10% 0 -10% 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
  will-change: transform;
}
/* Sem imagem: gradiente cinematográfico escuro com brilho âmbar. */
.hero:not(.hero--imagem) .hero__bg,
.hero:not(.hero--imagem)::before {
  content: "";
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(120% 90% at 80% 12%, rgba(201,162,75,0.16), transparent 55%),
    linear-gradient(160deg, rgba(201,162,75,0.05) 0%, transparent 40%),
    linear-gradient(160deg, #1B1A17 0%, #0E0E0E 60%, #080808 100%);
}
/* Overlay cinematográfico: escuro à esquerda (texto) desbotando à direita (imagem),
   com fusão suave para o fundo da página na base do hero. */
.hero__overlay {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(90deg,
      rgba(8,8,8,0.95) 0%,
      rgba(8,8,8,0.82) 30%,
      rgba(8,8,8,0.46) 58%,
      rgba(8,8,8,0.12) 82%,
      rgba(8,8,8,0) 100%),
    linear-gradient(180deg,
      rgba(8,8,8,0.34) 0%,
      rgba(8,8,8,0) 32%,
      rgba(14,14,14,0.55) 84%,
      var(--cor-fundo) 100%);
}
.hero__inner {
  position: relative;
  z-index: 2;
  padding: clamp(4rem, 12vh, 8rem) 0 clamp(5rem, 13vh, 9rem);
  width: 100%;
}
.hero__conteudo { max-width: 760px; }
.hero__titulo {
  color: #fff;
  margin-bottom: 1rem;
  font-size: clamp(2.6rem, 7vw, 5rem);
  font-weight: 700;
  text-shadow: 0 2px 30px rgba(0,0,0,0.25);
}
.hero__subtitulo {
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  color: rgba(255,255,255,0.9);
  margin-bottom: 2.25rem;
  max-width: 580px;
}
.hero__acoes { display: flex; flex-wrap: wrap; gap: 1rem; }

/* Eyebrow claro (sobre fundo escuro) */
.eyebrow--claro { color: var(--cor-acento-clara); }

/* Indicador de scroll — seta com leve bounce */
.hero__scroll {
  position: absolute; left: 50%; bottom: 20px; transform: translateX(-50%);
  z-index: 2; display: inline-flex; padding: 8px; border-radius: 50%;
  color: rgba(255,255,255,0.85);
  transition: color var(--transicao), background var(--transicao);
}
.hero__scroll:hover { color: #fff; background: rgba(255,255,255,0.12); }
.hero__scroll svg { display: block; animation: imob-bounce 1.8s ease-in-out infinite; }
@keyframes imob-bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(6px); }
}

/* Botão grande (CTA principal) */
.btn--grande { padding: 1.1rem 2rem; font-size: 1.05rem; }

/* --------------------------------------------------------------------------
   7. Cards de empreendimento (grid)
   -------------------------------------------------------------------------- */
.grid-empreendimentos {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap);
}
@media (min-width: 600px) { .grid-empreendimentos { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .grid-empreendimentos { grid-template-columns: repeat(3, 1fr); } }

.card {
  display: flex;
  flex-direction: column;
  background: var(--cor-card);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  overflow: hidden;
  box-shadow: var(--sombra);
  transition: transform var(--transicao), box-shadow var(--transicao), border-color var(--transicao);
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--sombra-forte);
  border-color: rgba(201, 162, 75, 0.45);
}

.card__media { position: relative; aspect-ratio: 4 / 3; background: var(--cor-fundo-alt); overflow: hidden; }
.card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--transicao-lenta);
}
.card:hover .card__media img { transform: scale(1.07); }
.card__media--vazio {
  display: flex; align-items: center; justify-content: center;
  color: var(--cor-texto-suave); font-size: 0.85rem;
}

.card__status {
  position: absolute; top: 0.75rem; left: 0.75rem;
  font-size: 0.72rem; font-weight: 600; letter-spacing: 0.03em;
  text-transform: uppercase;
  padding: 0.3rem 0.6rem; border-radius: 999px;
  background: var(--cor-secundaria); color: #1c1c1c;
}
.card__status--lancamento { background: var(--cor-secundaria); }
.card__status--em_obras  { background: #e8a33d; color: #1c1c1c; }
.card__status--pronto    { background: var(--cor-verde); color: #fff; }

.card__corpo { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; flex: 1; }
.card__titulo { font-size: 1.2rem; margin-bottom: 0.3rem; }
.card__titulo a { color: var(--cor-texto); }
.card__titulo a:hover { color: var(--cor-acento-clara); }
.card__local { font-size: 0.9rem; color: var(--cor-texto-suave); margin-bottom: 0.75rem; }
.card__local svg { vertical-align: -2px; }
.card__preco {
  font-family: var(--fonte-titulo); font-weight: 600;
  color: var(--cor-acento); margin-top: auto; padding-top: 0.5rem;
}
.card__preco small { display: block; font-weight: 400; font-size: 0.72rem; color: var(--cor-texto-suave); }
.card__cta { margin-top: 1rem; }

/* --------------------------------------------------------------------------
   8. Filtros (archive)
   -------------------------------------------------------------------------- */
.filtros {
  display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: flex-end;
  background: var(--cor-fundo-alt); border: 1px solid var(--cor-borda); border-radius: var(--raio);
  padding: 1.1rem 1.2rem; margin-bottom: 2rem; box-shadow: var(--sombra);
}
.filtros__campo { display: flex; flex-direction: column; gap: 0.25rem; flex: 1 1 160px; }
.filtros__campo label { font-size: 0.78rem; font-weight: 600; color: var(--cor-texto-suave); }
.filtros select, .filtros input {
  font: inherit; padding: 0.6rem 0.7rem; border: 1px solid var(--cor-borda);
  border-radius: var(--raio-sm); background: var(--cor-card); color: var(--cor-texto);
}
.filtros select:focus, .filtros input:focus {
  outline: none; border-color: var(--cor-acento);
  box-shadow: 0 0 0 3px rgba(201, 162, 75, 0.22);
}
.filtros__acoes { display: flex; gap: 0.5rem; flex: 0 0 auto; }

.page-header { margin-bottom: 1.5rem; }
.page-header__titulo { margin-bottom: 0.2rem; }
.resultados-info { color: var(--cor-texto-suave); font-size: 0.9rem; }

/* --------------------------------------------------------------------------
   9. Single empreendimento
   -------------------------------------------------------------------------- */
.empreendimento-hero {
  background: var(--cor-fundo-alt);
  border-bottom: 1px solid var(--cor-borda);
  padding: clamp(1.5rem, 4vw, 2.5rem) 0;
}
.empreendimento-hero__meta { display: flex; flex-wrap: wrap; gap: 0.6rem 1.2rem; align-items: center; color: var(--cor-texto-suave); }
.empreendimento-hero__meta .tag {
  background: var(--cor-card); border: 1px solid var(--cor-borda); border-radius: 999px;
  padding: 0.25rem 0.7rem; font-size: 0.82rem; color: var(--cor-texto);
}

.layout-single {
  display: grid; grid-template-columns: 1fr; gap: 2rem;
  padding-block: clamp(2rem, 5vw, 3rem);
}
@media (min-width: 960px) {
  .layout-single { grid-template-columns: minmax(0, 1fr) 340px; align-items: start; }
}

.bloco { margin-bottom: 2.5rem; }
.bloco__titulo {
  font-size: 1.3rem; margin-bottom: 1rem; padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--cor-secundaria); display: inline-block;
}

/* Galeria */
.galeria { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.6rem; }
@media (min-width: 720px) { .galeria { grid-template-columns: repeat(3, 1fr); } }
.galeria a { display: block; border-radius: var(--raio-sm); overflow: hidden; aspect-ratio: 4/3; }
.galeria img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transicao); }
.galeria a:hover img { transform: scale(1.05); }
.galeria__principal { grid-column: 1 / -1; aspect-ratio: 16/9; }

/* Tipologias (tabela) */
.tabela-tipologias { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
.tabela-tipologias th, .tabela-tipologias td {
  padding: 0.75rem 0.9rem; text-align: left; border-bottom: 1px solid var(--cor-borda);
}
.tabela-tipologias thead th {
  background: var(--cor-fundo-alt); color: var(--cor-acento); font-family: var(--fonte-titulo);
  font-size: 0.85rem; font-weight: 600; border-bottom: 2px solid var(--cor-acento);
}
.tabela-tipologias tbody tr:nth-child(even) { background: var(--cor-fundo-alt); }

/* Plantas */
.plantas { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
@media (min-width: 720px) { .plantas { grid-template-columns: repeat(3, 1fr); } }
.planta { border: 1px solid var(--cor-borda); border-radius: var(--raio-sm); overflow: hidden; background: var(--cor-card); }
.planta a { display:block; aspect-ratio: 1; }
.planta img { width:100%; height:100%; object-fit: cover; }
.planta__nome { padding: 0.6rem 0.75rem; font-size: 0.9rem; font-weight: 500; text-align:center; }

/* Listas de diferenciais / proximidades */
.lista-itens { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr; gap: 0.5rem; }
@media (min-width: 600px) { .lista-itens { grid-template-columns: repeat(2, 1fr); } }
.lista-itens li {
  position: relative; padding-left: 1.7rem; color: var(--cor-texto);
}
.lista-itens li::before {
  content: ""; position: absolute; left: 0; top: 0.45em;
  width: 0.7rem; height: 0.7rem; border-radius: 50%;
  background: var(--cor-secundaria);
}

/* Mapa */
.mapa-embed { position: relative; width: 100%; aspect-ratio: 16/9; border-radius: var(--raio); overflow: hidden; border: 1px solid var(--cor-borda); }
.mapa-embed iframe { position: absolute; inset: 0; width: 100% !important; height: 100% !important; border: 0; }

/* Sidebar de contato (sticky) */
.sidebar-contato {
  background: var(--cor-card); border: 1px solid var(--cor-borda); border-radius: var(--raio);
  padding: 1.4rem; box-shadow: var(--sombra);
}
@media (min-width: 960px) { .sidebar-contato { position: sticky; top: 90px; } }
.sidebar-contato__preco { font-family: var(--fonte-titulo); font-size: 1.5rem; color: var(--cor-acento); margin-bottom: 0.25rem; }
.sidebar-contato__rotulo { font-size: 0.8rem; color: var(--cor-texto-suave); margin-bottom: 1rem; }

/* --------------------------------------------------------------------------
   10. Seção Sobre / Contato (home)
   -------------------------------------------------------------------------- */
/* ---- Faixa de números de autoridade (sobreposta entre hero e conteúdo) ---- */
.numeros { position: relative; z-index: 3; margin-top: clamp(-4.5rem, -7vw, -3rem); }
.numeros__faixa {
  display: grid; grid-template-columns: 1fr; gap: 0.5rem;
  background: var(--cor-card);
  border: 1px solid var(--cor-borda);
  border-top: 2px solid var(--cor-acento);
  border-radius: var(--raio);
  box-shadow: var(--sombra-forte);
  padding: clamp(1.5rem, 4vw, 2.5rem);
}
@media (min-width: 640px) { .numeros__faixa { grid-template-columns: repeat(3, 1fr); } }
.numeros__item { text-align: center; padding: 0.75rem 0.5rem; position: relative; }
@media (min-width: 640px) {
  .numeros__item + .numeros__item::before {
    content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
    height: 56%; width: 1px; background: var(--cor-borda);
  }
}
.numeros__valor {
  display: inline-block;
  position: relative;
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: clamp(2.4rem, 5vw, 3.4rem);
  line-height: 1;
  color: var(--cor-acento);
  padding-bottom: 0.7rem;
}
.numeros__valor::after {
  content: ""; position: absolute; left: 50%; bottom: 0;
  transform: translateX(-50%);
  width: 36px; height: 2px; background: var(--cor-acento); opacity: 0.55;
}
.numeros__rotulo {
  display: block; margin-top: 0.65rem;
  font-size: 0.8rem; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cor-texto-suave);
}

/* ---- Sobre (card de texto sobreposto a uma imagem grande) ---- */
.sobre { display: grid; grid-template-columns: 1fr; overflow-x: clip; }

.sobre__foto { position: relative; }
.sobre__img {
  width: 100%;
  border-radius: var(--raio);
  box-shadow: var(--sombra-forte);
  position: relative; z-index: 1;
  display: block;
}
/* Moldura dourada deslocada atrás da imagem — profundidade. */
.sobre__selo {
  position: absolute; z-index: 0;
  right: -16px; bottom: -16px;
  width: 55%; height: 55%;
  border: 2px solid var(--cor-acento);
  border-radius: var(--raio);
  pointer-events: none;
}

/* Card de texto escuro elevado. */
.sobre__texto {
  position: relative;
  z-index: 2;
  background: var(--cor-card);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  box-shadow: var(--sombra-forte);
  padding: clamp(1.6rem, 4vw, 2.6rem);
}
.sobre__texto h2 { margin-bottom: 1rem; }

/* Mobile: empilha; o card sobe sobre a base da imagem (overlap). */
.sobre__texto {
  margin: -3.5rem 0.75rem 0;
}

/* Sem foto: card simples e centrado, sem sobreposição. */
.sobre--sem-foto { max-width: 760px; margin-inline: auto; }
.sobre--sem-foto .sobre__texto { margin: 0; max-width: none; }

/* Desktop: imagem à direita, card sobreposto vindo da esquerda. */
@media (min-width: 900px) {
  .sobre--sem-foto { grid-template-columns: 1fr; min-height: 0; }
  .sobre--sem-foto .sobre__texto { grid-column: 1 / -1; justify-self: stretch; margin: 0; }

  .sobre {
    grid-template-columns: 1fr 1fr;
    align-items: center;
    min-height: clamp(440px, 56vh, 600px);
  }
  .sobre__foto { grid-column: 2 / 3; grid-row: 1; height: 100%; }
  .sobre__img {
    height: 100%;
    min-height: clamp(440px, 56vh, 600px);
    object-fit: cover;
  }
  .sobre__texto {
    grid-column: 1 / 2; grid-row: 1;
    justify-self: end;
    max-width: 480px;
    margin: 0 -22% 0 0;   /* avança sobre a imagem à direita */
  }
}

/* ---- Contato (painel verde profundo, full-bleed visual) ---- */
.contato-secao { background: var(--cor-fundo); }
.contato-painel {
  position: relative;
  overflow: hidden;
  background: var(--grad-card);
  color: var(--cor-texto-suave);
  border: 1px solid var(--cor-borda);
  border-radius: calc(var(--raio) + 6px);
  padding: clamp(2.5rem, 6vw, 4.5rem);
  text-align: center;
  box-shadow: var(--sombra-forte), inset 0 1px 0 var(--realce-topo);
}
.contato-painel::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(70% 120% at 88% -12%, rgba(201,162,75,0.22), transparent 58%),
    radial-gradient(62% 110% at 6% 112%, rgba(31,111,79,0.10), transparent 60%);
}
.contato-painel > * { position: relative; z-index: 1; }
.secao__cabecalho--claro .secao__titulo,
.contato-painel .secao__titulo { color: #fff; }
.secao__cabecalho--claro .secao__subtitulo,
.contato-painel .secao__subtitulo { color: rgba(255,255,255,0.82); }
.contato-lista {
  list-style: none; padding: 0; margin: 0 auto 2rem;
  display: flex; flex-wrap: wrap; gap: 0.5rem 2rem; justify-content: center;
}
.contato-lista li { color: rgba(255,255,255,0.9); }
.contato-lista strong { color: var(--cor-acento-clara); font-weight: 600; }
.contato-lista a { color: #fff; }

/* CTA investidor — pontos de valor */
.contato-valores {
  list-style: none; padding: 0; margin: 0 auto 2.5rem;
  display: grid; grid-template-columns: 1fr; gap: 1.6rem; max-width: 820px;
}
@media (min-width: 720px) { .contato-valores { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }
.contato-valor { display: flex; flex-direction: column; align-items: center; gap: 0.55rem; padding: 0 0.5rem; }
.contato-valor__icone {
  display: inline-flex; align-items: center; justify-content: center;
  width: 54px; height: 54px; border-radius: 50%;
  background: rgba(201,162,75,0.12); color: var(--cor-acento);
  border: 1px solid rgba(201,162,75,0.32);
  box-shadow: 0 0 0 6px rgba(201,162,75,0.05);
}
.contato-valor__icone svg { width: 24px; height: 24px; }
.contato-valor__titulo { font-family: var(--fonte-titulo); font-weight: 600; color: #fff; font-size: 1.08rem; }
.contato-valor__desc { font-size: 0.9rem; line-height: 1.55; color: rgba(255,255,255,0.7); max-width: 260px; margin: 0; }

/* CTA investidor — bloco de ação (botão + contato), separado por divisor sutil */
.contato-acao {
  display: flex; flex-direction: column; align-items: center; gap: 1.4rem;
  max-width: 820px; margin: 0 auto;
  padding-top: 2.2rem; border-top: 1px solid rgba(255,255,255,0.1);
}
.contato-acao .contato-lista { margin: 0; }

/* --------------------------------------------------------------------------
   11. Botão flutuante de WhatsApp
   -------------------------------------------------------------------------- */
.whatsapp-flutuante {
  position: fixed;
  right: 18px; bottom: 18px;
  z-index: 60;
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--cor-whatsapp); color: #fff;
  padding: 0.85rem 1.1rem; border-radius: 999px;
  font-family: var(--fonte-titulo); font-weight: 600; font-size: 0.95rem;
  box-shadow: var(--sombra-forte);
  transition: transform var(--transicao), background var(--transicao);
}
.whatsapp-flutuante:hover { background: var(--cor-whatsapp-escura); color: #fff; transform: translateY(-2px); }
.whatsapp-flutuante svg { flex: 0 0 auto; }
.whatsapp-flutuante__texto { display: none; }
@media (min-width: 600px) { .whatsapp-flutuante__texto { display: inline; } }

/* --------------------------------------------------------------------------
   12. Rodapé
   -------------------------------------------------------------------------- */
.site-footer {
  position: relative;
  background:
    radial-gradient(80% 140% at 50% 0%, rgba(201, 162, 75, 0.06), transparent 55%),
    linear-gradient(180deg, #0C0C0B 0%, #060605 100%);
  color: rgba(242, 239, 231, 0.72);
  padding: clamp(2.5rem, 5vw, 3.5rem) 0 1.5rem;
  margin-top: 0;
  border-top: 1px solid var(--cor-borda);
}
/* Fio dourado de transição no topo do rodapé */
.site-footer::before {
  content: ""; position: absolute; top: -1px; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201, 162, 75, 0.5), transparent);
}
.site-footer a { color: #fff; }
.site-footer a:hover { color: var(--cor-secundaria); }
.site-footer__grid {
  display: grid; grid-template-columns: 1fr; gap: 2rem;
}
@media (min-width: 720px) { .site-footer__grid { grid-template-columns: 2fr 1fr 1fr; } }
.site-footer h4 { color: #fff; font-size: 1rem; margin-bottom: 0.8rem; }
.site-footer ul { list-style: none; padding: 0; }
.site-footer li { margin-bottom: 0.4rem; }
.site-footer__base {
  margin-top: 2.5rem; padding-top: 1.2rem;
  border-top: 1px solid rgba(255,255,255,0.15);
  font-size: 0.82rem; text-align: center; color: rgba(255,255,255,0.6);
}

/* --------------------------------------------------------------------------
   13. Conteúdo de página padrão (page.php) + 404
   -------------------------------------------------------------------------- */
.entry { max-width: 760px; margin-inline: auto; }
.entry__conteudo h2 { margin-top: 2rem; }
.entry__conteudo img { border-radius: var(--raio-sm); }

.erro-404 { text-align: center; padding: clamp(3rem, 8vw, 6rem) 0; }
.erro-404 .codigo { font-family: var(--fonte-titulo); font-size: clamp(4rem, 14vw, 8rem); color: var(--cor-secundaria); line-height: 1; }

/* Mensagem vazia genérica */
.aviso-vazio {
  text-align: center; padding: 2.5rem 1rem; color: var(--cor-texto-suave);
  background: var(--cor-fundo-alt); border-radius: var(--raio); border: 1px dashed var(--cor-borda);
}

/* --------------------------------------------------------------------------
   14. Polish dark — foco acessível, paginação e refinos do single
   -------------------------------------------------------------------------- */

/* Foco visível em links (acessibilidade) */
a:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Paginação (archive / index) */
.pagination, .navigation.pagination { margin-top: 3rem; text-align: center; }
.pagination .nav-links { display: inline-flex; flex-wrap: wrap; gap: 0.4rem; justify-content: center; }
.page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 44px; height: 44px; padding: 0 0.7rem;
  border: 1px solid var(--cor-borda); border-radius: var(--raio-sm);
  background: var(--cor-card); color: var(--cor-texto);
  font-weight: 600; transition: all var(--transicao);
}
.page-numbers:hover { border-color: var(--cor-acento); color: var(--cor-acento); }
.page-numbers.current {
  background: var(--cor-acento); color: #161514; border-color: var(--cor-acento);
}
.page-numbers.dots { background: transparent; border-color: transparent; }

/* Single: cabeçalho do empreendimento com leve brilho dourado */
.empreendimento-hero {
  position: relative;
  background:
    radial-gradient(90% 140% at 90% -20%, rgba(201, 162, 75, 0.08), transparent 60%),
    var(--cor-fundo-alt);
}
.empreendimento-hero__titulo { color: var(--cor-texto); }

/* Galeria/plantas: realce dourado sutil ao passar o mouse */
.galeria a, .planta a { position: relative; }
.galeria a:focus-visible, .planta a:focus-visible { outline: 2px solid var(--cor-acento); outline-offset: 2px; }

/* Bloco de descrição (the_content) — links em dourado claro */
.entry__conteudo a { color: var(--cor-acento-clara); text-decoration: underline; text-underline-offset: 3px; }
.entry__conteudo a:hover { color: var(--cor-texto); }

/* --------------------------------------------------------------------------
   15. Seções da Home: Por que o Sérgio / Selecionados / Números + Depoimentos
   -------------------------------------------------------------------------- */

/* Palavra destacada em itálico dourado (Playfair italic) */
.italico-dourado { font-style: italic; color: var(--cor-acento); font-weight: 600; }

/* ---- 1) Por que o Sérgio ---- */
.porque__grid { display: grid; grid-template-columns: 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
@media (min-width: 960px) { .porque__grid { grid-template-columns: 1.1fr 0.9fr; } }

.porque__cards { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 560px) { .porque__cards { grid-template-columns: 1fr 1fr; } }
/* O 5º card ocupa a linha inteira (destaque) */
.porque__cards .dif-card:last-child { grid-column: 1 / -1; }

.dif-card {
  background: var(--cor-card);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  padding: 1.4rem;
  transition: transform var(--transicao), border-color var(--transicao);
}
.dif-card:hover { transform: translateY(-4px); border-color: rgba(201, 162, 75, 0.4); }
.dif-card__icone {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; margin-bottom: 0.9rem;
  border-radius: 12px;
  background: rgba(201, 162, 75, 0.12);
  color: var(--cor-acento);
}
.dif-card__icone svg { width: 24px; height: 24px; }
.dif-card__titulo { font-size: 1.1rem; margin-bottom: 0.35rem; color: var(--cor-texto); }
.dif-card__desc { font-size: 0.92rem; color: var(--cor-texto-suave); margin: 0; }

.porque__titulo { font-size: clamp(1.9rem, 3.5vw, 2.9rem); margin-bottom: 1.2rem; }
.porque__texto p { color: var(--cor-texto-suave); }
.porque__texto .btn { margin-top: 1rem; }

/* ---- 2) Empreendimentos selecionados ---- */
.selec-grid { display: grid; grid-template-columns: 1fr; gap: var(--gap); }
@media (min-width: 600px) { .selec-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .selec-grid { grid-template-columns: repeat(3, 1fr); } }

.selec-card {
  display: flex; flex-direction: column;
  background: var(--cor-fundo-alt);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  overflow: hidden;
  transition: transform var(--transicao), box-shadow var(--transicao), border-color var(--transicao);
}
.selec-card:hover { transform: translateY(-6px); box-shadow: var(--sombra-forte); border-color: rgba(201, 162, 75, 0.45); }

.selec-card__media {
  position: relative; display: block; aspect-ratio: 4 / 3;
  overflow: hidden; background: var(--cor-card);
}
.selec-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transicao-lenta); }
.selec-card:hover .selec-card__img { transform: scale(1.07); }
.selec-card__semfoto {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: var(--cor-texto-suave); font-size: 0.85rem;
}
.selec-card__media::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, transparent 45%, rgba(8, 8, 8, 0.85) 100%);
}
.selec-card__nome {
  position: absolute; left: 1rem; right: 1rem; bottom: 0.9rem; z-index: 1;
  font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.35rem;
  color: #fff; line-height: 1.15; text-shadow: 0 2px 14px rgba(0, 0, 0, 0.5);
}

.selec-card__corpo { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; flex: 1; }
.selec-card__local {
  display: flex; align-items: center; gap: 0.4rem;
  color: var(--cor-acento); font-size: 0.85rem; margin: 0 0 0.6rem;
}
.selec-card__local svg { width: 16px; height: 16px; flex: 0 0 auto; }
.selec-card__local span { color: var(--cor-texto-suave); }
.selec-card__conceito { font-size: 0.92rem; color: var(--cor-texto-suave); margin: 0 0 1rem; }
.selec-card__tags { list-style: none; padding: 0; margin: 0 0 1.1rem; display: flex; flex-wrap: wrap; gap: 0.4rem; }
.selec-card__tags li {
  font-size: 0.74rem; font-weight: 600; letter-spacing: 0.02em;
  padding: 0.28rem 0.65rem; border-radius: 999px;
  background: rgba(201, 162, 75, 0.1); color: var(--cor-acento-clara);
  border: 1px solid rgba(201, 162, 75, 0.25);
}
.selec-card__link {
  margin-top: auto; font-weight: 600; color: var(--cor-acento-clara);
  transition: color var(--transicao);
}
.selec-card__link:hover { color: var(--cor-texto); }

/* ---- Faixa de números (logo abaixo do hero) + Depoimentos ---- */
/* Faixa-ribbon de estatísticas "montada" na borda inferior do hero */
.numeros-faixa {
  position: relative;
  z-index: 3;
  margin-top: clamp(-5.5rem, -7vw, -3.5rem);   /* puxa o card pra cima, sobre a imagem */
  padding-block: 0 clamp(2.5rem, 5vw, 4rem);   /* respiro só abaixo, antes de "Por que o Sérgio" */
}
.numeros-faixa .prova-numeros {
  margin-bottom: 0;
  box-shadow: var(--sombra-forte), inset 0 1px 0 var(--realce-topo);  /* destaca o card flutuante */
}
/* Com o card sobreposto fazendo a ponte, a seta de scroll vira ruído — oculta no hero da home */
.hero:has(+ .numeros-faixa) .hero__scroll { display: none; }

.prova-numeros {
  display: grid; grid-template-columns: 1fr; gap: 1.5rem;
  padding: clamp(1.8rem, 4vw, 2.6rem);
  background: var(--grad-card);
  border: 1px solid var(--cor-borda);
  border-top: 2px solid var(--cor-acento);
  border-radius: var(--raio);
  box-shadow: var(--sombra), inset 0 1px 0 var(--realce-topo);
  margin-bottom: clamp(3rem, 6vw, 4.5rem);
}
@media (min-width: 640px) { .prova-numeros { grid-template-columns: repeat(3, 1fr); } }
.prova-num { text-align: center; position: relative; }
@media (min-width: 640px) {
  .prova-num + .prova-num::before {
    content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
    height: 64%; width: 1px; background: var(--cor-borda);
  }
}
.prova-num__icone { display: inline-flex; color: var(--cor-acento); margin-bottom: 0.4rem; }
.prova-num__icone svg { width: 28px; height: 28px; }
.prova-num__valor {
  display: block; font-family: var(--fonte-titulo); font-weight: 700;
  font-size: clamp(2.2rem, 4.5vw, 3.2rem); line-height: 1; color: var(--cor-acento);
}
.prova-num__rotulo {
  display: block; margin-top: 0.5rem; font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--cor-texto-suave);
}

.depo-grid { display: grid; grid-template-columns: 1fr; gap: var(--gap); }
@media (min-width: 700px) { .depo-grid { grid-template-columns: repeat(3, 1fr); } }
.depo-card {
  margin: 0; display: flex; flex-direction: column;
  background: var(--cor-card);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio);
  padding: 1.5rem;
}
.estrelas { display: inline-flex; gap: 3px; color: var(--cor-acento); margin-bottom: 0.9rem; }
.estrelas .estrela { width: 18px; height: 18px; }
.estrela--vazia { color: var(--cor-borda); }
.depo-card__cit {
  margin: 0 0 1.3rem; font-size: 1.02rem; line-height: 1.6;
  color: var(--cor-texto); quotes: "“" "”";
}
.depo-card__cit::before { content: open-quote; color: var(--cor-acento); margin-right: 0.1em; }
.depo-card__cit::after { content: close-quote; color: var(--cor-acento); }
.depo-card__autor { display: flex; align-items: center; gap: 0.8rem; margin-top: auto; }
.depo-card__foto { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; border: 1px solid var(--cor-borda); }
.depo-card__nome { font-family: var(--fonte-titulo); font-weight: 600; color: var(--cor-texto); line-height: 1.2; }
.depo-card__nome small { display: block; font-family: var(--fonte-texto); font-weight: 400; font-size: 0.82rem; color: var(--cor-texto-suave); }

/* Reduced-motion: neutraliza zoom/elevação das novas seções */
@media (prefers-reduced-motion: reduce) {
  .selec-card:hover, .dif-card:hover { transform: none !important; }
  .selec-card:hover .selec-card__img { transform: none !important; }
}

/* --------------------------------------------------------------------------
   16. Single de empreendimento (layout rico, dark)
   -------------------------------------------------------------------------- */

/* Camadas de luz que acompanham o scroll da página (não chapado) */
.empreendimento {
  position: relative;
  background:
    radial-gradient(58% 26% at 90% 6%, rgba(201, 162, 75, 0.13), transparent 62%),
    radial-gradient(52% 24% at 4% 40%, rgba(31, 111, 79, 0.08), transparent 62%),
    radial-gradient(64% 26% at 96% 74%, rgba(201, 162, 75, 0.11), transparent 62%),
    radial-gradient(50% 22% at 6% 96%, rgba(201, 162, 75, 0.08), transparent 62%);
}

/* Hero + galeria */
.emp-hero { position: relative; }
.emp-hero__media {
  position: relative; width: 100%;
  height: clamp(360px, 60vh, 620px);
  overflow: hidden; background: var(--cor-fundo-alt);
}
.emp-hero__img { width: 100%; height: 100%; object-fit: cover; display: block; cursor: zoom-in; }
/* Botão "Ampliar" (abre a imagem em tela cheia) */
.emp-hero__expandir {
  position: absolute; top: 1rem; right: 1rem; z-index: 3;
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 0.85rem; border-radius: 999px;
  background: rgba(8,8,8,0.55); color: #fff; font-size: 0.85rem; font-weight: 600;
  border: 1px solid rgba(255,255,255,0.25); cursor: pointer;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  transition: background var(--transicao), border-color var(--transicao);
}
.emp-hero__expandir:hover { background: rgba(8,8,8,0.85); border-color: var(--cor-acento); color: #fff; }
.emp-hero__expandir svg { display: block; }
@media (max-width: 540px) { .emp-hero__expandir span { display: none; } }
.emp-hero__overlay {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(8,8,8,0.45) 0%, transparent 32%, rgba(8,8,8,0.88) 100%);
}
.emp-hero__voltar {
  position: absolute; top: 1rem; left: 1rem; z-index: 2;
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 0.95rem; border-radius: 999px;
  background: rgba(8,8,8,0.55); color: #fff; font-size: 0.9rem; font-weight: 600;
  border: 1px solid rgba(255,255,255,0.2);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  transition: background var(--transicao);
}
.emp-hero__voltar:hover { background: rgba(8,8,8,0.85); color: #fff; }
.emp-hero__info { position: absolute; left: 0; right: 0; bottom: clamp(1.2rem, 3vw, 2.2rem); z-index: 2; }
.emp-hero__titulo { color: #fff; font-size: clamp(2rem, 5vw, 3.4rem); margin: 0.5rem 0 0.3rem; text-shadow: 0 2px 18px rgba(0,0,0,0.5); }
.emp-hero__tagline {
  font-family: var(--fonte-titulo); font-style: italic;
  font-size: clamp(1.05rem, 2vw, 1.4rem); color: var(--cor-acento-clara);
  margin: 0 0 0.5rem; text-shadow: 0 2px 14px rgba(0,0,0,0.5);
}
.emp-hero__local { display: flex; align-items: center; gap: 0.4rem; margin: 0; }
.emp-hero__local svg { width: 18px; height: 18px; color: var(--cor-acento); }
.emp-hero__local span { color: rgba(255,255,255,0.92); }

.emp-galeria {
  position: relative;
  display: flex; align-items: center; gap: 0.5rem;
  background: var(--grad-alt); border-bottom: 1px solid var(--cor-borda);
  box-shadow: inset 0 1px 0 var(--realce-topo);
  padding: 0.6rem clamp(0.6rem, 2vw, 1rem);
}
/* Fio dourado de transição entre o hero e a galeria */
.emp-galeria::before {
  content: ""; position: absolute; top: -1px; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201, 162, 75, 0.45), transparent);
}
.emp-galeria__seta {
  flex: 0 0 auto; width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid var(--cor-borda); background: var(--cor-card);
  color: var(--cor-texto); font-size: 1.4rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: border-color var(--transicao), color var(--transicao);
}
.emp-galeria__seta:hover { border-color: var(--cor-acento); color: var(--cor-acento); }
.emp-galeria__thumbs {
  list-style: none; display: flex; gap: 0.5rem; margin: 0; padding: 0.2rem;
  overflow-x: auto; flex: 1; scrollbar-width: thin;
}
.emp-galeria__thumbs li { flex: 0 0 auto; }
.emp-thumb {
  display: block; width: 96px; height: 64px; padding: 0; cursor: pointer;
  border: 2px solid transparent; border-radius: 8px; overflow: hidden;
  background: none; opacity: 0.55;
  transition: opacity var(--transicao), border-color var(--transicao);
}
.emp-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.emp-thumb:hover { opacity: 1; }
.emp-thumb.is-active { opacity: 1; border-color: var(--cor-acento); }

/* Info rápida */
.emp-info {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem;
  margin-top: clamp(1.5rem, 4vw, 2.5rem);
}
@media (min-width: 760px) { .emp-info { grid-template-columns: repeat(4, 1fr); } }
.emp-info__card {
  background: var(--cor-card); border: 1px solid var(--cor-borda);
  border-radius: var(--raio); padding: 1.2rem 1rem; text-align: center;
}
.emp-info__icone { display: inline-flex; color: var(--cor-acento); margin-bottom: 0.4rem; }
.emp-info__icone svg { width: 26px; height: 26px; }
.emp-info__valor { display: block; font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.35rem; color: var(--cor-texto); }
.emp-info__rotulo { display: block; font-size: 0.76rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cor-texto-suave); margin-top: 0.2rem; }

/* Layout principal + form sticky */
.emp-layout { display: grid; grid-template-columns: 1fr; gap: clamp(2rem, 5vw, 3rem); padding-block: clamp(2rem, 5vw, 3.5rem); }
@media (min-width: 960px) { .emp-layout { grid-template-columns: minmax(0, 1fr) 360px; align-items: start; } }
@media (min-width: 960px) { .emp-aside { position: sticky; top: 88px; } }

.emp-form {
  background: var(--cor-card); border: 1px solid var(--cor-borda);
  border-top: 2px solid var(--cor-acento); border-radius: var(--raio);
  padding: clamp(1.3rem, 3vw, 1.8rem); box-shadow: var(--sombra);
}
.emp-form__titulo { font-size: 1.4rem; margin-bottom: 0.3rem; }
.emp-form__preco { color: var(--cor-acento); font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.2rem; margin-bottom: 1rem; }
.emp-form__texto { color: var(--cor-texto-suave); font-size: 0.95rem; margin: 0 0 1.2rem; }
.emp-form__campos { display: grid; gap: 0.7rem; }
.emp-form__label { display: grid; gap: 0.25rem; font-size: 0.82rem; color: var(--cor-texto-suave); }
.emp-form__label input, .emp-form__label textarea {
  font: inherit; background: var(--cor-fundo); border: 1px solid var(--cor-borda);
  border-radius: var(--raio-sm); color: var(--cor-texto); padding: 0.6rem 0.7rem; width: 100%;
}
.emp-form__label input:focus, .emp-form__label textarea:focus {
  outline: none; border-color: var(--cor-acento); box-shadow: 0 0 0 3px rgba(201,162,75,0.2);
}
.emp-form__campos .btn { margin-top: 0.4rem; }
.emp-form__wpp { margin-top: 0.6rem; }
.emp-form__aviso { padding: 0.65rem 0.85rem; border-radius: var(--raio-sm); font-size: 0.88rem; margin-bottom: 1rem; }
.emp-form__aviso--ok { background: rgba(59,122,69,0.16); color: #9bdcab; border: 1px solid rgba(59,122,69,0.45); }
.emp-form__aviso--erro { background: rgba(224,106,98,0.12); color: #e8a8a2; border: 1px solid rgba(224,106,98,0.4); }

/* Diferenciais (check) */
.dif-check-grid { display: grid; grid-template-columns: 1fr; gap: 0.7rem; }
@media (min-width: 600px) { .dif-check-grid { grid-template-columns: 1fr 1fr; } }
.dif-check {
  display: flex; gap: 0.6rem; align-items: flex-start;
  background: var(--cor-card); border: 1px solid var(--cor-borda);
  border-radius: var(--raio-sm); padding: 0.8rem 0.9rem;
}
.dif-check__icone { flex: 0 0 auto; color: var(--cor-acento); }
.dif-check__icone svg { width: 20px; height: 20px; }

/* Área de lazer */
.lazer-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
@media (min-width: 680px) { .lazer-grid { grid-template-columns: repeat(3, 1fr); } }
.lazer-card {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.6rem;
  background: var(--cor-card); border: 1px solid var(--cor-borda);
  border-radius: var(--raio); padding: 1.3rem 1rem;
  transition: transform var(--transicao), border-color var(--transicao);
}
.lazer-card:hover { transform: translateY(-4px); border-color: rgba(201,162,75,0.4); }
.lazer-card__icone {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(201,162,75,0.12); color: var(--cor-acento);
}
.lazer-card__icone svg { width: 26px; height: 26px; }
.lazer-card__nome { font-size: 0.92rem; color: var(--cor-texto); }

/* Ficha técnica */
.ficha { display: grid; grid-template-columns: 1fr; margin: 0; }
@media (min-width: 560px) { .ficha { grid-template-columns: 1fr 1fr; gap: 0 2rem; } }
.ficha__item { display: flex; justify-content: space-between; gap: 1rem; padding: 0.8rem 0; border-bottom: 1px solid var(--cor-borda); }
.ficha__item dt { color: var(--cor-texto-suave); margin: 0; }
.ficha__item dd { margin: 0; font-weight: 600; color: var(--cor-texto); text-align: right; }

/* Tour virtual */
.tour-card {
  display: flex; align-items: center; gap: 1rem;
  background: var(--cor-card); border: 1px solid var(--cor-borda);
  border-radius: var(--raio); padding: 1.1rem 1.3rem;
  transition: border-color var(--transicao), transform var(--transicao);
}
.tour-card:hover { border-color: var(--cor-acento); transform: translateY(-2px); }
.tour-card__icone {
  flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: 12px;
  background: rgba(201,162,75,0.12); color: var(--cor-acento);
}
.tour-card__icone svg { width: 28px; height: 28px; }
.tour-card__texto { flex: 1; display: flex; flex-direction: column; }
.tour-card__texto strong { color: var(--cor-texto); }
.tour-card__texto small { color: var(--cor-texto-suave); }
.tour-card__seta { color: var(--cor-acento); }
.tour-card__seta svg { width: 22px; height: 22px; }

/* Público ideal / Potencial */
.insights { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .insights { grid-template-columns: 1fr 1fr; } }
.insight-card { background: var(--cor-card); border: 1px solid var(--cor-borda); border-radius: var(--raio); padding: 1.4rem; }
.insight-card--ouro { border-color: rgba(201,162,75,0.45); background: linear-gradient(180deg, rgba(201,162,75,0.06), transparent); }
.insight-card__titulo { font-size: 1.1rem; margin-bottom: 0.5rem; }
.insight-card p { color: var(--cor-texto-suave); margin: 0; }

/* Por que investir */
.investir-card {
  background: var(--cor-fundo-alt); border: 1px solid var(--cor-borda);
  border-top: 2px solid var(--cor-acento);
  border-radius: calc(var(--raio) + 4px);
  padding: clamp(1.8rem, 4vw, 3rem);
  box-shadow: var(--sombra-forte);
  margin-bottom: clamp(2rem, 5vw, 3rem);
}
.investir-card__titulo { margin-bottom: 1.3rem; }
.investir-lista { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: 0.9rem; }
@media (min-width: 700px) { .investir-lista { grid-template-columns: 1fr 1fr; } }
.investir-lista li { display: flex; gap: 0.7rem; align-items: flex-start; color: var(--cor-texto); }
.investir-lista__seta { flex: 0 0 auto; color: var(--cor-acento); }
.investir-lista__seta svg { width: 20px; height: 20px; }

/* Localização */
.emp-local { margin-bottom: clamp(2.5rem, 6vw, 4rem); }
.emp-local__grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 860px) { .emp-local__grid { grid-template-columns: 2fr 1fr; align-items: start; } }
.emp-local__prox h3 { margin-bottom: 0.8rem; }

@media (prefers-reduced-motion: reduce) {
  .lazer-card:hover, .tour-card:hover { transform: none !important; }
}

/* --------------------------------------------------------------------------
   17. Subtom nas superfícies — reaplica o gradiente "lit-from-above" por cima
   dos background: individuais de cada card (este bloco precisa vir por último).
   .insight-card fica de fora para preservar o realce dourado do --ouro.
   -------------------------------------------------------------------------- */
.card,
.dif-card,
.depo-card,
.prova-numeros,
.selec-card,
.planta,
.tour-card,
.investir-card,
.emp-form,
.emp-info__card,
.dif-check,
.lazer-card,
.filtros {
  background-image: var(--grad-card);
}
