/* =========================================================
   VARIÁVEIS GLOBAIS DO TEMA
   Aqui ficam as cores, sombras e medidas reutilizadas no site.
   Isso facilita trocar a identidade visual inteira mexendo em poucos lugares.
========================================================= */
:root {
    --bg: #f5f6f8;                 /* cor de fundo geral do site */
    --surface: #ffffff;            /* cor base de superfícies brancas */
    --surface-alt: #f0f2f5;        /* cor alternativa para superfícies */
    --text: #111827;               /* cor principal dos textos */
    --muted: #6b7280;              /* cor de textos secundários/discretos */
    --line: #d7dce2;               /* cor de bordas e divisórias */
    --dark: #071098;               /* azul escuro principal da marca */
    --dark-2: #050a66;             /* azul escuro secundário */
    --accent: #1E93F2;             /* azul claro de destaque */
    --success-bg: #e8f8ef;         /* fundo de alertas de sucesso */
    --success: #166534;            /* texto/ícone de sucesso */
    --error-bg: #fff1f2;           /* fundo de alertas de erro */
    --error: #9f1239;              /* texto/ícone de erro */
    --radius: 20px;                /* raio padrão dos cantos arredondados */
    --shadow: 0 18px 50px rgba(15, 23, 42, 0.08); /* sombra padrão */
    --wa: #25D366;                 /* verde do WhatsApp */
}

/* =========================================================
   RESET / AJUSTES GERAIS
========================================================= */
* {
    box-sizing: border-box;        /* faz padding e border entrarem no cálculo da largura/altura */
}

html {
    scroll-behavior: smooth;       /* rolagem suave ao clicar em links internos */
}

body {
    margin: 0;                     /* remove margem padrão do navegador */
    font-family: Arial, Helvetica, sans-serif; /* fonte base do site */
    color: var(--text);            /* aplica cor principal do texto */
    background: var(--bg);         /* fundo geral da página */
}

a {
    color: inherit;                /* link herda a cor do elemento pai */
    text-decoration: none;         /* remove sublinhado padrão dos links */
}

img {
    max-width: 100%;               /* impede imagens de ultrapassarem o container */
    display: block;                /* remove espaços extras que imagens inline costumam gerar */
}

button,
input,
select,
textarea {
    font: inherit;                 /* faz campos herdarem a fonte do site */
}

.container {
    width: min(1240px, 92%);       /* largura máxima de 1240px, ou 92% da tela se menor */
    margin: 0 auto;                /* centraliza o container horizontalmente */
}

/* =========================================================
   TOPBAR
   Barra fina acima do menu principal
========================================================= */
.topbar-minimal {
    background: var(--dark);       /* fundo azul escuro */
    color: rgba(255,255,255,.88);  /* texto branco levemente transparente */
    font-size: 13px;               /* tamanho pequeno de texto */
    border-bottom: 1px solid rgba(255,255,255,.08); /* linha inferior bem sutil */
}

.topbar-inner {
    display: flex;                 /* usa flexbox */
    justify-content: space-between;/* distribui itens nas extremidades */
    align-items: center;           /* alinha verticalmente no centro */
    gap: 16px;                     /* espaço entre itens */
    min-height: 34px;              /* altura mínima da topbar */
    padding: 4px 0;                /* respiro vertical */
}

.topbar-inner a {
    color: #ffffff;                /* links em branco */
    font-weight: 700;              /* peso forte */
}

.topbar-actions {
    display: flex;                 /* organiza os botões/links da direita em linha */
    align-items: center;           /* alinha verticalmente */
    gap: 18px;                     /* espaço entre eles */
}

.topbar-cta {
    display: inline-flex;          /* botão em linha com flex */
    align-items: center;           /* centraliza verticalmente */
    justify-content: center;       /* centraliza horizontalmente */
    padding: 8px 14px;             /* espaçamento interno */
    border-radius: 10px;           /* cantos arredondados */
    background: #ffffff;           /* fundo branco */
    color: var(--dark) !important; /* texto azul escuro, forçado */
    font-weight: 800;              /* texto bem forte */
}

/* =========================================================
   NAVBAR
   Menu principal fixo no topo
========================================================= */
.navbar-clean {
    background: rgba(255, 255, 255, 0.94); /* fundo branco semitransparente */
    backdrop-filter: blur(10px);  /* efeito de vidro fosco */
    border-bottom: 1px solid rgba(7,16,152,0.08); /* borda inferior leve */
    position: sticky;             /* menu “cola” no topo ao rolar */
    top: 0;                       /* posição do sticky */
    z-index: 50;                  /* fica acima de muito conteúdo */
}

.nav-wrap {
    min-height: 64px;             /* altura mínima da navbar */
    display: flex;                /* usa flexbox */
    justify-content: space-between; /* logo de um lado, menu do outro */
    align-items: center;          /* centraliza verticalmente */
    gap: 20px;                    /* espaço entre blocos */
    padding: 8px 0;               /* respiro vertical */
}

.brand {
    font-size: 22px;              /* tamanho do nome da marca */
    font-weight: 700;             /* peso forte */
    letter-spacing: -0.03em;      /* aproxima um pouco as letras */
}

.brand-full {
    display: inline-flex;         /* logo tratado como flex em linha */
    align-items: center;          /* centraliza o conteúdo */
    text-decoration: none;        /* remove decoração de link */
    flex-shrink: 0;               /* impede o logo de encolher demais */
}

.brand-full-img {
    height: 42px;                 /* altura do logo — não alterar (afeta navbar) */
    width: auto;
    max-width: 100%;
    display: block;
    object-fit: contain;
    transform: scale(1.28);       /* aumento VISUAL sem afetar o fluxo */
    transform-origin: left center; /* ancora à esquerda para não desalinhar */
    filter: drop-shadow(0 2px 10px rgba(7,16,152,.10)); /* sombra suave no logo */
}

.brand-lockup {
    display: flex;                /* agrupa logo + nome */
    align-items: center;          /* alinha no centro */
    gap: 12px;                    /* espaço entre ícone e texto */
}

.brand-logo {
    height: 68px;                 /* altura do ícone/logo secundário */
    width: auto;                  /* largura proporcional */
}

.brand-name {
    font-size: 18px;              /* tamanho do nome da marca */
    font-weight: 800;             /* peso forte */
    letter-spacing: -0.03em;      /* aproxima as letras */
     color: var(--dark)           /* cor das letras*/
}

.menu {
    display: flex;                /* menu em linha */
    gap: 18px;                    /* espaço entre links */
    align-items: center;          /* alinha verticalmente */
    flex-wrap: wrap;              /* quebra linha se faltar espaço */
}

.menu-site {
    display: flex;                /* versão específica do menu do site */
    align-items: center;          /* alinhamento vertical */
    gap: 18px;                    /* espaço entre links */
}

.menu-site a.active {
    color: var(--dark);           /* link ativo em azul escuro */
    font-weight: 700;             /* destaque do link ativo */
}

.menu-site a:not(.btn) {
    color: #374151;               /* links normais em cinza escuro */
    padding: 4px 0;               /* respiro vertical pequeno */
    font-size: 15px;              /* tamanho do link */
    line-height: 1.2;             /* altura de linha compacta */
}

/* =========================================================
   BOTÕES
========================================================= */
.btn {
    display: inline-flex;         /* botão alinhável com flex */
    align-items: center;          /* centraliza verticalmente */
    justify-content: center;      /* centraliza horizontalmente */
    gap: 8px;                     /* espaço entre ícone e texto */
    border-radius: 999px;         /* botão arredondado tipo pílula */
    padding: 9px 16px;            /* espaçamento interno */
    border: 1px solid transparent;/* borda base invisível */
    cursor: pointer;              /* cursor de clique */
    font-weight: 700;             /* texto forte */
    transition: transform .15s ease, opacity .15s ease, background .15s ease; /* animação suave */
}

.btn:hover {
    transform: translateY(-1px);  /* sobe levemente ao passar mouse */
    opacity: .95;                 /* reduz opacidade bem pouco */
}

.btn-primary {
    background: var(--dark);      /* fundo azul escuro */
    color: #fff;                  /* texto branco */
}

.btn-primary:hover {
    opacity: .95;                 /* hover leve */
}

.btn-primary-outline {
    background: transparent;      /* sem fundo */
    color: var(--dark);           /* texto azul escuro */
    border-color: rgba(7,16,152,0.22); /* borda azul clara */
}

.btn-black {
    background: var(--dark);      /* fundo azul escuro */
    color: #fff;                  /* texto branco */
}

.btn-light {
    background: #fff;             /* fundo branco */
    color: var(--dark);           /* texto azul escuro */
    border-color: var(--line);    /* borda cinza */
}

.btn-dark-outline {
    background: transparent;      /* fundo transparente */
    color: var(--dark);           /* texto azul escuro */
    border-color: rgba(17, 24, 39, 0.16); /* borda escura suave */
}

.btn-dark-outline.inverse {
    color: #fff;                  /* texto branco */
    border-color: rgba(255,255,255,.3); /* borda branca translúcida */
}

.btn-white {
    background: #fff;             /* fundo branco */
    color: var(--dark);           /* texto azul escuro */
}

.full-width {
    width: 100%;                  /* ocupa a largura inteira disponível */
}

/* =========================================================
   ALERTAS / MENSAGENS
========================================================= */
.notice {
    margin: 18px 0 0;             /* espaço acima */
    padding: 14px 16px;           /* espaçamento interno */
    border-radius: 14px;          /* cantos arredondados */
    font-weight: 700;             /* texto forte */
}

.notice-success {
    background: var(--success-bg);/* fundo verde claro */
    color: var(--success);        /* texto verde */
    border: 1px solid #bbf7d0;    /* borda verde suave */
}

.notice-error {
    background: var(--error-bg);  /* fundo rosado */
    color: var(--error);          /* texto vinho/vermelho */
    border: 1px solid #fecdd3;    /* borda suave */
}

/* =========================================================
   HERO ANTIGO
========================================================= */
.hero-jll {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.86), rgba(255,255,255,0.72)), /* véu branco */
        radial-gradient(circle at top right, rgba(0,0,0,0.08), transparent 28%), /* brilho/sombra */
        linear-gradient(135deg, #eceff3 0%, #f8f9fb 52%, #e8ecef 100%); /* fundo em degradê */
    padding: 72px 0 54px;         /* espaço vertical */
}

.hero-jll-inner {
    display: grid;                /* layout em grid */
    grid-template-columns: 1.2fr .95fr; /* coluna esquerda maior que direita */
    gap: 38px;                    /* espaço entre colunas */
    align-items: center;          /* centraliza verticalmente */
}

.eyebrow,
.section-kicker {
    text-transform: uppercase;    /* deixa tudo maiúsculo */
    letter-spacing: .14em;        /* espaçamento entre letras */
    font-size: 12px;              /* tamanho pequeno */
    color: rgba(7, 16, 152, 0.55);/* azul suave */
    font-weight: 700;             /* peso forte */
}

.section-kicker.light {
    color: rgba(255,255,255,.75); /* versão clara para fundos escuros */
}

.hero-copy h1 {
    margin: 14px 0 18px;          /* espaçamento externo */
    font-size: clamp(42px, 6vw, 68px); /* tamanho responsivo */
    line-height: .98;             /* linhas bem compactas */
    letter-spacing: -0.045em;     /* letras um pouco mais próximas */
    max-width: 720px;             /* limita largura */
}

.hero-copy p {
    margin: 0;                    /* remove margem */
    max-width: 620px;             /* limita largura */
    color: #4b5563;               /* cinza */
    font-size: 18px;              /* tamanho do texto */
    line-height: 1.7;             /* espaçamento entre linhas */
}

/* =========================================================
   CARDS
========================================================= */
.hero-search-card,
.card-soft,
.card {
    background: rgba(255,255,255,0.9); /* fundo branco levemente translúcido */
    border: 1px solid rgba(17,24,39,.08); /* borda suave */
    border-radius: var(--radius); /* raio padrão */
    box-shadow: var(--shadow);    /* sombra padrão */
}

.hero-search-card {
    padding: 18px;                /* espaçamento interno */
}

/* =========================================================
   ABAS E PÍLULAS
========================================================= */
.search-tabs {
    display: flex;                /* itens em linha */
    gap: 10px;                    /* espaço entre eles */
    flex-wrap: wrap;              /* quebra linha se precisar */
    margin-bottom: 16px;          /* espaço abaixo */
}

.search-tabs span {
    padding: 10px 14px;           /* espaço interno */
    border-radius: 999px;         /* estilo pílula */
    background: rgba(30,147,242,0.10); /* fundo azul claro */
    color: rgba(7, 16, 152, 0.55);/* texto azul suave */
    font-size: 13px;              /* tamanho da fonte */
    font-weight: 700;             /* peso forte */
}

.search-tabs span.active {
    background: var(--dark);      /* aba ativa azul escuro */
    color: #fff;                  /* texto branco */
}

.search-tabs span:hover {
    outline: 2px solid rgba(30,147,242,.25); /* contorno ao passar mouse */
}

.pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 14px;
    border-radius: 999px;
    background: #f3f4f6;
    color: #4b5563;
    font-size: 13px;
    font-weight: 800;
    border: 1px solid rgba(7,16,152,0.10);
}

.pill:hover {
    background: #eef2ff;
    color: var(--dark);
    border-color: rgba(7,16,152,0.22);
}

.pill.active {
    background: var(--dark);
    color: #fff;
    border-color: var(--dark);
}

.tab-strip {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(7,16,152,0.14);
    font-weight: 800;
    color: var(--dark);
}

.tab:hover {
    background: #eef2ff;
}

.tab.active {
    background: var(--dark);
    color: #fff;
    border-color: var(--dark);
}

/* =========================================================
   BUSCA
========================================================= */
.search-main-row {
    display: grid;                /* usa grid */
    grid-template-columns: 1fr auto; /* campo ocupa o resto, botão tamanho natural */
    gap: 12px;                    /* espaço entre os dois */
    align-items: end;             /* alinha pela base */
}

.search-sub-row {
    display: grid;                /* grid secundário */
    grid-template-columns: repeat(3, 1fr); /* 3 colunas iguais */
    gap: 12px;                    /* espaço entre colunas */
    margin-top: 12px;             /* espaço acima */
}

.search-field label,
label {
    display: block;               /* label em linha própria */
    margin-bottom: 8px;           /* espaço abaixo */
    font-size: 13px;              /* tamanho pequeno */
    font-weight: 700;             /* peso forte */
    color: rgba(7, 16, 152, 0.55);/* azul suave */
}

input,
select,
textarea {
    width: 100%;                  /* ocupa toda largura disponível */
    padding: 14px 16px;           /* espaço interno */
    border: 1px solid var(--line);/* borda cinza */
    border-radius: 14px;          /* cantos arredondados */
    background: #fff;             /* fundo branco */
    color: var(--text);           /* texto principal */
    outline: none;                /* remove borda padrão azul do navegador */
}

textarea {
    resize: vertical;             /* só permite redimensionar verticalmente */
}

/* =========================================================
   SEÇÕES GERAIS
========================================================= */
.section {
    padding: 58px 0;              /* espaço vertical padrão */
}

.section-light,
.page-intro {
    background: #f8f9fb;          /* fundo claro */
    border-top: 1px solid rgba(17,24,39,.06); /* borda superior sutil */
    border-bottom: 1px solid rgba(17,24,39,.06); /* borda inferior sutil */
}

.page-intro {
    padding: 44px 0 36px;         /* espaço personalizado */
}

.page-intro h1,
.section-header h2,
.content-block h2 {
    margin: 10px 0 12px;
    font-size: clamp(30px, 4vw, 44px);
    line-height: 1.05;
    letter-spacing: -0.04em;
}

.page-intro p,
.section-header p,
.content-block p {
    color: rgba(7, 16, 152, 0.55);
    line-height: 1.7;
}

.compact-top {
    padding-top: 28px;            /* reduz espaço no topo */
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 22px;
    margin-bottom: 24px;
}

.section-header.narrow-gap {
    margin-bottom: 18px;          /* versão com menos espaço abaixo */
}

.text-link {
    font-weight: 700;
    color: var(--dark);
}

.tiny-label {
    color: rgba(7, 16, 152, 0.55);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 6px;
}

/* =========================================================
   CATEGORIAS
========================================================= */
.category-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 colunas iguais */
    gap: 16px;
}

.category-strip a {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 18px 20px;
    font-weight: 700;
    box-shadow: var(--shadow);
}

/* =========================================================
   LISTAGENS DE IMÓVEIS
========================================================= */
.listing-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 colunas */
    gap: 22px;
}

.listing-grid-compact {
    grid-template-columns: repeat(3, 1fr); /* 3 colunas */
}

.listing-card {
    background: #fff;
    border: 1px solid rgba(17,24,39,.08);
    border-radius: 24px;
    overflow: hidden;             /* corta excesso interno */
    box-shadow: var(--shadow);
}

.listing-card-large {
    display: grid;
    grid-template-columns: .95fr 1.05fr; /* mídia de um lado, conteúdo do outro */
}

.listing-media {
    background: linear-gradient(135deg, #d8dde3, #edf1f5); /* fundo de fallback */
    min-height: 100%;
}

.listing-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;            /* imagem cobre o espaço */
    min-height: 260px;            /* altura mínima */
}

.listing-media.small img {
    min-height: 220px;            /* altura menor em cards menores */
}

.listing-body {
    padding: 24px;                /* espaço interno do conteúdo */
}

.listing-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.listing-tags span {
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(30,147,242,0.10);
    font-size: 12px;
    font-weight: 700;
    color: #374151;
}

.listing-tags.simple {
    margin-bottom: 10px;
}

.listing-body h3 {
    margin: 0 0 10px;
    font-size: 28px;
    line-height: 1.08;
    letter-spacing: -0.03em;
}

.listing-location {
    color: rgba(7, 16, 152, 0.55);
    margin: 0 0 14px;
}

.listing-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    color: #374151;
    margin-bottom: 18px;
}

.listing-stats.minimal {
    margin-bottom: 0;
    color: rgba(7, 16, 152, 0.55);
}

.listing-footer {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: end;
}

.listing-footer strong,
.property-price-box strong {
    font-size: 28px;
    letter-spacing: -0.03em;
}

.listing-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

/* =========================================================
   CATÁLOGO E DETALHE DE IMÓVEL
========================================================= */
.catalog-layout {
    display: grid;
    grid-template-columns: 320px 1fr; /* sidebar fixa + conteúdo */
    gap: 26px;
    align-items: start;
}

.catalog-sidebar,
.property-aside .sticky-box,
.contact-layout .card-soft,
.property-stage,
.content-block {
    padding: 22px;
}

.filter-stack {
    display: grid;
    gap: 14px;
}

.property-intro-grid {
    display: grid;
    grid-template-columns: 1fr 320px; /* texto + box lateral */
    gap: 22px;
    align-items: end;
}

.property-price-box {
    background: #fff;
    border: 1px solid var(--line);
    padding: 22px;
    border-radius: 22px;
    box-shadow: var(--shadow);
}

.property-layout {
    display: grid;
    grid-template-columns: 1.15fr .72fr; /* palco principal + coluna lateral */
    gap: 26px;
    align-items: start;
}

.property-stage img {
    width: 100%;
    height: 560px;
    object-fit: cover;
    border-radius: 18px;
}

.thumb-strip {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); /* miniaturas automáticas */
    gap: 10px;
    margin-top: 14px;
}

.thumb-button {
    background: transparent;
    border: 0;
    padding: 0;
    cursor: pointer;
}

.thumb-button img {
    width: 100%;
    height: 82px;
    object-fit: cover;
    border-radius: 12px;
    border: 2px solid transparent;
}

.thumb-button:hover img {
    border-color: #111827;        /* destaque da miniatura no hover */
}

.media-section {
    margin-top: 28px;
}

.video-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 vídeos por linha */
    gap: 18px;
}

.video-frame {
    padding: 0;
    overflow: hidden;
}

.video-frame iframe {
    width: 100%;
    height: 280px;
    border: 0;
}

.data-list {
    display: grid;
    gap: 14px;
    margin: 18px 0 24px;
}

.data-list.spaced {
    margin: 22px 0 0;
}

.data-list div {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--line);
}

.data-list span {
    color: rgba(7, 16, 152, 0.55);
}

.sticky-box {
    position: sticky;
    top: 110px;                   /* distância do topo ao fixar */
}

.top-space {
    margin-top: 14px;
}

.property-content-grid,
.contact-layout {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 colunas */
    gap: 22px;
}

.content-block h2 {
    font-size: 32px;
}

/* =========================================================
   CTA
========================================================= */
.cta-band {
    background: linear-gradient(135deg, #071098, #1E93F2); /* faixa em degradê azul */
    color: #fff;
}

.cta-band-inner {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: center;
}

.cta-band h2 {
    margin: 10px 0 10px;
    font-size: clamp(28px, 3.8vw, 42px);
    letter-spacing: -0.03em;
}

.cta-band p {
    color: rgba(255,255,255,.72);
}

.cta-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* =========================================================
   FOOTER
========================================================= */
.footer-dark {
    background: #071098;
    color: #ffffff;
    margin-top: 44px;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr; /* coluna maior + duas menores */
    gap: 22px;
    padding: 34px 0;
}

.footer-dark p,
.footer-dark a {
    color: rgba(255,255,255,.74);
}

/* =========================================================
   ADMIN
========================================================= */
.admin-bar {
    position: sticky;
    top: 0;
}

.admin-layout {
    display: grid;
    grid-template-columns: 270px 1fr; /* sidebar + conteúdo */
    min-height: calc(100vh - 82px);   /* altura da tela menos topo */
}

.sidebar {
    background: #071098;
    color: #fff;
    padding: 24px;
}

.sidebar a {
    display: block;
    padding: 12px 14px;
    border-radius: 12px;
    color: rgba(255,255,255,.86);
    margin-bottom: 8px;
}

.sidebar a:hover {
    background: rgba(255,255,255,.08);
}

.admin-content {
    padding: 26px;
}

.admin-page-header,
.page-header {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: end;
    margin-bottom: 22px;
}

.page-header h1 {
    margin: 0;
    font-size: 36px;
    letter-spacing: -0.04em;
}

.page-header p {
    margin: 8px 0 0;
    color: rgba(7, 16, 152, 0.55);
}

.stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-bottom: 24px;
}

.stat-box {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 20px;
    padding: 22px;
}

.table-wrap {
    overflow: auto;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 20px;
}

table {
    width: 100%;
    border-collapse: collapse;
}

th,
td {
    padding: 15px 16px;
    border-bottom: 1px solid var(--line);
    text-align: left;
}

th {
    background: #f8f9fb;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.form-grid .full {
    grid-column: 1 / -1;          /* ocupa as duas colunas */
}

.login-box {
    width: min(460px, 92%);
    margin: 60px auto;
    padding: 26px;
}

.helper-text {
    color: rgba(7, 16, 152, 0.55);
    font-size: 13px;
    margin-top: 8px;
}

.empty {
    background: #fff;
    border: 1px dashed var(--line);
    border-radius: 20px;
    padding: 26px;
}

.admin-media-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.admin-media-card {
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
}

.admin-media-card img,
.video-placeholder {
    width: 100%;
    height: 160px;
    object-fit: cover;
    background: linear-gradient(135deg, #dce2e8, #eef2f7);
}

.video-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #111827;
}

.admin-media-card small {
    display: block;
    padding: 0 14px 14px;
    color: rgba(7, 16, 152, 0.55);
    word-break: break-all;
}

.admin-media-meta {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    font-size: 14px;
}

/* =========================================================
   HERO DE BUSCA ESTILO JLL / NEW LATINA
========================================================= */
.hero-search-only {
    position: relative;           /* base para elementos absolutos */
    overflow: hidden;             /* corta o que sair da área */
    background: linear-gradient(180deg,#f6f8fc 0%,#eef4ff 100%); /* fundo degradê */
    min-height: calc(100vh - 140px); /* quase tela cheia */
    display: flex;
    align-items: center;
}

.hero-search-shell {
    position: relative;
    z-index: 2;                   /* conteúdo acima do mapa decorativo */
    padding-top: 72px;
    padding-bottom: 72px;
}

.hero-search-copy {
    max-width: 760px;
    margin-bottom: 28px;
}

.hero-search-copy h1 {
    margin: 0 0 16px;
    font-size: clamp(38px,5vw,64px);
    line-height: 1.02;
    letter-spacing: -.045em;
    color: #08112c;
    max-width: 980px;
}

.hero-search-copy p {
    margin: 0;
    color: #5f6c8d;
    font-size: 18px;
    line-height: 1.7;
    max-width: 740px;
}

.hero-search-card-jll {
    max-width: 980px;
    padding: 22px;
    border-radius: 22px;
    border: 1px solid rgba(7,16,152,.08);
    box-shadow: 0 18px 45px rgba(7,16,152,.10);
    background: rgba(255,255,255,.92);
}

.hero-search-form-jll .search-line-single {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 14px;
    align-items: center;
}

.search-field-hero input {
    height: 76px;
    padding: 0 24px;
    border-radius: 16px;
    border: 1px solid rgba(7,16,152,.12);
    font-size: 24px;
    color: #30405f;
    background: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

.search-field-hero input::placeholder {
    color: #8190b0;
}

.btn-search-primary {
    height: 76px;
    padding: 0 28px;
    border-radius: 16px;
    background: linear-gradient(135deg,#081098 0%, #1e93f2 100%);
    color: #fff;
    font-size: 18px;
    font-weight: 800;
    box-shadow: 0 14px 28px rgba(7,16,152,.22);
}

.btn-search-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(7,16,152,.26);
}

.search-suggestion-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.search-hint {
    font-size: 13px;
    font-weight: 800;
    color: #6c7896;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.suggestion-chip {
    border: 0;
    background: #eef3ff;
    color: var(--dark);
    padding: 10px 14px;
    border-radius: 999px;
    font-weight: 700;
    cursor: pointer;
    transition: .2s ease;
}

.suggestion-chip:hover {
    background: #dde8ff;
    transform: translateY(-1px);
}

.hero-search-footnote {
    margin-top: 18px;
    color: #6f7c99;
    font-weight: 600;
}

/* =========================================================
   HERO NOVO
========================================================= */
.hero-jll-newlatina {
    position: relative;
    background: linear-gradient(160deg, #f8faff 0%, #f2f6fd 55%, #e9eef8 100%);
    min-height: 50vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.hero-jll-wrap {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 40px;
    align-items: center;
    min-height: 50vh;
    position: relative;
    z-index: 2;
}

.hero-jll-left {
    max-width: 760px;
}

.hero-brand-mini {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.20em;
    color: #6b82b0;           /* azul-acinzentado — menos saturado */
    margin-bottom: 12px;
    text-transform: uppercase;
}

.hero-jll-left h1 {
    font-size: 36px;
    line-height: 1.12;
    font-weight: 300;         /* leveza editorial — corporativo premium */
    color: #0d1b3e;           /* azul-marinho escuro, mais sóbrio */
    margin: 0 0 20px;
    max-width: 640px;
    letter-spacing: -0.01em;
}

.hero-category-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
}

.hero-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 16px;
    border-radius: 6px;
    background: transparent;
    color: #4a5f82;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    border: 1px solid #c8d6ea;
    transition: border-color .2s ease, color .2s ease, background .2s ease;
}

.hero-tab:hover {
    border-color: #071098;
    color: #071098;
    background: rgba(7,16,152,.04);
}

.hero-tab.active {
    background: #071098;
    color: #ffffff;
    border-color: #071098;
}

.hero-jll-search {
    width: 100%;
}

.hero-jll-search-box {
    background: #ffffff;
    border-radius: 10px;
    padding: 10px 10px 10px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid #d0dcee;
    box-shadow: 0 4px 24px rgba(13,27,62,.07);
}

.hero-jll-input-wrap {
    flex: 1;
}

.hero-jll-input-wrap input {
    width: 100%;
    height: 52px;
    border: none;
    outline: none;
    background: transparent;
    font-size: 20px;
    color: #1b2430;
    padding: 0 12px;
}

.hero-jll-input-wrap input::placeholder {
    color: #7b8798;
}

.hero-jll-btn {
    height: 46px;
    border: none;
    border-radius: 7px;
    background: #071098;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .03em;
    padding: 0 28px;
    cursor: pointer;
    white-space: nowrap;
    transition: background .2s ease, box-shadow .2s ease;
    box-shadow: 0 4px 14px rgba(7,16,152,.22);
    flex-shrink: 0;
}

.hero-jll-btn:hover {
    background: #0a18c0;
    box-shadow: 0 6px 20px rgba(7,16,152,.30);
}

.hero-jll-suggestions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.hero-chip {
    border: 1px solid #cdd8ea;
    background: transparent;
    color: #4a5f82;
    border-radius: 4px;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: border-color .2s ease, color .2s ease;
}

.hero-chip:hover {
    border-color: #071098;
    color: #071098;
}

.hero-jll-right {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 520px;
    position: relative;
}

.hero-after-search-spacer {
    height: 0;
    background: transparent;
}

/* =========================================================
   BOTÃO FLUTUANTE DO WHATSAPP
========================================================= */
.floating-whatsapp {
    position: fixed;              /* fica preso à tela */
    right: 24px;                  /* distância da direita */
    bottom: 24px;                 /* distância do fundo */
    width: 68px;                  /* largura do botão */
    height: 68px;                 /* altura do botão */
    border-radius: 999px;         /* círculo */
    background: var(--wa);        /* verde do WhatsApp */
    color: #fff;                  /* ícone branco */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 16px 30px rgba(0,0,0,.18);
    z-index: 70;                  /* acima do resto */
    transition: transform .2s ease, box-shadow .2s ease;
}

.floating-whatsapp svg {
    width: 34px;
    height: 34px;
    display: block;
}

.floating-whatsapp:hover {
    transform: translateY(-2px) scale(1.03);
    box-shadow: 0 22px 34px rgba(0,0,0,.22);
}

/* =========================================================
   RESPONSIVO
========================================================= */
@media (max-width: 1200px) {
    .hero-jll-left h1 {
        font-size: 34px;
    }
}

@media (max-width: 1100px) {
    .hero-jll-inner,
    .listing-card-large,
    .catalog-layout,
    .property-layout,
    .property-intro-grid,
    .property-content-grid,
    .contact-layout,
    .footer-grid,
    .admin-layout,
    .cta-band-inner {
        grid-template-columns: 1fr; /* tudo vira 1 coluna */
        display: grid;
    }

    .sticky-box {
        position: static;         /* remove sticky em telas menores */
    }

    .property-stage img {
        height: 420px;            /* reduz altura da imagem principal */
    }

    .video-grid,
    .listing-grid-compact,
    .listing-grid,
    .category-strip,
    .admin-media-grid,
    .stats,
    .form-grid,
    .search-sub-row {
        grid-template-columns: 1fr 1fr; /* cai para 2 colunas */
    }
}

@media (max-width: 992px) {
    .hero-jll-wrap {
        grid-template-columns: 1fr; /* hero vira 1 coluna */
        min-height: auto;
        padding-top: 44px;
        padding-bottom: 44px;
    }

    .hero-jll-right {
        display: none;            /* esconde bloco da direita */
    }

    .hero-jll-left h1 {
        font-size: 30px;
    }
}

@media (max-width: 980px) {
    .hero-search-only {
        min-height: auto;         /* hero deixa de ocupar tela inteira */
    }

    .hero-search-copy h1 {
        font-size: clamp(32px,9vw,48px);
    }

    .hero-search-form-jll .search-line-single {
        grid-template-columns: 1fr; /* campo e botão empilham */
    }

    .btn-search-primary,
    .search-field-hero input {
        height: 64px;
        font-size: 18px;
    }

    .hero-search-map {
        width: 70vw;
        height: 80vw;
        right: -15%;
        top: 12%;
        opacity: .15;
    }
}

@media (max-width: 768px) {
    .topbar-inner {
        flex-direction: column;   /* empilha conteúdo da topbar */
        align-items: flex-start;
        gap: 10px;
    }

    .topbar-actions {
        width: 100%;
        justify-content: space-between;
        gap: 12px;
    }

    .nav-wrap {
        min-height: 74px;         /* aumenta um pouco a navbar no mobile */
    }

    .brand-full-img {
        height: 56px;             /* logo maior no mobile */
    }

    .menu-site {
        gap: 16px;
    }

    .hero-search-shell {
        padding-top: 40px;
        padding-bottom: 48px;
    }

    .hero-search-card-jll {
        padding: 16px;
        border-radius: 18px;
    }

    .search-tabs {
        gap: 8px;
    }

    .pill {
        padding: 10px 12px;
        font-size: 12px;
    }

    .search-suggestion-row {
        gap: 8px;
    }

    .suggestion-chip {
        padding: 8px 12px;
        font-size: 13px;
    }

    .floating-whatsapp {
        width: 60px;
        height: 60px;
        right: 18px;
        bottom: 18px;
    }

    .hero-jll-newlatina {
        min-height: auto;
    }

    .hero-jll-left h1 {
        font-size: 26px;
    }

    .hero-jll-search-box {
        flex-direction: column;
        align-items: stretch;
        padding: 12px;
    }

    .hero-jll-input-wrap input {
        height: 48px;
        font-size: 16px;
        padding: 0 8px;
    }

    .hero-jll-btn {
        width: 100%;
        height: 48px;
        font-size: 15px;
    }

    .hero-tab {
        padding: 8px 14px;
        font-size: 13px;
    }
}

@media (max-width: 760px) {
    .nav-wrap,
    .section-header,
    .page-header,
    .listing-footer,
    .cta-band-inner {
        flex-direction: column;   /* empilha blocos flex */
        align-items: start;
    }

    .hero-copy h1 {
        font-size: 42px;
    }

    .search-main-row,
    .search-sub-row,
    .video-grid,
    .listing-grid,
    .listing-grid-compact,
    .category-strip,
    .property-content-grid,
    .contact-layout,
    .stats,
    .form-grid,
    .admin-media-grid {
        grid-template-columns: 1fr; /* tudo em 1 coluna */
    }

    .property-stage img {
        height: 320px;
    }

    .menu {
        gap: 10px;
    }

    .container {
        width: min(1240px, 94%);
    }
}

/* =========================================================
   MAPA/IMAGEM DECORATIVA DO HERO
========================================================= */
.hero-search-map {
    position: absolute;
    right: 4%;
    top: 50%;
    /* translateY centraliza; scale aumenta visualmente sem empurrar layout */
    transform: translateY(-50%) scale(1.40);
    transform-origin: center center;
    width: min(22vw, 320px);
    opacity: .12;                 /* levemente mais visível para compensar o scale */
    pointer-events: none;
    z-index: 1;
}

.hero-search-map img {
    width: 100%;                  /* imagem ocupa toda a largura do bloco */
    height: auto;                 /* mantém proporção */
    display: block;               /* remove espaços de inline */
}

@media (max-width: 980px) {
    .hero-search-map {
        width: min(52vw, 360px);  /* reduz no tablet */
        right: -2%;               /* joga um pouco para a direita */
        top: 58%;                 /* ajusta verticalmente */
        opacity: .10;             /* ainda mais discreto */
    }
}

@media (max-width: 768px) {
    .hero-search-map {
        display: none;            /* esconde no mobile */
    }
}
/* =========================================================
   LOGO PAG ADMIN
========================================================= */
.admin-login-logo{
    position: fixed;
    top: 24px;
    left: 24px;
    z-index: 999;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.admin-login-logo img{
    height: 46px;
    width: auto;
    display: block;
    object-fit: contain;
}

.admin-login-toplink{
    position: fixed;
    top: 28px;
    right: 24px;
    z-index: 999;
}

.admin-login-toplink a{
    color: var(--dark);
    font-weight: 700;
    text-decoration: none;
}

/* =========================================================
   REGRA GLOBAL DEFENSIVA — SVG
   Impede que SVGs sem height explícito cresçam além do container.
   Os ícones usam width/height como atributos HTML; isto é uma
   segunda linha de defesa.
========================================================= */
svg {
    overflow: hidden;
    vertical-align: middle;
    flex-shrink: 0;
}

/* =========================================================
   SEÇÃO IMÓVEIS EM DESTAQUE
========================================================= */

.destaques {
    padding: 56px 0 72px;
    position: relative;
    z-index: 2;
    background: #ffffff;
    border-radius: 20px 20px 0 0;
    margin-top: -20px;
    box-shadow: 0 -8px 40px rgba(13,27,62,.08);
}

.destaques__cabecalho {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}

.destaques__label {
    margin: 0 0 6px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #6b82b0;
}

.destaques__titulo {
    margin: 0;
    font-size: clamp(20px, 2.8vw, 28px);
    font-weight: 600;
    color: #0d1b3e;
    letter-spacing: -.02em;
    line-height: 1.2;
}

.destaques__ver-todos {
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 500;
    color: #4a5f82;
    border-color: #c8d6ea;
}

/* ── Carrossel automático de cards ───────────────────────── */

.destaques__carrossel {
    position: relative;
    overflow: hidden;
    /* fade nas bordas para suavizar entrada/saída */
    -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 7%, #000 93%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, #000 7%, #000 93%, transparent 100%);
}

.destaques__track {
    display: flex;
    gap: 24px;
    width: max-content;
    animation: destaques-scroll 70s linear infinite;
    will-change: transform;
}

/* pausa ao hover em qualquer card da faixa */
.destaques__track:hover {
    animation-play-state: paused;
}

@keyframes destaques-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* largura fixa + estado padrão discreto (recuado levemente) */
.destaques__track .ci-card {
    flex: 0 0 340px;
    width: 340px;
    transform: scale(0.97);
    opacity: 0.92;
    transition: opacity 300ms ease, transform 300ms ease, box-shadow 300ms ease;
}

/* quando qualquer card está em hover, os demais recuam mais */
.destaques__track:hover .ci-card {
    opacity: 0.72;
    transform: scale(0.96);
}

/* card em foco: avança com escala elegante — sem exagero */
.destaques__track .ci-card:hover,
.destaques__track:hover .ci-card:hover {
    opacity: 1;
    transform: scale(1.04);
    box-shadow: 0 20px 48px rgba(13,27,62,.18);
    position: relative;
    z-index: 5;
}

@media (max-width: 580px) {
    .destaques { padding: 36px 0 52px; border-radius: 14px 14px 0 0; }
    .destaques__track { gap: 16px; }
    .destaques__track .ci-card { flex: 0 0 280px; width: 280px; }
    .destaques__ver-todos { display: none; }
}

/* =========================================================
   CARD DE IMÓVEL  (.ci-card)
   Todos os SVGs têm width/height como atributo HTML.
   O CSS aqui é a segunda linha de defesa.
========================================================= */

.ci-card {
    background: var(--surface);
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 1px 6px rgba(13,27,62,.06), 0 4px 16px rgba(13,27,62,.04);
    border: 1px solid #eaeff8;
    transition: transform .30s ease, box-shadow .30s ease, opacity .30s ease;
    height: 100%;
}

/* fora do carrossel, hover simples */
.ci-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(13,27,62,.12);
}

/* ── Topo — imagem + todos os overlays ───────────────────── */

.ci-card__topo {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: var(--surface-alt);
    flex-shrink: 0;
}

.ci-card__img-link {
    display: block;
    width: 100%;
    height: 100%;
}

.ci-card__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}

.ci-card:hover .ci-card__img {
    transform: scale(1.03);
}

/* Skeleton shimmer */
.ci-card__skeleton {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, var(--surface-alt) 25%, #dde0e6 50%, var(--surface-alt) 75%);
    background-size: 200% 100%;
    animation: ci-shimmer 1.4s ease infinite;
    pointer-events: none;
    transition: opacity .3s ease;
    z-index: 1;
}

.ci-card__skeleton.oculto { opacity: 0; }

@keyframes ci-shimmer {
    0%   { background-position:  200% 0; }
    100% { background-position: -200% 0; }
}

/* Gradiente inferior — legibilidade do preço */
.ci-card__topo::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
        rgba(8, 12, 30, .88) 0%,
        rgba(8, 12, 30, .28) 42%,
        transparent 64%
    );
    pointer-events: none;
    z-index: 2;
    transition: opacity .3s ease;
}

.ci-card:hover .ci-card__topo::after {
    background: linear-gradient(to top,
        rgba(8, 12, 30, .94) 0%,
        rgba(8, 12, 30, .36) 46%,
        transparent 66%
    );
}

/* ── Badge código ─────────────────────────────────────────── */

.ci-cod {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 3;
    background: rgba(8,12,30,.55);
    backdrop-filter: blur(8px);
    color: rgba(255,255,255,.85);
    font-size: 9px;
    font-weight: 600;
    letter-spacing: .06em;
    padding: 3px 8px;
    border-radius: 3px;
    line-height: 1.5;
    white-space: nowrap;
}

/* ── Botão favorito ───────────────────────────────────────── */

.ci-fav {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 3;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    padding: 0;
    background: rgba(255, 255, 255, .88);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #94a3b8;
    transition: color .2s ease, transform .2s ease, background .2s ease;
}

.ci-fav svg {
    width: 16px;
    height: 16px;
    pointer-events: none;
    transition: fill .2s ease;
}

.ci-fav:hover          { color: #ef4444; transform: scale(1.18); background: #fff; }
.ci-fav--ativo         { color: #ef4444; }
.ci-fav--ativo svg     { fill: #ef4444; }

/* ── Pill "Ver detalhes" — hover sobre a imagem ──────────── */

.ci-card__ver-mais {
    position: absolute;
    bottom: 58px;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    z-index: 4;
    opacity: 0;
    pointer-events: none;
    background: rgba(255,255,255,.96);
    color: #0d1b3e;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .04em;
    padding: 6px 20px;
    border-radius: 4px;
    white-space: nowrap;
    box-shadow: 0 4px 20px rgba(0,0,0,.14);
    transition: opacity .25s ease, transform .25s ease;
    text-decoration: none;
}

.ci-card:hover .ci-card__ver-mais {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

/* ── Faixa de preço — sobre o gradiente inferior ─────────── */

.ci-card__preco-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 3;
    padding: 8px 14px 14px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ci-card__finalidade {
    font-size: 9px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .60);
}

.ci-card__preco {
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    letter-spacing: -.03em;
    line-height: 1.1;
}

/* ── Corpo — textos ──────────────────────────────────────── */

.ci-card__corpo {
    padding: 14px 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
}

.ci-card__tipo {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--accent);
    opacity: .80;
}

.ci-card__titulo {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.45;
    color: #0d1b3e;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ci-card__titulo a      { color: inherit; text-decoration: none; }
.ci-card__titulo a:hover { color: var(--accent); }

.ci-card__local {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: #8496b0;
}

.ci-card__local svg { color: #8496b0; }

.ci-sep { color: #c8d4e4; margin: 0 1px; }

.ci-card__desc {
    margin: 0;
    font-size: 11px;
    color: #8496b0;
    line-height: 1.65;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ── Specs ───────────────────────────────────────────────── */

.ci-specs {
    list-style: none;
    margin: 6px 0 0;
    padding: 10px 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px 14px;
    border-top: 1px solid #eaf0f8;
}

.ci-spec {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 600;
    color: #3d5070;
}

.ci-spec svg { color: #8496b0; }

/* =========================================================
   PÁGINA DE IMÓVEIS — topo
========================================================= */

.imoveis-topo {
    background: linear-gradient(160deg, #f8faff 0%, #f0f5fc 100%);
    border-bottom: 1px solid #e4ecf6;
    padding: 36px 0 0;
}

.imoveis-topo__inner {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    padding-bottom: 20px;
}

.imoveis-topo__kicker {
    display: block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #6b82b0;
    margin-bottom: 6px;
}

.imoveis-topo__titulo {
    margin: 0;
    font-size: clamp(20px, 2.8vw, 28px);
    font-weight: 600;
    color: #0d1b3e;
    letter-spacing: -.02em;
}

/* ── Tabs de categoria ───────────────────────────────────── */

.imoveis-tabs {
    display: flex;
    gap: 0;
    margin-top: 4px;
}

.imoveis-tab {
    padding: 12px 22px;
    font-size: 13px;
    font-weight: 600;
    color: #4a5f82;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: color .2s ease, border-color .2s ease;
    white-space: nowrap;
}

.imoveis-tab:hover        { color: #071098; }
.imoveis-tab.active       { color: #071098; border-bottom-color: #071098; }

/* =========================================================
   PÁGINA DE IMÓVEIS — corpo
========================================================= */

.imoveis-corpo {
    padding: 36px 0 80px;
    background: #f2f5fb;
}

.imoveis-layout {
    display: grid;
    grid-template-columns: 268px 1fr;
    gap: 28px;
    align-items: start;
}

/* ── Filtros ─────────────────────────────────────────────── */

.imoveis-filtros {
    background: #ffffff;
    border: 1px solid #e4ecf6;
    border-radius: 10px;
    padding: 22px 18px;
    position: sticky;
    top: 88px;
}

.filtros-titulo {
    margin: 0 0 16px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #6b82b0;
}

.filtros-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.filtros-campo label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: #4a5f82;
    margin-bottom: 4px;
    letter-spacing: .03em;
}

.filtros-campo input,
.filtros-campo select {
    width: 100%;
    height: 38px;
    border: 1px solid #d0dcee;
    border-radius: 6px;
    padding: 0 10px;
    font-size: 13px;
    color: #0d1b3e;
    background: #f8faff;
    outline: none;
    transition: border-color .2s ease, background .2s ease;
    box-sizing: border-box;
    appearance: auto;
}

.filtros-campo input:focus,
.filtros-campo select:focus {
    border-color: #071098;
    background: #fff;
}

.filtros-btn {
    height: 40px;
    border: none;
    border-radius: 6px;
    background: #071098;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s ease;
    margin-top: 4px;
    letter-spacing: .03em;
}

.filtros-btn:hover { background: #0a18c0; }

.filtros-limpar {
    display: block;
    text-align: center;
    font-size: 12px;
    color: #8496b0;
    text-decoration: none;
    margin-top: -4px;
    transition: color .2s ease;
}

.filtros-limpar:hover { color: #071098; }

/* ── Topo dos resultados ─────────────────────────────────── */

.imoveis-resultados__topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

.imoveis-contagem {
    margin: 0;
    font-size: 13px;
    color: #4a5f82;
}

.imoveis-contagem strong {
    color: #0d1b3e;
    font-size: 15px;
    font-weight: 700;
}

/* ── Grid de cards ───────────────────────────────────────── */

.imoveis-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

/* hover elegante na listagem — scale sem empurrar vizinhos */
.imoveis-grid .ci-card {
    transition: transform .28s ease, box-shadow .28s ease, opacity .28s ease;
}

.imoveis-grid:hover .ci-card {
    opacity: .88;
}

.imoveis-grid:hover .ci-card:hover {
    opacity: 1;
    transform: scale(1.03);
    box-shadow: 0 16px 44px rgba(13,27,62,.15);
    position: relative;
    z-index: 2;
}

/* ── Estado vazio ────────────────────────────────────────── */

.imoveis-vazio {
    padding: 64px 24px;
    text-align: center;
    color: #4a5f82;
    background: #ffffff;
    border: 1px solid #e4ecf6;
    border-radius: 10px;
    font-size: 14px;
}

.imoveis-vazio a {
    display: inline-block;
    margin-top: 14px;
    color: #071098;
    font-weight: 600;
    text-decoration: none;
}

.imoveis-vazio a:hover { text-decoration: underline; }

/* ── Responsivo ──────────────────────────────────────────── */

@media (max-width: 1100px) {
    .imoveis-layout { grid-template-columns: 230px 1fr; gap: 20px; }
}

@media (max-width: 860px) {
    .imoveis-layout           { grid-template-columns: 1fr; }
    .imoveis-filtros          { position: static; }
    .imoveis-grid             { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}

@media (max-width: 560px) {
    .imoveis-grid             { grid-template-columns: 1fr; gap: 14px; }
    .imoveis-topo__inner      { flex-direction: column; align-items: flex-start; }
    .imoveis-topo__inner .btn { display: none; }
    .imoveis-tabs             { overflow-x: auto; }
    .imoveis-tab              { padding: 10px 16px; }
}

/* =========================================================
   PÁGINA QUEM SOMOS
========================================================= */

/* ── Animação base (fade-up) ─────────────────────────────── */
[data-animate="fade-up"] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .55s ease, transform .55s ease;
}
[data-animate="fade-up"].anim-visivel {
    opacity: 1;
    transform: translateY(0);
}

/* ── Kicker reutilizável ─────────────────────────────────── */
.section-kicker-sobre {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: #1e93f2;
    margin-bottom: 12px;
}

.sobre-h2 {
    margin: 0 0 20px;
    font-size: clamp(22px, 3vw, 30px);
    font-weight: 600;
    color: #0d1b3e;
    letter-spacing: -.02em;
    line-height: 1.2;
}

.sobre-section-header {
    text-align: center;
    max-width: 560px;
    margin: 0 auto 52px;
}

.sobre-section-header .sobre-h2 { margin-bottom: 0; }

/* =========================================================
   HERO
========================================================= */
.sobre-hero {
    background: linear-gradient(145deg, #080f2e 0%, #0d1b3e 55%, #071098 100%);
    padding: 96px 0 88px;
    position: relative;
    overflow: hidden;
}

/* logo de marca como elemento gráfico de fundo animado */
.sobre-hero::after {
    content: '';
    position: absolute;
    right: -3%;
    top: 50%;
    transform: translateY(-50%);
    width: 640px;
    height: 640px;
    background-image: url('../brand/icon-newlatina.png');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center right;
    opacity: 0;                           /* começa invisível — animação assume */
    pointer-events: none;
    z-index: 0;
    animation: hero-logo-entrada 1400ms cubic-bezier(.22,.61,.36,1) 200ms forwards;
}

@keyframes hero-logo-entrada {
    from {
        opacity: 0;
        transform: translateY(-50%) translateX(48px) scale(.94);
    }
    to {
        opacity: 0.14;
        transform: translateY(-50%) translateX(0) scale(1);
    }
}

.sobre-hero__inner {
    display: block;                       /* coluna única — detalhe removido */
    max-width: 660px;
    position: relative;
    z-index: 1;
}

.sobre-hero__kicker {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(30,147,242,.85);
    margin-bottom: 18px;
}

.sobre-hero__titulo {
    margin: 0 0 20px;
    font-size: clamp(32px, 5vw, 52px);
    font-weight: 300;
    color: #ffffff;
    line-height: 1.1;
    letter-spacing: -.02em;
}

.sobre-hero__subtitulo {
    margin: 0 0 36px;
    font-size: 16px;
    color: rgba(255,255,255,.60);
    line-height: 1.7;
    max-width: 520px;
}

.sobre-hero__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: #1e93f2;
    color: #fff;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .03em;
    transition: background .2s ease;
    text-decoration: none;
}

.sobre-hero__cta:hover { background: #1a80d8; }

/* riscos decorativos removidos */

/* =========================================================
   SOBRE A EMPRESA
========================================================= */
.sobre-empresa {
    padding: 80px 0;
    background: #ffffff;
}

.sobre-empresa__grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 64px;
    align-items: start;
}

.sobre-empresa__texto p {
    margin: 0 0 16px;
    font-size: 15px;
    color: #3d5070;
    line-height: 1.75;
}

.sobre-empresa__destaque {
    margin-top: 28px;
    padding: 20px 24px;
    border-left: 3px solid #1e93f2;
    background: #f5f8ff;
    border-radius: 0 8px 8px 0;
}

.sobre-empresa__destaque blockquote {
    margin: 0 0 6px;
    font-size: 15px;
    font-style: italic;
    color: #0d1b3e;
    font-weight: 500;
    line-height: 1.6;
}

.sobre-empresa__destaque cite {
    font-size: 12px;
    color: #6b82b0;
    font-style: normal;
    font-weight: 600;
    letter-spacing: .04em;
}

/* missão / visão / valores */
.sobre-empresa__mv {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.sobre-mv-card {
    background: #f8faff;
    border: 1px solid #e4ecf6;
    border-radius: 10px;
    padding: 20px 20px 20px 18px;
    display: grid;
    grid-template-columns: 36px 1fr;
    grid-template-rows: auto auto;
    column-gap: 14px;
    row-gap: 4px;
    align-items: start;
    transition: box-shadow .25s ease, border-color .25s ease;
}

.sobre-mv-card:hover {
    border-color: #c0d4f0;
    box-shadow: 0 6px 24px rgba(13,27,62,.07);
}

.sobre-mv-card__icone {
    grid-row: 1 / 3;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: rgba(7,16,152,.07);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #071098;
    flex-shrink: 0;
}

.sobre-mv-card h4 {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    color: #0d1b3e;
    letter-spacing: .02em;
}

.sobre-mv-card p {
    margin: 0;
    font-size: 12px;
    color: #4a5f82;
    line-height: 1.65;
}

/* =========================================================
   DIFERENCIAIS
========================================================= */
.sobre-diferenciais {
    padding: 80px 0;
    background: #f2f5fb;
}

.sobre-diferenciais__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.sobre-dif-card {
    background: #ffffff;
    border: 1px solid #e4ecf6;
    border-radius: 10px;
    padding: 28px 24px;
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.sobre-dif-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(13,27,62,.10);
    border-color: #c0d4f0;
}

.sobre-dif-card__num {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    color: #1e93f2;
    margin-bottom: 14px;
}

.sobre-dif-card h3 {
    margin: 0 0 10px;
    font-size: 15px;
    font-weight: 700;
    color: #0d1b3e;
    letter-spacing: -.01em;
}

.sobre-dif-card p {
    margin: 0;
    font-size: 13px;
    color: #4a5f82;
    line-height: 1.7;
}

/* =========================================================
   NÚMEROS
========================================================= */
.sobre-numeros {
    padding: 72px 0;
    background: linear-gradient(135deg, #071098 0%, #0a1880 100%);
}

.sobre-numeros__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    text-align: center;
}

.sobre-num-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.sobre-num-item > * { line-height: 1; }

.sobre-num-valor {
    font-size: clamp(40px, 5vw, 56px);
    font-weight: 700;
    color: #ffffff;
    letter-spacing: -.03em;
    display: inline;
}

.sobre-num-sufixo {
    font-size: clamp(22px, 2.5vw, 30px);
    font-weight: 400;
    color: rgba(255,255,255,.55);
    margin-left: 3px;
    display: inline;
}

.sobre-num-label {
    margin: 14px 0 0;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,.50);
}

/* =========================================================
   PROCESSO
========================================================= */
.sobre-processo {
    padding: 80px 0;
    background: #ffffff;
}

.sobre-processo__trilha {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    position: relative;
}

/* linha conectora */
.sobre-processo__trilha::before {
    content: '';
    position: absolute;
    top: 24px;
    left: calc(12.5%);
    right: calc(12.5%);
    height: 1px;
    background: linear-gradient(to right, #1e93f2, #071098);
    z-index: 0;
}

.sobre-etapa {
    padding: 0 20px;
    text-align: center;
    position: relative;
    z-index: 1;
}

.sobre-etapa__num {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #071098;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    position: relative;
    z-index: 2;
    box-shadow: 0 0 0 6px #ffffff, 0 0 0 7px rgba(7,16,152,.15);
}

.sobre-etapa h4 {
    margin: 0 0 10px;
    font-size: 14px;
    font-weight: 700;
    color: #0d1b3e;
    letter-spacing: -.01em;
}

.sobre-etapa p {
    margin: 0;
    font-size: 13px;
    color: #4a5f82;
    line-height: 1.7;
}

/* =========================================================
   CTA FINAL
========================================================= */
.sobre-cta {
    padding: 80px 0;
    background: #f2f5fb;
    border-top: 1px solid #e4ecf6;
}

.sobre-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    flex-wrap: wrap;
}

.sobre-cta__titulo {
    margin: 0 0 8px;
    font-size: clamp(20px, 2.8vw, 26px);
    font-weight: 600;
    color: #0d1b3e;
    letter-spacing: -.02em;
}

.sobre-cta__sub {
    margin: 0;
    font-size: 14px;
    color: #4a5f82;
}

.sobre-cta__acoes {
    display: flex;
    gap: 12px;
    flex-shrink: 0;
    flex-wrap: wrap;
}

.sobre-cta__btn-primario {
    display: inline-flex;
    align-items: center;
    padding: 14px 28px;
    background: #071098;
    color: #fff;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .03em;
    transition: background .2s ease;
    white-space: nowrap;
}

.sobre-cta__btn-primario:hover { background: #0a18c0; }

.sobre-cta__btn-secundario {
    display: inline-flex;
    align-items: center;
    padding: 14px 28px;
    border: 1px solid #c8d6ea;
    color: #4a5f82;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    transition: border-color .2s ease, color .2s ease;
    white-space: nowrap;
}

.sobre-cta__btn-secundario:hover { border-color: #071098; color: #071098; }

/* =========================================================
   RESPONSIVO — Quem Somos
========================================================= */
@media (max-width: 1024px) {
    .sobre-diferenciais__grid { grid-template-columns: repeat(2, 1fr); }
    .sobre-numeros__grid      { grid-template-columns: repeat(2, 1fr); gap: 40px 32px; }
    .sobre-processo__trilha   { grid-template-columns: repeat(2, 1fr); gap: 40px; }
    .sobre-processo__trilha::before { display: none; }
}

@media (max-width: 768px) {
    .sobre-hero__inner        { max-width: 100%; }
    .sobre-empresa__grid      { grid-template-columns: 1fr; gap: 40px; }
    .sobre-cta__inner         { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 560px) {
    .sobre-diferenciais__grid { grid-template-columns: 1fr; }
    .sobre-numeros__grid      { grid-template-columns: repeat(2, 1fr); }
    .sobre-processo__trilha   { grid-template-columns: 1fr; }
    .sobre-hero               { padding: 64px 0 56px; }
}

/* =========================================================
   PÁGINA DE CONTATO
========================================================= */

/* ── Hero ─────────────────────────────────────────────── */
.contato-hero {
    background: linear-gradient(145deg, #080f2e 0%, #0d1b3e 55%, #071098 100%);
    padding: 72px 0 56px;
    position: relative;
    overflow: hidden;
}

.contato-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 80% 50%, rgba(7,16,152,.35) 0%, transparent 70%),
        radial-gradient(ellipse 40% 60% at 20% 80%, rgba(30,147,242,.12) 0%, transparent 60%);
    pointer-events: none;
}

.contato-hero__inner { position: relative; z-index: 1; }

.contato-hero__kicker {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #7ba9f5;
    margin-bottom: 14px;
}

.contato-hero__titulo {
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 300;
    color: #fff;
    line-height: 1.15;
    margin: 0 0 16px;
    letter-spacing: -.01em;
}

.contato-hero__sub {
    font-size: 16px;
    color: rgba(255,255,255,.72);
    max-width: 520px;
    line-height: 1.7;
    margin: 0;
}

/* ── Corpo ────────────────────────────────────────────── */
.contato-corpo {
    background: #f5f7fb;
    padding: 64px 0 80px;
}

.contato-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 40px;
    align-items: start;
}

/* ── Formulário ──────────────────────────────────────── */
.contato-form-wrap {
    background: #fff;
    border-radius: 12px;
    padding: 40px;
    box-shadow: 0 2px 20px rgba(13,27,62,.07);
}

.contato-form-aviso {
    background: #eff6ff;
    border-left: 3px solid #1e93f2;
    padding: 12px 16px;
    border-radius: 0 6px 6px 0;
    font-size: 13px;
    color: #1e40af;
    margin-bottom: 28px;
    line-height: 1.5;
}

.contato-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px 24px;
}

.form-campo {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.form-campo--full {
    grid-column: 1 / -1;
}

.form-campo label {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    letter-spacing: .01em;
}

.form-campo .obrigatorio {
    color: #e53e3e;
    margin-left: 2px;
}

.form-campo__opcional {
    font-weight: 400;
    color: #9ca3af;
    font-size: 12px;
}

.form-campo input,
.form-campo select,
.form-campo textarea {
    padding: 11px 14px;
    border: 1.5px solid #d1d5db;
    border-radius: 7px;
    font-size: 14px;
    color: #111827;
    background: #fff;
    transition: border-color .18s ease, box-shadow .18s ease;
    font-family: inherit;
    outline: none;
    -webkit-appearance: none;
}

.form-campo input::placeholder,
.form-campo textarea::placeholder { color: #9ca3af; }

.form-campo input:focus,
.form-campo select:focus,
.form-campo textarea:focus {
    border-color: #071098;
    box-shadow: 0 0 0 3px rgba(7,16,152,.08);
}

.form-campo textarea { resize: vertical; min-height: 108px; }

.form-campo select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
    cursor: pointer;
}

/* Validation states */
.form-campo input.campo-invalido,
.form-campo select.campo-invalido,
.form-campo textarea.campo-invalido {
    border-color: #e53e3e;
    box-shadow: 0 0 0 3px rgba(229,62,62,.08);
}

.form-erro {
    font-size: 12px;
    color: #e53e3e;
    min-height: 16px;
    line-height: 1.4;
}

/* Rodapé do formulário */
.contato-form-rodape {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.contato-btn-enviar {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: #071098;
    color: #fff;
    border: none;
    border-radius: 7px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
    white-space: nowrap;
    font-family: inherit;
    letter-spacing: .01em;
}

.contato-btn-enviar:hover:not(:disabled) {
    background: #0a18c0;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(7,16,152,.28);
}

.contato-btn-enviar:disabled {
    opacity: .65;
    cursor: not-allowed;
}

.contato-btn-enviar svg {
    flex-shrink: 0;
    transition: transform .2s ease;
}

.contato-btn-enviar:hover:not(:disabled) svg { transform: translateX(3px); }

.contato-form-nota {
    font-size: 12px;
    color: #9ca3af;
    margin: 0;
    line-height: 1.5;
    flex: 1;
    min-width: 200px;
}

/* ── Sidebar de info ─────────────────────────────────── */
.contato-info {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: sticky;
    top: 24px;
}

.contato-info-bloco {
    background: #fff;
    border-radius: 12px;
    padding: 28px;
    box-shadow: 0 2px 20px rgba(13,27,62,.07);
}

.contato-info-bloco__titulo {
    font-size: 14px;
    font-weight: 700;
    color: #0d1b3e;
    letter-spacing: .04em;
    text-transform: uppercase;
    margin: 0 0 20px;
}

.contato-canais {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.contato-canal {
    display: flex;
    align-items: center;
    gap: 14px;
}

.contato-canal__icone {
    width: 38px;
    height: 38px;
    border-radius: 9px;
    background: #f0f4ff;
    color: #071098;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.contato-canal__icone--wa {
    background: #dcfce7;
    color: #16a34a;
}

.contato-canal__label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: #9ca3af;
    margin-bottom: 2px;
}

.contato-canal__valor {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: #111827;
}

.contato-canal__valor--link {
    color: #071098;
    text-decoration: none;
    transition: color .15s ease;
}

.contato-canal__valor--link:hover { color: #0a18c0; }

/* Diferenciais */
.contato-diferenciais {
    background: #fff;
    border-radius: 12px;
    padding: 24px 28px;
    box-shadow: 0 2px 20px rgba(13,27,62,.07);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.contato-dif {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: #374151;
    font-weight: 500;
}

.contato-dif svg {
    color: #16a34a;
    flex-shrink: 0;
}

/* =========================================================
   RESPONSIVO — Contato
========================================================= */
@media (max-width: 1024px) {
    .contato-layout { grid-template-columns: 1fr 300px; gap: 28px; }
}

@media (max-width: 768px) {
    .contato-layout {
        grid-template-columns: 1fr;
    }
    .contato-info { position: static; }
    .contato-form-wrap { padding: 28px 20px; }
    .contato-hero { padding: 56px 0 44px; }
}

@media (max-width: 560px) {
    .contato-form-grid { grid-template-columns: 1fr; }
    .contato-form-rodape { flex-direction: column; align-items: stretch; }
    .contato-btn-enviar { justify-content: center; }
    .contato-corpo { padding: 40px 0 60px; }
}

/* =========================================================
   WIZARD DE CADASTRO DE IMÓVEL (.pf-*)
========================================================= */

/* ── Layout geral ─────────────────────────────────────── */
.pf-layout {
    display: grid;
    grid-template-columns: 228px 1fr;
    min-height: calc(100vh - 60px);
    background: #f1f3f7;
}

/* ── Sidebar ──────────────────────────────────────────── */
.pf-sidebar {
    background: #fff;
    border-right: 1px solid #e5e7eb;
    padding: 20px 14px 40px;
    position: sticky;
    top: 60px;
    height: calc(100vh - 60px);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pf-back-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: 6px 8px;
    border-radius: 6px;
    transition: color .15s, background .15s;
    margin-bottom: 4px;
}
.pf-back-link:hover { color: #111827; background: #f3f4f6; }

.pf-sidebar__title {
    font-size: 15px;
    font-weight: 700;
    color: #111827;
    padding: 4px 8px 16px;
    border-bottom: 1px solid #f3f4f6;
    margin-bottom: 8px;
}

/* Step buttons */
.pf-step-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 9px 10px;
    border: none;
    background: none;
    border-radius: 8px;
    cursor: pointer;
    text-align: left;
    transition: background .15s;
    font-family: inherit;
}
.pf-step-btn:hover { background: #f9fafb; }
.pf-step-btn.is-active { background: #eff6ff; }
.pf-step-btn.is-done .pf-step-num { background: #16a34a; color: #fff; }

.pf-step-num {
    width: 26px; height: 26px;
    border-radius: 50%;
    background: #e5e7eb;
    color: #6b7280;
    font-size: 12px;
    font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .2s, color .2s;
}
.pf-step-btn.is-active .pf-step-num { background: #2563eb; color: #fff; }

.pf-step-info { display: flex; flex-direction: column; gap: 1px; }
.pf-step-lbl {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    line-height: 1.3;
}
.pf-step-btn.is-active .pf-step-lbl { color: #1d4ed8; }
.pf-step-sub {
    font-size: 11px;
    color: #9ca3af;
    line-height: 1.3;
}

/* ── Main content ─────────────────────────────────────── */
.pf-main {
    padding: 32px 36px 120px;
    max-width: 960px;
}

/* ── Steps ────────────────────────────────────────────── */
.pf-step { display: none; }
.pf-step.is-active { display: block; }

.pf-step-header {
    margin-bottom: 24px;
}
.pf-step-header h2 {
    font-size: 24px;
    font-weight: 700;
    color: #111827;
    margin: 0 0 4px;
    letter-spacing: -.02em;
}
.pf-step-header p {
    font-size: 14px;
    color: #6b7280;
    margin: 0;
}

/* ── Cards ────────────────────────────────────────────── */
.pf-card {
    background: #fff;
    border-radius: 10px;
    padding: 24px;
    margin-bottom: 16px;
    box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
}

.pf-card-title {
    font-size: 12px;
    font-weight: 700;
    color: #374151;
    text-transform: uppercase;
    letter-spacing: .07em;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.pf-card-subtitle {
    font-size: 14px;
    font-weight: 700;
    color: #2563eb;
    margin-bottom: 16px;
}

.pf-badge {
    font-size: 10px;
    font-weight: 600;
    background: #f3f4f6;
    color: #6b7280;
    padding: 2px 8px;
    border-radius: 20px;
    letter-spacing: .04em;
    text-transform: none;
}

/* ── Grids ────────────────────────────────────────────── */
.pf-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px 18px;
}
.pf-grid--2 { grid-template-columns: repeat(2, 1fr); }
.pf-col-2   { grid-column: span 2; }
.pf-col-3   { grid-column: span 3; }

.pf-stack { display: flex; flex-direction: column; gap: 14px; }

/* ── Fields ───────────────────────────────────────────── */
.pf-field { display: flex; flex-direction: column; gap: 5px; }

.pf-field label {
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
    letter-spacing: .02em;
}
.pf-field label small {
    font-weight: 400;
    color: #9ca3af;
    font-size: 11px;
    margin-left: 4px;
}

.pf-req { color: #ef4444; margin-left: 2px; }

.pf-field input,
.pf-field select,
.pf-field textarea {
    padding: 9px 12px;
    border: 1.5px solid #e5e7eb;
    border-radius: 7px;
    font-size: 14px;
    color: #111827;
    background: #fff;
    font-family: inherit;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    box-sizing: border-box;
    width: 100%;
}
.pf-field input::placeholder,
.pf-field textarea::placeholder { color: #c4c9d4; }
.pf-field input:focus,
.pf-field select:focus,
.pf-field textarea:focus {
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}
.pf-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 34px;
    -webkit-appearance: none;
    cursor: pointer;
}
.pf-field textarea { resize: vertical; min-height: 96px; }

/* Input com prefixo/sufixo */
.pf-input-prefix,
.pf-input-suffix {
    display: flex;
    align-items: center;
    border: 1.5px solid #e5e7eb;
    border-radius: 7px;
    overflow: hidden;
    transition: border-color .15s, box-shadow .15s;
}
.pf-input-prefix:focus-within,
.pf-input-suffix:focus-within {
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}
.pf-input-prefix span,
.pf-input-suffix span {
    padding: 0 10px;
    font-size: 13px;
    color: #6b7280;
    background: #f9fafb;
    border-right: 1.5px solid #e5e7eb;
    height: 100%;
    display: flex;
    align-items: center;
    white-space: nowrap;
    flex-shrink: 0;
}
.pf-input-suffix span {
    border-right: none;
    border-left: 1.5px solid #e5e7eb;
}
.pf-input-prefix input,
.pf-input-suffix input {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    flex: 1;
}

/* ── Toggles ──────────────────────────────────────────── */
.pf-toggles-row {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center;
}

.pf-toggle {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    cursor: pointer;
    font-size: 13px;
    color: #374151;
    font-weight: 500;
    user-select: none;
}
.pf-toggle input[type="checkbox"] { display: none; }
.pf-toggle input[type="hidden"]   { display: none; }

.pf-toggle__track {
    width: 38px; height: 21px;
    border-radius: 11px;
    background: #d1d5db;
    position: relative;
    transition: background .2s;
    flex-shrink: 0;
}
.pf-toggle__thumb {
    position: absolute;
    top: 2px; left: 2px;
    width: 17px; height: 17px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,.25);
    transition: transform .2s;
}
.pf-toggle input[type="checkbox"]:checked ~ .pf-toggle__track { background: #2563eb; }
.pf-toggle input[type="checkbox"]:checked ~ .pf-toggle__track .pf-toggle__thumb {
    transform: translateX(17px);
}

/* ── Checkboxes estilizados ───────────────────────────── */
.pf-check {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    cursor: pointer;
    font-size: 14px;
    color: #374151;
    user-select: none;
}
.pf-check input[type="checkbox"] { display: none; }
.pf-check input[type="hidden"]   { display: none; }

.pf-check__box {
    width: 18px; height: 18px;
    border: 2px solid #d1d5db;
    border-radius: 4px;
    background: #fff;
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    transition: background .15s, border-color .15s;
}
.pf-check__box::after {
    content: '';
    width: 10px; height: 6px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg) translateY(-1px);
    opacity: 0;
    transition: opacity .1s;
}
.pf-check input[type="checkbox"]:checked + .pf-check__box {
    background: #2563eb;
    border-color: #2563eb;
}
.pf-check input[type="checkbox"]:checked + .pf-check__box::after { opacity: 1; }

.pf-check--lg { font-size: 14px; font-weight: 500; }

.pf-check-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px 24px;
}

/* Info box (dashed) */
.pf-info-box {
    border: 1.5px dashed #bfdbfe;
    border-radius: 8px;
    padding: 12px 16px;
    background: #eff6ff;
}
.pf-obs {
    font-size: 12px;
    color: #9ca3af;
    margin: 12px 0 0;
}

/* ── Counters ─────────────────────────────────────────── */
.pf-counters-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px 20px;
}

.pf-counter-field { display: flex; flex-direction: column; gap: 8px; }
.pf-counter-field label {
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
    letter-spacing: .02em;
}

.pf-counter {
    display: flex;
    align-items: stretch;
    border: 1.5px solid #e5e7eb;
    border-radius: 7px;
    overflow: hidden;
    height: 38px;
}
.pf-counter__btn {
    width: 34px;
    border: none;
    background: #f9fafb;
    color: #374151;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .12s;
    display: flex; align-items: center; justify-content: center;
}
.pf-counter__btn:hover { background: #f3f4f6; }
.pf-counter__input {
    flex: 1;
    border: none !important;
    border-left: 1.5px solid #e5e7eb !important;
    border-right: 1.5px solid #e5e7eb !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    text-align: center;
    font-size: 15px;
    font-weight: 600;
    padding: 0 4px !important;
    width: auto !important;
    min-width: 0;
}
.pf-counter__input:focus { box-shadow: none !important; border-color: #e5e7eb !important; }

/* ── Localização layout ───────────────────────────────── */
.pf-loc-layout {
    display: grid;
    grid-template-columns: 1fr 260px;
    gap: 20px;
    align-items: start;
}
.pf-loc-form { display: flex; flex-direction: column; gap: 16px; }

/* Mapa */
.pf-map-card {
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
    position: sticky;
    top: 80px;
}
.pf-map-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    border-bottom: 1px solid #f3f4f6;
}
.pf-map-open {
    font-size: 12px;
    color: #2563eb;
    font-weight: 500;
}
.pf-map-placeholder {
    height: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: #9ca3af;
    font-size: 13px;
    text-align: center;
    background: #f9fafb;
}
.pf-map-iframe {
    width: 100%;
    height: 320px;
    border: none;
}
.pf-help-link {
    font-size: 12px;
    color: #2563eb;
    text-decoration: underline;
}

/* ── Captadores / Envolvidos ──────────────────────────── */
.pf-captador-row,
.pf-envolvido-row {
    display: grid;
    grid-template-columns: 1fr 140px 140px auto;
    gap: 12px;
    align-items: end;
    margin-bottom: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid #f3f4f6;
}
.pf-envolvido-row { grid-template-columns: 1fr 140px 140px; }
.pf-captador-nome { /* natural width via grid */ }

.pf-add-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border: 1.5px dashed #bfdbfe;
    background: #eff6ff;
    color: #2563eb;
    border-radius: 7px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, border-color .15s;
    margin-top: 4px;
    font-family: inherit;
}
.pf-add-btn:hover { background: #dbeafe; border-color: #93c5fd; }

.pf-remove-btn {
    align-self: flex-end;
    width: 32px; height: 32px;
    border: 1.5px solid #fee2e2;
    background: #fff5f5;
    color: #ef4444;
    border-radius: 6px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .15s;
}
.pf-remove-btn:hover { background: #fee2e2; }

/* ── File upload zone ─────────────────────────────────── */
.pf-file-zone { position: relative; }
.pf-file-zone input[type="file"] {
    position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: 2;
    width: 100%; height: 100%;
}
.pf-file-zone__label {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px 16px;
    border: 2px dashed #d1d5db;
    border-radius: 10px;
    background: #fafafa;
    cursor: pointer;
    text-align: center;
    color: #6b7280;
    font-size: 14px;
    transition: border-color .15s, background .15s;
}
.pf-file-zone:hover .pf-file-zone__label,
.pf-file-zone input:focus + .pf-file-zone__label {
    border-color: #2563eb;
    background: #eff6ff;
}
.pf-file-zone__label strong { color: #2563eb; }
.pf-file-zone__label small { font-size: 12px; color: #9ca3af; }
.pf-file-zone__label svg { color: #9ca3af; }

.pf-file-current {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 10px;
    padding: 8px 12px;
    background: #f9fafb;
    border-radius: 7px;
    border: 1px solid #e5e7eb;
    font-size: 12px;
    color: #6b7280;
}
.pf-file-current img {
    width: 40px; height: 40px;
    object-fit: cover;
    border-radius: 4px;
}

/* ── Media grid ───────────────────────────────────────── */
.pf-media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 10px;
}
.pf-media-card {
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    background: #f9fafb;
}
.pf-media-card img {
    width: 100%; height: 90px;
    object-fit: cover; display: block;
}
.pf-media-video {
    height: 90px;
    display: flex; align-items: center; justify-content: center;
    background: #1e1b4b; color: #a5b4fc;
}
.pf-media-card__bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 8px;
    font-size: 11px;
    color: #6b7280;
    font-weight: 500;
}
.pf-media-del {
    color: #ef4444;
    display: flex;
    align-items: center;
    transition: opacity .15s;
}
.pf-media-del:hover { opacity: .7; }

/* ── Step footer ──────────────────────────────────────── */
.pf-step-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid #e5e7eb;
}

.pf-btn-next,
.pf-btn-prev,
.pf-btn-save {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 10px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    font-family: inherit;
    transition: all .15s;
}
.pf-btn-next, .pf-btn-save {
    background: #2563eb;
    color: #fff;
}
.pf-btn-next:hover, .pf-btn-save:hover { background: #1d4ed8; }
.pf-btn-prev {
    background: #f3f4f6;
    color: #374151;
}
.pf-btn-prev:hover { background: #e5e7eb; }
.pf-btn-save {
    background: #16a34a;
}
.pf-btn-save:hover { background: #15803d; }

/* ── Floating Action Button ───────────────────────────── */
.pf-fab-wrap {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 200;
}
.pf-fab {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 13px 24px;
    background: #2563eb;
    color: #fff;
    border: none;
    border-radius: 40px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    box-shadow: 0 4px 20px rgba(37,99,235,.40);
    transition: background .2s, transform .15s, box-shadow .2s;
}
.pf-fab:hover {
    background: #1d4ed8;
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(37,99,235,.45);
}
.pf-fab:disabled { opacity: .65; cursor: not-allowed; transform: none; }

/* =========================================================
   RESPONSIVO — Wizard
========================================================= */
@media (max-width: 1100px) {
    .pf-loc-layout { grid-template-columns: 1fr; }
    .pf-map-card   { position: static; }
}

@media (max-width: 900px) {
    .pf-counters-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
    .pf-check-grid    { grid-template-columns: repeat(2, 1fr); }
    .pf-captador-row  { grid-template-columns: 1fr 1fr; }
    .pf-envolvido-row { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
    .pf-layout { grid-template-columns: 1fr; }
    .pf-sidebar {
        position: static;
        height: auto;
        flex-direction: row;
        overflow-x: auto;
        padding: 12px;
        gap: 6px;
        border-right: none;
        border-bottom: 1px solid #e5e7eb;
    }
    .pf-sidebar__title,
    .pf-back-link,
    .pf-step-sub { display: none; }
    .pf-step-btn {
        flex-shrink: 0;
        padding: 8px 10px;
        flex-direction: column;
        align-items: center;
        gap: 4px;
        width: auto;
    }
    .pf-step-info { align-items: center; }
    .pf-step-lbl { font-size: 11px; }
    .pf-main { padding: 20px 16px 100px; }
    .pf-grid { grid-template-columns: repeat(2, 1fr); }
    .pf-col-3 { grid-column: span 2; }
    .pf-counters-grid { grid-template-columns: repeat(2, 1fr); }
    .pf-fab-wrap { bottom: 16px; right: 16px; }
}

@media (max-width: 480px) {
    .pf-grid { grid-template-columns: 1fr; }
    .pf-col-2, .pf-col-3 { grid-column: span 1; }
    .pf-counters-grid { grid-template-columns: repeat(2, 1fr); }
    .pf-check-grid { grid-template-columns: 1fr; }
    .pf-captador-row,
    .pf-envolvido-row { grid-template-columns: 1fr; }
    .pf-fab span { display: none; }
    .pf-fab { padding: 13px 16px; border-radius: 50%; }
}