/* Search-specific additions layered on top of sandahldesigns.webflow.css. */
.screen-reader-text {
  position: absolute;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.search-page {
  min-height: 100vh;
  background: #131e38;
  color: #fff;
  cursor: auto;
}

.search-page input,
.search-page textarea,
.search-page select {
  cursor: auto;
}

.search-page a,
.search-page button,
.search-page .clink,
.search-page .w-button {
  cursor: pointer;
}

.site-search {
  display: flex;
  align-items: center;
}

.search-nav-frame {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 200;
  width: 7vw;
  display: flex;
  pointer-events: none;
}

.search-nav-frame .nav-container {
  position: static;
  width: 100%;
  min-height: 100vh;
  pointer-events: auto;
}

.search-nav-frame .flyout-menu {
  pointer-events: auto;
}

.search-nav-frame .social-container {
  pointer-events: auto;
}

.search-nav-frame .navlinkhold {
  pointer-events: auto;
}

.search-nav-frame .navlink-search {
  pointer-events: auto;
}

.search-nav-frame .site-search-link {
  pointer-events: auto;
}

.search-main {
  display: flex;
  width: min(900px, calc(100% - 3rem));
  min-height: 100vh;
  margin: 0 auto;
  padding: 5rem 0 7rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.search-hero {
  width: 100%;
  margin-bottom: 3rem;
}

.search-hero .hero-head-500.heading-dark {
  max-width: 100%;
  color: #fff;
  text-align: center;
}

.site-search {
  justify-content: center;
  gap: 0;
}

.navlink-search {
  margin-bottom: 4rem;
}

.site-search-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  color: #fff;
}

.site-search-link:hover {
  color: #ee3026;
}

.site-search-link svg {
  width: 1.35rem;
  height: 1.35rem;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.25;
}

.site-search input[type="search"] {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-right: 0;
  border-radius: 16px 0 0 16px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  font: inherit;
  font-weight: 700;
  outline: none;
}

.site-search input[type="search"]::placeholder {
  color: rgba(255, 255, 255, 0.58);
}

.site-search input[type="search"]:focus {
  border-color: #fff;
  background: rgba(255, 255, 255, 0.12);
}

.site-search-large {
  align-items: stretch;
  margin: 1.5rem auto 0;
  width: min(48rem, 100%);
}

.site-search-large input[type="search"] {
  flex: 1 1 auto;
  width: auto;
  padding: 1rem 1.2rem;
  text-align: left;
}

.search-submit.cta-primary {
  border-color: #ee3026;
  border-radius: 0 16px 16px 0;
  color: #fff;
  margin-right: 0;
  cursor: pointer;
}

.search-submit.cta-primary:hover {
  background: #ee3026;
}

.site-search-large .search-submit.cta-primary {
  padding: 1rem 1.4rem;
}

.search-summary {
  margin-top: 1rem;
  color: rgba(255, 255, 255, 0.72);
  font-size: 1.05rem;
  text-align: center;
}

.search-results {
  display: grid;
  width: min(760px, 100%);
  gap: 1rem;
  text-align: left;
}

.search-result,
.search-empty {
  border-top: 1px solid rgba(255, 255, 255, 0.16);
}

.search-result {
  padding: 1.35rem 0;
}

.search-result-title {
  color: #fff;
  font-size: 1.55rem;
  font-weight: 700;
  line-height: 1.15;
  text-decoration: none;
}

.search-result-title:hover {
  color: #ee3026;
}

.search-result mark {
  padding: 0 0.16em;
  border-radius: 4px;
  background: rgba(238, 48, 38, 0.32);
  color: #fff;
  font-weight: 700;
}

.search-result p,
.search-empty p {
  max-width: 48rem;
  margin-right: 0;
  margin-left: 0;
  margin-top: 0.65rem;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.55;
}

.search-empty {
  width: min(760px, 100%);
  padding: 2rem 0;
  text-align: center;
}

.search-empty h2 {
  color: #fff;
}

.search-empty p {
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 991px) {
  .navlink-search {
    margin-bottom: 3rem;
  }

  .search-nav-frame .nav-container {
    width: 100%;
    min-height: 9vh;
  }

  .search-nav-frame {
    left: 0;
    right: 0;
    bottom: auto;
    width: 100%;
  }

  .search-main {
    padding: 8rem 0 4rem;
  }

  .site-search-large .search-submit.cta-primary {
    flex: 0 0 auto;
    padding-right: 1rem;
    padding-left: 1rem;
  }
}

@media screen and (max-width: 479px) {
  .navlink-search {
    margin-bottom: 2rem;
  }

  .search-result-title {
    font-size: 1.25rem;
  }
}
