/* --- Match form-floating height & native .form-select appearance --- */

.select2-container--bootstrap-5 .select2-selection--single {
    height: calc(3.5rem + 2px);
    min-height: calc(3.5rem + 2px);
    padding: 1.625rem 2.25rem 0.625rem 0.75rem;
    border-radius: var(--bs-border-radius, 0.375rem);
    border-color: var(--bs-border-color, #dee2e6);
    font-size: 1rem;
    line-height: 1.25;
    color: var(--bs-body-color, #212529);
    background-color: var(--bs-form-control-bg, #fff);
}

.select2-container--bootstrap-5
.select2-selection__rendered {
    line-height: 1.25;
    padding-left: 0;
    color: var(--bs-body-color, #212529);
}

.select2-container--bootstrap-5
.select2-selection__placeholder {
    color: #6c757d;
}

/* --- Focus/open ring --- */
.select2-container--bootstrap-5.select2-container--open .select2-selection--single,
.select2-container--bootstrap-5.select2-container--focus .select2-selection--single {
    border-color: #86b7fe;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
    outline: 0;
}

/* --- Arrow --- */
.select2-container--bootstrap-5 .select2-selection--single .select2-selection__arrow {
    height: 100%;
    right: 0.75rem;
}

/* --- Disabled state --- */
.select2-container--bootstrap-5.select2-container--disabled .select2-selection--single {
    background-color: #e9ecef;
    cursor: not-allowed;
}

/* --- Dropdown panel --- */
.select2-container--bootstrap-5
.select2-dropdown {
    border-color: var(--bs-border-color, #dee2e6);
}

/* --- Options --- */
.select2-container--bootstrap-5
.select2-results__option {
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    color: var(--bs-body-color, #212529);
}

.select2-container--bootstrap-5
.select2-results__option--highlighted {
    background-color: #f8f9fa !important;
    color: #212529 !important;
}

.select2-container--bootstrap-5
.select2-results__option--selected {
    background-color: #e9ecef !important;
    color: #212529 !important;
}

/* --- Hide form-floating label background cutout when Select2 is active --- */
.form-floating > .form-select.select2-hidden-accessible ~ label::after {
    display: none !important;
}

/* --- Validation state --- */
.select2-container--bootstrap-5.is-invalid .select2-selection--single {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25) !important;
}
