
.rc-filter--bar{
  display:flex; gap:.75rem; align-items:center;
  background:#fff; padding:.75rem; border-radius:.75rem;
  box-shadow:0 6px 20px rgba(0,0,0,.08);
}
.rc-filter__field{ flex:1; position:relative; }
.rc-filter__field select{
  width:100%; appearance:none; -webkit-appearance:none;
  background:#fff; border:1px solid rgba(0,0,0,.15);
  border-radius:.5rem; padding:.9rem 2.25rem .9rem .9rem;
  font-size:1rem; line-height:1.2;
}
.rc-filter__submit{
  white-space:nowrap; padding:.9rem 1.2rem; border-radius:.5rem; border:0;
  background:#ffb74d; color:#000; font-weight:700; cursor:pointer;
}
.rc-filter__submit:focus-visible,
.rc-filter__field select:focus-visible{
  outline:3px solid #ffb74d; outline-offset:2px;
}
@media (max-width: 768px){
  .rc-filter--bar{ flex-direction:column; align-items:stretch; }
}

/* seta custom no fim do select */
.rc-filter__field { position: relative; }

/* esconde a seta nativa e dá espaço pra nossa seta */
.rc-filter__field select{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #fff;                 /* mantém o fundo */
  padding-right: 2.5rem;            /* espaço para a seta */
}

/* IE/Edge legado: some com a seta nativa */
.rc-filter__field select::-ms-expand { display: none; }

/* a seta (SVG embutido) */
.rc-filter__field::after{
  content: "";
  position: absolute;
  top: 50%;
  right: .75rem;                    /* distância da borda direita */
  width: 12px;
  height: 8px;
  transform: translateY(-50%);
  pointer-events: none;             /* não bloqueia o clique no select */
  background-repeat: no-repeat;
  background-size: 100% 100%;
  /* cinza padrão */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  transition: filter .15s, transform .15s;
}

/* destaque no foco (escurece e rotaciona levemente) */
.rc-filter__field:focus-within::after{
  filter: brightness(0.5);
  transform: translateY(-50%) rotate(0.0001deg); /* mantém o anti-aliasing */
}

/* estado desabilitado (ex.: Bairro antes de escolher Cidade) */
.rc-filter__field select:disabled{
  color: #9e9e9e;
}
.rc-filter__field select:disabled ~ .rc-filter__field::after{} /* só pra clareza */

/* (opcional) usar a cor da marca no hover/foco */
.rc-filter__field:hover::after,
.rc-filter__field:focus-within::after{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23ff6f00' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* Zera bullets e prepara a lista */
.projects__list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-wrap:wrap;
  margin-left:-16px; margin-right:-16px; /* gutter simétrico */
}

/* Cada card com padding-gutter */
.projects__list .projects__item{
  box-sizing:border-box;
  padding-left:16px; padding-right:16px; margin-bottom:32px;
  width:25%;           /* 4 colunas no desktop */
}

/* 3 colunas em telas médias */
@media (max-width:1199px){
  .projects__list .projects__item{ width:33.333%; }
}

/* 2 colunas no mobile */
@media (max-width:767px){
  .projects__list .projects__item{ width:50%; }
}

/* Imagem ocupa toda a largura do card */
.projects__list img{ display:block; width:100%; height:auto; }


/* chips dos filtros ativos */
.rc-active-filters{
  display:flex; flex-wrap:wrap; gap:8px;
  margin: 8px 0 16px;
}
.rc-chip{
  background:#f6f6f6; border:1px solid #e6e6e6; color:#333;
  padding:6px 10px; border-radius:999px; font-weight:500; font-size:.95rem;
}
.rc-chip--clear{ background:#fff; border-color:#ddd; text-decoration:none; }

/* aviso de fallback (sem bairro) */
.rc-notice{
  background:#fff8e1; border:1px solid #ffe0a3; color:#6b4e00;
  padding:10px 12px; border-radius:8px; margin: 0 0 16px;
}
.rc-notice em{ font-style:normal; font-weight:600; }
.rc-notice__action{ margin-left:8px; font-weight:700; }

/* Base para posicionar overlay na imagem */
.card__image{ position:relative; overflow:hidden; }

/* Gradiente + texto branco sobre a foto */
.card__overlay{
  position:absolute; left:0; right:0; bottom:0;
  padding:16px 18px 14px;
  color:#fff;
  z-index:2;
}
.card__image::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0; height:52%;
  background:linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,.0));
  z-index:1;
}

/* Título sobre a imagem */
.card__heading--overlay{
  margin:0 0 6px;
  color:#fff !important;
  text-shadow:0 1px 1px rgba(0,0,0,.35);
  line-height:1.15;
}

/* Bullets (tipo · cidade · bairro) */
.card__meta{
  list-style:none; margin:0; padding:0;
  display:flex; flex-wrap:wrap; gap:8px 12px;
  font-size:.9rem; z-index:2; position:relative;
}
.card__meta li{ margin:0; padding:0; opacity:.95; }
.card__meta li + li{ position:relative; }
.card__meta li + li::before{
  content:"•"; margin-right:8px; opacity:.7;
}

/* estado normal: overlay visível */
.card__overlay{
  transform: translateY(0);
  opacity: 1;
  transition: transform .3s ease, opacity .3s ease;
  will-change: transform, opacity;
}

/* gradiente acompanha o overlay */
.card__image::after{
  transform: translateY(0);
  opacity: 1;
  transition: transform .3s ease, opacity .3s ease;
  will-change: transform, opacity;
}

/* no hover, desce e some (apenas em dispositivos com hover) */
@media (hover:hover){
  .card:hover .card__overlay{
    transform: translateY(100%);
    opacity: 0;
  }
  .card:hover .card__image::after{
    transform: translateY(100%);
    opacity: 0;
  }
}

.card:focus-within .card__overlay,
.card:focus-within .card__image::after{
  transform: translateY(0);
  opacity: 1;
}

/* seu template usa .rc-list como wrapper */
.rc-list .card__content .card__heading{
  display: block !important;
}

/* ------ Pills com borda para os itens de meta ------ */
.card__meta{
  list-style:none; margin:0; padding:0;
  display:flex; flex-wrap:wrap; gap:8px;
}

/* estilo padrão (fundo claro) */
.card__meta li{
  display:inline-flex; align-items:center;
  padding:6px 10px;
  border:1px solid rgba(0,0,0,.2);
  border-radius:999px;
  font-size:.85rem; line-height:1; font-weight:500;
  color:#222; background:rgba(0,0,0,.03);
}

/* quando estiver sobre a imagem (dentro do overlay) */
.card__overlay .card__meta li{
  color:#fff;
  border-color:rgba(255,255,255,.75);
  background:rgba(255,255,255,.08);
  /* opcional, dá um “vidro” suave: */
  /* backdrop-filter: blur(2px); */
}

/* remove o separador antigo (•) entre os itens */
.card__meta li+li::before{ content:none !important; }

/* compacto em telas muito pequenas */
@media (max-width: 420px){
  .card__meta{ gap:6px; }
  .card__meta li{ padding:5px 9px; font-size:.8rem; }
}


