@layer components {
  /* ── News List: Search ── */
  .news-search {
    padding: var(--space-lg) var(--space-md) var(--space-md);
  }

  .news-search__form {
    position: relative;
  }

  .news-search__icon {
    position: absolute;
    left: var(--space-md);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-ink-muted);
    font-size: 1.25rem;
    pointer-events: none;
  }

  .news-search__input {
    width: 100%;
    padding: var(--space-md) var(--space-md) var(--space-md) 3rem;
    background-color: var(--color-surface);
    border: none;
    border-radius: var(--radius-xl);
    font-size: var(--text-base);
    font-family: inherit;
    color: var(--color-ink);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-fast);

    &::placeholder {
      color: var(--color-ink-muted);
    }

    &:focus {
      outline: none;
      box-shadow: 0 0 0 2px oklch(var(--lch-primary) / 0.2);
    }
  }
}
