/* ==========================================================================
   ImobiRadar — folha de estilos
   Paleta profissional e limpa (tema escuro)
   ========================================================================== */

:root {
    --fundo: #0F172A;        /* azul escuro - fundo geral */
    --painel: #1E293B;       /* cards e painéis */
    --painel-claro: #273449; /* hover / linhas alternadas */
    --acento: #3B82F6;       /* azul - acento principal */
    --acento-hover: #2563EB;
    --texto: #F1F5F9;        /* texto principal */
    --texto-suave: #94A3B8;  /* texto secundário */
    --sucesso: #10B981;      /* verde */
    --alerta: #F59E0B;       /* amarelo */
    --borda: #334155;
    --raio: 12px;
    --sombra: 0 4px 16px rgba(0, 0, 0, 0.25);
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: "Segoe UI", Roboto, system-ui, -apple-system, sans-serif;
    background: var(--fundo);
    color: var(--texto);
    min-height: 100vh;
    line-height: 1.5;
}

/* --- Cabeçalho ----------------------------------------------------------- */

.cabecalho {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 32px;
    background: var(--painel);
    border-bottom: 1px solid var(--borda);
    flex-wrap: wrap;
    gap: 12px;
}

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

.logo {
    font-size: 32px;
    line-height: 1;
}

.cabecalho h1 {
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -0.5px;
}

.subtitulo {
    font-size: 13px;
    color: var(--texto-suave);
}

/* --- Ações do cabeçalho + seletor de cidade ------------------------------ */

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

.seletor-cidade {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--fundo);
    border: 1px solid var(--borda);
    border-radius: 8px;
    padding: 6px 12px;
}

.seletor-cidade-rotulo { font-size: 13px; color: var(--texto-suave); white-space: nowrap; }

.seletor-cidade select {
    background: transparent;
    border: none;
    color: var(--texto);
    font-size: 14px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    min-width: 150px;
}
.seletor-cidade select:focus { outline: none; }
.seletor-cidade select option { background: var(--painel); color: var(--texto); }

/* --- Botões -------------------------------------------------------------- */

.btn {
    border: none;
    border-radius: 8px;
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, opacity 0.15s, transform 0.05s;
    color: var(--texto);
}

.btn:active { transform: translateY(1px); }

.btn-primario { background: var(--acento); }
.btn-primario:hover { background: var(--acento-hover); }

.btn-secundario { background: var(--sucesso); }
.btn-secundario:hover { opacity: 0.9; }

.btn-neutro { background: var(--painel-claro); color: var(--texto-suave); }
.btn-neutro:hover { color: var(--texto); }

.btn-perigo { background: transparent; color: #f87171; border: 1px solid #f87171; padding: 6px 12px; font-size: 13px; }
.btn-perigo:hover { background: #f87171; color: #fff; }

.btn.carregando { opacity: 0.6; pointer-events: none; }

.btn-mini { padding: 5px 10px; font-size: 12px; }

/* --- Abas ---------------------------------------------------------------- */

.abas {
    display: flex;
    gap: 4px;
    padding: 0 32px;
    background: var(--painel);
    border-bottom: 1px solid var(--borda);
}

.aba {
    background: none;
    border: none;
    color: var(--texto-suave);
    padding: 14px 20px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    border-bottom: 3px solid transparent;
}

.aba:hover { color: var(--texto); }
.aba.ativa { color: var(--acento); border-bottom-color: var(--acento); }

/* --- Conteúdo ------------------------------------------------------------ */

.conteudo { padding: 24px 32px 48px; max-width: 1400px; margin: 0 auto; }

.painel-aba { display: none; }
.painel-aba.ativa { display: block; }

.painel {
    background: var(--painel);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    padding: 22px;
    margin-bottom: 24px;
    box-shadow: var(--sombra);
}

.painel h2 { font-size: 17px; font-weight: 600; margin-bottom: 16px; }

.painel-cabecalho {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.painel-cabecalho h2 { margin-bottom: 0; }

.contador { font-size: 13px; color: var(--texto-suave); }

/* --- Cards de resumo ----------------------------------------------------- */

.cards-resumo {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.card-resumo {
    background: var(--painel);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-shadow: var(--sombra);
}

.card-rotulo { font-size: 13px; color: var(--texto-suave); text-transform: uppercase; letter-spacing: 0.5px; }
.card-valor { font-size: 30px; font-weight: 700; }
.card-valor.azul { color: var(--acento); }
.card-valor.amarelo { color: var(--alerta); }
.card-valor.verde { color: var(--sucesso); }

/* --- Gráficos ------------------------------------------------------------ */

.graficos {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 24px;
}

.grafico-wrapper { position: relative; height: 320px; }

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

/* --- Filtros ------------------------------------------------------------- */

.filtros {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 18px;
}

.filtros select,
.filtros input,
.filtros-globais select,
.filtros-globais input,
.form-fonte input,
.form-fonte textarea {
    background: var(--fundo);
    border: 1px solid var(--borda);
    color: var(--texto);
    padding: 9px 12px;
    border-radius: 8px;
    font-size: 14px;
    min-width: 140px;
    font-family: inherit;
}

.form-fonte textarea { flex: 1; min-width: 260px; resize: vertical; }

.dica { font-size: 13px; color: var(--texto-suave); margin-top: 10px; }

.check-js {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 14px;
    color: var(--texto-suave);
    cursor: pointer;
    white-space: nowrap;
}
.check-js input { width: 16px; height: 16px; accent-color: var(--acento); cursor: pointer; }

.badge-js {
    background: rgba(139, 92, 246, 0.2);
    color: #c4b5fd;
    font-size: 11px;
}

.filtros input { max-width: 130px; }

.filtros select:focus,
.filtros input:focus,
.filtros-globais select:focus,
.filtros-globais input:focus,
.form-fonte input:focus,
.form-fonte textarea:focus {
    outline: none;
    border-color: var(--acento);
}

/* --- Barra de filtros global (topo do dashboard) ------------------------- */

.filtros-globais {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    padding: 16px 18px;
}

.filtros-globais select { min-width: 150px; flex: 1 1 150px; }
.filtros-globais #filtro-fonte { flex: 2 1 220px; min-width: 200px; }
.filtros-globais input { flex: 1 1 110px; min-width: 110px; max-width: 160px; }
.filtros-globais .btn { flex: 0 0 auto; }

/* Força os campos seguintes (faixas de preço e área) para uma nova linha */
.quebra-filtro { flex-basis: 100%; height: 0; margin: 0; }

/* --- Formulário de fonte ------------------------------------------------- */

.form-fonte { display: flex; gap: 10px; flex-wrap: wrap; }
.form-fonte input { flex: 1; min-width: 220px; }

/* --- Tabelas ------------------------------------------------------------- */

.tabela-wrapper { overflow-x: auto; }

.tabela { width: 100%; border-collapse: collapse; font-size: 14px; }

.tabela thead th {
    text-align: left;
    padding: 12px 14px;
    color: var(--texto-suave);
    font-weight: 600;
    border-bottom: 2px solid var(--borda);
    white-space: nowrap;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

/* Cabeçalhos clicáveis (ordenação) */
.tabela thead th.ordenavel { cursor: pointer; user-select: none; }
.tabela thead th.ordenavel:hover { color: var(--texto); }
.tabela thead th.ordenavel.ativo { color: var(--acento); }
.seta-ordem { margin-left: 5px; font-size: 11px; }

.tabela tbody td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--borda);
    vertical-align: middle;
}

.tabela tbody tr:hover { background: var(--painel-claro); }

.tabela .vazio { text-align: center; color: var(--texto-suave); padding: 28px; }

.tabela a { color: var(--acento); text-decoration: none; }
.tabela a:hover { text-decoration: underline; }

.celula-urls { max-width: 460px; }
.celula-urls a { word-break: break-all; font-size: 13px; }

/* --- Avaliação (CMA) ----------------------------------------------------- */

.avaliacao-resultado { margin-top: 22px; }

.avaliacao-valor {
    background: var(--fundo);
    border: 1px solid var(--borda);
    border-left: 4px solid var(--acento);
    border-radius: var(--raio);
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.avaliacao-numero { font-size: 38px; font-weight: 800; color: var(--acento); line-height: 1.1; }
.avaliacao-faixa { color: var(--texto-suave); font-size: 14px; }

.avaliacao-indicadores {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 28px;
    margin: 18px 4px;
}
.avaliacao-indicadores > div { display: flex; flex-direction: column; gap: 3px; }
.avaliacao-indicadores strong { font-size: 18px; color: var(--texto); }
.avaliacao-indicadores .btn { margin-left: auto; }

.avaliacao-subtitulo { font-size: 15px; margin: 8px 0 12px; color: var(--texto); }

/* --- Paginação da tabela ------------------------------------------------- */

.paginacao {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 18px;
}

.paginacao:empty { display: none; }

.btn-pagina {
    background: var(--painel-claro);
    color: var(--texto);
    border: 1px solid var(--borda);
    border-radius: 8px;
    min-width: 38px;
    height: 38px;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
}

.btn-pagina:hover:not(:disabled) {
    background: var(--acento);
    border-color: var(--acento);
}

.btn-pagina:disabled { opacity: 0.35; cursor: default; }

.pag-info { color: var(--texto-suave); font-size: 14px; padding: 0 10px; }

/* Etiquetas (badges) */
.badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
}
.badge-venda { background: rgba(59, 130, 246, 0.18); color: #93c5fd; }
.badge-aluguel { background: rgba(245, 158, 11, 0.18); color: #fcd34d; }
.badge-cat { background: var(--painel-claro); color: var(--texto-suave); }
.badge-queda { background: rgba(16, 185, 129, 0.18); color: #6ee7b7; white-space: nowrap; }

/* Preço anterior (pico) no radar: riscado e suave */
.preco-pico { color: var(--texto-suave); text-decoration: line-through; }

/* --- Toast --------------------------------------------------------------- */

.toast {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000;
    padding: 14px 20px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: var(--sombra);
    max-width: 360px;
}
.toast.oculto { display: none; }
.toast.sucesso { background: var(--sucesso); color: #04221a; }
.toast.erro { background: #ef4444; color: #fff; }
.toast.info { background: var(--acento); color: #fff; }

/* --- Login / assinatura -------------------------------------------------- */

.tela-login {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.login-card {
    background: var(--painel);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    box-shadow: var(--sombra);
    padding: 36px 32px;
    width: 100%;
    max-width: 380px;
    text-align: center;
}

.login-marca { display: flex; align-items: center; justify-content: center; gap: 12px; }
.login-marca h1 { font-size: 26px; font-weight: 700; letter-spacing: -0.5px; }
.login-sub { color: var(--texto-suave); font-size: 14px; margin: 6px 0 24px; }

#form-login { display: flex; flex-direction: column; gap: 12px; }
#form-login input {
    background: var(--fundo);
    border: 1px solid var(--borda);
    color: var(--texto);
    padding: 12px 14px;
    border-radius: 8px;
    font-size: 15px;
    font-family: inherit;
}
#form-login input:focus { outline: none; border-color: var(--acento); }
#form-login .btn { margin-top: 4px; padding: 12px; }

.login-erro { color: #f87171; font-size: 13px; margin-top: 4px; }
.login-erro.oculto { display: none; }

.aviso-assinatura {
    background: var(--fundo);
    border: 1px solid var(--borda);
    border-left: 4px solid var(--alerta);
    border-radius: var(--raio);
    padding: 18px 20px;
    text-align: left;
    margin: 8px 0 20px;
}
.aviso-assinatura h2 { font-size: 17px; margin-bottom: 8px; color: var(--alerta); }
.aviso-assinatura p { font-size: 14px; color: var(--texto-suave); }

/* Usuário logado no cabeçalho */
.usuario-info {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--texto-suave);
    white-space: nowrap;
}
.usuario-info strong { color: var(--texto); font-weight: 600; }
.badge-papel {
    background: rgba(59, 130, 246, 0.18);
    color: #93c5fd;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}
.link-sair { color: var(--texto-suave); text-decoration: none; font-weight: 600; }
.link-sair:hover { color: #f87171; }

/* --- Rodapé -------------------------------------------------------------- */

.rodape {
    text-align: center;
    padding: 20px;
    color: var(--texto-suave);
    font-size: 13px;
    border-top: 1px solid var(--borda);
}

/* --- Responsivo ---------------------------------------------------------- */

@media (max-width: 640px) {
    .cabecalho, .abas, .conteudo { padding-left: 16px; padding-right: 16px; }
    .card-valor { font-size: 24px; }
}
