.timeline-progress-wrapper {
    position: relative;
    padding-left: 0;
}

.timeline-item {
    position: relative;
    display: flex;
    align-items: flex-start;
}

.timeline-content-wrapper {
    display: flex;
    gap: 30px;
    flex: 1;
    margin-left: var(--content-spacing);
    margin-bottom: var(--items-spacing);
}

.timeline-item:last-child .timeline-content-wrapper {
    margin-bottom: 0;
}

/* Proporzioni colonne testo/immagini */
.timeline-content {
    flex: 0 0 var(--text-column-width);
    max-width: var(--text-column-width);
}

.timeline-images {
    flex: 1;
    max-width: calc(100% - var(--text-column-width) - 30px); /* 30px è il gap */
}

.timeline-dot {
    position: relative;
    width: var(--dot-size);
    height: var(--dot-size);
    background-color: var(--bar-color);
    border-radius: 50%;
    z-index: 4;
    flex-shrink: 0;
    transition: transform 0.3s ease;
}

/* Linea che connette i pallini */
.timeline-line-segment {
    position: absolute;
    left: calc(var(--dot-size) / 2 - var(--bar-width) / 2);
    top: calc(var(--dot-size) / 2);
    width: var(--bar-width);
    background-color: var(--bar-inactive-color, #e0e0e0);
    z-index: 1;
}

.timeline-progress-segment {
    width: 100%;
    height: 0%;
    background-color: var(--bar-color);
    transition: height 0.3s ease;
    position: absolute;
    top: 0;
}

/* Stili per le immagini con altezza proporzionale */
.timeline-images {
    display: grid;
    gap: 15px;
    align-self: start;
    margin-top: calc(var(--dot-size) / 2 - 10px); /* Allinea con il pallino */
}

/* Calcolo altezza base: 200px + proporzione basata su items-spacing */
/* Formula: altezza = 200px + (items-spacing * 1.5) */

/* Layout per 3 immagini - altezza iniziale che verrà sovrascritta da JS */
.timeline-images.images-3 {
    grid-template-columns: 1.5fr 1fr;
    grid-template-rows: repeat(2, 1fr);
    height: 320px; /* Valore iniziale per spacing 80px */
}

/* Layout per 2 immagini */
.timeline-images.images-2 {
    grid-template-columns: repeat(2, 1fr);
    height: 280px; /* Valore iniziale per spacing 80px */
}

/* Layout per 1 immagine */
.timeline-images.images-1 {
    height: 280px; /* Valore iniziale per spacing 80px */
}

.timeline-image {
    position: relative;
    overflow: hidden;
    border-radius: var(--image-border-radius);
}

.timeline-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.timeline-image:hover img {
    transform: scale(1.05);
}

/* Testi della timeline */
.timeline-item-step {
    margin-bottom: var(--step-spacing);
    font-weight: 600;
    letter-spacing: 1px;
}

.timeline-item-title {
    margin-bottom: var(--title-spacing);
    font-weight: 700;
}

.timeline-item-content {
    line-height: 1.6;
}

/* Stati attivi */
.timeline-item.active .timeline-dot {
    transform: scale(1.2);
}

/* Media queries per tablet */
@media (max-width: 1024px) {
    .timeline-content {
        flex: 0 0 40%;
        max-width: 40%;
    }
    
    .timeline-images {
        max-width: calc(60% - 30px);
    }
    
    /* Proporzioni ridotte su tablet */
    .timeline-images.images-3 {
        height: calc(180px + var(--items-spacing) * 1);
        max-height: 320px;
        min-height: 200px;
    }
    
    .timeline-images.images-2 {
        height: calc(160px + var(--items-spacing) * 0.8);
        max-height: 280px;
        min-height: 180px;
    }
    
    .timeline-images.images-1 {
        height: calc(160px + var(--items-spacing) * 0.8);
        max-height: 280px;
        min-height: 180px;
    }
}

/* Media queries per mobile - disposizione verticale */
@media (max-width: 768px) {
    .timeline-content-wrapper {
        flex-direction: column;
        gap: 20px;
    }
    
    .timeline-content {
        flex: 1;
        max-width: 100%;
    }
    
    .timeline-images {
        max-width: 100%;
        margin-top: 0;
    }
    
    /* Su mobile le immagini mantengono proporzioni fisse per usabilità */
    .timeline-images.images-3 {
        grid-template-columns: 1fr;
        grid-template-rows: repeat(3, 200px);
        height: auto;
        gap: 10px;
    }
    
    .timeline-images.images-3 .timeline-image:first-child {
        grid-row: 1;
    }
    
    .timeline-images.images-2 {
        grid-template-columns: 1fr;
        grid-template-rows: repeat(2, 200px);
        height: auto;
        gap: 10px;
    }
    
    .timeline-images.images-1 {
        height: 220px;
    }
}

/* Media queries per mobile piccolo - nasconde timeline */
@media (max-width: 480px) {
    /* Nasconde la linea della timeline su mobile */
    .timeline-line-segment {
        display: none;
    }
    
    /* Rimuove il margine sinistro */
    .timeline-content-wrapper {
        margin-left: 0;
    }
    
    /* Nasconde anche il pallino su mobile piccolo */
    .timeline-dot {
        display: none;
    }
    
    /* Aggiusta l'allineamento del contenuto */
    .timeline-item {
        padding-left: 0;
    }
    
    .timeline-images.images-3 {
        grid-template-rows: repeat(3, 180px);
    }
    
    .timeline-images.images-2 {
        grid-template-rows: repeat(2, 180px);
    }
    
    .timeline-images.images-1 {
        height: 200px;
    }
}