/* DS atom: full-width search with magnifier + clear (M-queue-filter-redesign) */

.ds-search {
  position: relative;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  width: 100%;
  min-height: 36px;
  /* Magnifier sits at --s-space-2 with 16px width; keep text strictly right of icon + gap. */
  padding-left: calc(var(--s-space-2) + 16px + var(--s-space-2));
  padding-right: calc(var(--s-space-4) + var(--s-space-1));
  border: 0.5px solid var(--s-color-border-subtle);
  border-radius: var(--s-radius-1);
  background: var(--s-color-bg-app);
  transition: border-color var(--s-duration-fast, 120ms) ease;
}

.ds-search:focus-within {
  border-color: var(--s-color-border-strong);
}

.ds-search__icon {
  position: absolute;
  left: var(--s-space-2);
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--s-color-fg-muted, var(--s-color-fg-muted));
  pointer-events: none;
}

.ds-search__input {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  padding: var(--s-space-2) var(--s-space-1);
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--s-color-fg-primary);
  font: inherit;
  font-size: var(--s-font-size-1);
  line-height: 1.3;
  box-sizing: border-box;
}

.ds-search__input:focus {
  outline: none;
}

.ds-search__clear {
  position: absolute;
  right: var(--s-space-1);
  top: 50%;
  transform: translateY(-50%);
  margin: 0;
  padding: 0 var(--s-space-1);
  border: 0;
  background: transparent;
  color: var(--s-color-fg-muted, var(--s-color-fg-muted));
  font: inherit;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  border-radius: var(--s-radius-1);
}

.ds-search__clear:hover {
  color: var(--s-color-fg-primary);
}

.ds-search__clear:focus-visible {
  outline: 2px solid var(--s-color-accent-active, oklch(60% 0.05 180));
  outline-offset: 1px;
}

.ds-search__clear[hidden] {
  display: none;
}
