/* Fluid Wave Animation Styles */
.waves-container {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 12vh;
    min-height: 80px;
    max-height: 150px;
    z-index: 5;
    pointer-events: none;
    /* Ensure no gap */
    transform: translateY(1px);
}

.waves {
    position: relative;
    width: 100%;
    height: 100%;
    margin-bottom: -7px; /* Fix for safari gap */
}

/* Parallax Animation */
.parallax > use {
    animation: move-forever 25s cubic-bezier(.55, .5, .45, .5) infinite;
    fill: var(--wave-fill, var(--bg-secondary));
}

.parallax > use:nth-child(1) {
    animation-delay: -2s;
    animation-duration: 7s;
    opacity: 0.3;
}

.parallax > use:nth-child(2) {
    animation-delay: -3s;
    animation-duration: 10s;
    opacity: 0.5;
}

.parallax > use:nth-child(3) {
    animation-delay: -4s;
    animation-duration: 13s;
    opacity: 0.7;
}

.parallax > use:nth-child(4) {
    animation-delay: -5s;
    animation-duration: 20s;
    opacity: 1;
}

/* Override existing inclined cuts */
.hero-section::after,
.gallery-section::after {
    display: none !important;
}

@keyframes move-forever {
    0% {
        transform: translate3d(-90px, 0, 0);
    }
    100% {
        transform: translate3d(85px, 0, 0);
    }
}

/* Mobile adjustments */
@media (max-width: 768px) {
    .waves-container {
        height: 40px;
        min-height: 40px;
    }
}
