﻿* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Inter', sans-serif;
    background: #F5F2EA;
    color: #2C3E35;
}

.font-heading {
    font-family: 'Playfair Display', Georgia, serif;
}

/* Explicit section backgrounds — Tailwind CDN can't compute custom-color opacity modifiers */
.bg-section-cream {
    background-color: #F5F2EA;
}

.bg-section-offwhite {
    background-color: #FAFAF8;
}
/* white-ish for contrast */
.bg-section-sage {
    background-color: #EEF0EC;
}
/* very light sage */
.bg-section-sand {
    background-color: #EDE8E0;
}
/* warm sand */
.bg-section-dark {
    background-color: #2C3E35;
}
/* forest */
.bg-section-alt {
    background-color: #F0EDE5;
}
/* slightly warm off-white */

/* Navbar */
#navbar {
    transition: all 0.3s ease;
}

    #navbar.scrolled {
        background: rgba(245,242,234,0.96);
        backdrop-filter: blur(12px);
        box-shadow: 0 1px 0 rgba(138,154,134,0.25);
        padding-top: 1rem;
        padding-bottom: 1rem;
    }

    #navbar.top {
        background: transparent;
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }

/* Hero Ken Burns + fade */
.hero-slide {
    position: absolute;
    inset: 0;
    transition: opacity 2s ease-in-out;
}

    .hero-slide.active {
        opacity: 1;
    }

    .hero-slide.inactive {
        opacity: 0;
    }

    .hero-slide img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 8s ease-in-out;
    }

    .hero-slide.active img {
        transform: scale(1.1);
    }

    .hero-slide.inactive img {
        transform: scale(1.0);
    }

/* Animate on scroll */
.aos {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

    .aos.visible {
        opacity: 1;
        transform: none;
    }

.aos-delay-1 {
    transition-delay: 0.1s;
}

.aos-delay-2 {
    transition-delay: 0.2s;
}

.aos-delay-3 {
    transition-delay: 0.3s;
}

/* Section padding */
.section {
    padding: 6rem 0;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 2rem;
}

/* Accordion */
.accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.3s ease;
}

    .accordion-content.open {
        max-height: 500px;
    }

.accordion-icon {
    transition: transform 0.3s ease;
}

.accordion-item.open .accordion-icon {
    transform: rotate(180deg);
}

/* Film strip gallery */
.film-thumbnail {
    transition: all 0.3s ease;
    filter: grayscale(1);
    opacity: 0.5;
}

    .film-thumbnail.active {
        filter: grayscale(0);
        opacity: 1;
        outline: 2px solid #3B7A75;
        outline-offset: 2px;
    }

    .film-thumbnail:hover {
        opacity: 0.8;
    }

.gallery-main img {
    transition: opacity 0.5s ease;
}

/* Event slider */
.event-slide {
    position: absolute;
    inset: 0;
    transition: opacity 0.7s ease;
}

    .event-slide.active {
        opacity: 1;
        z-index: 1;
    }

    .event-slide.inactive {
        opacity: 0;
        z-index: 0;
    }

/* Ticket hover */
.ticket-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

    .ticket-card:hover {
        transform: translateY(-8px);
        box-shadow: 0 20px 60px rgba(0,0,0,0.15);
    }

/* Counter */
.counter-num {
    font-family: 'Playfair Display', serif;
}

/* Mobile menu */
#mobile-menu {
    transition: transform 0.35s ease, opacity 0.35s ease;
    transform: translateX(100%);
    opacity: 0;
    pointer-events: none;
}

    #mobile-menu.open {
        transform: translateX(0);
        opacity: 1;
        pointer-events: all;
    }

/* Floating socials */
#floating-socials {
    transition: all 0.5s ease;
    opacity: 0;
    transform: translateX(48px);
    pointer-events: none;
}

    #floating-socials.visible {
        opacity: 1;
        transform: translateX(0);
        pointer-events: all;
    }

/* Cookie banner */
#cookie-banner {
    transition: transform 0.5s ease;
}

    #cookie-banner.hidden {
        transform: translateY(100%);
        display: none;
    }

/* News hover */
.news-card:hover .news-img {
    transform: scale(1.05);
}

.news-img {
    transition: transform 0.7s ease;
}

.news-card:hover .news-arrow {
    transform: translateX(4px);
}

.news-arrow {
    transition: transform 0.3s ease;
}

/* Podcast parallax */
#podcast-bg {
    background-attachment: fixed;
}

/* Section separators */
.section-divider {
    height: 1px;
    background: linear-gradient(to right, transparent, rgba(138,154,134,0.35), transparent);
}

/* Newsletter input placeholder */
#newsletter-form input::placeholder {
    color: rgba(245,242,234,0.4);
}

#newsletter-form input {
    color: #F5F2EA;
}

/* Form input borders — Tailwind CDN can't resolve border-brand-sage/30 */
input, textarea, select {
    border: 1px solid rgba(138,154,134,0.35) !important;
}

    input:focus, textarea:focus, select:focus {
        border-color: #3B7A75 !important;
        box-shadow: 0 0 0 3px rgba(59,122,117,0.15);
    }

/* Scrollbar hide */
.scrollbar-hide::-webkit-scrollbar {
    display: none;
}

.scrollbar-hide {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* Improve card appearance on tinted backgrounds */
.bg-section-sage .news-card,
.bg-section-sage .testimonial-card {
    background: #ffffff;
    box-shadow: 0 2px 16px rgba(44,62,53,0.07);
}

.bg-section-sand .bg-white {
    background: #ffffff !important;
}

/* Form error */
.form-error {
    color: #dc2626;
    font-size: 0.78rem;
    margin-top: 0.25rem;
    display: none;
}

    .form-error.show {
        display: block;
    }

/* Testimonial hover */
.testimonial-card {
    transition: transform 0.5s ease;
}

    .testimonial-card:hover {
        transform: translateY(-8px);
    }

/* Partners hover */
#partners-grid {
    transition: opacity 0.5s ease;
    opacity: 0.5;
}

    #partners-grid:hover {
        opacity: 1;
    }

/* Media item hover */
.media-item .media-overlay {
    transition: background 0.3s ease;
}

.media-item:hover .media-overlay {
    background: rgba(44,62,53,0.45);
}

.media-item .media-img {
    transition: transform 0.7s ease;
}

.media-item:hover .media-img {
    transform: scale(1.05);
}

.media-item .media-label {
    transition: opacity 0.3s ease;
    opacity: 0;
}

.media-item:hover .media-label {
    opacity: 1;
}

/* Hero text animations */
@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(24px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-slide-up {
    animation: slideUp 0.8s ease-out forwards;
}

/* Dropdown */
.dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: #F5F2EA;
    border: 1px solid rgba(138,154,134,0.25);
    border-radius: 12px;
    padding: 8px;
    min-width: 200px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12);
    z-index: 100;
}

    .dropdown-parent:hover .dropdown-menu, .dropdown-menu:hover {
        display: block;
    }

.dropdown-item {
    display: block;
    padding: 8px 12px;
    border-radius: 8px;
    color: #2C3E35;
    font-size: 0.875rem;
    text-decoration: none;
    transition: background 0.2s;
    white-space: nowrap;
}

    .dropdown-item:hover {
        background: rgba(59,122,117,0.1);
        color: #3B7A75;
    }

.dropdown-divider {
    height: 1px;
    background: rgba(138,154,134,0.15);
    margin: 4px 0;
}

/* Dot indicators */
.dot {
    transition: all 0.3s ease;
}

    .dot.active {
        width: 24px;
    }

/* Select custom arrow */
select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232C3E35' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
}