/* =============================================
   SWEETALERT2 - VEGAS CASINO THEME
   ============================================= */

:root {
    --swal-gold: #FFD700;
    --swal-gold-dark: #B8860B;
    --swal-gold-light: #FFEC8B;
    --swal-neon-pink: #FF1493;
    --swal-neon-blue: #00BFFF;
    --swal-neon-purple: #9400D3;
    --swal-casino-red: #DC143C;
    --swal-casino-green: #228B22;
    --swal-vegas-black: #0a0a0f;
    --swal-vegas-purple: #1a1a2e;
    --swal-vegas-dark: #16213e;
}

/* Backdrop */
.swal2-container.swal2-backdrop-show {
    background: rgba(10, 10, 15, 0.9) !important;
    backdrop-filter: blur(8px);
}

/* Popup Container */
.swal2-popup {
    background: linear-gradient(145deg, var(--swal-vegas-purple) 0%, var(--swal-vegas-black) 100%) !important;
    border: 2px solid var(--swal-gold) !important;
    border-radius: 20px !important;
    box-shadow: 
        0 0 30px rgba(255, 215, 0, 0.3),
        0 0 60px rgba(255, 215, 0, 0.1),
        0 25px 50px rgba(0, 0, 0, 0.5) !important;
    padding: 2rem !important;
    animation: swal-vegas-pop 0.4s cubic-bezier(0.68, -0.3, 0.265, 1.3) !important;
}

@keyframes swal-vegas-pop {
    0% { 
        transform: scale(0.7); 
        opacity: 0; 
    }
    100% { 
        transform: scale(1); 
        opacity: 1; 
    }
}

/* Title */
.swal2-title {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    background: linear-gradient(135deg, var(--swal-gold) 0%, var(--swal-gold-light) 50%, var(--swal-gold) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    text-shadow: none !important;
    font-size: 1.75rem !important;
    margin-bottom: 0.5rem !important;
}

/* HTML Content / Text */
.swal2-html-container,
.swal2-content {
    color: rgba(255, 255, 255, 0.85) !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
}

/* Icons */
.swal2-icon {
    border-width: 3px !important;
    margin: 1.5rem auto !important;
}

/* Success Icon - Gold */
.swal2-icon.swal2-success {
    border-color: var(--swal-gold) !important;
    color: var(--swal-gold) !important;
}

.swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(255, 215, 0, 0.3) !important;
}

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

.swal2-icon.swal2-success::before,
.swal2-icon.swal2-success::after {
    background: transparent !important;
}

/* Success Glow */
.swal2-icon.swal2-success {
    box-shadow: 0 0 20px rgba(255, 215, 0, 0.4) !important;
}

/* Error Icon - Casino Red */
.swal2-icon.swal2-error {
    border-color: var(--swal-casino-red) !important;
    color: var(--swal-casino-red) !important;
    box-shadow: 0 0 20px rgba(220, 20, 60, 0.4) !important;
}

.swal2-icon.swal2-error [class^='swal2-x-mark-line'] {
    background-color: var(--swal-casino-red) !important;
}

/* Warning Icon - Gold/Amber */
.swal2-icon.swal2-warning {
    border-color: var(--swal-gold) !important;
    color: var(--swal-gold) !important;
    box-shadow: 0 0 20px rgba(255, 215, 0, 0.4) !important;
}

/* Info Icon - Neon Blue */
.swal2-icon.swal2-info {
    border-color: var(--swal-neon-blue) !important;
    color: var(--swal-neon-blue) !important;
    box-shadow: 0 0 20px rgba(0, 191, 255, 0.4) !important;
}

/* Question Icon - Neon Purple */
.swal2-icon.swal2-question {
    border-color: var(--swal-neon-purple) !important;
    color: var(--swal-neon-purple) !important;
    box-shadow: 0 0 20px rgba(148, 0, 211, 0.4) !important;
}

/* Buttons Container */
.swal2-actions {
    margin-top: 1.5rem !important;
    gap: 1rem !important;
}

/* Confirm Button - Gold */
.swal2-confirm {
    background: linear-gradient(135deg, var(--swal-gold) 0%, var(--swal-gold-dark) 100%) !important;
    color: var(--swal-vegas-black) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    padding: 0.85rem 2rem !important;
    border-radius: 50px !important;
    border: none !important;
    box-shadow: 
        0 4px 15px rgba(255, 215, 0, 0.4),
        0 0 30px rgba(255, 215, 0, 0.2) !important;
    transition: all 0.3s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

.swal2-confirm:hover {
    transform: translateY(-2px) !important;
    box-shadow: 
        0 6px 20px rgba(255, 215, 0, 0.5),
        0 0 40px rgba(255, 215, 0, 0.3) !important;
}

.swal2-confirm:focus {
    box-shadow: 
        0 4px 15px rgba(255, 215, 0, 0.4),
        0 0 30px rgba(255, 215, 0, 0.2),
        0 0 0 3px rgba(255, 215, 0, 0.3) !important;
}

/* Cancel Button - Dark with Gold Border */
.swal2-cancel {
    background: linear-gradient(135deg, var(--swal-vegas-purple) 0%, var(--swal-vegas-dark) 100%) !important;
    color: var(--swal-gold) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    padding: 0.85rem 2rem !important;
    border-radius: 50px !important;
    border: 2px solid var(--swal-gold) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3) !important;
    transition: all 0.3s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

.swal2-cancel:hover {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.15) 0%, rgba(184, 134, 11, 0.15) 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 
        0 6px 20px rgba(0, 0, 0, 0.4),
        0 0 20px rgba(255, 215, 0, 0.2) !important;
}

.swal2-cancel:focus {
    box-shadow: 
        0 4px 15px rgba(0, 0, 0, 0.3),
        0 0 0 3px rgba(255, 215, 0, 0.3) !important;
}

/* Deny Button - Casino Red */
.swal2-deny {
    background: linear-gradient(135deg, var(--swal-casino-red) 0%, #8B0000 100%) !important;
    color: white !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    padding: 0.85rem 2rem !important;
    border-radius: 50px !important;
    border: none !important;
    box-shadow: 0 4px 15px rgba(220, 20, 60, 0.3) !important;
    transition: all 0.3s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

.swal2-deny:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(220, 20, 60, 0.4) !important;
}

/* Timer Progress Bar */
.swal2-timer-progress-bar {
    background: linear-gradient(90deg, var(--swal-gold) 0%, var(--swal-gold-dark) 100%) !important;
    box-shadow: 0 0 10px rgba(255, 215, 0, 0.5) !important;
}

.swal2-timer-progress-bar-container {
    background: rgba(255, 215, 0, 0.1) !important;
}

/* Input Fields */
.swal2-input,
.swal2-textarea,
.swal2-select {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 2px solid rgba(255, 215, 0, 0.3) !important;
    border-radius: 12px !important;
    color: white !important;
    font-family: 'Poppins', sans-serif !important;
    transition: all 0.3s ease !important;
}

.swal2-input:focus,
.swal2-textarea:focus,
.swal2-select:focus {
    border-color: var(--swal-gold) !important;
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.3) !important;
    outline: none !important;
}

.swal2-input::placeholder,
.swal2-textarea::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}

/* Close Button */
.swal2-close {
    color: var(--swal-gold) !important;
    font-size: 2rem !important;
    transition: all 0.3s ease !important;
}

.swal2-close:hover {
    color: var(--swal-gold-light) !important;
    transform: rotate(90deg) !important;
}

.swal2-close:focus {
    box-shadow: none !important;
}

/* Loading Spinner */
.swal2-loading .swal2-confirm {
    background: transparent !important;
    border: 3px solid var(--swal-gold) !important;
    border-top-color: transparent !important;
    animation: swal-vegas-spin 1s linear infinite !important;
}

@keyframes swal-vegas-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Toast Styles */
.swal2-popup.swal2-toast {
    background: linear-gradient(135deg, var(--swal-vegas-purple) 0%, var(--swal-vegas-black) 100%) !important;
    border: 1px solid var(--swal-gold) !important;
    box-shadow: 
        0 0 20px rgba(255, 215, 0, 0.2),
        0 10px 30px rgba(0, 0, 0, 0.4) !important;
}

.swal2-popup.swal2-toast .swal2-title {
    font-size: 1rem !important;
    background: linear-gradient(135deg, var(--swal-gold) 0%, var(--swal-gold-light) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

/* Validation Message */
.swal2-validation-message {
    background: rgba(220, 20, 60, 0.2) !important;
    color: #ff6b6b !important;
    border-left: 3px solid var(--swal-casino-red) !important;
    font-family: 'Poppins', sans-serif !important;
}

/* Footer */
.swal2-footer {
    border-top: 1px solid rgba(255, 215, 0, 0.2) !important;
    color: rgba(255, 255, 255, 0.6) !important;
    font-family: 'Poppins', sans-serif !important;
}

.swal2-footer a {
    color: var(--swal-gold) !important;
    text-decoration: none !important;
    transition: color 0.3s ease !important;
}

.swal2-footer a:hover {
    color: var(--swal-gold-light) !important;
}

/* Image */
.swal2-image {
    border-radius: 12px !important;
    border: 2px solid rgba(255, 215, 0, 0.3) !important;
}

/* Checkbox/Radio Styles */
.swal2-checkbox,
.swal2-radio {
    color: rgba(255, 255, 255, 0.85) !important;
}

.swal2-checkbox input:checked + span,
.swal2-radio input:checked + span {
    color: var(--swal-gold) !important;
}

/* Range Slider */
.swal2-range input[type="range"] {
    background: linear-gradient(90deg, var(--swal-gold) 0%, var(--swal-gold-dark) 100%) !important;
}

/* Animations Override for Smoother Experience */
.swal2-show {
    animation: swal-vegas-pop 0.4s cubic-bezier(0.68, -0.3, 0.265, 1.3) !important;
}

.swal2-hide {
    animation: swal-vegas-hide 0.25s ease-out !important;
}

@keyframes swal-vegas-hide {
    0% { 
        transform: scale(1); 
        opacity: 1; 
    }
    100% { 
        transform: scale(0.8); 
        opacity: 0; 
    }
}
