/*! ============================================================================= */
/*! Common style for search form. */
/*! ============================================================================= */
.search-form {
  display: flex;
  line-height: 1.25em;
  border-bottom: 1px solid currentColor;
  align-items: center;
  position: relative;
}

.search-form__icon-prepend {
  flex: 0 1;
  display: flex;
  align-items: center;
  padding-right: 0.5em;
}

.search-form__icon-prepend svg {
  font-size: 0.8em;
  stroke-width: 1px;
}

.search-form__input {
  flex: 1 1;
  padding: 0.5em 0;
  border: 0;
  outline: none;
  background: transparent;
  -webkit-appearance: none;
  color: inherit;
  font-size: inherit;
  line-height: initial;
  height: 2em;
}

.search-form__input::-webkit-input-placeholder {
  color: currentColor;
  opacity: 1;
}

.search-form__input::-moz-placeholder {
  color: currentColor;
  opacity: 1;
}

.search-form__input:-ms-input-placeholder {
  color: currentColor;
  opacity: 1;
}

.search-form__input::-ms-input-placeholder {
  color: currentColor;
  opacity: 1;
}

.search-form__input::placeholder {
  color: currentColor;
  opacity: 1;
}

.search-form__submit-btn {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  border: 0;
  background: transparent;
  -webkit-appearance: none;
  padding: 0.5em 0 0.5em 0.5em;
  color: inherit;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: opacity 250ms, transform 250ms;
  opacity: 0;
  transform: translateX(10px);
}

.search-form__submit-btn:focus, .search-form__submit-btn:active {
  outline: none;
}

.search-form__submit-btn svg {
  font-size: 0.8em;
  stroke-width: 1px;
}

.search-form__submit-btn--visible {
  opacity: 1;
  transform: translateX(0);
}
