/* ============================================================
   CasaPronta Região — styles.css
   Visual profissional/local. Paleta: slate + verde imobiliário.
   Mobile-first, responsivo.
   ============================================================ */

:root {
  --verde:        #15803d;
  --verde-escuro: #166534;
  --verde-claro:  #dcfce7;
  --slate-900:    #0f172a;
  --slate-700:    #334155;
  --slate-500:    #64748b;
  --slate-400:    #94a3b8;
  --slate-200:    #e2e8f0;
  --slate-100:    #f1f5f9;
  --slate-50:     #f8fafc;
  --branco:       #ffffff;
  --whats:        #25d366;
  --amber:        #d97706;
  --sombra:       0 1px 3px rgba(15,23,42,.08), 0 8px 24px rgba(15,23,42,.06);
  --sombra-forte: 0 10px 40px rgba(15,23,42,.18);
  --raio:         14px;
}

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

body {
  font-family: "Segoe UI", system-ui, -apple-system, Roboto, Arial, sans-serif;
  color: var(--slate-900);
  background: var(--slate-100);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

button { font-family: inherit; cursor: pointer; border: none; }
img { display: block; max-width: 100%; }

/* ---------- Topbar ---------- */

.topbar {
  position: sticky; top: 0; z-index: 40;
  background: var(--branco);
  border-bottom: 1px solid var(--slate-200);
  box-shadow: 0 1px 8px rgba(15,23,42,.04);
}
.topbar-inner {
  max-width: 1180px; margin: 0 auto; padding: 12px 18px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.logo { display: flex; align-items: center; gap: 10px; font-weight: 800; font-size: 1.18rem; cursor: pointer; }
.logo:hover .nome { opacity: .85; }
.logo .mark {
  width: 38px; height: 38px; border-radius: 10px;
  background: linear-gradient(135deg, var(--verde), var(--verde-escuro));
  color: #fff; display: grid; place-items: center; font-size: 1.25rem;
}
.logo .nome { color: var(--slate-900); }
.logo .nome b { color: var(--verde); }
.logo .regiao { font-size: .72rem; font-weight: 600; color: var(--slate-500); display: block; letter-spacing: .04em; text-transform: uppercase; }

.nav { display: flex; gap: 4px; margin-left: auto; flex-wrap: wrap; }
.nav-btn {
  background: transparent; color: var(--slate-700);
  padding: 9px 14px; border-radius: 10px; font-weight: 600; font-size: .92rem;
  display: flex; align-items: center; gap: 7px; transition: .15s;
}
.nav-btn:hover { background: var(--slate-100); }
.nav-btn.ativo { background: var(--verde-claro); color: var(--verde-escuro); }
.nav-btn .badge {
  background: var(--verde); color: #fff; border-radius: 999px;
  font-size: .7rem; min-width: 18px; height: 18px; padding: 0 5px;
  display: grid; place-items: center; font-weight: 700;
}

/* ---------- Layout geral ---------- */

.container { max-width: 1180px; margin: 0 auto; padding: 20px 18px 60px; }
.view { display: none; }
.view.ativa { display: block; animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.section-head { margin-bottom: 16px; }
.section-head h1 { font-size: 1.5rem; font-weight: 800; }
.section-head p { color: var(--slate-500); font-size: .95rem; margin-top: 2px; }

/* ---------- Barra de filtros ---------- */

.filtros {
  background: var(--branco); border: 1px solid var(--slate-200);
  border-radius: var(--raio); box-shadow: var(--sombra);
  padding: 16px; margin-bottom: 18px;
}
.busca-wrap { position: relative; margin-bottom: 14px; }
.busca-wrap .lupa { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--slate-400); }
.busca {
  width: 100%; padding: 12px 14px 12px 42px; font-size: 1rem;
  border: 1px solid var(--slate-200); border-radius: 10px; background: var(--slate-50);
}
.busca:focus { outline: none; border-color: var(--verde); background: #fff; box-shadow: 0 0 0 3px var(--verde-claro); }

.filtros-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
}
.campo label { display: block; font-size: .78rem; font-weight: 700; color: var(--slate-500); margin-bottom: 5px; text-transform: uppercase; letter-spacing: .03em; }
.campo select, .campo input {
  width: 100%; padding: 10px 12px; font-size: .95rem;
  border: 1px solid var(--slate-200); border-radius: 10px; background: #fff; color: var(--slate-900);
}
.campo select:focus, .campo input:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px var(--verde-claro); }

.filtros-rodape { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 14px; flex-wrap: wrap; }
.resultado-contagem { font-size: .9rem; color: var(--slate-500); font-weight: 600; }
.resultado-contagem b { color: var(--slate-900); }
.btn-limpar { background: var(--slate-100); color: var(--slate-700); padding: 8px 14px; border-radius: 10px; font-weight: 600; font-size: .88rem; }
.btn-limpar:hover { background: var(--slate-200); }

/* ---------- Grid de cards ---------- */

.grid {
  display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.card {
  background: var(--branco); border: 1px solid var(--slate-200);
  border-radius: var(--raio); overflow: hidden; box-shadow: var(--sombra);
  display: flex; flex-direction: column; transition: .18s;
}
.card:hover { transform: translateY(-3px); box-shadow: var(--sombra-forte); }

.card-img { position: relative; aspect-ratio: 16/10; background: var(--slate-100); cursor: pointer; }
.card-img img { width: 100%; height: 100%; object-fit: cover; }
.card-status {
  position: absolute; top: 10px; left: 10px;
  padding: 5px 11px; border-radius: 999px; font-size: .76rem; font-weight: 800;
  color: #fff; box-shadow: 0 2px 6px rgba(0,0,0,.18);
}
.st-planta  { background: #2563eb; }
.st-obra    { background: #d97706; }
.st-pronta  { background: #15803d; }
.st-vendida { background: #6b7280; }

.fav-btn {
  position: absolute; top: 10px; right: 10px;
  width: 38px; height: 38px; border-radius: 999px;
  background: rgba(255,255,255,.92); display: grid; place-items: center;
  font-size: 1.15rem; box-shadow: 0 2px 8px rgba(0,0,0,.15); transition: .15s;
}
.fav-btn:hover { transform: scale(1.08); }
.fav-btn.on { background: #fee2e2; }

.card-body { padding: 14px 15px 16px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.card-preco { font-size: 1.32rem; font-weight: 800; color: var(--verde-escuro); }
.card-titulo { font-size: .98rem; font-weight: 700; color: var(--slate-900); line-height: 1.3; }
.card-local { font-size: .86rem; color: var(--slate-500); display: flex; align-items: center; gap: 5px; }

.card-specs { display: flex; gap: 14px; flex-wrap: wrap; padding: 9px 0; border-top: 1px solid var(--slate-100); border-bottom: 1px solid var(--slate-100); }
.spec { display: flex; align-items: center; gap: 5px; font-size: .84rem; color: var(--slate-700); font-weight: 600; }
.spec .ic { color: var(--slate-400); }

.selos { display: flex; flex-wrap: wrap; gap: 6px; }
.selo {
  font-size: .73rem; font-weight: 700; color: var(--verde-escuro);
  background: var(--verde-claro); padding: 3px 9px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 4px;
}

.card-acoes { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; padding-top: 4px; }
/* WhatsApp (e "Ver parecidos") como ação principal em largura total no card */
.card-acoes .btn-whats, .card-acoes .btn-parecidos { flex-basis: 100%; white-space: nowrap; }
.btn-detalhe {
  flex: 1; background: var(--slate-100); color: var(--slate-700);
  padding: 11px; border-radius: 10px; font-weight: 700; font-size: .9rem; transition: .15s;
}
.btn-detalhe:hover { background: var(--slate-200); }

.btn-whats {
  flex: 1; background: var(--whats); color: #fff;
  padding: 11px; border-radius: 10px; font-weight: 700; font-size: .9rem;
  display: flex; align-items: center; justify-content: center; gap: 6px; transition: .15s;
}
.btn-whats:hover { background: #1ebe5d; }

/* ---------- Estado vazio ---------- */

.vazio {
  background: var(--branco); border: 2px dashed var(--slate-200); border-radius: var(--raio);
  padding: 48px 24px; text-align: center; color: var(--slate-500);
}
.vazio .emoji { font-size: 2.6rem; margin-bottom: 10px; }
.vazio h3 { color: var(--slate-700); font-size: 1.1rem; margin-bottom: 6px; }
.vazio p { font-size: .92rem; max-width: 380px; margin: 0 auto 16px; }
.vazio .btn-cta {
  background: var(--verde); color: #fff; padding: 10px 18px; border-radius: 10px; font-weight: 700; font-size: .92rem;
}
.vazio .btn-cta:hover { background: var(--verde-escuro); }

/* ---------- Modal de detalhes ---------- */

.modal-overlay {
  position: fixed; inset: 0; z-index: 60;
  background: rgba(15,23,42,.55); backdrop-filter: blur(2px);
  display: none; align-items: flex-start; justify-content: center;
  padding: 24px 16px; overflow-y: auto;
}
.modal-overlay.aberto { display: flex; animation: fade .2s ease; }
.modal {
  background: var(--branco); border-radius: 18px; max-width: 720px; width: 100%;
  box-shadow: var(--sombra-forte); overflow: hidden; margin: auto 0;
}
.modal-img { position: relative; aspect-ratio: 16/9; background: var(--slate-100); }
.modal-img img { width: 100%; height: 100%; object-fit: cover; }
.modal-fechar {
  position: absolute; top: 12px; right: 12px; width: 40px; height: 40px; border-radius: 999px;
  background: rgba(255,255,255,.95); font-size: 1.3rem; display: grid; place-items: center; box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.modal-body { padding: 22px; }

/* Galeria de fotos no modal */
.modal-galeria { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.modal-thumb { width: 64px; height: 48px; border-radius: 8px; overflow: hidden; border: 2px solid transparent; padding: 0; background: var(--slate-100); }
.modal-thumb img { width: 100%; height: 100%; object-fit: cover; }
.modal-thumb.ativa { border-color: var(--verde); }
.modal-preco { font-size: 1.9rem; font-weight: 800; color: var(--verde-escuro); }
.modal-titulo { font-size: 1.25rem; font-weight: 800; margin: 4px 0 6px; }
.modal-local { color: var(--slate-500); font-size: .95rem; margin-bottom: 16px; display: flex; align-items: center; gap: 6px; }

.modal-specs { display: grid; grid-template-columns: repeat(auto-fit, minmax(90px, 1fr)); gap: 10px; margin-bottom: 18px; }
.modal-spec { background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 12px; padding: 12px; text-align: center; }
.modal-spec .v { font-size: 1.15rem; font-weight: 800; color: var(--slate-900); }
.modal-spec .l { font-size: .76rem; color: var(--slate-500); font-weight: 600; }

.modal-bloco { margin-bottom: 18px; }
.modal-bloco h4 { font-size: .82rem; text-transform: uppercase; letter-spacing: .04em; color: var(--slate-500); margin-bottom: 8px; }
.modal-desc { color: var(--slate-700); font-size: .96rem; line-height: 1.6; }

.modal-anunciante { display: flex; align-items: center; gap: 10px; background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 12px; padding: 12px 14px; }
.modal-anunciante .av { width: 42px; height: 42px; border-radius: 999px; background: var(--verde-claro); color: var(--verde-escuro); display: grid; place-items: center; font-weight: 800; }
.modal-anunciante .nm { font-weight: 700; }
.modal-anunciante .tp { font-size: .8rem; color: var(--slate-500); }

.modal-acoes { display: flex; gap: 10px; margin-top: 20px; }
.modal-acoes .btn-whats { padding: 14px; font-size: 1rem; }
.modal-acoes .btn-fav-lg {
  background: var(--slate-100); color: var(--slate-700); padding: 14px 18px; border-radius: 10px; font-weight: 700; display: flex; align-items: center; gap: 7px;
}
.modal-acoes .btn-fav-lg.on { background: #fee2e2; color: #b91c1c; }

/* ---------- Formulário de cadastro ---------- */

.form-card {
  background: var(--branco); border: 1px solid var(--slate-200); border-radius: var(--raio);
  box-shadow: var(--sombra); padding: 24px; max-width: 760px;
}
.form-grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.form-grid .full { grid-column: 1 / -1; }
.form-campo label { display: block; font-size: .85rem; font-weight: 700; color: var(--slate-700); margin-bottom: 6px; }
.form-campo label .req { color: #dc2626; }
.form-campo input, .form-campo select, .form-campo textarea {
  width: 100%; padding: 11px 13px; font-size: .96rem; color: var(--slate-900);
  border: 1px solid var(--slate-200); border-radius: 10px; background: var(--slate-50);
}
.form-campo input:focus, .form-campo select:focus, .form-campo textarea:focus {
  outline: none; border-color: var(--verde); background: #fff; box-shadow: 0 0 0 3px var(--verde-claro);
}
.form-campo textarea { resize: vertical; min-height: 90px; }
.form-campo.erro input, .form-campo.erro select, .form-campo.erro textarea { border-color: #dc2626; background: #fef2f2; }
.erro-msg { color: #dc2626; font-size: .8rem; font-weight: 600; margin-top: 5px; display: none; }
.form-campo.erro .erro-msg { display: block; }

.selos-check { display: flex; flex-wrap: wrap; gap: 10px; }
.selo-check {
  display: flex; align-items: center; gap: 8px; padding: 9px 14px;
  border: 1px solid var(--slate-200); border-radius: 10px; background: var(--slate-50);
  font-size: .9rem; font-weight: 600; color: var(--slate-700); cursor: pointer; transition: .15s; user-select: none;
}
.selo-check input { width: 16px; height: 16px; accent-color: var(--verde); cursor: pointer; }
.selo-check:has(input:checked) { background: var(--verde-claro); border-color: var(--verde); color: var(--verde-escuro); }

.form-acoes { display: flex; gap: 12px; margin-top: 22px; flex-wrap: wrap; }
.btn-primario {
  background: var(--verde); color: #fff; padding: 13px 26px; border-radius: 10px; font-weight: 700; font-size: 1rem; transition: .15s;
}
.btn-primario:hover { background: var(--verde-escuro); }
.btn-secundario { background: var(--slate-100); color: var(--slate-700); padding: 13px 22px; border-radius: 10px; font-weight: 700; }
.btn-secundario:hover { background: var(--slate-200); }

.dica-form { font-size: .85rem; color: var(--slate-500); margin-top: 14px; background: var(--slate-50); border-radius: 10px; padding: 12px 14px; border-left: 3px solid var(--verde); }

/* ---------- Meus anúncios ---------- */

.meu-card { display: flex; gap: 14px; }
.meu-card .card-img { width: 130px; flex-shrink: 0; aspect-ratio: 1/1; border-radius: 10px; overflow: hidden; }
.meu-card-info { flex: 1; min-width: 0; }
.btn-remover { background: #fef2f2; color: #b91c1c; padding: 8px 14px; border-radius: 9px; font-weight: 700; font-size: .85rem; }
.btn-remover:hover { background: #fee2e2; }

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

.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: var(--slate-900); color: #fff; padding: 13px 22px; border-radius: 12px;
  font-weight: 600; font-size: .92rem; box-shadow: var(--sombra-forte); z-index: 80;
  opacity: 0; transition: .3s; display: flex; align-items: center; gap: 8px;
}
.toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }

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

.rodape { text-align: center; padding: 28px 18px; color: var(--slate-400); font-size: .82rem; }

/* ---------- Faixa de métricas (confiança) ---------- */

.metricas {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 18px;
}
.metrica {
  background: var(--branco); border: 1px solid var(--slate-200); border-radius: var(--raio);
  box-shadow: var(--sombra); padding: 14px 10px; text-align: center;
}
.metrica .v { font-size: 1.6rem; font-weight: 800; color: var(--verde-escuro); line-height: 1.1; }
.metrica .l { font-size: .76rem; color: var(--slate-500); font-weight: 600; margin-top: 2px; }

/* ---------- Ordenação ---------- */

.ordenar-wrap { display: flex; align-items: center; gap: 8px; }
.ordenar-wrap label { font-size: .82rem; font-weight: 700; color: var(--slate-500); white-space: nowrap; }
.ordenar-wrap select {
  padding: 8px 12px; font-size: .88rem; border: 1px solid var(--slate-200);
  border-radius: 10px; background: #fff; color: var(--slate-900); font-weight: 600;
}
.ordenar-wrap select:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px var(--verde-claro); }
.filtros-rodape .resultado-contagem { margin-left: auto; }

/* ---------- Cards vendidos ---------- */

.card--vendida .card-img img { filter: grayscale(.55) brightness(.92); }
.ribbon-vendida {
  position: absolute; top: 16px; right: -34px; transform: rotate(45deg);
  background: #6b7280; color: #fff; font-size: .72rem; font-weight: 800; letter-spacing: .08em;
  padding: 4px 40px; box-shadow: 0 2px 6px rgba(0,0,0,.25);
}
.btn-parecidos {
  flex: 1; background: var(--slate-700); color: #fff;
  padding: 11px; border-radius: 10px; font-weight: 700; font-size: .9rem;
  display: flex; align-items: center; justify-content: center; gap: 6px; transition: .15s;
}
.btn-parecidos:hover { background: var(--slate-900); }

/* ---------- Modal: motivos / lead / copiar ---------- */

.motivos-bloco .motivos { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.motivos li {
  background: var(--verde-claro); color: var(--verde-escuro); font-weight: 600; font-size: .92rem;
  padding: 9px 13px; border-radius: 10px; border-left: 3px solid var(--verde);
}

.lead-box { background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 12px; padding: 15px; }
.lead-box h4 { color: var(--slate-700); margin-bottom: 4px; }
.lead-dica { font-size: .82rem; color: var(--slate-500); margin-bottom: 11px; }
.lead-grid { display: grid; gap: 9px; grid-template-columns: 1fr 1fr; }
.lead-grid input, .lead-grid select {
  width: 100%; padding: 10px 12px; font-size: .92rem; border: 1px solid var(--slate-200);
  border-radius: 9px; background: #fff; color: var(--slate-900);
}
.lead-grid select { grid-column: 1 / -1; }
.lead-grid input:focus, .lead-grid select:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px var(--verde-claro); }

.btn-copiar {
  background: var(--slate-100); color: var(--slate-700); padding: 14px 16px; border-radius: 10px;
  font-weight: 700; white-space: nowrap; transition: .15s;
}
.btn-copiar:hover { background: var(--slate-200); }
.modal-vendida-aviso {
  background: #f1f5f9; border: 1px solid var(--slate-200); border-left: 3px solid var(--slate-400);
  border-radius: 10px; padding: 12px 14px; font-size: .9rem; color: var(--slate-700); margin-bottom: 14px;
}

/* ---------- Formulário em seções ---------- */

.form-secao { border: 1px solid var(--slate-200); border-radius: 12px; padding: 16px 16px 18px; margin-bottom: 16px; }
.form-secao legend {
  font-size: .82rem; font-weight: 800; color: var(--verde-escuro); text-transform: uppercase;
  letter-spacing: .04em; padding: 2px 10px; background: var(--verde-claro); border-radius: 999px;
}

/* ---------- Interessados recebidos (leads) ---------- */

.leads-area { margin-top: 6px; }
#leads-lista { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.lead-card {
  background: var(--branco); border: 1px solid var(--slate-200); border-radius: 12px;
  box-shadow: var(--sombra); padding: 14px; display: flex; flex-direction: column; gap: 6px;
}
.lead-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.lead-nome { font-weight: 800; color: var(--slate-900); }
.lead-data { font-size: .76rem; color: var(--slate-400); white-space: nowrap; }
.lead-tel a { color: var(--verde-escuro); font-weight: 700; text-decoration: none; font-size: .95rem; }
.lead-imovel { font-size: .86rem; color: var(--slate-600); }
.lead-interesse {
  align-self: flex-start; background: var(--verde-claro); color: var(--verde-escuro);
  font-size: .76rem; font-weight: 700; padding: 4px 11px; border-radius: 999px;
}

/* ---------- Indicador de modo (local x nuvem) ---------- */

.modo-aviso {
  display: flex; align-items: center; gap: 9px;
  background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 10px;
  padding: 9px 13px; font-size: .84rem; color: var(--slate-600); margin-bottom: 16px;
}
.modo-aviso b { color: var(--slate-700); font-weight: 700; }
.modo-aviso .dot {
  width: 8px; height: 8px; border-radius: 999px; background: var(--amber);
  box-shadow: 0 0 0 3px rgba(217,119,6,.18); flex-shrink: 0;
}

/* ---------- Seletor de demos ONKZ ---------- */

.demos-onkz {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--branco); border: 1px solid var(--slate-200); border-radius: 12px;
  box-shadow: var(--sombra); padding: 10px 14px; margin-bottom: 16px;
}
.demos-label { font-size: .85rem; font-weight: 600; color: var(--slate-500); }
.demos-label b { color: var(--slate-800); }
.demo-chip {
  background: var(--verde-claro); color: var(--verde-escuro);
  padding: 7px 13px; border-radius: 999px; font-weight: 700; font-size: .84rem;
  border: 1px solid transparent; transition: .15s;
}
.demo-chip:hover { filter: brightness(.96); border-color: var(--verde); }

/* ---------- Painel do anunciante (login + leads) ---------- */

.painel-anunciante {
  margin-top: 30px; background: var(--branco); border: 1px solid var(--slate-200);
  border-radius: 12px; box-shadow: var(--sombra); padding: 16px;
}
.painel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
.painel-user { font-size: .88rem; font-weight: 600; color: var(--slate-700); display: flex; align-items: center; gap: 10px; }
.painel-nota { font-size: .88rem; color: var(--slate-500); margin: 6px 0 12px; }
.painel-nota b { color: var(--slate-800); }
.painel-nota code { background: var(--slate-100); padding: 1px 6px; border-radius: 5px; font-size: .82rem; }

.login-form { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.login-form input {
  flex: 1; min-width: 180px; padding: 11px 13px; font-size: .95rem;
  border: 1px solid var(--slate-200); border-radius: 10px; background: var(--slate-50); color: var(--slate-900);
}
.login-form input:focus { outline: none; border-color: var(--verde); background: #fff; box-shadow: 0 0 0 3px var(--verde-claro); }
.login-form .btn-primario { padding: 11px 22px; }

#painel-sites { margin: 6px 0 12px; }
#painel-sites select {
  padding: 9px 12px; font-size: .92rem; border: 1px solid var(--slate-200);
  border-radius: 10px; background: #fff; color: var(--slate-900); font-weight: 600;
}
.leads-protegidos { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

/* Abas do painel */
.painel-tabs { display: flex; gap: 6px; border-bottom: 1px solid var(--slate-200); margin: 10px 0 14px; flex-wrap: wrap; }
.painel-tab {
  background: transparent; color: var(--slate-500); font-weight: 700; font-size: .9rem;
  padding: 9px 14px; border-radius: 9px 9px 0 0; border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.painel-tab:hover { color: var(--slate-700); background: var(--slate-50); }
.painel-tab.ativa { color: var(--verde-escuro); border-bottom-color: var(--verde); }

/* Formulários de gestão (site / imóvel) */
.gestao-form { background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 12px; padding: 16px; }
.gf-titulo { font-size: 1rem; font-weight: 800; margin-bottom: 12px; }
.gf-grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.gf-campo { display: flex; flex-direction: column; gap: 5px; font-size: .8rem; font-weight: 700; color: var(--slate-600); }
.gf-campo.gf-full { grid-column: 1 / -1; }
.gf-campo input, .gf-campo select, .gf-campo textarea {
  padding: 10px 12px; font-size: .95rem; font-weight: 400; color: var(--slate-900);
  border: 1px solid var(--slate-200); border-radius: 9px; background: #fff;
}
.gf-campo input:focus, .gf-campo select:focus, .gf-campo textarea:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px var(--verde-claro); }
.gf-campo.gf-cor input[type="color"] { padding: 2px; height: 40px; cursor: pointer; }
.gf-selos { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.gf-acoes { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }

.gestao-top { margin-bottom: 12px; }
.gestao-form-imovel { margin-bottom: 14px; }
#gestao-lista { display: flex; flex-direction: column; gap: 8px; }
.gestao-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  background: var(--branco); border: 1px solid var(--slate-200); border-radius: 10px; padding: 11px 14px;
}
.gestao-item.inativo { opacity: .6; }
.gi-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.gi-titulo { font-weight: 700; color: var(--slate-900); }
.gi-meta { font-size: .82rem; color: var(--slate-500); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.gi-status { position: static; font-size: .68rem; }
.gi-estado { font-size: .68rem; font-weight: 800; padding: 2px 8px; border-radius: 999px; text-transform: uppercase; letter-spacing: .03em; }
.gi-estado.publicado { background: var(--verde-claro); color: var(--verde-escuro); }
.gi-estado.oculto { background: var(--slate-200); color: var(--slate-600); }
.gi-estado.vendido { background: #e5e7eb; color: #4b5563; }
.gi-dup { font-size: .68rem; font-weight: 700; background: #fef3c7; color: #92400e; padding: 1px 8px; border-radius: 999px; }
.gi-acoes { display: flex; gap: 6px; flex-wrap: wrap; }
.btn-mini {
  background: var(--slate-100); color: var(--slate-700); padding: 7px 11px; border-radius: 8px;
  font-weight: 700; font-size: .8rem; transition: .15s;
}
.btn-mini:hover { background: var(--slate-200); }
.btn-mini-perigo { background: #fef2f2; color: #b91c1c; }
.btn-mini-perigo:hover { background: #fee2e2; }

/* Fotos do imóvel (gestão) */
.gf-fotos-sec { margin-top: 14px; border-top: 1px solid var(--slate-200); padding-top: 12px; }
.foto-upload { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.foto-upload .btn-mini { cursor: pointer; display: inline-flex; align-items: center; }
.fotos-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
.foto-item { position: relative; border: 1px solid var(--slate-200); border-radius: 10px; overflow: hidden; background: var(--slate-100); }
.foto-item.capa { border-color: var(--verde); box-shadow: 0 0 0 2px var(--verde-claro); }
.foto-item img { width: 100%; height: 90px; object-fit: cover; display: block; }
.foto-tag { position: absolute; top: 6px; left: 6px; background: var(--verde); color: #fff; font-size: .66rem; font-weight: 800; padding: 2px 7px; border-radius: 999px; }
.foto-acoes { display: flex; gap: 5px; padding: 6px; }
.foto-acoes .btn-mini { padding: 5px 8px; font-size: .74rem; flex: 1; justify-content: center; text-align: center; }
.painel-acoes { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin: 4px 0 14px; }

.lead-cidade { font-size: .84rem; color: var(--slate-600); }
.lead-whats { margin-top: 8px; padding: 9px; font-size: .86rem; }
.lead-card--teste { border-color: #fcd34d; background: #fffbeb; }
.tag-teste {
  font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em;
  background: #fde68a; color: #92400e; padding: 1px 7px; border-radius: 999px; vertical-align: middle;
}

/* ---------- Diagnóstico de conexão ---------- */

.diagnostico {
  margin-top: 30px; background: var(--branco); border: 1px solid var(--slate-200);
  border-radius: 12px; box-shadow: var(--sombra); padding: 14px 16px;
}
.diag-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.diag-titulo { font-size: .9rem; font-weight: 800; color: var(--slate-700); }
.btn-testar {
  background: var(--slate-100); color: var(--slate-700); padding: 8px 14px;
  border-radius: 9px; font-weight: 700; font-size: .84rem; transition: .15s;
}
.btn-testar:hover { background: var(--slate-200); }
.btn-testar:disabled { opacity: .6; cursor: default; }

.diag-grid { display: grid; gap: 8px; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.diag-item {
  display: flex; flex-direction: column; gap: 2px;
  background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 9px; padding: 9px 11px;
}
.diag-l { font-size: .72rem; color: var(--slate-500); font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.diag-v { font-size: .92rem; font-weight: 700; color: var(--slate-800); }
.diag-v.diag-ok { color: var(--verde-escuro); }
.diag-v.diag-erro { color: #b91c1c; }
.diag-v.diag-neutro { color: var(--slate-500); }

/* ============================================================
   LANDING PREMIUM DO CLIENTE (CLIENTE_PREMIUM_REBUILD_1)
   Layout próprio para /slug — separado do portal geral.
   ============================================================ */

html, body { overflow-x: hidden; }   /* evita scroll horizontal do full-bleed */
.cliente-premium { color: var(--slate-900); }

/* full-bleed helper (escapa do container centralizado) */
.cp-hero, .cp-inst, .cp-imoveis, .cp-cta { width: 100vw; margin-left: calc(50% - 50vw); }

/* ----- HERO full-screen ----- */
.cp-hero {
  min-height: 78vh; display: flex; align-items: center; justify-content: center;
  text-align: center; color: #fff; padding: 110px 24px;
  background: linear-gradient(135deg, var(--verde), var(--verde-escuro));
  background-size: cover; background-position: center;
}
/* Fallback elegante p/ sites SEM foto: gradiente escuro + textura sutil de casas
   (nada de bloco sólido chapado). */
.cp-hero--sem-foto {
  background-color: var(--verde-escuro);
  background-image:
    linear-gradient(135deg, rgba(0,0,0,.28), rgba(0,0,0,.52)),
    url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='140'%20height='140'%3E%3Cg%20fill='none'%20stroke='%23ffffff'%20stroke-opacity='0.06'%20stroke-width='2'%3E%3Cpath%20d='M24%2086%20L70%2046%20L116%2086%20V120%20H24%20Z'/%3E%3Cpath%20d='M58%20120%20V96%20H82%20V120'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(135deg, var(--verde-escuro), #0b3b22);
  background-size: cover, 140px 140px, cover;
  background-repeat: no-repeat, repeat, no-repeat;
  background-position: center;
}
.cp-hero-inner { max-width: 820px; }
.cp-hero h1 { font-size: clamp(2.1rem, 5vw, 3.3rem); font-weight: 800; line-height: 1.06; letter-spacing: -.02em; text-shadow: 0 2px 24px rgba(0,0,0,.4); }
.cp-hero p { font-size: clamp(1rem, 2.2vw, 1.2rem); margin-top: 16px; opacity: .96; text-shadow: 0 1px 12px rgba(0,0,0,.4); }
.cp-hero-ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 30px; }
.cp-btn-whats {
  background: var(--whats); color: #fff; font-weight: 800; font-size: 1.05rem;
  padding: 16px 30px; border-radius: 14px; text-decoration: none; display: inline-flex; align-items: center; gap: 9px;
  box-shadow: 0 10px 30px rgba(0,0,0,.32); transition: .15s;
}
.cp-btn-whats:hover { transform: translateY(-2px); background: #1ebe5d; }
.cp-btn-ghost {
  background: rgba(255,255,255,.12); color: #fff; font-weight: 700; font-size: 1rem;
  padding: 16px 28px; border-radius: 14px; border: 1.5px solid rgba(255,255,255,.6); transition: .15s;
}
.cp-btn-ghost:hover { background: rgba(255,255,255,.24); }
.cp-selos { display: flex; gap: 10px 22px; justify-content: center; flex-wrap: wrap; margin-top: 28px; font-size: .9rem; opacity: .95; }
.cp-selos span { display: inline-flex; align-items: center; gap: 7px; }
.cp-selos span::before { content: "✓"; font-weight: 800; }

/* ----- Seção institucional ----- */
.cp-inst { background: var(--branco); padding: 64px 24px; text-align: center; }
.cp-inst > h2 { font-size: clamp(1.45rem, 3vw, 1.95rem); font-weight: 800; max-width: 900px; margin: 0 auto; letter-spacing: -.01em; line-height: 1.18; text-wrap: balance; }
.cp-inst > h2 .nowrap { white-space: nowrap; }
.cp-inst > p { color: var(--slate-600); max-width: 680px; margin: 14px auto 0; line-height: 1.6; }
.cp-inst-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); max-width: 1000px; margin: 36px auto 0; }
.cp-inst-card { background: var(--slate-50); border: 1px solid var(--slate-200); border-radius: 16px; padding: 26px 22px; text-align: left; }
.cp-inst-card h3 { font-size: 1.1rem; font-weight: 800; color: var(--verde-escuro); }
.cp-inst-card p { color: var(--slate-600); margin-top: 8px; font-size: .95rem; line-height: 1.55; }

/* ----- Seção de imóveis ----- */
.cp-imoveis { background: var(--slate-100); padding: 60px 24px; }
.cp-sec-head { max-width: 1180px; margin: 0 auto 8px; text-align: center; }
.cp-sec-head h2 { font-size: clamp(1.5rem, 3.5vw, 2rem); font-weight: 800; }
.cp-sec-head p { color: var(--slate-500); margin-top: 6px; }
.cp-filtro { max-width: 1180px; margin: 18px auto; text-align: center; }
.cp-filtro-toggle {
  background: var(--branco); border: 1px solid var(--slate-200); color: var(--slate-700);
  font-weight: 700; font-size: .9rem; padding: 11px 18px; border-radius: 999px; box-shadow: var(--sombra);
}
.cp-filtro-toggle:hover { background: var(--slate-50); }
.cp-filtro-box { max-width: 460px; margin: 14px auto 0; }
.cp-filtro-box.recolhido { display: none; }
.cp-filtro-box input {
  width: 100%; padding: 13px 16px; font-size: 1rem; border: 1px solid var(--slate-200);
  border-radius: 12px; background: var(--branco);
}
.cp-filtro-box input:focus { outline: none; border-color: var(--verde); box-shadow: 0 0 0 3px var(--verde-claro); }
.cp-grid { max-width: 1180px; margin: 22px auto 0; gap: 26px; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); }

/* Cards premium (modo cliente) */
.cliente-premium .card { border: none; border-radius: 18px; box-shadow: 0 6px 24px rgba(15,23,42,.10); }
.cliente-premium .card:hover { transform: translateY(-4px); box-shadow: 0 20px 50px rgba(15,23,42,.18); }
.cliente-premium .card-img { aspect-ratio: 4/3; }
.cliente-premium .card-body { padding: 18px 18px 20px; gap: 10px; }
.cliente-premium .card-preco { font-size: 1.55rem; }
.cliente-premium .card-titulo { font-size: 1.05rem; }
.cliente-premium .card-acoes { padding-top: 8px; }

/* ----- CTA WhatsApp ----- */
.cp-cta {
  /* verde escuro/grafite premium (sem roxo/rosa), independente da cor do cliente */
  background: linear-gradient(135deg, #123524, #0c1f16); color: #fff;
  text-align: center; padding: 64px 24px;
}
.cp-cta h2 { font-size: clamp(1.5rem, 3.5vw, 2.1rem); font-weight: 800; }
.cp-cta p { max-width: 600px; margin: 14px auto 26px; opacity: .95; line-height: 1.6; }

/* WhatsApp no topo do cliente */
.nav-whats {
  background: var(--whats); color: #fff; font-weight: 700; font-size: .9rem;
  padding: 9px 15px; border-radius: 10px; text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
}
.nav-whats:hover { background: #1ebe5d; }

.rodape-link { color: var(--slate-500); text-decoration: underline; }
.rodape-link:hover { color: var(--slate-700); }

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

@media (max-width: 640px) {
  .topbar-inner { padding: 10px 14px; }
  .logo .regiao { display: none; }
  .nav { width: 100%; margin-left: 0; justify-content: space-between; }
  .nav-btn { padding: 8px 10px; font-size: .82rem; flex: 1; justify-content: center; }
  .nav-btn span.txt { display: none; }
  .nav-btn .badge { position: absolute; top: 2px; right: 6px; }
  .nav-btn { position: relative; }
  .section-head h1 { font-size: 1.25rem; }
  .meu-card { flex-direction: column; }
  .meu-card .card-img { width: 100%; aspect-ratio: 16/10; }
  .modal-acoes { flex-direction: column; }
  .modal-acoes .btn-fav-lg { justify-content: center; }

  .metrica .v { font-size: 1.3rem; }
  .metrica .l { font-size: .68rem; }

  .filtros-rodape { flex-direction: column; align-items: stretch; }
  .ordenar-wrap { justify-content: space-between; }
  .ordenar-wrap select { flex: 1; }
  .filtros-rodape .resultado-contagem { margin-left: 0; text-align: center; }
  .btn-limpar { width: 100%; }

  .lead-grid { grid-template-columns: 1fr; }

  /* Landing premium do cliente no celular (prioridade mobile) */
  .cp-hero { min-height: 82vh; padding: 84px 18px; }
  .cp-hero-ctas { flex-direction: column; }
  .cp-btn-whats, .cp-btn-ghost { width: 100%; justify-content: center; text-align: center; }
  .cp-selos { font-size: .82rem; gap: 6px 16px; }
  .cp-inst, .cp-imoveis, .cp-cta { padding: 44px 18px; }
  .cp-grid { grid-template-columns: 1fr; gap: 18px; }
  .nav-whats { flex: 1; justify-content: center; }
}
