/* Cinematic Jungle Theme Styles */

@theme {
    --color-jungle-dark: #040d04;
    --color-jungle-deep: #020502;
    --color-jungle-leaf: #1a3c1a;
    --color-gold-leaf: #d4af37;
    --color-amber-glow: #ffbf00;
    --font-display: "Cinzel", serif;
    --font-sans: "Inter", sans-serif;
    --font-serif: "Playfair Display", serif;
}

@keyframes fog {
    0% { transform: translate3d(0, 0, 0); }
    100% { transform: translate3d(-50%, 0, 0); }
}

@keyframes float {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50% { transform: translateY(-20px) rotate(5deg); }
}

@keyframes sway {
    0%, 100% { transform: rotate(-2deg); }
    50% { transform: rotate(2deg); }
}

@keyframes sun-rays {
    0%, 100% { opacity: 0.3; transform: scale(1); }
    50% { opacity: 0.6; transform: scale(1.1); }
}

.animate-fog {
    animation: fog 120s linear infinite;
}

.animate-float {
    animation: float 10s ease-in-out infinite;
}

.animate-sway {
    animation: sway 6s ease-in-out infinite;
}

.animate-sun-rays {
    animation: sun-rays 8s ease-in-out infinite;
}

/* Smooth reveal animations */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: all 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

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

.reveal-left {
    opacity: 0;
    transform: translateX(-60px);
    transition: all 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal-left.active {
    opacity: 1;
    transform: translateX(0);
}

.reveal-right {
    opacity: 0;
    transform: translateX(60px);
    transition: all 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal-right.active {
    opacity: 1;
    transform: translateX(0);
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 6px;
}

::-webkit-scrollbar-track {
    background: #040d04;
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(to bottom, #1a3c1a, #d4af37);
    border-radius: 10px;
}

/* Selection */
::selection {
    background: #d4af37;
    color: #000;
}

/* Navbar blur on scroll */
#navbar.scrolled {
    padding-top: 1rem;
    padding-bottom: 1rem;
    background-color: rgba(2, 5, 2, 0.95);
    border-bottom: 1px solid rgba(212, 175, 55, 0.1);
    backdrop-filter: blur(10px);
}

/* Mobile Menu Transition */
#mobile-menu.active {
    transform: translateX(0);
}

/* Parallax Layers */
.parallax-layer {
    will-change: transform;
    transition: transform 0.1s linear;
}

/* Sun Rays Effect */
.sun-rays {
    background: radial-gradient(circle at 20% 20%, rgba(255, 255, 200, 0.2) 0%, transparent 50%);
    filter: blur(40px);
}

/* Vignette Effect */
.vignette {
    background: radial-gradient(circle, transparent 40%, rgba(0,0,0,0.8) 100%);
}

/* Organic Button Hover */
.btn-organic {
    position: relative;
    overflow: hidden;
    transition: all 0.5s ease;
}

.btn-organic::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background: rgba(212, 175, 55, 0.2);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: width 0.6s ease, height 0.6s ease;
    z-index: -1;
}

.btn-organic:hover::before {
    width: 300%;
    height: 300%;
}

.btn-organic:hover {
    letter-spacing: 0.6em;
    box-shadow: 0 0 20px rgba(212, 175, 55, 0.3);
}

/* Foliage Overlays */
.foliage-overlay {
    pointer-events: none;
    z-index: 40;
}

/* Section Separator */
.section-divider {
    height: 150px;
    background-size: cover;
    background-position: center;
    position: relative;
    z-index: 10;
}
