/* Stili per i campi SmartERP (Select2) nei form Fluent Forms */

/* Asterisco required: rimuovi underline e forza colore rosso */
.ff-el-group .select2-container--default ~ .ff-el-input--label label .required,
.ff-el-group label .required {
    color: var(--fluentform-danger); !important;
    text-decoration: none !important;
    -webkit-text-decoration: none !important;
    border-bottom: none !important;
    font-weight: 700;
}

/* Container Select2: stessa altezza, padding e bordo degli input Fluent Forms */
.ff-el-group .select2-container--default .select2-selection--single {
    height: auto;
    min-height: 38px;
    padding: 8px 36px 8px 12px;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    background-color: #fff;
    font-size: 14px;
    line-height: 1.5;
    color: #374151;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.ff-el-group .select2-container--default.select2-container--focus .select2-selection--single,
.ff-el-group .select2-container--default.select2-container--open .select2-selection--single {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    outline: none;
}

/* Testo selezionato */
.ff-el-group .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 0;
    padding-right: 0;
    line-height: 1.5;
    color: #374151;
}

/* Freccia di Select2 */
.ff-el-group .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100%;
    right: 10px;
    top: 0;
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ff-el-group .select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #6b7280 transparent transparent transparent;
    border-width: 5px 5px 0 5px;
}

.ff-el-group .select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
    border-color: transparent transparent #6b7280 transparent;
    border-width: 0 5px 5px 5px;
}

/* X di clear */
.ff-el-group .select2-container--default .select2-selection--single .select2-selection__clear {
    margin-right: 26px;
    color: #6b7280;
    font-size: 18px;
    font-weight: 400;
    line-height: 1;
}


/* Dropdown */
.ff-el-group .select2-container--default .select2-dropdown {
    border: 1px solid #d1d5db;
    border-radius: 4px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    margin-top: 2px;
}

/* Opzioni nel dropdown */
.ff-el-group .select2-container--default .select2-results__option {
    padding: 8px 12px;
    font-size: 14px;
    line-height: 1.5;
    color: #374151;
}

/* Hover / selezione */
.ff-el-group .select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #eff6ff;
    color: #1d4ed8;
}

.ff-el-group .select2-container--default .select2-results__option[aria-selected="true"] {
    background-color: #dbeafe;
    color: #1e40af;
}

/* Placeholder */
.ff-el-group .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #9ca3af;
}

/* Forza larghezza 100% */
.ff-el-group .select2-container {
    width: 100% !important;
}

/* Assicurati che la select nativa sia nascosta */
.ff-el-group select.itc-erp-corsi-combobox.select2-hidden-accessible {
    border: 0 !important;
    clip: rect(0 0 0 0) !important;
    height: 1px !important;
    margin: -1px !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    width: 1px !important;
}

.fluentform span.select2.select2-container::after {
    border-width: 0;
}

/* Campo di ricerca nel dropdown (appenduto al body da Select2, non dentro ff-el-group) */
.itc-erp-corsi-dropdown .select2-search--dropdown .select2-search__field {
    padding: 6px 10px !important;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    font-size: 14px;
    line-height: 1.5;
    color: #374151;
    outline: none;
}

.itc-erp-corsi-dropdown .select2-search--dropdown .select2-search__field:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
