/* ================================================================
   Select2 DaisyUI Structural + Themed Extension
   ================================================================
   Base structure by user, color variables integrated via var(--color-*).
   Cosmetic design handled by DaisyUI.
================================================================== */

.select2-container {
    box-sizing: border-box;
    display: inline-block;
    margin: 0;
    position: relative;
    vertical-align: middle;
    width: 100% !important;
    /* color: var(--color-base-content); */
}

/* ================= Single select ================= */
.select2-container .select2-selection--single {
    box-sizing: border-box;
    cursor: pointer;
    display: flex;
    align-items: center;
    -webkit-user-select: none;
    user-select: none;
    /* background-color: var(--color-base-100); */
    /* border: var(--border) solid var(--color-base-300); */
    /* border-radius: var(--radius-field); */
    /* transition: border-color 0.2s ease, box-shadow 0.2s ease; */
}

/* Custom arrow icon */
.select2-selection {
  background-image: url("data:image/svg+xml;utf8,<svg fill='%23aaa' viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'><path d='M5.25 7.5L10 12.25L14.75 7.5H5.25Z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
  padding-right: 2rem; 
}

.select2-container .select2-selection--single:hover {
    /* border-color: var(--color-primary); */
}

.select2-container.select2-container--open .select2-selection--single {
    /* border-color: var(--color-primary); */
    /* box-shadow: 0 0 0 2px color-mix(in oklch, var(--color-primary) 25%, transparent); */
}

.select2-container.select2-container--disabled .select2-selection--single {
    /* background-color: var(--color-base-200); */
    /* border-color: var(--color-base-300); */
    /* color: color-mix(in oklch, var(--color-base-content) 60%, transparent); */
    /* cursor: not-allowed; */
    /* opacity: 0.6; */
}

.select2-container .select2-selection--single .select2-selection__rendered {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    /* padding: 0 2.5rem 0 1rem; */
}

.select2-container .select2-selection--single .select2-selection__clear {
    position: relative;
}

/* RTL support */
.select2-container[dir="rtl"] .select2-selection--single .select2-selection__rendered {
    /* padding-right: 1rem; */
    /* padding-left: 2.5rem; */
}


/* ================= Multiple select (UPD 260126) ================= */
.select2-container .select2-selection--multiple {
    box-sizing: border-box;
    cursor: pointer;
    display: flex; 
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem;
    min-height: 3rem; /* Высота как у DaisyUI input */
    padding: 2px 8px; /* чтобы плашки не прилипали к краям */
    -webkit-user-select: none;
    user-select: none;
    background-color: var(--color-base-100);
    border: var(--border) solid var(--color-base-300);
    border-radius: var(--radius-field);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

/* исправит наложение элементов */
.select2-container .select2-selection--multiple .select2-selection__rendered {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 4px; /* Расстояние между выбранными элементами */
    width: 100%;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: var(--color-primary);
    color: var(--color-primary-content);
    border-radius: var(--radius-selector, 0.5rem);
    padding: 0.25rem 0.75rem;
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    margin: 0; /* Убираем стандартные отступы Select2, так как используем gap */
    border: none;
}




/* ================= Dropdown ================= */
.select2-dropdown {
    box-sizing: border-box;
    display: block;
    position: absolute;
    left: -100000px;
    width: 100%;
    z-index: 1051;
    background-color: var(--color-base-100);
    border: var(--border) solid var(--color-base-300);
    border-radius: var(--radius-box);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
}

.select2-container--open .select2-dropdown {
    left: 0;
}

.select2-dropdown--above {
    border-bottom: none;
    border-top-left-radius: var(--radius-box);
    border-top-right-radius: var(--radius-box);
}

.select2-dropdown--below {
    border-top: none;
    border-bottom-left-radius: var(--radius-box);
    border-bottom-right-radius: var(--radius-box);
}

/* ================= Search field ================= */
.select2-search--dropdown {
    display: block;
    padding: 0.5rem;
    border-bottom: var(--border) solid var(--color-base-300);
    background-color: var(--color-base-100);
}

.select2-search--dropdown .select2-search__field {
    padding: 0.5rem;
    width: 100%;
    box-sizing: border-box;
    /* border: var(--border) solid var(--color-base-300); */
    border-radius: var(--radius-field);
    background-color: var(--color-base-100);
    /* color: var(--color-base-content); */
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.select2-search--dropdown .select2-search__field:focus {
    /* border-color: var(--color-primary); */
    box-shadow: 0 0 0 2px color-mix(in oklch, var(--color-primary) 25%, transparent);
    outline: none;
}

.select2-search--dropdown.select2-search--hide {
    display: none;
}

/* Inline search */
.select2-container .select2-search--inline {
    /* float: left; */
    display: block;
    padding: 0.5rem;
    border-bottom: var(--border) solid var(--color-base-300);
    background-color: var(--color-base-100);
}

.select2-container .select2-search--inline .select2-search__field {
    box-sizing: border-box;
    border: none;
    font-size: 100%;
    margin-top: 5px;
    padding: 0;
    background: transparent;
    outline: 0;
}

/* ================= Results ================= */
.select2-results {
    display: block;
    padding: 0 0 0.5rem 0;
}

.select2-results__options {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 250px;
    overflow-y: auto;
    background-color: var(--color-base-100);
}

.select2-results__option {
    padding: 0.5rem 1rem;
    -webkit-user-select: none;
    user-select: none;
    color: var(--color-base-content);
    transition: background-color 0.15s ease, color 0.15s ease;
}

.select2-results__option[aria-selected] {
    cursor: pointer;
}

.select2-results__option--highlighted[aria-selected] {
    /* background-color: var(--color-accent);
    color: var(--color-accent-content); */
    background-color: var(--color-primary);
    color: var(--color-primary-content);
}

.select2-results__option[aria-selected="true"] {
    background-color: var(--color-info);
    color: var(--color-info-content);
    border: var(--border) solid var(--color-base-content);
    /* border-radius: var(--radius-field); */
}

.select2-results__message {
    padding: 0.5rem 1rem;
    color: color-mix(in oklch, var(--color-base-content) 70%, transparent);
    opacity: 0.8;
}

/* ================= Arrow ================= */
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 2.8rem;
    position: absolute;
    top: 1px;
    right: 1px;
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: currentColor transparent transparent transparent;
    border-style: solid;
    border-width: 5px 4px 0 4px;
    opacity: 0.6;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
    border-color: transparent transparent currentColor transparent;
    border-width: 0 4px 5px 4px;
    opacity: 1;
}

/* ================= Accessibility helpers ================= */
.select2-close-mask {
    border: 0;
    margin: 0;
    padding: 0;
    display: block;
    position: fixed;
    left: 0;
    top: 0;
    min-height: 100%;
    min-width: 100%;
    height: auto;
    width: auto;
    opacity: 0;
    z-index: 99;
}

.select2-hidden-accessible {
    border: 0 !important;
    clip: rect(0 0 0 0) !important;
    -webkit-clip-path: inset(50%) !important;
    clip-path: inset(50%) !important;
    height: 1px !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    width: 1px !important;
    white-space: nowrap !important;
}
