/* ============================================
   Tom Select — Gestalt Design System Overrides

   Replaces Tom Select Bootstrap 5 theme defaults
   with gestalt design tokens. Include AFTER the
   Tom Select Bootstrap 5 CSS and gestalt-variables.css.
   ============================================ */

/* --- Control (closed-state trigger) --- */
.ts-wrapper.single .ts-control,
.ts-wrapper.multi .ts-control {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background-color: #fff;
    color: var(--color-text);
    font-size: 0.9rem;
    min-height: 38px;
    padding: var(--space-sm) var(--space-md);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    cursor: pointer;
}

/* Placeholder text */
.ts-wrapper .ts-control > input::placeholder {
    color: var(--color-text-light);
    font-size: 0.9rem;
}

/* Focus state */
.ts-wrapper.focus .ts-control,
.ts-wrapper .ts-control:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.15);
    outline: none;
}

/* --- Dropdown panel --- */
.ts-dropdown {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: #fff;
    box-shadow: var(--elevation-2);
    z-index: var(--z-dropdown);
    margin-top: var(--space-xs);
}

/* Individual option */
.ts-dropdown .option {
    font-size: 0.9rem;
    color: var(--color-text);
    padding: var(--space-sm) var(--space-md);
    transition: background-color var(--transition-fast), color var(--transition-fast);
    cursor: pointer;
}

/* Hover state */
.ts-dropdown .option:hover,
.ts-dropdown .option.active {
    background-color: var(--color-bg-subtle);
    color: var(--color-primary-dark);
}

/* Selected option */
.ts-dropdown .option.selected {
    background-color: var(--color-primary);
    color: #fff;
}

/* "No results" text */
.ts-dropdown .no-results {
    padding: var(--space-sm) var(--space-md);
    color: var(--color-text-light);
    font-size: 0.9rem;
}

/* --- Caret/arrow --- */
.ts-wrapper.single .ts-control::after {
    border-color: var(--color-text-secondary) transparent transparent transparent;
}

/* --- Multi-select item pills (future use) --- */
.ts-wrapper.multi .ts-control .item {
    background-color: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text);
    padding: 2px var(--space-sm);
    margin: 2px 2px;
    font-size: 0.85rem;
}

.ts-wrapper.multi .ts-control .item .remove {
    color: var(--color-text-light);
}

.ts-wrapper.multi .ts-control .item .remove:hover {
    color: var(--color-danger);
}

/* --- Validation integration --- */
.ts-wrapper.is-invalid .ts-control {
    border-color: var(--color-danger);
}

.ts-wrapper.is-invalid.focus .ts-control {
    border-color: var(--color-danger);
    box-shadow: 0 0 0 3px rgba(197, 48, 48, 0.15);
}

/* --- Disabled state --- */
.ts-wrapper.disabled .ts-control {
    background-color: var(--color-bg-subtle);
    opacity: 0.65;
    cursor: not-allowed;
}
