/**
 * Select2 custom theme – matches .kt-select from KTUI
 * Supports light and dark modes via .dark class on <html>
 */

/* =====================================================
   HIDE THE ORIGINAL <select> ELEMENT
   ===================================================== */
.select2-hidden-accessible {
  border: 0 !important;
  clip: rect(0 0 0 0) !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;
}

/* =====================================================
   CONTAINER
   ===================================================== */
.select2-container {
  box-sizing: border-box;
  display: block;
  margin: 0;
  position: relative;
  width: 100% !important;
}

/* =====================================================
   FIXED-WIDTH SELECTS (business / professional filter in card headers)
   ===================================================== */
.kt-card .select2-container {
  width: 250px !important;
  min-width: 250px !important;
  max-width: 250px !important;
  flex-shrink: 0;
}

/* =====================================================
   SINGLE SELECTION
   ===================================================== */
.select2-container--default .select2-selection--single {
  position: relative;
  display: block;
  width: 100%;
  height: 34px;
  cursor: pointer;
  box-sizing: border-box;
  border: 1px solid var(--input, oklch(92% 0.004 286.32));
  border-radius: calc(var(--radius, 0.5rem) - 2px);
  background-color: var(--background, oklch(1 0 0));
  color: var(--foreground, oklch(14.1% 0.005 285.823));
  font-size: 0.8125rem;
  box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05);
  transition: color 150ms, box-shadow 150ms, border-color 150ms;
  /* chevron siempre a la derecha, fijo */
  background-repeat: no-repeat;
  background-size: 14px 11px;
  background-position: right 10px center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%239f9fa9' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E");
  outline: none;
  user-select: none;
}

/* El texto renderizado ocupa todo el ancho menos espacio para chevron */
.select2-container--default .select2-selection--single .select2-selection__rendered {
  display: block;
  padding-left: 12px;
  padding-right: 52px; /* espacio para × + chevron cuando allowClear=true */
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--foreground, oklch(14.1% 0.005 285.823));
  line-height: 34px;
}

.select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: color-mix(in oklab, var(--muted-foreground, oklch(55.2% 0.016 285.938)) 80%, transparent);
  font-weight: normal;
}

/* Ocultar flecha nativa de select2 */
.select2-container--default .select2-selection--single .select2-selection__arrow {
  display: none;
}

/* Botón clear (×): posición absoluta centrada, ANTES del chevron */
.select2-container--default .select2-selection--single .select2-selection__clear {
  position: absolute;
  right: 30px; /* 10px margen del borde + 14px chevron + 6px separación */
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  cursor: pointer;
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
  font-weight: normal;
  font-size: 1.1rem;
  line-height: 1;
  padding: 0 4px;
  z-index: 1;
}

.select2-container--default .select2-selection--single .select2-selection__clear:hover {
  color: var(--foreground, oklch(14.1% 0.005 285.823));
}

/* =====================================================
   FOCUSED / OPEN – SINGLE
   ===================================================== */
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--ring, oklch(87.1% 0.006 286.286));
  box-shadow:
    0 0 0 3px color-mix(in oklab, var(--ring, oklch(87.1% 0.006 286.286)) 30%, transparent),
    0 1px 2px 0 rgba(0,0,0,0.05);
  outline: none;
  /* chevron apunta arriba */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%239f9fa9' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 11 6-6 6 6'/%3E%3C/svg%3E");
}

/* =====================================================
   MULTIPLE SELECTION
   ===================================================== */
.select2-container--default .select2-selection--multiple {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  width: 100%;
  box-sizing: border-box;
  cursor: pointer;
  border: 1px solid var(--input, oklch(92% 0.004 286.32));
  border-radius: calc(var(--radius, 0.5rem) - 2px);
  background-color: var(--background, oklch(1 0 0));
  padding: 5px 10px;
  box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05);
  transition: border-color 200ms, box-shadow 200ms;
  outline: none;
}

.select2-container--default.select2-container--open .select2-selection--multiple,
.select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: var(--ring, oklch(87.1% 0.006 286.286));
  box-shadow:
    0 0 0 2px color-mix(in oklab, var(--ring, oklch(87.1% 0.006 286.286)) 20%, transparent),
    0 1px 2px 0 rgba(0,0,0,0.05);
  outline: none;
}

.select2-container--default .select2-selection--multiple .select2-selection__rendered {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 0;
  margin: 0;
  list-style: none;
  width: 100%;
}

/* Tags */
.select2-container--default .select2-selection--multiple .select2-selection__choice {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: var(--radius, 0.5rem);
  padding: 3px 10px;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.25;
  border: 1px solid var(--border, oklch(94% 0.004 286.32));
  background-color: color-mix(in oklab, var(--accent, oklch(96.7% 0.003 264.542)) 50%, transparent);
  color: var(--accent-foreground, oklch(21% 0.006 285.885));
  max-width: 220px;
  flex-shrink: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  box-shadow: 0 1px 2px 0 rgba(0,0,0,0.08);
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border-radius: 9999px;
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: bold;
  flex-shrink: 0;
  transition: all 150ms;
  order: -1;
  line-height: 1;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
  background-color: color-mix(in oklab, var(--accent, oklch(96.7% 0.003 264.542)) 60%, transparent);
  color: var(--accent-foreground, oklch(21% 0.006 285.885));
}

/* Inline search */
.select2-container--default .select2-selection--multiple .select2-search--inline {
  flex: 1;
  min-width: 60px;
}

.select2-container--default .select2-selection--multiple .select2-search--inline .select2-search__field {
  background: transparent;
  border: none;
  outline: none;
  color: var(--foreground, oklch(14.1% 0.005 285.823));
  font-size: 0.8125rem;
  margin: 0;
  padding: 0;
  width: 100%;
}

/* =====================================================
   DISABLED
   ===================================================== */
.select2-container--default.select2-container--disabled .select2-selection--single,
.select2-container--default.select2-container--disabled .select2-selection--multiple {
  cursor: not-allowed;
  opacity: 0.6;
}

.select2-container--default.select2-container--disabled .select2-selection__clear,
.select2-container--default.select2-container--disabled .select2-selection__choice__remove {
  display: none;
}

/* =====================================================
   DROPDOWN — Z-INDEX ALTO PARA APARECER SOBRE MODALES
   ===================================================== */
.select2-container--open .select2-dropdown {
  z-index: 99999 !important;
}

.select2-dropdown {
  position: absolute;
  z-index: 99999 !important;
  border-radius: calc(var(--radius, 0.5rem) - 2px);
  border: 1px solid var(--border, oklch(94% 0.004 286.32));
  background-color: var(--popover, oklch(1 0 0));
  color: var(--popover-foreground, oklch(14.1% 0.005 285.823));
  box-shadow: 0 8px 24px rgba(0,0,0,0.12), 0 2px 6px rgba(0,0,0,0.08);
  overflow: hidden;
  width: 100%;
}

.select2-container--default .select2-dropdown--below {
  border-top: none;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.select2-container--default .select2-dropdown--above {
  border-bottom: none;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.select2-container--default.select2-container--open.select2-container--below .select2-selection--single,
.select2-container--default.select2-container--open.select2-container--below .select2-selection--multiple {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.select2-container--default.select2-container--open.select2-container--above .select2-selection--single,
.select2-container--default.select2-container--open.select2-container--above .select2-selection--multiple {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

/* =====================================================
   DROPDOWN SEARCH FIELD
   ===================================================== */
.select2-search--dropdown {
  padding: 8px 10px;
  background-color: var(--popover, oklch(1 0 0));
  border-bottom: 1px solid var(--border, oklch(94% 0.004 286.32));
}

.select2-search--dropdown .select2-search__field {
  width: 100%;
  box-sizing: border-box;
  border: none;
  border-bottom: 1px solid var(--border, oklch(94% 0.004 286.32));
  border-radius: 0;
  background-color: transparent;
  color: var(--foreground, oklch(14.1% 0.005 285.823));
  padding: 2px 0 4px 0;
  font-size: 0.8125rem;
  line-height: 1.4;
  height: auto;
  outline: none;
  box-shadow: none;
  transition: border-color 150ms;
  font-family: inherit;
  -webkit-appearance: none;
  appearance: none;
}

.select2-search--dropdown .select2-search__field:focus {
  border-bottom-color: var(--ring, oklch(87.1% 0.006 286.286));
  outline: none;
  box-shadow: none;
}

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

/* =====================================================
   RESULTS LIST
   ===================================================== */
.select2-results {
  display: block !important;
}

.select2-results > .select2-results__options,
ul.select2-results__options {
  max-height: 15em;
  overflow-y: auto;
  padding: 4px !important;
  margin: 0 !important;
  list-style: none !important;
}

/* Ultra-specific: target li inside ul inside the dropdown */
.select2-results__option,
li.select2-results__option,
ul.select2-results__options > li,
ul.select2-results__options > li.select2-results__option,
.select2-container--default .select2-results__option,
.select2-container--default .select2-results__option[role="option"],
.select2-container--default .select2-results > .select2-results__options > .select2-results__option,
.select2-container--default .select2-results__option .select2-results__option {
  display: block !important;
  border-radius: calc(var(--radius, 0.5rem) - 2px) !important;
  padding-top: 7px !important;
  padding-bottom: 7px !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  margin: 0 !important;
  margin-left: 0 !important;
  font-size: 0.8125rem !important;
  cursor: pointer;
  color: var(--popover-foreground, oklch(14.1% 0.005 285.823));
  transition: background-color 100ms, color 100ms;
  user-select: none;
  list-style: none !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted {
  background-color: var(--accent, oklch(96.7% 0.003 264.542)) !important;
  color: var(--accent-foreground, oklch(21% 0.006 285.885)) !important;
}

.select2-container--default .select2-results__option[aria-selected="true"] {
  background-color: var(--accent, oklch(96.7% 0.003 264.542)) !important;
  color: var(--accent-foreground, oklch(21% 0.006 285.885)) !important;
  font-weight: 500;
}

.select2-container--default .select2-results__option[aria-disabled="true"] {
  opacity: 0.6;
  pointer-events: none;
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
}

.select2-results__option.select2-results__message,
.select2-container--default .select2-results__message {
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
  cursor: default;
}

.select2-results__group {
  padding: 4px 12px !important;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.select2-results__option.loading-results {
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
  cursor: default;
}

/* =====================================================
   DARK MODE
   ===================================================== */

.dark .select2-container--default .select2-selection--single {
  border-color: var(--input, oklch(27.4% 0.006 286.033));
  background-color: var(--background, oklch(14.1% 0.005 285.823));
  color: var(--foreground, oklch(98.5% 0 0));
  box-shadow: 0 1px 2px 0 rgba(0,0,0,0.3);
}

.dark .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--foreground, oklch(98.5% 0 0));
}

.dark .select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: color-mix(in oklab, var(--muted-foreground, oklch(55.2% 0.016 285.938)) 80%, transparent);
}

.dark .select2-container--default.select2-container--open .select2-selection--single,
.dark .select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--ring, oklch(27.4% 0.006 286.033));
  box-shadow:
    0 0 0 3px color-mix(in oklab, var(--ring, oklch(27.4% 0.006 286.033)) 30%, transparent),
    0 1px 2px 0 rgba(0,0,0,0.3);
}

.dark .select2-container--default .select2-selection--multiple {
  border-color: var(--input, oklch(27.4% 0.006 286.033));
  background-color: var(--background, oklch(14.1% 0.005 285.823));
  color: var(--foreground, oklch(98.5% 0 0));
  box-shadow: 0 1px 2px 0 rgba(0,0,0,0.3);
}

.dark .select2-container--default.select2-container--open .select2-selection--multiple,
.dark .select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: var(--ring, oklch(27.4% 0.006 286.033));
  box-shadow:
    0 0 0 2px color-mix(in oklab, var(--ring, oklch(27.4% 0.006 286.033)) 20%, transparent),
    0 1px 2px 0 rgba(0,0,0,0.3);
}

.dark .select2-container--default .select2-selection--multiple .select2-selection__choice {
  border-color: var(--border, oklch(27.4% 0.006 286.033));
  background-color: color-mix(in oklab, var(--accent, oklch(21% 0.006 285.885)) 50%, transparent);
  color: var(--accent-foreground, oklch(98.5% 0 0));
}

.dark .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
}

.dark .select2-container--default .select2-selection--multiple .select2-search--inline .select2-search__field {
  color: var(--foreground, oklch(98.5% 0 0));
}

.dark .select2-container--default.select2-container--disabled .select2-selection--single,
.dark .select2-container--default.select2-container--disabled .select2-selection--multiple {
  background-color: var(--background, oklch(14.1% 0.005 285.823));
}

.dark .select2-dropdown {
  border-color: var(--border, oklch(27.4% 0.006 286.033));
  background-color: var(--popover, oklch(14.1% 0.005 285.823));
  color: var(--popover-foreground, oklch(98.5% 0 0));
  box-shadow: 0 8px 24px rgba(0,0,0,0.5), 0 2px 6px rgba(0,0,0,0.3);
}

.dark .select2-search--dropdown {
  border-bottom-color: var(--border, oklch(27.4% 0.006 286.033));
  background-color: var(--popover, oklch(14.1% 0.005 285.823));
}

.dark .select2-search--dropdown .select2-search__field {
  border-bottom-color: var(--border, oklch(27.4% 0.006 286.033));
  background-color: transparent;
  color: var(--foreground, oklch(98.5% 0 0));
  -webkit-appearance: none;
  appearance: none;
}

.dark .select2-search--dropdown .select2-search__field:focus {
  border-bottom-color: var(--ring, oklch(27.4% 0.006 286.033));
  box-shadow: none;
}

.dark .select2-results__option,
.dark li.select2-results__option,
.dark ul.select2-results__options > li,
.dark ul.select2-results__options > li.select2-results__option,
.dark .select2-container--default .select2-results__option,
.dark .select2-container--default .select2-results__option[role="option"],
.dark .select2-container--default .select2-results > .select2-results__options > .select2-results__option {
  color: var(--popover-foreground, oklch(98.5% 0 0));
  padding-top: 7px !important;
  padding-bottom: 7px !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.dark .select2-container--default .select2-results__option--highlighted[aria-selected],
.dark .select2-container--default .select2-results__option--highlighted {
  background-color: var(--accent, oklch(21% 0.006 285.885)) !important;
  color: var(--accent-foreground, oklch(98.5% 0 0)) !important;
}

.dark .select2-container--default .select2-results__option[aria-selected="true"] {
  background-color: var(--accent, oklch(21% 0.006 285.885));
  color: var(--accent-foreground, oklch(98.5% 0 0));
}

.dark .select2-container--default .select2-results__option[aria-disabled="true"],
.dark .select2-results__option.select2-results__message,
.dark .select2-results__group {
  color: var(--muted-foreground, oklch(55.2% 0.016 285.938));
}

/* =====================================================
   INVALID STATE — jQuery Validate sets aria-invalid="true" on the
   original <select>; we target the adjacent .select2-container.
   Mirrors the kt-input[aria-invalid="true"] pattern from KTUI.
   ===================================================== */

/* Border rojo — single */
select[aria-invalid="true"] + .select2-container--default .select2-selection--single,
select[aria-invalid="true"] + .select2-container--default .select2-selection--multiple {
  border-color: var(--destructive, oklch(57.7% 0.245 27.325));
}
@supports (color: color-mix(in lab, red, red)) {
  select[aria-invalid="true"] + .select2-container--default .select2-selection--single,
  select[aria-invalid="true"] + .select2-container--default .select2-selection--multiple {
    border-color: color-mix(in oklab, var(--destructive, oklch(57.7% 0.245 27.325)) 60%, transparent);
  }
}

/* Ring rojo al abrir / enfocar cuando es inválido */
select[aria-invalid="true"] + .select2-container--default.select2-container--open .select2-selection--single,
select[aria-invalid="true"] + .select2-container--default.select2-container--focus .select2-selection--single,
select[aria-invalid="true"] + .select2-container--default.select2-container--open .select2-selection--multiple,
select[aria-invalid="true"] + .select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: var(--destructive, oklch(57.7% 0.245 27.325));
  box-shadow:
    0 0 0 3px color-mix(in oklab, var(--destructive, oklch(57.7% 0.245 27.325)) 20%, transparent),
    0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

/* ── Dark mode ── */
.dark select[aria-invalid="true"] + .select2-container--default .select2-selection--single,
.dark select[aria-invalid="true"] + .select2-container--default .select2-selection--multiple {
  border-color: var(--destructive, oklch(57.7% 0.245 27.325));
}

.dark select[aria-invalid="true"] + .select2-container--default.select2-container--open .select2-selection--single,
.dark select[aria-invalid="true"] + .select2-container--default.select2-container--focus .select2-selection--single,
.dark select[aria-invalid="true"] + .select2-container--default.select2-container--open .select2-selection--multiple,
.dark select[aria-invalid="true"] + .select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: var(--destructive, oklch(57.7% 0.245 27.325));
  box-shadow:
    0 0 0 3px color-mix(in oklab, var(--destructive, oklch(57.7% 0.245 27.325)) 20%, transparent),
    0 1px 2px 0 rgba(0, 0, 0, 0.3);
}

