.carousel {
    display: flex;
    width: max-content;
    flex-direction: column;
    justify-self: center;
    margin: 0 -0.5rem;
}

.carousel button {
    padding: 0.5rem;
}

.carousel>div {
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel .picture-list {
    display: flex;
    scroll-snap-type: x mandatory;
    overflow-x: scroll;
    gap: 1rem;
    width: clamp(15rem, calc(100vw - 2 * (2rem + 0.5rem)), 42rem);
    margin-right: 0.5rem;
    margin-left: 0.5rem;
    border-radius: 1rem;
}

.carousel .picture-list li {
    display: flex;
    flex-direction: column;
    scroll-snap-align: start;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
}

.carousel .picture-list li a {
    height: min-content;
    display: flex;
}

.carousel .picture-list img {
    height: clamp(10rem, 60vw, 28rem);
    width: clamp(15rem, calc(100vw - 2 * (2rem + 0.5rem)), 42rem);
    object-fit: cover;
}