.spinner{display:inline-block;position:relative}.spinner-container{display:flex;align-items:center;justify-content:center}.spinner-sm{width:16px;height:16px}.spinner-md{width:24px;height:24px}.spinner-lg{width:32px;height:32px}.spinner-xl{width:48px;height:48px}.spinner-primary{color:#2563eb}.spinner-secondary{color:#6b7280}.spinner-white{color:#fff}.spinner-gray{color:#9ca3af}.spinner-default{animation:spin 1s linear infinite}.spinner-default svg{width:100%;height:100%}.spinner-dots{display:flex;gap:4px}.spinner-dots .dot{width:8px;height:8px;border-radius:50%;background-color:currentColor;animation:pulse 1s ease-in-out infinite}.spinner-dots .dot:nth-child(1){animation-delay:0s}.spinner-dots .dot:nth-child(2){animation-delay:.2s}.spinner-dots .dot:nth-child(3){animation-delay:.4s}.spinner-sm .spinner-dots .dot{width:4px;height:4px}.spinner-lg .spinner-dots .dot{width:12px;height:12px}.spinner-xl .spinner-dots .dot{width:16px;height:16px}.spinner-pulse{border-radius:50%;background-color:currentColor;animation:pulse 1s ease-in-out infinite}.spinner-bars{display:flex;gap:2px;align-items:flex-end}.spinner-bars .bar{background-color:currentColor;animation:bars 1s ease-in-out infinite}.spinner-bars .bar:nth-child(1){animation-delay:0s}.spinner-bars .bar:nth-child(2){animation-delay:.1s}.spinner-bars .bar:nth-child(3){animation-delay:.2s}.spinner-bars .bar:nth-child(4){animation-delay:.3s}.spinner-sm .spinner-bars .bar{width:4px;height:16px}.spinner-md .spinner-bars .bar{width:4px;height:24px}.spinner-lg .spinner-bars .bar{width:4px;height:32px}.spinner-xl .spinner-bars .bar{width:8px;height:48px}.spinner-ring{border:2px solid currentColor;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bars{0%,to{transform:scaleY(1)}50%{transform:scaleY(.5)}}.custom-purple{color:#8b5cf6!important}.custom-green{color:#10b981!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
