/* ===========================
   GBF – Imóveis Similares
   =========================== */

.gbf-sim-wrap{
  margin: 2rem 0;
  /* alinhamento entre cabeçalho e cards */
  --edge: 12px;   /* respiro lateral compartilhado */
  --gap: 16px;    /* gap entre cards */
}

/* ===== Cabeçalho ===== */
.gbf-sim-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:.75rem;
  /* alinhado às bordas dos cards */
  padding-inline: var(--edge);
}
.gbf-sim-head h2{
  margin:0;
  line-height:1.3;
  font-family:Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  font-weight:500;
  font-size:24px;
  color:#2A2A2A;
}
@media (max-width: 767px){
  .gbf-sim-head h2{ font-size:20px; }
}

/* ===== Controles ===== */
.gbf-sim-ctrls{ display:flex; gap:.5rem; align-items:center; }

.gbf-sim-btn{
  width:44px; height:44px;
  display:inline-flex; align-items:center; justify-content:center;
  border:0; border-radius:999px;
  background: rgba(0,0,0,.55);
  color:#fff;
  cursor:pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
  transition: background-color .25s ease, box-shadow .25s ease;
  position:relative;
  font-size:0; line-height:1;
  outline:none;
}
/* desliga seta antiga */
.gbf-sim-btn::before{ content:none !important; }
/* seta via SVG */
.gbf-sim-btn svg{
  width:18px; height:18px;
  display:block; fill:currentColor; pointer-events:none;
  transform: translateY(-0.5px);
}
.gbf-sim-btn[data-dir="prev"] svg{
  transform: translateY(-0.5px) rotate(180deg);
}
.gbf-sim-btn:hover,
.gbf-sim-btn:focus{ background: rgba(0,0,0,.75); }
.gbf-sim-btn:active{ background: rgba(0,0,0,.90); }
.gbf-sim-btn:focus-visible{
  outline:none;
  box-shadow: 0 0 0 2px rgba(255,255,255,.45), 0 4px 16px rgba(0,0,0,.25);
}
/* Esconde setas no mobile, mostra no desktop */
@media (max-width: 768px){ .gbf-sim-ctrls{ display:none; } }
@media (min-width:1024px){ .gbf-sim-ctrls{ display:flex; } }

/* ===== Carrossel (ajuste anti-filete) ===== */
.gbf-sim-row{
  display:grid;
  grid-auto-flow:column;
  gap: var(--gap);

  /* mobile: cards largos */
  grid-auto-columns: 80%;

  overflow-x:auto;
  scroll-snap-type:x mandatory;

  box-sizing:border-box;
  padding: 0 var(--edge) .25rem;         /* respiro nas laterais */
  scroll-padding-inline: var(--edge);    /* snap respeita o padding */

  -ms-overflow-style:none;
  scrollbar-width:none;
}
.gbf-sim-row::-webkit-scrollbar{ display:none; }

/* Tablet: 2 cards visíveis, sem vazar */
@media (min-width:640px){
  .gbf-sim-row{
    grid-auto-columns: calc((100% - (1 * var(--gap))) / 2 - 0.75px);
  }
}
/* Desktop: 4 cards visíveis, sem aparecer o 5º */
@media (min-width:1024px){
  .gbf-sim-row{
    grid-auto-columns: calc((100% - (3 * var(--gap))) / 4 - 0.75px);
  }
}

/* ===== Card ===== */
.gbf-sim-card{
  position:relative;
  scroll-snap-align:start;
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 8px 24px rgba(0,0,0,.06) !important;
  margin-bottom:10px;
  transform:translateY(0);
  transition:box-shadow .25s ease, transform .25s ease;
  isolation:isolate;
}
.gbf-sim-card:hover{
  box-shadow:0 12px 28px rgba(0,0,0,.12) !important;
  transform:translateY(-2px);
}

/* Imagem */
.gbf-sim-img{ display:block; background:#f3f3f3; }
.gbf-sim-img img{
  display:block;
  width:100%;
  height:220px;
  object-fit:cover;
}

/* Corpo */
.gbf-sim-body{
  padding:14px 16px 16px;
  display:flex; flex-direction:column; flex-grow:1;
}
.gbf-sim-tax{ font-size:.8rem; opacity:.7; margin-bottom:.25rem; }

/* Título/descrição */
.gbf-card-title{
  margin:0 0 6px;
  font-size:16px;
  font-weight:500;
  line-height:1.35;
}
.gbf-card-title a{ color:#111; text-decoration:none; }
.gbf-card-title a:hover{ text-decoration:underline; }
.gbf-card-excerpt{
  margin:0 0 10px;
  font-size:14px;
  line-height:1.45;
  color:#555;
}

/* Meta e preço */
.gbf-sim-meta{
  display:flex; align-items:center; flex-wrap:wrap;
  gap:10px;
  row-gap:6px;
  color:#2b2b2b; font-size:.9rem; opacity:.9;
}
.gbf-sim-price{
  margin-top:auto;
  padding-top:12px;
  font-size:16px;
  font-weight:500;
  color:#111;
}

/* Neutraliza cor global de <a> dentro da seção */
.gbf-sim-wrap a{ color:inherit; }

/* ===== CTA “vidro” ===== */
.gbf-sim-card--cta .gbf-sim-cta{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  border-radius:inherit; z-index:5;
  text-decoration:none;
  font-weight:700; font-size:1.05rem; letter-spacing:.2px;
  color:#fff; text-shadow:0 2px 6px rgba(0,0,0,.25);
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(4px) saturate(120%);
  -webkit-backdrop-filter:blur(4px) saturate(120%);
  box-shadow:0 4px 16px rgba(0,0,0,.06);
}
.gbf-sim-card--cta .gbf-sim-cta:hover{
  background:rgba(255,255,255,.20);
  border-color:rgba(255,255,255,.26);
}
@supports not (backdrop-filter:blur(1px)){
  .gbf-sim-card--cta .gbf-sim-cta{
    background:rgba(255,255,255,.82);
    border-color:rgba(0,0,0,.06);
    box-shadow:0 2px 10px rgba(0,0,0,.05);
  }
}

/* imagem responsiva – limite de altura */
.gbf-sim-img img{ height: clamp(200px, 32vw + 80px, 220px); }

/* Ícone de localização no verde padrão */
.gbf-sim-loc .elementor-icon-list-icon svg path{ fill:#009049; }
.gbf-sim-loc .elementor-icon-list-icon svg{ width:16px; height:16px; }

/* clamp do título */
.gbf-card-title{ line-height:1.35; }
.gbf-card-title__clamp{
  display: -webkit-box !important;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  white-space: normal !important;
  line-height: 1.35;
  height: calc(2 * 1.35em);
  max-height: calc(2 * 1.35em);
  width: 100%;
}
.elementor-widget-heading .gbf-card-title__clamp{
  display: -webkit-box !important;
}

/* Fonte Roboto em todos os blocos do card */
.gbf-sim-card,
.gbf-card-title,
.gbf-card-excerpt,
.gbf-sim-meta,
.gbf-sim-price,
.gbf-sim-loc .elementor-icon-list-text,
.gbf-sim-feats .elementor-icon-list-text{
  font-family: Roboto, system-ui, -apple-system, "Segoe UI", Arial, sans-serif !important;
}

/* Botão desabilitado (início/fim do carrossel) */
.gbf-sim-btn[aria-disabled="true"]{
  background: rgba(0,0,0,.15);
  color: #fff;
  opacity: .5;
  pointer-events: none;  /* não clica */
  box-shadow: none;
  cursor: default;       /* opcional: evita mãozinha */
}

.gbf-sim-btn[aria-disabled="true"]:hover,
.gbf-sim-btn[aria-disabled="true"]:focus{
  background: rgba(0,0,0,.15);
  box-shadow: none;
}


