/* Ajustes para el contenedor de select personalizado */
.select-custom-container {
    position: relative;
    width: 100%;
}

.select-custom {
    visibility: hidden; /* Ocultamos el select nativo */
    position: absolute;
}

/* Apariencia del display */
.select-custom-display {
    display: flex;
    height: calc(1.5em + 1rem + 2px);
    padding: 0.5rem 1rem;
    font-size: 1.09375rem;
    line-height: 1.5;
    border-radius: 0.3rem;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    cursor: pointer;
    border: 1px solid #ced4da;
    background-color: #fff;
    transition: border-color 0.3s ease;
}

/* Icono de flecha */
.select-custom-display i {
    font-size: 1rem;
    color: #6c757d;
}

/* Opciones desplegables */
.select-custom-options {
    display: none;
    position: absolute;
    width: 100%;
    top: 100%;
    left: 0;
    z-index: 1;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
    background-color: #ffffff;
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.15);

    /* --- NUEVO: Scroll cuando la lista sea muy larga --- */
    max-height: 200px;    /* aj¨˛stalo: px, % o vh seg¨˛n prefieras */
    overflow-y: auto;
}

/* Mostrar opciones cuando est¨¦ activo */
.select-custom-container.active .select-custom-options {
    display: block;
}

/* Estilo de cada opci¨®n */
.select-custom-option {
    padding: 0.75rem 1rem;
    cursor: pointer;
    transition: background-color 0.2s ease;
}
.select-custom-option:hover {
    background-color: #f1f1f1;
}
