.cnb-has-badges,
.product-tile {
  position: relative;
}

.cnb-badges {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 11;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  max-width: calc(100% - 20px);
}

.cnb-badges--single {
  position: static;
  margin: 0 0 12px;
  flex-direction: row;
  flex-wrap: wrap;
}

.cnb-badges--inline {
  position: absolute;
  top: 10px;
  left: 10px;
}

.cnb-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .02em;
  color: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
}

.cnb-badge--new {
  background: #0ea5e9;
}

.cnb-badge--hit {
  background: #16a34a;
}

.cnb-badge--sale {
  background: #ef4444;
}

.cnb-badge--clearance {
  background: #dc2626;
}

.cnb-badge--best-price {
  background: #f59e0b;
}

.cnb-badge--bestseller {
  background: #7c3aed;
}

.cnb-badge--limited {
  background: #0f766e;
}

.cnb-badge--recommended {
  background: #2563eb;
}

@media (max-width: 640px) {
  .cnb-badge {
    font-size: 10px;
    padding: 4px 8px;
  }
}
