/* SweetAlert2 — align with Overthink tokens (:root in style.css) */

.swal2-container {
    z-index: 200000;
}

/* Modal dialogs only — toasts reuse these classes but must not dim the full viewport */
.swal2-container.swal2-backdrop-show:not(:has(.swal2-popup.swal2-toast)),
.swal2-container.swal2-noanimation:not(:has(.swal2-popup.swal2-toast)) {
    background: rgba(4, 2, 1, 0.48) !important;
}

.swal2-container:has(.swal2-popup.swal2-toast) {
    background: transparent !important;
    pointer-events: none;
}

.swal2-container:has(.swal2-popup.swal2-toast) .swal2-popup {
    pointer-events: auto;
}

/* Light toasts only — do not override .shop-toast-dark (e.g. add-to-cart on product grid) */
.swal2-popup.swal2-toast:not(.shop-toast-dark) {
    border: 1px solid var(--secondary-color, #d0c6b9) !important;
    border-radius: 10px !important;
    box-shadow: 0 10px 32px rgba(4, 2, 1, 0.12) !important;
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif) !important;
    color: var(--content-heading, #040201) !important;
    background: var(--color-white, #fff) !important;
    padding: 0.85rem 1rem !important;
}

.swal2-popup.swal2-toast.shop-toast-dark {
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif) !important;
    border-radius: 10px !important;
    padding: 0.85rem 1rem !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.38) !important;
}

.swal2-popup:not(.swal2-toast) {
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif);
    background: var(--color-white, #fff);
    color: var(--content-heading, #040201);
    border-radius: 10px;
    border: 1px solid var(--secondary-color, #d0c6b9);
    box-shadow: 0 16px 48px rgba(4, 2, 1, 0.14);
    padding: 1.35rem 1.25rem 1.5rem;
}

.swal2-title {
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif);
    font-weight: var(--fw-semibold, 600);
    font-size: 1.2rem;
    color: var(--content-heading, #040201);
    padding: 0 0 0.35em;
}

.swal2-html-container {
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif);
    font-size: var(--text-body, 1rem);
    color: var(--content-text, #665749);
    line-height: 1.55;
}

.swal2-close {
    color: var(--interactive-muted, rgba(4, 2, 1, 0.62));
    outline: none;
    box-shadow: none;
}

.swal2-close:hover {
    color: var(--content-heading, #040201);
}

.swal2-close:focus {
    outline: none;
    box-shadow: inset 0 0 0 2px var(--secondary-color, #d0c6b9);
}

.swal2-actions {
    gap: 0.65rem;
    margin: 1.15em auto 0;
}

/* Primary / secondary actions (buttonsStyling: false via global mixin) */
.swal2-styled.swal2-confirm {
    background: var(--color-black, #040201) !important;
    color: var(--color-white, #fff) !important;
    border: none !important;
    border-radius: 4px !important;
    padding: 0.55em 1.35em !important;
    font-weight: var(--fw-medium, 500) !important;
    font-size: 0.9375rem !important;
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif) !important;
    box-shadow: none !important;
    transition: opacity 0.15s ease, background 0.15s ease;
}

.swal2-styled.swal2-confirm:hover {
    opacity: 0.92;
}

.swal2-styled.swal2-confirm:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(4, 2, 1, 0.22) !important;
}

.swal2-styled.swal2-cancel,
.swal2-styled.swal2-deny {
    background: var(--color-white, #fff) !important;
    color: var(--content-heading, #040201) !important;
    border: 1px solid #d8d0c6 !important;
    border-radius: 4px !important;
    padding: 0.55em 1.35em !important;
    font-weight: var(--fw-medium, 500) !important;
    font-size: 0.9375rem !important;
    font-family: var(--font-family-base, 'Poppins', 'Inter', sans-serif) !important;
    box-shadow: none !important;
}

.swal2-styled.swal2-cancel:hover,
.swal2-styled.swal2-deny:hover {
    background: var(--primary-color, #e8e2da) !important;
}

.swal2-styled.swal2-cancel:focus,
.swal2-styled.swal2-deny:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(208, 198, 185, 0.65) !important;
}

/* Destructive confirm when using customClass (optional future use) */
.swal2-styled.swal2-confirm.swal2-overthink-danger {
    background: #8b3a36 !important;
}

.swal2-styled.swal2-confirm.swal2-overthink-danger:hover {
    background: #732f2c !important;
    opacity: 1;
}

/* Icons — muted, on-brand */
.swal2-icon {
    border-width: 3px;
}

.swal2-icon.swal2-success {
    border-color: rgba(90, 107, 90, 0.55);
    color: #3d4f3d;
}

.swal2-icon.swal2-error {
    border-color: rgba(180, 74, 70, 0.55);
    color: #a94442;
}

.swal2-icon.swal2-warning {
    border-color: rgba(154, 155, 135, 0.85);
    color: var(--color-brown, #665749);
}

.swal2-icon.swal2-info {
    border-color: rgba(102, 87, 73, 0.45);
    color: var(--color-brown, #665749);
}

.swal2-icon.swal2-question {
    border-color: rgba(102, 87, 73, 0.45);
    color: var(--color-brown, #665749);
}

/* Loading spinner */
.swal2-loader {
    border-color: var(--secondary-color, #d0c6b9) transparent var(--secondary-color, #d0c6b9) transparent;
}

.swal2-timer-progress-bar {
    background: var(--color-black, #040201);
}

/* Toast icon column — keep success ring visible on dark toasts */
.swal2-toast:not(.shop-toast-dark) .swal2-icon {
    border-width: 2px;
}

.swal2-toast.shop-toast-dark .swal2-icon.swal2-success {
    border-color: rgba(255, 255, 255, 0.35);
    color: #c8e6c9;
}
