.custom-carousel{
    width: 100%;
    overflow-x: auto;
    margin: 3em auto;
    display: flex;
    gap: 1em;
    scroll-behavior: smooth;
    anchor-name: --carousel;
    scroll-snap-type: x mandatory;
    scroll-marker-group: after;
}

.custom-carousel::scroll-marker-group{
    display: flex;
    justify-content: center;
    gap: .5em;
}

.custom-card::scroll-marker{
    content: "";
    height: 1em;
    width: 1em;
    background-color: black;
    opacity: .2;
    border-radius: 50%;
}

.custom-card::scroll-marker:target-current{
    background-color: var(--color-blue);
    opacity: 1;
}

.custom-carousel::-webkit-scrollbar{
    display: none;
}
/* "←" */
.custom-carousel::scroll-button(right), .custom-carousel::scroll-button(left){
    content: "→";
    border: none;
    background-color: var(--color-orange);
    color: var(--color-white);
    font-size: 1.8em;
    height: 60px;
    width: 60px;
    border-radius: 50%;
    cursor: pointer;
    position: fixed;
    position-anchor: --carousel;
    position-area: right center;
    translate: -50%;
    padding: 0;
    display: inline-block;
}
.custom-carousel::scroll-button(left){
    content: "←";
    position-area: left center;
    translate: 50%;
}

.custom-carousel::scroll-button(right):disabled, .custom-carousel::scroll-button(left):disabled{
    opacity: .5;
    cursor: auto;
}

.custom-card{
    scroll-snap-align: start;
    flex: 0 0 20em;
}


@media(max-width: 500px){
    .card{
        flex: 0 0 100%;
    }
}
