/* ═══════════════════════════════════════════════════════════════════
   SELECT2 — Bootstrap 5 Theme Override (Krajee)
   • Fully uses BS5 CSS variables → auto light/dark support
   • Single select: matches .form-control height exactly
   • Multi select: fixed height, chips scroll horizontally
   • Dropdown: matches app background, no tints
   ═══════════════════════════════════════════════════════════════════ */

/* ── Shared input shell ───────────────────────────────────────────── */
.select2-container--krajee-bs5 .select2-selection--single,
.select2-container--krajee-bs5 .select2-selection--multiple {
    background-color : var(--bs-body-bg);
    border           : 1px solid var(--bs-border-color);
    border-radius    : var(--bs-border-radius, 0.375rem);
    color            : var(--bs-body-color);
    transition       : border-color 0.15s ease-in-out,
    box-shadow   0.15s ease-in-out;
}

/* ── Single select ────────────────────────────────────────────────── */
.select2-container--krajee-bs5 .select2-selection--single {
    height      : calc(1.5em + 0.75rem + 2px);
    display     : flex;
    align-items : center;
    padding     : 0;
    position    : relative;
}

.select2-container--krajee-bs5 .select2-selection--single
.select2-selection__rendered {
    line-height  : 1.5;
    padding      : 0.375rem 2rem 0.375rem 0.75rem;
    color        : var(--bs-body-color);
    width        : 100%;
    overflow     : hidden;
    text-overflow: ellipsis;
    white-space  : nowrap;
}

.select2-container--krajee-bs5 .select2-selection--single
.select2-selection__placeholder {
    color  : var(--bs-secondary-color, var(--bs-body-color));
    opacity: 0.65;
}

.select2-container--krajee-bs5 .select2-selection--single
.select2-selection__clear {
    position   : absolute;
    right      : 1.75rem;
    top        : 50%;
    transform  : translateY(-50%);
    color      : var(--bs-body-color);
    opacity    : 0.5;
    font-size  : 1.1rem;
    line-height: 1;
    cursor     : pointer;
    transition : opacity 0.15s;
}
.select2-container--krajee-bs5 .select2-selection--single
.select2-selection__clear:hover {
    opacity: 1;
}

.select2-container--krajee-bs5 .select2-selection--single
.select2-selection__arrow {
    position : absolute;
    right    : 0.6rem;
    top      : 50%;
    transform: translateY(-50%);
    height   : auto;
    width    : 16px;
}
.select2-container--krajee-bs5 .select2-selection--single
.select2-selection__arrow b {
    border-color: var(--bs-body-color) transparent transparent transparent;
    border-style: solid;
    border-width: 5px 4px 0 4px;
    opacity     : 0.65;
    display     : block;
}
.select2-container--krajee-bs5.select2-container--open
.select2-selection--single .select2-selection__arrow b {
    border-color: transparent transparent var(--bs-body-color) transparent;
    border-width: 0 4px 5px 4px;
}

/* ── Focus / open state ───────────────────────────────────────────── */
.select2-container--krajee-bs5.select2-container--focus
.select2-selection--single,
.select2-container--krajee-bs5.select2-container--open
.select2-selection--single,
.select2-container--krajee-bs5.select2-container--focus
.select2-selection--multiple,
.select2-container--krajee-bs5.select2-container--open
.select2-selection--multiple {
    border-color: #86b7fe;
    outline     : 0;
    box-shadow  : 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Detach border when dropdown is attached below */
.select2-container--krajee-bs5.select2-container--open.select2-container--below
.select2-selection--single,
.select2-container--krajee-bs5.select2-container--open.select2-container--below
.select2-selection--multiple {
    border-bottom-left-radius : 0;
    border-bottom-right-radius: 0;
    border-bottom-color       : transparent;
    box-shadow                : none;
}
/* Detach border when dropdown is attached above */
.select2-container--krajee-bs5.select2-container--open.select2-container--above
.select2-selection--single,
.select2-container--krajee-bs5.select2-container--open.select2-container--above
.select2-selection--multiple {
    border-top-left-radius : 0;
    border-top-right-radius: 0;
    border-top-color       : transparent;
    box-shadow             : none;
}

/* ── Disabled ─────────────────────────────────────────────────────── */
.select2-container--krajee-bs5.select2-container--disabled
.select2-selection--single,
.select2-container--krajee-bs5.select2-container--disabled
.select2-selection--multiple {
    opacity       : 0.65;
    cursor        : not-allowed;
    pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════════════
   MULTI-SELECT — fixed height, chips scroll horizontally
   ═══════════════════════════════════════════════════════════════════ */
.select2-container--krajee-bs5 .select2-selection--multiple {
    height     : calc(1.5em + 0.75rem + 2px);
    display    : flex;
    align-items: center;
    padding    : 0 0.375rem;
    overflow   : hidden;
    cursor     : text;
}

/* Inner <ul>: single scrollable row */
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-selection__rendered {
    display           : flex;
    flex-wrap         : nowrap;
    align-items       : center;
    gap               : 0.25rem;
    overflow-x        : auto;
    overflow-y        : hidden;
    scrollbar-width   : none;
    -ms-overflow-style: none;
    padding           : 0;
    margin            : 0;
    width             : 100%;
    height            : 100%;
    list-style        : none;
}
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-selection__rendered::-webkit-scrollbar {
    display: none;
}

/* ── Chip / tag ───────────────────────────────────────────────────── */
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-selection__choice {
    display         : inline-flex;
    align-items     : center;
    gap             : 0.25rem;
    flex-shrink     : 0;
    max-width       : 180px;
    height          : 1.5rem;
    padding         : 0 0.5rem;
    border-radius   : var(--bs-border-radius-pill, 50rem);
    font-size       : 0.75rem;
    line-height     : 1;
    white-space     : nowrap;
    overflow        : hidden;
    text-overflow   : ellipsis;
    background-color: var(--bs-body-bg);
    border          : 1px solid var(--bs-border-color);
    color           : var(--bs-body-color);
}

.select2-container--krajee-bs5 .select2-selection--multiple
.select2-selection__choice__display {
    overflow     : hidden;
    text-overflow: ellipsis;
    max-width    : 140px;
}

/* Chip × remove */
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-selection__choice__remove {
    display         : inline-flex;
    align-items     : center;
    justify-content : center;
    width           : 14px;
    height          : 14px;
    border-radius   : 50%;
    color           : var(--bs-body-color);
    opacity         : 0.55;
    font-size       : 0.8rem;
    line-height     : 1;
    cursor          : pointer;
    flex-shrink     : 0;
    order           : -1;
    transition      : opacity 0.15s, background-color 0.15s;
}
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-selection__choice__remove:hover {
    opacity         : 1;
    background-color: rgba(220, 53, 69, 0.2);
}

/* Inline search input */
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-search--inline {
    flex-shrink: 0;
    margin     : 0;
    padding    : 0;
}
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-search--inline .select2-search__field {
    height    : 1.5rem;
    border    : none;
    outline   : none;
    background: transparent;
    color     : var(--bs-body-color);
    font-size : var(--bs-body-font-size, 1rem);
    padding   : 0 0.25rem;
    min-width : 80px;
}
.select2-container--krajee-bs5 .select2-selection--multiple
.select2-search--inline .select2-search__field::placeholder {
    color  : var(--bs-secondary-color, var(--bs-body-color));
    opacity: 0.65;
}

/* ═══════════════════════════════════════════════════════════════════
   DROPDOWN
   ═══════════════════════════════════════════════════════════════════ */
.select2-container--krajee-bs5 .select2-dropdown {
    background-color: var(--bs-body-bg);
    border          : 1px solid #86b7fe;
    border-radius   : var(--bs-border-radius, 0.375rem);
    box-shadow      : 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    color           : var(--bs-body-color);
}
.select2-container--krajee-bs5 .select2-dropdown--below {
    border-top-left-radius : 0;
    border-top-right-radius: 0;
}
.select2-container--krajee-bs5 .select2-dropdown--above {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

/* Dropdown search field */
.select2-container--krajee-bs5 .select2-search--dropdown .select2-search__field {
    background-color: var(--bs-body-bg);
    border          : 1px solid var(--bs-border-color);
    border-radius   : var(--bs-border-radius-sm, 0.25rem);
    color           : var(--bs-body-color);
    padding         : 0.375rem 0.75rem;
}
.select2-container--krajee-bs5 .select2-search--dropdown
.select2-search__field:focus {
    border-color: #86b7fe;
    outline     : 0;
    box-shadow  : 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Options */
.select2-container--krajee-bs5 .select2-results__option {
    padding: 0.4rem 0.75rem;
    color  : var(--bs-body-color);
}

/* Already selected (but not hovered) */
.select2-container--krajee-bs5 .select2-results__option[aria-selected="true"] {
    background-color: var(--bs-body-bg);
    color           : var(--bs-body-color);
}

/* Hovered / keyboard-focused */
.select2-container--krajee-bs5
.select2-results__option--highlighted[aria-selected] {
    background-color: var(--bs-primary, #0d6efd);
    color           : #fff;
}

/* Disabled option */
.select2-container--krajee-bs5 .select2-results__option[aria-disabled="true"] {
    color  : var(--bs-secondary-color, var(--bs-body-color));
    opacity: 0.5;
}

/* ═══════════════════════════════════════════════════════════════════
   THEME-ADAPTIVE OVERRIDES
   All colors use Bootstrap 5 CSS variables — auto light/dark mode.
   Drop this after Bootstrap's own CSS and any custom overrides.
   ═══════════════════════════════════════════════════════════════════ */
.select2-container--krajee-bs5 .select2-results__option[aria-selected] {
    background-color : var(--bs-body-bg);
    border           : 1px solid var(--bs-border-color);
    border-radius    : var(--bs-border-radius, 0.375rem);
    color            : var(--bs-body-color);
    transition       : background-color 0.15s ease, color 0.15s ease;
}

/* Already selected item — show a subtle tint so user knows it's picked */
.select2-container--krajee-bs5 .select2-results__option[aria-selected="true"] {
    background-color : color-mix(in srgb, var(--bs-primary, #0d6efd) 12%, var(--bs-body-bg));
    border-color     : color-mix(in srgb, var(--bs-primary, #0d6efd) 30%, var(--bs-border-color));
    color            : var(--bs-body-color);
}

/* Hover / keyboard focus on any option */
.select2-container--krajee-bs5 .select2-results__option--highlighted[aria-selected] {
    background-color : var(--bs-primary, #0d6efd);
    border-color     : var(--bs-primary, #0d6efd);
    color            : #fff;
}

/* Hover on an already-selected item — slightly darker tint */
.select2-container--krajee-bs5 .select2-results__option--highlighted[aria-selected="true"] {
    background-color : color-mix(in srgb, var(--bs-primary, #0d6efd) 85%, var(--bs-body-bg));
    border-color     : var(--bs-primary, #0d6efd);
    color            : #fff;
}

/* Disabled option */
.select2-container--krajee-bs5 .select2-results__option[aria-disabled="true"] {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-secondary-color);
    opacity          : 0.5;
    cursor           : not-allowed;
}
/* ── Autocomplete suggestions dropdown ───────────────────────────── */
.autocomplete-suggestions {
    background-color : var(--bs-body-bg)!important;
    border           : 1px solid var(--bs-border-color);
    border-radius    : var(--bs-border-radius, 0.375rem);
    box-shadow       : 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    color            : var(--bs-body-color);
    overflow-y       : auto;
    z-index          : 9999;
}

.autocomplete-suggestion {
    padding          : 0.45rem 0.75rem;
    cursor           : pointer;
    color            : var(--bs-body-color);
    font-size        : 0.875rem;
    white-space      : nowrap;
    overflow         : hidden;
    text-overflow    : ellipsis;
    transition       : background-color 0.1s ease;
}

.autocomplete-suggestion:hover,
.autocomplete-selected {
    background-color : var(--bs-primary-bg-subtle, color-mix(in srgb, var(--bs-primary, #0d6efd) 15%, var(--bs-body-bg)));
    color            : var(--bs-emphasis-color, var(--bs-body-color));
}

/* ── Form controls — inputs, textareas, selects ──────────────────── */
.form-control,
.form-select {
    background-color : var(--bs-secondary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

.form-control:focus,
.form-select:focus {
    background-color : var(--bs-secondary-bg);
    border-color     : #86b7fe;
    color            : var(--bs-body-color);
    box-shadow       : 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

.form-control::placeholder {
    color   : var(--bs-secondary-color);
    opacity : 1;
}

.form-control:disabled,
.form-select:disabled {
    background-color : var(--bs-tertiary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-secondary-color);
    opacity          : 0.7;
    cursor           : not-allowed;
}

/* ── Input groups ────────────────────────────────────────────────── */
.input-group-text {
    background-color : var(--bs-tertiary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

/* ── Cards ───────────────────────────────────────────────────────── */
.card {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

.card-header,
.card-footer {
    background-color : var(--bs-tertiary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

/* ── Tables ──────────────────────────────────────────────────────── */
.table {
    --bs-table-bg            : var(--bs-body-bg);
    --bs-table-striped-bg    : var(--bs-secondary-bg);
    --bs-table-hover-bg      : color-mix(in srgb, var(--bs-primary, #0d6efd) 8%, var(--bs-body-bg));
    --bs-table-border-color  : var(--bs-border-color);
    color                    : var(--bs-body-color);
}

.table thead th {
    background-color : var(--bs-tertiary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-secondary-color);
    font-weight      : 600;
    font-size        : 0.75rem;
    text-transform   : uppercase;
    letter-spacing   : 0.04em;
}

/* ── Modals ──────────────────────────────────────────────────────── */
.modal-content {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

.modal-header,
.modal-footer {
    background-color : var(--bs-tertiary-bg);
    border-color     : var(--bs-border-color);
}

/* ── Dropdowns ───────────────────────────────────────────────────── */
.dropdown-menu {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
    box-shadow       : 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.dropdown-item {
    color : var(--bs-body-color);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color : var(--bs-secondary-bg);
    color            : var(--bs-emphasis-color);
}

.dropdown-item.active,
.dropdown-item:active {
    background-color : var(--bs-primary, #0d6efd);
    color            : #fff;
}

.dropdown-divider {
    border-color : var(--bs-border-color);
}

/* ── Badges / pills ──────────────────────────────────────────────── */
.badge.bg-secondary {
    background-color : var(--bs-secondary-bg)  !important;
    color            : var(--bs-secondary-color) !important;
    border           : 1px solid var(--bs-border-color);
}

/* ── Nav tabs ────────────────────────────────────────────────────── */
.nav-tabs {
    border-color : var(--bs-border-color);
}

.nav-tabs .nav-link {
    color : var(--bs-secondary-color);
}

.nav-tabs .nav-link:hover {
    border-color     : var(--bs-border-color) var(--bs-border-color) transparent;
    color            : var(--bs-body-color);
}

.nav-tabs .nav-link.active {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color) var(--bs-border-color) var(--bs-body-bg);
    color            : var(--bs-emphasis-color);
}

/* ── List groups ─────────────────────────────────────────────────── */
.list-group-item {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

.list-group-item.active {
    background-color : var(--bs-primary, #0d6efd);
    border-color     : var(--bs-primary, #0d6efd);
    color            : #fff;
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    background-color : var(--bs-secondary-bg);
    color            : var(--bs-emphasis-color);
}

/* ── Pagination ──────────────────────────────────────────────────── */
.page-link {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-primary, #0d6efd);
}

.page-link:hover {
    background-color : var(--bs-secondary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-primary, #0d6efd);
}

.page-item.active .page-link {
    background-color : var(--bs-primary, #0d6efd);
    border-color     : var(--bs-primary, #0d6efd);
    color            : #fff;
}

.page-item.disabled .page-link {
    background-color : var(--bs-secondary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-secondary-color);
}

/* ── Alerts ──────────────────────────────────────────────────────── */
.alert {
    border-color : var(--bs-border-color);
}

/* ── Tooltips ────────────────────────────────────────────────────── */
.tooltip-inner {
    background-color : var(--bs-emphasis-color);
    color            : var(--bs-body-bg);
}

/* ── Scrollbar — subtle in dark mode ─────────────────────────────── */
@media (prefers-color-scheme: dark) {
    :root {
        scrollbar-color: var(--bs-secondary-bg) var(--bs-body-bg);
    }
}

[data-bs-theme="dark"] {
    scrollbar-color: var(--bs-secondary-bg) var(--bs-body-bg);
}

/* ═══════════════════════════════════════════════════════════════════
   MODAL FORM THEME FIX
   Higher specificity to beat Bootstrap's .modal-content defaults
   and select2's own styles inside modals.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Modal shell ─────────────────────────────────────────────────── */
.modal .modal-content {
    background-color : var(--bs-body-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

.modal .modal-header,
.modal .modal-footer {
    background-color : var(--bs-tertiary-bg);
    border-color     : var(--bs-border-color);
    color            : var(--bs-body-color);
}

.modal .modal-body {
    background-color : var(--bs-body-bg);
    color            : var(--bs-body-color);
}

/* ── Form labels ─────────────────────────────────────────────────── */
.modal .control-label,
.modal .form-label,
.modal label {
    color : var(--bs-body-color);
}

/* ── All inputs, textareas, plain selects ────────────────────────── */
.modal .form-control,
.modal .form-select {
    background-color : var(--bs-secondary-bg) !important;
    border-color     : var(--bs-border-color) !important;
    color            : var(--bs-body-color)   !important;
}

.modal .form-control:focus,
.modal .form-select:focus {
    background-color : var(--bs-secondary-bg) !important;
    border-color     : #86b7fe               !important;
    color            : var(--bs-body-color)   !important;
    box-shadow       : 0 0 0 0.25rem rgba(13, 110, 253, 0.25) !important;
}

.modal .form-control::placeholder {
    color   : var(--bs-secondary-color);
    opacity : 1;
}

/* ── Input group addons (datetime picker icons) ──────────────────── */
.modal .input-group-text {
    background-color : var(--bs-tertiary-bg) !important;
    border-color     : var(--bs-border-color) !important;
    color            : var(--bs-body-color)   !important;
}

/* ── Select2 — single select inside modal ────────────────────────── */
.modal .select2-container--krajee-bs5 .select2-selection--single {
    background-color : var(--bs-secondary-bg) !important;
    border-color     : var(--bs-border-color) !important;
    color            : var(--bs-body-color)   !important;
}

.modal .select2-container--krajee-bs5 .select2-selection--single
.select2-selection__rendered {
    color : var(--bs-body-color) !important;
}

.modal .select2-container--krajee-bs5 .select2-selection--single
.select2-selection__placeholder {
    color   : var(--bs-secondary-color) !important;
    opacity : 1;
}

.modal .select2-container--krajee-bs5 .select2-selection--single
.select2-selection__clear {
    color : var(--bs-body-color) !important;
}

.modal .select2-container--krajee-bs5 .select2-selection--single
.select2-selection__arrow b {
    border-top-color : var(--bs-body-color) !important;
}

/* ── Select2 — multi select inside modal ─────────────────────────── */
.modal .select2-container--krajee-bs5 .select2-selection--multiple {
    background-color : var(--bs-secondary-bg) !important;
    border-color     : var(--bs-border-color) !important;
    color            : var(--bs-body-color)   !important;
}

.modal .select2-container--krajee-bs5 .select2-selection--multiple
.select2-search__field {
    background : transparent      !important;
    color      : var(--bs-body-color) !important;
}

/* ── Select2 focus/open state ────────────────────────────────────── */
.modal .select2-container--krajee-bs5.select2-container--focus
.select2-selection--single,
.modal .select2-container--krajee-bs5.select2-container--open
.select2-selection--single,
.modal .select2-container--krajee-bs5.select2-container--focus
.select2-selection--multiple,
.modal .select2-container--krajee-bs5.select2-container--open
.select2-selection--multiple {
    border-color : #86b7fe !important;
    box-shadow   : 0 0 0 0.25rem rgba(13, 110, 253, 0.25) !important;
}

/* ── help-block (Yii2 validation messages) ───────────────────────── */
.modal .help-block {
    color     : var(--bs-danger, #dc3545);
    font-size : 0.8rem;
    margin-top: 0.25rem;
}

/* ── Error summary box ───────────────────────────────────────────── */
.modal .error-summary {
    background-color : color-mix(in srgb, var(--bs-danger, #dc3545) 10%, var(--bs-body-bg));
    border           : 1px solid color-mix(in srgb, var(--bs-danger, #dc3545) 40%, var(--bs-border-color));
    border-radius    : var(--bs-border-radius, 0.375rem);
    color            : var(--bs-body-color);
    padding          : 0.75rem 1rem;
    margin-top       : 1rem;
}
/* ══════════════════════════════════════════════════════════════════
   SELECT2 — Bootstrap theme: INPUT SHELL (single select)
   ══════════════════════════════════════════════════════════════════ */

/* ── Outer container width ───────────────────────────────────────── */
.select2-container--bootstrap {
    width: 100% !important;
}

/* ── The visible input box ───────────────────────────────────────── */
.select2-container--bootstrap .select2-selection--single {
    height           : calc(1.5em + 0.75rem + 2px); /* matches BS5 .form-control */
    background-color : var(--bs-secondary-bg);
    border           : 1px solid var(--bs-border-color);
    border-radius    : var(--bs-border-radius, 0.375rem);
    color            : var(--bs-body-color);
    display          : flex;
    align-items      : center;
    padding          : 0;
    transition       : border-color 0.15s ease-in-out,
                       box-shadow   0.15s ease-in-out;
    outline          : none;
}

/* Focus / open state */
.select2-container--bootstrap.select2-container--focus
    .select2-selection--single,
.select2-container--bootstrap.select2-container--open
    .select2-selection--single {
    border-color : #86b7fe;
    box-shadow   : 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Detach bottom border when dropdown opens below */
.select2-container--bootstrap.select2-container--open.select2-container--below
    .select2-selection--single {
    border-bottom-left-radius  : 0;
    border-bottom-right-radius : 0;
    border-bottom-color        : transparent;
    box-shadow                 : none;
}

/* Detach top border when dropdown opens above */
.select2-container--bootstrap.select2-container--open.select2-container--above
    .select2-selection--single {
    border-top-left-radius  : 0;
    border-top-right-radius : 0;
    border-top-color        : transparent;
    box-shadow              : none;
}

/* Disabled state */
.select2-container--bootstrap.select2-container--disabled
    .select2-selection--single {
    background-color : var(--bs-secondary-bg);
    border-color     : var(--bs-border-color);
    opacity          : 0.65;
    cursor           : not-allowed;
    pointer-events   : none;
}

/* ── Rendered text (the selected value label) ────────────────────── */
.select2-container--bootstrap .select2-selection--single
    .select2-selection__rendered {
    color         : var(--bs-body-color);
    line-height   : 1.5;
    padding       : 0.375rem 2.25rem 0.375rem 0.75rem; /* space for arrow + clear */
    width         : 100%;
    overflow      : hidden;
    text-overflow : ellipsis;
    white-space   : nowrap;
}

/* Placeholder */
.select2-container--bootstrap .select2-selection--single
    .select2-selection__placeholder {
    color   : var(--bs-secondary-color, var(--bs-body-color));
    opacity : 0.65;
}

/* ── Clear "×" button ────────────────────────────────────────────── */
.select2-container--bootstrap .select2-selection--single
    .select2-selection__clear {
    float       : right;          /* or use position if needed */
    color       : var(--bs-body-color);
    opacity     : 0.45;
    font-size   : 1rem;
    line-height : 1;
    margin-right: 0.25rem;
    cursor      : pointer;
    transition  : opacity 0.15s;
}

.select2-container--bootstrap .select2-selection--single
    .select2-selection__clear:hover {
    opacity : 1;
}

/* ── Chevron arrow ───────────────────────────────────────────────── */
.select2-container--bootstrap .select2-selection--single
    .select2-selection__arrow {
    position  : absolute;
    top       : 50%;
    right     : 0.65rem;
    transform : translateY(-50%);
    height    : auto;
    width     : 16px;
}

.select2-container--bootstrap .select2-selection--single
    .select2-selection__arrow b {
    display      : block;
    width        : 0;
    height       : 0;
    border-style : solid;
    border-width : 5px 4px 0 4px;
    border-color : var(--bs-body-color) transparent transparent transparent;
    opacity      : 0.6;
}

/* Flip arrow when open */
.select2-container--bootstrap.select2-container--open
    .select2-selection--single .select2-selection__arrow b {
    border-width : 0 4px 5px 4px;
    border-color : transparent transparent var(--bs-body-color) transparent;
}

/* ══════════════════════════════════════════════════════════════════
   SELECT2 — Bootstrap theme dropdown override
   Scoped to .select2-container--bootstrap so it won't affect
   other select2 instances using different themes.
   ══════════════════════════════════════════════════════════════════ */

/* ── Dropdown shell ──────────────────────────────────────────────── */
.select2-container--bootstrap .select2-dropdown {
    background-color : var(--bs-secondary-bg);
    border           : 1px solid #86b7fe;          /* matches BS5 focus ring */
    border-radius    : var(--bs-border-radius, 0.375rem);
    box-shadow       : 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    color            : var(--bs-body-color);
    overflow         : hidden;
}

.select2-container--bootstrap .select2-dropdown--above {
    border-bottom-left-radius  : 0;
    border-bottom-right-radius : 0;
    border-bottom-color        : var(--bs-border-color);
}

.select2-container--bootstrap .select2-dropdown--below {
    border-top-left-radius  : 0;
    border-top-right-radius : 0;
    border-top-color        : var(--bs-border-color);
}

/* ── Search input inside dropdown ────────────────────────────────── */
.select2-container--bootstrap .select2-search--dropdown {
    padding : 0.5rem;
    background-color : var(--bs-secondary-bg);
}

.select2-container--bootstrap .select2-search--dropdown .select2-search__field {
    width            : 100%;
    background-color : var(--bs-secondary-bg);
    border           : 1px solid var(--bs-border-color);
    border-radius    : var(--bs-border-radius-sm, 0.25rem);
    color            : var(--bs-body-color);
    padding          : 0.375rem 0.75rem;
    font-size        : var(--bs-body-font-size, 1rem);
    outline          : none;
    transition       : border-color 0.15s ease, box-shadow 0.15s ease;
}

.select2-container--bootstrap .select2-search--dropdown .select2-search__field:focus {
    border-color : #86b7fe;
    box-shadow   : 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* ── Results list ────────────────────────────────────────────────── */
.select2-container--bootstrap .select2-results {
    background-color : var(--bs-secondary-bg);
}

.select2-container--bootstrap .select2-results__options {
    max-height   : 200px;
    overflow-y   : auto;
    padding      : 0.25rem 0;
    margin       : 0;
    /* Thin scrollbar */
    scrollbar-width : thin;
    scrollbar-color : var(--bs-border-color) transparent;
}

.select2-container--bootstrap .select2-results__options::-webkit-scrollbar {
    width : 4px;
}
.select2-container--bootstrap .select2-results__options::-webkit-scrollbar-track {
    background : transparent;
}
.select2-container--bootstrap .select2-results__options::-webkit-scrollbar-thumb {
    background    : var(--bs-border-color);
    border-radius : 2px;
}

/* ── Individual option ───────────────────────────────────────────── */
.select2-container--bootstrap .select2-results__option {
    padding         : 0.45rem 0.875rem;
    font-size       : var(--bs-body-font-size, 1rem);
    color           : var(--bs-body-color);
    background-color: transparent;
    cursor          : pointer;
    transition      : background-color 0.1s ease, color 0.1s ease;
    user-select     : none;
}

/* Already selected */
.select2-container--bootstrap .select2-results__option[aria-selected="true"] {
    background-color : color-mix(in srgb,
                         var(--bs-primary, #0d6efd) 12%,
                         var(--bs-secondary-bg));
    color            : var(--bs-body-color);
}

/* Hovered / keyboard-focused */
.select2-container--bootstrap .select2-results__option--highlighted,
.select2-container--bootstrap .select2-results__option--highlighted[aria-selected] {
    background-color : var(--bs-primary, #0d6efd);
    color            : #fff;
}

/* Disabled option */
.select2-container--bootstrap .select2-results__option[aria-disabled="true"] {
    color   : var(--bs-secondary-color, var(--bs-body-color));
    opacity : 0.5;
    cursor  : not-allowed;
}

/* ── "No results" message ────────────────────────────────────────── */
.select2-container--bootstrap .select2-results__message {
    padding  : 0.5rem 0.875rem;
    color    : var(--bs-secondary-color, var(--bs-body-color));
    opacity  : 0.6;
    font-size: 0.875rem;
}

/* ── Group labels ────────────────────────────────────────────────── */
.select2-container--bootstrap .select2-results__group {
    padding        : 0.4rem 0.875rem 0.2rem;
    font-size      : 0.7rem;
    font-weight    : 600;
    letter-spacing : 0.06em;
    text-transform : uppercase;
    color          : var(--bs-secondary-color, var(--bs-body-color));
    opacity        : 0.6;
}