:root {
    --orienteme-primary: #33bea1;
    --orienteme-primary-dark: #28967f;
    --orienteme-verde-orienteme: #418C83;
    --orienteme-white: #ffffff;
    --orienteme-border: #dee2e6;
    --font-family-primary: 'Poppins', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --border-radius: 12px;
    --spacing-md: 1.5rem;
    --spacing-lg: 2rem;
}

.om-alert-confirm-btn {
    font-family: var(--font-family-primary) !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: var(--border-radius) !important;
    border: 2px solid var(--orienteme-verde-orienteme) !important;
    font-size: 1rem !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    min-width: 120px !important;
    text-align: center !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
    user-select: none !important;
    line-height: 1.5 !important;
    color: var(--orienteme-white) !important;
    background-color: var(--orienteme-verde-orienteme) !important;
    border-color: var(--orienteme-verde-orienteme) !important;
    box-shadow: none !important;
}

.om-alert-confirm-btn:hover {
    color: var(--orienteme-white) !important;
    background-color: #2ba087 !important;
    border-color: var(--orienteme-primary-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(65, 140, 131, 0.3) !important;
}

.om-alert-confirm-btn:focus,
.om-alert-confirm-btn.focus {
    box-shadow: 0 0 0 0.2rem rgba(51, 190, 161, 0.5) !important;
    background-color: var(--orienteme-verde-orienteme) !important;
    outline: none !important;
}

.om-alert-deny-btn {
    font-family: var(--font-family-primary) !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: var(--border-radius) !important;
    border: 2px solid #418C83 !important;
    font-size: 1rem !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    min-width: 120px !important;
    text-align: center !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
    user-select: none !important;
    line-height: 1.5 !important;
    color: var(--orienteme-white) !important;
    background-color: #418C83 !important;
    border-color: #418C83 !important;
    box-shadow: none !important;
}

.om-alert-deny-btn:hover {
    color: var(--orienteme-white) !important;
    background-color: #2ba087 !important;
    border-color: var(--orienteme-primary-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(65, 140, 131, 0.3) !important;
}

.om-alert-deny-btn:focus,
.om-alert-deny-btn.focus {
    box-shadow: 0 0 0 0.2rem rgba(51, 190, 161, 0.5) !important;
    background-color: #418C83 !important;
    outline: none !important;
}

.om-alert-cancel-btn {
    font-family: var(--font-family-primary) !important;
    font-weight: 500 !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: var(--border-radius) !important;
    font-size: 1rem !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    min-width: 120px !important;
    text-align: center !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
    user-select: none !important;
    line-height: 1.5 !important;
    color: var(--orienteme-verde-orienteme) !important;
    background-color: transparent !important;
    border: solid 2px var(--orienteme-verde-orienteme) !important;
    box-shadow: none !important;
}

.om-alert-cancel-btn:hover {
    color: var(--orienteme-white) !important;
    background-color: var(--orienteme-verde-orienteme) !important;
    border-color: var(--orienteme-verde-orienteme) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(65, 140, 131, 0.3) !important;
}

.om-alert-cancel-btn:focus,
.om-alert-cancel-btn.focus {
    box-shadow: 0 0 0 0.2rem rgba(51, 190, 161, 0.5) !important;
    background-color: var(--orienteme-verde-orienteme) !important;
    color: var(--orienteme-white) !important;
    outline: none !important;
}

.om-alert-actions {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: var(--spacing-md) !important;
    margin-top: var(--spacing-lg) !important;
}

.om-toast-container .swal2-toast {
    font-family: var(--font-family-primary) !important;
    border-radius: 8px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1) !important;
}

.om-toast-popup {
    font-family: var(--font-family-primary) !important;
}

.swal2-popup {
    font-family: var(--font-family-primary) !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1) !important;
}

.swal2-title {
    font-family: var(--font-family-primary) !important;
    color: #1e1b33 !important;
    font-weight: 500 !important;
}

.swal2-content {
    font-family: var(--font-family-primary) !important;
    color: #696969 !important;
}

.swal2-html-container {
    font-family: var(--font-family-primary) !important;
    color: #696969 !important;
}

.swal2-icon {
    border-color: transparent !important;
}

.swal2-icon.swal2-info {
    border-color: #17a2b8 !important;
    color: #17a2b8 !important;
}

.swal2-icon.swal2-success {
    border-color: #00cf3a !important;
    color: #00cf3a !important;
}

.swal2-icon.swal2-warning {
    border-color: #ffc107 !important;
    color: #ffc107 !important;
}

.swal2-icon.swal2-error {
    border-color: #c02620 !important;
    color: #c02620 !important;
}

.swal2-icon.swal2-question {
    border-color: var(--orienteme-verde-orienteme) !important;
    color: var(--orienteme-verde-orienteme) !important;
}

.swal2-actions .om-alert-confirm-btn,
.swal2-actions .om-alert-deny-btn,
.swal2-actions .om-alert-cancel-btn {
    margin: 0 0.5rem !important;
}

.swal2-popup .swal2-actions .swal2-deny:not(.om-alert-deny-btn),
.swal2-popup .swal2-actions .swal2-cancel:not(.om-alert-cancel-btn) {
    display: none !important;
}

.swal2-popup .swal2-actions .swal2-deny:empty,
.swal2-popup .swal2-actions .swal2-cancel:empty {
    display: none !important;
}

.swal2-popup .swal2-actions .swal2-deny[style*="display: none"],
.swal2-popup .swal2-actions .swal2-cancel[style*="display: none"] {
    display: none !important;
}

.om-alert-mascot .mascote-tooltip {
    border: 1px solid #E5E5E5 !important;
    border-top-right-radius: 20px !important;
    border-bottom-right-radius: 20px !important;
    border-top-left-radius: 30px !important;
    box-shadow: 0px 4px 8px 0px #418C831A !important;
    min-height: 80px !important;
    text-align: left !important;
    font-family: var(--font-family-primary) !important;
    background-color: #fff !important;
}

.om-alert-mascot .mascote-flutuante {
    animation: om-alert-flutuacao 3s ease-in-out infinite !important;
}

@keyframes om-alert-flutuacao {
    0%, 100% {
        transform: translateY(0px);
    }
    50% {
        transform: translateY(-10px);
    }
}

.om-alert-mascot .mascote-flutuante img {
    transition: transform 0.3s ease !important;
    will-change: transform !important;
}

.om-alert-mascot .text-muted {
    color: #696969 !important;
    font-family: var(--font-family-primary) !important;
}

.swal2-popup:has(.om-alert-mascot) .swal2-icon {
    display: none !important;
}

@media (max-width: 768px) {
    .om-alert-confirm-btn,
    .om-alert-deny-btn,
    .om-alert-cancel-btn {
        padding: 0.5rem 1rem !important;
        min-width: 100px !important;
        font-size: 0.9rem !important;
    }
    
    .om-alert-actions {
        flex-direction: column !important;
        gap: 0.75rem !important;
    }

    .om-alert-mascot .mascote-flutuante img {
        width: 50px !important;
    }

    .om-alert-mascot .mascote-tooltip {
        min-height: 60px !important;
        padding: 0.5rem !important;
    }
}

.swal2-container {
    z-index: 99999 !important;
}

.swal2-backdrop-show {
    background-color: rgba(0, 0, 0, 0.4) !important;
}