/* =============================================================
   COMPONENT — BADGE
   ============================================================= */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.2rem 0.6rem;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  white-space: nowrap;
  border: 1px solid transparent;
  line-height: 1.5;
}

.badge--default {
  background: var(--color-bg-elevated);
  border-color: var(--color-border-light);
  color: var(--color-text-secondary);
}

.badge--accent {
  background: var(--color-accent-dim);
  border-color: var(--color-accent-border);
  color: var(--color-text-accent);
}

.badge--new {
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.25);
  color: #4ade80;
}

.badge--sale {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.25);
  color: #f87171;
}

.badge--digital {
  background: rgba(59, 130, 246, 0.12);
  border-color: rgba(59, 130, 246, 0.25);
  color: #60a5fa;
}

.badge--limited {
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.25);
  color: #fbbf24;
}

.badge--custom {
  background: var(--color-accent-dim);
  border-color: var(--color-accent-border);
  color: var(--color-text-accent);
}
