/* =========================================
   TOKENS / TEMA (CLARO • PALETA AZUL)
   Base do logo: #1C3B73
========================================= */
:root {
    /* Tema */
    --tema-claro: #bfd4f5;
    --tema: #1c3b73;
    --tema-escuro: #102a52;

    /* Base escura (texto/sombra) */
    --espresso: #07162e;

    /* Acento (teal) */
    --acento: #22c1c3;
    --acento-2: #9ce7e8;

    /* Neutros */
    --cor-fundo: #f5f7fd;
    --cor-superficie: #ffffff;
    --cor-superficie-2: #eaf0fa;

    --cor-borda: rgb(var(--espresso-rgb) / .12);

    --cor-texto: rgb(var(--espresso-rgb) / .92);
    --cor-texto-suave: rgb(var(--espresso-rgb) / .72);
    --cor-texto-fraco: rgb(var(--espresso-rgb) / .55);

    /* UI */
    --raio: 18px;
    --raio-grande: 26px;
    --sombra: 0 18px 60px rgb(var(--espresso-rgb) / .14);
    --sombra-suave: 0 10px 30px rgb(var(--espresso-rgb) / .10);
    --largura-maxima: 1400px;
    --transicao: cubic-bezier(.2, .8, .2, 1);

    /* RGB (pra alpha) */
    --tema-rgb: 28 59 115;
    /* #1C3B73 */
    --espresso-rgb: 7 22 46;
    /* #07162E */
    --acento-rgb: 34 193 195;
    /* #22C1C3 */

    --cor-fundo-rgb: 245 247 253;
    /* #F5F7FD */
    --cor-superficie-rgb: 255 255 255;
    /* #FFFFFF */
    --cor-superficie-2-rgb: 234 240 250;
    /* #EAF0FA */

    --branco-rgb: 255 255 255;
    --preto-rgb: 0 0 0;

    --cor-texto-invertido: rgb(var(--branco-rgb) / 1);

    /* Skeleton */
    --skeleton-a: #f3f6fb;
    --skeleton-b: #e6edf7;
    --skeleton-a-rgb: 243 246 251;
    --skeleton-b-rgb: 230 237 247;

    /* Select2 */
    --s2-opt-selected: rgb(var(--tema-rgb) / .22);
    --s2-opt-hover: rgb(var(--tema-rgb) / .36);

    --imovel-raio: 12px;
    --imovel-borda: rgb(var(--espresso-rgb) / .10);
    --imovel-divisor: rgb(var(--espresso-rgb) / .10);
    --imovel-sombra: 0 10px 28px rgb(var(--espresso-rgb) / .08);
}



/* =========================================
   RESET / BASE
========================================= */
* {
    box-sizing: border-box;
}

html,
body {
    min-height: 100%;
}

body>main#conteudo {
    min-height: 80svh;
}

body {
    margin: 0;
    font-family: Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    color: var(--cor-texto);
    background:
        radial-gradient(1000px 700px at 15% -10%, rgb(var(--acento-rgb) / .14), transparent 60%),
        radial-gradient(900px 650px at 90% 10%, rgb(var(--tema-rgb) / .14), transparent 60%),
        linear-gradient(180deg, rgb(var(--tema-rgb) / .10), transparent 45%),
        var(--cor-fundo);
    line-height: 1.5;
}


a {
    color: inherit;
    text-decoration: none !important;
}

button {
    cursor: pointer;
}


/* =========================================
   LAYOUT / UTILITÁRIOS
========================================= */
.conteiner {
    width: min(var(--largura-maxima), calc(100% - 40px));
    margin-inline: auto;
}

.centralizar {
    display: flex;
    justify-content: center;
    margin-top: 18px;
}

.secao {
    padding: 56px 0;
}

.lazy {
    animation: loading 1.5s infinite linear;
    background: var(--skeleton-a);
    background: linear-gradient(90deg,
            rgb(var(--skeleton-a-rgb) / 1) 25%,
            rgb(var(--skeleton-b-rgb) / 1) 50%,
            rgb(var(--skeleton-a-rgb) / 1) 75%);
    background-size: 200% 50%;
    position: relative;
    border: solid 1px transparent;
}


/* =========================================
   CABEÇALHO / NAVEGAÇÃO
========================================= */
.cabecalho {
    position: sticky;
    top: 0;
    z-index: 999;
    backdrop-filter: blur(14px);
    background: linear-gradient(to bottom,
            rgb(var(--cor-fundo-rgb) / .92),
            rgb(var(--cor-fundo-rgb) / .72));
    border-bottom: 1px solid rgb(var(--espresso-rgb) / .08);
}

.cabecalho__interno {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
}

.marca {
    display: flex;
    gap: 10px;
    align-items: center;
}

/* substitui o .marca__selo */
.marca__logo {
    height: 5.5rem;
    /* controla a altura do logo */
    width: auto;
    /* mantém proporção */
    display: block;
    object-fit: contain;
}

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

.menu a {
    color: var(--cor-texto-suave);
    padding: 10px 12px;
    border-radius: 12px;
    transition: background .2s var(--transicao), transform .2s var(--transicao), color .2s var(--transicao);
}

.menu a:hover {
    background: rgb(var(--espresso-rgb) / .06);
    color: var(--cor-texto);
    transform: translateY(-1px);
}

.menu__cta {
    border: 1px solid rgb(var(--acento-rgb) / .55);
    background: rgb(var(--acento-rgb) / .14);
    color: var(--espresso) !important;
}

.botao-icone {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    border: 1px solid var(--cor-borda);
    background: rgb(var(--cor-superficie-rgb) / .55);
    cursor: pointer;
    display: none;
    box-shadow: var(--sombra-suave);
}

/* MOBILE */
@media (max-width: 768px) {
    .botao-icone {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .menu {
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        display: grid;
        gap: 8px;
        padding: 12px 16px 16px;
        background: rgb(var(--cor-fundo-rgb) / .96);
        border-bottom: 1px solid rgb(var(--espresso-rgb) / .08);
        box-shadow: var(--sombra-suave);
        transform: translateY(-8px);
        opacity: 0;
        pointer-events: none;
        transition: opacity .2s var(--transicao), transform .2s var(--transicao);
    }

    /* quando aberto */
    .menu.is-open {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }

    /* pra posicionar o menu absoluto certinho */
    .cabecalho__interno {
        position: relative;
    }
}

/* opcional: trava scroll do body quando menu aberto */
body.menu-aberto {
    overflow: hidden;
}



/* =========================================
   CAPA / HERO
========================================= */
.capa {
    position: relative;
    padding: 56px 0 26px;
}

.capa__fundo {
    position: absolute;
    inset: -10% 0;

    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;

    will-change: transform;
    transform: translate3d(0, 0, 0) scale(1.05) !important;

    -webkit-mask-image: linear-gradient(to bottom,
            rgb(var(--preto-rgb) / 1) 0%,
            rgb(var(--preto-rgb) / 1) 40%,
            rgb(var(--preto-rgb) / 0) 100%);
    mask-image: linear-gradient(to bottom,
            rgb(var(--preto-rgb) / 1) 0%,
            rgb(var(--preto-rgb) / 1) 40%,
            rgb(var(--preto-rgb) / 0) 100%);
}


.capa__interno {
    position: relative;
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 18px;
    align-items: start;
}

.chamada-pequena {
    margin: 0 0 10px;
    color: rgb(var(--tema-rgb) / .88);
    letter-spacing: .22em;
    text-transform: uppercase;
    font-size: .78rem;
}

.titulo-principal {
    margin: 0 0 12px;
    font-size: clamp(2.0rem, 3.2vw, 3.1rem);
    line-height: 1.08;
}

.texto-destaque {
    color: var(--tema-escuro);
}

.texto-apoio {
    margin: 0 0 16px;
    color: var(--cor-texto-suave);
    max-width: 58ch;
}

.acoes {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.link-suave {
    color: var(--cor-texto-suave);
    padding: 10px 4px;
}

.link-suave:hover {
    color: var(--cor-texto);
}


.capa {
    position: relative;
    overflow: hidden;
}



.capa__interno {
    position: relative;
    z-index: 1;
}

@media (max-width: 980px) {
    .capa__interno {
        grid-template-columns: 1fr;
    }
}



/* =========================================
   CARTÕES / BOTÕES
========================================= */
.cartao {
    border-radius: var(--raio-grande);
    background: linear-gradient(180deg,
            rgb(var(--cor-superficie-rgb) / .92),
            rgb(var(--cor-superficie-2-rgb) / .92));
    border: 1px solid rgb(var(--espresso-rgb) / .10);
    box-shadow: var(--sombra-suave);
    padding: 18px;
}

.cartao--destaque {
    position: sticky;
    top: 86px;
}

@media (max-width: 980px) {
    .cartao--destaque {
        position: relative;
        top: auto;
    }
}

.cartao__titulo {
    margin: 0 0 6px;
    font-size: 1.15rem;
}

.cartao__texto {
    margin: 0 0 14px;
    color: var(--cor-texto-suave);
}

.botao {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--cor-borda);
    cursor: pointer;
    transition: transform .2s var(--transicao), background .2s var(--transicao), border .2s var(--transicao);
    user-select: none;
}

.botao:hover {
    transform: translateY(-1px);
}

.botao--principal {
    background: linear-gradient(135deg, var(--tema-claro), var(--tema));
    border-color: rgb(var(--acento-rgb) / .55);
    color: var(--espresso);
    font-weight: 900;
}

.botao--fantasma {
    background: rgb(var(--espresso-rgb) / .04);
    border-color: rgb(var(--espresso-rgb) / .14);
    color: var(--cor-texto);
}

.botao--largo {
    width: 100%;
}

.separador {
    height: 1px;
    background: rgb(var(--espresso-rgb) / .12);
    margin: 14px 0;
}

.microtexto {
    margin: 0;
    font-size: .9rem;
    color: var(--cor-texto-fraco);
}

/* =========================================
   ÍCONES
========================================= */
.icone-container {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;

    background: rgb(var(--espresso-rgb) / .06);
    border: 1px solid rgb(var(--espresso-rgb) / .12);
    box-shadow: var(--sombra-suave);
}

.icone {
    width: 22px;
    height: 22px;
    display: block;
}

/* variações opcionais */
.icone--pequeno-container {
    width: 36px;
    height: 36px;
    border-radius: 12px;
}

.icone--pequeno {
    width: 18px;
    height: 18px;
}

.icone--grande-container {
    width: 56px;
    height: 56px;
    border-radius: 18px;
}

.icone--grande {
    width: 28px;
    height: 28px;
}

/* caso use em linha com texto */
.icone--inline-container {
    width: 28px;
    height: 28px;
    border-radius: 10px;
    box-shadow: none;
}

.icone--inline {
    width: 16px;
    height: 16px;
    vertical-align: middle;
}


/* =========================================
   SEÇÕES / GRADES / ELEMENTOS
========================================= */
.cabecalho-secao {
    margin-bottom: 16px;
}

.titulo-secao {
    margin: 0 0 6px;
    font-size: 1.9rem;
}

.grade {
    display: grid;
    gap: 12px;
}

.grade--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}


@media (max-width: 640px) {
    .grade--2 {
        grid-template-columns: 1fr;
    }
}

.grade--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 980px) {
    .grade--3 {
        grid-template-columns: 1fr;
    }
}

.titulo-cartao {
    margin: 0 0 6px;
}

.texto-cartao {
    margin: 0 0 10px;
    color: var(--cor-texto-suave);
}

.lista-check {
    margin: 0;
    padding-left: 18px;
    color: var(--cor-texto-suave);
}

.lista-check li {
    margin: 6px 0;
}

.passos {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

@media (max-width: 980px) {
    .passos {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}


.passo__numero {
    display: inline-block;
    font-weight: 900;
    color: rgb(var(--tema-rgb) / .88);
    letter-spacing: .14em;
    margin-bottom: 8px;
}

/* =========================================
   CONTATO / CTA (WHATSAPP)
========================================= */
.contato {
    text-align: center;
    display: grid;
    gap: 12px;
    justify-items: center;
}

.contato__texto {
    margin: 0;
}




/* =========================================
   BOTÃO FLUTUANTE
========================================= */
.botao-flutuante {
    position: fixed;
    right: 18px;
    bottom: 18px;
    width: 54px;
    height: 54px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--tema-claro), var(--tema));
    color: var(--espresso);
    border: 1px solid rgb(var(--tema-rgb) / .55);
    box-shadow: var(--sombra);
    z-index: 60;
}




/* =========================================
   PÁGINA DE ERRO
========================================= */

.error-hero {
    min-height: calc(100vh - 120px);
    /* ajusta caso seu header/footer mudem */
    padding: clamp(28px, 6vw, 72px) 0;
    display: flex;
    align-items: center;
    overflow: hidden;

    /* fundo suave */
    background:
        radial-gradient(1200px 700px at 50% 10%, rgb(var(--acento-rgb) / .14), transparent 60%),
        radial-gradient(900px 600px at 20% 40%, rgb(var(--tema-rgb) / .10), transparent 60%),
        linear-gradient(180deg, rgb(var(--cor-fundo-rgb) / .96), rgb(var(--cor-fundo-rgb) / .88));
}

.error-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
            rgb(var(--cor-superficie-rgb) / .55),
            rgb(var(--cor-superficie-2-rgb) / .40));
    pointer-events: none;
}

.error-wrap {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: center;
}

/* Card */
.error-card {
    width: min(820px, 100%);
    border-radius: var(--raio-grande, 18px);
    padding: clamp(18px, 3vw, 28px);
    background: linear-gradient(180deg,
            rgb(var(--cor-superficie-rgb) / .92),
            rgb(var(--cor-superficie-2-rgb) / .92));
    border: 1px solid rgb(var(--espresso-rgb) / .10);
    box-shadow: var(--sombra-suave);
    backdrop-filter: blur(10px);
}

.error-title {
    margin: 0 0 10px;
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    line-height: 1.12;
    color: var(--cor-texto);
    letter-spacing: -0.02em;
}

.error-divider {
    height: 1px;
    background: rgb(var(--espresso-rgb) / .12);
    margin: 12px 0 14px;
}

.error-copy {
    margin: 0;
    color: var(--cor-texto-suave);
    line-height: 1.55;
    max-width: 70ch;
}

.error-copy strong {
    font-weight: 800;
    color: var(--cor-texto);
}

.error-copy small {
    display: inline-block;
    margin-top: 6px;
    font-size: .92rem;
    color: var(--cor-texto-fraco);
}

/* Ações */
.error-actions {
    margin-top: 18px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

/* Botão (fallback caso não exista no seu CSS global) */
.error-actions .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgb(var(--espresso-rgb) / .14);
    cursor: pointer;
    text-decoration: none;
    user-select: none;
    transition: transform .2s var(--transicao, ease), background .2s var(--transicao, ease), border .2s var(--transicao, ease);
}

.error-actions .btn:hover {
    transform: translateY(-1px);
}

.error-actions .btn:focus-visible {
    outline: 3px solid rgb(var(--tema-rgb) / .45);
    outline-offset: 3px;
}

/* Primário */
.error-actions .btn--primary {
    background: linear-gradient(135deg, var(--tema-claro), var(--tema));
    border-color: rgb(var(--tema-rgb) / .55);
    color: var(--espresso);
    font-weight: 900;
}

/* Brilho opcional */
.error-actions .btn--shine {
    position: relative;
    overflow: hidden;
}

.error-actions .btn--shine::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-120%);
    background: linear-gradient(90deg,
            rgb(var(--branco-rgb) / 0),
            rgb(var(--branco-rgb) / .45),
            rgb(var(--branco-rgb) / 0));
    transition: transform .6s var(--transicao, ease);
}

.error-actions .btn--shine:hover::after {
    transform: translateX(120%);
}

/* Responsivo */
@media (max-width: 640px) {
    .error-card {
        padding: 16px;
    }

    .error-actions .btn {
        width: 100%;
    }
}

/* =========================
   FOOTER (pequeno e discreto)
========================= */
.site-footer {
    margin-top: 28px;
    padding: 10px 0;
    border-top: 1px solid rgb(var(--espresso-rgb) / .08);
    background: transparent;
}

.site-footer .copy {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;

    font-size: .82rem;
    line-height: 1.25;
    color: var(--cor-texto-fraco);
}

.site-footer .copy a {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    border-radius: 10px;
    opacity: .85;
    transition: opacity .2s var(--transicao), background .2s var(--transicao);
}

.site-footer .copy a:hover {
    opacity: 1;
    background: rgb(var(--espresso-rgb) / .04);
}

.site-footer .copy img {
    height: 18px;
    /* bem pequeno */
    width: auto;
    display: block;
    object-fit: contain;
    opacity: .9;
}

/* mobile */
@media (max-width: 640px) {
    .site-footer {
        padding: 8px 0;
    }

    .site-footer .copy {
        font-size: .78rem;
        gap: 8px;
    }

    .site-footer .copy img {
        height: 16px;
    }
}








/* =========================
   PÁGINA PESQUISA IMÓVEIS
========================= */
.pesquisa-layout {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 18px;
    align-items: start;
}

.pesquisa-resultados {
    min-width: 0;
}

.pesquisa-topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 14px;
}

.pesquisa-titulo {
    margin: 0;
}

.pesquisa-controles {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.view-toggle {
    display: flex;
    gap: 8px;
}

.vt {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    border: 1px solid var(--cor-borda);
    background: rgb(var(--cor-superficie-rgb) / .55);
    box-shadow: var(--sombra-suave);
}

.vt.ativo {
    background: linear-gradient(135deg, var(--tema-claro), var(--tema));
    border-color: rgb(var(--tema-rgb) / .55);
    font-weight: 900;
}

/* GRID */
.imoveis-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

/* LIST */
.imoveis-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

/* CARD IMÓVEL */
.imovel-card {
    border-radius: var(--raio);
    overflow: hidden;
    background: linear-gradient(180deg,
            rgb(var(--cor-superficie-rgb) / .92),
            rgb(var(--cor-superficie-2-rgb) / .92));
    border: 1px solid rgb(var(--espresso-rgb) / .10);
    box-shadow: var(--sombra-suave);
}

.imovel-link {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.imovel-foto {
    position: relative;
    height: 220px;
    overflow: hidden;
}

.imovel-foto img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.imovel-foto img:hover {
    transform: scale(1.2);
}

.imovel-preco {
    position: absolute;
    left: 14px;
    bottom: 14px;
    padding: 8px 10px;
    border-radius: 12px;
    background: rgb(var(--preto-rgb) / .35);
    color: var(--cor-texto-invertido);
    font-weight: 900;
    backdrop-filter: blur(6px);
}

.imovel-corpo {
    padding: 14px 16px 16px;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.imovel-titulo {
    margin: 0 0 8px;
    font-size: 1.05rem;
}

.imovel-local {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    color: var(--cor-texto-suave);
    margin-bottom: 10px;
}

.imovel-local .pin {
    line-height: 1.2;
}

.imovel-caracteristicas {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    color: var(--cor-texto);
    font-size: .95rem;
}

.imovel-caracteristicas strong {
    font-weight: 900;
}

.imovel-mais {
    margin-top: auto;
    color: var(--cor-texto-suave);
    width: min-content;
    text-wrap: nowrap;
}

.imovel-mais:hover {
    color: var(--cor-texto);
}

/* paginação */
.paginacao {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 18px;
}

.pg {
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--cor-borda);
    background: rgb(var(--branco-rgb) / .55);
    box-shadow: var(--sombra-suave);
}

.pg--info {
    border: none;
    background: transparent;
    box-shadow: none;
    color: var(--cor-texto-suave);
}


/* =========================
   FILTROS — card + formulário
========================= */
.pesquisa-filtros {
    /* layout/scroll */
    position: sticky;
    top: 86px;
    max-height: calc(100vh - 86px - 18px);
    overflow-y: auto;
    overflow-x: hidden;
    /* overscroll-behavior: contain;
    scrollbar-gutter: stable; */

    /* visual */
    padding: 0px;
    border-radius: var(--raio);
    background: linear-gradient(180deg,
            rgb(var(--cor-superficie-rgb) / .92),
            rgb(var(--cor-superficie-2-rgb) / .90));
    border: 1px solid rgb(var(--espresso-rgb) / .10);
    box-shadow: var(--sombra-suave);
}

.filtros-topo {
    position: sticky;
    top: 0;
    z-index: 5;

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;

    padding: 10px 10px 5px;
    margin: 0 0 12px;

    background: linear-gradient(180deg,
            rgb(var(--cor-superficie-rgb) / .95),
            rgb(var(--cor-superficie-2-rgb) / .92));
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgb(var(--espresso-rgb) / .10);
}

.filtros-body {
    padding: 0 10px;
}

.pesquisa-filtros .cartao__titulo {
    font-size: 1.08rem;
    letter-spacing: -0.01em;
    margin: 10px 0;
}

.filtros-fechar {
    display: none;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    border: 1px solid var(--cor-borda);
    background: rgb(var(--cor-superficie-rgb) / .60);
    box-shadow: var(--sombra-suave);
    font-size: 18px;
    line-height: 1;
}

.pesquisa-filtros hr {
    border: 0;
    height: 1px;
    background: rgb(var(--espresso-rgb) / .10);
    margin: 14px 0;
}

.pesquisa-filtros .cartao__subtitulo {
    margin: 0 0 10px;
    font-size: 1.02rem;
    font-weight: 900;
    letter-spacing: -0.01em;
}

.filtro-form {
    display: grid;
    gap: 10px;
}

.f-label {
    margin: 2px 0 2px;
    font-size: .82rem;
    color: var(--cor-texto-suave);
}

.f-input {
    width: 100%;
    min-height: 44px;
    padding: 11px 12px;

    border-radius: 16px;

    border: 1px solid rgb(var(--espresso-rgb) / .14);
    background: rgb(var(--cor-superficie-rgb) / .78);
    box-shadow: 0 10px 22px rgb(var(--espresso-rgb) / .08);

    outline: none;
}

.f-input::placeholder {
    color: rgb(var(--espresso-rgb) / .45);
}

.f-input:focus {
    border-color: rgb(var(--tema-rgb) / .85);
    box-shadow:
        0 0 0 4px rgb(var(--tema-rgb) / .20),
        0 10px 22px rgb(var(--espresso-rgb) / .10);
}

.f-input--small {
    padding: 10px 12px;
    border-radius: 12px;
}

.f-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

/* ações sempre visíveis no fim do card */
.pesquisa-filtros .f-acoes {
    display: grid;
    gap: 10px;

    position: sticky;
    bottom: 0;
    z-index: 4;

    padding: 12px;
    margin-top: 12px;

    background: linear-gradient(to top,
            rgb(var(--cor-superficie-rgb) / .96) 65%,
            rgb(var(--cor-superficie-rgb) / 0));
    backdrop-filter: blur(8px);
}

/* grupos de características */
.f-grupo-carac {
    padding: 10px 10px 8px;
    border-radius: 16px;
    border: 1px solid rgb(var(--espresso-rgb) / .08);
    background: rgb(var(--cor-superficie-rgb) / .50);
}

.f-item-carac {
    margin: 8px 0 !important;
    padding-top: 6px;
    border-top: 1px dashed rgb(var(--espresso-rgb) / .10);
}

.f-item-carac:first-child {
    border-top: 0;
    padding-top: 0;
}


/* =========================
   SCROLLBAR (card filtros)
========================= */
.pesquisa-filtros::-webkit-scrollbar {
    width: 8px;
}

.pesquisa-filtros::-webkit-scrollbar-track {
    background: transparent;
}

.pesquisa-filtros::-webkit-scrollbar-thumb {
    background: var(--tema);
    border-radius: 999px;
    border: 1px solid rgb(var(--branco-rgb) / .55);
}

.pesquisa-filtros::-webkit-scrollbar-thumb:hover {
    background: var(--tema-escuro);
    cursor: pointer;
}


/* =========================
   SELECT2 (skin do filtro)
========================= */
.select2-dropdown {
    z-index: 3000 !important;
    /* acima do offcanvas */
}

/* SINGLE */
.select2-container--default .select2-selection--single {
    min-height: 44px;
    border-radius: 16px;
    border: 1px solid rgb(var(--espresso-rgb) / .14);
    background: rgb(var(--cor-superficie-rgb) / .78);
    box-shadow: 0 10px 22px rgb(var(--espresso-rgb) / .08);
    display: flex;
    align-items: center;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 44px !important;
}


.select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 12px;
    padding-right: 44px;
    color: var(--cor-texto);
    line-height: 1.2;
}

.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: rgb(var(--espresso-rgb) / .45);
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 44px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: rgb(var(--espresso-rgb) / .45) transparent transparent transparent;
    border-width: 6px 5px 0 5px;
}

/* MULTIPLE */
.select2-container--default .select2-selection--multiple {
    min-height: 44px;
    border-radius: 16px;
    border: 1px solid rgb(var(--espresso-rgb) / .14);
    background: rgb(var(--cor-superficie-rgb) / .78);
    box-shadow: 0 10px 22px rgb(var(--espresso-rgb) / .08);
    padding: 6px 8px;
}

.select2-container--default .select2-selection--multiple .select2-selection__rendered {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    border: 1px solid rgb(var(--tema-rgb) / .35);
    background: rgb(var(--tema-rgb) / .14);
    color: var(--espresso);
    border-radius: 999px;
    padding: 5px 10px;
    margin: 0;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    margin-right: 6px;
    color: rgb(var(--espresso-rgb) / .65);
}

.select2-container--default .select2-search--inline .select2-search__field {
    margin: 2px 0 0;
    height: 28px;
    font-family: inherit;
    color: var(--cor-texto);
}

/* focus/open */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--multiple {
    border-color: rgb(var(--tema-rgb) / .85);
    box-shadow:
        0 0 0 4px rgb(var(--tema-rgb) / .18),
        0 10px 22px rgb(var(--espresso-rgb) / .10);
}

/* dropdown */
.select2-dropdown {
    /* border-radius: 16px !important; */
    border: 1px solid rgb(var(--espresso-rgb) / .12) !important;
    box-shadow: var(--sombra);
    overflow: hidden;
}

.select2-container--default .select2-results__options {
    max-height: 260px;
    scrollbar-width: thin;
}

.select2-container--default .select2-results__option {
    padding: 10px 12px;
    font-size: .92rem;
}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background: var(--s2-opt-hover);
    color: var(--espresso);
}

.select2-container--default .select2-results__option[aria-selected="true"] {
    background: var(--s2-opt-selected);
    color: var(--espresso);
}

/* clear (x) */
.select2-container--default .select2-selection__clear {
    color: rgb(var(--espresso-rgb) / .55);
    margin-right: 10px;
}

/* item selecionado (estado "marcado") */
.select2-container--default .select2-results__option[aria-selected="true"] {
    background: var(--s2-opt-selected) !important;
    color: var(--espresso) !important;
}

/* item em destaque (hover / setas do teclado) */
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background: var(--s2-opt-hover) !important;
    color: var(--espresso) !important;
}


/* =========================
   OFFCANVAS (mobile/tablet)
========================= */
.pesquisa-filtros-btn {
    display: none;
    /* só no mobile */
    gap: 8px;
    padding: 10px 12px;
    border-radius: 14px;
}

.filtros-backdrop {
    position: fixed;
    inset: 0;
    background: rgb(var(--preto-rgb) / .35);
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s var(--transicao);
    z-index: 110;
}

.filtros-backdrop.is-open {
    opacity: 1;
    pointer-events: auto;
}

body.filtros-aberto {
    overflow: hidden;
}


/* =========================
   RESPONSIVO
========================= */
@media (max-width: 980px) {
    .pesquisa-layout {
        grid-template-columns: 1fr;
    }

    .pesquisa-filtros-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .filtros-fechar {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: rgb(var(--cor-superficie-rgb) / .75);
    }

    .pesquisa-filtros {
        position: fixed;
        top: 0;
        left: 0;

        height: calc(100dvh - calc(2 * (14px + env(safe-area-inset-top))));
        max-height: none;

        width: min(92vw, 380px);
        border-radius: 0 22px 22px 0;

        transform: translateX(-105%);
        transition: transform .28s var(--transicao);

        z-index: 1000;
        box-shadow: var(--sombra);

        margin-top: calc(14px + env(safe-area-inset-top));
        margin-bottom: calc(14px + env(safe-area-inset-bottom));
    }

    .pesquisa-filtros.is-open {
        transform: translateX(0);
    }
}




/* =========================
   PÁGINA IMÓVEL (módulo)
========================= */
/* ---------- LAYOUT (2 colunas) ---------- */
.imovel-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) clamp(300px, 28vw, 390px);
    gap: 22px;
    align-items: start;
    margin-top: 16px;
}

/* coluna padrão */
.imovel-coluna {
    display: grid;
    gap: 14px;
    min-width: 0;
}

/* coluna direita sticky (acompanha scroll) */
.imovel-layout>.imovel-coluna:nth-child(2) {
    position: sticky;
    top: 86px;
    /* mantém alinhado com seu header sticky */
    align-self: start;
}

/* mobile/tablet: vira 1 coluna e remove sticky */
@media (max-width: 980px) {
    .imovel-layout {
        grid-template-columns: 1fr;
    }

    .imovel-layout>.imovel-coluna:nth-child(2) {
        position: static;
        top: auto;
    }
}

/* ---------- CARDS (mais profissionais) ---------- */
.imovel-layout .cartao,
.cartao.imovel-carrousel {
    border-radius: var(--imovel-raio);
    background: rgb(var(--cor-superficie-rgb) / .92);
    border: 1px solid var(--imovel-borda);
    box-shadow: var(--imovel-sombra);
}

/* tira o “gradiente bobo” do card global só dentro do módulo */
.imovel-layout .cartao {
    background: rgb(var(--branco-rgb) / .92);
}

/* ---------- HERO (títulos menores) ---------- */
.imovel-layout .hero .titulo-principal {
    margin: 0 0 8px;
    font-size: clamp(1.55rem, 2.25vw, 2.15rem);
    line-height: 1.12;
    letter-spacing: -0.02em;
}

.imovel-layout .hero .texto-apoio {
    margin: 0;
    color: var(--cor-texto-suave);
    max-width: 72ch;
}

/* linha separadora logo após hero (antes das sections) */
.imovel-layout .hero {
    padding-bottom: 14px;
    border-bottom: 1px solid var(--imovel-divisor);
    margin-bottom: 14px;
}

/* ---------- SECTIONS (sem padding gigante + divisores) ---------- */
/* suas sections estão como <div class="secao"> dentro do card */
.imovel-layout .cartao .secao {
    padding: 18px 0;
    /* substitui o 56px global */
}

/* divisor entre seções (dimensões / características / descrição etc) */
.imovel-layout .cartao .secao+.secao {
    border-top: 1px solid var(--imovel-divisor);
}

/* cabeçalho da seção mais discreto */
.imovel-layout .cabecalho-secao {
    margin-bottom: 10px;
}

.imovel-layout .titulo-secao {
    margin: 0;
    font-size: 1.12rem;
    font-weight: 850;
    letter-spacing: -0.01em;
}

/* conteúdo das seções (agora em GRID) */
.imovel-layout .cartao .secao>div {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px 16px;
    /* linha / coluna */
    align-items: start;
}

/* cada item */
.imovel-layout .cartao .secao span {
    display: flex;
    align-items: flex-start;
    gap: 8px;

    line-height: 1.35;
    color: var(--cor-texto-suave);
    font-size: .95rem;

    /* opcional: melhora o “bloco” visual sem ficar infantil */
    padding: 6px 0;
}

/* ícones */
.imovel-layout .cartao .secao span img.icone--inline {
    width: 16px;
    height: 16px;
    margin-top: 2px;
    opacity: .85;
}

/* responsivo: no mobile vira 1 coluna */
@media (max-width: 640px) {
    .imovel-layout .cartao .secao>div {
        grid-template-columns: 1fr;
    }
}


.imovel-layout .cartao .secao span {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.35;
    color: var(--cor-texto-suave);
    font-size: .95rem;
}

.imovel-layout .cartao .secao span img.icone--inline {
    width: 16px;
    height: 16px;
    margin-top: 2px;
    opacity: .85;
}

/* descrição com leitura melhor */
.imovel-descricao {
    color: var(--cor-texto-suave);
    line-height: 1.7;
}

.imovel-descricao p {
    margin: 0 0 12px;
}

.imovel-descricao p:last-child {
    margin-bottom: 0;
}

/* ---------- COLUNA DIREITA (cards com hierarquia) ---------- */
.imovel-layout>.imovel-coluna:nth-child(2) .cartao {
    padding: 16px;
}

.imovel-layout>.imovel-coluna:nth-child(2) .cartao+.cartao {
    margin-top: 10px;
}

/* “compartilhar” (se você mantiver só as imgs soltas) */
.imovel-layout>.imovel-coluna:nth-child(2) .cartao img.icone--inline {
    width: 18px;
    height: 18px;
}


/* ---------- CORRETORES (moderno e compacto) ---------- */
.corretores-lista {
    display: grid;
    gap: 0;
    margin-top: 8px;
}

/* item vira “linha” */
.corretor {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 12px;
    padding: 12px 0;

    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

/* divisor entre corretores (sem card dentro de card) */
.corretor+.corretor {
    border-top: 1px solid rgb(var(--espresso-rgb) / .08);
}

.corretor__avatar {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    overflow: hidden;
    display: grid;
    place-items: center;
    align-self: center;

    background: rgb(var(--espresso-rgb) / .05);
    border: 1px solid rgb(var(--espresso-rgb) / .10);
    color: var(--tema-escuro);
    font-weight: 900;
}

.corretor__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.corretor__body {
    min-width: 0;
    display: grid;
    gap: 0px;
}

.corretor__topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.corretor__nome {
    font-weight: 900;
    font-size: .98rem;
    line-height: 1.15;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.corretor__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-size: .86rem;
    color: var(--cor-texto-suave);
}

.corretor__acoes {
    display: inline-flex;
    gap: 8px;
    flex: 0 0 auto;
}

/* botões pequenos (ícone) */
.acao-icone {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;

    border: 1px solid rgb(var(--espresso-rgb) / .12);
    background: rgb(var(--cor-superficie-rgb) / .80);
    box-shadow: none;

    transition: transform .18s var(--transicao), background .18s var(--transicao), border-color .18s var(--transicao);
}

.acao-icone:hover {
    transform: translateY(-1px);
    background: rgb(var(--espresso-rgb) / .04);
    border-color: rgb(var(--espresso-rgb) / .16);
}

.acao-icone:focus-visible {
    outline: 3px solid rgb(var(--tema-rgb) / .35);
    outline-offset: 2px;
}

.acao-icone img {
    width: 16px;
    height: 16px;
    display: block;
}

/* leve destaque pro WhatsApp sem virar “botãozão” */
.acao-icone--wa {
    border-color: rgb(var(--tema-rgb) / .35);
    background: rgb(var(--tema-rgb) / .14);
}

/* mobile: mantém compacto */
@media (max-width: 420px) {
    .corretor {
        grid-template-columns: 40px 1fr;
        gap: 10px;
    }

    .acao-icone {
        width: 32px;
        height: 32px;
    }
}


/* ---------- BOTÕES no módulo (menos arredondado) ---------- */
.imovel-layout .botao {
    border-radius: 10px;
}

.imovel-layout .botao--principal {
    box-shadow: none;
}

.imovel-layout .botao--fantasma {
    background: rgb(var(--espresso-rgb) / .03);
}

/* ---------- CARROSSEL (CSS-only com scroll-snap) ---------- */
/*
  Você já renderiza várias <img> dentro de:
  <div class="cartao imovel-carrousel"> ... </div>

  Aqui transformamos isso em um “carrossel” horizontal
  com snap (arrastar no mouse / swipe no mobile).
*/
.cartao.imovel-carrousel {
    padding: 0;
    overflow: hidden;
    border-radius: var(--imovel-raio);
}

/* o container vira trilho */
.cartao.imovel-carrousel {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

/* esconde scrollbar (sem quebrar acessibilidade) */
.cartao.imovel-carrousel::-webkit-scrollbar {
    height: 8px;
}

.cartao.imovel-carrousel::-webkit-scrollbar-track {
    background: transparent;
}

.cartao.imovel-carrousel::-webkit-scrollbar-thumb {
    background: rgb(var(--espresso-rgb) / .18);
    border-radius: 999px;
}

/* cada imagem vira um slide */
.cartao.imovel-carrousel>img {
    flex: 0 0 100%;
    width: 100%;
    height: clamp(280px, 52vh, 520px);
    object-fit: cover;
    display: block;
    scroll-snap-align: start;
}

/* deixa o carrossel com “cara” de galeria (como ref) */
@media (min-width: 981px) {
    .cartao.imovel-carrousel>img {
        height: clamp(320px, 48vh, 560px);
    }
}


/* setas+ dots carrousel */
/* extras do carrossel (se usar o HTML opcional) */
.imovel-carrousel[data-carousel] {
    position: relative;
    padding: 0;
    overflow: hidden;
    display: block;
    /* desfaz o flex que usamos no CSS-only */
}

.imovel-carrousel .carrousel-track {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

/* remove a barra de rolagem (mantém swipe/scroll) */
.imovel-carrousel .carrousel-track {
    scrollbar-width: none;
    /* Firefox */
    -ms-overflow-style: none;
    /* IE/Edge antigo */
    overscroll-behavior-x: contain;
    touch-action: pan-y;
    /* ajuda a não "brigar" com scroll vertical */
}

.imovel-carrousel .carrousel-track::-webkit-scrollbar {
    width: 0;
    height: 0;
}

.imovel-carrousel .carrousel-track>img {
    flex: 0 0 100%;
    scroll-snap-align: start;
    width: 100%;
    height: clamp(280px, 52vh, 560px);
    object-fit: cover;
    display: block;
    cursor: pointer;
}

.imovel-carrousel .carrousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    height: 42px;
    border-radius: 10px;
    border: 1px solid rgb(var(--branco-rgb) / .35);
    background: rgb(var(--preto-rgb) / .35);
    color: rgb(var(--branco-rgb) / 1);
    backdrop-filter: blur(8px);
    display: grid;
    place-items: center;
    font-size: 26px;
    line-height: 1;
    z-index: 2;
}

.imovel-carrousel .carrousel-prev {
    left: 10px;
}

.imovel-carrousel .carrousel-next {
    right: 10px;
}

.imovel-carrousel .carrousel-dots {
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 12px;
    display: flex;
    gap: 8px;
    justify-content: center;
    z-index: 2;
}

.imovel-carrousel .carrousel-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgb(var(--branco-rgb) / .55);
   border: 1px solid rgb(var(--preto-rgb) / .12);
}

.imovel-carrousel .carrousel-dot.is-active {
    background: rgb(var(--branco-rgb) / .95);
}

/* ---------- SHARE / CARD AÇÃO (coluna direita) ---------- */
.card-acao {
    display: grid;
    gap: 12px;
}

.share-topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.share-label {
    font-size: .88rem;
    font-weight: 900;
    letter-spacing: -0.01em;
}

.share-sub {
    font-size: .82rem;
    color: var(--cor-texto-suave);
    margin-top: 2px;
}

.share-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(44px, 1fr));
    gap: 8px;
}

.share-btn {
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: 10px;
    border: 1px solid rgb(var(--espresso-rgb) / .12);
    background: rgb(var(--cor-superficie-rgb) / .78);
    box-shadow: none;

    transition: transform .18s var(--transicao), background .18s var(--transicao), border-color .18s var(--transicao);
}

.share-btn:hover {
    transform: translateY(-1px);
    background: rgb(var(--espresso-rgb) / .04);
    border-color: rgb(var(--espresso-rgb) / .16);
}

.share-btn:focus-visible {
    outline: 3px solid rgb(var(--tema-rgb) / .35);
    outline-offset: 2px;
}

.share-btn img {
    width: 18px;
    height: 18px;
    display: block;
}

.share-btn--ghost {
    width: 42px;
    padding: 0;
}

.share-icon {
    font-size: 18px;
    line-height: 1;
}

.share-divider {
    height: 1px;
    background: rgb(var(--espresso-rgb) / .10);
    margin: 2px 0;
}

/* ---------- PREÇO (compacto) ---------- */
.preco-box {
    display: grid;
    gap: 6px;
}

.preco-meta {
    display: grid;
    gap: 6px;
}

.tag-transacao {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 900;

    background: rgb(var(--tema-rgb) / .14);
    border: 1px solid rgb(var(--tema-rgb) / .35);
    color: var(--espresso);
}

.preco-mini {
    color: var(--cor-texto-suave);
    font-size: .95rem;
    line-height: 1.35;
}


/* ---------- LIGHTBOX (viewer fullscreen) ---------- */
.lb {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    background: rgb(var(--preto-rgb) / .92);
   color: rgb(var(--branco-rgb) / 1);
}

.lb.is-open {
    display: block;
}

.lb__backdrop {
    position: absolute;
    inset: 0;
}

.lb__top {
    position: absolute;
    top: 10px;
    left: 14px;
    right: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    z-index: 2;
    pointer-events: none;
}

.lb__counter {
    font-size: .9rem;
    opacity: .9;
    pointer-events: none;
}

.lb__tools {
    display: inline-flex;
    gap: 8px;
    pointer-events: auto;
}

.lb__icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    border: 1px solid rgb(var(--branco-rgb) / .18);
    background: rgb(var(--branco-rgb) / .08);
     color: rgb(var(--branco-rgb) / 1);
    display: grid;
    place-items: center;
    cursor: pointer;
}

.lb__icon:hover {
    background: rgb(var(--branco-rgb) / .14);
}

.lb__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    border-radius: 14px;
    border: 1px solid rgb(var(--branco-rgb) / .18);
    background: rgb(var(--branco-rgb) / .08);
    color: rgb(var(--branco-rgb) / 1);
    font-size: 40px;
    line-height: 1;
    display: grid;
    place-items: center;
    z-index: 2;
    cursor: pointer;
}

.lb__nav:hover {
    background: rgb(var(--branco-rgb) / .14);
}

.lb__prev {
    left: 16px;
}

.lb__next {
    right: 16px;
}

.lb__stage {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 70px 64px 110px;
    z-index: 1;
    outline: none;
}

.lb__stage img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transform-origin: center center;
    user-select: none;
    -webkit-user-drag: none;
    cursor: grab;
}

.lb__stage.is-dragging img {
    cursor: grabbing;
}

.lb__thumbs {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 12px;
    padding: 0 14px;
    display: flex;
    gap: 10px;
    justify-content: center;
    align-items: center;
    z-index: 2;
    overflow-x: auto;
    scroll-snap-type: x mandatory;

    scrollbar-width: none;
    -ms-overflow-style: none;
}

.lb__thumbs::-webkit-scrollbar {
    width: 0;
    height: 0;
}

.lb__thumb {
    width: 86px;
    height: 54px;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgb(var(--branco-rgb) / .18);
    background: rgb(var(--branco-rgb) / .06);
    opacity: .75;
    cursor: pointer;
    scroll-snap-align: center;
    flex: 0 0 auto;
}

.lb__thumb:hover {
    opacity: 1;
}

.lb__thumb.is-active {
    opacity: 1;
    border-color: rgb(var(--branco-rgb) / .55);
}

.lb__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 640px) {
    .lb__stage {
        padding: 64px 16px 106px;
    }

    .lb__nav {
        width: 46px;
        height: 46px;
        font-size: 34px;
    }

    .lb__thumb {
        width: 72px;
        height: 46px;
    }
}

/* ---------- MAPA DO IMOVEL ---------- */

.mapa-wrap {
    display: grid;
    gap: 10px;
}

.mapa {
    height: 320px;
    border-radius: var(--imovel-raio);
    overflow: hidden;
    border: 1px solid var(--imovel-borda);
    box-shadow: none;
}

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

/* opcional: deixa o leaflet com “cara” do layout */
.mapa .leaflet-control-zoom a {
    border-radius: 10px;
}

/* garante o mesmo visual do módulo fora do grid */
.imovel-layout .cartao,
.cartao.imovel-carrousel,
.cartao.mapa-card {
    border-radius: var(--imovel-raio);
    background: rgb(var(--branco-rgb) / .92);
    border: 1px solid var(--imovel-borda);
    box-shadow: var(--imovel-sombra);
}

/* card do mapa full-width */
.mapa-card {
    padding: 16px;
    margin-top: 14px;
}

/* header compacto (título + ações) */
.mapa-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.mapa-actions {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
}

/* botões tipo “chip” (mais modernos e menores) */
.mapa-btn {
    height: 36px;
    padding: 0 12px;
    border-radius: 999px;

    display: inline-flex;
    align-items: center;
    gap: 8px;

    border: 1px solid rgb(var(--espresso-rgb) / .12);
    background: rgb(var(--cor-superficie-rgb) / .78);
    box-shadow: none;

    font-weight: 900;
    font-size: .84rem;
    color: inherit;
    text-decoration: none;

    transition: transform .18s var(--transicao), background .18s var(--transicao), border-color .18s var(--transicao);
}

.mapa-btn:hover {
    transform: translateY(-1px);
    background: rgb(var(--espresso-rgb) / .04);
    border-color: rgb(var(--espresso-rgb) / .16);
}

.mapa-btn:focus-visible {
    outline: 3px solid rgb(var(--tema-rgb) / .35);
    outline-offset: 2px;
}

.mapa-btn img {
    width: 16px;
    height: 16px;
    display: block;
    opacity: .95;
}

/* mapa */
.mapa-wrap {
    display: grid;
}

.mapa {
    height: 360px;
    border-radius: var(--imovel-raio);
    overflow: hidden;
    border: 1px solid var(--imovel-borda);
}

/* no mobile: vira botão só com ícone */
@media (max-width: 520px) {
    .mapa-btn {
        width: 40px;
        padding: 0;
        justify-content: center;
    }

    .mapa-btn span {
        display: none;
    }
}


/* =========================
   SEÇÃO: IMÓVEIS MAIS ACESSADOS
========================= */
#imoveis_mais_acessados .imoveis-mais-acessados {
    display: grid;
    gap: 16px;

    /* cria N colunas conforme couber, com largura “de vitrine” */
    grid-template-columns: repeat(auto-fit, minmax(260px, 320px));

    /* centraliza quando tiver menos cards (1,2,3) */
    justify-content: center;
}

/* no mobile deixa ocupar a largura toda */
@media (max-width: 640px) {
    #imoveis_mais_acessados .imoveis-mais-acessados {
        grid-template-columns: 1fr;
        justify-content: stretch;
    }
}

/* =========================
   PÁGINA SOBRE
========================= */
.pagina-sobre .sobre-wrap{
    display: grid;
    gap: 16px;
}

/* HERO */
.pagina-sobre .sobre-hero{
    text-align: center;
    display: grid;
    gap: 10px;
    justify-items: center;
    margin-bottom: 8px;
}

.pagina-sobre .sobre-hero .texto-apoio{
    max-width: 78ch;
}

/* bloco de texto (história) */
.pagina-sobre .sobre-prosa{
    max-width: 92ch;
    margin-inline: auto;
    padding: 18px;
}

.pagina-sobre .sobre-prosa p{
    margin: 0 0 12px;
    color: var(--cor-texto-suave);
    line-height: 1.75;
}

.pagina-sobre .sobre-prosa p:last-child{
    margin-bottom: 0;
}

/* CARDS (fundação / atuação / bairros) */
.pagina-sobre .sobre-cards{
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
}

@media (max-width: 980px){
    .pagina-sobre .sobre-cards{
        grid-template-columns: 1fr;
    }
}

.pagina-sobre .sobre-card{
    padding: 18px;
}

.pagina-sobre .sobre-badge{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;

    padding: 6px 10px;
    border-radius: 999px;

    background: rgb(var(--tema-rgb) / .14);
    border: 1px solid rgb(var(--tema-rgb) / .35);
    color: var(--espresso);

    font-weight: 900;
    font-size: .82rem;
    letter-spacing: .02em;
    margin-bottom: 10px;
}

.pagina-sobre .sobre-card .titulo-cartao{
    margin: 0 0 8px;
}

.pagina-sobre .sobre-card .texto-cartao{
    margin: 0;
}

/* Missão / Visão */
.pagina-sobre .sobre-mv{
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 640px){
    .pagina-sobre .sobre-mv{
        grid-template-columns: 1fr;
    }
}

/* Lista de bairros com colunas */
.pagina-sobre .sobre-bairros{
    columns: 2;
    column-gap: 18px;
}

.pagina-sobre .sobre-bairros li{
    break-inside: avoid;
}

@media (max-width: 640px){
    .pagina-sobre .sobre-bairros{
        columns: 1;
    }
}

/* CTA discreta */
.pagina-sobre .sobre-cta{
    text-align: center;
    display: grid;
    gap: 10px;
    justify-items: center;
}

/* =========================
   CARD: ARQUIVOS DO IMÓVEL
========================= */
.arquivos-lista{
  display: grid;
  gap: 0;
  margin-top: 8px;
  max-height: 30vh;
  overflow-y: auto;
  overflow-x: unset;
}

.arquivos-lista::-webkit-scrollbar {
    width: 8px;
}

.arquivos-lista::-webkit-scrollbar-track {
    background: transparent;
}

.arquivos-lista::-webkit-scrollbar-thumb {
    background: var(--tema);
    border-radius: 999px;
    border: 1px solid rgb(var(--branco-rgb) / .55);
}

.arquivos-lista::-webkit-scrollbar-thumb:hover {
    background: var(--tema-escuro);
    cursor: pointer;
}

.arquivo-item{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
}

.arquivo-item + .arquivo-item{
  border-top: 1px solid rgb(var(--espresso-rgb) / .08);
}

.arquivo-info{
  min-width: 0;
  display: grid;
  gap: 4px;
}

.arquivo-nome{
  font-weight: 900;
  font-size: .96rem;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.arquivo-meta{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  font-size: .82rem;
  color: var(--cor-texto-fraco);
}

.arquivo-desc{
  font-size: .86rem;
  color: var(--cor-texto-suave);
  line-height: 1.35;
}

.arquivo-acoes{
  flex: 0 0 auto;
  display: inline-flex;
  gap: 8px;
}

.arquivo-btn{
  height: 34px;
  padding: 0 12px;
  border-radius: 10px;

  display: inline-flex;
  align-items: center;
  gap: 8px;

  border: 1px solid rgb(var(--espresso-rgb) / .12);
  background: rgb(var(--cor-superficie-rgb) / .80);
  box-shadow: none;

  font-weight: 900;
  font-size: .84rem;
  color: inherit;
  text-decoration: none;

  transition: transform .18s var(--transicao), background .18s var(--transicao), border-color .18s var(--transicao);
}

.arquivo-btn:hover{
  transform: translateY(-1px);
  background: rgb(var(--espresso-rgb) / .04);
  border-color: rgb(var(--espresso-rgb) / .16);
}

.arquivo-btn:focus-visible{
  outline: 3px solid rgb(var(--tema-rgb) / .35);
  outline-offset: 2px;
}

.arquivo-ico{
  width: 36px;
  height: 26px;
  border-radius: 10px;
  display: grid;
  place-items: center;

  background: rgb(var(--tema-rgb) / .14);
  border: 1px solid rgb(var(--tema-rgb) / .26);
  color: var(--espresso);
  font-weight: 900;
  line-height: 1;
}

/* =========================
   PÁGINA CONTATO (MINI)
========================= */
.pagina-contato .contato-hero{
  text-align: center;
  display: grid;
  gap: 10px;
  justify-items: center;
  margin-bottom: 14px;
}

.pagina-contato .contato-card{
  display: grid;
  gap: 12px;
  padding: 18px;
}

.pagina-contato .contato-card .texto-cartao{
  margin: 0;
  text-align: center;
}

.pagina-contato .contato-mapa{
  width: 100%;
  height: 320px;
  border: 0;
  border-radius: var(--raio);
  overflow: hidden;
  background: rgb(var(--cor-superficie-rgb) / .55);
}