/* ===== Tom Select / Autocomplete Custom Styles ===== */
/* Matches Workspace/Form/Select component styling */

.ts-wrapper,
.ts-wrapper.single,
.ts-wrapper.multi {
    width: 100% !important;
}

.ts-wrapper .ts-control,
.ts-wrapper.single .ts-control,
.ts-wrapper.multi .ts-control {
    width: 100% !important;
    padding: 0.625rem 1rem !important;
    min-height: 42px !important;
    display: flex !important;
    align-items: center !important;
    background-color: #fff !important;
    background-image: none !important;
    border: 1px solid #d1d5db !important;
    border-radius: 0.5rem !important;
    color: #111827 !important;
    font-size: 0.875rem !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    box-shadow: none !important;
}

.dark .ts-wrapper .ts-control,
.dark .ts-wrapper.single .ts-control,
.dark .ts-wrapper.multi .ts-control {
    background-color: #374151 !important;
    border-color: #4b5563 !important;
    color: #fff !important;
}

/* Focus state - uses primary color */
.ts-wrapper.focus .ts-control,
.ts-wrapper .ts-control:focus,
.ts-wrapper.single.focus .ts-control {
    border-color: var(--color-primary-500, #6366f1) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.2) !important;
    background-color: #fff !important;
}

.dark .ts-wrapper.focus .ts-control,
.dark .ts-wrapper.single.focus .ts-control {
    border-color: var(--color-primary-500, #6366f1) !important;
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.3) !important;
    background-color: #374151 !important;
}

/* Hover state */
.ts-wrapper .ts-control:hover,
.ts-wrapper.single .ts-control:hover {
    border-color: #9ca3af !important;
}

.dark .ts-wrapper .ts-control:hover,
.dark .ts-wrapper.single .ts-control:hover {
    border-color: #6b7280 !important;
}

/* Input inside control */
.ts-wrapper .ts-control > input,
.ts-wrapper.single .ts-control > input {
    color: #111827 !important;
    background: transparent !important;
    font-size: 0.875rem !important;
    font-weight: 400 !important;
}

.ts-wrapper .ts-control > input::placeholder {
    color: #9ca3af !important;
    font-size: 0.875rem !important;
    font-weight: 400 !important;
}

.dark .ts-wrapper .ts-control > input,
.dark .ts-wrapper.single .ts-control > input {
    color: #fff !important;
}

/* Selected item */
.ts-wrapper .ts-control .item,
.ts-wrapper.single .ts-control .item,
.ts-wrapper.single .ts-control > .item {
    color: #111827 !important;
    font-weight: 400 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.dark .ts-wrapper .ts-control .item,
.dark .ts-wrapper.single .ts-control .item,
.dark .ts-wrapper.single .ts-control > .item {
    color: #fff !important;
    background: transparent !important;
}

/* Dropdown menu */
.ts-wrapper .ts-dropdown {
    background-color: #fff;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
    margin-top: 0.25rem;
    overflow: hidden;
    z-index: 9999 !important;
}

.dark .ts-wrapper .ts-dropdown {
    background-color: #1f2937;
    border-color: #4b5563;
}

/* Dropdown content */
.ts-wrapper .ts-dropdown .ts-dropdown-content {
    max-height: 280px;
    overflow-y: auto;
    padding: 0.25rem 0;
}

/* Options */
.ts-wrapper .ts-dropdown .option {
    padding: 0.625rem 1rem;
    color: #374151;
    font-size: 0.875rem;
    cursor: pointer;
    transition: all 0.15s;
    border-bottom: 1px solid #f3f4f6;
}

.ts-wrapper .ts-dropdown .option:last-child {
    border-bottom: none;
}

.dark .ts-wrapper .ts-dropdown .option {
    color: #d1d5db;
    border-bottom-color: #374151;
}

/* Option hover/active - uses primary color */
.ts-wrapper .ts-dropdown .option:hover,
.ts-wrapper .ts-dropdown .option.active {
    background-color: rgba(99, 102, 241, 0.1);
    color: var(--color-primary-600, #4f46e5);
}

.dark .ts-wrapper .ts-dropdown .option:hover,
.dark .ts-wrapper .ts-dropdown .option.active {
    background-color: rgba(99, 102, 241, 0.2);
    color: #a5b4fc;
}

/* Option selected */
.ts-wrapper .ts-dropdown .option.selected {
    background-color: rgba(99, 102, 241, 0.15);
    color: var(--color-primary-700, #4338ca);
    font-weight: 500;
}

.dark .ts-wrapper .ts-dropdown .option.selected {
    background-color: rgba(99, 102, 241, 0.3);
    color: #c7d2fe;
}

/* No results */
.ts-wrapper .ts-dropdown .no-results {
    padding: 1.5rem 1rem;
    text-align: center;
    color: #9ca3af;
    font-size: 0.875rem;
}

/* Loading spinner */
.ts-wrapper.loading .ts-control::after {
    border-color: var(--color-primary-500, #6366f1) transparent transparent transparent;
}

/* Caret/Arrow */
.ts-wrapper .ts-control::after {
    border-color: #9ca3af transparent transparent transparent !important;
    margin-top: -2px;
}

.ts-wrapper.dropdown-active .ts-control::after {
    border-color: transparent transparent var(--color-primary-500, #6366f1) transparent !important;
}

/* Disabled state */
.ts-wrapper.disabled .ts-control {
    opacity: 0.6;
    cursor: not-allowed !important;
}

/* ===== Multi-Select Styles ===== */
.ts-wrapper.multi .ts-control {
    padding: 0.375rem 0.5rem !important;
    gap: 0.375rem;
    flex-wrap: wrap;
}

.ts-wrapper.multi .ts-control > .item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.375rem !important;
    padding: 0.25rem 0.5rem !important;
    margin: 0 !important;
    background-color: rgba(99, 102, 241, 0.1) !important;
    border: 1px solid rgba(99, 102, 241, 0.3) !important;
    border-radius: 0.375rem !important;
    color: var(--color-primary-700, #4338ca) !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    line-height: 1.25 !important;
}

.dark .ts-wrapper.multi .ts-control > .item {
    background-color: rgba(99, 102, 241, 0.2) !important;
    border-color: rgba(99, 102, 241, 0.4) !important;
    color: #c7d2fe !important;
}

/* Remove button (x) */
.ts-wrapper.multi .ts-control > .item .remove {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 1rem !important;
    height: 1rem !important;
    margin-left: 0.125rem !important;
    padding: 0 !important;
    border: none !important;
    border-radius: 50% !important;
    background-color: transparent !important;
    color: var(--color-primary-500, #6366f1) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
}

.ts-wrapper.multi .ts-control > .item .remove:hover {
    background-color: rgba(99, 102, 241, 0.2) !important;
    color: var(--color-primary-700, #4338ca) !important;
}

.dark .ts-wrapper.multi .ts-control > .item .remove {
    color: #a5b4fc !important;
}

.dark .ts-wrapper.multi .ts-control > .item .remove:hover {
    background-color: rgba(99, 102, 241, 0.3) !important;
    color: #fff !important;
}

/* Input placeholder in multi-select */
.ts-wrapper.multi .ts-control > input {
    min-width: 60px !important;
    flex: 1 !important;
}

.ts-wrapper.multi .ts-control > input::placeholder {
    color: #9ca3af !important;
}