/* ===============================
   IMÓVEIS - GRID ESTILO MARKETPLACE
   (menu/footer não mexe)
================================ */

.imoveis-page{
  background: #fff;
}

/* HERO */
.imoveis-hero{
  padding: 46px 0 18px;
  background:
    radial-gradient(1200px 400px at 50% -60px, rgba(199,164,74,.14), transparent 55%),
    linear-gradient(180deg, #fbfaf7, #fff);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.imoveis-title{
  margin: 0;
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(30px, 4vw, 46px);
  letter-spacing: -0.6px;
  line-height: 1.05;
}

.imoveis-subtitle{
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.7;
  max-width: 70ch;
}

/* FILTROS */
.imoveis-filters{
  margin-top: 22px;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr auto;
  gap: 12px;
  align-items: center;
}

.imoveis-search,
.imoveis-select{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.86);
  padding: 12px 14px;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
  font-family: "Manrope", Verdana, Arial, sans-serif;
}

.imoveis-search:focus,
.imoveis-select:focus{
  outline: none;
  border-color: rgba(199,164,74,.55);
  box-shadow: 0 18px 38px rgba(0,0,0,.08);
}

/* TABS */
.imoveis-tabs{
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  flex-wrap: wrap;
}

.imoveis-tabs .tab{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(15,15,15,.04);
  color: #111;
  cursor:pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  font-weight: 800;
  font-family: "Manrope", Verdana, Arial, sans-serif;
}

.imoveis-tabs .tab:hover{
  transform: translateY(-1px);
  background: rgba(199,164,74,.10);
  border-color: rgba(199,164,74,.35);
}

.imoveis-tabs .tab.is-active{
  background: linear-gradient(180deg, rgba(199,164,74,.92), rgba(168,132,46,.92));
  border-color: rgba(0,0,0,.18);
  color: #111;
  font-weight: 900;
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
}

.imoveis-counter{
  margin-top: 12px;
  font-size: 13px;
  color: rgba(0,0,0,.52);
}

/* GRID */
.imoveis-grid-section{
  padding: 28px 0 64px;
}

.imoveis-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

/* CARD */
.im-card{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  box-shadow: 0 12px 30px rgba(0,0,0,.06);
  overflow: hidden;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.im-card:hover{
  transform: translateY(-3px);
  border-color: rgba(199,164,74,.30);
  box-shadow: 0 20px 48px rgba(0,0,0,.10);
}

/* mídia */
.im-media{
  position: relative;
  background: #111;
  height: 230px; /* parecido com print */
  overflow: hidden;
  cursor: pointer;
}

.im-media img{
  width: 100%;
  height: 100%;
  object-fit: cover; /* marketplace normalmente corta */
  display:block;
  transform: scale(1.01);
  transition: transform .25s ease;
}

.im-card:hover .im-media img{
  transform: scale(1.04);
}

.im-media-empty{
  width: 100%;
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(255,255,255,.7);
  font-weight: 800;
}

/* badges topo */
.im-badges{
  position:absolute;
  top: 12px;
  left: 12px;
  display:flex;
  gap: 8px;
}

.im-badge{
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  background: rgba(255,255,255,.92);
  color:#111;
  border: 1px solid rgba(0,0,0,.06);
}

/* “bolinhas” de carrossel fake */
.im-dots{
  position:absolute;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  display:flex;
  gap: 6px;
  opacity: .85;
}

.im-dots span{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
}

.im-dots span:nth-child(3){
  background: rgba(255,255,255,.95);
}

/* corpo */
.im-body{
  padding: 16px;
}

.im-desc{
  margin: 0 0 10px;
  font-size: 13px;
  color: rgba(0,0,0,.62);
  line-height: 1.5;
  min-height: 38px; /* segura altura tipo print */
}

.im-price{
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 4px;
}

.im-price-tag{
  font-size: 13px;
  font-weight: 700;
  color: rgba(0,0,0,.55);
  margin-left: 6px;
}

.im-total{
  font-size: 14px;
  color: rgba(0,0,0,.55);
  margin-bottom: 12px;
}

.im-total span{
  color: rgba(0,0,0,.45);
}

.im-facts{
  font-weight: 800;
  margin-bottom: 8px;
  color: rgba(0,0,0,.85);
}

.im-address{
  font-size: 13px;
  color: rgba(0,0,0,.55);
  margin-bottom: 12px;
}

/* ações */
.im-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* empty state */
.im-empty{
  padding: 18px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

/* responsivo */
@media (max-width: 980px){
  .imoveis-filters{
    grid-template-columns: 1fr 1fr;
  }
  .imoveis-tabs{
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .imoveis-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px){
  .imoveis-filters{
    grid-template-columns: 1fr;
  }
  .imoveis-tabs .tab{
    flex: 1;
  }
  .imoveis-grid{
    grid-template-columns: 1fr;
  }
}

.imoveis-footer{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
}

.imoveis-counterline{
  font-size: 13px;
  color: rgba(0,0,0,.55);
}
/* ===== Footer do grid: centraliza e destaca o botão ===== */
.imoveis-footer{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content: center; /* centraliza tudo */
  gap: 14px;
  flex-wrap: wrap;
}

.imoveis-counterline{
  font-size: 13px;
  color: rgba(0,0,0,.55);
}

/* Botão “Carregar mais” mais chamativo */
button[data-load-more]{
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 900;
  box-shadow: 0 14px 32px rgba(0,0,0,.10);
  border: 1px solid rgba(199,164,74,.28);
  background: linear-gradient(180deg, rgba(199,164,74,.14), rgba(15,15,15,.02));
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

button[data-load-more]:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 42px rgba(0,0,0,.14);
  filter: brightness(1.02);
}

button[data-load-more][disabled]{
  opacity: .75;
  cursor: not-allowed;
  transform: none;
}

/* ===== Voltar ao topo ===== */
.back-to-top{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 50;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.92);
  box-shadow: 0 16px 40px rgba(0,0,0,.12);

  font-weight: 900;
  cursor: pointer;

  opacity: 0;
  pointer-events: none;
  transform: translateY(6px);
  transition: opacity .15s ease, transform .15s ease;
}

.back-to-top.is-visible{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.back-to-top:hover{
  transform: translateY(-1px);
}

@media (max-width: 980px){
  .imoveis-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .imoveis-grid{ grid-template-columns: 1fr; }
  .back-to-top{ bottom: 86px; } /* idem */
}