/* Logo Reveal Animation */
.logo-reveal-container {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #000;
}

/* Initial black overlay that covers the logo completely */
.logo-reveal-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 1);
    z-index: 3;
    transition: opacity 0.5s ease;
}

.logo-reveal-container.reveal-started::before {
    opacity: var(--overlay-opacity, 1);
}

.logo-reveal {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
}

.logo-reveal img {
    max-width: 30%;
    max-height: 30%;
    object-fit: contain;
    filter: drop-shadow(0 0 20px rgba(255, 255, 255, 0.3));
    transform: translateY(var(--logo-y-offset, 50vh));
    transition: transform 0.1s ease-out;
}

/* Copyright text inside logo reveal */
.copyright {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    text-align: center;
    z-index: 4;
}

.copyright p {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

/* Footer Styles */
.footer {
    background-color: var(--color-dark);
    color: var(--color-white);
}

/* Mobile-specific adjustments for the footer logo */
@media (max-width: 768px) {
    .logo-reveal-container .logo-reveal img {
        width: 150px; /* Adjust for tablet screens */
    }
    .logo-reveal img {
        max-width: none !important;
        width: 150px !important;
        height: auto;
    }
}

@media (max-width: 480px) {
    .logo-reveal-container .logo-reveal img {
        width: 220px; /* Adjust for small screens */
    }
    .logo-reveal img {
        max-width: none !important;
        width: 220px !important;
        height: auto;
    }
}

/* You can add additional adjustments below if needed */
