@keyframes shimmer {
    0% { opacity: 1; }
    50% { opacity: 0.5; }
    100% { opacity: 1; }
}
body { min-height: 100vh; overflow-y: auto; }
.loading-shimmer {
    animation: shimmer 1.5s infinite ease-in-out;
}
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}        
.baygio-oday-text { animation: fadeIn 1.5s ease-out; }
.vip-content { opacity: 0; transition: opacity 1.5s ease-out; }
.vip-content.show { opacity: 1; }

#qr-modal { transition: opacity 0.5s ease-in-out; }
#disclaimer-modal { 
    transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), backdrop-filter 0.8s ease;
    backdrop-filter: blur(0px);
}
#disclaimer-modal.show-modal {
    opacity: 1;
    backdrop-filter: blur(4px); /* Khi hiện thì mờ nền */
}

/* Map */

#map-container {
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
    z-index: 0;
    background: white;
    padding: 10px;
    border-radius: 15px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

#map {
    height: 700px;
    width: 100%;
    border-radius: 10px;
    background: #f0f0f0;
}

.map-title {
    text-align: center;
    color: #333;
    margin-bottom: 20px;
    font-weight: 300;
    letter-spacing: 2px;
}