/* searchable-select.css — Widget <select> com busca incremental.
   Extraído de components.css na Fase C da modularização. */

/* ════════════════════════════════════
   SEARCHABLE SELECT (ss)
════════════════════════════════════ */
.ss-wrap { position: relative; display: inline-flex; }

.ss-trigger {
  display: inline-flex; align-items: center; gap: 6px;
  height: 36px; padding: 0 10px 0 12px;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: #fff; color: var(--text);
  font-size: .82rem; font-family: var(--font);
  cursor: pointer; white-space: nowrap; min-width: 120px; max-width: 220px;
  transition: border-color .15s, box-shadow .15s;
}
.ss-trigger:hover:not(:disabled) { border-color: var(--color-accent); }
.ss-trigger:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(67,97,238,.12); }
.ss-trigger--active { border-color: var(--color-accent); background: #eef2ff; color: var(--color-accent); font-weight: 600; }
.ss-trigger:disabled { opacity: .45; cursor: default; }
[data-theme="dark"] .ss-trigger { background: #1e293b; }
[data-theme="dark"] .ss-trigger--active { background: #1e2d42; }

.ss-trigger-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ss-trigger-caret { width: 14px; height: 14px; flex-shrink: 0; opacity: .5; }
.ss-trigger--active .ss-trigger-caret { opacity: 1; }

.ss-panel {
  position: absolute; top: calc(100% + 4px); left: 0; z-index: 230;
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: 0 8px 24px rgba(0,0,0,.12);
  min-width: 200px; max-width: 360px;
}
[data-theme="dark"] .ss-panel { background: #1e293b; }
.ss-panel.hidden { display: none; }

.ss-search {
  display: block; width: 100%; box-sizing: border-box;
  padding: 8px 10px; border: none; border-bottom: 1px solid var(--border);
  background: transparent; color: var(--text); font-size: .82rem; font-family: var(--font);
  outline: none;
}
.ss-search::placeholder { color: var(--text-muted); }

.ss-list { max-height: 220px; overflow-y: auto; padding: 4px 0; }

.ss-item {
  display: block; width: 100%; text-align: left; padding: 7px 14px;
  border: none; background: transparent; color: var(--text);
  font-size: .82rem; font-family: var(--font); cursor: pointer;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; box-sizing: border-box;
}
.ss-item:hover { background: rgba(67,97,238,.07); color: var(--color-accent); }
.ss-item--active { font-weight: 600; color: var(--color-accent); }
.ss-item--all { color: var(--text-muted); }
.ss-empty { padding: 12px 14px; color: var(--text-muted); font-size: .82rem; text-align: center; }

