/**
 * Style slidera - prosty i działający
 */

/* Kontener - max 1920px szerokości */
.slider-spot-container {
    position: relative;
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    overflow: hidden;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .slider-spot-container {
        max-width: 100%;
    }
}

/* Wrapper - wysokość 400px PC, 312px mobile */
.slider-spot-wrapper {
    position: relative;
    width: 100%;
    max-width: 100%;
    height: 400px;
    overflow: hidden;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .slider-spot-container {
        border-radius: 4px;
        overflow: hidden;
    }
    
    .slider-spot-wrapper {
        height: 312px;
        border-radius: 4px;
        overflow: hidden;
    }
}

/* Track - pozycja absolute, szerokość ustawiana przez JS */
.slider-spot-track {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: row !important; /* Slajdy obok siebie */
    flex-wrap: nowrap !important; /* Nie zawijaj do nowej linii */
    transition: transform 0.6s ease;
    will-change: transform;
    margin: 0;
    padding: 0;
}

/* Slajd - 100% szerokości wrappera */
.slider-spot-slide {
    flex: 0 0 100% !important;
    flex-shrink: 0 !important; /* Nie kurcz się */
    flex-grow: 0 !important; /* Nie rozszerzaj się */
    width: 100% !important;
    min-width: 0 !important; /* Ważne dla flexbox */
    height: 100% !important;
    position: relative;
    overflow: hidden;
    margin: 0;
    padding: 0;
    /* Szerokość będzie ustawiana przez JS w pikselach */
}

.slider-spot-link {
    display: block;
    width: 100%;
    height: 100%;
}

.slider-spot-slide picture {
    display: block;
    width: 100%;
    height: 100%;
}

/* PC - obrazek 1920x400px - przycinaj boki, wysokość 400px */
.slider-spot-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* Mobile - obrazek 568x312px - pokaż cały, nie przycinaj */
@media (max-width: 768px) {
    .slider-spot-image {
        object-fit: contain;
    }
}

/* Strzałki nawigacyjne */
.slider-spot-prev,
.slider-spot-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.8);
    border: none;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s;
}

.slider-spot-prev:hover,
.slider-spot-next:hover {
    background: rgba(255, 255, 255, 1);
}

.slider-spot-prev {
    left: 20px;
}

.slider-spot-next {
    right: 20px;
}

.slider-spot-prev .dashicons,
.slider-spot-next .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    color: #333;
}

/* Ukryj strzałki na mobile */
@media (max-width: 1024px) {
    .slider-spot-prev,
    .slider-spot-next {
        display: none !important;
    }
}

/* Kropki nawigacyjne */
.slider-spot-dots {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 10;
}

.slider-spot-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.8);
    background: transparent;
    cursor: pointer;
    padding: 0;
    transition: background 0.3s;
}

.slider-spot-dot:hover {
    background: rgba(255, 255, 255, 0.5);
}

.slider-spot-dot.active {
    background: rgba(255, 255, 255, 1);
    border-color: rgba(255, 255, 255, 1);
}

@media (max-width: 768px) {
    .slider-spot-dots {
        bottom: 10px;
    }
    
    .slider-spot-dot {
        width: 10px;
        height: 10px;
    }
}

