/* public/dist/css/selects.css */

/* --- STANDARD SELECT & CUSTOM SELECT MODERNIZATION --- */

select.form-control,
.custom-select {
    height: 42px !important;
    padding: 0.6rem 2.5rem 0.6rem 0.85rem !important;
    font-size: 0.9rem !important;
    border: 1.5px solid var(--main-grey-300) !important;
    border-radius: var(--r-sm) !important;
    background-color: #fff !important;
    color: var(--main-grey-800) !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23adb5bd' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 14px 10px !important;
    transition: all 0.2s ease-in-out !important;
    cursor: pointer;
}

/* 
   NOTA: La "tendina" (menu a discesa) della select nativa è renderizzata dal sistema operativo.
   Queste regole tentano di migliorarla nei browser che lo permettono.
*/
select option {
    padding: 10px !important;
    background-color: #fff !important;
    color: var(--main-grey-700) !important;
    font-size: 0.9rem !important;
}

select.form-control:focus,
.custom-select:focus {
    border-color: var(--main-blue-500) !important;
    box-shadow: 0 0 0 3px rgba(var(--main-blue-rgb), 0.1) !important;
    outline: none !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%233b8ce0' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
}

/* Stile per le sezioni interne (optgroup) */
select optgroup {
    font-weight: 700 !important;
    color: var(--main-grey-500) !important;
    text-transform: uppercase !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.03em !important;
    background-color: var(--main-grey-50) !important;
}

/* --- SELECT2 GLOBAL RESET & MODERNIZATION --- */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border: 1.5px solid var(--main-grey-300) !important;
    border-radius: var(--r-sm) !important;
    background-color: #fff !important;
    min-height: 42px !important;
    transition: all 0.2s ease-in-out !important;
    outline: none !important;
}

/* Single Selection */
.select2-container--default .select2-selection--single {
    height: 42px !important;
    display: flex;
    align-items: center;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--main-grey-800) !important;
    padding-left: 12px !important;
    font-size: 0.9rem;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 40px !important;
    top: 1px !important;
    right: 8px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: var(--main-grey-400) transparent transparent transparent !important;
    border-width: 6px 5px 0 5px !important;
}

/* Multiple Selection (Tags) */
.select2-container--default .select2-selection--multiple {
    padding: 3px 6px !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__rendered {
    padding: 0 !important;
    display: flex !important;
    flex-wrap: wrap;
    gap: 4px;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: var(--main-blue-50) !important;
    border: 1px solid var(--main-blue-200) !important;
    color: var(--main-blue-800) !important;
    border-radius: 6px !important;
    padding: 2px 10px 2px 24px !important; /* Spazio per la 'x' */
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    margin: 2px 0 !important;
    position: relative;
    transition: all 0.2s;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice:hover {
    background-color: var(--main-blue-100) !important;
    border-color: var(--main-blue-300) !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: var(--main-blue-400) !important;
    font-weight: bold !important;
    border: none !important;
    background: none !important;
    position: absolute !important;
    left: 6px !important;
    top: 45% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    font-size: 14px !important;
    transition: color 0.2s !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
    color: var(--main-red-600) !important;
    background: none !important;
}

/* Dropdown Menu (La "Tendina") */
.select2-dropdown {
    border: 1px solid var(--main-grey-200) !important;
    border-radius: var(--r-md) !important;
    box-shadow: var(--shadow-lg) !important;
    background-color: #fff !important;
    margin-top: 6px !important;
    overflow: hidden !important;
    z-index: 9999 !important;
    padding: 6px !important; /* Crea respiro tra opzioni e bordo */
}

/* Lista delle opzioni */
.select2-results__options {
    max-height: 280px !important;
    padding-right: 4px !important; /* Spazio per la scrollbar */
}

/* Singola opzione */
.select2-results__option {
    padding: 8px 12px !important;
    font-size: 0.9rem !important;
    color: var(--main-grey-700) !important;
    border-radius: var(--r-sm) !important; /* Opzioni arrotondate */
    margin-bottom: 2px !important;
    transition: all 0.15s ease !important;
}

.select2-results__option:last-child {
    margin-bottom: 0 !important;
}

/* Opzione evidenziata (Hover) */
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: var(--main-blue-50) !important; /* Sfondo leggero */
    color: var(--main-blue-600) !important; /* Testo blu */
    font-weight: 600 !important;
}

/* Opzione già selezionata nella lista */
.select2-container--default .select2-results__option[aria-selected=true] {
    background-color: var(--main-blue-100) !important;
    color: var(--main-blue-700) !important;
    font-weight: 700 !important;
}

/* Barra di ricerca interna alla tendina */
.select2-search--dropdown {
    padding: 8px 4px 12px 4px !important;
    border-bottom: 1px solid var(--main-grey-100) !important;
    margin-bottom: 8px !important;
}

.select2-search--dropdown .select2-search__field {
    border: 1.5px solid var(--main-grey-200) !important;
    border-radius: var(--r-sm) !important;
    padding: 6px 10px !important;
    font-size: 0.85rem !important;
    outline: none !important;
}

/* Personalizzazione Scrollbar della tendina */
.select2-results__options::-webkit-scrollbar {
    width: 6px;
}
.select2-results__options::-webkit-scrollbar-track {
    background: transparent;
}
.select2-results__options::-webkit-scrollbar-thumb {
    background: var(--main-grey-300);
    border-radius: 10px;
}
.select2-results__options::-webkit-scrollbar-thumb:hover {
    background: var(--main-grey-400);
}

/* Focus State Global */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple {
    border-color: var(--main-blue-500) !important;
    box-shadow: 0 0 0 3px rgba(var(--main-blue-rgb), 0.1) !important;
}

/* Rende il box Select2 non cliccabile e cambia lo sfondo in stile ReadOnly standard */
.select2-container.select2-readonly {
    pointer-events: none; /* Blocca tutti i click, hover ed eventi del mouse */
}

.select2-container.select2-readonly .select2-selection {
    background-color: #e9ecef !important; /* Grigio chiaro di Bootstrap per i campi readonly */
    border-color: #ced4da !important;
    opacity: 1 !important;
    cursor: not-allowed;
}

/* Nasconde l'eventuale freccetta di apertura o pulsante clear se ereditati */
.select2-container.select2-readonly .select2-selection__clear {
    display: none !important;
}