/* Modern Select2 Theme with Dark/Light Mode Support */
.select2-container--bootstrap-5 .select2-selection {
    border-radius: var(--radius-xs);
    border: 1px solid var(--bs-border-color);
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    min-height: 40px;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
    color: var(--bs-body-color);
    padding-left: 0;
    line-height: 38px;
}

.select2-container--bootstrap-5 .select2-selection--single .select2-selection__arrow {
    height: 38px;
}

.select2-container--bootstrap-5 .select2-selection--multiple {
    min-height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 0.75rem;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__rendered {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.25rem;
    padding: 0;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice {
    background-color: var(--bs-primary-bg-subtle);
    color: var(--bs-primary);
    border: 1px solid var(--bs-primary);
    border-radius: var(--radius-xs);
    padding: 0.25rem 0.5rem;
    margin: 0.125rem;
    font-size: var(--fs-body);
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice__remove {
    color: var(--bs-body-color);
    margin-right: 0.25rem;
    border: none;
    background: transparent;
    opacity: 0.8;
    font-size: var(--fs-md);
    line-height: 0.75;
}

.select2-container--bootstrap-5 .select2-selection--multiple .select2-selection__choice__remove:hover {
    color: var(--bs-danger);
    opacity: 1;
}

.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

.select2-dropdown {
    border: 1px solid var(--bs-primary);
    border-radius: var(--radius-sm);
    background-color: var(--bs-body-bg);
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    animation: select2DropdownFadeIn 0.2s ease-in-out;
}

.select2-container--bootstrap-5 .select2-search--dropdown .select2-search__field {
    border: 1px solid var(--bs-border-color);
    border-radius: var(--radius-xs);
    padding: 0.5rem;
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.select2-container--bootstrap-5 .select2-search--dropdown .select2-search__field:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
    outline: 0;
}

.select2-container--bootstrap-5 .select2-results__option {
    padding: 0.5rem 0.75rem;
    color: var(--bs-body-color);
}

.select2-container--bootstrap-5 .select2-results__option--highlighted[aria-selected] {
    background-color: var(--bs-primary);
    color: #fff;
}

.select2-container--bootstrap-5 .select2-results__option[aria-selected=true] {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-primary);
}

/* Custom placeholder styling */
.select2-container--bootstrap-5 .select2-selection__placeholder {
    color: var(--bs-secondary-color);
    opacity: 0.65;
}

/* Improve accessibility - focus states */
.select2-container--bootstrap-5 *:focus {
    outline: none;
}

/* Remove shadow from open dropdown to match Bootstrap 5 */
.select2-container--bootstrap-5.select2-container--open {
    z-index: 1056;
    /* Higher than Bootstrap modal (1055) */
}

/* Add sliding transition effect for dropdown */
@keyframes select2DropdownFadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Dark mode specific adjustments */
[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection {
    background-color: var(--bs-dark);
    border-color: var(--bs-border-color-translucent);
}

[data-bs-theme="dark"] .select2-dropdown {
    background-color: var(--bs-dark);
    border-color: var(--bs-border-color-translucent);
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-search--dropdown .select2-search__field {
    background-color: var(--bs-dark);
    border-color: var(--bs-border-color-translucent);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-results__option--highlighted[aria-selected] {
    background-color: var(--bs-primary);
}


/* Handling loading state */
.select2-container--bootstrap-5 .select2-results__option.loading-results {
    padding: 6px;
    text-align: center;
}

/* Fix for container width */
.select2-container {
    width: 100% !important;
}

/* Adjust height for single select */
.select2-container--bootstrap-5 .select2-selection--single {
    height: calc(1.5em + 0.75rem + 2px);
}

.select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
    line-height: calc(1.5em + 0.75rem);
}

/* Clear button styles */
.select2-container--bootstrap-5 .select2-selection__clear {
    color: var(--bs-secondary-color);
    background: transparent;
    border: none;
    padding: 0 5px;
    font-weight: bold;
    line-height: 1;
    font-size: var(--fs-2xl);
    height: 100%;
    margin-right: 5px;
    opacity: 0.6;
}

.select2-container--bootstrap-5 .select2-selection__clear:hover {
    opacity: 1;
}
.select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered {
    padding-top: 5px;
    padding-bottom: 5px;
    display: flex;
    align-items: center;
}