/* Portal Imóveis no Mapa — Grupo Zaluski · mobile-first */
:root{
  --brand:#0d6e4f; --brand2:#0a5a40; --accent:#f39c12; --bg:#f5f6f8;
  --text:#22303c; --muted:#67768a; --border:#e1e6ec; --white:#fff;
  --shadow:0 4px 18px rgba(20,40,60,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Segoe UI',system-ui,sans-serif;color:var(--text);background:var(--bg);overflow:hidden}

header{height:56px;background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 16px;position:relative;z-index:1200}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1rem}
.logo .pin{width:32px;height:32px;border-radius:9px;background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center}
.logo small{display:block;font-size:.6rem;font-weight:600;color:var(--muted);letter-spacing:.8px;text-transform:uppercase}

.filters{height:52px;background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;padding:0 16px;overflow-x:auto;position:relative;z-index:1190}
.filters select,.filters input{height:34px;border:1px solid var(--border);border-radius:8px;
  padding:0 10px;font-size:.85rem;background:#fff;min-width:120px}
.filters label{font-size:.7rem;color:var(--muted);font-weight:700;text-transform:uppercase;white-space:nowrap}
.count-pill{margin-left:auto;background:var(--brand);color:#fff;font-size:.76rem;font-weight:700;
  border-radius:16px;padding:6px 13px;white-space:nowrap}

.app{display:flex;height:calc(100% - 108px)}
#map{flex:1;height:100%}

aside{width:350px;background:var(--white);border-left:1px solid var(--border);
  overflow-y:auto;padding:12px;flex-shrink:0}
aside h2{font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:4px 2px 10px}
.vazio{font-size:.85rem;color:var(--muted);padding:8px}
.list-card{display:flex;gap:11px;border:1px solid var(--border);border-radius:11px;padding:9px;
  margin-bottom:9px;cursor:pointer;transition:.15s;background:#fff}
.list-card:hover{box-shadow:var(--shadow);border-color:var(--brand)}
.thumb{width:86px;height:72px;border-radius:8px;flex-shrink:0;background:#dfe6ee center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.list-card .info{min-width:0}
.list-card .price{font-weight:800;color:var(--brand);font-size:.92rem}
.list-card .title{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:2px 0}
.list-card .meta{font-size:.72rem;color:var(--muted)}
.tag-aprox{display:inline-block;font-size:.62rem;background:#fff4e0;color:#b9770e;border-radius:5px;padding:1px 6px;margin-top:3px}

.price-marker{background:var(--white);border:2px solid var(--brand);color:var(--brand);
  font-weight:800;font-size:.73rem;border-radius:16px;padding:3px 9px;white-space:nowrap;
  box-shadow:0 2px 8px rgba(0,0,0,.25)}
.price-marker:hover{background:var(--brand);color:#fff}
.price-marker.aprox{border-style:dashed}
/* Símbolos por nível de precisão (regras 1-4) */
.price-marker.prec-cidade{border-style:dotted;border-color:#e67e22;color:#b9770e;background:#fff8ec}
.price-marker.prec-bairro{border-style:dashed;border-color:#e6a817;color:#9c7700;background:#fffbef}
.price-marker.prec-rua{border-style:dashed;border-color:#2980b9;color:#1f618d;background:#f0f8ff}
.price-marker.prec-exato{border-style:solid}

/* Legenda de precisão */
.legenda-prec{position:absolute;bottom:18px;left:12px;z-index:1240;background:rgba(255,255,255,.95);
  border:1px solid var(--border);border-radius:10px;padding:8px 12px;font-size:.68rem;
  box-shadow:var(--shadow);line-height:1.8}
.legenda-prec b{display:block;font-size:.62rem;text-transform:uppercase;color:var(--muted);letter-spacing:.5px}
.legenda-prec .lp{display:inline-block;border:2px solid;border-radius:10px;padding:0 6px;margin-right:4px;font-weight:700}
.lp-cid{border-style:dotted;border-color:#e67e22;color:#b9770e}
.lp-rua{border-style:dashed;border-color:#2980b9;color:#1f618d}
.lp-ex{border-style:solid;border-color:var(--brand);color:var(--brand)}

.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:rgba(13,110,79,.25)}
.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{
  background:var(--brand);color:#fff;font-weight:700}

.basemap-ctl{position:absolute;top:124px;right:14px;z-index:1250;background:var(--white);
  border-radius:13px;box-shadow:var(--shadow);padding:9px;width:168px}
.basemap-ctl h4{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:2px 4px 7px}
.bm-opt{display:flex;align-items:center;gap:8px;border:2px solid transparent;border-radius:10px;
  padding:5px;cursor:pointer;transition:.13s;margin-bottom:3px}
.bm-opt:hover{background:var(--bg)}
.bm-opt.active{border-color:var(--brand);background:#eef7f3}
.bm-thumb{width:36px;height:36px;border-radius:8px;flex-shrink:0;display:flex;
  align-items:center;justify-content:center;font-size:1.05rem}
.t-ruas{background:linear-gradient(135deg,#aed6f1,#85c1e9)}
.t-sat{background:linear-gradient(135deg,#1e3d2f,#3b6b4f)}
.t-hib{background:linear-gradient(135deg,#2c4a3b,#6da482)}
.t-cad{background:linear-gradient(135deg,#f7dc9f,#e9b85c)}
.t-car{background:linear-gradient(135deg,#3b6b4f,#e8e337)}
.bm-opt span{font-size:.76rem;font-weight:700}
.bm-opt small{display:block;font-size:.62rem;color:var(--muted);font-weight:400}

.detail{position:absolute;top:124px;left:14px;width:372px;max-width:calc(100vw - 28px);
  max-height:calc(100% - 150px);background:var(--white);border-radius:15px;
  box-shadow:0 10px 40px rgba(10,30,50,.3);z-index:1300;overflow-y:auto;display:none}
.detail.open{display:block;animation:slideIn .2s ease}
@keyframes slideIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:none}}
.detail .gallery{height:180px;background:#dfe6ee center/cover no-repeat;border-radius:15px 15px 0 0;
  display:flex;align-items:center;justify-content:center;font-size:3rem}
.detail .close{position:absolute;top:10px;right:12px;background:rgba(0,0,0,.45);color:#fff;
  border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;z-index:2}
.detail .body{padding:14px 16px 16px}
.detail .price{font-size:1.4rem;font-weight:800;color:var(--brand)}
.detail .title{font-size:.98rem;font-weight:700;margin:3px 0 2px}
.detail .loc{font-size:.8rem;color:var(--muted);margin-bottom:10px}
.badge-aprox{background:#fff4e0;color:#b9770e;border:1px solid #f5d8a4;font-size:.74rem;
  font-weight:600;border-radius:8px;padding:6px 10px;margin-bottom:10px}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.chip{background:var(--bg);border:1px solid var(--border);border-radius:8px;font-size:.73rem;padding:4px 9px}
.chip b{color:var(--brand)}
.detail .desc{font-size:.84rem;color:var(--muted);margin-bottom:13px;white-space:pre-line}
.btn-row{display:flex;gap:8px;flex-wrap:wrap}
.btn{flex:1;min-width:120px;border:none;border-radius:10px;padding:11px 10px;font-size:.82rem;
  font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;
  text-decoration:none;transition:.15s}
.btn.site{background:var(--brand);color:#fff}.btn.site:hover{background:var(--brand2)}
.btn.sv{background:#fff;color:var(--text);border:1px solid var(--border)}
.btn.sv:hover{border-color:var(--accent);color:var(--accent)}
.poly-note{font-size:.72rem;color:var(--muted);margin-top:10px;display:flex;align-items:center;gap:6px}
.poly-swatch{width:14px;height:14px;border-radius:4px;background:rgba(243,156,18,.35);border:2px solid var(--accent)}
#svBox{margin-top:12px}
#svBox iframe{width:100%;height:230px;border:0;border-radius:10px}

@media(max-width:880px){
  aside{display:none}
  .detail{left:8px;right:8px;width:auto;top:116px}
  .basemap-ctl{top:116px;right:8px;width:148px}
}
