/**
 * Tom Select (bootstrap5 teması) — Selçuk Üniversitesi etkinlik paleti ile uyum
 */

.ts-wrapper {
    width: 100%;
}

/* Çoklu seçim (.multi) bu blokta max-height almaz; uzun etiketler satır kırabilir */
.ts-wrapper.form-select .ts-control,
.ts-wrapper.multi .ts-control,
.ts-wrapper.single .ts-control {
    border-radius: 10px;
    border-color: #dee2e6;
    min-height: calc(1.5em + 0.75rem + 2px);
    padding: 0.5rem 2.5rem 0.5rem 0.875rem;
    box-shadow: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

/* Tek seçim: sabit yükseklik; uzun metin tek satır + … */
.ts-wrapper.single .ts-control {
    max-height: calc(1.5em + 0.75rem + 2px);
    flex-wrap: nowrap;
    overflow: hidden;
    align-items: center;
}

/* basis 0%: kalan alan önce .item’a gider; uzun metin ok’a kadar uzar */
.ts-wrapper.single .ts-control > .item {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    flex: 1 1 0%;
    max-width: 100%;
}

/* Boş kutuda placeholder için input satırı dolar */
.ts-wrapper.single:not(.has-items) .ts-control > input {
    min-width: 0 !important;
    flex: 1 1 0% !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/*
 * Seçim varken control_input hâlâ flex’te kalabiliyor (hidePlaceholder kapalıyken);
 * .item ile genişlik paylaşıp metni ok’tan çok önce kesiyor. Akıştan çıkar.
 */
.ts-wrapper.single.has-items .ts-control > input {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    clip: rect(0, 0, 0, 0) !important;
    overflow: hidden !important;
    flex: 0 0 0 !important;
    min-width: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.ts-wrapper.single.form-select-sm .ts-control,
.ts-wrapper.single.form-control-sm .ts-control {
    min-height: calc(1.5em + 0.5rem + 2px);
    max-height: calc(1.5em + 0.5rem + 2px);
}

.ts-wrapper.single.form-select-lg .ts-control,
.ts-wrapper.single.form-control-lg .ts-control {
    min-height: calc(1.5em + 1rem + 2px);
    max-height: calc(1.5em + 1rem + 2px);
}

.ts-wrapper.focus .ts-control,
.ts-wrapper.dropdown-active .ts-control {
    border-color: #1a4fa8;
    box-shadow: 0 0 0 0.2rem rgba(26, 79, 168, 0.18);
}

.ts-wrapper .ts-control input {
    font-size: 1rem;
}

/* Salt okunur kontrol: yazı yok, klavye ile harf girilmez; select gibi tıklanır */
.ts-wrapper .ts-control > input[readonly] {
    cursor: pointer;
    caret-color: transparent;
    user-select: none;
}

.ts-wrapper .ts-control::after {
    border-color: #64748b transparent transparent transparent;
}

.ts-dropdown {
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 14px 40px rgba(15, 23, 42, 0.14);
    overflow: hidden;
    margin-top: 6px !important;
}

.ts-dropdown .option {
    padding: 0.55rem 1rem;
    font-size: 0.95rem;
}

.ts-dropdown .option:hover,
.ts-dropdown .option.active {
    background: linear-gradient(135deg, #0b2e6c 0%, #1a4fa8 100%);
    color: #fff;
}

.ts-dropdown .create:hover,
.ts-dropdown .create.active {
    background: #f1f5f9;
    color: #0f172a;
}

.ts-dropdown .spacer {
    display: none;
}

.ts-wrapper.multi .ts-control > div {
    border-radius: 8px;
}

/* Admin tablolarında dar hücre */
.table td .ts-wrapper.multi .ts-control {
    min-height: 2.25rem;
    padding-top: 0.35rem;
    padding-bottom: 0.35rem;
}

.table td .ts-wrapper.single .ts-control {
    min-height: 2.25rem;
    max-height: 2.25rem;
    padding-top: 0.35rem;
    padding-bottom: 0.35rem;
}
