/* LiveIndicator Atom */
/* Live/real-time status indicator with pulse animation */

.live-indicator {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.live-indicator-dot {
  width: var(--space-2);
  height: var(--space-2);
  border-radius: var(--border-radius-full);
  background: var(--color-success);
  position: relative;
}

/* Pulse animation */
.live-indicator-pulse .live-indicator-dot::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--border-radius-full);
  background: inherit;
  animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(2);
    opacity: 0;
  }
}

/* Status variants */
.live-indicator-active .live-indicator-dot {
  background: var(--color-success);
}

.live-indicator-warning .live-indicator-dot {
  background: var(--color-warning);
}

.live-indicator-error .live-indicator-dot {
  background: var(--color-error);
}

.live-indicator-inactive .live-indicator-dot {
  background: var(--text-muted);
}

.live-indicator-inactive.live-indicator-pulse .live-indicator-dot::before {
  animation: none;
}

/* Sizes */
.live-indicator-sm {
  font-size: var(--text-2xs);
}

.live-indicator-sm .live-indicator-dot {
  width: var(--space-1_5);
  height: var(--space-1_5);
}

.live-indicator-lg {
  font-size: var(--text-sm);
}

.live-indicator-lg .live-indicator-dot {
  width: var(--space-2_5);
  height: var(--space-2_5);
}

/* Dot only (no label) */
.live-indicator-dot-only {
  gap: 0;
}
