/**
 * Loading States Styles
 * Provides visual feedback for actions based on bot feedback
 */

/* Loading indicator */
.loading-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;

/* Spinner animation */
.spinner {
    display: inline-block;
    width: calc(var(--spacing-md) * 1.167);
    height: calc(var(--spacing-md) * 1.167);
    border: 2px solid rgba(var(--color-text-primary-rgb, 224, 224, 224), 0.3);
    border-top-color: var(--color-primary, var(--color-primary));
    border-radius: var(--radius-full);
    animation: spin 0.8s linear infinite;

@keyframes spin {
    to { transform: rotate(360deg); }

/* Loading state for buttons */
button.loading,
.action-btn.loading {
    opacity: 0.7;
    cursor: wait;
    pointer-events: none;

button.loading .spinner,
.action-btn.loading .spinner {
    margin-right: 0.5rem;

/* Success state */
button.success,
.action-btn.success {
    background: var(--color-success, #28a745) !important;
    border-color: var(--color-success, #28a745) !important;
    animation: successPulse 0.3s ease;

@keyframes successPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }

.success-icon {
    display: inline-block;
    margin-right: 0.5rem;
    font-weight: bold;

/* Error state */
button.error-state,
.action-btn.error-state {
    background: var(--color-error, #dc3545) !important;
    border-color: var(--color-error, #dc3545) !important;
    animation: errorShake 0.3s ease;

@keyframes errorShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }

.error-icon {
    display: inline-block;
    margin-right: 0.5rem;
    font-weight: bold;

/* Loading overlay for containers */
.loading-overlay {
    position: relative;

.loading-overlay::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(var(--color-bg-primary-rgb, 26, 26, 26), 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;

.loading-overlay::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: calc(var(--spacing-2xl) * 1.25);
    height: calc(var(--spacing-2xl) * 1.25);
    border: 4px solid rgba(var(--color-text-primary-rgb, 224, 224, 224), 0.3);
    border-top-color: var(--color-primary, var(--color-primary));
    border-radius: var(--radius-full);
    animation: spin 0.8s linear infinite;
    z-index: 1001;

/* Skeleton loading states */
.skeleton {
    background: linear-gradient(
        90deg,
        rgba(var(--color-text-primary-rgb, 224, 224, 224), 0.1) 0%,
        rgba(var(--color-text-primary-rgb, 224, 224, 224), 0.2) 50%,
        rgba(var(--color-text-primary-rgb, 224, 224, 224), 0.1) 100%
    );
    background-size: 200% 100%;
    animation: skeletonLoading 1.5s ease-in-out infinite;
    border-radius: var(--radius-sm);

@keyframes skeletonLoading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }

}}}}}}}}}}}}}}}}