/* Custom styles beyond Tailwind */

html {
    scroll-behavior: smooth;
}

/* Scroll reveal animations */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

/* Stagger children animations */
.reveal:nth-child(2) { transition-delay: 0.15s; }
.reveal:nth-child(3) { transition-delay: 0.3s; }

/* Navbar shrink on scroll */
.nav-scrolled {
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

/* Gold button pulse on hover */
.bg-gold-400:hover {
    transform: translateY(-1px);
}

/* Form input focus glow */
input:focus, textarea:focus {
    box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.15);
}

/* Smooth image placeholder */
.bg-sage-100 {
    background-image: linear-gradient(135deg, #e8ede9 0%, #d1dcd4 100%);
}

/* Rotating hero word animation */
.rotating-word-enter {
    animation: rotateWordIn 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.rotating-word-exit {
    animation: rotateWordOut 0.4s cubic-bezier(0.7, 0, 0.84, 0) forwards;
}

@keyframes rotateWordIn {
    from {
        opacity: 0;
        transform: translateY(40px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes rotateWordOut {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-40px);
    }
}

/* Footer logo filter for dark background */
footer img {
    filter: brightness(0) invert(1);
    opacity: 0.8;
}
