/* CSS for Hero Multi Slider - Full Width - Matching Original Hero Style */

/* Nascondi QUALSIASI hero statico quando c'è lo slider multi */
body:has(.hero-multi) .hero-bg-image:not(.hero-multi .hero-bg-image) {
    display: none !important;
}

/* Nascondi anche l'eventuale sezione contenitore dell'hero statico */
body:has(.hero-multi) .l-section:has(.hero-bg-image) {
    display: none !important;
}

.hero-multi {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* Override Slick container constraints */
.hero-multi .slideshow--hero,
.hero-multi .slideshow--hero.slick-initialized,
.hero-multi .slideshow--hero.slick-slider {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Nascondi le slide extra PRIMA che Slick si inizializzi */
.hero-multi .slideshow--hero:not(.slick-initialized)>.hero-bg-image:not(:first-child) {
    display: none !important;
}

.hero-multi .slick-list {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.hero-multi .slick-track {
    display: flex !important;
}

.hero-multi .slick-slide {
    height: auto !important;
    float: none !important;
}

.hero-multi .slick-slide>div {
    height: 100% !important;
    width: 100% !important;
}

/* Hero BG Image - Full viewport */
.hero-multi .hero-bg-image {
    width: 100% !important;
    height: 640px !important;
    display: flex !important;
    position: relative !important;
    background: #164B91 !important;
    margin: 0 !important;
    padding: 0 !important;
}

@media (max-width: 50em) {
    .hero-multi .hero-bg-image {
        height: auto !important;
        min-height: 400px !important;
    }
}

/* Immagine di sfondo a schermo intero */
.hero-multi .hero-bg-image__image {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 1 !important;
}

.hero-multi .hero-bg-image__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
}

/* Overlay blu - Nascosto come originale */
.hero-multi .hero-bg-image__blue {
    display: none !important;
}

/* Testo sovrapposto - contenitore */
.hero-multi .hero-bg-image__text {
    position: absolute !important;
    z-index: 3 !important;
    height: 100% !important;
    left: 0 !important;
    right: 0 !important;
    padding: 1em !important;
    width: 100% !important;
    background: none !important;
}

/* BORDO - Dimensioni fisse circa 1065x600 con margine */
.hero-multi .hero-bg-image__border {
    border: 1px solid rgba(240, 240, 240, 0.5) !important;
    display: block !important;
    background: none !important;
    /* Dimensioni fisse come originale */
    width: 1065px !important;
    max-width: calc(100% - 4rem) !important;
    height: 600px !important;
    max-height: calc(100% - 2rem) !important;
    /* Centratura */
    margin: 1rem auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

@media (max-width: 1100px) {
    .hero-multi .hero-bg-image__border {
        width: calc(100% - 4rem) !important;
        height: calc(100% - 2rem) !important;
        margin: 1rem 2rem !important;
    }
}

@media (max-width: 50em) {
    .hero-multi .hero-bg-image__border {
        width: calc(100% - 2rem) !important;
        height: auto !important;
        min-height: 350px !important;
        margin: 1rem !important;
    }
}

/* TITOLO - Stile originale con gradient */
.hero-multi .hero-bg-image__title {
    background: linear-gradient(90deg, #00b8b4 0%, #164B91 100%) !important;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.3) !important;
    color: #ffffff !important;
    display: inline-block !important;
    font-size: 30px !important;
    font-weight: 600 !important;
    margin: 1rem !important;
    padding: 1rem 1.5rem !important;
    z-index: 10 !important;
    text-transform: none !important;
}

/* Titolo con a capo forzato a metà */
.hero-multi .hero-bg-image__title--wrap {
    max-width: 490px !important;
}

/* Titolo su una riga (va a capo solo prima del bordo) */
.hero-multi .hero-bg-image__title--nowrap {
    max-width: 90% !important;
}

@media (min-width: 53.125em) {
    .hero-multi .hero-bg-image__title {
        font-size: 42px !important;
        margin: 4rem 1rem 2rem 4rem !important;
    }
}

/* SOTTOTITOLO - Stile originale */
.hero-multi .hero-bg-image__subtitle {
    color: #ffffff !important;
    font-weight: 400 !important;
    font-size: 17px !important;
    margin-left: 3rem !important;
    margin-right: 0 !important;
    max-width: 490px !important;
}

@media (min-width: 50em) {
    .hero-multi .hero-bg-image__subtitle {
        font-size: 20px !important;
        margin-left: 4rem !important;
    }
}

/* PULLQUOTE - Stile originale */
.hero-multi .hero-bg-image__pullquote {
    margin-left: 1rem !important;
    position: relative !important;
    width: 90% !important;
}

@media (min-width: 50em) {
    .hero-multi .hero-bg-image__pullquote {
        width: 420px !important;
        margin-left: 4rem !important;
    }
}

.hero-multi .hero-bg-image__pullquote-text {
    color: #ffffff !important;
    font-weight: 400 !important;
    font-size: 17px !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
}

@media (min-width: 50em) {
    .hero-multi .hero-bg-image__pullquote-text {
        font-size: 20px !important;
    }
}

.hero-multi .hero-bg-image__pullquote-citation {
    color: #dc7d11 !important;
    font-size: 13px !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
    text-transform: uppercase !important;
}

@media (min-width: 50em) {
    .hero-multi .hero-bg-image__pullquote-citation {
        font-size: 15px !important;
    }
}

/* BUTTON - Stile originale */
.hero-multi .hero-bg-image__pullquote-button {
    margin: 2rem 0 0 0 !important;
}

@media (min-width: 50em) {
    .hero-multi .hero-bg-image__pullquote-button {
        margin: 2rem 0 0 4rem !important;
    }
}

.hero-multi .hero-bg-image__pullquote-button .button {
    background-color: #dc7d11 !important;
    border: 2px solid #dc7d11 !important;
    color: #fff !important;
    padding: 0.7rem 1.2rem !important;
    text-decoration: none !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    display: inline-block !important;
    font-size: 1rem !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.hero-multi .hero-bg-image__pullquote-button .button:hover {
    background-color: #fff !important;
    color: #dc7d11 !important;
    border: 2px solid #dc7d11 !important;
}

/* Navigation Arrows - Smaller and more visible background */
.hero-multi .slick-arrow {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 100 !important;
    background: rgba(0, 0, 0, 0.45) !important;
    /* Dark background for visibility */
    border: none !important;
    width: 50px !important;
    height: 60px !important;
    /* Reduced height as requested */
    cursor: pointer !important;
    font-size: 0 !important;
    outline: none !important;
    opacity: 0.9 !important;
    /* More visible */
    transition: all 0.3s ease !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.hero-multi .slick-arrow:hover {
    opacity: 1 !important;
    background: rgba(0, 0, 0, 0.6) !important;
}

.hero-multi .slick-arrow:before {
    content: '' !important;
    display: block !important;
    width: 14px !important;
    height: 14px !important;
    border-top: 4px solid #fff !important;
    /* Thicker arrows */
    border-right: 4px solid #fff !important;
    /* Thicker arrows */
    margin: 0 !important;
}

.hero-multi .slick-prev {
    left: 35px !important;
    /* Aligned better with the decorative border */
}

.hero-multi .slick-prev:before {
    transform: rotate(-135deg) !important;
    margin-left: 6px !important;
    /* Centering tweak */
}

.hero-multi .slick-next {
    right: 35px !important;
    /* Aligned better with the decorative border */
}

.hero-multi .slick-next:before {
    transform: rotate(45deg) !important;
    margin-right: 6px !important;
    /* Centering tweak */
}

/* Pallini di navigazione - alzati per evitare sovrapposizione bordo */
.hero-multi .slick-dots {
    position: absolute !important;
    bottom: 50px !important;
    z-index: 100 !important;
    list-style: none !important;
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

.hero-multi .slick-dots li {
    margin: 0 6px !important;
}

.hero-multi .slick-dots li button {
    background: transparent !important;
    border: 2px solid #fff !important;
    border-radius: 50% !important;
    width: 14px !important;
    height: 14px !important;
    font-size: 0 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    padding: 0 !important;
}

.hero-multi .slick-dots li button:before {
    display: none !important;
}

.hero-multi .slick-dots li.slick-active button {
    background: #fff !important;
}

/* Responsive Adjustments - Mobile */
@media (max-width: 50em) {
    .hero-multi {
        height: auto !important;
        min-height: 0 !important;
        margin-bottom: 40px !important;
        z-index: 10 !important;
    }

    .hero-multi .hero-bg-image {
        flex-direction: column !important;
        height: auto !important;
        background: #164B91 !important;
    }

    .hero-multi .hero-bg-image__image {
        position: relative !important;
        height: 250px !important;
        width: 100% !important;
        z-index: 2 !important;
    }

    .hero-multi .hero-bg-image__text {
        position: relative !important;
        height: auto !important;
        padding: 2.5rem 1.5rem 2.5rem 1.5rem !important;
        background: #164B91 !important;
        z-index: 1 !important;
        display: block !important;
        overflow: visible !important;
    }

    .hero-multi .hero-bg-image__border {
        display: block !important;
        width: 100% !important;
        height: auto !important;
        margin: 0 !important;
        border: none !important;
        padding: 0 !important;
    }

    .hero-multi .hero-bg-image__title {
        font-size: 24px !important;
        line-height: 1.2 !important;
        margin: 0 0 1rem 0 !important;
        max-width: 100% !important;
        display: inline-block !important;
    }

    .hero-multi .hero-bg-image__subtitle {
        margin-left: 0 !important;
        font-size: 16px !important;
        line-height: 1.5 !important;
        max-width: 100% !important;
        /* Line clamping: show 3 lines Max */
        display: -webkit-box !important;
        -webkit-line-clamp: 3 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .hero-multi .hero-bg-image__pullquote-button {
        margin-top: 1.5rem !important;
        /* Fixed distance from text */
        display: block !important;
        padding-bottom: 0 !important;
    }

    /* Smooth height transition for the whole container */
    .hero-multi .slick-list {
        transition: height 0.5s ease-in-out !important;
    }

    /* Hide arrows on smartphone */
    .hero-multi .slick-arrow {
        display: none !important;
    }

    /* Smaller dots positioned just below the image */
    .hero-multi .slick-dots {
        bottom: auto !important;
        top: 215px !important;
        /* Positioned at the bottom of the 250px image */
        z-index: 100 !important;
    }

    .hero-multi .slick-dots li button {
        width: 10px !important;
        height: 10px !important;
        border-width: 1.5px !important;
    }
}

/* Mobile Menu Language Switcher Styling */
.mobile-menu__links .menu--mobile-lang {
    padding: 1rem 1.5rem !important;
    /* Reduced padding */
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    display: block !important;
    background: transparent !important;
    margin-top: 10px !important;
}

.mobile-menu__links .menu--mobile-lang select {
    width: 50% !important;
    /* Half width as requested */
    min-width: 140px !important;
    background: #fff !important;
    color: #333 !important;
    padding: 10px !important;
    border-radius: 4px !important;
    border: 1px solid #ccc !important;
    font-size: 16px !important;
    height: auto !important;
    appearance: menulist !important;
    /* Ensure it looks like a select */
}

/* Fix Hero Slider Dots appearing OVER the mobile menu */
.mobile-menu {
    z-index: 9999 !important;
    /* Ensure menu bar is top */
}

.mobile-menu__links {
    z-index: 10000 !important;
    /* Ensure menu panel is above everything */
}

/* Ensure the container is visible if it was forced hidden by theme */
.site-jrs-usa .mobile-menu__links .menu--mobile-lang {
    display: block !important;
}