/**
 * Navbar-Carousel Fix
 * Removes space between navbar and carousel
 */

/* AGGRESSIVE: Remove ALL possible spacing between navbar and carousel */
.site-header,
header,
.site-content,
main,
.site-content > .container,
.site-content > .container-fluid,
main > .container,
main > .container-fluid,
.category-carousel,
.category-carousel-wrapper {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Carousel/hero spacing — controlled per breakpoint below */
.carousel-inner,
.carousel-item {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

.site-header,
header {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Force no gap between header and content */
.site-header + *,
header + *,
.site-header + .site-content,
header + main {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Body-level spacing removal */
body,
body.home,
body.page,
body.single,
body.archive,
body.search {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* WordPress specific spacing removal */
.wp-site-blocks,
.entry-content,
.post-content,
.page-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Ensure carousel is full width (exclude category-carousel and caption elements) */
.carousel:not(.category-carousel),
.carousel-inner:not(.category-carousel .carousel-inner),
.carousel-item:not(.category-carousel .carousel-item),
.slider,
.banner,
.hero-section {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

/* Reset caption - must NOT inherit carousel full-width positioning */
.homepage-carousel-caption {
    width: 100% !important;
    max-width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    position: absolute !important;
    box-sizing: border-box !important;
}

/* Mobile: hide caption on video slides, stack caption below image slides */
@media (max-width: 768px) {
    /* Video captions enabled on mobile */
    .carousel-item.has-video .homepage-carousel-caption {
        display: block !important;
        position: relative !important;
        bottom: auto !important;
    }

    .homepage-carousel-caption {
        position: relative !important;
        bottom: auto !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Fix blank space below video slides on mobile */
    .hero-carousel .carousel-item,
    .hero-carousel .carousel-item.has-video {
        height: auto !important;
        min-height: unset !important;
        max-height: none !important;
    }

    .hero-carousel,
    .hero-carousel .carousel,
    .hero-carousel .carousel-inner {
        height: auto !important;
        min-height: unset !important;
        max-height: none !important;
    }

    .carousel-video {
        min-height: unset !important;
        height: auto !important;
        max-height: 280px !important;
    }
}

/* Ensure category carousel captions are perfectly centered */
.category-carousel .carousel-caption {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    width: 80% !important;
    max-width: 800px !important;
    height: auto !important;
    min-height: 200px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 20px !important;
    z-index: 10 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    border-radius: 8px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

.category-carousel .carousel-caption h2 {
    font-size: 2.5rem !important;
    font-weight: 700 !important;
    color: #fff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    width: 100% !important;
    margin: 0 0 10px 0 !important;
    padding: 10px 0 !important;
    text-align: center !important;
}

.category-carousel .carousel-caption p {
    font-size: 1.2rem !important;
    color: #fff !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5) !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: center !important;
}
