.ts-wrapper.single .ts-control,
.ts-wrapper.multi .ts-control {
    background-color: var(--white, #ffffff);
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 0.75rem;
    padding: 0.75rem 1rem;
    color: var(--black, #000000);
    font-size: 15px;
    font-weight: 500;
    transition:
        border-color 0.3s ease-in-out,
        background-color 0.3s ease-in-out;
    background-image: none !important;
    min-height: 48px;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    position: relative;
    cursor: text;
    box-shadow: none !important;
}

/* Dark Mode override */
:where(.dark, .dark *) .ts-wrapper.single .ts-control,
:where(.dark, .dark *) .ts-wrapper.multi .ts-control {
    background-color: var(--gray, #0f1514);
    border-color: rgba(255, 255, 255, 0.15);
    color: var(--white-fixed, #ffffff);
}

/* Focus state */
.ts-wrapper.single.focus .ts-control,
.ts-wrapper.multi.focus .ts-control,
.ts-wrapper.single.dropdown-active .ts-control,
.ts-wrapper.multi.dropdown-active .ts-control {
    background-color: var(--white, #ffffff) !important;
    border-color: var(--brand-main) !important;
    outline: none !important;
}

:where(.dark, .dark *) .ts-wrapper.single.focus .ts-control,
:where(.dark, .dark *) .ts-wrapper.multi.focus .ts-control,
:where(.dark, .dark *) .ts-wrapper.single.dropdown-active .ts-control,
:where(.dark, .dark *) .ts-wrapper.multi.dropdown-active .ts-control {
    background-color: var(--gray, #0f1514) !important;
    border-color: var(--brand-main) !important;
}

/* 2. Custom Chevron Arrow */
.ts-wrapper.single .ts-control::after {
    content: "";
    position: absolute;
    right: 1.25rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.25rem;
    height: 1.25rem;
    transition: transform 0.3s ease-in-out;
    opacity: 0.4;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

:where(.dark, .dark *) .ts-wrapper.single .ts-control::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    opacity: 0.6;
}

.ts-wrapper.single.dropdown-active .ts-control::after {
    transform: translateY(-50%) rotate(180deg);
    opacity: 1;
}

/* 3. Dropdown Menu Container */
.ts-dropdown {
    background-color: var(--white, #ffffff);
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 0.75rem;
    margin-top: 0.5rem;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    padding: 0.5rem;
    z-index: 50;
}

:where(.dark, .dark *) .ts-dropdown {
    background-color: var(--gray, #0f1514);
    border-color: rgba(255, 255, 255, 0.15);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

/* 4. Custom Slim Scrollbar */
.ts-dropdown .ts-dropdown-content {
    max-height: 250px !important;
    overflow-y: auto !important;
    scrollbar-width: thin !important;
    scrollbar-color: var(--brand-main) transparent !important;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar {
    width: 5px !important;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-track {
    background: transparent !important;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.1) !important;
    border-radius: 20px !important;
}

:where(.dark, .dark *) .ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb {
    background-color: rgba(255, 255, 255, 0.15) !important;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb:hover {
    background-color: var(--brand-main) !important;
}

.ts-dropdown .option {
    padding: 0.75rem 1rem;
    font-size: 14px;
    color: rgba(0, 0, 0, 0.6);
    border-radius: 0.5rem;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
    margin-bottom: 0.25rem;
}

:where(.dark, .dark *) .ts-dropdown .option {
    color: rgba(255, 255, 255, 0.6);
}

.ts-dropdown .option.selected {
    background-color: rgba(0, 134, 88, 0.1);
    color: var(--brand-main);
    font-weight: 600;
}

.ts-dropdown .option.active {
    background-color: rgba(0, 0, 0, 0.05);
    color: var(--black);
}

:where(.dark, .dark *) .ts-dropdown .option.active {
    background-color: rgba(255, 255, 255, 0.05);
    color: white;
}

/* 5. Search Input & Placeholder Design */
.ts-wrapper .ts-control input {
    color: var(--black) !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    display: inline-block !important;
    background: transparent !important;
    border: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: auto !important;
    flex: 1 1 4px !important;
    min-width: 4px !important;
    opacity: 1 !important;
    outline: none !important;
    line-height: 1.5 !important;
    height: auto !important;
}

:where(.dark, .dark *) .ts-wrapper .ts-control input {
    color: var(--white-fixed) !important;
}

.ts-wrapper .ts-control input::placeholder {
    color: rgba(0, 0, 0, 0.4) !important;
}

:where(.dark, .dark *) .ts-wrapper .ts-control input::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

.ts-wrapper.single.dropdown-active .ts-control .item {
    display: none !important;
}

/* 6. Multi-Select: stable height — override tom-select's has-items padding change */
.ts-wrapper.multi .ts-control,
.ts-wrapper.multi.has-items .ts-control {
    min-height: 48px !important;
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
    transition:
        border-color 0.3s ease-in-out,
        background-color 0.3s ease-in-out !important;
}

/* Multi-Select Tags */
.ts-wrapper.multi .ts-control .item {
    background-color: rgba(0, 134, 88, 0.1);
    border: 1px solid rgba(0, 134, 88, 0.2);
    color: var(--brand-main);
    border-radius: 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.225rem 0.625rem !important;
    display: inline-flex !important;
    align-items: center;
    gap: 0.375rem;
}

.ts-wrapper.multi .ts-control .item .remove {
    color: var(--color-main);
    margin-left: 0.5rem;
    font-weight: bold;
    cursor: pointer;
    text-decoration: none !important;
    border-left: none !important;
    padding-left: 2px !important;
    background-image: none !important;
}