/* ============================================
   WEMASS NOTIFICATIONS - Customización SweetAlert2
   Diseño corporativo Wemass para toasts y modales
   ============================================ */

/* ==========================================
   TOAST NOTIFICATIONS (esquina superior)
   ========================================== */

.wemass-toast {
    background: var(--wemass-blue-dark) !important;
    box-shadow: var(--shadow-xl) !important;
    border-radius: var(--border-radius-lg) !important;
    border-left: 6px solid var(--wemass-green) !important;
    padding: 18px 20px !important;
    min-width: 340px !important;
    backdrop-filter: blur(10px) !important;
}

/* Override para página de login (fondo oscuro) */
body.login-page .wemass-toast {
    background: var(--wemass-white) !important;
    border: 2px solid var(--wemass-green) !important;
    border-left: 6px solid var(--wemass-green) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4) !important;
}

body.login-page .wemass-toast .wemass-toast-title {
    color: var(--wemass-blue-petrol) !important;
}

body.login-page .wemass-toast .wemass-toast-text {
    color: var(--wemass-gray-medium) !important;
}

body.login-page .wemass-toast .wemass-toast-icon {
    border-color: var(--wemass-green) !important;
}

.wemass-toast .wemass-toast-title {
    color: var(--wemass-white) !important;
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    margin: 0 0 6px 0 !important;
    letter-spacing: 0.3px !important;
}

.wemass-toast .wemass-toast-text {
    color: rgba(255, 255, 255, 0.9) !important;
    font-family: var(--font-body) !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

.wemass-toast .wemass-toast-icon {
    border-color: var(--wemass-green) !important;
    border-width: 3px !important;
}

/* Iconos específicos para cada tipo */
.wemass-toast .swal2-icon.swal2-success [class^='swal2-success-line'] {
    background-color: var(--wemass-green) !important;
}

.wemass-toast .swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(160, 214, 24, 0.3) !important;
}

.wemass-toast .swal2-icon.swal2-error [class^='swal2-x-mark-line'] {
    background-color: #ff4444 !important;
}

.wemass-toast .swal2-icon.swal2-warning {
    border-color: #ffa726 !important;
    color: #ffa726 !important;
}

.wemass-toast .swal2-icon.swal2-info {
    border-color: #42a5f5 !important;
    color: #42a5f5 !important;
}

/* Barra de progreso del timer */
.wemass-toast .swal2-timer-progress-bar {
    background: var(--wemass-green) !important;
    height: 4px !important;
}

.wemass-toast .swal2-popup.swal2-toast .swal2-timer-progress-bar-container {
    top: auto !important;
    bottom: 0 !important;
}

/* ==========================================
   MODAL NOTIFICATIONS (centro pantalla)
   ========================================== */

.wemass-modal {
    background: var(--wemass-white) !important;
    box-shadow: var(--shadow-xl) !important;
    border-radius: var(--border-radius-lg) !important;
    padding: 30px !important;
    max-width: 480px !important;
}

/* Borde superior según tipo */
.wemass-modal.wemass-modal-success {
    border-top: 6px solid var(--wemass-green) !important;
}

.wemass-modal.wemass-modal-error {
    border-top: 6px solid #dc3545 !important;
}

.wemass-modal.wemass-modal-warning {
    border-top: 6px solid #ffa726 !important;
}

.wemass-modal.wemass-modal-info {
    border-top: 6px solid #42a5f5 !important;
}

.wemass-modal .wemass-modal-title {
    color: var(--wemass-blue-petrol) !important;
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
    font-size: 1.5rem !important;
    margin: 0 0 16px 0 !important;
    letter-spacing: 0.3px !important;
}

.wemass-modal .wemass-modal-text {
    color: var(--wemass-gray-medium) !important;
    font-family: var(--font-body) !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    line-height: 1.6 !important;
    margin: 0 0 24px 0 !important;
}

.wemass-modal .wemass-modal-icon {
    margin: 0 auto 20px !important;
}

/* Iconos modales */
.wemass-modal .swal2-icon.swal2-success {
    border-color: var(--wemass-green) !important;
}

.wemass-modal .swal2-icon.swal2-success [class^='swal2-success-line'] {
    background-color: var(--wemass-green) !important;
}

.wemass-modal .swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(160, 214, 24, 0.3) !important;
}

.wemass-modal .swal2-icon.swal2-error {
    border-color: #dc3545 !important;
}

.wemass-modal .swal2-icon.swal2-error [class^='swal2-x-mark-line'] {
    background-color: #dc3545 !important;
}

.wemass-modal .swal2-icon.swal2-warning {
    border-color: #ffa726 !important;
    color: #ffa726 !important;
}

.wemass-modal .swal2-icon.swal2-info {
    border-color: #42a5f5 !important;
    color: #42a5f5 !important;
}

/* ==========================================
   BOTONES (modales y confirmaciones)
   ========================================== */

.wemass-modal .wemass-btn-confirm {
    background: var(--wemass-green) !important;
    color: var(--wemass-blue-petrol) !important;
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 12px 32px !important;
    border: none !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--shadow-md) !important;
    transition: all 0.2s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.wemass-modal .wemass-btn-confirm:hover {
    background: #8ac013 !important;
    box-shadow: var(--shadow-lg) !important;
    transform: translateY(-2px) !important;
}

.wemass-modal .wemass-btn-confirm:active {
    transform: translateY(0) !important;
}

.wemass-modal .wemass-btn-cancel {
    background: transparent !important;
    color: var(--wemass-gray-medium) !important;
    font-family: var(--font-heading) !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    padding: 12px 32px !important;
    border: 2px solid var(--wemass-gray-light) !important;
    border-radius: var(--border-radius) !important;
    transition: all 0.2s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.wemass-modal .wemass-btn-cancel:hover {
    background: var(--wemass-gray-light) !important;
    border-color: var(--wemass-gray-medium) !important;
    color: var(--wemass-blue-dark) !important;
}

/* Botón de confirmación peligrosa (delete, etc.) */
.wemass-modal .wemass-btn-danger {
    background: #dc3545 !important;
    color: var(--wemass-white) !important;
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 12px 32px !important;
    border: none !important;
    border-radius: var(--border-radius) !important;
    box-shadow: var(--shadow-md) !important;
    transition: all 0.2s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.wemass-modal .wemass-btn-danger:hover {
    background: #c82333 !important;
    box-shadow: var(--shadow-lg) !important;
    transform: translateY(-2px) !important;
}

/* ==========================================
   ANIMACIONES CUSTOM
   ========================================== */

@keyframes wemassSlideIn {
    from {
        transform: translateX(100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes wemassSlideOut {
    from {
        transform: translateX(0);
        opacity: 1;
    }

    to {
        transform: translateX(100%);
        opacity: 0;
    }
}

.swal2-show.wemass-toast {
    animation: wemassSlideIn 0.3s ease-out !important;
}

.swal2-hide.wemass-toast {
    animation: wemassSlideOut 0.3s ease-in !important;
}
