/**
 * @file alerts.css
 * @description Estilos para alertas, toasts (notificações temporárias).
 */

/* ============================================================
 * Toast Container
 * ============================================================ */

.toast-container {
    position: fixed;
    top: var(--spacing-lg);
    right: var(--spacing-lg);
    z-index: var(--z-toast);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    max-width: 400px;
}

/* ============================================================
 * Toast Individual
 * ============================================================ */

.toast {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-lg);
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    animation: toastIn 0.3s ease;
    font-size: var(--font-size-sm);
}

.toast.toast-closing {
    animation: toastOut 0.2s ease forwards;
}

@keyframes toastIn {
    from {
        opacity: 0;
        transform: translateX(50px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes toastOut {
    to {
        opacity: 0;
        transform: translateX(50px);
    }
}

.toast-icon {
    font-size: var(--font-size-lg);
    flex-shrink: 0;
    margin-top: 1px;
}

.toast-body {
    flex: 1;
    min-width: 0;
}

.toast-title {
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    margin-bottom: 2px;
}

.toast-message {
    font-size: var(--font-size-xs);
    color: var(--text-secondary);
}

.toast-close {
    flex-shrink: 0;
    cursor: pointer;
    color: var(--text-light);
    padding: 2px;
    font-size: var(--font-size-base);
    background: none;
    border: none;
    border-radius: var(--border-radius-sm);
}

.toast-close:hover {
    color: var(--text-primary);
    background: var(--gray-100);
}

/* Variantes de toast */
.toast.toast-success {
    border-left: 4px solid var(--success-color);
}
.toast.toast-success .toast-icon { color: var(--success-color); }

.toast.toast-error {
    border-left: 4px solid var(--danger-color);
}
.toast.toast-error .toast-icon { color: var(--danger-color); }

.toast.toast-warning {
    border-left: 4px solid var(--warning-color);
}
.toast.toast-warning .toast-icon { color: var(--warning-color); }

.toast.toast-info {
    border-left: 4px solid var(--info-color);
}
.toast.toast-info .toast-icon { color: var(--info-color); }

/* ============================================================
 * Inline Alerts
 * ============================================================ */

.alert-inline {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
}

.alert-inline-success {
    background: var(--success-light);
    color: var(--success-dark);
    border: 1px solid var(--success-color);
}

.alert-inline-error {
    background: var(--danger-light);
    color: var(--danger-dark);
    border: 1px solid var(--danger-color);
}

.alert-inline-warning {
    background: var(--warning-light);
    color: var(--warning-dark);
    border: 1px solid var(--warning-color);
}

.alert-inline-info {
    background: var(--info-light);
    color: var(--info-dark);
    border: 1px solid var(--info-color);
}
