/**
 * @license EUPL-1.2+
 * Copyright Gemeente Amsterdam
 */

@use "../../common/text-rendering" as *;

.ams-search-field {
  display: flex;
  isolation: isolate; // create new stacking context, so the input’s z-index doesn’t escape the component
}

@mixin reset-input {
  -webkit-appearance: none; // Reset appearance for Safari < 15.4
  appearance: none; // Reset native appearance, this causes issues on iOS and Android devices
  border: none;
  border-radius: 0; // Reset rounded borders on iOS devices
  margin-block: 0;
}

.ams-search-field__input {
  background-color: var(--ams-search-field-input-background-color);
  box-shadow: var(--ams-search-field-input-box-shadow);
  box-sizing: border-box;
  color: var(--ams-search-field-input-color);
  font-family: var(--ams-search-field-input-font-family);
  font-size: var(--ams-search-field-input-font-size);
  font-weight: var(--ams-search-field-input-font-weight);
  inline-size: 100%;
  line-height: var(--ams-search-field-input-line-height);
  outline-offset: var(--ams-search-field-input-outline-offset);
  padding-block: var(--ams-search-field-input-padding-block);
  padding-inline: var(--ams-search-field-input-padding-inline);
  touch-action: manipulation;

  @include text-rendering;
  @include reset-input;

  &:hover {
    box-shadow: var(--ams-search-field-input-hover-box-shadow);
  }

  &:focus {
    z-index: 1; // Make sure the focus outline isn’t cut off by the adjacent button
  }
}

.ams-search-field__input:invalid,
.ams-search-field__input[aria-invalid="true"] {
  box-shadow: var(--ams-search-field-input-invalid-box-shadow);

  &:hover {
    box-shadow: var(--ams-search-field-input-invalid-hover-box-shadow);
  }
}

.ams-search-field__input::placeholder {
  color: var(--ams-search-field-input-placeholder-color);
  opacity: 100%; // This resets the lower opacity set by Firefox
}

.ams-search-field__input::-webkit-search-cancel-button {
  appearance: none;
  background-image: var(--ams-search-field-input-cancel-button-background-image);
  block-size: var(--ams-search-field-input-cancel-button-block-size);
  cursor: var(--ams-search-field-input-cancel-button-cursor);
  inline-size: var(--ams-search-field-input-cancel-button-inline-size);
  margin-inline-start: 0.5rem;
}
