:root {
  --azul: #1f5fa8;
  --azul-escuro: #163e6e;
  --tinta: #1b2733;
  --cinza: #6b7785;
  --linha: #e3e8ee;
  --fundo: #f5f7fa;
  --venda: #1f8a4c;
  --aluguel: #b9651b;
  --raio: 10px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  color: var(--tinta);
  background: var(--fundo);
}
a { color: var(--azul); text-decoration: none; }
a:hover { text-decoration: underline; }

/* topo */
.topo {
  display: flex; align-items: center; gap: 24px;
  background: #fff; border-bottom: 1px solid var(--linha);
  padding: 12px 24px; position: sticky; top: 0; z-index: 10;
}
.marca { font-weight: 700; font-size: 1.15rem; color: var(--tinta); }
.marca span { color: var(--azul); }
.topo nav { display: flex; gap: 16px; }
.topo nav a { color: var(--cinza); font-weight: 500; }
.topo .usuario { margin-left: auto; display: flex; align-items: center; gap: 12px; color: var(--cinza); font-size: .9rem; }
.sair { font-size: .85rem; }

.conteudo { max-width: 1080px; margin: 0 auto; padding: 24px; }
.rodape { text-align: center; color: var(--cinza); font-size: .8rem; padding: 32px 0; }

/* login */
.login-caixa {
  max-width: 360px; margin: 8vh auto; background: #fff;
  padding: 32px; border-radius: var(--raio); border: 1px solid var(--linha);
}
.login-caixa h1 { margin: 0; font-size: 1.4rem; }
.login-caixa .sub { color: var(--cinza); margin: 4px 0 24px; }
.login-caixa label, .filtros label { display: flex; flex-direction: column; gap: 4px; font-size: .85rem; color: var(--cinza); margin-bottom: 14px; }
input, select, button {
  font: inherit; padding: 9px 11px; border: 1px solid var(--linha);
  border-radius: 8px; background: #fff; color: var(--tinta);
}
input:focus, select:focus { outline: 2px solid var(--azul); border-color: var(--azul); }
button {
  background: var(--azul); color: #fff; border: none; cursor: pointer; font-weight: 600;
}
button:hover { background: var(--azul-escuro); }
.login-caixa button { width: 100%; margin-top: 6px; }
.alerta { background: #fdecec; color: #a02020; padding: 10px 12px; border-radius: 8px; margin-bottom: 16px; font-size: .9rem; }

/* filtros */
.filtros {
  background: #fff; border: 1px solid var(--linha); border-radius: var(--raio);
  padding: 18px; margin-bottom: 24px;
}
.linha-busca { display: flex; gap: 10px; margin-bottom: 14px; }
.linha-busca .q { flex: 1; font-size: 1.05rem; }
.linha-busca button { padding: 9px 26px; }
.campos { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 0 16px; }
.campos label { margin-bottom: 0; }

/* listagem */
.resultado-cabecalho { margin-bottom: 14px; color: var(--cinza); }
.lista { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.card { background: #fff; border: 1px solid var(--linha); border-radius: var(--raio); overflow: hidden; transition: box-shadow .15s, transform .15s; }
.card:hover { box-shadow: 0 6px 20px rgba(20,40,70,.12); transform: translateY(-2px); }
.card-link { color: inherit; display: block; }
.card-link:hover { text-decoration: none; }
.card img, .sem-foto { width: 100%; height: 160px; object-fit: cover; display: block; background: #eef1f5; }
.sem-foto { display: flex; align-items: center; justify-content: center; color: #aeb6c0; font-size: .85rem; }
.card-info { padding: 12px 14px; }
.preco { font-weight: 700; font-size: 1.15rem; }
.op { font-size: .65rem; text-transform: uppercase; padding: 2px 7px; border-radius: 20px; vertical-align: middle; margin-left: 6px; color: #fff; }
.op.venda { background: var(--venda); }
.op.aluguel { background: var(--aluguel); }
.detalhes { color: var(--cinza); font-size: .85rem; margin: 4px 0; }
.titulo { font-size: .9rem; margin: 6px 0 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.fonte { color: var(--cinza); font-size: .78rem; }
.tag { background: #eaf2fb; color: var(--azul); padding: 1px 7px; border-radius: 10px; margin-left: 4px; }

/* paginação */
.paginacao { display: flex; align-items: center; gap: 18px; justify-content: center; margin: 28px 0; color: var(--cinza); }

.vazio { background: #fff; border: 1px dashed var(--linha); border-radius: var(--raio); padding: 40px; text-align: center; color: var(--cinza); }
.vazio .dica { font-size: .9rem; }

/* detalhe */
.voltar { display: inline-block; margin-bottom: 16px; color: var(--cinza); }
.imovel { display: grid; grid-template-columns: 1.2fr 1fr; gap: 28px; background: #fff; border: 1px solid var(--linha); border-radius: var(--raio); padding: 24px; }
.galeria { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; align-content: start; }
.galeria img, .sem-foto.grande { width: 100%; height: 150px; object-fit: cover; border-radius: 6px; }
.galeria img:first-child { grid-column: 1 / -1; height: 260px; }
.sem-foto.grande { grid-column: 1 / -1; height: 260px; }
.preco-grande { font-size: 1.8rem; font-weight: 800; }
.ficha h1 { font-size: 1.3rem; margin: 8px 0 4px; }
.local { color: var(--cinza); margin: 0 0 16px; }
.atributos { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 0 0 18px; }
.atributos li { background: var(--fundo); border-radius: 8px; padding: 8px 10px; font-size: .9rem; }
.atributos b { display: block; color: var(--cinza); font-size: .72rem; text-transform: uppercase; }
.fonte-linha { font-size: .9rem; color: var(--cinza); }
.externo { margin-left: 8px; }
.bloco { border-top: 1px solid var(--linha); padding-top: 14px; margin-top: 14px; }
.bloco h3 { margin: 0 0 8px; font-size: .95rem; }
.outras, .historico { list-style: none; padding: 0; margin: 0; font-size: .9rem; }
.outras li, .historico li { padding: 4px 0; }
.historico span { color: var(--cinza); display: inline-block; width: 92px; }
.descricao { font-size: .9rem; line-height: 1.5; white-space: pre-line; color: #33414f; }

/* tabela fontes */
.sub { color: var(--cinza); }
.tabela { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--linha); border-radius: var(--raio); overflow: hidden; }
.tabela th, .tabela td { text-align: left; padding: 10px 14px; border-bottom: 1px solid var(--linha); font-size: .9rem; }
.tabela th { background: var(--fundo); color: var(--cinza); font-size: .78rem; text-transform: uppercase; }
.tabela small { color: var(--cinza); }
.tabela .num { text-align: right; }

/* resultado + exportar */
.resultado-cabecalho { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.btn-csv { background: #fff; border: 1px solid var(--linha); border-radius: 8px; padding: 7px 14px; font-size: .85rem; color: var(--azul); font-weight: 600; }
.btn-csv:hover { background: #eaf2fb; text-decoration: none; }

/* abas (novidades) */
.abas { display: flex; gap: 8px; margin-bottom: 18px; border-bottom: 1px solid var(--linha); }
.aba { padding: 10px 16px; color: var(--cinza); font-weight: 600; border-bottom: 3px solid transparent; margin-bottom: -1px; }
.aba:hover { text-decoration: none; color: var(--tinta); }
.aba.ativa { color: var(--azul); border-bottom-color: var(--azul); }
.filtros.compacto { padding: 14px 18px; }

/* tabela: cores de variação */
.tabela .queda { color: var(--venda); font-weight: 700; }
.tabela .risco { color: var(--cinza); text-decoration: line-through; }

/* gráfico de preço (SVG) */
.grafico { width: 100%; height: auto; margin: 4px 0 12px; }
.grafico .eixo { stroke: var(--linha); stroke-width: 1; }
.grafico .linha { fill: none; stroke: var(--azul); stroke-width: 2; }
.grafico .ponto { fill: var(--azul); }
.grafico .rotulo { fill: var(--cinza); font-size: 10px; }

@media (max-width: 720px) {
  .imovel { grid-template-columns: 1fr; }
  .topo { gap: 14px; padding: 10px 14px; }
}
