﻿.main-header {
    box-shadow: none;
    border: none !important;
}

.main-render {
    padding-top: 75px;
}

.main-footer {
    display: none !important;
}
/* ── Layout base ─────────────────────────────────────────────────── */
#mapa-page {
    position: relative;
    height: calc(100vh - 86px);
    overflow: hidden;
    --mapa-bar-h: 64px; /* altura efetiva do header (barra + linha de filtros ativos quando visível); atualizada via JS */
}

/* ── Loading overlay (cobre #mapa-container) ─────────────────────── */
#mapa-loading {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 5;
    background: rgba(255,255,255,0.75);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-secondary-pure, #163867);
    pointer-events: auto;
    transition: opacity .2s ease;
}
#mapa-loading.oculto { opacity: 0; pointer-events: none; }

/* Modo padrão: spinner + texto numa linha (igual ao loading antigo). */
.mapa-loading-card {
    display: flex;
    align-items: center;
    gap: 10px;
}

.mapa-spinner {
    width: 22px; height: 22px;
    border: 2px solid rgba(22,56,103,.15);
    border-top-color: var(--color-secondary-pure, #163867);
    border-radius: 50%;
    animation: mapa-spin .7s linear infinite;
    flex: 0 0 auto;
}
@keyframes mapa-spin { to { transform: rotate(360deg); } }

/* Barra de progresso — escondida no modo padrão. */
.mapa-loading-barra { display: none; }

#mapa-loading.mapa-loading--destino .mapa-loading-card {
    flex-direction: column;
    gap: 12px;
    width: min(86%, 320px);
    padding: 20px 22px;
    background: transparent;
    border: none;
    border-radius: 14px;
    text-align: center;
}

#mapa-loading.mapa-loading--destino .mapa-loading-texto {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--color-secondary-pure, #163867);
}

#mapa-loading.mapa-loading--destino .mapa-loading-barra {
    display: block;
    width: 100%;
    height: 6px;
    border-radius: 999px;
    background: var(--color-secondary-tinted, #E8EEF5);
    overflow: hidden;
}

.mapa-loading-barra-fill {
    display: block;
    width: 8%;
    height: 100%;
    border-radius: 999px;
    background: var(--color-secondary-pure, #163867);
}

/* Avanço gradual automático: enche de ~8% a ~92% e segura — não depende de
   timing exato dos AJAX/voo; ao concluir, o overlay some (opacity). */
#mapa-loading.mapa-loading--destino .mapa-loading-barra-fill {
    animation: mapa-prog-destino 1.8s ease-out forwards;
}
@keyframes mapa-prog-destino {
    0%   { width: 8%; }
    55%  { width: 68%; }
    100% { width: 92%; }
}

@media (prefers-reduced-motion: reduce) {
    .mapa-spinner { animation-duration: 1.4s; }
    #mapa-loading.mapa-loading--destino .mapa-loading-barra-fill {
        animation: none;
        width: 60%;
    }
}

/* ── Wrapper da barra (full-width com centralização) ─────────────── */
#mapa-barra-wrapper {
    position: absolute;
    top: 0; left: 0; right: 0;
    z-index: 20;
    background: #fff;
    box-shadow: 0 1px 6px rgba(0,0,0,.08);
}
#mapa-barra-filtros {
    max-width: 1650px;
    margin: 0 auto;
    height: 64px;
    padding: 0 16px;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* ── Negócio tabs ────────────────────────────────────────────────── */
.mapa-negocio-btn {
    font-size: 13px;
    padding: 6px 14px;
    border-radius: 20px;
    font-weight: bold;
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    line-height: 1.4;
    transition: background 0.2s ease, color 0.2s ease;
}
.mapa-negocio-btn.ativo {
    background: var(--color-secondary-pure, #163867);
    color: #fff;
}
.mapa-negocio-btn:not(.ativo) {
    background: transparent;
    color: var(--color-secondary-pure, #163867);
}
    .mapa-negocio-btn:not(.ativo):hover {
        background: var(--color-secondary-pale, #B3C3DA);
    }

/* ── Separador vertical ──────────────────────────────────────────── */
.mapa-barra-sep {
    width: 1px; height: 28px;
    background: var(--color-neutral-light, #D1D1D1);
    flex-shrink: 0;
}

/* ── Selects dinâmicos ───────────────────────────────────────────── */
.mapa-select {
    height: 36px;
    border: 1px solid #16386761;
    border-radius: 5px;
    padding: 0 12px;
    font-size: 13px;
    background: #ffffff;
    color: #2c3e50;
    cursor: pointer;
    outline: none;
    flex: 1 1 0;
    font-weight: 500;
    min-width: 0;
    width: 100%;
    transition: border-color .2s ease, background .2s ease;
}
.mapa-select:hover { border-color: var(--color-secondary-soft, #4A70A1); background: #fff; }
.mapa-select:focus { border-color: var(--color-secondary-pure, #163867); background: #fff; }

/* ── Select2 na barra de filtros (desktop/tablet) ─────────────────────────
   O plugin substitui o <select> nativo por um .select2-container. Aqui ele
   herda o mesmo dimensionamento do .mapa-select (flex 1, 36px) e a mesma
   moldura, pra não quebrar o layout flex da barra. */
#mapa-barra-filtros .select2-container { flex: 1 1 0; min-width: 0; }
#mapa-barra-filtros .select2-container .select2-selection--single {
    height: 36px;
    border: 1px solid #16386761;
    border-radius: 5px;
    display: flex;
    align-items: center;
    padding: 0 10px;
    background: #fff;
}
#mapa-barra-filtros .select2-container .select2-selection--single .select2-selection__rendered {
    padding: 0;
    line-height: 34px;
    font-size: 13px;
    font-weight: 500;
    color: #2c3e50;
}
#mapa-barra-filtros .select2-container .select2-selection--single .select2-selection__arrow { height: 34px; }
#mapa-barra-filtros .select2-container--open .select2-selection--single { border-color: var(--color-secondary-pure, #163867); }
/* Dropdown sempre acima do mapa/controles do Leaflet (panes ~600, controles ~1000). */
.select2-container--open { z-index: 2000; }
/* Dropdown dos selects com busca (tipo/cidade/bairro): mostra ~10 itens antes do
   scroll e largura que acompanha o input, mas pode extrapolar um pouco (com teto).
   O dropdown é anexado no <body>, por isso a classe própria mapa-select2-dropdown. */
.select2-dropdown.mapa-select2-dropdown { max-width: 360px; }
.select2-dropdown.mapa-select2-dropdown .select2-results__options { max-height: 330px; }

/* ── Botões barra ────────────────────────────────────────────────── */
#btn-mais-filtros   { flex-shrink: 0; font-size: 12px; position: relative; }
#btn-mais-filtros.ativo {
    background: var(--color-secondary-pure, #163867);
    color: #fff;
}

/* ── Botões flutuantes ao lado esquerdo do painel lista ─────────── */
#mapa-btns-mapa {
    position: absolute;
    top: 15px;
    right: 12px;
    z-index: 4;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

    #mapa-btns-mapa .btn {
        padding: 6px 16px;
    }

:is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) {
    grid-auto-rows: 304px; /* ou minmax(0, 260px) */
}

#btn-desenhar-area {
    font-size: 15px;
    font-weight: 400;
    letter-spacing: .6px;
}

#btn-desenhar-area i {
    font-size: 19px;
}

/* ── Ações flutuantes (canto inferior esquerdo) ─────────────────── */
#mapa-acoes-regiao {
    display: flex;
    flex-direction: row;
    gap: 8px;
    pointer-events: none;
    max-width: calc(100% - 48px);
    flex-wrap: wrap;
    justify-content: flex-end;
}

#mapa-acoes-regiao.visivel {
    pointer-events: auto;
}

#mapa-acoes-regiao.d-none {
    display: none !important;
}

#mapa-acoes-regiao .btn {
    font-size: 15px;
}

.mapa-acao-flutuante {
    font-weight: 600;
    white-space: nowrap;
}

.mapa-acao-flutuante > i {
    margin-right: 6px;
}

#mapa-acoes-regiao.visivel .mapa-acao-flutuante {
    opacity: 1;
    transform: translateY(0);
}

#mapa-acoes-regiao .mapa-cidade-ancora-texto {
    letter-spacing: .6px;
    text-transform: capitalize;
}


/* Badge numérico (contador de filtros aplicados) */
.mapa-badge-contador {
    position: absolute;
    top: -6px; right: -6px;
    min-width: 18px; height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: var(--color-accent, #1E9E5F);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    box-shadow: 0 0 0 2px #fff;
}

/* ── Linha de filtros ativos ─────────────────────────────────────── */
#mapa-filtros-ativos {
    max-width: 1650px;
    margin: 0 auto;
    padding: 8px 16px 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    border-top: 1px solid var(--color-neutral-tinted, #F0F0F0);
}
#mapa-filtros-ativos.d-none { display: none !important; }

.mapa-filtros-ativos-label {
    font-size: 12px;
    color: var(--color-neutral-deep, #555);
    font-weight: 600;
    flex-shrink: 0;
}

.mapa-chip-removivel {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 28px;
    padding: 0 10px 0 12px;
    border-radius: 999px;
    background: var(--color-secondary-tinted, #E8EEF5);
    color: var(--color-secondary-pure, #163867);
    font-size: 12px;
    font-weight: 500;
    border: 1px solid transparent;
    white-space: nowrap;
    text-transform: lowercase; /* Padroniza a aparência dos chips ativos */
    transition: background .15s ease;
}
/* Primeira letra do label fica maiúscula pra ficar visualmente agradável */
.mapa-chip-removivel > span::first-letter { text-transform: uppercase; }
.mapa-chip-removivel:hover {
    background-color: var(--color-essence-ivory, #FFF);
    color: var(--color-secondary-pure, #163867);
    border: var(--border-width-hairline, 1px) solid #153563;
}
.mapa-chip-removivel .chip-x {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px; height: 16px;
    border-radius: 50%;
    background: rgba(0,0,0,.08);
    color: inherit;
    cursor: pointer;
    border: 0;
    padding: 0;
    line-height: 1;
    font-size: 10px;
}
.mapa-chip-removivel .chip-x:hover { background: rgba(0,0,0,.18); }

.mapa-link-limpar {
    background: none;
    border: 0;
    padding: 0 4px;
    margin-left: auto;
    color: var(--color-destructive-pure, #c62828);
    font-size: 12px;
    cursor: pointer;
    text-decoration: underline;
}
.mapa-link-limpar:hover { color: var(--color-destructive-deep, #8e1c1c); }

/* ── Mapa ────────────────────────────────────────────────────────── */
#mapa-container {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 0;
}

/* Attribution mais discreta — obrigatória pelas licenças OSM/CARTO/Esri, mas
   pode ficar menor pra não poluir o canto do mapa. */
.leaflet-control-attribution {
    font-size: 9px !important;
    opacity: .65;
    padding: 1px 6px !important;
}
.leaflet-control-attribution:hover { opacity: 1; }

/* Control de camadas (basemap switcher) — estilizado como um botão do portal
   ("Camadas" + ícone), posicionado logo abaixo do "Desenhar Área" no top-right
   pra agrupar os controles visuais do mapa numa única coluna. */
.leaflet-control-layers {
    background: #fff !important;
    border: 1px solid var(--color-neutral-pale, #E5E5E5) !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
}

/* Posicionado no bottom-right, um respiro acima da attribution do Leaflet
   (que também fica no bottom-right) pra não se sobreporem. */
.leaflet-bottom.leaflet-right .leaflet-control-layers {
    margin-right: 12px !important;
}

/* Toggle colapsado: substitui o ícone PNG default do Leaflet por nosso botão
   com ícone SVG de "layers" + label "Camadas". */
.leaflet-control-layers-toggle {
    width: auto !important;
    height: 34px !important;
    background-image: none !important; /* remove o ícone PNG default */
    padding: 0 14px 0 12px;
    display: flex !important;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .3px;
    text-decoration: none;
    box-shadow: var(--shadow-level-5);
    white-space: nowrap;
    background-color: var(--color-essence-ivory, #FFF);
    color: #000 !important;
    border: var(--border-width-hairline, 1px) solid #000;
    border-radius: 5px;
}
.leaflet-control-layers-toggle::before {
    content: '';
    display: inline-block;
    width: 18px;
    height: 18px;
    background-color: currentColor;
    /* Ícone "layers" (3 lâminas empilhadas) via mask SVG inline */
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M11.99 18.54l-7.37-5.73L3 14.07l9 7 9-7-1.63-1.27-7.38 5.74zM12 16l7.37-5.73L21 9l-9-7-9 7 1.63 1.27L12 16z'/%3E%3C/svg%3E") center / contain no-repeat;
            mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M11.99 18.54l-7.37-5.73L3 14.07l9 7 9-7-1.63-1.27-7.38 5.74zM12 16l7.37-5.73L21 9l-9-7-9 7 1.63 1.27L12 16z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.leaflet-control-layers-toggle::after { content: 'Camadas'; }
.leaflet-control-layers-toggle:hover { background: var(--color-neutral-tinted, #FAFAFA) !important; }

/* Expandido: toggle some, lista de opções aparece. */
.leaflet-control-layers-expanded .leaflet-control-layers-toggle { display: none !important; }
.leaflet-control-layers-expanded {
    padding: 10px 14px !important;
    min-width: 180px;
}
.leaflet-control-layers-expanded label {
    display: flex !important;
    align-items: center;
    gap: 8px;
    margin: 6px 0;
    font-size: 14px;
    color: #292929;
    cursor: pointer;
}
    .leaflet-control-layers-expanded label:hover {
        color: var(--color-accent-pure) !important;
    }
.leaflet-control-layers-expanded label input { margin: 0; cursor: pointer; }
.leaflet-control-layers-separator { margin: 8px -14px !important; }

/* Impede que arrastar o mapa (pan) destaque texto como "seleção" — mas SÓ nos
   panes interativos do Leaflet. Popups e nossos overlays customizados continuam
   selecionáveis (regra abaixo), pra usuário poder copiar endereço, valor e
   código do imóvel dos cards de popup. */
.leaflet-container .leaflet-marker-pane,
.leaflet-container .leaflet-shadow-pane,
.leaflet-container .leaflet-overlay-pane,
.leaflet-container .leaflet-tile-pane,
.leaflet-container .leaflet-tooltip-pane,
.leaflet-container .mapa-pin-preco,
.leaflet-container .marker-cluster {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
/* Reabilita seleção dentro de popups (Leaflet padrão + customizados do mapa) —
   o usuário precisa copiar endereço/valor/código do imóvel. */
.leaflet-popup-content,
.leaflet-popup-content *,
.mp-bldg-card, .mp-bldg-card *,
.mp-cluster-popup, .mp-cluster-popup * {
    -webkit-user-select: text;
    -moz-user-select: text;
    -ms-user-select: text;
    user-select: text;
}

.imovel-image-icons div {
    z-index: auto;
    padding: 8px;
    background: rgb(255 255 255);
    border-radius: 8px;
    border: 1px solid #163867;
}
.imovel-image-icons .abs-rotate {
    max-width: 30px;
    max-height: 30px;
    padding: 5px;
    height: 30px;
    width: 30px;
}
.imovel-image-badge.assinado-together {
    max-width: fit-content;
    border-radius: 10px !important;
    z-index: 1;
    padding: 4px 6px;
    bottom: 5px;
    right: 7px;
}

.imovel-card .imovel-festival-faixa {
    right: auto;
    width: 435px;
    left: -223px;
    top: 71px;
    transform: rotate(315deg) translateX(100px);
}
/* ── Overlay IA flutuante sobre o mapa ──────────────────────────── */
#mapa-ia-overlay {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 25;
    display: flex;
    align-items: center;
    gap: 0;
    width: min(420px, calc(100% - 32px));
    background: #fff;
    border-radius: 999px;
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
    padding: 4px 4px 4px 12px;
}
#mapa-ia-overlay .ia-overlay-search-icon {
    color: var(--color-neutral-soft, #8a9bb5);
    font-size: 16px;
    flex-shrink: 0;
    margin-right: 6px;
}
#mapa-ia-overlay #filtro-ia {
    flex: 1;
    border: 0;
    background: transparent;
    height: 36px;
    font-size: 13px;
    outline: none;
    color: #2c3e50;
}
#mapa-ia-overlay #filtro-ia::placeholder { color: #8a9bb5; }
.mapa-ia-submit {
    height: 32px;
    padding: 0 14px;
    border: 0;
    border-radius: 999px;
    background: var(--color-accent-pure, #1E9E5F);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s ease;
}
.mapa-ia-submit:hover { background: var(--color-accent-deep, #167a47); }

/* ── Chip "Área desenhada" sobre o mapa ─────────────────────────── */
/* Compartilha o look-and-feel do #mapa-hint-desenho (verde + texto branco +
   sombra) porque os dois se sucedem no fluxo de "desenhar área": o hint some
   quando o usuário termina o traçado e este chip aparece confirmando.
   Manter o mesmo "container visual" reforça que é a mesma etapa do fluxo. */
#chip-area-desenhada {
    position: absolute;
    bottom: 52px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    display: flex;
    align-items: center;
    gap: 10px;
    background: #186531;
    color: #fff;
    border-radius: 8px;
    padding: 8px 14px;
    font-size: .8rem;
    font-weight: 600;
    box-shadow: 0 2px 10px rgba(0,0,0,.35);
    white-space: nowrap;
    pointer-events: auto;
}
#chip-area-desenhada.d-none { display: none !important; }
#chip-area-desenhada i.uil-vector-square { color: rgba(255,255,255,.9); }
#chip-area-desenhada #btn-chip-area-remover {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.4);
    color: #fff;
    border-radius: 5px;
    padding: 3px 8px;
    font-size: .75rem;
    cursor: pointer;
    transition: background .15s;
}
#chip-area-desenhada #btn-chip-area-remover:hover { background: rgba(255,255,255,.3); }

/* ── Split container ─────────────────────────────────────────────── */
#mapa-split {
    position: absolute;
    top: var(--mapa-bar-h, 64px); left: 0; right: 0; bottom: 0;
    display: flex;
    flex-direction: row;
}

/* ── MODO TESTE: painel-lista à ESQUERDA, mapa à DIREITA ─────────────
   Toda a inversão acontece via esta única classe modificadora. Para voltar
   ao layout original, basta remover `painel-esquerda` do #mapa-split. */
#mapa-split.painel-esquerda { flex-direction: row-reverse; }

/* Borda do painel: era à esquerda (separava do mapa à direita); agora à direita. */
#mapa-split.painel-esquerda #mapa-painel-lista {
    border-left: 0;
    border-right: 1px solid var(--color-neutral-light, #D1D1D1);
}

/* Handle de colapso: agora fica no lado ESQUERDO do mapa-area
   (que está à direita), com cantos arredondados à direita. */
#mapa-split.painel-esquerda .mapa-colapsar-handle {
    right: auto;
    left: 0;
    border-radius: 0 8px 8px 0;
    border-left: 0;
    border-right: 1px solid var(--color-neutral-light, #D1D1D1);
    box-shadow: 2px 0 8px rgba(0,0,0,.1);
}

/* Ícone do btn-expandir-painel (tray) — está fixo como 'angle-left-b' no
   Razor. No modo invertido a seta deve apontar pra DIREITA pra sugerir
   "expande pra direita". scaleX(-1) espelha o glyph sem trocar a classe. */
#mapa-split.painel-esquerda #btn-expandir-painel i { transform: scaleX(-1); }

/* Área do mapa (flex item esquerdo) */
#mapa-area {
    position: relative;
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

/* Handle de colapso (borda direita de #mapa-area, 28×56px) */
.mapa-colapsar-handle {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 28px; height: 56px;
    background: #fff;
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    border-radius: 8px 0 0 8px;
    border-right: 0;
    box-shadow: -2px 0 8px rgba(0,0,0,.1);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 15;
    font-size: 18px;
    color: var(--color-neutral-deep, #555);
    transition: background 0.2s ease, color 0.2s ease;
}
.mapa-colapsar-handle:hover {
    background: var(--color-secondary-tinted, #E8EEF5);
    color: var(--color-secondary-pure, #163867);
}
#mapa-split.painel-colapsado .mapa-colapsar-handle { display: none; }

/* ── Drawer "Mais filtros" (lateral direito) ─────────────────────── */
#mapa-painel-mais-filtros {
    position: fixed;
    inset: 0;
    z-index: 1901;
    display: none;
    pointer-events: none;
}
#mapa-painel-mais-filtros.visivel { display: block; pointer-events: auto; }

.mf-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 12, 24, 0.4);
    opacity: 0;
    transition: opacity 220ms cubic-bezier(.2,.7,.2,1);
}
#mapa-painel-mais-filtros.visivel .mf-overlay { opacity: 1; }

.mf-drawer {
    position: absolute;
    right: 0;
    top: 0;
    margin-left: auto;
    width: 420px;
    max-width: 100vw;
    height: 100vh;
    background: var(--color-essence-ivory, #fff);
    box-shadow: -8px 0 24px rgba(0,0,0,0.16);
    display: flex;
    flex-direction: column;
    transform: translateX(40px);
    opacity: 0;
    transition: transform 220ms cubic-bezier(.2,.7,.2,1),
                opacity   220ms cubic-bezier(.2,.7,.2,1);
}
#mapa-painel-mais-filtros.visivel .mf-drawer {
    transform: translateX(0);
    opacity: 1;
}

.mf-header {
    flex: 0 0 auto;
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--color-neutral-pale, #E5E5E5);
}
.mf-titulo {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
    flex: 0 0 auto;
    color: var(--color-neutral-deepest, #292929);
}
.mf-badge-ativos {
    background: var(--color-secondary-tinted, #E8EEF5);
    color: var(--color-secondary-pure, #163867);
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
}
.mf-badge-ativos.d-none { display: none; }
.mf-fechar {
    margin-left: auto;
}
.mf-fechar:hover { background: var(--color-neutral-tinted, #FAFAFA); }

.mf-corpo {
    position: relative;              /* ancora o overlay de loading */
    flex: 1 1 auto;
    overflow: hidden;                /* NÃO rola — o overlay fica filho dele */
    display: flex;
    flex-direction: column;
    min-height: 0;                   /* permite o filho flex shrink corretamente */
}
.mf-corpo-scroll {
    flex: 1 1 auto;
    overflow-y: auto;                /* rola APENAS o conteúdo, não o overlay */
    padding: 16px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    min-height: 0;
}
.mf-loading { color: var(--color-neutral-deep, #555); font-size: 13px; }

/* Overlay translúcido que aparece sobre o conteúdo atual durante o reload do partial.
   O usuário vê seu estado anterior (chips, ranges) levemente apagado em vez de uma
   tela branca com spinner — muito menos "travada" entre selecionar Tipo e ver os
   Subtipos chegarem. */
.mf-overlay-loading {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 40%;                /* spinner alinhado próximo ao topo da área visível */
    background: rgba(255, 255, 255, 0.65);
    backdrop-filter: blur(1.5px);
    -webkit-backdrop-filter: blur(1.5px);
    z-index: 10;
    opacity: 0;
    pointer-events: none;            /* invisível não bloqueia */
    transition: opacity .18s ease;
}
.mf-overlay-loading.visivel {
    opacity: 1;
    pointer-events: auto;            /* enquanto carregando, bloqueia clique no fundo */
}
.mf-overlay-loading .mapa-spinner { width: 28px; height: 28px; }
/* Conteúdo atrás do overlay fica levemente desbotado pra dar dica visual de transição */
.mf-corpo.mf-carregando .mf-corpo-scroll > .mf-grupo { opacity: .6; transition: opacity .18s ease; }

.mf-grupo { display: flex; flex-direction: column; gap: 10px; }
.mf-grupo-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-transform: uppercase;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .5px;
    color: var(--color-neutral-deep, #4A4A4A);
    margin: 0 0 2px;
}
.mf-sub-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--color-neutral-deep, #4A4A4A);
    margin-top: 4px;
}
.mf-grupo-remover {
    background: none;
    border: none;
    padding: 0;
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    color: var(--color-secondary-soft, #4A70A1);
    cursor: pointer;
    text-decoration: underline;
    flex-shrink: 0;
    line-height: 1;
}
.mf-grupo-remover:hover { color: var(--color-primary, #E5351F); }

.mf-chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.mf-chip {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid #b0bac6;
    background: #fff;
    color: var(--color-neutral-deepest, #292929);
    font-size: 12px;
    cursor: pointer;
    transition: background 120ms, color 120ms, border-color 120ms, transform 120ms;
    margin: 0;
    user-select: none;
}
    .mf-chip:hover {
        border-color: var(--color-secondary-pale, #B3C3DA);
        transform: translateY(-1px);
        background: var(--color-secondary-tinted, #E8EEF5);
    }
.mf-chip.ativo {
    background: var(--color-secondary-pure, #163867);
    color: #fff;
    border-color: var(--color-secondary-pure, #163867);
    font-weight: 600;
}
.mf-chip-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 0;
    height: 0;
}

/* Estado "bloqueado": quando o grupo tem alguma seleção ativa, todos os chips
   ficam não-clicáveis — a única forma de alterar é via botão "Remover".
   Chips selecionados continuam destacados; os não-selecionados ficam apagados
   pra deixar claro que não podem ser escolhidos sem antes remover. */
.mf-grupo-bloqueado .mf-chip { cursor: not-allowed; pointer-events: none; }
.mf-grupo-bloqueado .mf-chip:not(.ativo) { opacity: .4; }

.mf-range {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
/* Wrapper que posiciona o "R$" / "m²" dentro do .mf-field sem alterar o input */
.mf-range-field { position: relative; }
.mf-range-field .mf-field { width: 100%; }
.mf-range-affix {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-neutral-soft, #8a9bb5);
    font-size: 12px;
    font-weight: 600;
    pointer-events: none;
    line-height: 1;
}
.mf-range-field-prefix .mf-range-affix { left: 12px; }
.mf-range-field-prefix .mf-field       { padding-left: 32px; }
.mf-range-field-suffix .mf-range-affix { right: 12px; }
.mf-range-field-suffix .mf-field       { padding-right: 32px; }
.mf-field {
    height: 40px;
    border: 1px solid var(--color-neutral-pale, #E5E5E5);
    border-radius: 8px;
    padding: 0 12px;
    font-size: 13px;
    background: #fff;
    color: var(--color-neutral-deepest, #292929);
    width: 100%;
}
.mf-field:focus {
    outline: none;
    border-color: var(--color-secondary-pure, #163867);
}
.mf-field.preenchido {
    font-weight: 500;
    color: var(--color-neutral-deepest, #292929);
}

.mf-busca { position: relative; }
.mf-busca-input { padding-right: 32px; }
.mf-busca-icon {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-neutral-soft, #BDBDBD);
    font-size: 14px;
    pointer-events: none;
}

.mf-lista-scroll {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 180px;
    overflow-y: auto;
    padding: 4px 2px;
}

.mf-checks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 16px;
}
.mf-check {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    margin: 0;
    font-size: 13px;
}
.mf-check-texto {
    line-height: 1.3;
    text-transform: uppercase;
}
.mf-check-qtd { color: var(--color-neutral-soft, #BDBDBD); font-size: 11px; }
.mf-check input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    background: #fff;
    margin: 0;
    transition: background 120ms, border-color 120ms;
}
.mf-check input[type="checkbox"]:checked {
    background: var(--color-secondary-pure, #163867);
    border-color: var(--color-secondary-pure, #163867);
}
.mf-check input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 1px;
    width: 5px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.mf-link-cidade {
    display: block;
    padding: 6px 0;
    font-size: 13px;
    color: var(--color-secondary-pure, #163867);
    text-decoration: none;
    text-transform: uppercase;
}
.mf-link-cidade:hover { text-decoration: underline; }

.mf-footer {
    flex: 0 0 auto;
    background: var(--color-neutral-tinted, #FAFAFA);
    border-top: 1px solid var(--color-neutral-pale, #E5E5E5);
    padding: 14px 20px;
    display: flex;
    gap: 10px;
}
.mf-btn-limpar {
    flex: 1 1 0;
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    color: var(--color-neutral-deep, #4A4A4A);
    height: 40px;
    font-weight: 500;
}
.mf-btn-aplicar {
    flex: 2 1 0;
    font-weight: 600;
}

/* ── Painel direito: Lista ───────────────────────────────────────── */
.mapa-painel {
    display: flex;
    flex-direction: column;
    background: #fff;
    overflow: hidden;
}

/* Split panel — flex item direito */
#mapa-painel-lista {
    position: relative;
    width: 40%;
    flex-shrink: 0;
    border-left: 1px solid var(--color-neutral-light, #D1D1D1);
    transition: width 200ms ease;
}

@media (max-width: 1279.98px) and (min-width: 1024px) {
    #mapa-painel-lista { width: 42%; }
}

/* Painel colapsado — tray 56px */
#mapa-split.painel-colapsado #mapa-painel-lista { width: 56px; }
#mapa-split.painel-colapsado .mapa-painel-header,
#mapa-split.painel-colapsado .mapa-painel-corpo { display: none !important; }

/* Tray — conteúdo visível quando colapsado */
#mapa-tray-conteudo {
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    padding: 12px 8px;
    height: 100%;
    overflow: hidden;
}
#mapa-split.painel-colapsado #mapa-tray-conteudo { display: flex; }

/* Botão expandir (circular 40×40) */
.mapa-tray-expandir {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--color-secondary-pure, #163867);
    color: #fff;
    border: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    font-size: 18px;
    transition: background 0.2s ease;
}
.mapa-tray-expandir:hover { background: var(--color-secondary-darker, #0D2241); }

/* Texto vertical da tray */
.mapa-tray-texto {
    flex: 1;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    font-size: 11px;
    font-weight: 600;
    color: var(--color-secondary-pure, #163867);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-height: calc(100% - 100px);
    padding: 8px 0;
}

.mapa-painel-header {
    padding: 10px 14px;
    border-bottom: 1px solid var(--color-neutral-light, #D1D1D1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-shrink: 0;
}
.mapa-painel-corpo { overflow-y: auto; flex: 1; }

/* Controles do header da lista (sort + toggle vista) */
.mapa-painel-header-controles {
    flex-shrink: 0;
}
/* Os <select> e botões dentro do header não devem disparar o toggle de colapso */
.mapa-painel-header-controles select,
.mapa-painel-header-controles button {
    cursor: pointer;
}

.mapa-select-sort {
    height: 30px;
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    border-radius: 5px;
    padding: 0 10px;
    font-size: 12px;
    background: #fff;
    color: #2e2e2e;
    outline: none;
    cursor: pointer;
    max-width: 130px;
}

.mapa-toggle-vista {
    display: inline-flex;
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    border-radius: 8px;
    overflow: hidden;
}
.mapa-toggle-vista-btn {
    width: 30px; height: 30px;
    border: 0;
    background: #fff;
    color: var(--color-neutral-deep, #555);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 14px;
    transition: background .15s ease, color .15s ease;
}
.mapa-toggle-vista-btn:hover { background: var(--color-neutral-tinted, #FAFAFA); }
.mapa-toggle-vista-btn.ativo {
    background: var(--color-secondary-pure, #163867);
    color: #fff;
}

/* ── Ícone de colapso ────────────────────────────────────────────── */
.mapa-toggle-icone {
    transition: transform .35s cubic-bezier(0.4, 0, 0.2, 1);
    flex-shrink: 0;
    line-height: 1;
}

/* Lançamento como patrocínio na listagem do mapa */
.imovel-card.imovel-novo {
    background: #ebebeba1 !important;
    border: 1px solid #cfcfcf;
}

/* ── Cards da lista (reutiliza o template article.imovel-card do Buscar) ── */
#mapa-cards {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    align-items: start;
}
#mapa-cards.mapa-cards-lista {
    display: flex !important;
    flex-direction: column;
}
#mapa-cards .btn-carregar-mais-cards {
    grid-column: 1 / -1;
}

/* Wrapper do card (consumido pelo JS via data-imovel-id) */
.mapa-card-item {
    position: relative;
    border-radius: 12px;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    background: #fff;
    overflow: hidden;
}
.mapa-card-item:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,.12);
    transform: translateY(-2px);
}
.mapa-card-item > article {
    width: 100%;
    height: 100%;
}

.mapa-card-subtitulo-grid { display: none !important; }

/* Bloco extra do preview mobile (oculto; revelado só por .mm-preview--imovel). */
.mapa-card-preview-extra { display: none; }

/* Stats compactos (ícone + número) — base oculta; ativada no grid/popup/preview. */
.mapa-card-stats {
    display: none;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}
.mapa-card-stats {
    display: none;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    overflow-x: auto;
    width: 100%;
}
.mapa-card-stats::-webkit-scrollbar {
    width: 3px; /* Width of vertical scrollbar */
    height: 3px; /* Height of horizontal scrollbar */
}

/* The background track */
.mapa-card-stats::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 5px;
}

/* The draggable scrolling handle */
.mapa-card-stats::-webkit-scrollbar-thumb {
    background: #c3c3c3;
    border-radius: 5px;
}

/* Handle on hover */
.mapa-card-stats::-webkit-scrollbar-thumb:hover {
    background: #555555;
}
.mapa-card-stats .mapa-card-stat {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    border: 1px solid var(--color-neutral-light, #D1D1D1);
    border-radius: 999px;
    padding: 2px 10px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.6;
    color: var(--color-secondary-pure, #163867);
    background: #fff;
    white-space: nowrap;
}
.mapa-card-stats .mapa-card-stat i {
    font-size: 14px;
    line-height: 1;
}
/* Negócio (Venda/Aluguel/Lançamento): ícone fixo + texto que trunca se for longo. */
.mapa-card-stat-negocio {
    max-width: 140px;
    min-width: 0;
}
.mapa-card-stat-negocio i {
    flex: 0 0 auto;
}
.mapa-card-stat-negocio .ellipse-text {
    max-width: 100%;
}

/* Card vertical (foto topo, título, preço+m², stats, botão). O :is() aplica o MESMO
   layout no grid (#mapa-cards), no popup do pin (.leaflet-popup) e nos previews mobile. */
:is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-item {
    height: 100%;
}
:is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-item .imovel-card {
    flex-direction: column !important;
    align-items: stretch !important;
    height: 100% !important;
}
:is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-item .imovel-image {
    width: 100%;
    flex: 0 0 150px;
    max-width: 100%;
    min-width: 100%;
    height: 150px;
}
    :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-item .imovel-image-content img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }
:is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup) .mapa-card-item .imovel-info {
    width: 100%;
    flex: 1 1 auto;
    padding: 4px 12px 10px !important;
    gap: 4px !important;
    overflow: hidden;
}


/* Oculta o que não faz parte do card novo (subtítulos, diferencial, anunciante, .imovel-feature). */
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .mapa-card-subtitulo-lista,
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .mapa-card-subtitulo-grid,
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .mapa-card-diferencial,
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .imovel-anunciante,
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .divisor,
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .imovel-feature {
            display: none !important;
        }

:is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .mapa-card-endereco {
    display: -webkit-box !important;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 15px !important;
    line-height: 1.25;
    color: black !important;
    margin: 0 !important;
}

        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info .mapa-card-valor-m2 {
            display: block !important;
        }

        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info > div:first-child {
            order: 1;
        }
        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-info > div:nth-child(2) {
            flex-direction: column !important;
            align-items: stretch !important;
            gap: 4px !important;
            order: 2;
        }

        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-price {
            align-items: baseline;
            gap: 0 8px !important;
        }
            :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .imovel-price p {
                margin: 0;
                font-size: 11px;
                line-height: 1.1;
            }
                :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup) .imovel-price p:first-child strong {
                    font-size: 16px !important;
                    line-height: 1.1;
                }
            :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-valor-m2 {
                font-size: 11px !important;
                color: var(--color-secondary-pure, #163867);
            }

        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-stats {
            display: flex;
        }

            :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-stats.grid-anunciante {
                overflow: hidden;
                align-items: baseline;
            }

            :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-stats.grid-anunciante span {
                font-weight: 500;
            }

            :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-card-stats.grid-anunciante picture {
                max-width: 16px;
                line-height: 1;
                border-radius: 3px;
            }

        :is(#mapa-cards:not(.mapa-cards-lista), .leaflet-popup, .mm-preview--imovel, .mm-preview--lista) .mapa-btn-imovel {
            width: 100%;
            margin-top: 2px;
        }
        /* ───── Modo lista (1 coluna) — altura fixa, imagem max 200px ─────────── */
        #mapa-cards.mapa-cards-lista .mapa-card-item {
            min-height: 160px;
            overflow: visible;
            width: 100%;
        }

            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-card {
                height: 100% !important;
            }

            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-image {
                flex: 0 0 200px !important;
                width: 200px !important;
                max-width: 200px !important;
                height: 100%;
                min-width: auto;
            }

            #mapa-cards.mapa-cards-lista .mapa-card-item .mapa-btn-imovel {
                display: none;
            }

            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-image img {
                width: 100%;
                height: 100%;
                object-fit: cover;
                display: block;
            }

            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-info {
                flex: 1 1 auto;
                min-width: 0;
                overflow: hidden;
            }

        #mapa-cards.mapa-cards-lista .imovel-info .mapa-card-subtitulo-grid {
            display: none !important;
        }

.mapa-card-item .favorito-resultado-busca {
    position: absolute;
    top: 6px;
    right: 7px;
    z-index: 2;
    padding: 6px 5px;
}

/* ── Card canônico no popup do pin (desktop) e no preview mobile: ajustes próprios desses contextos ── */

/* Coração à esquerda do X de fechar do Leaflet (que fica em right:6px). */
.leaflet-popup .mapa-card-item .favorito-resultado-busca {
    right: 40px;
}
.leaflet-popup .mapa-card-item {
    border: 0;
    border-radius: 0;
}
.leaflet-popup .mapa-card-item:hover {
    box-shadow: none;
    transform: none;
}

/* Preview mobile: card edge-to-edge e foto hero maior. */
.mm-preview--imovel .mapa-card-item {
    border: 0;
    border-radius: 0;
}
.mm-preview--imovel .mapa-card-item .imovel-image {
    flex: 0 0 200px;
    height: 200px;
}
        /* ── Popup do pin ────────────────────────────────────────────────── */
        .leaflet-popup-content-wrapper {
            padding: 0 !important;
            border-radius: 12px !important;
            overflow: hidden !important;
            box-shadow: 0 8px 32px rgba(0,0,0,.14) !important;
        }

        .leaflet-popup-content {
            margin: 0 !important;
            width: 280px !important;
            overflow: hidden !important;
        }

        /* Skeleton enquanto o card do pin carrega (popup abre na hora). */
        .leaflet-popup .mapa-popup-loading {
            display: flex;
            align-items: center;
            justify-content: center;
            min-height: 150px;
        }

        .leaflet-popup .leaflet-popup-close-button {
            top: 6px !important;
            right: 6px !important;
            width: 30px !important;
            height: 30px !important;
            z-index: 1000 !important;
            background: #ffffff !important;
            font: initial !important;
            border-radius: var(--border-radius-nano, 8px);
            color: #163867 !important;
            transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
            border: var(--border-width-hairline, 1px) solid #163867 !important;
        }

            .leaflet-popup .leaflet-popup-close-button:hover {
                box-shadow: var(--shadow-level-1);
                transform: translateY(-1px);
                background-color: #b3c3da !important;
                color: #050b17 !important;
                border-color: #050b17 !important;
            }

            .leaflet-popup .leaflet-popup-close-button span {
                font-size: 27px;
                position: relative;
                top: -1px;
                line-height: 1;
            }

.leaflet-popup-content .mapa-btn-imovel {
    display: none;
}

.leaflet-popup-tip {
    display: none;
}
.mapa-popup {
    max-width: 280px;
    border-radius: 12px;
    overflow: hidden;
}

        .mapa-popup-img {
            width: 100%;
            height: 150px;
            object-fit: cover;
            display: block;
        }

        .mapa-popup-info {
            padding: 12px;
            display: flex;
            flex-direction: column;
            gap: 4px;
        }
        /* Blocos extras do card (só usados no preview mobile) ocultos no popup desktop. */
        .leaflet-popup .mp-pin-badges,
        .leaflet-popup .mp-pin-descricao,
        .leaflet-popup .mp-pin-anunciante,
        .leaflet-popup .mp-pin-negocio {
            display: none !important;
        }

        /* ── Popup do pin = mesmo visual do card ── */
        .leaflet-popup .mapa-popup-info {
            gap: 8px;
            padding: 12px 14px 14px;
        }
        .leaflet-popup .mp-pin-title {
            display: -webkit-box;
            -webkit-line-clamp: 2;
            -webkit-box-orient: vertical;
            overflow: hidden;
            font-size: 14px;
            line-height: 1.25;
            margin: 0;
        }
        .leaflet-popup .mp-pin-stats {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            gap: 6px;
            margin: 0;
        }
            .leaflet-popup .mp-pin-stats span {
                display: inline-flex;
                align-items: center;
                gap: 5px;
                border: 1px solid var(--color-neutral-light, #D1D1D1);
                border-radius: 999px;
                padding: 2px 10px;
                font-size: 12px;
                font-weight: 600;
                color: var(--color-secondary-pure, #163867);
                background: #fff;
                white-space: nowrap;
            }
                .leaflet-popup .mp-pin-stats span i { font-size: 14px; line-height: 1; }

        .leaflet-popup .mp-pin-btn {
            width: 100%;
            margin-top: 2px;
        }

        /* Coração de favoritar à ESQUERDA do X de fechar (close fica em right:6px). */
        .leaflet-popup .mp-pin-favorito {
            position: absolute;
            top: 6px;
            right: 38px;
            z-index: 1000;
            background: #fff;
            border-radius: 8px;
            padding: 5px 6px;
            box-shadow: 0 1px 4px rgba(0,0,0,.18);
        }

        .leaflet-popup-content p {
            margin: 0;
        }
        /* ── Pins com preço ──────────────────────────────────────────────── */
        .leaflet-map-pane,
        .leaflet-marker-pane,
        .leaflet-shadow-pane,
        .leaflet-overlay-pane,
        .leaflet-marker-icon {
            overflow: visible !important;
        }

        .mapa-pin-wrapper {
            background: transparent !important;
            border: none !important;
            overflow: visible !important;
        }

        .mapa-pin-preco {
            position: absolute;
            background: #fff;
            color: var(--color-secondary-pure, #133769);
            border: 1px solid var(--color-secondary-pure, #133769);
            font-weight: 700;
            font-size: 12px;
            padding: 4px 10px;
            border-radius: 12px;
            white-space: nowrap;
            box-shadow: 0 2px 8px rgba(0,0,0,.25);
            cursor: pointer;
            transform: translate(-50%, calc(-100% - 8px));
            left: 0;
            top: 0;
            transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
        }

            .mapa-pin-preco::after {
                /*content: '';*/
                position: absolute;
                top: 100%;
                left: 50%;
                transform: translateX(-50%);
                border: 5px solid transparent;
                border-top-color: var(--color-secondary-pure, #133769);
                border-bottom: 0;
            }
            /* Pin "já visto" — usuário clicou nele alguma vez (persistido em localStorage). */
            .mapa-pin-preco.visitado {
                background: #eaeaea;
                color: #2e415a;
                border-color: #2e415a;
                box-shadow: 0 1px 4px rgba(0,0,0,.12);
            }

                .mapa-pin-preco.visitado::after {
                    border-top-color: #BFC6CF;
                }
                /* .ativo (hover do card no painel direito) tem prioridade sobre .visitado */
                .mapa-pin-preco.ativo,
                .mapa-pin-preco.visitado.ativo {
                    background: var(--color-success-pure, #e67e22);
                    color: #fff;
                    border-color: var(--color-success-pure, #e67e22);
                }

                    .mapa-pin-preco.ativo::after,
                    .mapa-pin-preco.visitado.ativo::after {
                        border-top-color: var(--color-success-pure, #e67e22);
                    }
                /* Pin SELECIONADO — o que está aberto/clicado AGORA (popup/preview visível).
                   Tem prioridade sobre .visitado e .ativo. */
                .mapa-pin-preco.selecionado,
                .mapa-pin-preco.visitado.selecionado,
                .mapa-pin-preco.ativo.selecionado {
                    background: var(--color-secondary-pure, #163867);
                    color: #fff;
                    border-color: var(--color-secondary-pure, #163867);
                }

                    .mapa-pin-preco.selecionado::after,
                    .mapa-pin-preco.visitado.selecionado::after,
                    .mapa-pin-preco.ativo.selecionado::after {
                        border-top-color: var(--color-secondary-pure, #163867);
                    }
        /* Hover sobre o pin no mapa (especialmente útil quando vários estão sobrepostos no spiderfy):
   o elemento sob o cursor sobe para o z-index mais alto e ganha um leve "pop" sutil. */
        .mapa-pin-wrapper:hover {
            z-index: 1001000 !important;
        }

            .mapa-pin-wrapper:hover .mapa-pin-preco {
                transform: translate(-50%, calc(-100% - 11px)) scale(1.04);
                box-shadow: 0 6px 14px rgba(0,0,0,.32);
                z-index: 9999 !important;
            }
        /* Hover sobre um CLUSTER (ou a pílula de edifício): sobe pro topo — mesma lógica do
   .mapa-pin-preco. Resolve o caso de um cluster ficar escondido atrás de uma pílula:
   ao passar o mouse, ele vem pra frente de todos.
   O z-index vai no elemento POSICIONADO (.marker-cluster, que é o .leaflet-marker-icon);
   o "pop" (scale) vai no DIV interno pra não conflitar com o translate3d inline do Leaflet. */
        .leaflet-marker-icon.marker-cluster:hover,
        .mp-edificio-wrapper:hover {
            z-index: 1001000 !important;
        }

        .marker-cluster div {
            transition: transform .12s ease;
        }

        .marker-cluster:hover div {
            transform: scale(1.08);
        }
        /* ── Marcador de edifício (pílula navy) ──────────────────────────── */
        .mp-edificio-wrapper {
            pointer-events: auto;
        }

        .mp-edificio-pill {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: var(--color-secondary-pure, #163867);
            color: #fff;
            border: 2px solid #fff;
            border-radius: 999px;
            padding: 6px 14px 6px 6px;
            box-shadow: 0 2px 8px rgba(0,0,0,.22);
            transform: translate(-50%, -50%);
            transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
            cursor: pointer;
            white-space: nowrap;
        }

            .mp-edificio-pill:hover {
                transform: translate(-50%, calc(-50% - 1px)) scale(1.04);
            }

            .mp-edificio-pill.ativo {
                background: var(--color-accent-pure, #1E9E5F);
                box-shadow: 0 0 0 4px rgba(24,101,49,.25), 0 2px 8px rgba(0,0,0,.22);
                transform: translate(-50%, -50%) scale(1.04);
            }

            .mp-edificio-pill .mp-icon {
                width: 24px;
                height: 24px;
                border-radius: 50%;
                background: rgba(255,255,255,.18);
                display: inline-flex;
                align-items: center;
                justify-content: center;
                flex-shrink: 0;
            }

            .mp-edificio-pill .mp-textos {
                display: inline-flex;
                flex-direction: column;
                line-height: 1.1;
            }

            .mp-edificio-pill .mp-count {
                font-size: 12px;
                font-weight: 700;
                line-height: 1.1;
            }

            .mp-edificio-pill .mp-from {
                font-size: 10px;
                opacity: .85;
                line-height: 1.2;
                margin-top: 1px;
            }
        /* ── Popover de edifício (320px) ─────────────────────────────────── */
        .leaflet-popup.mp-building-popup .leaflet-popup-content-wrapper {
            width: 320px !important;
            padding: 0 !important;
            border-radius: 12px !important;
            overflow: hidden !important;
        }

        .leaflet-popup.mp-building-popup .leaflet-popup-content {
            width: 320px !important;
            margin: 0 !important;
            overflow: hidden !important;
        }

        .mp-bldg-card {
            display: flex;
            flex-direction: column;
            background: #fff;
        }

        .mp-bldg-loading {
            display: flex;
            align-items: center;
            justify-content: center;
            min-height: 160px;
        }

        .mp-bldg-erro {
            padding: 18px;
            text-align: center;
            color: var(--color-neutral-deep, #555);
            font-size: 12px;
        }

        .mp-bldg-hero {
            position: relative;
            height: 60px;
            overflow: hidden;
            background: linear-gradient(135deg, #1E4E8C, #163867);
        }

        .mp-bldg-hero-bg {
            position: absolute;
            right: 12px;
            top: 4px;
            opacity: .28;
        }

            .mp-bldg-hero-bg svg {
                width: 48px;
                height: 72px;
            }

        .mp-bldg-hero::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(to top, rgba(0,0,0,.55), transparent 60%);
        }

        .mp-bldg-titulo {
            position: absolute;
            bottom: 8px;
            left: 12px;
            right: 40px;
            color: #fff;
            z-index: 1;
        }

        .mp-bldg-nome {
            font-size: 13px;
            font-weight: 700;
            line-height: 1.2;
        }

        .mp-bldg-endereco {
            font-size: 10px;
            opacity: .9;
            line-height: 1.3;
            margin-top: 2px;
        }

        .mp-bldg-fechar {
            position: absolute;
            top: 10px;
            right: 10px;
            width: 28px;
            height: 28px;
            border-radius: 50%;
            background: rgba(0,0,0,.55);
            color: #fff;
            border: 0;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            z-index: 2;
            font-size: 16px;
            line-height: 1;
        }

            .mp-bldg-fechar:hover {
                background: rgba(0,0,0,.75);
            }

        .mp-bldg-sort {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 6px 10px;
            border-bottom: 1px solid var(--color-neutral-tinted, #F0F0F0);
            font-size: 10px;
            color: var(--color-neutral-deep, #555);
        }

        .mp-bldg-sort-select {
            border: 0;
            background: transparent;
            font-size: 10px;
            cursor: pointer;
            color: var(--color-secondary-pure, #163867);
            font-weight: 600;
        }

        .mp-bldg-lista {
            max-height: 200px;
            overflow-y: auto;
        }

        .mp-edificio-unidade-item {
            display: grid;
            grid-template-columns: 48px 1fr auto;
            gap: 8px;
            align-items: center;
            padding: 8px 10px;
            border-top: 1px solid var(--color-neutral-tinted, #F0F0F0);
            text-decoration: none;
            color: inherit;
        }

            .mp-edificio-unidade-item:first-child {
                border-top: 0;
            }

            .mp-edificio-unidade-item:hover {
                background: var(--color-bg-app, #F8F9FB);
            }

            .mp-edificio-unidade-item img,
            .mp-edificio-unidade-item .mp-thumb-placeholder {
                width: 48px;
                height: 48px;
                border-radius: 6px;
                object-fit: cover;
                display: block;
            }

            .mp-edificio-unidade-item .mp-thumb-placeholder {
                background: var(--color-neutral-tinted, #F0F0F0);
            }

        .mp-edificio-unidade-info {
            min-width: 0;
        }

            .mp-edificio-unidade-info .mp-unid-nome {
                font-size: 11px;
                font-weight: 700;
                line-height: 1.25;
                color: var(--color-secondary-pure, #163867);
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
            }

            .mp-edificio-unidade-info .mp-unid-tipo {
                font-size: 9px;
                text-transform: uppercase;
                color: var(--color-neutral-deep, #555);
                margin-top: 1px;
            }

            .mp-edificio-unidade-info .mp-unid-stats {
                font-size: 9px;
                color: var(--color-neutral-deep, #555);
                margin-top: 2px;
            }

        .mp-edificio-unidade-preco {
            font-size: 12px;
            font-weight: 700;
            color: var(--color-secondary-pure, #163867);
            white-space: nowrap;
        }

        .mp-bldg-footer {
            padding: 8px 10px;
        }
        /* O CTA usa as classes padrão de botão (btn btn-md btn-accent btn-outlined);
   aqui só alinhamos o ícone de seta (que aponta para o painel, à esquerda) antes do texto. */
        .mp-bldg-cta {
            display: inline-flex;
            align-items: center;
            gap: 6px;
        }

            .mp-bldg-cta i {
                font-size: 16px;
                line-height: 1;
            }
        /* Estados de carregamento/erro do popup de cluster. O conteúdo em si reusa o
           card .mp-bldg-* (via construirHtmlCardAgrupado); as antigas classes de layout
           da mini-lista (cabecalho/lista/item/info/endereco/tipo/preco) foram removidas. */
        .mp-cluster-mini-loading {
            display: flex;
            align-items: center;
            justify-content: center;
            min-height: 80px;
        }

        .mp-cluster-mini-erro {
            padding: 12px;
            font-size: 11px;
            color: var(--color-neutral-deep, #555);
            text-align: center;
        }

        /* ── Mobile: popover de edifício vira bottom-sheet ───────────────── */
        .mp-bldg-bottom-sheet {
            position: fixed;
            left: 0;
            right: 0;
            bottom: 0;
            background: #fff;
            border-radius: 20px 20px 0 0;
            max-height: 75vh;
            overflow: hidden;
            transform: translateY(110%);
            transition: transform .3s cubic-bezier(.4, 0, .2, 1);
            z-index: 1100;
            box-shadow: 0 -4px 24px rgba(0,0,0,.18);
            display: flex;
            flex-direction: column;
        }

            .mp-bldg-bottom-sheet.visivel {
                transform: translateY(0);
            }

            .mp-bldg-bottom-sheet .mp-bldg-lista {
                max-height: calc(75vh - 280px);
            }
        /* ── Desenho de polígono ─────────────────────────────────────────── */
        #mapa-container.modo-desenho,
        #mapa-container.modo-desenho .leaflet-interactive,
        #mapa-container.modo-desenho .leaflet-container {
            cursor: crosshair !important;
            user-select: none;
            -webkit-user-select: none;
        }
            /* Em modo desenho, marcadores e popups precisam ignorar mouse pra
   o mousedown chegar até o handler do mapa (caso contrário o desenho
   nunca começa quando o usuário clica em cima de um pino/cluster/pílula). */
            #mapa-container.modo-desenho .leaflet-marker-icon,
            #mapa-container.modo-desenho .leaflet-marker-shadow,
            #mapa-container.modo-desenho .leaflet-popup-pane,
            #mapa-container.modo-desenho .leaflet-tooltip-pane {
                pointer-events: none !important;
            }

        #mapa-hint-desenho {
            position: absolute;
            bottom: 52px;
            left: 50%;
            transform: translateX(-50%);
            background: #186531;
            color: #fff;
            border-radius: 8px;
            padding: 8px 14px;
            z-index: 997;
            display: flex;
            align-items: center;
            gap: 10px;
            box-shadow: 0 2px 10px rgba(0,0,0,.35);
            white-space: nowrap;
            font-size: .8rem;
            pointer-events: auto;
        }

            #mapa-hint-desenho button {
                background: rgba(255,255,255,.15);
                border: 1px solid rgba(255,255,255,.4);
                color: #fff;
                border-radius: 5px;
                padding: 3px 10px;
                font-size: .75rem;
                cursor: pointer;
                display: flex;
                gap: 5px;
                transition: background .15s;
            }

                #mapa-hint-desenho button:hover {
                    background: rgba(255,255,255,.3);
                }
        /* ── Ícones de características do anúncio (Vídeo / Tour Virtual / Financiamento) ── */
        .mapa-card-icones-anuncio {
            position: absolute;
            top: 6px;
            left: 6px;
            z-index: 3;
            display: flex;
            gap: 4px;
            pointer-events: none; /* não atrapalha o clique no link do card */
        }

.imovel-image-icons {
    top: 6px;
    right: 42px;
}


#mapa-cards.mapa-cards-lista .imovel-image-icons {
    right: 6px;
}
/* ── Loading não-destrutivo nos cards ────────────────────────────── */
/* Overlay ancorado em parent não-rolável p/ não rolar junto com #mapa-cards. */
.mapa-painel-corpo-wrap {
    position: relative;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

            .mapa-painel-corpo-wrap.mapa-cards-carregando .mapa-cards-overlay,
            .mapa-painel-corpo-wrap .mapa-cards-overlay {
                position: absolute;
                inset: 0;
                background: rgba(255, 255, 255, 0.7);
                display: flex;
                align-items: flex-start;
                justify-content: center;
                padding-top: 20px;
                z-index: 5;
                pointer-events: none;
            }
        /* ── Clusters Leaflet: paleta azul secundária — halo translúcido + núcleo sólido ── */
        /* Progressão light → dark acompanha a densidade: small (poucos) → large (muitos) */

        .marker-cluster-small {
            background-color: rgba(74, 112, 161, 0.22);
        }
        /* soft/22% */
        .marker-cluster-medium {
            background-color: rgba(30, 78, 140, 0.22);
        }
        /* mid/22%  */
        .marker-cluster-large {
            background-color: rgba(13, 34, 65, 0.22);
        }
        /* darker/22% */

        .marker-cluster-small div {
            background-color: var(--color-secondary-soft, #4A70A1);
        }

        .marker-cluster-medium div {
            background-color: #1E4E8C;
        }

        .marker-cluster-large div {
            background-color: var(--color-secondary-darker, #0D2241);
        }

        .marker-cluster span {
            color: #fff;
        }

        .marker-cluster div {
            border: 1px solid white;
        }
        /* Cluster de alta densidade ligeiramente maior para reforçar a hierarquia */
        .marker-cluster-large {
            width: 48px !important;
            height: 48px !important;
        }

            .marker-cluster-large div {
                width: 38px;
                height: 38px;
                margin-left: 5px;
                margin-top: 5px;
            }

            .marker-cluster-large span {
                line-height: 38px;
            }

        @media (min-width: 1550px) {
            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-image {
                flex: 0 0 300px !important;
                width: 300px !important;
                max-width: 300px !important;
                height: 100%;
                min-width: auto;
            }

            .imovel-image {
                max-width: 100%;
            }
        }

        @media screen and (min-width: 1600px) {
            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-image {
                flex: 0 0 350px !important;
                width: 350px !important;
                max-width: 350px !important;
                height: 100%;
                min-width: auto;
            }
        }

        @media screen and (min-width: 1950px) {
            #mapa-cards {
                grid-template-columns: 1fr 1fr 1fr;
            }

            #mapa-cards.mapa-cards-lista .mapa-card-item .imovel-image {
                flex: 0 0 400px !important;
                width: 400px !important;
                max-width: 400px !important;
                height: 100%;
                min-width: auto;
            }
        }

/* ── Estado vazio do painel (nenhum imóvel na área) ── */
.mapa-vazio {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 32px 18px;
    gap: 6px;
}

.mapa-vazio-titulo {
    margin: 4px 0 0;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-secondary-pure, #163867);
}

.mapa-vazio-sub {
    margin: 0 0 20px;
    font-size: 15px;
    line-height: 1.45;
    color: var(--color-neutral-deep, #555);
}

.mapa-vazio-acoes {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

.mapa-vazio-acao {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    text-align: left;
    background: var(--color-essence-ivory, #fff);
    border: 1px solid var(--color-neutral-pale, #E5E5E5);
    border-radius: 12px;
    padding: 12px 14px;
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

    .mapa-vazio-acao:hover,
    .mapa-vazio-acao:focus-visible {
        border-color: var(--color-secondary-soft, #4A70A1);
        background: var(--color-secondary-tinted, #E8EEF5);
        box-shadow: 0 2px 8px rgba(22, 56, 103, .08);
        outline: none;
    }

.mapa-vazio-acao-ic {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    border-radius: 10px;
    background: var(--color-secondary-tinted, #E8EEF5);
    color: var(--color-secondary-pure, #163867);
    font-size: 22px;
    transition: background .15s ease;
}

    .mapa-vazio-acao:hover .mapa-vazio-acao-ic {
        background: #fff;
    }

.mapa-vazio-acao-txt {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.mapa-vazio-acao-titulo {
    font-size: 17px;
    font-weight: 600;
    color: var(--color-secondary-pure, #163867);
}

.mapa-vazio-acao-desc {
    font-size: 14px;
    line-height: 1.35;
    color: var(--color-neutral-deep, #555);
}