.reveal {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity 0.65s ease, transform 0.65s ease;
}

.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.hover-lift {
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.hover-lift:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 42px rgba(122, 88, 49, 0.12);
    border-color: rgba(175, 122, 69, 0.22);
}

.floating-slow {
    animation: floatSlow 5.6s ease-in-out infinite;
}

.floating-medium {
    animation: floatMedium 4.6s ease-in-out infinite;
}

.floating-fast {
    animation: floatFast 3.8s ease-in-out infinite;
}

.soft-pulse {
    animation: softPulse 3s ease-in-out infinite;
}

@keyframes floatSlow {
    0%, 100% { transform: translateY(0px) rotate(0deg); }
    50% { transform: translateY(-10px) rotate(-1deg); }
}

@keyframes floatMedium {
    0%, 100% { transform: translateY(0px) rotate(0deg); }
    50% { transform: translateY(-8px) rotate(1deg); }
}

@keyframes floatFast {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-7px); }
}

@keyframes softPulse {
    0%, 100% {
        transform: scale(1);
        opacity: 1;
    }
    50% {
        transform: scale(1.03);
        opacity: 0.95;
    }
}
.parallax-item {
    will-change: transform;
    transition: transform 0.18s ease-out;
}
