/**
 * Gestiolex Autosave Styles
 * =========================
 * Stili per il feedback visivo dell'autosave
 */

/* Indicatore di stato accanto ai campi */
.autosave-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    margin-left: 8px;
    font-size: 0.85rem;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.autosave-status.visible {
    opacity: 1;
}

/* Stati del bordo campo */
.autosave-modified {
    border-color: #ffc107 !important;
    box-shadow: 0 0 0 2px rgba(255, 193, 7, 0.15) !important;
}

.autosave-saving {
    border-color: #0d6efd !important;
    box-shadow: 0 0 0 2px rgba(13, 110, 253, 0.15) !important;
}

.autosave-saved {
    border-color: #198754 !important;
    box-shadow: 0 0 0 2px rgba(25, 135, 84, 0.15) !important;
}

.autosave-error {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.15) !important;
}

/* Animazione spinner */
@keyframes autosave-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.autosave-status .fa-spinner {
    animation: autosave-spin 1s linear infinite;
}

/* Badge di stato inline (stile tutorial admin) */
.autosave-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 500;
    margin-left: 8px;
    transition: all 0.2s ease;
}

.autosave-badge.saving {
    background: #e7f1ff;
    color: #0d6efd;
}

.autosave-badge.saved {
    background: #d1e7dd;
    color: #0f5132;
}

.autosave-badge.error {
    background: #f8d7da;
    color: #842029;
}

.autosave-badge.modified {
    background: #fff3cd;
    color: #664d03;
}

/* Tooltip per errori */
.autosave-tooltip {
    position: absolute;
    background: #dc3545;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    white-space: nowrap;
    z-index: 1000;
    margin-top: 4px;
}

.autosave-tooltip::before {
    content: '';
    position: absolute;
    top: -4px;
    left: 10px;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 4px solid #dc3545;
}

/* Wrapper per campi con autosave */
.autosave-field-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.autosave-field-wrapper .form-control,
.autosave-field-wrapper .form-select {
    flex: 1;
}

/* Stile per input groups con autosave */
.input-group .autosave-status {
    position: absolute;
    right: -28px;
    top: 50%;
    transform: translateY(-50%);
}

/* Pulse animation per salvato */
@keyframes autosave-pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

.autosave-status .fa-check {
    animation: autosave-pulse 0.3s ease;
}
