/* wwwroot/css/avatares.css */

.avatar-scroller {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 6px 2px 12px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    user-select: none; /* evita selecciones raras en desktop */
    -webkit-user-select: none;
}

.avatar-card {
    scroll-snap-align: center;
    flex: 0 0 auto;
    width: 128px; /* tamaño fijo */
    height: 128px; /* tamaño fijo */
    border: 2px solid #e5e7eb;
    border-radius: 14px;
    padding: 4px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
    cursor: pointer;
}

    .avatar-card:hover {
        transform: translateY(-2px);
    }

    .avatar-card.selected {
        border-color: #0d6efd !important; /* más fuerte */
        box-shadow: 0 0 0 3px rgba(13,110,253,.15);
        outline: 2px solid rgba(13,110,253,.35); /* refuerzo visual */
        outline-offset: 0;
    }

    .avatar-card img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        display: block;
    }

/* Elimina estas media queries si quieres fijar 128x128 SIEMPRE */
/*
@media (min-width:420px){ .avatar-card{ width: calc((100% - 36px)/3); } }
@media (min-width:768px){ .avatar-card{ width: calc((100% - 48px)/4); } }
*/
