.portal-listing-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 8px;
  pointer-events: auto;
}

.portal-result-media .portal-listing-badges {
  position: absolute;
  left: 10px;
  top: 10px;
  z-index: 4;
  margin: 0;
  max-width: calc(100% - 20px);
}

.detail-gallery-badges {
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 10;
  max-width: min(calc(100% - 120px), 520px);
  pointer-events: none;
}

.detail-gallery-badges .portal-listing-badges {
  position: static;
  margin: 0;
  max-width: none;
  pointer-events: auto;
}

.portal-listing-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 11px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.2;
  white-space: nowrap;
  text-transform: uppercase;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.12);
}

.portal-listing-badge--action {
  cursor: pointer;
}

.portal-listing-badge--action:hover,
.portal-listing-badge--action:focus-visible {
  filter: brightness(1.06);
  outline: 2px solid rgba(255, 255, 255, 0.65);
  outline-offset: 1px;
}

.portal-listing-badge--calcola-rata {
  background: #1d4ed8;
  color: #fff;
}

.portal-listing-badge--ottimo {
  background: #15803d;
  color: #fff;
}

.portal-listing-badge--nuovo {
  background: #d97706;
  color: #fff;
}

.portal-listing-badge--vista-mare,
.portal-listing-badge--vista-lago {
  background: #0284c7;
  color: #fff;
}

.portal-listing-badge--vista-parco {
  background: #059669;
  color: #fff;
}

.portal-listing-badge--panoramico {
  background: #6366f1;
  color: #fff;
}

.portal-listing-badge--classe-a {
  background: #15803d;
  color: #fff;
}

.portal-listing-badge--asta {
  background: #7c3aed;
  color: #fff;
}

.portal-listing-badge--ribassato {
  background: #dc2626;
  color: #fff;
}

.portal-listing-badge--esclusiva {
  background: #1e3a5f;
  color: #fff;
}

.portal-listing-badge--brand {
  background: var(--brand, #0f6b4b);
  color: #fff;
}

.portal-listing-badge--muted {
  background: #475569;
  color: #fff;
}

/* Scheda/elenco su foto: testo sempre bianco anche se altri CSS del dettaglio caricano dopo */
.detail-gallery-badges .portal-listing-badge,
.portal-result-media .portal-listing-badge {
  color: #fff !important;
}
