.nuvion-hero-slider {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 600px; /* domyślnie, ale nadpisuje Elementor */
}

.nuvion-hero-slider__slides {
    width: 100%;
    height: 100%;
    position: relative;
}

.nuvion-hero-slider__slide {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.8s, transform 0.8s;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
}
.nuvion-hero-slider__slide.active {
    opacity: 1;
    pointer-events: auto;
    z-index: 2;
}

/* Fade animation */
.nuvion-hero-slider[data-animation="fade"] .nuvion-hero-slider__slide {
    transform: none;
}
.nuvion-hero-slider[data-animation="fade"] .nuvion-hero-slider__slide.active {
    opacity: 1;
}

/* Slide animation */
.nuvion-hero-slider[data-animation="slide"] .nuvion-hero-slider__slide {
    opacity: 1;
    transform: translateX(100%);
    z-index: 1;
}
.nuvion-hero-slider[data-animation="slide"] .nuvion-hero-slider__slide.active {
    transform: translateX(0);
    z-index: 2;
}
.nuvion-hero-slider[data-animation="slide"] .nuvion-hero-slider__slide.left {
    transform: translateX(-100%);
}
.nuvion-hero-slider[data-animation="slide"] .nuvion-hero-slider__slide.right {
    transform: translateX(100%);
}

/* Kontener */
.nuvion-hero-slider__container {
    width: var(--content-width, 1200px);
    max-width: 100vw;
    margin: 0 auto;
    height: auto;
}

.nuvion-hero-slider__inner {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    padding-left: 15px;
    padding-right: 15px;
}

.nuvion-hero-slider__content {
    position: relative;
    z-index: 2;
    width: 100%;
}
.nuvion-hero-slider__content--left {
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.nuvion-hero-slider__content--center {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.nuvion-hero-slider__content--right {
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.nuvion-hero-slider__title {
    padding: 0;
    line-height: 1.2;
    margin: 15px 0;
}
.nuvion-hero-slider__subtitle {
    font-family: "Montserrat", Sans-serif;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2.3px;
    margin:  0;
}
.nuvion-hero-slider__text {
    font-size: 1.2rem;
    margin-bottom: 1.2rem;
}
.nuvion-hero-slider__btn.elementor-button {
    display: inline-block;
    padding: 20px 26px 18px;
    font-size: 16px;
    line-height: 1;
    background: var( --e-global-color-woostify_color_5 )
}
.nuvion-hero-slider__btn:hover {
    
}

.nuvion-hero-slider__btn.elementor-button .dashicons {
    font-size: 16px;
    margin-left: 5px;
    transition: all 300ms ease;
}

.nuvion-hero-slider__btn.elementor-button:hover .dashicons {
    margin-left: 10px;
    //color: var( --e-global-color-woostify_color_5 );
}

/* Strzałki */
.nuvion-hero-slider__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    color: #fff;
    border: none;
    font-size: 2rem;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 300ms ease;
    opacity: 0;
}
.nuvion-hero-slider__arrow:hover {
    background: var( --e-global-color-woostify_color_6 );
}
.nuvion-hero-slider__arrow--prev {
    left: 20px;
}
.nuvion-hero-slider__arrow--next {
    right: 20px;
}

.nuvion-hero-slider:hover .nuvion-hero-slider__arrow {
    opacity: 1;
}

/* Dots */
.nuvion-hero-slider .nuvion-hero-slider__dots {
    position: absolute;
    z-index: 10;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 12px;
}
.nuvion-hero-slider .nuvion-hero-slider__dot {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: rgba(255,255,255,0);
    border: 2px solid var( --e-global-color-woostify_color_1 );
    cursor: pointer;
    transition: background 0.2s;
    padding:  0;
}
.nuvion-hero-slider .nuvion-hero-slider__dot.active,
.nuvion-hero-slider .nuvion-hero-slider__dot:hover {
    background: var( --e-global-color-woostify_color_5 );
    border-color: var( --e-global-color-woostify_color_5 );
}



@media (max-width: 768px) {
    .nuvion-hero-slider__arrow {
        top: auto;
        bottom: 30px;
        transform: none;
        width: 40px;
        height: 40px;
        font-size: 1.5rem;
    }
}