/* ============================================================================
   site_base.css — estrutura compartilhada dos 4 templates do Tova.
   Cada família (site_tata/oga/vera/ava.css) define as variáveis e a cara.
   DNA: mobile-first, 1 CTA, preço total, ficha tem/não-tem, selos honestos.
   ============================================================================ */
:root {
  --p: #C2613B;          /* cor primária (CTA) */
  --p-escuro: #9E4A2A;
  --sec: #243B38;        /* cor secundária (nav/hero) */
  --bg: #FFFFFF;
  --bg-suave: #F7F5F0;
  --tx: #1C1A16;
  --tx-suave: #6B6458;
  --linha: #E8E3DA;
  --card-bg: #FFFFFF;
  --rad: 14px;
  --fonte: 'Plus Jakarta Sans', sans-serif;
  --wa: #1FA855;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--fonte); background: var(--bg); color: var(--tx); line-height: 1.6; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
.container { max-width: 1080px; margin: 0 auto; padding: 0 18px; }

/* ---- barra de preview (só aparece com ?tpl=) ---- */
.preview-bar { background: #1C1A16; color: #fff; font-size: 12.5px; padding: 8px 16px; text-align: center; }
.preview-bar a { color: #F0B27A; font-weight: 700; margin: 0 4px; text-decoration: underline; }

/* ---- nav ---- */
.nav-site { background: var(--bg); border-bottom: 1px solid var(--linha); position: sticky; top: 0; z-index: 50; }
.nav-site .container { display: flex; align-items: center; gap: 18px; padding-top: 13px; padding-bottom: 13px; }
.nav-site .logo { font-weight: 800; font-size: 18px; letter-spacing: -0.3px; }
.nav-site nav { margin-left: auto; display: flex; align-items: center; gap: 18px; font-size: 14px; font-weight: 600; }
.nav-site nav a { color: var(--tx-suave); }
.nav-site nav a.btn-cta, .nav-site nav a.nav-tel, .nav-site nav a.nav-conversa { color: #fff; }

/* ---- botões ---- */
.btn-cta { display: inline-block; background: var(--p); color: #fff !important; font-weight: 700; font-size: 14.5px;
  border: none; border-radius: 99px; padding: 11px 22px; cursor: pointer; font-family: inherit; text-align: center; }
.btn-cta:hover { background: var(--p-escuro); }
.btn-wa { background: var(--wa) !important; }
.btn-wa:hover { background: #178A45 !important; }
.btn-sec { background: var(--sec) !important; }

/* ---- hero base ---- */
.hero { padding: 52px 0 46px; background: var(--bg-suave); }
.hero h1 { font-size: clamp(26px, 4.5vw, 40px); font-weight: 800; letter-spacing: -1px; line-height: 1.18; }
.hero p { color: var(--tx-suave); margin-top: 8px; font-size: 16px; }

/* ---- busca ---- */
.busca { display: flex; gap: 8px; margin-top: 20px; background: #fff; border: 1px solid var(--linha);
  border-radius: 14px; padding: 8px; flex-wrap: wrap; }
.busca select, .busca input { flex: 1 1 140px; border: none; background: var(--bg-suave); border-radius: 9px;
  padding: 11px 13px; font-family: inherit; font-size: 14px; color: var(--tx); min-width: 0; }
.busca select:focus, .busca input:focus { outline: 2px solid var(--p); }
.busca .btn-cta { flex: 0 0 auto; }
.chips-busca { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; }
.chips-busca a { font-size: 12.5px; font-weight: 600; background: #fff; border: 1px solid var(--linha);
  border-radius: 99px; padding: 5px 14px; color: var(--tx-suave); }
.chips-busca a:hover { border-color: var(--p); color: var(--p); }

/* ---- grade de cards ---- */
.sec-imoveis { padding: 40px 0 8px; }
.sec-imoveis h2 { font-size: 22px; font-weight: 800; letter-spacing: -0.5px; margin-bottom: 18px; }
.grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 16px; }
.vazio { color: var(--tx-suave); padding: 24px 0; }
.vazio a { color: var(--p); font-weight: 700; }

.card { background: var(--card-bg); border: 1px solid var(--linha); border-radius: var(--rad); overflow: hidden;
  display: block; transition: transform .15s ease, box-shadow .15s ease; }
.card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(28, 26, 22, .10); }
.card-foto { height: 150px; position: relative; display: flex; align-items: center; justify-content: center; }
.card-emoji { font-size: 40px; opacity: .9; }
.card-nfotos { position: absolute; right: 9px; bottom: 8px; background: rgba(0,0,0,.45); color: #fff;
  font-size: 11px; border-radius: 99px; padding: 2px 9px; }
.g0 { background: linear-gradient(135deg, #C2613B, #9E4A2A); }
.g1 { background: linear-gradient(135deg, #243B38, #3E7A4E); }
.g2 { background: linear-gradient(135deg, #3B5E9E, #243B38); }
.g3 { background: linear-gradient(135deg, #8B857A, #5C574E); }
.selo { position: absolute; top: 9px; left: 9px; font-size: 10.5px; font-weight: 800; letter-spacing: .6px;
  text-transform: uppercase; border-radius: 99px; padding: 3px 10px; color: #fff; }
.selo-novo { background: var(--wa); }
.selo-alta { background: var(--p); }
.selo-res { background: #1C1A16; }
.card-foto.tem-foto, .galeria.tem-foto { background-size: cover; background-position: center; }
.galeria-thumbs { display: flex; gap: 7px; margin-top: 8px; overflow-x: auto; padding-bottom: 4px; }
.galeria-thumbs img { width: 74px; height: 54px; object-fit: cover; border-radius: 8px; cursor: pointer;
  border: 2px solid transparent; flex: 0 0 auto; }
.galeria-thumbs img:hover { border-color: var(--p); }
.card-bd { padding: 13px 15px 15px; }
.card-preco { font-size: 19px; font-weight: 800; letter-spacing: -0.4px; }
.card-preco small { font-size: 12px; font-weight: 600; color: var(--tx-suave); }
.card-total { font-size: 12px; color: var(--tx-suave); margin-top: 1px; }
.card-tit { font-size: 14px; font-weight: 600; margin-top: 7px; line-height: 1.4; }
.card-loc { font-size: 12.5px; color: var(--tx-suave); margin-top: 2px; }
.specs { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.specs span { font-size: 11.5px; font-weight: 600; background: var(--bg-suave); border-radius: 99px;
  padding: 3px 10px; color: var(--tx-suave); }
.specs .sp-suite { background: var(--p); color: #fff; }

/* ---- página do imóvel ---- */
.migalha { padding: 16px 18px 0; font-size: 13.5px; }
.migalha a { color: var(--tx-suave); font-weight: 600; }
.det { display: grid; grid-template-columns: 1.4fr .9fr; gap: 26px; padding-top: 18px; padding-bottom: 56px; }
.det-main h1 { font-size: clamp(22px, 3.4vw, 30px); font-weight: 800; letter-spacing: -0.7px; margin-top: 18px; line-height: 1.25; }
.det-loc { color: var(--tx-suave); font-size: 14px; margin: 4px 0 10px; }
.galeria { height: 300px; border-radius: var(--rad); position: relative; display: flex; align-items: center;
  justify-content: center; }
.galeria .card-emoji { font-size: 64px; }
.galeria-aviso { position: absolute; right: 12px; bottom: 10px; background: rgba(0,0,0,.45); color: #fff;
  font-size: 12px; border-radius: 99px; padding: 3px 12px; }
.poi { display: flex; gap: 7px; flex-wrap: wrap; margin: 12px 0 4px; }
.poi span { font-size: 12px; font-weight: 600; background: var(--bg-suave); border: 1px solid var(--linha);
  border-radius: 99px; padding: 4px 12px; color: var(--tx-suave); }
.det-texto { margin-top: 16px; font-size: 15px; color: var(--tx); white-space: pre-line; }
.det-sub { font-size: 16px; font-weight: 800; margin: 26px 0 12px; }
.temtem { display: flex; gap: 7px; flex-wrap: wrap; }
.temtem span { font-size: 12.5px; font-weight: 600; border-radius: 99px; padding: 5px 13px; }
.temtem .tem { background: #E7F0E9; color: #2C5E3A; }
.temtem .naotem { background: var(--bg-suave); color: var(--tx-suave); border: 1px dashed var(--linha); }
.simulador { margin-top: 24px; background: var(--bg-suave); border: 1px solid var(--linha); border-radius: var(--rad);
  padding: 16px 18px; font-size: 14px; }
.simulador p { margin-top: 4px; }
.simulador small { color: var(--tx-suave); font-size: 12px; display: block; margin-top: 6px; }

.det-aside { position: sticky; top: 76px; align-self: start; display: flex; flex-direction: column; gap: 14px; }
.tprecos { background: var(--card-bg); border: 1px solid var(--linha); border-radius: var(--rad); padding: 16px 18px; }
.tp-l { display: flex; justify-content: space-between; font-size: 14px; padding: 6px 0; }
.tp-l b { font-weight: 700; }
.tp-total { border-top: 2px solid var(--tx); margin-top: 6px; padding-top: 10px; font-size: 15px; }
.tp-total b { font-size: 17px; }
.det-aside .btn-cta { width: 100%; }
.termo-box { border-radius: var(--rad); padding: 13px 16px; font-size: 13.5px; }
.termo-box small { display: block; font-size: 11.5px; opacity: .8; margin-top: 3px; }
.termo-box.t-abaixo { background: #E9EEF6; color: #2A4470; }
.termo-box.t-no_preco { background: #E7F0E9; color: #2C5E3A; }
.termo-box.t-acima { background: #FBEAE6; color: #8A3526; }

/* ---- formulários (lead/alerta) ---- */
.lead-box, .alerta-box { background: var(--card-bg); border: 1px solid var(--linha); border-radius: var(--rad); padding: 18px; }
.lead-box h3 { font-size: 16px; font-weight: 800; }
.lead-box p, .alerta-box p { font-size: 13px; color: var(--tx-suave); margin: 3px 0 12px; }
.lead-box form, .alerta-box form { display: flex; flex-direction: column; gap: 9px; }
.lead-box input, .lead-box select, .alerta-box input { border: 1px solid var(--linha); background: var(--bg-suave);
  border-radius: 9px; padding: 11px 13px; font-family: inherit; font-size: 14px; color: var(--tx); }
.lead-box input:focus, .lead-box select:focus, .alerta-box input:focus { outline: 2px solid var(--p); }
.ok { background: #E7F0E9; color: #2C5E3A; font-size: 13.5px; font-weight: 600; border-radius: 9px;
  padding: 10px 13px; margin-bottom: 12px; }
.lgpd { font-size: 11px; color: var(--tx-suave); line-height: 1.45; }
.alerta-box { margin: 26px 0 0; display: grid; grid-template-columns: 1fr 1.2fr; gap: 18px; align-items: center; }
.alerta-box .ok { grid-column: 1 / -1; margin-bottom: 0; }
.alerta-box b { font-size: 16px; }
.alerta-box form { flex-direction: row; flex-wrap: wrap; }
.alerta-box form input { flex: 1 1 150px; }

/* ---- avalie seu imóvel (captação de proprietário) ---- */
.avalie { margin: 22px 0 0; background: var(--sec); color: #fff; border-radius: var(--rad); padding: 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.avalie b { font-size: 18px; }
.avalie p { font-size: 13.5px; opacity: .85; margin-top: 2px; }

/* ---- rodapé + flutuantes ---- */
.rodape-site { margin-top: 52px; border-top: 1px solid var(--linha); padding: 26px 0 80px; }
.rodape-site .container { display: flex; gap: 6px 22px; align-items: baseline; flex-wrap: wrap; }
.rod-nome { font-weight: 800; font-size: 15px; }
.rod-info { font-size: 13px; color: var(--tx-suave); }
.rod-selo { margin-left: auto; font-size: 12px; color: var(--tx-suave); }
.wa-float { position: fixed; right: 18px; bottom: 18px; width: 54px; height: 54px; border-radius: 50%;
  background: var(--wa); color: #fff; display: flex; align-items: center; justify-content: center;
  font-size: 26px; box-shadow: 0 8px 22px rgba(31, 168, 85, .45); z-index: 60; }
.sticky-cta { display: none; }

/* ---- responsivo ---- */
@media (max-width: 860px) {
  .det { grid-template-columns: 1fr; }
  .det-aside { position: static; }
  .alerta-box { grid-template-columns: 1fr; }
  .galeria { height: 220px; }
  .nav-site nav a:not(.btn-cta):not(.nav-tel):not(.nav-conversa) { display: none; }
  /* CTA fixo no rodapé do celular (padrão QuintoAndar) — só na pág. do imóvel */
  .sticky-cta { display: flex; gap: 10px; position: fixed; left: 0; right: 0; bottom: 0; z-index: 70;
    background: var(--bg); border-top: 1px solid var(--linha); padding: 10px 14px; }
  .sticky-cta .btn-cta { flex: 1; }
  .det ~ .sticky-cta ~ .wa-float, body:has(.sticky-cta) .wa-float { display: none; }
}

/* logo da imobiliária na barra (enviado no painel; favicon gerado dele) */
.logo-img { height: 32px; width: auto; vertical-align: middle; margin-right: 9px; border-radius: 6px; }
