/**
 * Stili per slider galleria camere
 * Scroll nativo orizzontale con dots indicatori
 * 
 * @package PastaGirolomoni
 * @version 0.0.11.0.17
 */

/* ============================================
   MOBILE FIRST - Base styles
   ============================================ */

/* Wrapper principale slider */
.camera-gallery-slider {
    position: relative;
    width: 100%;
    margin-bottom: 1rem;
}

/* Track scrollabile orizzontale */
.camera-gallery-track {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch; /* Smooth scroll iOS */
    gap: 0;
    scrollbar-width: none; /* Firefox - nasconde scrollbar */
    -ms-overflow-style: none; /* IE/Edge - nasconde scrollbar */
}

/* Nasconde scrollbar su Chrome/Safari */
.camera-gallery-track::-webkit-scrollbar {
    display: none;
}

/* Singola slide */
.camera-gallery-slide {
    flex: 0 0 100%;
    width: 100%;
    scroll-snap-align: start;
    scroll-snap-stop: always;
}

/* Immagine dentro slide */
.camera-gallery-image {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 4 / 3; /* Mantiene proporzioni */
}

/* Placeholder quando non ci sono immagini */
.camera-gallery-placeholder {
    width: 100%;
    padding: 3rem 1rem;
    text-align: center;
    background-color: #f5f5f5;
    border: 1px dashed #ddd;
    border-radius: 4px;
}

.camera-gallery-placeholder-text {
    margin: 0;
    color: #666;
    font-size: 0.9rem;
}

/* ============================================
   DOTS INDICATORI
   Posizionati all'interno delle immagini con trasparenza
   ============================================ */

.camera-gallery-dots {
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 20px;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.camera-gallery-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease, opacity 0.3s ease;
    border: none;
    padding: 0;
    flex-shrink: 0;
}

.camera-gallery-dot:hover {
    background-color: rgba(255, 255, 255, 0.8);
    transform: scale(1.2);
}

.camera-gallery-dot-active {
    background-color: rgba(255, 255, 255, 0.9);
    transform: scale(1.3);
}

/* ============================================
   TABLET - 768px e superiori
   ============================================ */

@media (min-width: 768px) {
    .camera-gallery-image {
        aspect-ratio: 16 / 9; /* Proporzioni più larghe su tablet */
    }
    
    .camera-gallery-dots {
        bottom: 1.25rem;
        padding: 0.625rem 1.125rem;
    }
    
    .camera-gallery-dot {
        width: 12px;
        height: 12px;
    }
}

/* ============================================
   DESKTOP - 1024px e superiori
   ============================================ */

@media (min-width: 1024px) {
    .camera-gallery-slider {
        margin-bottom: 1.5rem;
    }
    
    .camera-gallery-image {
        max-height: 500px; /* Limita altezza su desktop */
        object-fit: cover;
    }
    
    .camera-gallery-dots {
        bottom: 1.5rem;
        gap: 0.75rem;
        padding: 0.75rem 1.25rem;
    }
    
    .camera-gallery-dot {
        width: 14px;
        height: 14px;
    }
}

/* ============================================
   ACCESSIBILITÀ
   ============================================ */

/* Focus visibile per navigazione da tastiera */
.camera-gallery-dot:focus {
    outline: 2px solid #333;
    outline-offset: 2px;
}

/* Riduce animazioni per utenti che preferiscono meno movimento */
@media (prefers-reduced-motion: reduce) {
    .camera-gallery-track {
        scroll-behavior: auto;
    }
    
    .camera-gallery-dot {
        transition: none;
    }
}

