:root {
    --cor-primaria: #005ca9;
    --cor-destaque: #f39200;
    --cor-fundo: #f8fafc;
    --cor-texto: #0f172a;
    --cor-texto-sec: #475569;
    --cor-borda: #e2e8f0;
    --radius-lg: 20px;
}

html {
    scrollbar-gutter: stable;
}

.imovel-hero-full {
    width: auto;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow-x: clip;
}

.imovel-hero {
    background:
        radial-gradient(circle at top right, rgba(243, 146, 0, 0.22), transparent 28%),
        linear-gradient(135deg, #0f3f78 0%, #155fad 52%, #0f67c7 100%);
    color: #fff;
    padding: 30px 0 38px;
}

.imovel-hero-conteudo {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    align-items: center;
    gap: 28px;
}

.imovel-hero-copy {
    display: grid;
    gap: 10px;
}

.imovel-hero-tipo {
    display: inline-flex;
    width: fit-content;
    padding: 6px 11px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    font-size: 14px;
    font-weight: 800;
    opacity: 0.9;
}

.imovel-hero h1 {
    margin: 0;
    max-width: 900px;
    font-size: clamp(30px, 4.5vw, 52px);
    line-height: 1.05;
    font-weight: 900;
    text-transform: uppercase;
}

.imovel-hero-local {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 17px;
    line-height: 1.4;
}

.imovel-hero-tags,
.imovel-resumo-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.imovel-hero-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 10px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.10);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
}

.imovel-hero-price-card {
    display: grid;
    gap: 7px;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.96);
    color: #0f172a;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.22);
}

.imovel-hero-price-card > span,
.imovel-hero-price-card small {
    color: #64748b;
    font-size: 13px;
    font-weight: 800;
}

.imovel-hero-price-card strong {
    color: #0f67c7;
    font-size: clamp(25px, 2.6vw, 34px);
    line-height: 1.08;
    font-weight: 900;
    white-space: nowrap;
}

.imovel-hero-cta {
    margin-top: 8px;
}

.imovel-detalhe-layout {
    display: grid;
    grid-template-columns: minmax(0, 2.1fr) minmax(320px, 0.95fr);
    gap: 28px;
    margin: 26px 0 40px;
    align-items: start;
}

.imovel-detalhe-principal,
.imovel-detalhe-sidebar {
    display: grid;
    gap: 18px;
}

.imovel-detalhe-principal .card,
.imovel-detalhe-sidebar .card {
    margin: 0;
}

.imovel-detalhe-sidebar {
    gap: 16px;
    position: sticky;
    top: 96px;
    align-self: start;
}

.imovel-galeria {
    margin: 0;
    padding: 0;
    overflow: hidden;
    border: 1px solid #e8eef5;
    border-radius: 22px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

.imovel-galeria-main {
    background: #eef4fb;
    border-radius: 22px;
    overflow: hidden;
}

.imovel-galeria-main img,
.imovel-galeria-placeholder {
    display: block;
    width: 100%;
    height: 330px;
    object-fit: cover;
}

.imovel-galeria-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px;
    background: linear-gradient(135deg, #eef4fb, #dbe8f7);
    color: #475569;
    text-align: center;
}

.imovel-galeria-placeholder .bi {
    color: #0f67c7;
    font-size: 34px;
}

.imovel-galeria-placeholder strong {
    color: #0f172a;
    font-size: 18px;
}

.imovel-galeria-placeholder span {
    max-width: 460px;
    font-size: 14px;
    line-height: 1.5;
}

.imovel-galeria-thumbs {
    display: flex;
    gap: 10px;
    padding: 12px 14px 14px;
    overflow-x: auto;
}

.imovel-thumb {
    width: 72px;
    height: 52px;
    padding: 0;
    border: 1px solid transparent;
    border-radius: 10px;
    background: #fff;
    cursor: pointer;
    overflow: hidden;
}

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

.imovel-thumb.ativo {
    border-color: #9fc3ee;
    box-shadow: 0 0 0 3px rgba(15, 103, 199, 0.08);
}

.imovel-bloco {
    background: #fff;
    border: 1px solid #edf2f7;
    border-radius: 20px;
    padding: 20px 22px;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.03);
}

.imovel-bloco h2 {
    margin: 0 0 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid #e7eef6;
    font-size: 17px;
    font-weight: 700;
    color: #0f172a;
}

.imovel-bloco-head {
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid #e7eef6;
}

.imovel-bloco-head span {
    display: block;
    margin-bottom: 4px;
    color: #64748b;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.imovel-bloco-head h2 {
    margin: 0;
    padding: 0;
    border: 0;
    color: #0f67c7;
    font-size: 26px;
    line-height: 1.15;
    font-weight: 900;
}

.imovel-card-head {
    margin-bottom: 12px;
}

.imovel-card-head h2 {
    font-size: 22px;
}

.imovel-resumo-oportunidade {
    border-color: #dbe8f7;
    background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}

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

.imovel-resumo-item {
    min-width: 0;
    padding: 14px;
    border: 1px solid #dbe6f4;
    border-radius: 16px;
    background: #fff;
}

.imovel-resumo-item span {
    display: block;
    margin-bottom: 5px;
    color: #64748b;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.imovel-resumo-item strong {
    color: #0f172a;
    font-size: 17px;
    line-height: 1.35;
}

.imovel-resumo-chips {
    margin-top: 14px;
}

.imovel-resumo-chips span {
    display: inline-flex;
    align-items: center;
    border: 1px solid #dbe6f4;
    border-radius: 999px;
    background: #eef6ff;
    padding: 6px 10px;
    color: #0f3f78;
    font-size: 13px;
    font-weight: 800;
}

.imovel-resumo-nota {
    margin: 14px 0 0;
    border-left: 4px solid #0f67c7;
    border-radius: 10px;
    background: #f8fbff;
    padding: 11px 13px;
    color: #334155;
    font-size: 14px;
    line-height: 1.6;
}

.analise-localizacao-card {
    border-color: #dbe8f7;
}

.imovel-relatorio-decisao-card {
    border-color: #bfdbfe;
    background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
}

.imovel-relatorio-decisao-card .ia-relatorio-consolidado-acoes .btn {
    justify-content: center;
    min-width: 240px;
}

.analise-localizacao-premium {
    display: grid;
    gap: 14px;
}

.analise-localizacao-map {
    position: relative;
    z-index: 0;
    min-height: 360px;
    overflow: hidden;
    border: 1px solid #dbe6f4;
    border-radius: 8px;
    background: #eaf2fb;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.analise-localizacao-map .leaflet-pane {
    z-index: 1;
}

.analise-localizacao-map .leaflet-overlay-pane {
    z-index: 2;
}

.analise-localizacao-map .leaflet-shadow-pane {
    z-index: 3;
}

.analise-localizacao-map .leaflet-marker-pane {
    z-index: 4;
}

.analise-localizacao-map .leaflet-tooltip-pane {
    z-index: 5;
}

.analise-localizacao-map .leaflet-popup-pane,
.analise-localizacao-map .leaflet-control-container {
    z-index: 6;
}

.analise-localizacao-loading {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 18px;
    color: #475569;
    font-size: 14px;
    font-weight: 800;
    text-align: center;
}

.analise-localizacao-marker span {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border: 2px solid #ffffff;
    border-radius: 8px;
    background: var(--poi-color, #0f67c7);
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.25);
}

.analise-localizacao-body {
    display: grid;
    gap: 16px;
}

.analise-localizacao-indice {
    display: grid;
    gap: 10px;
}

.analise-localizacao-indice > div:first-child {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.analise-localizacao-indice span,
.analise-localizacao-ratings span {
    color: #334155;
    font-size: 14px;
    font-weight: 900;
}

.analise-localizacao-indice strong {
    color: #334155;
    font-size: 18px;
    font-weight: 900;
}

.analise-localizacao-indice-nota {
    margin: 0;
    color: #64748b;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.45;
}

.analise-localizacao-indice-nota strong {
    color: #475569;
    font-weight: 900;
}

.analise-localizacao-barra {
    height: 8px;
    overflow: hidden;
    border-radius: 999px;
    background: #e5e7eb;
}

.analise-localizacao-barra span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #22c55e;
}

.analise-localizacao-ratings {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 24px;
}

.analise-localizacao-ratings--infra {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.analise-localizacao-ratings > div {
    display: grid;
    gap: 4px;
}

.analise-localizacao-seguranca-linha {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px 20px;
    margin-top: 4px;
    padding: 14px 16px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #f8fafc;
}

.analise-localizacao-seguranca-linha-texto {
    display: grid;
    gap: 4px;
    min-width: min(100%, 240px);
    flex: 1 1 200px;
}

.analise-localizacao-seguranca-titulo {
    display: block;
    color: #334155;
    font-size: 14px;
    font-weight: 900;
}

.analise-localizacao-seguranca-linha-texto small {
    color: #64748b;
    font-size: 12px;
    font-weight: 650;
    line-height: 1.35;
}

.analise-localizacao-seguranca-stars {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.analise-localizacao-stars {
    display: inline-flex;
    gap: 2px;
    color: #f5b301;
    font-size: 17px;
}

.analise-localizacao-stars .bi-star {
    color: #cbd5e1;
}

.analise-localizacao-indisponivel {
    width: fit-content;
    padding: 5px 9px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #64748b;
    font-size: 12px;
    font-weight: 800;
}

.analise-localizacao-pois {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.analise-oportunidade-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.analise-oportunidade-grid article {
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 12px;
    border: 1px solid #dbe6f4;
    border-radius: 8px;
    background: #ffffff;
}

.analise-oportunidade-grid span {
    color: #64748b;
    font-size: 12px;
    font-weight: 900;
}

.analise-oportunidade-grid strong {
    color: #0f172a;
    font-size: 22px;
    line-height: 1.1;
    font-weight: 950;
}

.analise-oportunidade-grid small {
    color: #64748b;
    font-size: 12px;
    line-height: 1.35;
    font-weight: 700;
}

.analise-cenarios-margem-wrap {
    display: grid;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid #dbe6f4;
    border-radius: 12px;
    background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
}

.analise-cenarios-margem-intro {
    display: grid;
    gap: 6px;
}

.analise-cenarios-margem-intro > span {
    color: #0f172a;
    font-size: 13px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.analise-cenarios-margem-intro small {
    margin: 0;
    color: #64748b;
    font-size: 12px;
    font-weight: 650;
    line-height: 1.45;
}

.analise-cenarios-margem-intro strong {
    color: #475569;
    font-weight: 900;
}

.analise-cenarios-margem-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.analise-cenario-margem-card {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #ffffff;
}

.analise-cenario-margem-card--unico {
    max-width: 100%;
}

.analise-cenario-margem-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}

.analise-cenario-margem-head > span {
    color: #334155;
    font-size: 12px;
    font-weight: 900;
    line-height: 1.25;
}

.analise-cenario-margem-info {
    flex-shrink: 0;
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: #e8f1fc;
    color: #0f67c7;
    cursor: help;
    font-size: 15px;
    line-height: 1;
}

.analise-cenario-margem-info:hover,
.analise-cenario-margem-info:focus-visible {
    background: #d6e8fb;
    outline: none;
    box-shadow: 0 0 0 2px rgba(15, 103, 199, 0.25);
}

.analise-cenario-margem-sub {
    margin: 0;
    color: #64748b;
    font-size: 11px;
    font-weight: 650;
    line-height: 1.35;
}

.analise-cenario-margem-card strong {
    color: #0f172a;
    font-size: 20px;
    font-weight: 950;
    line-height: 1.1;
}

.analise-cenario-margem-card > small:last-of-type {
    color: #64748b;
    font-size: 12px;
    font-weight: 700;
}

.analise-cenario-margem-venda {
    color: #334155 !important;
    font-size: 12px;
    font-weight: 800 !important;
}

.analise-cenario-margem-resultado--negativo {
    color: #92400e !important;
}

.analise-cenario-margem-aviso {
    color: #92400e !important;
    font-weight: 700 !important;
}

.analise-localizacao-poi {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 8px;
    min-width: 0;
    padding: 10px;
    border: 1px solid #dbe6f4;
    border-radius: 8px;
    background: #f8fbff;
}

.analise-localizacao-poi span {
    min-width: 0;
    color: #475569;
    font-size: 13px;
    font-weight: 800;
}

.analise-localizacao-poi strong {
    color: #0f172a;
    font-size: 16px;
    font-weight: 900;
}

.analise-localizacao-texto {
    display: flex;
    gap: 8px;
    margin: 0;
    color: #334155;
    font-size: 14px;
    line-height: 1.55;
}

.analise-localizacao-texto .bi {
    color: #64748b;
    margin-top: 2px;
}

.analise-recomendacao {
    padding: 12px;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    background: #eff6ff;
}

.analise-recomendacao-final {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    background: #eff6ff;
}

.analise-recomendacao-final > div:first-child {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.analise-recomendacao-final span {
    color: #1e40af;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.analise-recomendacao-final strong {
    color: #0f172a;
    font-size: 18px;
    line-height: 1.2;
    font-weight: 950;
    text-align: right;
}

.analise-recomendacao-final p,
.analise-recomendacao-final small {
    margin: 0;
    color: #334155;
    font-size: 14px;
    line-height: 1.55;
}

.analise-recomendacao-final small {
    color: #64748b;
    font-size: 12px;
}

.analise-recomendacao-listas {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.analise-recomendacao-listas > div {
    min-width: 0;
    border: 1px solid #dbeafe;
    border-radius: 8px;
    background: #ffffff;
    padding: 10px;
}

.analise-recomendacao-listas h4 {
    margin: 0 0 8px;
    color: #0f172a;
    font-size: 13px;
    line-height: 1.25;
    font-weight: 900;
}

.analise-recomendacao-listas ul {
    display: grid;
    gap: 6px;
    margin: 0;
    padding-left: 17px;
}

.analise-recomendacao-listas li {
    color: #475569;
    font-size: 12px;
    line-height: 1.45;
}

.imovel-texto-lista {
    display: grid;
    gap: 10px;
    color: #334155;
    line-height: 1.65;
    font-size: 15px;
}

.imovel-texto-lista p {
    margin: 0;
}

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

.imovel-info-item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 52px;
    padding: 12px 14px;
    border: 1px solid #edf2f7;
    border-radius: 14px;
    background: #fbfdff;
    color: #1e293b;
    font-size: 15px;
    font-weight: 500;
}

.imovel-info-item .bi {
    color: #3b82f6;
    font-size: 16px;
}

.imovel-bullets {
    margin: 0;
    padding-left: 20px;
    display: grid;
    gap: 12px;
    color: #334155;
    line-height: 1.75;
    font-size: 15px;
}

.imovel-documentos {
    display: grid;
    gap: 10px;
}

/* Só o link do título do documento; não afeta <a class="btn"> dentro do resultado (ex.: pagamento avulso). */
.imovel-documentos .imovel-documento-linha > a {
    color: #1768d0;
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
}

.imovel-documento-item {
    display: grid;
    gap: 8px;
}

.imovel-documento-linha {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.imovel-documento-item .btn-ia-documento {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    justify-self: start;
    /* Herda padding e tipografia de .btn (12px 16px), igual aos demais botões primários */
}

.imovel-documento-item .btn-ia-documento .bi {
    font-size: 1.05em;
}

.ia-documento-resultado {
    border: 1px solid #d8e4f5;
    border-radius: 12px;
    background: #f7fbff;
    padding: 12px 14px;
    font-size: 14px;
    color: #1f2937;
    line-height: 1.6;
}

.ia-documento-resultado.erro {
    border-color: #f2c0c0;
    background: #fff5f5;
    color: #8f1d1d;
}

.ia-documento-resultado .ia-documento-resumo {
    margin: 0 0 8px;
}

.ia-confianca-badge {
    display: inline-flex;
    margin: 0 0 8px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.ia-confianca-badge.ia-confianca-alta {
    background: #e8f7ec;
    color: #146c2e;
}

.ia-confianca-badge.ia-confianca-media {
    background: #fff4dd;
    color: #8a5b00;
}

.ia-confianca-badge.ia-confianca-baixa {
    background: #ffe8e8;
    color: #9f1d1d;
}

.ia-confianca-justificativa {
    margin: 0 0 8px;
    font-size: 13px;
    color: #4b5563;
}

.ia-documento-resultado ul {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 4px;
}

.ia-painel-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}

.ia-painel-card {
    background: #ffffff;
    border: 1px solid #dbe7f5;
    border-radius: 10px;
    padding: 8px 10px;
}

.ia-painel-card h4,
.ia-painel-bloco h4 {
    margin: 0 0 4px;
    font-size: 12px;
    color: #475569;
}

.ia-painel-card p {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    color: #111827;
}

.ia-risco.ia-risco-baixo {
    color: #146c2e;
}

.ia-risco.ia-risco-medio {
    color: #8a5b00;
}

.ia-risco.ia-risco-alto {
    color: #9f1d1d;
}

.ia-painel-bloco {
    margin-bottom: 8px;
}

.ia-confianca-cta {
    margin-top: 10px;
    display: inline-flex;
}

.ia-documento-disclaimer {
    margin: 0 0 10px;
    font-size: 12px;
    color: #6b7280;
    line-height: 1.5;
}

.ia-relatorio-consolidado-wrap {
    margin-top: 12px;
    display: grid;
    gap: 10px;
}

.ia-relatorio-consolidado-acoes {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ia-franquia-relatorio-banner {
    margin: 0 0 14px;
    padding: 12px 14px;
    border-radius: 12px;
    background: #f0f7ff;
    border: 1px solid #cfe8ff;
    font-size: 14px;
    line-height: 1.5;
    color: #1e3a5f;
}

.ia-franquia-relatorio-banner p {
    margin: 0;
}

.ia-avulso-mensagem {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.5;
}

.ia-avulso-acoes {
    margin: 0;
}

.ia-avulso-acoes .btn {
    width: auto;
}

.ia-documento-resultado .btn-primario,
.ia-documento-resultado a.btn-primario {
    color: #1f2937;
}

.imovel-resumo-compra {
    margin: 0;
    padding: 22px 22px 20px;
    border: 1px solid #cfe0f5;
    border-radius: 22px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.08);
}

.imovel-desconto-resumo {
    display: inline-flex;
    align-items: center;
    margin: 0 0 16px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #eef8f0;
    color: #2f9e44;
    font-size: 13px;
    font-weight: 700;
}

.imovel-preco-bloco {
    display: grid;
    gap: 7px;
    margin-bottom: 16px;
}

.imovel-preco-bloco span {
    color: #475569;
    font-size: 14px;
}

.imovel-preco-riscado {
    color: #98a2b3;
    font-size: 16px;
    font-weight: 500;
    text-decoration: line-through;
}

.imovel-preco-principal {
    color: #0f67c7;
    font-size: clamp(25px, 2.2vw, 32px);
    font-weight: 900;
    line-height: 1.08;
    white-space: nowrap;
}

.imovel-leiloes {
    margin: 6px 0 16px;
}

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

.imovel-leilao {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.imovel-leilao + .imovel-leilao {
    border-left: 1px solid #e2e8f0;
    padding-left: 14px;
}

.imovel-leilao-titulo {
    color: #8a93a3;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.imovel-leilao-valor {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #0f67c7;
    font-size: 15px;
    font-weight: 700;
}

.imovel-leilao-valor strong {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    font-weight: 700;
    line-height: 1.15;
}

.imovel-leilao-cifrao {
    font-size: 0.92em;
    font-weight: 700;
}

.imovel-leilao-valor .bi,
.imovel-leilao-meta .bi {
    color: #3b82f6;
}

.imovel-leilao-meta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 12px;
    border: 1px solid #dbe5f0;
    border-radius: 12px;
    background: #f8fbff;
    color: #4b6787;
    font-weight: 700;
    font-size: 13px;
}

.imovel-leilao.ativo .imovel-leilao-titulo,
.imovel-leilao.ativo .imovel-leilao-valor,
.imovel-leilao.ativo .imovel-leilao-meta {
    color: #0f67c7;
}

.imovel-leilao.secundario-suave .imovel-leilao-titulo,
.imovel-leilao.secundario-suave .imovel-leilao-valor,
.imovel-leilao.secundario-suave .imovel-leilao-meta {
    color: #98a3b3;
}

.imovel-leilao.secundario-suave .imovel-leilao-valor .bi,
.imovel-leilao.secundario-suave .imovel-leilao-meta .bi {
    color: #8fb1eb;
}

.imovel-leilao.encerrado .imovel-leilao-titulo,
.imovel-leilao.encerrado .imovel-leilao-valor,
.imovel-leilao.encerrado .imovel-leilao-meta {
    color: #9aa3b2;
}

.imovel-leilao.encerrado .imovel-leilao-valor strong,
.imovel-leilao.encerrado .imovel-leilao-meta span {
    text-decoration: line-through;
}

.imovel-custos-box {
    margin-top: 10px;
    padding: 16px 18px;
    border: 1px solid #edf2f7;
    border-radius: 18px;
    background: #fbfdff;
}

.imovel-custos-box p {
    margin: 0 0 12px;
    color: #1f2937;
    line-height: 1.55;
    font-size: 14px;
}

.imovel-custos-box hr {
    border: 0;
    border-top: 1px solid #dbe4ee;
    margin: 14px 0 13px;
}

.imovel-custos-total {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    font-size: 15px;
}

.imovel-custos-total strong {
    color: #0f67c7;
    font-size: 17px;
}

.imovel-custos-nota {
    color: #64748b;
    font-size: 12px;
    line-height: 1.65;
}

.imovel-ajuda-card {
    margin: 0;
    padding: 22px 22px 20px;
    border: 1px solid #f6e7ba;
    border-radius: 22px;
    background: #fffdf6;
    box-shadow: 0 12px 26px rgba(166, 81, 0, 0.05);
}

.imovel-acesso-card,
.imovel-favorito-card {
    margin: 0;
    padding: 20px 22px;
    border: 1px solid #edf2f7;
    border-radius: 22px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.imovel-acesso-card {
    background: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.imovel-favorito-card {
    background: #f8fbff;
}

.imovel-acesso-card__kicker {
    display: inline-flex;
    margin-bottom: 10px;
    color: #0f5db8;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.imovel-acesso-card h3,
.imovel-bloqueio-link h3 {
    margin: 0 0 10px;
    color: #0f172a;
    font-size: 18px;
    line-height: 1.35;
}

.imovel-acesso-card p {
    margin: 0 0 16px;
    color: #475569;
    line-height: 1.6;
    font-size: 14px;
}

.imovel-card-export-card {
    display: grid;
    gap: 12px;
    padding: 20px 22px;
    border: 1px solid #edf2f7;
    border-radius: 22px;
    background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.imovel-card-export-card--locked {
    background: linear-gradient(180deg, #fffaf0 0%, #ffffff 100%);
}

.imovel-card-export-card h3 {
    margin: 0;
    color: #0f172a;
    font-size: 20px;
    line-height: 1.25;
}

.imovel-card-export-card p {
    margin: 0;
    color: #475569;
    font-size: 14px;
    line-height: 1.6;
}

.imovel-card-export-btn {
    width: 100%;
    justify-content: center;
}

.imovel-card-export-link {
    color: #0f5db8;
    font-size: 13px;
    font-weight: 700;
}

.imovel-ajuda-card h3 {
    margin: 0 0 12px;
    color: #a65100;
    font-size: 18px;
    line-height: 1.35;
}

.imovel-ajuda-card p {
    margin: 0 0 18px;
    color: #b06a19;
    line-height: 1.6;
    font-size: 14px;
}

.btn-ajuda-compra {
    width: 100%;
    min-height: 48px;
    text-align: center;
    background: #f59e0b;
    color: #1f2937;
    border-radius: 14px;
    box-shadow: none;
}

.imovel-mobile-actionbar {
    display: none;
}

.btn.imovel-site-origem-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    min-height: 56px;
    padding: 0 18px;
    margin-top: 4px;
    border-radius: 16px;
    background: #0f67c7;
    color: #fff;
    text-transform: none;
    text-decoration: none;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.1;
    text-align: center;
    vertical-align: middle;
    box-shadow: 0 12px 28px rgba(15, 103, 199, 0.14);
}

.imovel-site-origem-btn .bi {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    line-height: 1;
}

.imovel-bloqueio-link {
    margin: 0;
    padding: 20px 22px;
    border: 1px solid #edf2f7;
    border-radius: 22px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
    background: #ffffff;
}

.imovel-bloqueio-link p {
    margin: 0 0 16px;
    color: #334155;
    line-height: 1.6;
    font-size: 15px;
}

.imovel-favorito-aviso {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 0;
    color: #2563eb;
    font-size: 14px;
    line-height: 1.55;
}

.imovel-favorito-aviso > div {
    width: 100%;
}

.imovel-favorito-aviso a {
    color: #2563eb;
    font-weight: 700;
    text-decoration: none;
}

.imovel-favorito-aviso .bi {
    flex-shrink: 0;
    margin-top: 2px;
}

.imovel-favorito-form {
    margin: 0;
}

.imovel-favorito-inline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    justify-content: flex-start;
}

.imovel-favorito-texto {
    flex: 0 1 auto;
}

.imovel-favorito-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #2563eb;
    cursor: pointer;
    padding: 0;
}

.imovel-favorito-toggle .bi {
    font-size: 20px;
}

.imovel-favorito-toggle:hover {
    color: #1d4ed8;
}

.imovel-favorito-toggle--off {
    color: #2563eb;
}

.comparativo-m2-card-detalhe {
    margin: 0;
    padding: 20px 22px;
    background: #fff;
    border: 1px solid #edf2f7;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.03);
}

.comparativo-m2-grid-detalhe {
    margin-top: 16px;
}

body.modal-open {
    overflow: hidden;
}

.ia-relatorio-modal[hidden] {
    display: none;
}

.ia-relatorio-modal {
    position: fixed;
    inset: 0;
    z-index: 1400;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.ia-relatorio-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.66);
}

.ia-relatorio-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 460px);
    border: 1px solid #dbe6f4;
    border-radius: 18px;
    background: #ffffff;
    padding: 28px;
    text-align: center;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.28);
}

.ia-relatorio-modal__spinner {
    width: 46px;
    height: 46px;
    margin: 0 auto 16px;
    border: 4px solid #dbeafe;
    border-top-color: #0f67c7;
    border-radius: 999px;
    animation: ia-relatorio-spin 0.9s linear infinite;
}

.ia-relatorio-modal__success {
    display: block;
    margin-bottom: 14px;
    color: #16a34a;
    font-size: 46px;
}

.ia-relatorio-modal__success[hidden] {
    display: none;
}

.ia-relatorio-modal__dialog h3 {
    margin: 0 0 8px;
    color: #0f172a;
    font-size: 24px;
    font-weight: 900;
}

.ia-relatorio-modal__dialog p {
    margin: 0;
    color: #475569;
    font-size: 15px;
    line-height: 1.55;
}

.ia-relatorio-modal__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

.ia-relatorio-modal__actions[hidden] {
    display: none;
}

@keyframes ia-relatorio-spin {
    to {
        transform: rotate(360deg);
    }
}

.assessoria-modal[hidden] {
    display: none;
}

.card-export-modal[hidden] {
    display: none;
}

.card-export-modal {
    position: fixed;
    inset: 0;
    z-index: 1250;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 24px;
    overflow-y: auto;
}

.card-export-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.62);
}

.card-export-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 860px);
    margin: auto 0;
    padding: 64px 24px 24px;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.28);
    max-height: calc(100vh - 48px);
    overflow-y: auto;
}

.card-export-modal__close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border: 0;
    border-radius: 999px;
    background: #f1f5f9;
    color: #334155;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    z-index: 4;
}

.card-export-modal__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding-right: 44px;
    margin-bottom: 16px;
}

.card-export-modal__head > div {
    display: grid;
    gap: 6px;
}

.card-export-modal__head h3 {
    margin: 0;
    color: #0f172a;
    font-size: 26px;
    line-height: 1.2;
}

.card-export-modal__perfil {
    color: #0f5db8;
    font-size: 14px;
    font-weight: 700;
}

.card-export-modal__templates {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 16px;
}

.card-export-modal__formats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
}

.card-export-format {
    min-height: 40px;
    padding: 0 14px;
    border: 1px solid #dbe6f1;
    border-radius: 999px;
    background: #ffffff;
    color: #334155;
    font-size: 13px;
    font-weight: 700;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.card-export-format.is-active {
    border-color: #8fb9ea;
    background: #eef6ff;
    color: #0f5db8;
    box-shadow: 0 10px 20px rgba(15, 93, 184, 0.08);
}

.card-export-template {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border: 1px solid #dbe6f1;
    border-radius: 16px;
    background: #f8fbff;
    text-align: left;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.card-export-template strong {
    color: #0f172a;
    font-size: 15px;
    line-height: 1.2;
}

.card-export-template span {
    color: #64748b;
    font-size: 12px;
    line-height: 1.45;
}

.card-export-template.is-active {
    border-color: #8fb9ea;
    background: #eef6ff;
    box-shadow: 0 12px 24px rgba(15, 93, 184, 0.10);
    transform: translateY(-1px);
}

.card-export-modal__preview {
    display: flex;
    justify-content: center;
    padding: 12px;
    border-radius: 20px;
    background: #f8fbff;
    border: 1px solid #e3edf7;
}

.card-export-modal__preview img {
    display: block;
    width: min(100%, 620px);
    max-height: min(64vh, 720px);
    height: auto;
    border-radius: 16px;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
    object-fit: contain;
    cursor: default;
    -webkit-user-drag: none;
    user-select: none;
}

.card-export-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 16px;
}

.assessoria-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.assessoria-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.58);
}

.assessoria-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 400px);
    padding: 28px;
    border-radius: 20px;
    background: #fff;
    box-shadow: 0 20px 60px rgba(15, 23, 42, 0.28);
}

.assessoria-modal__close {
    position: absolute;
    top: 14px;
    right: 16px;
    border: 0;
    background: transparent;
    color: #334155;
    font-size: 32px;
    line-height: 1;
    cursor: pointer;
}

.assessoria-modal__dialog h3 {
    margin: 0 0 20px;
    color: #1f2937;
    font-size: 24px;
    line-height: 1.2;
}

.assessoria-modal__form {
    display: grid;
    gap: 10px;
}

.assessoria-modal__form input,
.assessoria-modal__form textarea {
    width: 100%;
    min-height: 48px;
    padding: 12px 14px;
    border: 1px solid #d8e1eb;
    border-radius: 10px;
    background: #fff;
    color: #1f2937;
    font-size: 15px;
}

.assessoria-modal__form textarea {
    min-height: 132px;
    resize: vertical;
}

.assessoria-modal__status {
    margin: 2px 0 4px;
    font-size: 14px;
    line-height: 1.5;
}

.assessoria-modal__status.sucesso {
    color: #15803d;
}

.assessoria-modal__status.erro {
    color: #b91c1c;
}

.assessoria-modal__submit,
.assessoria-modal__whatsapp {
    width: 100%;
    justify-content: center;
}

.assessoria-modal__whatsapp {
    min-height: 52px;
    border-radius: 12px;
    background: #22c55e;
    color: #fff;
    text-decoration: none;
    font-weight: 700;
}

@media (max-width: 900px) {
    .imovel-hero {
        padding: 22px 0 28px;
    }

    .imovel-hero-conteudo {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .imovel-hero-price-card strong,
    .imovel-preco-principal {
        white-space: normal;
    }

    .imovel-detalhe-layout {
        grid-template-columns: 1fr;
        margin-bottom: 96px;
    }

    .imovel-detalhe-sidebar {
        position: static;
    }

    .imovel-info-grid {
        grid-template-columns: 1fr;
    }

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

    .imovel-galeria-main img,
    .imovel-galeria-placeholder {
        height: 250px;
    }

    .imovel-resumo-grid {
        grid-template-columns: 1fr;
    }

    .analise-localizacao-map {
        min-height: 300px;
    }

    .analise-localizacao-ratings,
    .analise-localizacao-pois,
    .analise-oportunidade-grid,
    .analise-cenarios-margem-grid,
    .analise-recomendacao-listas {
        grid-template-columns: 1fr;
    }

    .analise-localizacao-seguranca-linha {
        flex-direction: column;
        align-items: flex-start;
    }

    .analise-recomendacao-final > div:first-child {
        align-items: flex-start;
        flex-direction: column;
    }

    .analise-recomendacao-final strong {
        text-align: left;
    }

    .imovel-bloco-head h2 {
        font-size: 24px;
    }

    .imovel-mobile-actionbar {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: 12px;
        z-index: 900;
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 12px;
        padding: 10px;
        border: 1px solid #dbe6f4;
        border-radius: 18px;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: 0 18px 44px rgba(15, 23, 42, 0.18);
        backdrop-filter: blur(10px);
    }

    .imovel-mobile-actionbar span {
        display: block;
        color: #64748b;
        font-size: 11px;
        font-weight: 800;
    }

    .imovel-mobile-actionbar strong {
        display: block;
        color: #0f67c7;
        font-size: 18px;
        line-height: 1.1;
        font-weight: 900;
    }

    .imovel-mobile-actionbar .btn {
        width: auto;
        min-height: 44px;
        padding: 0 14px;
    }
}

* {
    box-sizing: border-box;
}

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

body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    color: var(--cor-texto);
    background: var(--cor-fundo);
    overflow-x: hidden;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

body > main {
    flex: 1 0 auto;
    padding-bottom: 24px;
}

details > summary {
    list-style: none;
}

details > summary::-webkit-details-marker {
    display: none;
}

.container {
    width: min(1200px, 94%);
    margin: 0 auto;
}

.topo {
    background: #fff;
    border-bottom: 1px solid rgba(203, 213, 225, 0.75);
    position: sticky;
    top: 0;
    z-index: 1100;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
    backdrop-filter: blur(10px);
}

body:has(.imovel-hero-full) .topo {
    border-bottom: 0;
    box-shadow: none;
}

.topo-admin {
    border-bottom: 2px solid var(--cor-primaria);
}

.admin-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.admin-selo {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
    background: var(--cor-primaria);
    padding: 5px 12px;
    border-radius: 999px;
    line-height: 1;
}

.admin-app-body {
    background: #eef2f7;
}

.admin-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
}

.admin-sidebar {
    background: linear-gradient(180deg, #13243f, #0f1d34);
    color: #d6deea;
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.admin-logo {
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
}

.admin-logo-img {
    filter: brightness(0) invert(1);
}

.admin-logo .admin-selo {
    background: #1f6fd4;
}

.admin-menu {
    display: grid;
    gap: 6px;
}

.admin-menu a {
    text-decoration: none;
    color: #d6deea;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
}

.admin-menu a:hover,
.admin-menu a.ativo {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.admin-sidebar-footer {
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    display: grid;
    gap: 10px;
}

.admin-sidebar-footer a,
.admin-sidebar-footer .btn-link {
    text-decoration: none;
    color: #d6deea;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    font-size: 12px;
    text-align: left;
    text-transform: uppercase;
    font-weight: 700;
}

.admin-main {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.admin-topbar {
    height: 64px;
    background: #fff;
    border-bottom: 1px solid #dbe3ef;
    display: flex;
    align-items: center;
    padding: 0 24px;
}

.admin-topbar h1 {
    margin: 0;
    font-size: 18px;
    color: #1f2937;
}

.admin-content {
    padding: 20px 24px 28px;
}

.topo-admin-login {
    background: transparent;
    border-bottom: none;
    position: static;
}

.topo-conteudo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    min-height: 72px;
    padding: 12px 0;
}

.logo {
    text-decoration: none;
    color: var(--cor-primaria);
    font-weight: 700;
    font-size: 22px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.logo-img {
    height: 45px;
    width: auto;
    object-fit: contain;
}

.logo-text-fallback {
    color: var(--cor-primaria);
    font-weight: 700;
    font-size: 22px;
}

.menu-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 14px;
    border: 1px solid #d8e3ef;
    border-radius: 12px;
    background: #ffffff;
    color: #0f172a;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.menu-toggle .bi {
    font-size: 18px;
}

.menu {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.menu a,
.btn-link {
    text-decoration: none;
    color: var(--cor-texto);
    font-weight: 700;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1;
    transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.menu > a:not(.menu-auth-btn),
.menu > .menu-dropdown > .btn-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 10px;
    border-radius: 10px;
    color: #0f172a;
}

.menu > a:not(.menu-auth-btn):hover,
.menu > .menu-dropdown > .btn-link:hover,
.menu > .menu-dropdown > .btn-link:focus-visible {
    color: #0f5db8;
    background: rgba(15, 93, 184, 0.06);
}

.menu-link-ativo {
    color: #0f5db8 !important;
    background: rgba(15, 93, 184, 0.08);
}

.menu-link-ativo::after {
    content: "";
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: 6px;
    height: 2px;
    border-radius: 999px;
    background: #0f5db8;
}

.menu a.menu-auth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 18px;
    border-radius: 12px;
    border: 1px solid transparent;
    text-transform: uppercase;
    text-decoration: none;
}

.menu a.menu-auth-btn-login {
    border-color: #cbd5e1;
    color: #1f2937;
    background: #fff;
}

.menu a.menu-auth-btn-login:hover {
    border-color: #9fc3ee;
    color: #0f5db8;
    background: #f8fbff;
}

.menu a.menu-auth-btn-cadastro {
    background: var(--cor-destaque);
    color: #1f2937;
}

.menu a.menu-auth-btn-cadastro:hover {
    background: #ffb31a;
}

.menu form {
    margin: 0;
}

.menu-dropdown {
    position: relative;
}

.menu-dropdown::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    height: 10px;
}

.menu-dropdown-toggle {
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.menu-dropdown-content {
    position: absolute;
    top: 100%;
    right: 0;
    min-width: 220px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.12);
    padding: 8px;
    display: none;
    z-index: 1110;
}

.menu-dropdown:hover .menu-dropdown-content,
.menu-dropdown:focus-within .menu-dropdown-content {
    display: block;
}

.menu-dropdown-content a,
.menu-dropdown-logout {
    display: block;
    width: 100%;
    text-align: left;
    padding: 9px 10px;
    border-radius: 8px;
    text-decoration: none;
    color: #1e293b;
    font-size: 13px;
    font-weight: 600;
    border: none;
    background: none;
    cursor: pointer;
    text-transform: none;
    letter-spacing: 0;
}

.menu-dropdown-content a:hover,
.menu-dropdown-logout:hover {
    background: #f1f5f9;
}

.menu-dropdown-content form {
    margin: 0;
}

.hero {
    margin: 42px 0;
    background: linear-gradient(135deg, #003f78, #005ca9);
    color: #fff;
    border-radius: 16px;
    padding: 40px 32px;
}

.hero-slider {
    --hero-height: 430px;
    position: relative;
    margin: 0 0 36px;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(245, 164, 0, 0.22), transparent 30%),
        linear-gradient(135deg, #0b2542 0%, #0f3f78 54%, #0f67c7 100%);
    min-height: var(--hero-height);
    border-radius: 0;
}

.hero-slider-static {
    --hero-height: 380px;
    min-height: var(--hero-height);
}

.hero-track {
    position: relative;
    min-height: var(--hero-height);
}

.hero-slide {
    display: none;
    min-height: var(--hero-height);
    color: #fff;
    position: relative;
}

.hero-slide.ativo {
    display: block;
}

.hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.hero-bg-1 {
    background-image: var(--hero-bg-url);
    background-color: #1e3a5f;
}

.hero-bg-2 {
    background-image: linear-gradient(135deg, #12355b, #234f7f);
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.38);
}

.hero-slider-static .hero-overlay {
    background: rgba(15, 23, 42, 0.24);
}

.hero-conteudo {
    max-width: 760px;
    padding: 0;
    position: relative;
    z-index: 2;
}

.hero-slide-layout {
    position: relative;
    z-index: 2;
    min-height: var(--hero-height);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 64px 0;
    box-sizing: border-box;
}

.hero-slide-layout:not(.hero-slide-layout-com-imovel) {
    justify-content: center;
}

.hero-slide-layout-com-imovel {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 420px);
    gap: 28px;
    align-items: center;
}

.hero-conteudo h1,
.hero-conteudo h2 {
    font-size: 54px;
    line-height: 1.12;
    margin: 0 0 14px;
}

.hero-conteudo p {
    font-size: 18px;
    line-height: 1.5;
    margin: 0 0 22px;
    color: rgba(255, 255, 255, 0.9);
}

.hero-conteudo.hero-titulo-muito_grande h1,
.hero-conteudo.hero-titulo-muito_grande h2 {
    font-size: 54px;
}

.hero-conteudo.hero-titulo-grande h1,
.hero-conteudo.hero-titulo-grande h2 {
    font-size: 46px;
}

.hero-conteudo.hero-titulo-medio h1,
.hero-conteudo.hero-titulo-medio h2 {
    font-size: 38px;
}

.hero-conteudo.hero-titulo-pequeno h1,
.hero-conteudo.hero-titulo-pequeno h2 {
    font-size: 32px;
}

.hero-conteudo.hero-subtitulo-muito_grande p {
    font-size: 18px;
}

.hero-conteudo.hero-subtitulo-grande p {
    font-size: 17px;
}

.hero-conteudo.hero-subtitulo-medio p {
    font-size: 16px;
}

.hero-conteudo.hero-subtitulo-pequeno p {
    font-size: 15px;
}

.hero-conteudo-centralizado {
    text-align: center;
    margin: 0 auto;
}

.hero-acoes-centralizadas {
    justify-content: center;
}

.hero-imovel-card {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 0;
    align-self: center;
    margin: 18px 0;
    color: #0f172a;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.45);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
    backdrop-filter: blur(4px);
}

.hero-imovel-card__media {
    position: relative;
    min-height: 210px;
    background: #dbe4f0;
}

.hero-imovel-card__media img,
.hero-imovel-card__placeholder {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-imovel-card__placeholder {
    min-height: 210px;
    background: linear-gradient(135deg, #cbd5e1, #9fb2ca);
}

.hero-imovel-card__badge {
    position: absolute;
    top: 14px;
    left: 14px;
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 10px;
    background: #f59e0b;
    color: #fff;
    font-size: 14px;
    font-weight: 800;
}

.hero-imovel-card__content {
    display: grid;
    gap: 10px;
    padding: 18px 18px 20px;
}

.hero-imovel-card__tipo {
    color: #64748b;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.hero-imovel-card__titulo {
    font-size: 26px;
    line-height: 1.14;
}

.hero-imovel-card__local {
    color: #475569;
    font-size: 15px;
    line-height: 1.5;
}

.hero-imovel-card__preco {
    color: #0f67c7;
    font-size: 28px;
    font-weight: 800;
}

.hero-imovel-card__cta {
    color: #0f67c7;
    font-size: 14px;
    font-weight: 700;
}

.hero-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 999px;
    border: none;
    background: rgba(15, 23, 42, 0.55);
    color: #fff;
    cursor: pointer;
    z-index: 5;
}

.hero-nav-prev { left: 10px; }
.hero-nav-next { right: 10px; }

.btn-hero {
    background: #4f73ff;
    color: #fff;
    padding: 14px 24px;
    border-radius: 6px;
    box-shadow: 0 8px 22px rgba(79, 115, 255, 0.35);
}

.metricas .card-metrica {
    text-align: center;
    margin: 0;
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.05);
}

.home-fullbleed {
    width: auto;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow-x: clip;
}

.home-fullbleed .hero-slider {
    margin-bottom: 0;
}

.home-legacy-block,
.home-destaques > h2,
.home-destaques > .destaques-topo {
    display: none;
}

.home-section-head {
    max-width: 860px;
    margin: 0 auto 22px;
    text-align: center;
}

.home-section-head--split {
    max-width: none;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 28px;
    text-align: left;
}

.home-section-head h2 {
    margin: 6px 0 10px;
    font-size: clamp(30px, 3vw, 44px);
    line-height: 1.12;
}

.home-section-head p {
    max-width: 760px;
    margin: 0;
    color: #53657c;
    line-height: 1.75;
}

.home-eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 12px;
    border-radius: 999px;
    background: #eaf3ff;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.home-search-dock {
    width: 100%;
    margin: -58px 0 42px;
    padding: 0 16px;
    position: relative;
    z-index: 4;
}

.home-search-dock__inner {
    margin-left: auto;
    margin-right: auto;
}

.home-search-dock__card {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    justify-items: center;
    gap: 18px;
    padding: 22px;
    border: 1px solid #d9e6f5;
    border-radius: 18px;
    background: linear-gradient(135deg, #ffffff 0%, #f7fbff 100%);
    box-shadow: 0 22px 46px rgba(15, 23, 42, 0.1);
}

.home-search-dock__copy {
    min-width: 0;
    max-width: 780px;
    text-align: center;
}

.home-search-dock__copy h2 {
    margin: 8px 0 6px;
    font-size: clamp(24px, 2.6vw, 34px);
    line-height: 1.12;
    text-align: center;
}

.home-search-dock__copy p {
    max-width: 640px;
    margin: 0 auto;
    color: #53657c;
    line-height: 1.6;
}

.home-hero-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    width: min(100%, 640px);
    margin: 0;
    padding: 8px;
    border: 1px solid #cfe0f5;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 14px 32px rgba(15, 93, 184, 0.08);
}

.home-hero-search label {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.home-hero-search span {
    padding: 0 10px;
    color: #45617f;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.home-hero-search input {
    width: 100%;
    min-height: 44px;
    border: 0;
    border-radius: 10px;
    padding: 0 10px;
    color: #10233f;
    font-size: 15px;
    background: transparent;
    outline: none;
}

.btn-hero-search {
    align-self: stretch;
    gap: 8px;
    border-radius: 10px;
    background: #f5a400;
    color: #0f172a;
    border: 1px solid #f5a400;
    font-weight: 900;
}

.home-hero-trust {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    grid-column: auto;
}

.home-hero-trust span {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 32px;
    padding: 0 11px;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f3f78;
    font-size: 12px;
    font-weight: 800;
}

.hero-imovel-card__placeholder {
    align-content: center;
    justify-items: center;
    gap: 8px;
    color: #0f5db8;
    font-weight: 900;
}

.hero-imovel-card__placeholder .bi {
    font-size: 34px;
}

.home-confianca {
    padding: clamp(24px, 3vw, 34px);
    border: 1px solid #dbe7f6;
    border-radius: 18px;
    background: linear-gradient(135deg, #ffffff 0%, #f6faff 100%);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.05);
}

.home-confianca .home-section-head--split {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    text-align: center;
}

.home-confianca .home-section-head p {
    margin-left: auto;
    margin-right: auto;
}

.home-confianca .home-section-head--split .btn {
    justify-self: center;
}

.home-confianca-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.home-confianca-card {
    display: grid;
    justify-items: center;
    gap: 10px;
    padding: 20px;
    border: 1px solid #dce7f4;
    border-radius: 14px;
    background: #ffffff;
    text-align: center;
}

.home-confianca-icone {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    color: #0f67c7;
    background: #eaf3ff;
    font-size: 20px;
}

.home-confianca-card h3 {
    margin: 0;
    font-size: 20px;
}

.home-confianca-card p {
    margin: 0;
    color: #5b6c81;
    line-height: 1.7;
}

.quem-premium-how--anim.quem-premium-how--enhance .home-confianca-card {
    opacity: 0;
    transform: translateY(18px);
    transition:
        box-shadow 0.28s ease,
        border-color 0.28s ease,
        transform 0.28s ease;
}

.quem-premium-how--anim.quem-premium-how--revealed .home-confianca-card:not(.is-revealed) {
    opacity: 1;
    transform: none;
}

.quem-premium-how--anim .home-confianca-card.is-revealed {
    animation: quemFuncCardIn 0.58s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(1) {
    animation-delay: 0.02s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(2) {
    animation-delay: 0.07s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(3) {
    animation-delay: 0.12s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(4) {
    animation-delay: 0.17s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(5) {
    animation-delay: 0.22s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(6) {
    animation-delay: 0.27s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(7) {
    animation-delay: 0.32s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(8) {
    animation-delay: 0.37s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(9) {
    animation-delay: 0.42s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(10) {
    animation-delay: 0.47s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:hover {
    transform: translateY(-5px);
    border-color: rgba(15, 103, 199, 0.38);
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.11);
}

.quem-premium-how--anim .home-confianca-card.is-revealed .home-confianca-icone {
    animation: quemFuncIconFloat 4.2s ease-in-out infinite;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(1) .home-confianca-icone {
    animation-delay: 0s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(2) .home-confianca-icone {
    animation-delay: -0.45s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(3) .home-confianca-icone {
    animation-delay: -0.9s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(4) .home-confianca-icone {
    animation-delay: -1.35s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(5) .home-confianca-icone {
    animation-delay: -1.8s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(6) .home-confianca-icone {
    animation-delay: -0.2s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(7) .home-confianca-icone {
    animation-delay: -0.65s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(8) .home-confianca-icone {
    animation-delay: -1.1s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(9) .home-confianca-icone {
    animation-delay: -1.55s;
}

.quem-premium-how--anim .home-confianca-card.is-revealed:nth-child(10) .home-confianca-icone {
    animation-delay: -1.05s;
}

@keyframes quemFuncCardIn {
    from {
        opacity: 0;
        transform: translateY(18px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes quemFuncIconFloat {
    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-4px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .quem-premium-how--anim.quem-premium-how--enhance .home-confianca-card {
        opacity: 1;
        transform: none;
        animation: none !important;
    }

    .quem-premium-how--anim .home-confianca-card.is-revealed:hover {
        transform: none;
    }

    .quem-premium-how--anim .home-confianca-card.is-revealed .home-confianca-icone {
        animation: none !important;
    }
}

/* Home index: entrada no scroll (mesmo ritmo da A Ferramenta; sem grid de destaques) */
.home-reveal--anim.home-reveal--enhance .home-confianca-card,
.home-reveal--anim.home-reveal--enhance .funcionalidade-card,
.home-reveal--anim.home-reveal--enhance .card-metrica {
    opacity: 0;
    transform: translateY(18px);
    transition:
        box-shadow 0.28s ease,
        border-color 0.28s ease,
        transform 0.28s ease;
}

.home-reveal--anim.home-reveal--revealed .home-confianca-card:not(.is-revealed),
.home-reveal--anim.home-reveal--revealed .funcionalidade-card:not(.is-revealed),
.home-reveal--anim.home-reveal--revealed .card-metrica:not(.is-revealed) {
    opacity: 1;
    transform: none;
}

.home-reveal--anim .home-confianca-card.is-revealed,
.home-reveal--anim .funcionalidade-card.is-revealed,
.home-reveal--anim .card-metrica.is-revealed {
    animation: quemFuncCardIn 0.58s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.home-reveal--anim .home-confianca-card.is-revealed:nth-child(1),
.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(1),
.home-reveal--anim .card-metrica.is-revealed:nth-child(1) {
    animation-delay: 0.02s;
}

.home-reveal--anim .home-confianca-card.is-revealed:nth-child(2),
.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(2),
.home-reveal--anim .card-metrica.is-revealed:nth-child(2) {
    animation-delay: 0.07s;
}

.home-reveal--anim .home-confianca-card.is-revealed:nth-child(3),
.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(3),
.home-reveal--anim .card-metrica.is-revealed:nth-child(3) {
    animation-delay: 0.12s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(4),
.home-reveal--anim .card-metrica.is-revealed:nth-child(4) {
    animation-delay: 0.17s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(5) {
    animation-delay: 0.22s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(6) {
    animation-delay: 0.27s;
}

.home-reveal--anim .home-confianca-card.is-revealed:hover,
.home-reveal--anim .funcionalidade-card.is-revealed:hover {
    transform: translateY(-5px);
    border-color: rgba(15, 103, 199, 0.38);
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.11);
}

.home-reveal--anim .home-confianca-card.is-revealed .home-confianca-icone,
.home-reveal--anim .funcionalidade-card.is-revealed .funcionalidade-icone {
    animation: quemFuncIconFloat 4.2s ease-in-out infinite;
}

.home-reveal--anim .home-confianca-card.is-revealed:nth-child(1) .home-confianca-icone {
    animation-delay: 0s;
}

.home-reveal--anim .home-confianca-card.is-revealed:nth-child(2) .home-confianca-icone {
    animation-delay: -0.45s;
}

.home-reveal--anim .home-confianca-card.is-revealed:nth-child(3) .home-confianca-icone {
    animation-delay: -0.9s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(1) .funcionalidade-icone {
    animation-delay: 0s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(2) .funcionalidade-icone {
    animation-delay: -0.45s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(3) .funcionalidade-icone {
    animation-delay: -0.9s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(4) .funcionalidade-icone {
    animation-delay: -1.35s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(5) .funcionalidade-icone {
    animation-delay: -1.8s;
}

.home-reveal--anim .funcionalidade-card.is-revealed:nth-child(6) .funcionalidade-icone {
    animation-delay: -0.2s;
}

@media (prefers-reduced-motion: reduce) {
    .home-reveal--anim.home-reveal--enhance .home-confianca-card,
    .home-reveal--anim.home-reveal--enhance .funcionalidade-card,
    .home-reveal--anim.home-reveal--enhance .card-metrica {
        opacity: 1;
        transform: none;
        animation: none !important;
    }

    .home-reveal--anim .home-confianca-card.is-revealed:hover,
    .home-reveal--anim .funcionalidade-card.is-revealed:hover {
        transform: none;
    }

    .home-reveal--anim .home-confianca-card.is-revealed .home-confianca-icone,
    .home-reveal--anim .funcionalidade-card.is-revealed .funcionalidade-icone {
        animation: none !important;
    }
}

.home-dados-inteligencia {
    position: relative;
    overflow: hidden;
    padding: clamp(30px, 4vw, 48px);
    border: 1px solid #dbe7f6;
    border-radius: 24px;
    background:
        radial-gradient(circle at 14% 20%, rgba(15, 103, 199, 0.12), transparent 30%),
        radial-gradient(circle at 88% 10%, rgba(16, 185, 129, 0.12), transparent 34%),
        linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.07);
}

.home-dados-pipeline .home-pipeline-board {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    justify-content: space-between;
    gap: 6px;
    margin-top: clamp(18px, 3vw, 28px);
    padding: clamp(14px, 2.2vw, 24px);
    border-radius: 18px;
    border: 1px solid rgba(15, 103, 199, 0.14);
    background: rgba(255, 255, 255, 0.72);
}

.home-pipeline-stage {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-align: center;
}

.home-pipeline-stage-label {
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.home-pipeline-nodes {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
    max-width: 230px;
}

.home-pipeline-node {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid #e2eaf4;
    background: #fff;
    font-size: 13px;
    font-weight: 600;
    color: #334155;
    text-align: left;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.05);
    animation: homePipelineNodeFloat 4.8s ease-in-out infinite;
}

.home-pipeline-node:nth-child(2) {
    animation-delay: -1.1s;
}

.home-pipeline-node:nth-child(3) {
    animation-delay: -2.2s;
}

.home-pipeline-node i {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: rgba(15, 103, 199, 0.1);
    color: #0f67c7;
    font-size: 16px;
}

.home-pipeline-connector {
    flex: 0 0 auto;
    width: clamp(40px, 6vw, 76px);
    align-self: center;
    position: relative;
    color: rgba(15, 103, 199, 0.5);
}

.home-pipeline-connector-svg {
    display: block;
    width: 100%;
    height: 24px;
}

.home-pipeline-connector-svg--v {
    display: none;
}

.home-pipeline-path {
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-dasharray: 6 8;
    animation: homePipelineDash 1.1s linear infinite;
}

.home-pipeline-beads {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.home-pipeline-beads span {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 50%;
    left: 0;
    margin-top: -3.5px;
    border-radius: 50%;
    background: linear-gradient(135deg, #245adf, #10b981);
    opacity: 0;
    animation: homePipelineBeadH 2.5s ease-in-out infinite;
}

.home-pipeline-beads span:nth-child(2) {
    animation-delay: 0.38s;
}

.home-pipeline-beads span:nth-child(3) {
    animation-delay: 0.76s;
}

.home-pipeline-beads--late span {
    animation-delay: 0.12s;
}

.home-pipeline-beads--late span:nth-child(2) {
    animation-delay: 0.5s;
}

.home-pipeline-beads--late span:nth-child(3) {
    animation-delay: 0.88s;
}

.home-pipeline-hub {
    position: relative;
    width: 100%;
    max-width: 248px;
    padding: 20px 14px 18px;
    border-radius: 16px;
    border: 1px solid rgba(124, 58, 237, 0.28);
    background: linear-gradient(180deg, #faf5ff 0%, #ffffff 100%);
    box-shadow: 0 12px 28px rgba(91, 33, 182, 0.08);
    overflow: hidden;
}

.home-pipeline-hub-ring {
    position: absolute;
    left: 50%;
    top: 38%;
    width: 118px;
    height: 118px;
    margin: -59px 0 0 -59px;
    border: 2px dashed rgba(124, 58, 237, 0.22);
    border-radius: 50%;
    animation: homePipelineRing 14s linear infinite;
    pointer-events: none;
}

.home-pipeline-hub-core {
    position: relative;
    z-index: 2;
    width: 54px;
    height: 54px;
    margin: 0 auto 10px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: linear-gradient(135deg, #245adf 0%, #7c3aed 100%);
    color: #fff;
    font-size: 24px;
    box-shadow: 0 12px 24px rgba(79, 70, 229, 0.32);
    animation: homePipelineHubPulse 2.8s ease-in-out infinite;
}

.home-pipeline-hub-text {
    position: relative;
    z-index: 2;
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
    color: #475569;
    font-weight: 600;
}

.home-pipeline-out {
    width: 100%;
    max-width: 248px;
    padding: 16px 14px;
    border-radius: 16px;
    border: 1px solid rgba(16, 185, 129, 0.35);
    background: linear-gradient(180deg, #ecfdf5 0%, #ffffff 100%);
    box-shadow: 0 12px 28px rgba(16, 185, 129, 0.1);
}

.home-pipeline-out-chart {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 7px;
    height: 54px;
    margin-bottom: 12px;
}

.home-pipeline-out-chart i {
    display: block;
    width: 13px;
    border-radius: 5px 5px 2px 2px;
    background: linear-gradient(180deg, #10b981, #0f67c7);
    animation: homePipelineBar 2.3s ease-in-out infinite;
}

.home-pipeline-out-chart i:nth-child(1) {
    height: 32%;
    animation-delay: 0s;
}

.home-pipeline-out-chart i:nth-child(2) {
    height: 50%;
    animation-delay: 0.18s;
}

.home-pipeline-out-chart i:nth-child(3) {
    height: 38%;
    animation-delay: 0.36s;
}

.home-pipeline-out-chart i:nth-child(4) {
    height: 66%;
    animation-delay: 0.54s;
}

.home-pipeline-out-text {
    margin: 0;
    font-size: 13px;
    font-weight: 600;
    color: #0f766e;
    line-height: 1.45;
}

.home-pipeline-steps {
    list-style: none;
    margin: clamp(20px, 3vw, 28px) 0 0;
    padding: 0;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-pipeline-steps li {
    margin: 0;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid #e2eaf4;
    background: rgba(255, 255, 255, 0.88);
    font-size: 14px;
    line-height: 1.5;
    color: #475569;
}

/* A Ferramenta: passos do pipeline com o mesmo vocabulário de card da home */
.quem-premium-page .home-pipeline-steps li {
    border-radius: 16px;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.home-pipeline-steps strong {
    color: #0f67c7;
    font-weight: 800;
}

@keyframes homePipelineDash {
    to {
        stroke-dashoffset: -28;
    }
}

@keyframes homePipelineBeadH {
    0% {
        left: 0;
        opacity: 0;
        transform: scale(0.65);
    }

    18% {
        opacity: 1;
    }

    82% {
        opacity: 1;
    }

    100% {
        left: calc(100% - 7px);
        opacity: 0;
        transform: scale(0.95);
    }
}

@keyframes homePipelineBeadV {
    0% {
        top: 0;
        opacity: 0;
        transform: scale(0.65);
    }

    18% {
        opacity: 1;
    }

    82% {
        opacity: 1;
    }

    100% {
        top: calc(100% - 7px);
        opacity: 0;
        transform: scale(0.95);
    }
}

@keyframes homePipelineNodeFloat {
    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-3px);
    }
}

@keyframes homePipelineRing {
    to {
        transform: rotate(360deg);
    }
}

@keyframes homePipelineHubPulse {
    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }
}

@keyframes homePipelineBar {
    0%,
    100% {
        transform: scaleY(0.88);
        opacity: 0.72;
        transform-origin: bottom;
    }

    50% {
        transform: scaleY(1);
        opacity: 1;
        transform-origin: bottom;
    }
}

@media (max-width: 900px) {
    .home-dados-pipeline .home-pipeline-board {
        flex-direction: column;
    }

    .home-pipeline-connector {
        width: 100%;
        height: 42px;
    }

    .home-pipeline-connector-svg--h {
        display: none;
    }

    .home-pipeline-connector-svg--v {
        display: block;
        width: 24px;
        height: 100%;
        margin: 0 auto;
    }

    .home-pipeline-beads span,
                    .home-pipeline-beads--late span {
        top: 0;
        left: 50%;
        margin-top: 0;
        margin-left: -3.5px;
        animation-name: homePipelineBeadV;
    }

    .home-pipeline-path {
        animation-name: homePipelineDash;
    }

    .home-pipeline-steps {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {
    .home-pipeline-path,
    .home-pipeline-beads span,
    .home-pipeline-node,
    .home-pipeline-hub-ring,
    .home-pipeline-hub-core,
    .home-pipeline-out-chart i {
        animation: none !important;
    }

    .home-pipeline-hub-core {
        transform: none;
    }

    .home-pipeline-out-chart i {
        opacity: 1;
        transform: scaleY(1);
    }
}

.home-dados-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 26px;
    margin-top: 24px;
}

.home-dados-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    border: 1px solid rgba(15, 103, 199, 0.18);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 20px 42px rgba(15, 23, 42, 0.08);
}

.home-dados-card--inteligencia {
    border-color: rgba(16, 185, 129, 0.32);
}

.home-dados-card-head {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex-shrink: 0;
    min-height: clamp(6.85rem, 11.2vw, 8.35rem);
    padding: 20px 22px 18px;
    color: #fff;
    background: linear-gradient(135deg, #245adf 0%, #6747e8 100%);
    box-sizing: border-box;
}

.home-dados-card--inteligencia .home-dados-card-head {
    background: linear-gradient(135deg, #0f67c7 0%, #10b981 100%);
}

.home-dados-card-head span {
    display: block;
    margin-bottom: 7px;
    color: rgba(255, 255, 255, 0.78);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.home-dados-card-head h3 {
    margin: 0;
    font-size: clamp(20px, 2.1vw, 26px);
    line-height: 1.15;
}

.home-dados-visual {
    position: relative;
    min-height: 255px;
    margin: 18px;
    border: 1px solid #e5edf7;
    border-radius: 16px;
    background:
        linear-gradient(90deg, rgba(15, 103, 199, 0.035) 1px, transparent 1px),
        linear-gradient(180deg, rgba(15, 103, 199, 0.035) 1px, transparent 1px),
        #f8fbff;
    background-size: 32px 32px;
}

.home-dados-browser {
    position: absolute;
    top: 28px;
    width: 38%;
    min-height: 95px;
    padding: 20px 18px 14px;
    border: 1px solid #e8eef6;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
    animation: homeDadosFloat 5s ease-in-out infinite;
}

.home-dados-browser--left {
    left: 22px;
}

.home-dados-browser--right {
    right: 22px;
    animation-delay: -1.8s;
}

.home-dados-window-dots {
    position: absolute;
    top: 12px;
    left: 13px;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #ef4444;
    box-shadow: 13px 0 #f59e0b, 26px 0 #22c55e;
}

.home-dados-browser div {
    height: 12px;
    margin: 8px 0;
    border-radius: 999px;
    background: #edf2f8;
}

.home-dados-browser div:nth-of-type(2) {
    width: 72%;
}

.home-dados-browser strong {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin-top: 14px;
    color: #52637a;
    font-size: 13px;
}

.home-dados-orbita {
    position: absolute;
    inset: 72px 22% 72px;
    border: 2px dashed rgba(15, 103, 199, 0.32);
    border-radius: 50%;
    transform: rotate(23deg);
    animation: homeDadosRotate 11s linear infinite;
}

.home-dados-orbita--two {
    inset: 88px 30% 50px;
    border-color: rgba(16, 185, 129, 0.34);
    animation-duration: 14s;
    animation-direction: reverse;
}

.home-dados-core {
    position: absolute;
    left: 50%;
    top: 48%;
    width: 74px;
    height: 74px;
    display: grid;
    place-items: center;
    border: 10px solid rgba(255, 255, 255, 0.76);
    border-radius: 999px;
    background: linear-gradient(135deg, #245adf, #7c3aed);
    color: #fff;
    transform: translate(-50%, -50%);
    box-shadow: 0 16px 32px rgba(79, 70, 229, 0.3);
    animation: homeDadosPulse 2.6s ease-in-out infinite;
    z-index: 2;
}

.home-dados-core i {
    font-size: 26px;
}

.home-dados-chip {
    position: absolute;
    left: 50%;
    bottom: 30px;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 10px 13px;
    border-radius: 9px;
    background: #0f172a;
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    transform: translateX(-50%);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.2);
}

.home-dados-paper {
    position: absolute;
    left: 19%;
    top: 45px;
    width: 116px;
    min-height: 162px;
    padding: 18px 16px;
    border: 1px solid #e5edf7;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08);
}

.home-dados-paper span,
.home-dados-score-card span {
    display: block;
    margin-bottom: 14px;
    color: #5f4bd8;
    font-size: 11px;
    font-weight: 900;
    text-align: center;
}

.home-dados-paper i {
    display: block;
    height: 10px;
    margin: 11px 0;
    border-radius: 999px;
    background: #e9eef6;
    animation: homeDadosBar 2.8s ease-in-out infinite;
}

.home-dados-paper i:nth-child(3) {
    width: 80%;
    animation-delay: 0.2s;
}

.home-dados-paper i:nth-child(4) {
    width: 92%;
    animation-delay: 0.4s;
}

.home-dados-paper i:nth-child(5) {
    width: 68%;
    animation-delay: 0.6s;
}

.home-dados-flow {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.home-dados-flow span {
    position: absolute;
    left: 42%;
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: #7c3aed;
    box-shadow: 0 0 0 8px rgba(124, 58, 237, 0.09);
    animation: homeDadosMove 2.4s ease-in-out infinite;
}

.home-dados-flow span:nth-child(1) {
    top: 42%;
}

.home-dados-flow span:nth-child(2) {
    top: 50%;
    animation-delay: 0.35s;
}

.home-dados-flow span:nth-child(3) {
    top: 58%;
    animation-delay: 0.7s;
}

.home-dados-score-card {
    position: absolute;
    right: 16%;
    top: 35px;
    width: 132px;
    min-height: 178px;
    padding: 15px;
    border: 2px solid rgba(79, 70, 229, 0.75);
    border-radius: 17px;
    background: #fff;
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.12);
    animation: homeDadosFloat 4.8s ease-in-out infinite;
}

.home-dados-score-card strong {
    width: 62px;
    height: 62px;
    display: grid;
    place-items: center;
    margin: 0 auto 8px;
    border-radius: 999px;
    background: conic-gradient(#10b981 0 78%, #e2e8f0 78% 100%);
    color: #0f8f63;
    font-size: 23px;
    box-shadow: inset 0 0 0 8px #fff;
}

.home-dados-score-card small {
    display: block;
    margin-bottom: 11px;
    color: #64748b;
    font-size: 10px;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
}

.home-dados-score-card div {
    height: 8px;
    margin: 8px 0;
    overflow: hidden;
    border-radius: 999px;
    background: #eef2f7;
}

.home-dados-score-card b {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #10b981, #0f67c7);
    animation: homeDadosMetricFill 2.8s ease-in-out infinite;
}

.home-dados-score-card div:nth-of-type(2) b {
    animation-delay: 0.25s;
}

.home-dados-score-card div:nth-of-type(3) b {
    animation-delay: 0.5s;
}

.home-dados-lista {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0 22px 22px;
    list-style: none;
}

.home-dados-lista li {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    color: #475569;
    line-height: 1.5;
}

.home-dados-lista li .home-dados-lista-copy {
    flex: 1;
    min-width: 0;
}

.home-dados-lista i {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 999px;
    background: rgba(16, 185, 129, 0.12);
    color: #0f8f63;
}

.home-dados-lista--metricas i {
    background: rgba(15, 103, 199, 0.1);
    color: #0f67c7;
}

@keyframes homeDadosFloat {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-8px);
    }
}

@keyframes homeDadosRotate {
    to {
        transform: rotate(383deg);
    }
}

@keyframes homeDadosPulse {
    0%,
    100% {
        transform: translate(-50%, -50%) scale(1);
    }
    50% {
        transform: translate(-50%, -50%) scale(1.08);
    }
}

@keyframes homeDadosBar {
    0%,
    100% {
        opacity: 0.45;
        transform: scaleX(0.76);
        transform-origin: left;
    }
    50% {
        opacity: 1;
        transform: scaleX(1);
    }
}

@keyframes homeDadosMove {
    0% {
        opacity: 0;
        transform: translateX(0) scale(0.8);
    }
    30%,
    70% {
        opacity: 1;
    }
    100% {
        opacity: 0;
        transform: translateX(118px) scale(1);
    }
}

@keyframes homeDadosMetricFill {
    0%,
    100% {
        width: 46%;
    }
    50% {
        width: 92%;
    }
}

.home-destaques .home-section-head--split {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    text-align: center;
}

.home-destaques .home-section-head p {
    margin-left: auto;
    margin-right: auto;
}

.home-destaques .link-destaques {
    justify-self: center;
}

.metricas--premium .card-metrica {
    position: relative;
    overflow: hidden;
    min-height: 158px;
    padding: 22px;
    text-align: left;
    border: 1px solid #dbe7f6;
    border-radius: 16px;
    background: #ffffff;
}

.metricas--premium .card-metrica::after {
    content: "";
    position: absolute;
    right: -34px;
    top: -38px;
    width: 110px;
    height: 110px;
    border-radius: 999px;
    background: rgba(15, 103, 199, 0.08);
}

.metricas--premium .card-metrica > span {
    display: block;
    margin-bottom: 10px;
    color: #64748b;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.metricas--premium .card-metrica h3 {
    margin: 0 0 8px;
    font-size: clamp(30px, 3vw, 40px);
    line-height: 1.05;
}

.metricas--premium .card-metrica p {
    margin: 0;
    color: #56677d;
    line-height: 1.55;
}

.home-destaques .destaque-preco-linha,
.home-destaques .destaque-avaliacao {
    display: none;
}

.home-jornada {
    position: relative;
    overflow: hidden;
}

.home-jornada .funcionalidades-topo .home-eyebrow {
    margin-bottom: 8px;
}

.secao-cidades-estados-seo {
    padding: 28px;
    border: 1px solid #e2eaf4;
    border-radius: 16px;
    background: #f8fbff;
}

.secao-cidades-estados-seo h2 {
    font-size: clamp(24px, 2.5vw, 34px);
}

@media (max-width: 900px) {
    .hero-slider {
        --hero-height: 380px;
    }

    .hero-slide-layout-com-imovel {
        grid-template-columns: 1fr;
    }

    .hero-conteudo {
        padding: 0;
    }

    .hero-imovel-card {
        margin: 0 0 28px;
    }

    .home-section-head--split {
        display: grid;
        gap: 16px;
    }

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

    .home-section-head--split .btn,
    .home-section-head--split .link-destaques {
        justify-self: start;
    }

    .home-search-dock {
        margin-top: -44px;
    }

    .home-search-dock__card {
        grid-template-columns: 1fr;
    }

    .home-hero-trust {
        grid-column: auto;
    }
}

@media (max-width: 640px) {
    .hero-slider {
        --hero-height: 360px;
    }

    .hero-slide-layout {
        padding: 44px 0;
    }

    .seo-premium-hero,
    .quem-premium-hero {
        padding: 38px 0 64px;
    }

    .seo-premium-search,
    .quem-premium-hero__panel,
    .seo-premium-section,
    .quem-premium-story:not(.home-confianca),
    .quem-premium-team,
    .quem-premium-how:not(.secao-funcionalidades) {
        border-radius: 16px;
        padding: 16px;
    }

    .seo-premium-metrics {
        width: min(100%, calc(100% - 20px));
    }

    .home-search-dock {
        width: 100%;
        padding: 0 10px;
        margin-top: -34px;
        margin-bottom: 24px;
    }

    .planos-premium-hero-dock,
    .quem-premium-hero-dock {
        padding: 0 10px;
        margin-top: -34px;
        margin-bottom: 24px;
    }

    .quem-premium-page > .quem-premium-hero + .home-dados-pipeline {
        margin-top: clamp(-40px, -11vw, -28px);
    }

    .quem-premium-page > .quem-premium-hero + .home-dados-inteligencia:not(.home-dados-pipeline) {
        margin-top: clamp(-44px, -12vw, -32px);
        margin-bottom: clamp(28px, 6vw, 40px);
    }

    .quem-premium-page > .home-dados-inteligencia:not(.home-dados-pipeline) + .quem-premium-hero-dock {
        margin-top: 0;
    }

    .home-search-dock__card {
        padding: 16px;
        border-radius: 16px;
    }

    .home-hero-search {
        grid-template-columns: 1fr;
    }

    .btn-hero-search {
        min-height: 44px;
    }

    .home-hero-trust {
        display: grid;
        justify-items: center;
    }

    .home-confianca-grid,
    .home-dados-grid,
    .grade-4 {
        grid-template-columns: 1fr;
    }

    .home-confianca,
    .home-dados-inteligencia {
        padding: 18px;
    }

    .home-dados-card-head {
        min-height: clamp(6.35rem, 22vw, 7.25rem);
    }

    .home-dados-visual {
        min-height: 225px;
        margin: 14px;
    }

    .home-dados-browser {
        width: 42%;
        padding-left: 12px;
        padding-right: 12px;
    }

    .home-dados-browser--left {
        left: 12px;
    }

    .home-dados-browser--right {
        right: 12px;
    }

    .home-dados-paper {
        left: 8%;
        width: 104px;
    }

    .home-dados-score-card {
        right: 7%;
        width: 118px;
    }

    .home-dados-flow span {
        left: 39%;
    }

    .metricas--premium .card-metrica {
        min-height: 0;
    }
}

.metricas .card-metrica h3 {
    font-size: 34px;
    color: var(--cor-primaria);
    margin-bottom: 6px;
}

.cta-ajuda {
    display: grid;
    grid-template-columns: minmax(0, 520px) minmax(280px, 420px);
    justify-content: space-between;
    gap: 40px;
    align-items: end;
    min-height: 470px;
    padding: 56px 0 24px;
}

.cta-ajuda-full {
    width: auto;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: #eef1f5;
    overflow-x: clip;
}

.cta-ajuda-texto {
    max-width: 470px;
    padding-bottom: 48px;
    justify-self: start;
    text-align: left;
}

.cta-ajuda-texto h2 {
    margin-top: 0;
    margin-bottom: 16px;
    font-size: 52px;
    line-height: 1.05;
    text-align: left;
}

.cta-ajuda-texto p {
    margin: 0 0 22px;
    color: #4b5563;
    line-height: 1.85;
    text-align: left;
}

.cta-ajuda-texto .btn {
    display: inline-flex;
    justify-content: center;
    text-align: center;
}

.cta-ajuda-imagem-wrap {
    display: flex;
    justify-content: center;
    align-items: end;
}

.cta-ajuda-imagem {
    max-width: 100%;
    max-height: 420px;
    object-fit: contain;
    display: block;
}

.cta-servicos {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    margin-top: -6px;
    padding-bottom: 34px;
}

.cta-servico-card {
    margin: 0;
    padding: 22px 18px 20px;
    border: 1px solid #edf2f7;
    border-radius: 8px;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.04);
}

.cta-servico-card h3 {
    margin: 0 0 10px;
    font-size: 18px;
    text-align: left;
}

.cta-servico-card p {
    margin: 0 0 14px;
    color: #6b7280;
    font-size: 14px;
    line-height: 1.7;
}

.cta-servico-card ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.cta-servico-card li {
    color: #5f6b7a;
    font-size: 13px;
    line-height: 1.5;
}

.cta-servico-card li::before {
    content: "\2713";
    color: #8cc6d7;
    font-weight: 700;
    margin-right: 8px;
}

.cta-servico-icone {
    width: 46px;
    height: 46px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    background: #dff3fb;
    color: #0f67c7;
}

.cta-servico-icone .bi {
    font-size: 22px;
    line-height: 1;
}

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

.secao,
.secao-intro {
    margin: 52px 0;
}

.a-leilaum {
    text-align: center;
}

.a-leilaum-conteudo {
    max-width: 760px;
    margin: 0 auto;
}

.a-leilaum p {
    max-width: 700px;
    margin: 0 auto 18px;
    color: var(--cor-texto-sec);
    font-size: 16px;
    line-height: 1.75;
}

.secao-leilao-caixa-destaque {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 34px 0;
    background: #eef1f5;
}

.secao-leilao-caixa-destaque .card {
    margin: 0;
    text-align: center;
}

.secao-leilao-caixa-destaque .card p {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.85;
}

.secao-leilao-caixa-destaque .seo-badges {
    justify-content: center;
}

.secao-leilao-caixa-vantagens .card p,
.secao-leilao-caixa-etapas .card p {
    line-height: 1.85;
}

.erro-404 {
    min-height: calc(100vh - 220px);
    padding: 56px 0;
    background: #ffffff;
}

.erro-404-conteudo {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
    align-items: center;
    gap: 30px;
}

.erro-404-texto {
    color: #0f172a;
}

.erro-404-codigo {
    display: block;
    margin-bottom: 8px;
    font-size: clamp(64px, 11vw, 110px);
    line-height: 0.95;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #0f67c7;
}

.erro-404 h1 {
    margin: 0 0 14px;
    color: #111827;
    font-size: clamp(28px, 4.2vw, 46px);
    text-align: left;
}

.erro-404-texto p {
    max-width: 520px;
    margin: 0;
    color: #4b5563;
    line-height: 1.85;
}

.erro-404-acoes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.erro-404-voltar {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 22px;
    color: #2563eb !important;
    font-weight: 600;
}

.erro-404-voltar:hover {
    color: #1d4ed8 !important;
}

.erro-404-path {
    margin-top: 12px !important;
    color: rgba(191, 219, 254, 0.9) !important;
    font-size: 13px;
}

.erro-404-ilustracao img {
    width: 100%;
    max-width: 740px;
    display: block;
    margin-left: auto;
    filter: drop-shadow(0 12px 24px rgba(15, 23, 42, 0.16));
}

@media (max-width: 900px) {
    .erro-404 {
        padding: 36px 0 42px;
    }

    .erro-404-conteudo {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .erro-404 h1 {
        text-align: center;
    }

    .erro-404-texto p {
        margin-left: auto;
        margin-right: auto;
    }

    .erro-404-acoes {
        justify-content: center;
    }

    .erro-404-voltar {
        justify-content: center;
    }

    .erro-404-ilustracao img {
        margin-right: auto;
        max-width: 600px;
    }
}

.btn-a-leilaum {
    background: linear-gradient(180deg, #0f67c7, #0b58a8);
    color: #fff;
    border-radius: 8px;
    padding: 12px 22px;
    box-shadow: 0 10px 24px rgba(15, 93, 184, 0.18);
}

.secao-intro h1,
.secao h2 {
    margin-bottom: 12px;
    font-size: 46px;
    text-align: center;
}

.secao-cta .cta-ajuda-texto,
.secao-cta .cta-ajuda-texto h2,
.secao-cta .cta-ajuda-texto p {
    text-align: left;
}

.secao-intro p {
    color: var(--cor-texto-sec);
}

.secao-intro-destaque {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: 0;
    margin-bottom: 20px;
    padding: 48px 0 50px;
    background: linear-gradient(180deg, #095baa, #0d61b4);
    color: #fff;
    text-align: center;
}

.secao-intro-destaque h1 {
    margin: 0 0 10px;
    color: #fff;
    font-size: 28px;
    line-height: 1.1;
    font-weight: 700;
}

.secao-intro-destaque p {
    margin: 0 auto;
    max-width: 880px;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.6;
}

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

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

.hero h1 {
    margin: 0 0 10px;
}

.hero p {
    margin: 0 0 20px;
    color: #e2e8f0;
}

.hero-acoes {
    display: flex;
    gap: 12px;
}

.btn {
    border: none;
    border-radius: 10px;
    padding: 12px 16px;
    cursor: pointer;
    font-weight: 700;
    text-decoration: none;
    display: inline-block;
}

.btn-primario {
    background: var(--cor-destaque);
    color: #1f2937;
}

.btn-secundario {
    background: #fff;
    color: var(--cor-primaria);
}

.card {
    margin: 28px 0;
    background: #fff;
    border: 1px solid var(--cor-borda);
    border-radius: 14px;
    padding: 24px;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
}

.card h3 {
    margin-top: 0;
}

.card-admin-login {
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

.admin-login-body {
    background:
        radial-gradient(circle at top left, rgba(243, 146, 0, 0.16), transparent 28%),
        radial-gradient(circle at bottom right, rgba(0, 92, 169, 0.16), transparent 34%),
        linear-gradient(180deg, #eef5fb 0%, #f8fbff 100%);
}

.admin-login-main {
    flex: 1 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px 18px;
}

.admin-login-logo {
    margin: 0 auto 14px;
}

.admin-login-wrap {
    width: min(100%, 420px);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.card-admin-login {
    max-width: 380px;
    width: 100%;
    background: #fff;
    border: 1px solid #e8edf4;
    border-radius: 24px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.10);
    padding: 32px 28px 26px;
}

.card-admin-login h1 {
    margin: 0 0 18px;
    font-size: 42px;
    font-weight: 700;
    text-align: center;
    color: #0f172a;
    line-height: 1.1;
}

.admin-login-form {
    gap: 0;
}

.login-helper-text {
    margin: 0 0 18px;
    color: #64748b;
    font-size: 14px;
    text-align: left;
}

.admin-login-form input {
    border: 1px solid #d6e1ee;
    min-height: 52px;
    font-size: 15px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.admin-login-form input:focus {
    border-color: #7aa9de;
    box-shadow: 0 0 0 4px rgba(0, 92, 169, 0.10);
    background: #fff;
    outline: none;
}

.login-recaptcha-wrap {
    margin-top: 16px;
}

.login-remember {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #111827;
    font-size: 14px;
    font-weight: 500;
}

.login-remember input {
    width: 16px;
    height: 16px;
    margin: 0;
}

.btn-admin-login-submit {
    margin-top: 16px;
    width: 100%;
    border-radius: 14px;
    background: var(--cor-destaque);
    color: #1f2937;
    min-height: 52px;
    font-weight: 700;
    letter-spacing: 0.02em;
    box-shadow: 0 14px 30px rgba(243, 146, 0, 0.24);
}

.login-aux-link {
    display: block;
    margin-top: 10px;
    text-align: center;
    color: #1f4f98;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
}

.login-aux-link:hover {
    text-decoration: underline;
}

.auth-entry-shell {
    width: min(100%, 1140px);
    display: grid;
    grid-template-columns: minmax(320px, 1.05fr) minmax(340px, 0.95fr);
    gap: 34px;
    align-items: center;
}

.auth-entry-aside {
    position: relative;
    padding: 28px 18px 28px 10px;
}

.auth-entry-logo {
    display: inline-flex;
    margin-bottom: 26px;
}

.auth-entry-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.64);
    color: #1d4f8e;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.auth-entry-aside h1 {
    margin: 0 0 16px;
    max-width: 620px;
    color: #0f172a;
    font-size: 46px;
    line-height: 1.08;
    font-weight: 800;
}

.auth-entry-aside p {
    margin: 0;
    max-width: 560px;
    color: #475569;
    font-size: 18px;
    line-height: 1.7;
}

.auth-entry-benefits {
    display: grid;
    gap: 12px;
    margin-top: 28px;
}

.auth-entry-benefit {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid rgba(214, 225, 238, 0.9);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.72);
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.04);
    color: #1e293b;
    font-size: 15px;
    font-weight: 500;
}

.auth-entry-benefit .bi {
    flex: 0 0 auto;
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: rgba(0, 92, 169, 0.12);
    color: #0f67c7;
    font-size: 18px;
}

.auth-entry-card-wrap {
    display: flex;
    justify-content: center;
}

.card-auth-login {
    max-width: 440px;
}

.card-auth-login h2 {
    margin: 0 0 8px;
    color: #0f172a;
    font-size: 34px;
    line-height: 1.1;
    font-weight: 800;
}

.auth-login-form {
    gap: 14px;
}

.auth-field {
    display: grid;
    gap: 7px;
}

.auth-field span {
    color: #334155;
    font-size: 13px;
    font-weight: 700;
}

.auth-field input {
    margin: 0;
    padding: 0 15px;
    border-radius: 14px;
    background: #f8fbff;
}

.auth-login-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 4px;
}

.auth-terms-check {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    color: #334155;
    font-size: 14px;
    line-height: 1.55;
}

.auth-terms-check input {
    width: 16px;
    height: 16px;
    margin: 0;
    align-self: center;
}

.auth-terms-check span {
    display: block;
}

.auth-terms-check a {
    color: #1f4f98;
    font-weight: 700;
    text-decoration: none;
}

.auth-terms-check a:hover {
    text-decoration: underline;
}

.auth-login-inline-link {
    color: #1f4f98;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.auth-login-inline-link:hover {
    text-decoration: underline;
}

.auth-login-footer-links {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #e9eff6;
}

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

.contato-layout {
    display: grid;
    grid-template-columns: minmax(300px, 1fr) minmax(340px, 1fr);
    gap: 52px;
    align-items: start;
    margin: 42px 0 30px;
}

.contato-feedback {
    margin: 18px 0 22px;
}

.contato-feedback .alerta {
    margin-top: 0;
}

.contato-info h1 {
    margin: 0 0 18px;
    font-size: 28px;
    line-height: 1.1;
    font-weight: 700;
}

.contato-info p {
    margin: 0;
    color: #334155;
    font-size: 15px;
    line-height: 1.6;
}

.contato-canais {
    margin-top: 24px;
}

.contato-canais p {
    margin: 0 0 14px;
}

.contato-canais-icones {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.contato-canal-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 18px;
    border: 1px solid #dbe5f0;
    border-radius: 14px;
    background: #fff;
    color: #0f5db8;
    text-decoration: none;
    font-weight: 700;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.contato-canal-link:hover {
    border-color: #9dc6de;
    box-shadow: 0 10px 24px rgba(15, 93, 184, 0.08);
    transform: translateY(-1px);
}

.contato-canal-link-desabilitado {
    background: #f3f6fb;
    border-color: #d7deea;
    color: #8a97aa;
    cursor: default;
    pointer-events: none;
}

.contato-canal-link-desabilitado:hover {
    border-color: #d7deea;
    box-shadow: none;
    transform: none;
}

.contato-canal-link .bi {
    font-size: 20px;
}

.contato-form-wrap {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
    padding: 24px;
}

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

.contato-form label {
    font-size: 16px;
    font-weight: 600;
    color: #1f2937;
}

.contato-form label span {
    color: #dc2626;
}

.contato-form input,
.contato-form select,
.contato-form textarea {
    width: 100%;
    min-height: 48px;
    padding: 11px 12px;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    font-size: 16px;
    font-family: inherit;
    color: #111827;
    background: #fff;
}

.contato-form textarea {
    min-height: 110px;
    resize: vertical;
}

.contato-form input:focus,
.contato-form select:focus,
.contato-form textarea:focus {
    outline: none;
    border-color: #8ab6da;
    box-shadow: 0 0 0 3px rgba(15, 93, 184, 0.08);
}

.btn-contato-enviar {
    justify-self: start;
    background: #0f67c7;
    color: #fff;
    min-width: 190px;
    padding: 12px 20px;
}

input {
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    padding: 10px;
}

select,
textarea {
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    padding: 10px;
    font-family: inherit;
}

.alerta {
    border-radius: 8px;
    padding: 10px 12px;
    margin-top: 20px;
}

.alerta-erro {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.alerta-sucesso {
    background: #dcfce7;
    color: #166534;
    border: 1px solid #86efac;
}

.pagina-fullbleed {
    width: 100dvw;
    margin-left: calc(50% - 50dvw);
    margin-right: calc(50% - 50dvw);
    overflow-x: clip;
}

.quem-somos-pagina {
    color: #4b5563;
    background: #fff;
}

.quem-somos-pagina .container {
    width: min(1200px, calc(100dvw - 48px));
    max-width: none;
    margin-left: auto;
    margin-right: auto;
}

.quem-hero {
    background: linear-gradient(180deg, #095baa, #0d61b4);
    color: #fff;
    text-align: center;
    padding: 48px 0 50px;
}

.quem-hero h1 {
    margin: 0 0 10px;
    font-size: 28px;
    line-height: 1.1;
    font-weight: 700;
}

.quem-hero p {
    margin: 0 auto;
    max-width: 880px;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.6;
}

.quem-bloco,
.quem-equipe,
.quem-diferenciais {
    padding: 58px 0;
}

.quem-principios {
    padding: 42px 0 62px;
    background: #f8fafc;
}

.quem-historia-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
    gap: 54px;
    align-items: start;
}

.quem-historia-texto h2,
.quem-principios h2,
.quem-equipe h2,
.quem-diferenciais h2,
.quem-cta-faixa h2 {
    margin: 0 0 12px;
    color: #0f5db8;
    font-size: 26px;
    line-height: 1.12;
    text-align: center;
}

.quem-historia-texto h2 {
    text-align: left;
    margin-bottom: 18px;
}

.quem-historia-texto p,
.quem-profissional-texto p {
    margin: 0 0 16px;
    font-size: 16px;
    line-height: 1.95;
}

.quem-expertise-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid #edf2f7;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
}

.quem-expertise-card h2,
.quem-expertise-card h3 {
    margin: 0;
    padding: 0 28px 18px;
    color: #111827;
    font-size: 22px;
    font-weight: 700;
    text-align: center;
}

.quem-expertise-linhas p {
    margin: 0;
    padding: 18px 22px;
    border-top: 1px solid #eef2f7;
    font-size: 15px;
    line-height: 1.85;
    background: #fbfcfe;
}

.quem-icone,
.quem-icone-menor {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #0f5db8;
    color: #fff;
}

.quem-icone {
    width: 72px;
    height: 72px;
    margin: 28px auto 18px;
    align-self: center;
}

.quem-icone-menor {
    width: 34px;
    height: 34px;
    margin-bottom: 16px;
}

.quem-icone-svg {
    display: none;
}

.quem-icone .bi {
    font-size: 28px;
    line-height: 1;
}

.quem-icone-menor .bi {
    font-size: 16px;
    line-height: 1;
}

.quem-subtitulo {
    margin: 0 auto 28px;
    max-width: 860px;
    color: #6b7280;
    text-align: center;
    font-size: 14px;
    line-height: 1.6;
    font-weight: 700;
}

.quem-principios-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
    max-width: 1120px;
    margin: 0 auto;
}

.quem-principio-card {
    background: #fff;
    border: 1px solid #eef2f7;
    border-radius: 8px;
    padding: 24px 22px 22px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.quem-principio-card h3,
.quem-diferencial-card h3,
.quem-profissional h3 {
    margin: 0 0 12px;
    color: #1f2937;
    font-size: 22px;
    text-align: left;
}

.quem-principio-card p,
.quem-diferencial-card p,
.quem-principio-card li,
.quem-profissional-cargo {
    margin: 0;
    font-size: 15px;
    line-height: 1.9;
}

.quem-principio-card ul {
    margin: 0;
    padding-left: 20px;
}

.quem-principio-card li + li {
    margin-top: 4px;
}

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

.quem-profissional-foto {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 8px;
    display: block;
    margin-bottom: 12px;
}

.quem-profissional h3 {
    color: #67b8d9;
    font-size: 16px;
    margin-bottom: 6px;
}

.quem-profissional-cargo {
    color: #0f5db8;
    font-weight: 600;
    margin-bottom: 16px;
}

.quem-profissional-texto {
    max-width: 96%;
}

.quem-profissional-texto p {
    margin: 0 0 22px;
    line-height: 2;
}

.quem-profissional-texto p:last-child {
    margin-bottom: 0;
}

.quem-cta-faixa {
    background: linear-gradient(180deg, #095baa, #0d61b4);
    color: #fff;
    padding: 54px 0;
    text-align: center;
}

.quem-cta-faixa h2 {
    color: #fff;
    font-size: 28px;
    line-height: 1.2;
    margin-bottom: 12px;
}

.quem-cta-faixa p {
    margin: 0 auto 22px;
    max-width: 940px;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.7;
}

.quem-cta-botoes {
    display: flex;
    justify-content: center;
    gap: 12px;
}

.quem-cta-botoes .btn {
    min-width: 190px;
    padding: 13px 20px;
}

.btn-cta-claro {
    background: var(--cor-destaque);
    color: #1f2937;
}

.quem-diferenciais-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    max-width: 1120px;
    margin: 0 auto;
}

.quem-diferencial-card {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 18px;
    align-items: start;
    background: #fff;
    border: 1px solid #eef2f7;
    border-radius: 8px;
    padding: 22px 22px 20px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.quem-diferencial-card .quem-icone-menor {
    margin-bottom: 0;
}

.secao-cta {
    margin-bottom: 44px;
    padding-bottom: 12px;
}

.planos-pagina {
    color: #4b5563;
    background: #fff;
}

.planos-pagina .container {
    width: min(1200px, calc(100dvw - 48px));
    max-width: none;
    margin-left: auto;
    margin-right: auto;
}

.planos-hero {
    background: linear-gradient(180deg, #095baa, #0d61b4);
    color: #fff;
    text-align: center;
    padding: 48px 0 50px;
}

.planos-hero h1 {
    margin: 0 0 10px;
    font-size: 28px;
    line-height: 1.1;
    font-weight: 700;
}

.planos-hero p {
    margin: 0 auto;
    max-width: 880px;
    color: rgba(255, 255, 255, 0.92);
    font-size: 15px;
    line-height: 1.6;
}

.planos-bloco {
    padding: 58px 0;
}

.planos-bloco + .planos-bloco {
    padding-top: 8px;
}

.planos-cabecalho {
    margin: 0 auto 28px;
    max-width: 860px;
    text-align: center;
}

.planos-cabecalho h2,
.planos-cta h2 {
    margin: 0 0 12px;
    color: #0f5db8;
    font-size: 26px;
    line-height: 1.12;
    font-weight: 700;
}

.planos-cabecalho p,
.planos-cta p {
    margin: 0;
    font-size: 16px;
    line-height: 1.85;
    color: #4b5563;
}

.planos-cta {
    max-width: 860px;
    margin: 0 auto;
    padding: 28px 30px;
    border-radius: 18px;
}

.planos-cta form {
    margin-top: 20px;
}

.planos-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    align-items: stretch;
}

.planos-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 18px;
    min-height: 100%;
    padding: 28px 26px 24px;
    background: #fff;
    border: 1px solid #eef2f7;
    border-radius: 18px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.planos-card-destaque {
    border: 2px solid var(--cor-primaria);
    box-shadow: 0 18px 36px rgba(15, 93, 184, 0.10);
}

.planos-card-topo {
    display: grid;
    gap: 8px;
}

.planos-kicker {
    color: #6b7280;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.planos-card h3 {
    margin: 0;
    color: #1f2937;
    font-size: 28px;
    line-height: 1.15;
    font-weight: 700;
}

.planos-preco {
    margin: 0;
    color: #0f5db8;
    font-size: 34px;
    line-height: 1.1;
    font-weight: 800;
}

.planos-preco small {
    font-size: 16px;
    font-weight: 600;
    color: #64748b;
}

.planos-resumo {
    margin: 0;
    font-size: 15px;
    line-height: 1.85;
    color: #4b5563;
}

.planos-lista {
    margin: 0;
    padding-left: 20px;
    display: grid;
    gap: 10px;
    color: #334155;
    font-size: 15px;
    line-height: 1.8;
}

.planos-acao {
    margin-top: auto;
    padding-top: 8px;
}

.planos-acao .btn,
.planos-acao form {
    width: 100%;
}

.planos-acao .btn {
    justify-content: center;
}

.planos-tag {
    position: absolute;
    top: 18px;
    right: 18px;
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(15, 93, 184, 0.10);
    color: #0f5db8;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.plano {
    position: relative;
}

.plano .preco {
    font-size: 28px;
    font-weight: 700;
    margin: 8px 0 14px;
}

.plano ul {
    padding-left: 18px;
    color: var(--cor-texto-sec);
}

.plano-destaque {
    border: 2px solid var(--cor-primaria);
}

.tag {
    position: absolute;
    top: 12px;
    right: 12px;
    font-size: 12px;
    font-weight: 700;
    background: var(--cor-primaria);
    color: #fff;
    border-radius: 999px;
    padding: 4px 10px;
}

.rodape {
    margin-top: 0;
    background: linear-gradient(120deg, #03162d, #072647);
    padding: 36px 0;
    color: #d0d9e6;
}

.rodape .logo {
    color: #fff;
}

.logo-img-rodape {
    height: 45px;
    width: auto;
    object-fit: contain;
}

.rodape-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 26px;
}

.rodape h4 {
    color: #fff;
    margin-top: 0;
}

.rodape a {
    display: block;
    color: #d0d9e6;
    text-decoration: none;
    margin-bottom: 8px;
}

.rodape p,
.rodape a,
.rodape h4 {
    text-align: left;
}

.rodape-tagline {
    line-height: 1.85;
}

.rodape-instagram-link {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    padding: 10px 16px;
    border-radius: 14px;
    border: 1px solid rgba(148, 163, 184, 0.35);
    background: rgba(255, 255, 255, 0.06);
    color: #ffffff !important;
    font-weight: 700;
    transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

.rodape-instagram-link .bi {
    font-size: 18px;
}

.rodape-instagram-link:hover {
    border-color: rgba(255, 255, 255, 0.55);
    background: rgba(255, 255, 255, 0.12);
    transform: translateY(-1px);
}

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

.newsletter-form input {
    background: #fff;
}

.rodape-cta-acoes {
    display: grid;
    gap: 12px;
    margin-top: 14px;
    max-width: 360px;
}

.rodape-cta-acoes .btn {
    text-align: center;
}

.rodape-cta-acoes .btn,
.rodape-cta-acoes .btn:visited,
.rodape-cta-acoes .btn.btn-primario,
.rodape-cta-acoes .btn.btn-secundario {
    color: #111827;
}

.rodape-cta-acoes .btn.btn-primario {
    background: var(--cor-destaque);
    border-color: var(--cor-destaque);
}

.rodape-grid > div:last-child h4,
.rodape-grid > div:last-child p {
    color: #fff;
}

.rodape-grid > div:last-child p {
    line-height: 1.85;
}

.indicador {
    margin: 0;
    font-size: 32px;
    font-weight: 700;
    color: var(--cor-primaria);
}

.texto-secundario {
    color: var(--cor-texto-sec);
    font-size: 13px;
}

.filtros-admin {
    display: grid;
    grid-template-columns: 2fr repeat(3, 1fr) auto;
    gap: 10px;
    align-items: center;
}

.hero-admin-imoveis {
    display: grid;
    gap: 8px;
    max-height: 340px;
    overflow: auto;
    border: 1px solid var(--cor-borda);
    border-radius: 10px;
    padding: 10px;
    background: #f8fafc;
}

.hero-admin-imovel-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    color: var(--cor-texto);
}

.hero-admin-preview-wrap {
    margin-top: 18px;
}

.hero-admin-preview {
    position: relative;
    border-radius: 12px;
    min-height: 220px;
    overflow: hidden;
    border: 1px solid #dbe2ee;
    background: #1e3a5f;
}

.hero-admin-preview-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0.2));
}

.hero-admin-preview-content {
    position: relative;
    z-index: 2;
    padding: 28px 24px;
    max-width: 560px;
}

.hero-admin-preview-card {
    position: absolute;
    right: 20px;
    bottom: 20px;
    z-index: 2;
    display: none;
    gap: 8px;
    width: min(280px, calc(100% - 40px));
    padding: 16px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.94);
    color: #0f172a;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.16);
}

.hero-admin-preview-card__label {
    color: #64748b;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.hero-admin-preview-card__cta {
    color: #0f67c7;
    font-size: 13px;
    font-weight: 700;
}

.hero-admin-preview-content h4 {
    margin: 0 0 10px;
    font-size: 28px;
    line-height: 1.15;
}

.hero-admin-preview-content p {
    margin: 0 0 16px;
    color: rgba(255, 255, 255, 0.92);
}

.hero-admin-preview-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.hero-admin-preview-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #4f73ff;
    color: #fff;
    border-radius: 8px;
    min-height: 34px;
    padding: 6px 12px;
    font-weight: 700;
    font-size: 13px;
}

.hero-admin-preview-btn-sec {
    background: #e2e8f0;
    color: #1f2937;
}

.tabela-wrap {
    width: 100%;
    overflow: auto;
}

.tabela-admin {
    width: 100%;
    border-collapse: collapse;
    min-width: 980px;
}

.tabela-admin th,
.tabela-admin td {
    padding: 10px;
    border-bottom: 1px solid var(--cor-borda);
    text-align: left;
    vertical-align: top;
}

.checkbox-linha {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--cor-texto-sec);
}

.lista-pesquisas {
    display: grid;
    gap: 12px;
}

.card-interno {
    margin: 0;
    border-style: dashed;
}

.json-preview {
    background: #0f172a;
    color: #e2e8f0;
    padding: 10px;
    border-radius: 8px;
    overflow: auto;
    font-size: 12px;
}

.admin-log-output {
    margin: 16px 0 0;
    padding: 14px;
    max-height: 320px;
    overflow: auto;
    border-radius: 8px;
    background: #0f172a;
    color: #e2e8f0;
    font-size: 12px;
    line-height: 1.6;
    white-space: pre-wrap;
}

.admin-log-output--compact {
    margin: 0;
    max-height: 150px;
    min-width: 320px;
}

.admin-progress {
    width: 160px;
    height: 9px;
    overflow: hidden;
    border-radius: 999px;
    background: #e2e8f0;
    margin-bottom: 6px;
}

.admin-progress__bar {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #0f67c7, #f59e0b);
    transition: width .2s ease;
}

.admin-inline-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.imoveis-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 20px 0 36px;
}

.busca-hero-full {
    width: auto;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow-x: clip;
}

.busca-hero {
    background:
        radial-gradient(circle at top right, rgba(245, 164, 0, 0.22), transparent 30%),
        linear-gradient(135deg, #0b2542 0%, #0f3f78 54%, #0f67c7 100%);
    color: #fff;
    text-align: center;
    padding: 36px 0 86px;
    margin-bottom: -34px;
}

.busca-hero .container {
    display: grid;
    justify-items: center;
    gap: 12px;
}

.busca-hero__kicker {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, 0.26);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.9);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.busca-hero h1 {
    margin: 0;
    max-width: 850px;
    font-size: clamp(34px, 4.8vw, 54px);
    line-height: 1.04;
    font-weight: 900;
}

.busca-hero p {
    max-width: 760px;
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 17px;
    line-height: 1.65;
}

.busca-hero__stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 4px;
}

.busca-hero__stats span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.11);
    color: rgba(255, 255, 255, 0.88);
    font-size: 13px;
    font-weight: 700;
}

.busca-hero__stats strong {
    color: #ffffff;
    font-size: 15px;
}

.busca-card-wrap {
    width: min(1180px, calc(100% - 32px));
    margin: -34px auto 0;
    position: relative;
    z-index: 2;
}

.busca-acoes-mapa,
.resultado-toolbar,
.imoveis-grid,
.paginacao {
    width: min(1180px, calc(100% - 32px));
    margin-left: auto;
    margin-right: auto;
}

.busca-card {
    position: relative;
    z-index: 2;
    margin: 0;
    width: 100%;
    padding: 22px;
    border-radius: 20px;
    border-color: #e5edf7;
    background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
    box-shadow: 0 20px 42px rgba(15, 23, 42, 0.08);
}

.busca-form {
    display: grid;
    gap: 14px;
}

.busca-topo {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(360px, 1.1fr);
    align-items: end;
    gap: 18px;
}

.busca-topo-texto {
    display: grid;
    gap: 6px;
}

.busca-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(15, 93, 184, 0.08);
    color: #0f5db8;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.busca-topo-texto h2 {
    margin: 0;
    color: #0f172a;
    font-size: 24px;
    line-height: 1.15;
}

.busca-topo-texto p {
    margin: 0;
    color: #64748b;
    font-size: 15px;
    line-height: 1.7;
}

.busca-grid {
    display: grid;
    gap: 14px;
}

.busca-grid-1 {
    grid-template-columns: 1fr;
}

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

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

.busca-grid-localizacao {
    grid-template-columns: minmax(120px, 0.7fr) minmax(0, 1.15fr) minmax(0, 1.15fr);
}

.busca-grid-condicoes {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.busca-grid-bairro {
    grid-template-columns: minmax(240px, 1fr) auto;
    align-items: end;
}

.busca-grupo {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid #e5edf7;
    border-radius: 18px;
    background: #f8fbff;
}

.busca-grupo__titulo {
    display: flex;
    align-items: center;
    gap: 9px;
    color: #0f172a;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.busca-grupo__titulo i {
    color: #0f67c7;
    font-size: 16px;
}

.busca-form label {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: #374151;
    margin-bottom: 8px;
    letter-spacing: 0.01em;
}

.busca-form input,
.busca-form select {
    width: 100%;
    min-height: 50px;
    border: 1px solid #d8e3ef;
    border-radius: 12px;
    background: #fff;
    padding: 12px 14px;
    font-size: 15px;
    color: #374151;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.02);
}

.busca-campo-principal {
    margin: 0;
}

.busca-campo-principal span {
    display: block;
    margin-bottom: 8px;
    color: #374151;
    font-size: 13px;
    font-weight: 800;
}

.busca-campo-principal input {
    min-height: 56px;
    padding-left: 18px;
    border-color: #bfd5ed;
    font-size: 16px;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.045);
}

.busca-form input::placeholder {
    color: #9ca3af;
}

.busca-form select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 42px;
    background-image:
        linear-gradient(45deg, transparent 50%, #4b5563 50%),
        linear-gradient(135deg, #4b5563 50%, transparent 50%);
    background-position:
        calc(100% - 18px) calc(50% - 1px),
        calc(100% - 13px) calc(50% - 1px);
    background-size: 5px 5px, 5px 5px;
    background-repeat: no-repeat;
}

.busca-form input:focus,
.busca-form select:focus {
    outline: none;
    border-color: #8ab6da;
    box-shadow: 0 0 0 4px rgba(15, 93, 184, 0.08);
}

.busca-multiselect {
    position: relative;
}

.busca-multiselect__toggle {
    width: 100%;
    min-height: 50px;
    border: 1px solid #d8e3ef;
    border-radius: 12px;
    background: #fff;
    padding: 12px 14px;
    font-size: 15px;
    color: #374151;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.02);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    text-align: left;
    cursor: pointer;
}

.busca-multiselect__toggle span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.busca-multiselect__toggle i {
    color: #4b5563;
    font-size: 13px;
    transition: transform 0.2s ease;
}

.busca-multiselect--open .busca-multiselect__toggle {
    border-color: #8ab6da;
    box-shadow: 0 0 0 4px rgba(15, 93, 184, 0.08);
}

.busca-multiselect--open .busca-multiselect__toggle i {
    transform: rotate(180deg);
}

.busca-multiselect--disabled .busca-multiselect__toggle {
    background: #f8fafc;
    color: #94a3b8;
    cursor: not-allowed;
}

.busca-multiselect__menu {
    position: absolute;
    z-index: 40;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    max-height: 260px;
    overflow-y: auto;
    border: 1px solid #d8e3ef;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.14);
    padding: 8px;
    display: none;
}

.busca-multiselect--open .busca-multiselect__menu {
    display: block;
}

.busca-form .busca-multiselect__option {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 38px;
    margin: 0;
    padding: 8px 10px;
    border-radius: 10px;
    color: #374151;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.25;
    letter-spacing: 0;
    cursor: pointer;
}

.busca-form .busca-multiselect__option:hover {
    background: #f1f7fd;
}

.busca-form .busca-multiselect__option input {
    width: 16px;
    min-height: 16px;
    height: 16px;
    margin: 0;
    padding: 0;
    flex: 0 0 auto;
    accent-color: #0f67c7;
    box-shadow: none;
}

.busca-multiselect__empty {
    display: block;
    padding: 10px;
    color: #6b7280;
    font-size: 14px;
}

.busca-acoes {
    display: grid;
    gap: 10px;
    justify-items: end;
}

.busca-acoes--linha {
    justify-items: end;
    padding-top: 2px;
}

.busca-acoes-texto {
    margin: 0;
    max-width: 380px;
    color: #64748b;
    font-size: 13px;
    line-height: 1.6;
    text-align: right;
}

.busca-botoes-linha {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.busca-botoes-linha .btn {
    min-height: 48px;
    border-radius: 12px;
    padding: 0 22px;
    font-size: 15px;
    font-weight: 700;
    box-shadow: none;
}

.busca-filtros-ativos {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding-top: 2px;
}

.busca-filtros-ativos > span {
    color: #64748b;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.busca-filtros-ativos a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 30px;
    padding: 0 10px;
    border: 1px solid #bdd5ee;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f5db8;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
}

.busca-filtros-ativos a:hover {
    border-color: #8fb9ea;
    background: #e4f0ff;
}

.btn-busca-limpar {
    border: 1px solid transparent;
    background: transparent;
    color: #1b6fae;
    padding-left: 10px;
    padding-right: 10px;
}

.btn-busca-limpar:hover {
    background: rgba(15, 93, 184, 0.06);
    color: #0f5db8;
}

.btn-busca-salvar {
    border: 1px solid #d8e3ef;
    background: #fff;
    color: #0f5db8;
}

.btn-busca-salvar:hover {
    border-color: #9fc3ee;
    background: #f8fbff;
    color: #0f5db8;
}

.btn-busca-filtrar {
    border: 1px solid #e49a00;
    background: linear-gradient(180deg, #ffbf2f, #f3a300);
    color: #1f2937;
}

.btn-busca-filtrar:hover {
    background: linear-gradient(180deg, #ffc84d, #e59a00);
    border-color: #d48f00;
}

.btn-busca-filtrar {
    min-width: 92px;
}

.btn-mapa {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 48px;
    border: 1px solid #9dc6de;
    border-radius: 12px;
    color: #1b6fae;
    background: #fff;
    padding: 0 20px;
    font-weight: 700;
    box-shadow: none;
}

.btn-mapa:hover {
    border-color: #5f9fc3;
    color: #0f5db8;
    background: #f8fcff;
}

.resultado-mapa-wrap {
    display: grid;
    justify-items: end;
    gap: 6px;
}

.resultado-mapa-ajuda {
    color: #64748b;
    font-size: 12px;
    line-height: 1.45;
    text-align: right;
    max-width: 260px;
}

.btn-mapa.btn-mapa-desabilitado,
.btn-mapa:disabled {
    border-color: #d8e3ef;
    color: #94a3b8;
    background: #f8fafc;
    cursor: not-allowed;
}

.mapa-imoveis {
    width: 100%;
    height: 640px;
    border: 1px solid var(--cor-borda);
    border-radius: 12px;
    overflow: hidden;
}

.busca-mapa-modal[hidden] {
    display: none;
}

.busca-mapa-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.busca-mapa-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.42);
}

.busca-mapa-modal__dialog {
    position: relative;
    z-index: 1;
    width: 100vw;
    height: 100vh;
    background: #f8fafc;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
}

.busca-mapa-modal__topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 24px;
    background: rgba(255, 255, 255, 0.96);
    border-bottom: 1px solid #dbe5f0;
}

.busca-mapa-modal__titulo-wrap {
    display: grid;
    gap: 4px;
}

.busca-mapa-modal__titulo-wrap h2 {
    margin: 0;
    color: #0f172a;
    font-size: 30px;
}

.busca-mapa-modal__titulo-wrap p {
    margin: 0;
    color: #64748b;
    font-size: 15px;
}

.busca-mapa-modal__acoes {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}

.busca-mapa-modal__contador {
    color: #334155;
    font-size: 14px;
    font-weight: 700;
}

.busca-mapa-modal__limpar,
.busca-mapa-modal__fechar {
    min-height: 46px;
    border-radius: 12px;
    padding: 0 18px;
}

.busca-mapa-modal__limpar {
    border: 1px solid #d8e3ef;
    background: #ffffff;
    color: #0f5db8;
}

.busca-mapa-modal__fechar {
    background: #0f5db8;
    color: #ffffff;
}

.mapa-imoveis-modal {
    height: 100%;
    border: 0;
    border-radius: 0;
}

.mapa-desenhar-area-control {
    margin-top: 14px !important;
    margin-right: 18px !important;
}

.mapa-desenhar-area-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 44px;
    padding: 0 16px;
    border: 2px solid #0f5db8;
    border-radius: 2px;
    background: #ffffff;
    color: #0f5db8;
    font: inherit;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.14);
    cursor: pointer;
}

.mapa-desenhar-area-btn:hover,
.mapa-desenhar-area-btn:focus-visible,
.mapa-desenhar-area-btn.ativo {
    background: #eaf3ff;
    border-color: #0f67c7;
    color: #0f67c7;
    outline: none;
}

.mapa-desenhar-area-btn i {
    font-size: 19px;
    line-height: 1;
}

.mapa-uf-control {
    width: 244px;
    max-height: min(520px, calc(100vh - 180px));
    margin-top: 14px !important;
    margin-left: 18px !important;
    padding: 14px;
    overflow: auto;
    border: 1px solid #d8e3ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.14);
}

.mapa-uf-control__title {
    margin-bottom: 10px;
    color: #0f172a;
    font-size: 14px;
    font-weight: 800;
}

.mapa-uf-control__list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
}

.mapa-uf-control__btn {
    min-height: 34px;
    border: 1px solid #d8e3ef;
    border-radius: 7px;
    background: #f8fafc;
    color: #0f172a;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
}

.mapa-uf-control__btn:hover,
.mapa-uf-control__btn:focus-visible,
.mapa-uf-control__btn.ativo {
    border-color: #0f5db8;
    background: #eaf3ff;
    color: #0f5db8;
    outline: none;
}

.mapa-zonas-card {
    position: absolute;
    top: 102px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 700;
    width: min(336px, calc(100vw - 32px));
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.16);
}

.mapa-zonas-card[hidden] {
    display: none;
}

.mapa-zonas-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 16px 10px;
    color: #0f172a;
    font-size: 18px;
}

.mapa-zonas-card__body {
    display: grid;
    gap: 10px;
    padding: 10px 16px 16px;
}

.mapa-zonas-card__zona {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #334155;
    font-size: 15px;
}

.mapa-zonas-card__zona strong {
    color: #64748b;
    font-weight: 800;
    white-space: nowrap;
}

.mapa-zonas-card__aplicar {
    width: calc(100% - 32px);
    min-height: 42px;
    margin: 0 16px 16px;
    border: 0;
    border-radius: 7px;
    background: #0f5db8;
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
}

.mapa-zonas-card__aplicar:hover,
.mapa-zonas-card__aplicar:focus-visible {
    background: #0f67c7;
    outline: none;
}

.mapa-popup .leaflet-popup-content-wrapper {
    border-radius: 18px;
    padding: 0;
    box-shadow: 0 20px 44px rgba(15, 23, 42, 0.18);
}

.mapa-popup .leaflet-popup-content {
    margin: 0;
    width: 280px !important;
}

.mapa-popup-card {
    overflow: hidden;
    background: #ffffff;
}

.mapa-popup-thumb {
    display: block;
    width: 100%;
    height: 138px;
    object-fit: cover;
    background: #d9e4f0;
}

.mapa-popup-thumb-placeholder {
    background: linear-gradient(135deg, #cbd5e1, #9fb2ca);
}

.mapa-popup-body {
    display: grid;
    gap: 8px;
    padding: 14px 14px 16px;
}

.mapa-popup-body h3 {
    margin: 0;
    color: #0f172a;
    font-size: 18px;
    line-height: 1.25;
}

.mapa-popup-localizacao {
    margin: 0;
    color: #64748b;
    font-size: 13px;
    line-height: 1.45;
}

.mapa-popup-preco-wrap {
    display: grid;
    gap: 2px;
}

.mapa-popup-preco-label {
    color: #64748b;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.mapa-popup-preco {
    color: #0f67c7;
    font-size: 22px;
    line-height: 1.1;
}

.mapa-popup-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    margin-top: 2px;
    border: 1px solid #d8e4f2;
    border-radius: 12px;
    color: #0f5db8;
    font-weight: 700;
    text-decoration: none;
}

.mapa-popup-link:hover {
    background: #f8fbff;
}

.area-cliente-shell {
    width: min(1180px, calc(100dvw - 32px));
    margin: 24px auto 48px;
    display: grid;
    grid-template-columns: 216px minmax(0, 1fr);
    gap: 20px;
    box-sizing: border-box;
}

.area-cliente-sidebar {
    position: sticky;
    top: 98px;
    align-self: start;
}

.area-cliente-sidebar__card {
    padding: 14px;
    border: 1px solid #dbe6f1;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.055);
}

.area-cliente-sidebar__kicker {
    display: inline-flex;
    margin: 0 0 10px 4px;
    color: #64748b;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.area-cliente-nav {
    display: grid;
    gap: 8px;
}

.area-cliente-nav__link {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 0 11px;
    border: 1px solid transparent;
    border-radius: 13px;
    background: transparent;
    color: #334155;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
}

.area-cliente-nav__link i {
    font-size: 17px;
    color: #0f5db8;
}

.area-cliente-nav__link:hover,
.area-cliente-nav__link--ativo {
    color: #0f172a;
    border-color: #b8d0eb;
    box-shadow: 0 10px 22px rgba(15, 93, 184, 0.08);
    transform: translateY(-1px);
}

.area-cliente-nav__link--ativo {
    background: #eef6ff;
    box-shadow: inset 3px 0 0 #0f67c7, 0 10px 22px rgba(15, 93, 184, 0.08);
}

.area-cliente-main {
    width: 100%;
    min-width: 0;
}

.area-cliente-shell .card {
    margin: 0;
}

.area-cliente-hero {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px;
    border: 1px solid #dbe6f1;
    border-radius: 20px;
    background: linear-gradient(135deg, #ffffff 0%, #f7fbff 100%);
    color: #0f172a;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.055);
}

.area-cliente-hero__copy {
    max-width: 560px;
}

.area-cliente-hero__kicker {
    display: inline-flex;
    margin-bottom: 8px;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.area-cliente-hero h1 {
    margin: 0;
    color: #0f172a;
    font-size: clamp(28px, 3vw, 34px);
    line-height: 1.12;
}

.area-cliente-hero p {
    margin: 10px 0 0;
    color: #475569;
    font-size: 15px;
    line-height: 1.6;
}

.area-cliente-highlight,
.area-cliente-profile-card {
    min-width: 240px;
    max-width: 300px;
    padding: 16px 18px;
    border: 1px solid #dbe6f1;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.045);
}

.area-cliente-highlight__label {
    display: inline-flex;
    margin-bottom: 8px;
    color: #64748b;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.area-cliente-highlight strong,
.area-cliente-profile-card strong {
    display: block;
    color: #0f172a;
    font-size: 18px;
    line-height: 1.25;
}

.area-cliente-highlight p,
.area-cliente-profile-card p {
    margin: 8px 0 0;
    color: #475569;
    font-size: 13px;
    line-height: 1.55;
}

.area-cliente-profile-card {
    display: flex;
    align-items: center;
    gap: 14px;
}

.area-cliente-profile-card__avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #0f67c7 0%, #1f7be0 100%);
    color: #ffffff;
    font-size: 18px;
    font-weight: 800;
}

.area-cliente-badge {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: #eaf3ff;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.area-cliente-badge--premium {
    background: rgba(255, 191, 47, 0.16);
    color: #8a5300;
}

.area-cliente-stats {
    margin-top: 16px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.area-cliente-stat {
    padding: 16px 18px;
    border-radius: 16px;
    border: 1px solid #dbe6f1;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.area-cliente-stat span {
    display: block;
    color: #64748b;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.area-cliente-stat strong {
    display: block;
    margin-top: 8px;
    color: #0f172a;
    font-size: 18px;
    line-height: 1.3;
}

.area-cliente-grid {
    margin-top: 18px;
    display: grid;
    gap: 18px;
}

.area-cliente-grid--perfil,
.area-cliente-grid--plano {
    grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr);
}

.area-cliente-grid--favoritos {
    grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
}

.area-cliente-grid--pesquisas {
    grid-template-columns: 1fr;
}

.area-cliente-grid--pesquisas .area-cliente-card-list {
    width: 100%;
    grid-template-columns: minmax(0, 1fr);
    justify-items: stretch;
}

.area-cliente-grid--pesquisas .area-cliente-card {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}

.area-cliente-grid--favoritos-full {
    grid-template-columns: 1fr;
}

.area-cliente-grid--favoritos-full .area-cliente-card {
    min-width: 0;
}

.area-cliente-stack,
.area-cliente-card-list {
    display: grid;
    gap: 16px;
    align-content: start;
}

.area-cliente-card {
    padding: 22px;
    border: 1px solid #dbe6f1;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.045);
}

.area-cliente-card--compact {
    padding: 18px 20px;
}

.area-cliente-card--cta {
    border-color: #f3d28a;
    background: linear-gradient(180deg, #fff8e6 0%, #ffffff 100%);
}

.area-cliente-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid #edf2f7;
}

.area-cliente-card__eyebrow {
    display: inline-flex;
    margin-bottom: 8px;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.area-cliente-card h2 {
    margin: 0;
    color: #0f172a;
    font-size: 22px;
    line-height: 1.2;
}

.area-cliente-card p {
    margin: 0;
    color: #475569;
    font-size: 14px;
    line-height: 1.65;
}

.area-cliente-billing-actions {
    display: grid;
    gap: 10px;
    margin: 16px 0 12px;
}

.area-cliente-billing-actions form {
    margin: 0;
}

.area-cliente-billing-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    width: 100%;
    min-height: 46px;
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 0 14px;
    font-size: 13px;
    line-height: 1.2;
    text-align: center;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.area-cliente-billing-btn i {
    flex: 0 0 auto;
    font-size: 16px;
    line-height: 1;
}

.area-cliente-billing-btn span {
    min-width: 0;
}

.area-cliente-billing-btn:hover {
    transform: translateY(-1px);
}

.area-cliente-billing-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 4px rgba(15, 93, 184, 0.14);
}

.area-cliente-billing-btn--primary {
    background: linear-gradient(180deg, #0f67c7 0%, #0b56a8 100%);
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(15, 93, 184, 0.22);
}

.area-cliente-billing-btn--primary:hover {
    background: linear-gradient(180deg, #1473dc 0%, #0a4f9b 100%);
    color: #ffffff;
    box-shadow: 0 14px 28px rgba(15, 93, 184, 0.28);
}

.area-cliente-billing-btn--secondary {
    border-color: #cfe0f2;
    background: #f8fbff;
    color: #0f5db8;
}

.area-cliente-billing-btn--secondary:hover {
    border-color: #9fc3ee;
    background: #eef6ff;
    color: #0b4b96;
    box-shadow: 0 10px 20px rgba(15, 93, 184, 0.1);
}

.area-cliente-form {
    display: grid;
    gap: 14px;
}

.area-cliente-form--duas-colunas {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.area-cliente-form--inline {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    margin-bottom: 18px;
}

.area-cliente-field {
    display: grid;
    gap: 6px;
}

.area-cliente-field span {
    color: #0f172a;
    font-size: 13px;
    font-weight: 700;
}

.area-cliente-field input,
.area-cliente-field textarea {
    width: 100%;
    min-height: 44px;
    padding: 11px 14px;
    border: 1px solid #d7e2ee;
    border-radius: 12px;
    background: #fbfdff;
    color: #0f172a;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.area-cliente-field textarea {
    min-height: 120px;
    resize: vertical;
}

.area-cliente-field input:focus,
.area-cliente-field textarea:focus {
    outline: none;
    border-color: #8fb9ea;
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(15, 93, 184, 0.08);
}

.area-cliente-field input[disabled] {
    color: #64748b;
    background: #f5f8fb;
}

.area-cliente-field small {
    color: #64748b;
    font-size: 12px;
    line-height: 1.5;
}

.area-cliente-field--full {
    grid-column: 1 / -1;
}

.area-cliente-field--grow {
    min-width: 0;
}

.area-cliente-form__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.area-cliente-subsecao {
    display: grid;
    gap: 16px;
    padding: 18px;
    border: 1px solid #dbe6f1;
    border-radius: 18px;
    background: #f8fbff;
}

.area-cliente-subsecao__head {
    display: grid;
    gap: 8px;
}

.area-cliente-subsecao__head h3 {
    margin: 0;
    color: #0f172a;
    font-size: 20px;
    line-height: 1.2;
}

.area-cliente-subsecao__head p {
    color: #475569;
}

.area-cliente-branding-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.area-cliente-color-field {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr);
    gap: 10px;
}

.area-cliente-color-field input[type="color"] {
    width: 56px;
    min-width: 56px;
    min-height: 44px;
    padding: 4px;
    border-radius: 14px;
    cursor: pointer;
}

.area-cliente-branding-uploader {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 260px;
    gap: 18px;
    align-items: start;
}

.area-cliente-branding-preview {
    display: grid;
    gap: 10px;
}

.area-cliente-branding-preview__card {
    position: relative;
    min-height: 288px;
    padding: 16px;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid #dbe6f1;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.area-cliente-branding-preview__stripe {
    position: absolute;
    inset: 0 0 auto;
    height: 8px;
    background: var(--branding-primaria, #0f67c7);
}

.area-cliente-branding-preview__image {
    height: 126px;
    margin-top: 18px;
    border-radius: 14px;
    background: linear-gradient(135deg, #dbe7f5 0%, #b9cce2 100%);
}

.area-cliente-branding-preview__content {
    display: grid;
    gap: 6px;
    margin-top: 16px;
    padding-right: 72px;
    color: var(--branding-texto, #1f2937);
}

.area-cliente-branding-preview__content small {
    color: var(--branding-primaria, #0f67c7);
    font-size: 11px;
    font-weight: 700;
}

.area-cliente-branding-preview__content strong {
    font-size: 24px;
    line-height: 1.1;
}

.area-cliente-branding-preview__content span {
    font-size: 12px;
    line-height: 1.5;
}

.area-cliente-branding-preview__logo {
    position: absolute;
    right: 14px;
    bottom: 14px;
    width: 58px;
    height: 58px;
    border-radius: 14px;
    border: 1px solid rgba(15, 103, 199, 0.18);
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.area-cliente-branding-preview__logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.area-cliente-branding-preview__logo span {
    padding: 0 8px;
    text-align: center;
    color: var(--branding-primaria, #0f67c7);
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
}

.area-cliente-checkbox--compact {
    font-size: 13px;
}

.area-cliente-aviso-topo {
    margin-bottom: 18px !important;
}

.area-cliente-empty-state {
    display: grid;
    gap: 14px;
    justify-items: start;
    padding: 20px;
    border: 1px dashed #bdd3ea;
    border-radius: 16px;
    background: #f8fbff;
}

.area-cliente-empty-state p {
    color: #475569;
}

.area-cliente-empty-state i,
.area-cliente-card--empty > i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: #eaf3ff;
    color: #0f5db8;
    font-size: 20px;
}

.area-cliente-lista,
.area-cliente-feature-list {
    display: grid;
    gap: 10px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.area-cliente-lista li,
.area-cliente-feature-list li {
    color: #334155;
    font-size: 14px;
    line-height: 1.65;
}

.area-cliente-feature-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.area-cliente-feature-list i {
    margin-top: 2px;
    color: #0f5db8;
    font-size: 16px;
}

.area-cliente-links-rapidos {
    display: grid;
    gap: 8px;
}

.area-cliente-links-rapidos a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0 13px;
    border: 1px solid #dbe6f1;
    border-radius: 12px;
    color: #0f5db8;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    background: #f8fbff;
}

.area-cliente-links-rapidos a:hover {
    border-color: #a6c8ee;
    background: #eef6ff;
}

.area-cliente-table-wrap {
    margin-top: 0;
    max-width: 100%;
    overflow-x: auto;
    border: 1px solid #edf2f7;
    border-radius: 16px;
}

.area-cliente-table {
    min-width: 760px;
    margin: 0;
}

.area-cliente-table thead th {
    background: #f8fbff;
    color: #64748b;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.area-cliente-table tbody td {
    vertical-align: middle;
    white-space: normal;
    word-break: break-word;
}

.area-cliente-table tbody tr:hover td {
    background: #fbfdff;
}

.area-cliente-table--relatorios thead th,
.area-cliente-table--relatorios tbody td {
    font-size: 14px;
}

.area-cliente-table--favoritos thead th,
.area-cliente-table--favoritos tbody td {
    font-size: 14px;
}

.area-cliente-favorito-numero,
.area-cliente-favorito-titulo {
    font-size: 15px;
    line-height: 1.2;
}

.area-cliente-relatorio-titulo {
    display: inline-block;
    font-size: 16px;
    line-height: 1.1;
}

.area-cliente-relatorio-numero {
    font-size: 12px;
}

.area-cliente-table form {
    margin: 0;
}

.area-cliente-table-alerta-form .area-cliente-checkbox {
    margin: 0;
}

.area-cliente-table-acoes {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.area-cliente-acao-icone {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 1px solid #dbe6f1;
    border-radius: 11px;
    padding: 0;
    background: #ffffff;
    color: #0f5db8;
    text-decoration: none;
    cursor: pointer;
}

.area-cliente-acao-icone i {
    font-size: 16px;
}

.area-cliente-acao-icone:hover {
    color: #0b4b96;
    border-color: #a6c8ee;
    background: #eef6ff;
}

.area-cliente-acao-icone--danger {
    color: #0f5db8;
}

.area-cliente-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 0 0 14px;
}

.area-cliente-meta-grid span {
    display: block;
    color: #64748b;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.area-cliente-meta-grid strong {
    display: block;
    margin-top: 4px;
    color: #0f172a;
    font-size: 14px;
}

.area-cliente-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-bottom: 14px;
}

.area-cliente-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: #f4f8fc;
    color: #334155;
    font-size: 12px;
    font-weight: 700;
}

.area-cliente-card--empty {
    text-align: center;
}

.area-cliente-card--empty p {
    max-width: 560px;
    margin: 0 auto;
}

.area-cliente-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #334155;
    font-weight: 600;
}

.area-cliente-checkbox input {
    width: 18px;
    height: 18px;
}

.resultado-contador {
    font-weight: 700;
    color: var(--cor-texto);
}

.resultado-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 14px;
    margin-bottom: 8px;
    padding: 14px 16px;
    border: 1px solid #dbe6f1;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.045);
}

.resultado-principal {
    display: grid;
    gap: 4px;
}

.resultado-meta {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.resultado-faixa {
    color: #64748b;
    font-size: 14px;
}

.resultado-por-pagina {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #64748b;
    font-size: 13px;
    font-weight: 700;
}

.resultado-por-pagina select {
    min-height: 42px;
    border: 1px solid #d8e3ef;
    border-radius: 12px;
    background: #fff;
    padding: 0 14px;
}

.busca-empty-state {
    grid-column: 1 / -1;
    display: grid;
    justify-items: center;
    gap: 12px;
    margin: 0;
    padding: 42px 24px;
    border: 1px dashed #bdd3ea;
    border-radius: 18px;
    background: #f8fbff;
    text-align: center;
}

.busca-empty-state i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: #eaf3ff;
    color: #0f5db8;
    font-size: 24px;
}

.busca-empty-state h2 {
    margin: 0;
    color: #0f172a;
    font-size: 24px;
}

.busca-empty-state p {
    max-width: 560px;
    margin: 0;
    color: #475569;
    line-height: 1.65;
}

.paginacao {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
    margin-bottom: 8px;
}

.paginacao-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
    padding: 0 16px;
    border: 1px solid #d8e4f2;
    border-radius: 14px;
    background: #ffffff;
    color: #0f5db8;
    font-weight: 700;
    font-size: 15px;
    line-height: 1;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.paginacao-link:hover,
.paginacao-link:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(15, 93, 184, 0.28);
    box-shadow: 0 14px 28px rgba(15, 93, 184, 0.12);
    outline: none;
}

.paginacao-link.ativa {
    border-color: #0f5db8;
    background: #0f5db8;
    color: #ffffff;
    box-shadow: 0 14px 28px rgba(15, 93, 184, 0.2);
}

.paginacao-link.desabilitado {
    color: #94a3b8;
    background: #f8fafc;
    border-color: #e2e8f0;
    box-shadow: none;
    pointer-events: none;
}

.imovel-card h3 {
    margin-top: 0;
    margin-bottom: 8px;
}

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

.link-destaques {
    color: #1b6fae;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
}

.secao-funcionalidades {
    background: linear-gradient(180deg, #f8fbff 0%, #eef4ff 100%);
    border: 1px solid #d8e4f8;
    border-radius: var(--radius-lg);
    padding: clamp(22px, 2.8vw, 34px);
}

.funcionalidades-topo {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
    text-align: center;
}

.funcionalidades-kicker {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    color: #0f3b72;
    background: #dbe9ff;
    margin-bottom: 10px;
}

.funcionalidades-topo h2 {
    margin: 6px 0 10px;
}

.funcionalidades-topo p {
    margin: 0;
    line-height: 1.8;
}

.funcionalidades-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.funcionalidade-card {
    margin: 0;
    background: #fff;
    border: 1px solid #dce6f5;
    border-radius: 16px;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
}

.funcionalidade-icone {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    color: #0f67c7;
    background: #e9f2ff;
    margin-bottom: 8px;
}

.funcionalidade-card h3 {
    margin: 0 0 8px;
    font-size: 19px;
}

.funcionalidade-card p {
    margin: 0;
    color: var(--cor-texto-sec);
    line-height: 1.75;
}

.funcionalidades-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
    justify-content: center;
}

.secao-cidades-rj-seo {
    text-align: center;
}

.seo-cidades-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}

.seo-cidades-links .badge {
    text-decoration: none;
}

.secao-cidades-estados-seo {
    text-align: center;
}

.seo-estados-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    margin: 14px 0 18px;
}

.seo-estado-tab {
    border: 1px solid #cfdff3;
    background: #f4f8ff;
    color: #123054;
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: all .2s ease;
}

.seo-estado-tab:hover {
    background: #e8f1ff;
}

.seo-estado-tab.ativo {
    background: #0f67c7;
    border-color: #0f67c7;
    color: #fff;
}

.seo-cidades-painel {
    margin-top: 4px;
}

.seo-cidades-painel .seo-cidades-links {
    margin-bottom: 14px;
}

.seo-ver-uf {
    display: inline-flex;
}

.seo-landing-wrap {
    max-width: 1180px;
}

.seo-landing-wrap .secao {
    margin: 38px 0;
}

.seo-landing-wrap .card {
    border: 1px solid #dce6f5;
    border-radius: 16px;
}

.seo-hero-card {
    background: linear-gradient(135deg, #ffffff, #f4f8ff);
    max-width: 920px;
    margin: 0 auto;
}

.seo-hero-main {
    text-align: center;
}

.seo-hero-main > p {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}

.seo-hero-main .seo-badges {
    justify-content: center;
}

.seo-hero-main .seo-cta-linha {
    justify-content: center;
}

.seo-landing-wrap .secao h2 {
    font-size: clamp(30px, 3.2vw, 46px);
}

.seo-cta-linha {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.seo-cta-linha .btn {
    min-width: 220px;
    text-align: center;
}

.seo-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.seo-badges .badge {
    text-decoration: none;
}

.seo-cidade-panorama {
    text-align: center;
}

.seo-cidade-panorama p {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.seo-cidade-panorama .seo-cta-linha {
    justify-content: center;
}

.seo-uf-panorama {
    text-align: center;
}

.seo-uf-panorama p {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.seo-uf-panorama .seo-cta-linha {
    justify-content: center;
}

.seo-bairro-panorama {
    text-align: center;
}

.seo-bairro-panorama p {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.seo-bairro-panorama .seo-cta-linha {
    justify-content: center;
}

.seo-landing-wrap .secao-faq {
    max-width: 900px;
}

.seo-landing-wrap .secao-faq .faq-lista {
    text-align: center;
}

.seo-landing-wrap .secao-faq .faq-lista summary {
    text-align: center;
    padding-left: 42px;
    padding-right: 42px;
}

.seo-landing-wrap .secao-faq .faq-lista p {
    text-align: center;
}

.seo-cards-icones .card {
    position: relative;
    padding-top: 58px;
}

.seo-card-icone {
    position: absolute;
    top: 14px;
    left: 18px;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: #e9f2ff;
    color: #0f67c7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.seo-etapas-grid .card {
    border-style: dashed;
}

.seo-etapa-card {
    position: relative;
    padding-top: 56px;
}

.seo-etapa-numero {
    position: absolute;
    top: 14px;
    left: 18px;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    background: #0f67c7;
    color: #fff;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.seo-premium-page {
    background: #f5f8fc;
}

/* A Ferramenta: fundo contínuo (hero azul continua à parte; resto em uma mesma “lona”) */
.quem-premium-page {
    background:
        linear-gradient(180deg, #eaf0f8 0%, #f4f7fb 18%, #f5f8fc 45%, #f1f5fa 100%);
}

.text-nowrap {
    white-space: nowrap;
}

.seo-premium-page > .container.secao,
.quem-premium-page > .container.secao {
    margin-left: auto;
    margin-right: auto;
}

.seo-premium-hero,
.quem-premium-hero {
    padding: clamp(48px, 6vw, 82px) 0 clamp(70px, 8vw, 110px);
    color: #ffffff;
    background:
        radial-gradient(circle at top right, rgba(245, 164, 0, 0.22), transparent 30%),
        linear-gradient(135deg, #0b2542 0%, #0f3f78 54%, #0f67c7 100%);
}

.planos-premium-hero,
.quem-premium-hero {
    padding-bottom: clamp(70px, 8vw, 110px);
}

.seo-premium-hero__grid,
.quem-premium-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: clamp(24px, 4vw, 54px);
    align-items: center;
}

.seo-premium-hero__copy,
.quem-premium-hero__copy {
    display: grid;
    gap: 14px;
}

.seo-premium-hero .home-eyebrow,
.quem-premium-hero .home-eyebrow {
    width: fit-content;
    background: rgba(255, 255, 255, 0.14);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.seo-premium-hero h1,
.quem-premium-hero h1 {
    max-width: 820px;
    margin: 0;
    font-size: clamp(38px, 5.5vw, 64px);
    line-height: 1.02;
    color: #ffffff;
    text-align: left;
}

.seo-premium-hero p,
.quem-premium-hero p {
    max-width: 720px;
    margin: 0;
    color: rgba(255, 255, 255, 0.86);
    font-size: 17px;
    line-height: 1.7;
}

.seo-premium-hero__actions,
.quem-premium-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}

.seo-premium-search,
.quem-premium-hero__panel {
    display: grid;
    gap: 13px;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.96);
    color: #0f172a;
    box-shadow: 0 24px 54px rgba(15, 23, 42, 0.22);
}

.seo-premium-search__label,
.quem-premium-hero__panel > span {
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.seo-premium-search label {
    display: grid;
    gap: 6px;
}

.seo-premium-search label span {
    color: #41516a;
    font-size: 12px;
    font-weight: 900;
}

.seo-premium-search input,
.seo-premium-search select {
    width: 100%;
    min-height: 48px;
    padding: 0 13px;
    border: 1px solid #cfe0f5;
    border-radius: 12px;
    background: #ffffff;
    color: #10233f;
    font-size: 15px;
}

.seo-premium-search .btn {
    min-height: 48px;
}

.seo-premium-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: -44px;
    position: relative;
    z-index: 2;
}

.seo-premium-metric {
    padding: 22px;
    border: 1px solid #dbe7f6;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
}

.seo-premium-metric span {
    display: block;
    margin-bottom: 8px;
    color: #64748b;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.seo-premium-metric strong {
    display: block;
    color: #0f67c7;
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.08;
}

.seo-premium-metric p {
    margin: 6px 0 0;
    color: #53657c;
}

.seo-premium-section {
    padding: clamp(22px, 3vw, 34px);
    border: 1px solid #dce7f4;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.05);
}

.seo-premium-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.seo-premium-steps article,
.seo-premium-state-card,
.seo-premium-city-card,
.quem-premium-timeline article {
    padding: 20px;
    border: 1px solid #dbe7f6;
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.seo-premium-steps article span,
.quem-premium-timeline article span {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    border-radius: 999px;
    background: #0f67c7;
    color: #ffffff;
    font-weight: 900;
}

.seo-premium-steps h3,
.quem-premium-timeline h3 {
    margin: 0 0 8px;
    font-size: 20px;
}

.seo-premium-steps p,
.quem-premium-timeline p {
    margin: 0;
    color: #5b6c81;
    line-height: 1.65;
}

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

.seo-premium-state-card,
.seo-premium-city-card {
    display: grid;
    gap: 5px;
    color: #0f172a;
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.seo-premium-state-card:hover,
.seo-premium-city-card:hover {
    transform: translateY(-2px);
    border-color: #b8d2ef;
    box-shadow: 0 16px 32px rgba(15, 93, 184, 0.1);
}

.seo-premium-state-card span {
    color: #0f5db8;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.12em;
}

.seo-premium-state-card strong {
    color: #0f172a;
    font-size: 30px;
    line-height: 1;
}

.seo-premium-state-card small,
.seo-premium-city-card span {
    color: #64748b;
    font-size: 13px;
    font-weight: 700;
}

.seo-premium-city-card strong {
    color: #0f172a;
    font-size: 16px;
    line-height: 1.3;
}

.seo-premium-faq {
    background: #ffffff;
    border: 1px solid #dce7f4;
    border-radius: 20px;
    padding: clamp(24px, 3vw, 36px);
}

.seo-premium-page .seo-premium-faq,
.home-fullbleed ~ .secao-faq,
.quem-premium-page ~ .secao-faq {
    max-width: min(1120px, 94%);
}

.seo-premium-faq .faq-lista,
.home-fullbleed ~ .secao-faq .faq-lista {
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.quem-premium-hero__panel strong {
    color: #0f172a;
    font-size: clamp(26px, 2.6vw, 36px);
    line-height: 1.08;
}

.quem-premium-hero__panel p {
    color: #52647b;
}

.quem-premium-hero__checklist {
    display: grid;
    gap: 9px;
    margin-top: 4px;
}

.quem-premium-hero__checklist span {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    color: #334155;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.45;
}

.quem-premium-hero__checklist i {
    color: #0f67c7;
    font-size: 17px;
    line-height: 1.2;
}

.quem-premium-story:not(.home-confianca),
.quem-premium-team,
.quem-premium-how:not(.secao-funcionalidades) {
    padding: clamp(22px, 3vw, 34px);
    border: 1px solid #dce7f4;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.05);
}

.planos-premium-hero-dock,
.quem-premium-hero-dock {
    width: 100%;
    margin: -58px 0 42px;
    padding: 0 16px;
    position: relative;
    z-index: 4;
}

/* A Ferramenta: pipeline e bloco «do edital» acopladas ao hero; “Como funciona” em fluxo normal */
.quem-premium-page > .quem-premium-hero + .home-dados-pipeline {
    margin-top: clamp(-52px, -6.5vw, -36px);
    margin-bottom: 0;
    position: relative;
    z-index: 2;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom: none;
    box-shadow: none;
}

/* Um único painel: pipeline + «Como trabalhamos os dados» — evita faixa, sombra e borda duplicada entre eles */
.quem-premium-page > .home-dados-pipeline + .home-dados-inteligencia:not(.home-dados-pipeline) {
    margin-top: 0;
    border-top: none;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.quem-premium-page > .quem-premium-hero + .home-dados-inteligencia:not(.home-dados-pipeline) {
    margin-top: clamp(-40px, -5vw, -24px);
    margin-bottom: clamp(32px, 5vw, 48px);
    position: relative;
    z-index: 2;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.quem-premium-page > .home-dados-inteligencia:not(.home-dados-pipeline) + .quem-premium-hero-dock {
    margin-top: 0;
}

/* Blocos “full bleed”: pipeline solto no fundo; demais conteúdos em cartões estilo index */
.quem-premium-page .home-dados-inteligencia.home-dados-pipeline {
    border: none;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
}

.quem-premium-page > .home-dados-inteligencia:not(.home-dados-pipeline) {
    padding-top: clamp(24px, 3.5vw, 40px);
    padding-bottom: clamp(24px, 3.5vw, 40px);
    background: transparent;
    border: none;
    box-shadow: none;
}

.quem-premium-page > .home-dados-pipeline + .home-dados-inteligencia:not(.home-dados-pipeline) {
    padding-top: clamp(12px, 2vw, 24px);
}

.quem-premium-dados-card .home-section-head {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.quem-premium-dados-card .home-dados-grid {
    margin-top: clamp(18px, 2.5vw, 26px);
}

.quem-premium-page section.quem-premium-story:has(> .home-confianca) {
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.quem-premium-page > .container.secao:not(.secao-funcionalidades) {
    padding-top: clamp(32px, 4.5vw, 58px);
    padding-bottom: clamp(32px, 4.5vw, 58px);
}

.quem-premium-page > .container.secao.secao-funcionalidades {
    margin-top: clamp(24px, 3.5vw, 40px);
    margin-bottom: clamp(24px, 3.5vw, 40px);
}

.quem-premium-page .quem-premium-how.secao-funcionalidades.home-jornada {
    background: linear-gradient(180deg, #f8fbff 0%, #eef4ff 100%);
    border: 1px solid #d8e4f8;
    border-radius: var(--radius-lg);
    padding: clamp(22px, 2.8vw, 34px);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.05);
}

.quem-premium-page .quem-premium-funcionalidades-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 4px;
}

.quem-premium-page .quem-premium-how.secao-funcionalidades .home-confianca-card {
    justify-items: start;
    text-align: left;
}

.quem-premium-page > .home-dados-inteligencia {
    padding-left: 0;
    padding-right: 0;
}

.quem-premium-page > .secao:not(.quem-premium-hero):not(.quem-premium-cta) {
    margin-top: 0;
    margin-bottom: 0;
}

.quem-premium-page .quem-premium-cta {
    background: transparent;
    padding-top: clamp(20px, 3vw, 40px);
    padding-bottom: clamp(36px, 5vw, 64px);
}

.planos-premium-hero-dock .planos-premium-section,
.quem-premium-hero-dock .quem-premium-story:not(.home-confianca) {
    margin-left: auto;
    margin-right: auto;
    box-shadow: 0 24px 58px rgba(15, 23, 42, 0.12);
}

.planos-premium-hero-dock .home-section-head,
.quem-premium-hero-dock .home-section-head {
    color: #0f172a;
}

.planos-premium-hero-dock .home-section-head h2,
.quem-premium-hero-dock .home-section-head h2 {
    color: #0f172a;
}

.planos-premium-hero-dock .home-section-head p,
.quem-premium-hero-dock .home-section-head p {
    color: #53657c;
}

.quem-premium-section-head {
    max-width: 920px;
    text-align: center;
}

.quem-premium-section-head p {
    margin-left: auto;
    margin-right: auto;
}

.quem-premium-how .home-section-head--split {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    text-align: center;
}

.quem-premium-timeline,
.quem-premium-team-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.quem-premium-timeline--four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.quem-premium-plan-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.quem-premium-plan-card {
    padding: clamp(22px, 3vw, 30px);
    border: 1px solid #dbe7f6;
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
}

.quem-premium-plan-card--featured {
    border-color: rgba(15, 103, 199, 0.32);
    background:
        radial-gradient(circle at top right, rgba(15, 103, 199, 0.12), transparent 36%),
        #ffffff;
}

.quem-premium-plan-card > span {
    display: inline-flex;
    margin-bottom: 10px;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.quem-premium-plan-card h3 {
    margin: 0 0 16px;
    font-size: clamp(24px, 2.4vw, 32px);
    line-height: 1.15;
}

.quem-premium-plan-card ul {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.quem-premium-plan-card li {
    color: #334155;
    line-height: 1.55;
}

.quem-premium-plan-card li::before {
    content: "\2713";
    margin-right: 8px;
    color: #0f67c7;
    font-weight: 900;
}

.quem-premium-person {
    overflow: hidden;
    border: 1px solid #dbe7f6;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.quem-premium-person img {
    width: 100%;
    height: 320px;
    display: block;
    object-fit: cover;
    object-position: center top;
}

.quem-premium-person > div {
    padding: 22px;
}

.quem-premium-person span {
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.quem-premium-person h3 {
    margin: 7px 0 10px;
    font-size: 28px;
}

.quem-premium-person p {
    margin: 0 0 14px;
    color: #53657c;
    line-height: 1.7;
}

.quem-premium-person ul {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.quem-premium-person li {
    color: #334155;
    font-size: 14px;
    line-height: 1.5;
}

.quem-premium-person li::before {
    content: "\2713";
    margin-right: 8px;
    color: #0f67c7;
    font-weight: 900;
}

.quem-premium-cta {
    padding: 38px 0;
    background: #ffffff;
}

.quem-premium-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: clamp(24px, 3vw, 34px);
    border-radius: 22px;
    background:
        radial-gradient(circle at top right, rgba(245, 164, 0, 0.2), transparent 34%),
        linear-gradient(135deg, #0b2542, #0f67c7);
    color: #ffffff;
}

.quem-premium-cta__inner .home-eyebrow {
    background: rgba(255, 255, 255, 0.14);
    color: #ffffff;
}

.quem-premium-cta h2 {
    margin: 8px 0;
    color: #ffffff;
    text-align: left;
}

.quem-premium-cta p {
    max-width: 680px;
    margin: 0;
    color: rgba(255, 255, 255, 0.86);
}

.quem-premium-cta__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.planos-premium-page,
.contato-premium-page {
    background: #f5f8fc;
}

.planos-premium-page > .container.secao,
.contato-premium-page > .container.secao {
    margin-left: auto;
    margin-right: auto;
}

.planos-premium-panel,
.contato-premium-panel {
    display: grid;
    gap: 12px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.96);
    color: #0f172a;
    box-shadow: 0 24px 54px rgba(15, 23, 42, 0.22);
}

.planos-premium-panel span,
.contato-premium-panel span {
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.planos-premium-panel strong,
.contato-premium-panel strong {
    font-size: clamp(26px, 2.6vw, 36px);
    line-height: 1.08;
}

.planos-premium-panel p,
.contato-premium-panel p {
    color: #53657c;
}

/* Página obrigado pós-checkout */
body:has(.assinatura-obrigado-shell) > main {
    padding-bottom: 0;
}

.assinatura-obrigado-shell.planos-premium-page {
    background: #f5f8fc;
}

.assinatura-obrigado-conteudo {
    min-height: clamp(620px, 76vh, 820px);
    background:
        linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
    padding: clamp(36px, 5vw, 58px) 0 clamp(44px, 6vw, 72px);
}

.assinatura-obrigado-container {
    width: min(1060px, 94%);
    margin: 0 auto;
}

.assinatura-obrigado-header {
    display: grid;
    gap: 10px;
    max-width: 760px;
    margin-bottom: 22px;
}

.assinatura-obrigado-header .home-eyebrow,
.assinatura-obrigado-section-head .home-eyebrow {
    width: fit-content;
}

.assinatura-obrigado-header h1,
.assinatura-obrigado-section-head h2 {
    margin: 0;
    color: #0f172a;
    line-height: 1.08;
    text-align: left;
}

.assinatura-obrigado-header h1 {
    font-size: clamp(34px, 4.2vw, 52px);
}

.assinatura-obrigado-header p {
    max-width: 620px;
    margin: 0;
    color: #53657c;
    font-size: 17px;
    line-height: 1.6;
}

.assinatura-obrigado-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    padding: clamp(20px, 3vw, 28px);
    border: 1px solid #dce7f4;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.07);
}

.assinatura-obrigado-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 16px;
    font-size: 28px;
}

.assinatura-obrigado-status--success {
    background: #e8f7ef;
    color: #15803d;
}

.assinatura-obrigado-status--warning {
    background: #fff7df;
    color: #b77900;
}

.assinatura-obrigado-status--danger {
    background: #feeceb;
    color: #c2410c;
}

.assinatura-obrigado-resumo {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.assinatura-obrigado-resumo > span {
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.assinatura-obrigado-corpo {
    display: grid;
    gap: 10px;
}

.assinatura-obrigado-corpo > p {
    margin: 0;
    color: #334155;
    font-size: 15px;
    line-height: 1.65;
}

.assinatura-obrigado-lede {
    max-width: 680px;
    font-size: clamp(21px, 2.2vw, 28px) !important;
    line-height: 1.18 !important;
}

.assinatura-obrigado-corpo > p strong,
.assinatura-obrigado-lede strong {
    color: #0f172a;
}

.assinatura-obrigado-corpo .texto-secundario {
    color: #64748b;
    font-size: 15px;
}

.assinatura-obrigado-corpo .texto-secundario strong {
    color: #0f172a;
}

.assinatura-obrigado-acoes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 4px;
}

.assinatura-obrigado-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    min-height: 46px;
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 0 16px;
    font-size: 14px;
    line-height: 1.2;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.assinatura-obrigado-btn:hover {
    transform: translateY(-1px);
}

.assinatura-obrigado-btn--primary {
    background: linear-gradient(180deg, #0f67c7 0%, #0b56a8 100%);
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(15, 93, 184, 0.22);
}

.assinatura-obrigado-btn--primary:hover {
    background: linear-gradient(180deg, #1473dc 0%, #0a4f9b 100%);
    color: #ffffff;
}

.assinatura-obrigado-btn--secondary {
    border-color: #cfe0f2;
    background: #f8fbff;
    color: #0f5db8;
}

.assinatura-obrigado-btn--secondary:hover {
    border-color: #9fc3ee;
    background: #eef6ff;
    color: #0b4b96;
}

.assinatura-obrigado-beneficios {
    margin-top: clamp(22px, 3vw, 32px);
}

.assinatura-obrigado-section-head {
    display: grid;
    gap: 8px;
    margin-bottom: 14px;
}

.assinatura-obrigado-section-head h2 {
    font-size: clamp(24px, 2.6vw, 34px);
}

.assinatura-obrigado-beneficios-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.assinatura-obrigado-beneficio-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    min-height: 106px;
    padding: 16px;
    border: 1px solid #dce7f4;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.045);
}

.assinatura-obrigado-beneficio-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: #eaf3ff;
    color: #0f5db8;
    font-size: 18px;
}

.assinatura-obrigado-beneficio-card p {
    margin: 0;
    color: #334155;
    font-size: 14px;
    line-height: 1.55;
}

@media (max-width: 900px) {
    .assinatura-obrigado-beneficios-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .assinatura-obrigado-card {
        grid-template-columns: 1fr;
    }

    .assinatura-obrigado-acoes {
        flex-direction: column;
        align-items: stretch;
    }

    .assinatura-obrigado-acoes .btn {
        width: 100%;
        justify-content: center;
    }

    .assinatura-obrigado-beneficios-grid {
        grid-template-columns: 1fr;
    }
}

.planos-premium-section,
.contato-premium-layout,
.contato-premium-intents {
    padding: clamp(22px, 3vw, 34px);
    border: 1px solid #dce7f4;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.05);
}

.planos-premium-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.planos-premium-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 26px;
    border: 1px solid #dbe7f6;
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.planos-premium-card--featured {
    border-color: #0f67c7;
    box-shadow: 0 20px 44px rgba(15, 103, 199, 0.14);
}

.planos-premium-card .planos-lista {
    padding: 0;
    list-style: none;
}

.planos-premium-card .planos-lista li {
    display: flex;
    gap: 9px;
    color: #334155;
    line-height: 1.55;
}

.planos-premium-card .planos-lista li::before {
    content: "\2713";
    color: #0f67c7;
    font-weight: 900;
}

.planos-comparativo {
    display: grid;
    gap: 10px;
}

.planos-comparativo div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    min-height: 56px;
    padding: 12px 16px;
    border: 1px solid #dbe7f6;
    border-radius: 14px;
    background: #f8fbff;
}

.planos-comparativo span {
    color: #0f172a;
    font-weight: 800;
}

.planos-comparativo strong {
    color: #0f67c7;
    text-align: right;
}

.planos-nota {
    margin: 16px 0 0;
    color: #64748b;
    line-height: 1.65;
}

.contato-feedback-premium {
    margin-top: -28px;
    position: relative;
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.contato-feedback-premium .alerta {
    width: min(100%, 640px);
    margin-top: 0;
    text-align: center;
    padding: 18px 28px;
    font-size: 1.0625rem;
    line-height: 1.55;
    border-radius: 14px;
    box-shadow: 0 8px 24px rgba(22, 101, 52, 0.08);
}

.contato-premium-intents {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: -44px;
    position: relative;
    z-index: 2;
}

.contato-premium-intents article {
    display: grid;
    gap: 10px;
    padding: 20px;
    border: 1px solid #dbe7f6;
    border-radius: 16px;
    background: #ffffff;
}

.contato-premium-intents h3 {
    margin: 0;
    font-size: 20px;
}

.contato-premium-intents p {
    margin: 0;
    color: #53657c;
    line-height: 1.65;
}

.contato-premium-layout {
    display: grid;
    grid-template-columns: minmax(280px, 0.82fr) minmax(360px, 1.18fr);
    gap: 22px;
    align-items: start;
}

.contato-premium-aside {
    display: grid;
    gap: 16px;
}

.contato-premium-aside h2 {
    margin: 0;
    text-align: left;
    font-size: clamp(28px, 3vw, 40px);
}

.contato-premium-aside p {
    margin: 0;
    color: #53657c;
    line-height: 1.7;
}

.contato-premium-note {
    padding: 16px;
    border: 1px solid #dbe7f6;
    border-radius: 16px;
    background: #f8fbff;
}

.contato-premium-note strong {
    display: block;
    margin-bottom: 6px;
    color: #0f172a;
}

.contato-form-wrap-premium {
    border-radius: 18px;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06);
}

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

.contato-form label small {
    color: #64748b;
    font-size: 12px;
    font-weight: 700;
}

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

    .seo-premium-hero__grid,
    .quem-premium-hero__grid,
    .planos-premium-hero .seo-premium-hero__grid,
    .contato-premium-hero .seo-premium-hero__grid,
    .quem-premium-cta__inner {
        grid-template-columns: 1fr;
        display: grid;
    }

    .seo-premium-metrics,
    .seo-premium-steps,
    .seo-premium-state-grid,
    .seo-premium-city-grid,
    .quem-premium-timeline,
    .quem-premium-team-grid,
    .quem-premium-plan-grid,
    .planos-premium-grid,
    .contato-premium-intents,
    .contato-premium-layout,
    .contato-form-grid {
        grid-template-columns: 1fr;
    }

    .seo-premium-metrics {
        margin-top: -34px;
    }

    .planos-premium-hero-dock,
    .quem-premium-hero-dock {
        margin-top: -44px;
    }

    .quem-premium-page > .home-dados-inteligencia:not(.home-dados-pipeline) + .quem-premium-hero-dock {
        margin-top: 0;
    }

    .quem-premium-person img {
        height: 260px;
    }

    .contato-premium-intents {
        margin-top: -34px;
    }
}

.destaque-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
    border: 1px solid #dde7f2;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.destaque-card:hover {
    transform: translateY(-3px);
    border-color: #bdd5ee;
    box-shadow: 0 18px 38px rgba(15, 93, 184, 0.12);
}

.destaque-thumb-wrap {
    position: relative;
    margin: 0;
    flex-shrink: 0;
}

.destaque-thumb {
    width: 100%;
    height: 214px;
    object-fit: cover;
    display: block;
    border-radius: 18px 18px 0 0;
}

.destaque-thumb-placeholder {
    height: 214px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    background: linear-gradient(135deg, #eef4fb, #dbe8f7);
    color: #0f5db8;
    font-weight: 800;
}

.destaque-thumb-placeholder i {
    font-size: 32px;
}

.desconto-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: #0f8f63;
    color: #fff;
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.18);
}

.destaque-conteudo {
    padding: 18px;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
}

.destaque-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.destaque-tipo {
    font-size: 12px;
    letter-spacing: 0.04em;
    color: #5b6778;
    text-transform: uppercase;
    margin: 0;
}

.destaque-preco-chip {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 9px;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    white-space: nowrap;
}

.destaque-card h3 {
    margin: 0 0 12px;
    font-size: 19px;
    line-height: 1.35;
    text-transform: uppercase;
}

.destaque-localizacao {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    margin: 0 0 16px;
    color: #48627e;
    font-size: 14px;
    text-transform: uppercase;
}

.destaque-localizacao i {
    margin-top: 2px;
    color: #0f67c7;
    font-size: 13px;
    flex-shrink: 0;
}

.destaque-atributos {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.destaque-atributo {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 60px;
    padding: 10px 12px;
    border: 1px solid #dbe5f0;
    border-radius: 14px;
    background: #f8fbff;
}

.destaque-atributos-compactos .destaque-atributo {
    min-height: 50px;
    padding: 8px 10px;
}

.destaque-atributo-vazio {
    opacity: 0.88;
}

.destaque-icone {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(15, 93, 184, 0.12);
    color: #0f67c7;
    font-size: 13px;
    font-weight: 800;
    flex-shrink: 0;
}

.destaque-icone .bi {
    font-size: 12px;
    line-height: 1;
}

.destaque-atributo-label {
    display: block;
    margin-bottom: 4px;
    color: #6b7280;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.destaque-avaliacao {
    margin: 0;
    padding-top: 16px;
    border-top: 1px solid #e5e7eb;
    color: #374151;
}

.destaque-avaliacao span {
    color: #6b7280;
    text-decoration: line-through;
}

.destaque-preco-bloco {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.destaque-avaliacao-inline {
    color: #374151;
    font-size: 13px;
    line-height: 1.2;
}

.destaque-avaliacao-inline span {
    color: #6b7280;
    text-decoration: line-through;
}

.destaque-avaliacao-topo {
    margin: 0 0 12px;
    padding-top: 10px;
    border-top: 1px solid #e5e7eb;
}

.destaque-avaliacao-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin: 4px 0 14px;
    padding: 10px 12px;
    border: 1px solid #e1ebf6;
    border-radius: 13px;
    background: #fbfdff;
}

.destaque-avaliacao-box span {
    color: #64748b;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.destaque-avaliacao-box strong {
    color: #334155;
    font-size: 14px;
    line-height: 1.15;
    white-space: nowrap;
}

.destaque-leiloes {
    margin: 4px 0 14px;
}

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

.destaque-leilao {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 10px;
    border: 1px solid #e1ebf6;
    border-radius: 14px;
    background: #fbfdff;
}

.destaque-leilao + .destaque-leilao {
    border-left: 1px solid #e1ebf6;
}

.destaque-leilao-titulo {
    color: #8a93a3;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.destaque-leilao-valor {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #0f67c7;
    font-size: 15px;
    font-weight: 700;
}

.destaque-leilao-valor .bi,
.destaque-leilao-meta .bi {
    color: #3b82f6;
}

.destaque-leilao-valor strong {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    font-weight: 700;
    line-height: 1.15;
}

.destaque-leilao-cifrao {
    font-size: 0.92em;
    font-weight: 700;
}

.destaque-leilao-meta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 12px;
    border: 1px solid #dbe5f0;
    border-radius: 12px;
    background: #f8fbff;
    color: #4b6787;
    font-weight: 700;
    font-size: 13px;
}

.destaque-leilao.ativo .destaque-leilao-titulo,
.destaque-leilao.ativo .destaque-leilao-valor,
.destaque-leilao.ativo .destaque-leilao-meta {
    color: #0f67c7;
}

.destaque-leilao.ativo {
    border-color: #bdd5ee;
    background: #eef6ff;
}

.destaque-leilao.secundario-suave .destaque-leilao-titulo,
.destaque-leilao.secundario-suave .destaque-leilao-valor,
.destaque-leilao.secundario-suave .destaque-leilao-meta {
    color: #98a3b3;
}

.destaque-leilao.secundario-suave .destaque-leilao-valor .bi,
.destaque-leilao.secundario-suave .destaque-leilao-meta .bi {
    color: #8fb1eb;
}

.destaque-leilao.encerrado .destaque-leilao-valor,
.destaque-leilao.encerrado .destaque-leilao-meta,
.destaque-leilao.encerrado .destaque-leilao-titulo {
    color: #9aa3b2;
}

.destaque-leilao.encerrado .destaque-leilao-valor strong,
.destaque-leilao.encerrado .destaque-leilao-meta span {
    text-decoration: line-through;
}

.destaque-preco-linha {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 16px 0 18px;
}

.destaque-preco-label {
    color: #111827;
    font-weight: 700;
}

.destaque-preco {
    color: #0f67c7;
    font-size: 18px;
    line-height: 1.2;
}

.btn-destaque-detalhes {
    width: 100%;
    text-align: center;
    background: #0f67c7;
    color: #ffffff;
    border: 1px solid #0f67c7;
    margin-top: auto;
}

.btn-destaque-detalhes:hover {
    background: #0b55aa;
    border-color: #0b55aa;
}

.destaque-card-footer {
    display: grid;
    gap: 12px;
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid #edf2f7;
}

.destaque-decisao-preco {
    display: grid;
    gap: 3px;
}

.destaque-decisao-preco span {
    color: #64748b;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.destaque-decisao-preco strong {
    color: #0f67c7;
    font-size: clamp(20px, 2vw, 25px);
    line-height: 1.08;
}

.destaque-decisao-preco small {
    color: #64748b;
    font-size: 12px;
    font-weight: 700;
}

.secao-faq {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.faq-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 20px;
    padding: 0 8px;
    margin-bottom: 10px;
    border-radius: 999px;
    background: #53b6ea;
    color: #0f172a;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.faq-subtitulo {
    margin: 0 0 20px;
    color: #6b7280;
    font-size: 16px;
}

.faq-lista {
    display: grid;
    gap: 8px;
    text-align: left;
}

.faq-lista details {
    background: #f7f7f6;
    border: 1px solid #f0f0ef;
    border-radius: 2px;
    padding: 0;
    overflow: hidden;
}

.faq-lista summary {
    display: block;
    padding: 15px 18px;
    font-weight: 600;
    font-size: 15px;
    color: #353b45;
    cursor: pointer;
    position: relative;
}

.faq-lista summary::after {
    content: "+";
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    color: #7b8794;
    font-size: 18px;
    line-height: 1;
}

.faq-lista details[open] summary::after {
    content: "-";
}

.faq-lista p {
    margin: 0;
    padding: 0 18px 16px;
    color: #6b7280;
    line-height: 1.7;
}

.faq-cta {
    text-align: center;
    margin-top: 18px;
}

.a-leilaum .btn,
.faq-cta .btn,
.secao-cta .btn {
    min-width: 190px;
    text-align: center;
}

.imagens-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.imagem-item {
    margin: 0;
}

.imagem-item img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--cor-borda);
}

.comparativo-m2-card {
    margin-top: 8px;
}

.imovel-auth-gate-principal {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    border-color: #cfe0f4;
    background: #f8fbff;
}

.imovel-auth-gate-principal__copy {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.imovel-auth-gate-principal__copy > i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: #eaf3ff;
    color: #0f5db8;
    font-size: 18px;
}

.imovel-auth-gate-principal__copy span {
    display: block;
    margin-bottom: 4px;
    color: #0f5db8;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.imovel-auth-gate-principal__copy h2 {
    margin: 0;
    color: #0f172a;
    font-size: 22px;
    line-height: 1.2;
}

.imovel-auth-gate-principal__copy p {
    max-width: 760px;
    margin: 8px 0 0;
    color: #475569;
    line-height: 1.55;
}

.imovel-auth-gate-principal__acoes {
    display: flex;
    align-items: center;
    flex: 0 0 auto;
    gap: 12px;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: center;
}

.imovel-auth-gate-principal__acoes .btn {
    min-width: 180px;
    text-align: center;
    white-space: nowrap;
}

.imovel-auth-gate-link,
.imovel-auth-lock-line a {
    color: #0f5db8;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
}

.imovel-auth-gate-link:hover,
.imovel-auth-lock-line a:hover {
    text-decoration: underline;
}

.imovel-auth-lock-line {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    width: fit-content;
    max-width: 100%;
    margin: 14px 0 0;
    padding: 9px 12px;
    border: 1px solid #dbe6f4;
    border-radius: 999px;
    background: #f8fbff;
    color: #475569;
    font-size: 13px;
    line-height: 1.35;
}

.imovel-auth-lock-line i {
    color: #0f5db8;
    font-size: 14px;
}

.imovel-auth-lock-line--plain {
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.imovel-auth-feature-card {
    gap: 14px;
    max-width: 1200px;
    margin: 30px auto 40px;
}

.imovel-auth-feature-card__preview {
    display: grid;
    gap: 4px;
    max-width: 420px;
    padding: 14px;
    border: 1px dashed #cbd9ea;
    border-radius: 14px;
    background: rgba(248, 251, 255, 0.9);
}

.imovel-auth-feature-card__preview span,
.imovel-auth-feature-card__preview small {
    color: #64748b;
    font-size: 12px;
}

.imovel-auth-feature-card__preview strong {
    color: #0f172a;
    font-size: 20px;
    line-height: 1.15;
}

.comparativo-m2-resumo {
    margin-top: 2px;
    color: var(--cor-texto-sec);
}

.comparativo-m2-decisao {
    display: inline-grid;
    gap: 3px;
    margin-bottom: 12px;
    padding: 10px 13px;
    border: 1px solid #dbe6f4;
    border-radius: 12px;
    background: #f8fbff;
}

.comparativo-m2-decisao span {
    color: #64748b;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.comparativo-m2-decisao strong {
    color: #0f172a;
    font-size: 16px;
    line-height: 1.15;
}

.comparativo-m2-decisao-boa {
    border-color: #bfe7d4;
    background: #f0fdf7;
}

.comparativo-m2-decisao-boa strong {
    color: #087447;
}

.comparativo-m2-decisao-alerta {
    border-color: #fed7aa;
    background: #fff7ed;
}

.comparativo-m2-decisao-alerta strong {
    color: #b45309;
}

.comparativo-m2-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 12px;
}

.comparativo-m2-item {
    border: 1px solid var(--cor-borda);
    border-radius: 10px;
    padding: 12px;
    background: #fafcff;
}

.comparativo-m2-label {
    display: block;
    font-size: 13px;
    color: var(--cor-texto-sec);
    margin-bottom: 6px;
}

.comparativo-m2-valor {
    display: block;
    font-size: 20px;
    margin-bottom: 8px;
    color: #0f172a;
}

.comparativo-m2-barra {
    height: 10px;
    width: 100%;
    border-radius: 999px;
    background: #e2e8f0;
    overflow: hidden;
}

.comparativo-m2-barra span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #1d74bf;
}

.comparativo-m2-barra-bairro span {
    background: #f59e0b;
}

.comparativo-m2-nota {
    margin-top: 10px;
    font-size: 13px;
    color: var(--cor-texto-sec);
}

.comparativo-m2-aviso-fallback {
    margin: 0 0 14px;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid #fbbf24;
    background: #fffbeb;
    color: #713f12;
    font-size: 14px;
    line-height: 1.45;
    font-weight: 600;
}

.comparativo-m2-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.comparativo-m2-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border: 1px solid #dbe6f4;
    border-radius: 999px;
    background: #f8fbff;
    color: #334155;
    font-size: 12px;
    font-weight: 800;
}

.imovel-financiamento-card {
    display: grid;
    gap: 20px;
    border-color: #d9e6f5;
    background:
        radial-gradient(circle at top right, rgba(15, 103, 199, 0.08), transparent 30%),
        #ffffff;
}

.imovel-detalhe-principal > .imovel-financiamento-card {
    display: none;
}

.imovel-detalhe-principal > .imovel-financiamento-card.imovel-auth-feature-card {
    display: grid;
}

.imovel-financiamento-fullslot {
    width: 100%;
    margin: -16px 0 40px;
}

.imovel-financiamento-aviso + .imovel-financiamento-fullslot {
    margin-top: 18px;
}

.imovel-financiamento-fullslot .imovel-financiamento-card {
    display: grid;
    width: 100%;
    margin: 0;
}

.imovel-financiamento-aviso {
    display: grid;
    gap: 12px;
    margin: -16px 0 40px;
    border-color: #fed7aa;
    background: #fffaf2;
}

.imovel-financiamento-aviso p {
    margin: 0;
    color: #53657c;
    line-height: 1.65;
}

.imovel-financiamento-aviso-nota {
    color: #9a5b0b !important;
    font-size: 13px;
}

.imovel-financiamento-aviso-btn {
    width: fit-content;
    margin-top: 2px;
}

.imovel-financiamento-aviso--aberto {
    margin-bottom: 0;
}

.imovel-financiamento-intro {
    max-width: 920px;
    margin: -4px 0 0;
    color: #53657c;
    line-height: 1.65;
}

.financiamento-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: 22px;
    align-items: start;
}

.financiamento-form,
.financiamento-resumo {
    display: grid;
    gap: 18px;
}

.financiamento-grupo {
    display: grid;
    gap: 12px;
    padding-bottom: 18px;
    border-bottom: 1px solid #edf2f7;
}

.financiamento-grupo:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.financiamento-grupo h3,
.financiamento-resumo h3,
.financiamento-graficos h3 {
    margin: 0;
    color: #1f2937;
    font-size: 16px;
    font-weight: 900;
}

.financiamento-tipo-opcoes {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.financiamento-tipo-card {
    position: relative;
    display: grid;
    gap: 7px;
    min-height: 104px;
    padding: 18px;
    border: 2px solid #e2e8f0;
    border-radius: 14px;
    background: #ffffff;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.financiamento-tipo-card:has(input:checked) {
    border-color: #6d5bd0;
    background: #f3f0ff;
    box-shadow: 0 10px 24px rgba(109, 91, 208, 0.12);
}

.financiamento-tipo-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.financiamento-tipo-card strong {
    color: #1f2937;
    font-size: 15px;
    text-align: center;
}

.financiamento-tipo-card span {
    color: #53657c;
    font-size: 13px;
    line-height: 1.45;
    text-align: center;
}

.financiamento-range {
    display: grid;
    gap: 8px;
}

.financiamento-range input[type="range"] {
    width: 100%;
    accent-color: #dc2626;
}

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

.financiamento-form label,
.financiamento-check-row label {
    display: grid;
    gap: 6px;
    color: #334155;
    font-size: 13px;
    font-weight: 800;
}

.financiamento-form input[type="number"],
.financiamento-form input[type="text"] {
    width: 100%;
    min-height: 42px;
    padding: 9px 11px;
    border: 1px solid #d9e2ef;
    border-radius: 9px;
    background: #ffffff;
    color: #1f2937;
    font: inherit;
    font-weight: 600;
}

.financiamento-form small,
.financiamento-ajuda {
    margin: 0;
    color: #64748b;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.5;
}

.financiamento-ajuda {
    padding: 12px 14px;
    border-radius: 12px;
    background: #f8fbff;
}

.financiamento-check-row {
    grid-template-columns: minmax(0, 1fr) minmax(160px, 0.36fr);
    align-items: end;
}

.financiamento-check-row label:first-child,
.financiamento-despesas-mensais label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
}

.financiamento-despesas-mensais {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(120px, 0.5fr);
    gap: 10px 12px;
    align-items: center;
    padding: 12px;
    border: 1px dashed #d9e2ef;
    border-radius: 12px;
    background: #fbfdff;
}

.financiamento-resumo {
    position: sticky;
    top: 96px;
    padding: 18px;
    border: 1px solid #dce7f4;
    border-radius: 20px;
    background: #fbfdff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

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

.financiamento-kpis article,
.financiamento-lucro-venda,
.financiamento-comparativo {
    padding: 14px;
    border-radius: 14px;
    background: #f3f6fb;
}

.financiamento-kpis article {
    display: grid;
    gap: 5px;
    min-height: 96px;
}

.financiamento-kpis span,
.financiamento-lucro-venda span,
.financiamento-comparativo span {
    color: #64748b;
    font-size: 12px;
    line-height: 1.35;
}

.financiamento-kpis strong,
.financiamento-lucro-venda strong,
.financiamento-comparativo strong {
    color: #5b45c4;
    font-size: 18px;
    line-height: 1.15;
}

.financiamento-kpis small,
.financiamento-lucro-venda small {
    color: #64748b;
    font-size: 11px;
    line-height: 1.4;
}

.financiamento-kpi-lucro,
.financiamento-lucro-venda {
    background: #e9faf4;
}

.financiamento-kpi-lucro strong,
.financiamento-lucro-venda strong,
.financiamento-resultado strong {
    color: #10a37f;
}

.financiamento-lucro-venda {
    display: grid;
    gap: 5px;
    background: #f1edff;
}

.financiamento-comparativo {
    display: grid;
    gap: 10px;
    background: #f2efff;
}

.financiamento-comparativo h4 {
    margin: 0 0 4px;
    color: #1f2937;
    font-size: 15px;
}

.financiamento-comparativo p {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 0;
}

.financiamento-comparativo hr {
    width: 100%;
    border: 0;
    border-top: 1px solid rgba(91, 69, 196, 0.18);
    margin: 2px 0;
}

.financiamento-graficos {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    padding-top: 8px;
    border-top: 1px solid #edf2f7;
}

.financiamento-graficos > div {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.financiamento-graficos > div:last-child {
    grid-column: 1 / -1;
}

.financiamento-graficos canvas {
    width: 100%;
    height: 220px;
    border: 1px solid #edf2f7;
    border-radius: 14px;
    background: #ffffff;
}

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

    .financiamento-resumo {
        position: static;
    }
}

@media (max-width: 720px) {
    .imovel-auth-gate-principal {
        align-items: stretch;
        flex-direction: column;
    }

    .imovel-auth-gate-principal__copy {
        grid-template-columns: 1fr;
    }

    .imovel-auth-gate-principal__acoes {
        justify-content: flex-start;
    }

    .financiamento-tipo-opcoes,
    .financiamento-form-grid,
    .financiamento-check-row,
    .financiamento-kpis,
    .financiamento-graficos {
        grid-template-columns: 1fr;
    }

    .financiamento-despesas-mensais {
        grid-template-columns: 1fr;
    }

    .financiamento-graficos > div:last-child {
        grid-column: auto;
    }
}

.tabela-admin thead th {
    font-size: 13px;
    color: var(--cor-texto-sec);
}

.admin-planilha-wrap {
    max-height: 420px;
    border: 1px solid var(--cor-borda);
    border-radius: 10px;
    background: #fff;
}

.admin-planilha {
    min-width: 1180px;
}

.admin-planilha thead th {
    background: #f8fafc;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.admin-planilha tbody td {
    font-size: 13px;
    white-space: nowrap;
}

.admin-planilha tbody tr:nth-child(even) {
    background: #fcfdff;
}

.admin-planilha tbody tr:hover {
    background: #f5f9ff;
}

.badge {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 999px;
    background: #e2e8f0;
    color: #334155;
    font-size: 12px;
    font-weight: 700;
}

.badge-ok {
    background: #dcfce7;
    color: #166534;
}

.badge-alerta {
    background: #fee2e2;
    color: #991b1b;
}

.badge-aviso {
    background: #fef3c7;
    color: #92400e;
}

.badge-pago {
    background: #dbeafe;
    color: #1e3a8a;
}

.badge-papel {
    background: #f1f5f9;
    color: #0f172a;
}

.acoes-linha {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 8px;
    min-width: 360px;
}

@media (max-width: 900px) {
    .area-cliente-shell {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .area-cliente-sidebar {
        position: static;
    }

    .area-cliente-sidebar__card {
        overflow-x: auto;
    }

    .area-cliente-sidebar__kicker {
        display: none;
    }

    .area-cliente-nav {
        display: flex;
        gap: 8px;
        min-width: max-content;
    }

    .area-cliente-nav__link {
        white-space: nowrap;
    }

    .area-cliente-hero,
    .area-cliente-stats,
    .area-cliente-grid--perfil,
    .area-cliente-grid--plano,
    .area-cliente-grid--favoritos,
    .area-cliente-grid--favoritos-full,
    .area-cliente-grid--pesquisas,
    .area-cliente-branding-grid,
    .area-cliente-branding-uploader,
    .area-cliente-form--duas-colunas,
    .area-cliente-form--inline {
        grid-template-columns: 1fr;
    }

    .area-cliente-hero {
        flex-direction: column;
    }

    .area-cliente-highlight,
    .area-cliente-profile-card {
        max-width: none;
    }

    .grade-3,
    .grade-2,
    .grade-4,
    .imoveis-grid,
    .imagens-grid {
        grid-template-columns: 1fr;
    }

    .comparativo-m2-grid {
        grid-template-columns: 1fr;
    }

    .filtros-admin {
        grid-template-columns: 1fr;
    }

    .busca-topo,
    .busca-grid-3,
    .busca-grupo .busca-grid-3,
    .busca-grid-localizacao,
    .busca-grid-condicoes,
    .busca-grid-bairro {
        grid-template-columns: 1fr;
    }

    .busca-topo {
        align-items: stretch;
    }

    .busca-topo-texto h2 {
        font-size: 22px;
    }

    .busca-card-wrap {
        width: min(100%, calc(100% - 24px));
    }

    .busca-acoes {
        justify-items: stretch;
    }

    .busca-acoes-texto {
        max-width: none;
        text-align: left;
    }

    .busca-botoes-linha {
        justify-content: flex-start;
    }

    .busca-botoes-linha .btn {
        width: 100%;
        justify-content: center;
    }

    .resultado-toolbar,
    .resultado-meta {
        align-items: flex-start;
        flex-direction: column;
    }

    .resultado-meta,
    .resultado-por-pagina,
    .resultado-por-pagina select,
    .btn-mapa {
        width: 100%;
    }

    .resultado-por-pagina {
        align-items: stretch;
        flex-direction: column;
    }

    .resultado-mapa-wrap {
        width: 100%;
        justify-items: stretch;
    }

    .resultado-mapa-ajuda {
        max-width: none;
        text-align: left;
    }

    .busca-mapa-modal__topo {
        padding: 14px 16px;
        align-items: flex-start;
        flex-direction: column;
    }

    .busca-mapa-modal__titulo-wrap h2 {
        font-size: 24px;
    }

    .busca-mapa-modal__acoes {
        width: 100%;
        justify-content: flex-start;
    }

    .busca-mapa-modal__limpar,
    .busca-mapa-modal__fechar {
        width: 100%;
        justify-content: center;
    }

    .mapa-imoveis {
        height: 420px;
    }

    .mapa-imoveis-modal {
        height: 100%;
    }

    .mapa-desenhar-area-control {
        margin-top: 10px !important;
        margin-right: 10px !important;
    }

    .mapa-desenhar-area-btn {
        min-height: 40px;
        padding: 0 12px;
        font-size: 13px;
    }

    .mapa-uf-control {
        width: min(220px, calc(100vw - 28px));
        max-height: 280px;
        margin-top: 10px !important;
        margin-left: 10px !important;
        padding: 12px;
    }

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

    .mapa-zonas-card {
        top: 132px;
        left: 10px;
        transform: none;
        width: min(300px, calc(100vw - 20px));
    }

    .hero-conteudo {
        padding: 0;
    }

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

    .hero-conteudo.hero-titulo-muito_grande h1,
    .hero-conteudo.hero-titulo-muito_grande h2 {
        font-size: clamp(34px, 9vw, 44px);
    }

    .hero-slide-layout-com-imovel {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .hero-imovel-card {
        max-width: 100%;
        margin: 0;
    }

    .hero-imovel-card__titulo {
        font-size: 22px;
    }

    .secao-intro h1,
    .secao h2 {
        font-size: 32px;
    }

    .secao-intro-destaque {
        padding: 40px 0 42px;
        margin-bottom: 18px;
    }

    .secao-intro-destaque h1 {
        font-size: 38px;
    }

    .secao-intro-destaque p {
        font-size: 15px;
    }

    .cta-ajuda {
        grid-template-columns: 1fr;
        gap: 20px;
        min-height: auto;
        padding: 28px 0 12px;
    }

    .cta-ajuda-texto {
        max-width: none;
        padding-bottom: 0;
    }

    .cta-ajuda-texto h2,
    .cta-ajuda-texto p {
        text-align: center;
    }

    .cta-ajuda-imagem {
        max-height: 320px;
    }

    .cta-servicos {
        grid-template-columns: 1fr;
        padding-bottom: 18px;
    }

    .quem-historia-grid,
    .quem-principios-grid,
    .quem-equipe-grid,
    .quem-diferenciais-grid,
    .planos-grid {
        grid-template-columns: 1fr;
    }

    .quem-hero {
        padding: 40px 0 42px;
    }

    .quem-hero h1 {
        font-size: 38px;
    }

    .planos-hero {
        padding: 40px 0 42px;
    }

    .planos-hero h1 {
        font-size: 38px;
    }

    .quem-historia-texto h2,
    .quem-principios h2,
    .quem-equipe h2,
    .quem-diferenciais h2,
    .quem-cta-faixa h2,
    .planos-cabecalho h2,
    .planos-cta h2 {
        font-size: 30px;
    }

    .planos-cta,
    .planos-card {
        padding-left: 22px;
        padding-right: 22px;
    }

    .quem-cta-botoes {
        flex-direction: column;
        align-items: center;
    }

    .contato-layout {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .contato-info h1 {
        font-size: 28px;
    }

    .contato-info p {
        font-size: 15px;
    }

    .auth-entry-shell {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .auth-entry-aside {
        padding: 6px 0 0;
    }

    .auth-entry-aside h1 {
        font-size: 34px;
    }

    .auth-entry-aside p {
        font-size: 16px;
    }

    .auth-entry-card-wrap {
        justify-content: stretch;
    }

    .card-auth-login {
        max-width: none;
    }

    .auth-login-meta {
        flex-direction: column;
        align-items: flex-start;
    }

    .rodape-grid {
        grid-template-columns: 1fr;
    }

    .topo-conteudo {
        position: relative;
        flex-wrap: wrap;
        gap: 14px;
    }

    .menu-toggle {
        display: inline-flex;
        margin-left: auto;
    }

    .menu {
        display: none;
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
        padding: 14px;
        border: 1px solid #e2e8f0;
        border-radius: 18px;
        background: #ffffff;
        box-shadow: 0 16px 38px rgba(15, 23, 42, 0.08);
    }

    .menu.menu-mobile-open {
        display: flex;
    }

    .menu > a:not(.menu-auth-btn),
    .menu > .menu-dropdown > .btn-link,
    .menu a.menu-auth-btn {
        width: 100%;
        justify-content: flex-start;
        min-height: 48px;
        padding: 0 14px;
    }

    .menu-link-ativo::after {
        left: 14px;
        right: 14px;
        bottom: 8px;
    }

    .menu-dropdown {
        width: 100%;
    }

    .menu-dropdown::after {
        display: none;
    }

    .menu-dropdown-content {
        position: static;
        display: none;
        min-width: 100%;
        margin-top: 8px;
        padding: 8px;
        box-shadow: none;
        border-radius: 14px;
        background: #f8fafc;
    }

    .menu-dropdown.menu-dropdown-mobile-open .menu-dropdown-content {
        display: block;
    }

    .menu-dropdown:hover .menu-dropdown-content,
    .menu-dropdown:focus-within .menu-dropdown-content {
        display: none;
    }

    .admin-shell {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        gap: 10px;
    }

    .admin-menu {
        display: flex;
        gap: 8px;
        overflow: auto;
        padding-bottom: 4px;
    }

    .admin-menu a {
        white-space: nowrap;
    }

    .admin-sidebar-footer {
        margin-top: 0;
    }

    .admin-topbar {
        height: auto;
        padding: 14px 16px;
    }

    .admin-content {
        padding: 14px 16px 20px;
    }

    .destaques-topo {
        align-items: flex-start;
        flex-direction: column;
    }
}

.pagina-legal {
    background: #f5f7fb;
    padding-bottom: 48px;
}

.legal-conteudo {
    padding: 0 0 48px;
}

.legal-wrapper {
    background: #fff;
    border: 1px solid #dce6f2;
    border-radius: 24px;
    box-shadow: 0 18px 42px rgba(15, 39, 75, 0.08);
    max-width: 980px;
    padding: 32px;
}

.legal-atualizacao {
    color: #51627b;
    font-size: 14px;
    margin: 0 0 18px;
}

.legal-bloco + .legal-bloco {
    margin-top: 24px;
}

.legal-bloco h2 {
    color: #0c2a57;
    font-size: 24px;
    margin: 0 0 10px;
}

.legal-bloco p,
.legal-bloco li {
    color: #334155;
    font-size: 16px;
    line-height: 1.75;
}

.legal-bloco p {
    margin: 0 0 12px;
}

.legal-bloco ul {
    margin: 12px 0 0 22px;
    padding: 0;
}

.legal-bloco a {
    color: #135fc9;
    font-weight: 600;
    text-decoration: none;
}

.legal-bloco a:hover {
    text-decoration: underline;
}

.rodape-copy {
    border-top: 1px solid rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.84);
    font-size: 14px;
    margin-top: 28px;
    padding-top: 18px;
    text-align: center;
}

@media (max-width: 768px) {
    .area-cliente-shell {
        width: min(100%, calc(100% - 20px));
        margin: 20px auto 42px;
    }

    .area-cliente-card,
    .area-cliente-sidebar__card {
        padding: 16px;
        border-radius: 16px;
    }

    .area-cliente-hero {
        padding: 20px 18px;
        border-radius: 18px;
    }

    .area-cliente-hero h1 {
        font-size: 28px;
    }

    .area-cliente-card h2 {
        font-size: 22px;
    }

    .card-export-modal {
        padding: 14px;
    }

    .card-export-modal__dialog {
        margin: 0;
        padding: 56px 18px 18px;
        border-radius: 20px;
        max-height: calc(100vh - 28px);
    }

    .card-export-modal__templates {
        grid-template-columns: 1fr;
    }

    .card-export-modal__head,
    .area-cliente-card__head,
    .area-cliente-form__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .area-cliente-meta-grid {
        grid-template-columns: 1fr;
    }

    .legal-wrapper {
        border-radius: 18px;
        padding: 22px 18px;
    }

    .legal-bloco h2 {
        font-size: 21px;
    }
}
