/**
 * @file
 * Header Search Narrow Block.
 */

@import "../base/media-queries.pcss.css";

.block-search-narrow {
  margin-inline: calc(-1 * var(--sp));
  margin-block-end: var(--sp2);
  background: var(--color--black);

  & .search-block-form {
    display: flex;
  }

  & .form-item {
    flex-grow: 1;
    margin: 0;
  }

  & .form-actions {
    margin: 0;
  }

  & input[type="search"] {
    width: calc(100% + var(--sp2));
    height: calc(3 * var(--sp));
    padding-block: 0;
    padding-inline-start: var(--sp);
    padding-inline-end: var(--sp);
    transition: background-size 0.4s;
    color: var(--color--white);
    border: solid 1px transparent;
    background-color: transparent;
    background-image: linear-gradient(var(--color--primary-50), var(--color--primary-50)); /* Two values are needed for IE11 support. */
    background-repeat: no-repeat;
    background-position: bottom left; /* LTR */
    background-size: 0% 5px;
    box-shadow: none;
    font-family: var(--font-serif);
    font-size: 16px;
    -webkit-appearance: none;

    &:focus {
      outline: solid 4px transparent;
      outline-offset: -4px;
      background-size: 100% 5px;
    }

    @media (--md) {
      height: calc(4 * var(--sp));
      padding-inline-start: var(--sp2);
      padding-inline-end: var(--sp2);
    }
  }

  & .search-form__submit {
    position: relative;
    overflow: hidden;
    align-self: stretch;
    width: var(--sp3);
    height: auto;
    margin-block: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
    padding-block: 0;
    padding-inline-start: 0;
    padding-inline-end: 0;
    cursor: pointer;
    border-color: transparent;
    background-color: transparent;

    /*
      When in Windows high contrast mode, FF will not output either background
      images or SVGs that are nested directly within a <button> element, so we add a <span>.
    */
    & .icon--search {
      position: absolute;
      inset-block-start: 0;
      inset-inline-start: 0;
      display: block;
      width: 100%; /* Width of the SVG background image. */
      height: 100%;
      pointer-events: none;
      background-image: url("../../images/search--white.svg");
      background-repeat: no-repeat;
      background-position: center;
      background-size: auto;

      &::after {
        position: absolute;
        inset-block-end: 0;
        inset-inline-start: 0;
        width: 100%;
        height: 0;
        content: "";
        transition: transform 0.2s;
        transform: scaleX(0);
        transform-origin: left; /* LTR */
        border-block-start: solid 5px var(--color--primary-50);
      }

      @media (forced-colors: active) {
        background: buttontext;
        mask-image: url("../../images/search--white.svg");
        mask-repeat: no-repeat;
        mask-position: center;
      }
    }

    &:focus {
      outline: solid 4px transparent;
      outline-offset: -4px;
      box-shadow: none;

      & span::after {
        transform: scaleX(1);
      }

      @media screen and (-ms-high-contrast: active) {
        border-bottom-width: var(--sp0-5);

        & span::after {
          content: none;
        }
      }
    }

    @media (--md) {
      width: 80px;
    }

    @media screen and (-ms-high-contrast: active) {
      /* IE11's high contrast show will not show the background image, so we show the text. */
      & .visually-hidden {
        position: static;
        overflow: visible;
        clip: auto;
        width: auto;
        height: auto;
        text-align: center;
      }

      /* Edge's high contrast does show the background image, so we hide it. */
      & .icon--search {
        display: none;
      }
    }
  }

  /* 500px is the width of the primary nav at mobile. */
  @media (min-width: 500px) {
    margin-inline-start: 0;
    margin-inline-end: 0;
  }
}

body:not(.is-always-mobile-nav) .block-search-narrow {
  @media (--nav) {
    display: none;
  }
}

[dir="rtl"] .block-search-narrow {
  & input[type="search"] {
    background-position: bottom right;
  }

  & .search-form__submit .icon--search::after {
    transform-origin: right;
  }
}