/* ============================================================
   Hero Slider – styles
   ============================================================ */

/* ── Wrapper ─────────────────────────────────────────────── */
.hero-slider {
    position: relative;
    width: 100%;
    overflow: hidden;
    /* height controlled by Elementor responsive slider control */
    height: 700px;
}

/* ── Track ───────────────────────────────────────────────── */
.hero-slider__track {
    position: relative;
    width: 100%;
    /* height set by JS to match wrapper */
}

/* ── Slides — always absolutely stacked ──────────────────── */
.hero-slider__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--hero-slider-fade-duration, 1000ms) ease-in-out;
}

.hero-slider__slide--active {
    opacity: 1;
    pointer-events: auto;
}

/* ── Background image layer (Ken Burns target) ───────────── */
.hero-slider__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    will-change: transform;
    transform-origin: center center;
}

/* ── Ken Burns ───────────────────────────────────────────── */
@keyframes heroKenBurns {
    from { transform: scale(1); }
    to   { transform: scale(1.08); }
}

.hero-slider__bg--ken-burns {
    animation-name: heroKenBurns;
    animation-timing-function: ease-in-out;
    animation-fill-mode: forwards;
    /* animation-duration set inline by JS */
}

/* ── Colour overlay ──────────────────────────────────────── */
.hero-slider__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background-color: rgba(29, 35, 71, 0.8);
    pointer-events: none;
}

/* ── Content overlay ─────────────────────────────────────── */
.hero-slider__content {
    position: absolute;
    inset: 0;
    z-index: 2;

    /* Vertical centering via flexbox */
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    align-items: center;

    /* Boxed layout — centred, max 1200px, 50px side padding on desktop */
    max-width: 1200px !important;
    width: 100% !important;
    height: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 50px !important;
    padding-right: 50px !important;
    left: 50% !important;
    transform: translateX(-50%);

    text-align: center !important;

    color: var(--e-global-color-68ed4b6) !important;

    opacity: 1;
    transition: opacity var(--hero-slider-content-fade-duration, 300ms) ease-out;

    box-sizing: border-box !important;
}

.hero-slider__content--hidden {
    opacity: 0;
}

/* ── Tablet (≤ 1024px) ───────────────────────────────────── */
@media (max-width: 1024px) {
    .hero-slider__content {
        padding-left: 40px !important;
        padding-right: 40px !important;
    }
}

/* ── Mobile (≤ 767px) ────────────────────────────────────── */
@media (max-width: 767px) {
    .hero-slider__content {
        padding-left: 25px !important;
        padding-right: 25px !important;
    }
}

/* ── Slide as link ───────────────────────────────────────── */
a.hero-slider__slide {
    cursor: pointer;
    text-decoration: none;
    display: block;
}

/* ── Typography ──────────────────────────────────────────── */
.hero-slider__heading {
    color: var(--e-global-color-68ed4b6) !important;
    text-align: center !important;
    width: 100%;
    margin: 0 0 1rem;

    font-family: var(--e-global-typography-874d607-font-family), Sans-serif;
    font-size: var(--e-global-typography-874d607-font-size);
    font-weight: var(--e-global-typography-874d607-font-weight);
    line-height: var(--e-global-typography-874d607-line-height);
    letter-spacing: var(--e-global-typography-874d607-letter-spacing);
}

.hero-slider__text {
    color: var(--e-global-color-68ed4b6) !important;
    text-align: center !important;
    width: 100%;
    max-width: 60%;
    margin: 0 0 1.25rem;

    font-family: var(--e-global-typography-d0f7550-font-family), Sans-serif;
    font-size: var(--e-global-typography-d0f7550-font-size);
    font-weight: var(--e-global-typography-d0f7550-font-weight);
    line-height: var(--e-global-typography-d0f7550-line-height, 1.4em);
    letter-spacing: var(--e-global-typography-d0f7550-letter-spacing);
    word-spacing: var(--e-global-typography-d0f7550-word-spacing);
}

/* ── Mobile (≤ 767px) ────────────────────────────────────── */
@media (max-width: 767px) {
    .hero-slider__text {
        max-width: 100%;
    }
}
