/*
 * loading-spinner.css — BL-6: shared animated loading widget
 * registry: SCAFFOLD; cabling_task: BL-6; expires: 2026-07-18
 *
 * Namespace: .rfy-spinner*  (no overlap con .spinner globale legacy in globals.css).
 *
 * Anti-freeze: rotazione SEMPRE attiva tramite CSS keyframes locale,
 * fallback statico solo via @media (prefers-reduced-motion: reduce).
 *
 * Token usage:
 *   --color-primary    — colore arco rotante
 *   --color-border     — colore traccia statica
 *   --color-text       — colore label messaggio
 *   --color-text-muted — fallback label se --color-text non disponibile
 *
 * Dark mode: ereditato via [data-theme="dark"] sui token globali. Nessun
 * override hardcoded — l'unico hardcode è il fallback in .rfy-spinner--theme-dark
 * usato quando il consumer chiede esplicitamente tema dark forzato.
 */

/* ─── Layout containers ────────────────────────────────────────────────── */

.rfy-spinner {
  display: flex;
  align-items: center;
  gap: var(--space-3, 0.75rem);
  color: var(--color-text, #1a1a1a);
  font-family: inherit;
  font-size: var(--font-size-sm, 0.875rem);
  line-height: 1.4;
}

.rfy-spinner--inline {
  display: inline-flex;
  vertical-align: middle;
}

.rfy-spinner--block {
  display: flex;
  justify-content: center;
  padding: var(--space-6, 1.5rem) var(--space-4, 1rem);
  text-align: left;
}

/* ─── Ring (rotating arc) ──────────────────────────────────────────────── */

.rfy-spinner__ring {
  display: inline-block;
  flex-shrink: 0;
  border-style: solid;
  border-color: var(--color-border, #e5e7eb);
  border-top-color: var(--color-primary, #319795);
  border-radius: 50%;
  animation: rfy-spinner-spin 0.85s linear infinite;
  will-change: transform;
}

/* Size variants */
.rfy-spinner--sm .rfy-spinner__ring {
  width: 16px;
  height: 16px;
  border-width: 2px;
}
.rfy-spinner--md .rfy-spinner__ring {
  width: 24px;
  height: 24px;
  border-width: 2.5px;
}
.rfy-spinner--lg .rfy-spinner__ring {
  width: 40px;
  height: 40px;
  border-width: 3.5px;
}

/* ─── Label (animated text) ────────────────────────────────────────────── */

.rfy-spinner__label {
  color: inherit;
  animation: rfy-spinner-pulse 1.8s ease-in-out infinite;
}

/* ─── Theme overrides (explicit only — auto follows token theme) ──────── */

.rfy-spinner--theme-dark {
  color: #e5e7eb;
}
.rfy-spinner--theme-dark .rfy-spinner__ring {
  border-color: rgba(255, 255, 255, 0.18);
  border-top-color: #5eead4;
}
.rfy-spinner--theme-light {
  color: #1a1a1a;
}
.rfy-spinner--theme-light .rfy-spinner__ring {
  border-color: #e5e7eb;
  border-top-color: #319795;
}

/* ─── Keyframes ────────────────────────────────────────────────────────── */

@keyframes rfy-spinner-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes rfy-spinner-pulse {
  0%, 100% { opacity: 0.7; }
  50%      { opacity: 1; }
}

/* ─── Reduced motion: disable rotation + pulse but keep visibility ─────── */

@media (prefers-reduced-motion: reduce) {
  .rfy-spinner__ring {
    animation: none;
  }
  .rfy-spinner__label {
    animation: none;
    opacity: 1;
  }
}
