/* Seção: Imóveis em Destaque */
.imoveis-destaque {
  position: relative;
  padding: 80px 0 100px 0;
  background: none;
  background-image: url('../img/destaqueimagem.svg?v=2');
  background-repeat: no-repeat;
  background-size: cover;
  background-position: left top;
  background-repeat: no-repeat;
  background-position: center;
  overflow: hidden;
}

/* Título */
.id-titulo {
  position: relative;
  z-index: 1;
  color: #6fc0ef;
  text-align: center;
  margin: 0 0 28px 0;
  font-family: 'Poppins', Arial, sans-serif;
  font-weight: 800;
  font-size: 2.6rem;
  text-transform: uppercase;
  letter-spacing: 2px;
}

/* Grid de cards */
.id-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

/* Card */
/* Cards alinhados ao design da página Imóveis */
.id-card { display:flex; flex-direction:column; text-decoration:none; background:#0f2d44; border-radius:6px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.12); transition:transform 0.2s ease, box-shadow 0.2s ease; height:100%; }
.id-card:hover { transform:translateY(-4px); box-shadow:0 14px 32px rgba(0,0,0,.18); }

/* Imagem */
.id-thumb { background-size:cover; background-position:center; height:140px; flex-shrink:0; }

/* Área informativa */
.id-info { background:rgba(8, 24, 39, 0.85); padding:12px 14px; color:#d8ecf7; flex:1; display:flex; flex-direction:column; min-height:110px; }
.id-badges { display:flex; gap:8px; margin-bottom:10px; flex-wrap:wrap; }
.id-badge { display:inline-block; padding:4px 10px; font-weight:700; font-size:0.75rem; letter-spacing:0.5px; border-radius:3px; }
.id-badge-tipo { background:#0e466e; color:#ffffff; }
.id-badge-negocio { background:#2ea1d4; color:#ffffff; }
.id-comodos { color:#8ad5ff; font-size:0.8rem; margin-bottom:6px; font-weight:600; letter-spacing:0.3px; }
.id-endereco { color:#d8ecf7; font-size:0.85rem; margin-bottom:8px; font-weight:500; }
.id-descricao { color:#d8ecf7; font-size:0.9rem; line-height:1.4; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; flex:1; }

/* Faixa de preço */
.id-preco-wrap { display:flex; align-items:stretch; background:#2ea1d4; flex-shrink:0; margin-top:auto; }
.id-preco { flex:1; color:#ffffff; font-weight:800; font-size:1.15rem; padding:12px 14px; display:flex; align-items:center; }
.id-extras { display:flex; flex-direction:column; justify-content:center; gap:4px; padding:8px 12px; font-size:0.7rem; color:#ffffff; background:rgba(0,0,0,0.2); border-left:1px solid rgba(255,255,255,0.2); min-width:120px; }
.id-extra-item { display:block; line-height:1.3; white-space:nowrap; }

/* CTA inferior */
.id-cta { position: relative; z-index: 1; text-align: center; margin-top: 22px; }
.id-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  text-decoration: none;
  padding: 0 20px;
  margin-top: 0;
  margin-bottom: 0;
  border-radius: 0;
  font-family: 'Poppins', Arial, sans-serif;
  font-weight: 400;
  letter-spacing: .4px;
  text-transform: uppercase;
  background: linear-gradient(90deg,
    var(--brandBlueDark, #0e3b62) 0%,
    var(--brandBlueMid, #0c619a) 50%,
    var(--brandBlueLight, #069cf1) 100%);
  transition: filter .25s ease;
  line-height: 1;
  margin-left: 12px;
  margin-right: 12px;
  height: 48px;
}
.id-btn:hover { filter: brightness(1.05); }

/* Responsivo */
@media (max-width: 1200px) {
  .id-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 920px) {
  .id-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .id-grid { grid-template-columns: 1fr; }
  .id-thumb { height: 200px; }
} 

/* Reuso do CSS do modal da listagem */
.modal-imovel { 
  display:none; 
  position:fixed; 
  z-index:99999; 
  left:0; 
  top:0; 
  width:100%; 
  height:100%; 
  background:rgba(0,0,0,0.9); 
  align-items:center; 
  justify-content:center;
  backdrop-filter:blur(5px);
  animation:modalFadeIn 0.3s ease-out;
}

@keyframes modalFadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes modalSlideIn { from { transform:translateY(50px) scale(0.9); opacity:0; } to { transform:translateY(0) scale(1); opacity:1; } }
@keyframes modalSlideOut { from { transform:translateY(0) scale(1); opacity:1; } to { transform:translateY(-30px) scale(0.95); opacity:0; } }
@keyframes modalFadeOut { from { opacity:1; } to { opacity:0; } }

.modal-imovel-conteudo { position:relative; max-width:900px; max-height:85vh; background:#fff; border-radius:12px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 15px 35px rgba(0,0,0,0.3); animation:modalSlideIn 0.4s ease-out; }
.modal-fechar { position:absolute; top:15px; right:20px; color:#fff; font-size:24px; font-weight:300; cursor:pointer; z-index:100001; background:rgba(0,0,0,0.6); width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all 0.3s ease; border:1px solid rgba(255,255,255,0.2); }
.modal-fechar:hover { background:rgba(231,76,60,0.9); transform:scale(1.1); border-color:rgba(255,255,255,0.4); }
.modal-info { padding:12px 20px; background:#f8f9fa; color:#495057; border-top:1px solid #dee2e6; position:relative; }
.modal-info h2 { margin:0 0 8px; font-size:16px; font-weight:600; color:#212529; text-align:center; }
.modal-meta { display:grid; grid-template-columns:1fr 1fr; gap:6px 15px; font-size:11px; line-height:1.4; }
.modal-meta-row { display:flex; justify-content:space-between; align-items:center; padding:4px 0; border-bottom:1px solid #e9ecef; }
.modal-meta-row:last-child { border-bottom:none; }
.modal-meta-label { font-weight:500; color:#6c757d; display:flex; align-items:center; gap:4px; font-size:10px; }
.modal-meta-label i { font-size:10px; color:#adb5bd; }
.modal-meta-value { font-weight:600; color:#212529; font-size:11px; }
.modal-meta-preco { grid-column:1 / -1; text-align:center; padding:6px; background:linear-gradient(135deg, #e3f2fd 0%, #f3e5f5 100%); border-radius:6px; margin-top:4px; }
.modal-meta-preco .modal-meta-value { font-size:16px; font-weight:700; color:#1976d2; }
.modal-galeria { position:relative; width:100%; height:450px; display:flex; align-items:center; justify-content:center; background:linear-gradient(45deg, #000 0%, #1a1a1a 100%); overflow:hidden; }
.modal-galeria img { max-width:100%; max-height:100%; object-fit:contain; border-radius:0; transition:all 0.4s ease; opacity:1; }
.modal-galeria:hover img { transform:scale(1.02); }
.modal-nav { position:absolute; background:rgba(0,0,0,0.7); color:#fff; border:none; padding:12px; font-size:20px; cursor:pointer; z-index:10000; transition:all 0.3s ease; border-radius:50%; width:45px; height:45px; display:flex; align-items:center; justify-content:center; border:1px solid rgba(255,255,255,0.2); }
.modal-nav:hover { background:rgba(46,161,212,0.8); transform:scale(1.05); border-color:rgba(255,255,255,0.3); box-shadow:0 3px 10px rgba(46,161,212,0.3); }
.modal-prev { left:20px; }
.modal-next { right:20px; }
.modal-contador { padding:8px; text-align:center; background:linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%); color:#6c757d; font-size:11px; font-weight:500; border-top:1px solid rgba(0,0,0,0.08); position:relative; }
.modal-contador::before { content:''; position:absolute; top:0; left:50%; transform:translateX(-50%); width:40px; height:2px; background:linear-gradient(135deg, #2ea1d4 0%, #1e88e5 100%); border-radius:0 0 2px 2px; }

@media (max-width: 1080px) { .modal-prev { left:15px; } .modal-next { right:15px; } .modal-imovel-conteudo { max-width:95%; } .modal-galeria { height:400px; } }
@media (max-width: 920px) { .modal-info { padding:10px 15px; } .modal-info h2 { font-size:14px; } .modal-meta { grid-template-columns:1fr; gap:4px; } .modal-meta-preco .modal-meta-value { font-size:14px; } .modal-galeria { height:350px; } }
@media (max-width: 768px) { .modal-imovel-conteudo { max-width:98%; max-height:95vh; border-radius:15px; } .modal-galeria { height:320px; } .modal-nav { width:40px; height:40px; font-size:18px; padding:10px; } .modal-fechar { width:35px; height:35px; font-size:20px; top:12px; right:15px; } }
@media (max-width: 560px) { .modal-galeria { height:280px; } .modal-nav { width:35px; height:35px; font-size:16px; } .modal-prev { left:8px; } .modal-next { right:8px; } .modal-contador { padding:6px; font-size:10px; } }