/**
 * @file
 * Badge component styles
 * Replicating shadcn/ui Badge and tricycle-status-badge components
 */

/* Base badge */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

/* Badge variants */
.badge-default {
  background-color: var(--color-gray-100);
  color: var(--color-text-primary);
}

.badge-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.badge-secondary {
  background-color: var(--color-gray-200);
  color: var(--color-text-secondary);
}

/* Status badges - matching Next.js tricycle-status-badge.tsx */
.badge-active,
.badge-success {
  background-color: var(--color-success-light);
  color: var(--color-success-text);
}

.badge-inactive,
.badge-neutral {
  background-color: var(--color-gray-100);
  color: var(--color-gray-800);
}

.badge-suspended,
.badge-warning {
  background-color: var(--color-warning-light);
  color: var(--color-warning-text);
}

.badge-expired,
.badge-danger {
  background-color: var(--color-danger-light);
  color: var(--color-danger-text);
}

.badge-pending,
.badge-info {
  background-color: var(--color-info-light);
  color: var(--color-info-text);
}

.badge-review {
  background-color: #EDE9FE;
  color: #6B21A8;
}

.badge-approved {
  background-color: var(--color-success-light);
  color: var(--color-success-text);
}

.badge-rejected {
  background-color: var(--color-danger-light);
  color: var(--color-danger-text);
}

/* Badge sizes */
.badge-sm {
  padding: 2px var(--spacing-1);
  font-size: 10px;
}

.badge-lg {
  padding: var(--spacing-2) var(--spacing-3);
  font-size: var(--font-size-sm);
}

/* Badge with dot */
.badge-dot {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
}

.badge-dot::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: currentColor;
}

/* Outline badge */
.badge-outline {
  background-color: transparent;
  border: 1px solid currentColor;
}

.badge-outline.badge-primary {
  color: var(--color-primary);
}

.badge-outline.badge-success {
  color: var(--color-success);
}

.badge-outline.badge-warning {
  color: var(--color-warning);
}

.badge-outline.badge-danger {
  color: var(--color-danger);
}

/* Location badge */
.location-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  background-color: var(--color-gray-100);
  border-radius: var(--radius-md);
}

.location-badge svg {
  width: 12px;
  height: 12px;
}

/* Count badge */
.badge-count {
  min-width: 20px;
  height: 20px;
  padding: 0 var(--spacing-1);
  font-size: 11px;
  font-weight: var(--font-weight-bold);
  background-color: var(--color-danger);
  color: var(--color-white);
  border-radius: var(--radius-full);
}

/* Badge in navigation */
.nav-badge {
  margin-left: auto;
  padding: 2px 6px;
  font-size: 10px;
}

/* Verified badge */
.badge-verified {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
  color: var(--color-success);
  background-color: var(--color-success-bg);
  border-radius: var(--radius-md);
}

.badge-verified svg {
  width: 12px;
  height: 12px;
}

/* Payment type badges */
.badge-kyc {
  background-color: #DBEAFE;
  color: #1E40AF;
}

.badge-tracker {
  background-color: #FCE7F3;
  color: #BE185D;
}

.badge-bundle {
  background-color: #EDE9FE;
  color: #6B21A8;
}

/* Badge group */
.badge-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2);
}
