.sf-page--search {
  background: var(--color-white);
}

.search-page {
  padding: var(--space-4) 0 var(--space-7);
}

.search-page__container {
  width: min(var(--container-wide), 100% - (var(--space-3) * 2));
  margin-inline: auto;
}

.search-head {
  display: grid;
  gap: var(--space-1);
  margin-bottom: var(--space-3);
}

.search-head__title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(1.7rem, 4.3vw, 3rem);
  line-height: var(--line-height-tight);
  color: var(--color-espresso);
}

.search-head__title span {
  color: var(--color-charcoal);
}

.search-head__meta {
  margin: 0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-taupe);
}

.search-toolbar {
  display: grid;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}

.search-toolbar__field {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 2rem;
  padding: 0 0.35rem;
  border-bottom: 1px solid var(--color-border);
}

.search-toolbar__icon {
  width: 1rem;
  height: 1rem;
  color: var(--color-metal);
}

.search-toolbar__icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.search-toolbar__field input {
  width: min(100%, 24rem);
  margin: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  color: var(--color-charcoal);
  font-family: var(--font-body);
}

.search-toolbar__field input:focus {
  outline: none;
  box-shadow: none;
}

.search-sort {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.search-sort__link {
  border: 0;
  background: transparent;
  min-height: 2.2rem;
  padding: 0.55rem 0.7rem;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-taupe);
}

.search-sort__link.is-active {
  color: var(--color-espresso);
  background: linear-gradient(140deg, var(--color-surface) 0%, var(--color-bg) 100%);
}

.search-sort__link:hover,
.search-sort__link:focus-visible {
  color: var(--color-metal);
  outline: none;
}

.search-refresh {
  margin-bottom: var(--space-3);
  border: var(--border-thin);
  border-radius: var(--radius-sm);
  background: var(--color-shell-surface-card);
  padding: var(--space-2);
}

.search-refresh__label {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-taupe);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.search-refresh__skeletons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-1);
  margin-top: var(--space-1);
}

.search-refresh__skeletons span {
  display: block;
  height: 3.5rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(
    90deg,
    var(--color-shell-surface-muted) 0%,
    var(--color-shell-surface-strong) 50%,
    var(--color-shell-surface-muted) 100%
  );
  background-size: 200% 100%;
  animation: searchSkeleton 1.15s linear infinite;
}

@keyframes searchSkeleton {
  0% {
    background-position: 0 0;
  }

  100% {
    background-position: -200% 0;
  }
}

.search-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 2rem);
  width: min(100%, 1500px);
  margin-inline: auto;
}

.search-card {
  position: relative;
  border: var(--border-thin);
  border-radius: var(--radius-md);
  background: var(--color-shell-surface-strong);
  overflow: hidden;
  box-shadow: var(--shadow-subtle);
}

.search-card__media {
  position: relative;
  display: block;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--color-white);
}

.search-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transition: transform 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

.search-card:hover .search-card__image,
.search-card:focus-within .search-card__image {
  transform: scale(1.04);
}

.search-card__badges {
  position: absolute;
  top: var(--space-1);
  left: var(--space-1);
  z-index: 1;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.search-card__badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.45rem;
  padding: 0 0.5rem;
  border-radius: 100px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border: 1px solid var(--color-shell-category-border);
  background: var(--color-shell-surface-strong);
}

.search-card__badge--inventory {
  color: var(--color-espresso);
  border-color: var(--color-shell-category-active-border);
}

.search-card__badge--new {
  color: var(--color-metal);
}

.search-card__content {
  display: grid;
  gap: 0.35rem;
  padding: var(--space-2) var(--space-2) var(--space-3);
}

.search-card__meta {
  margin: 0;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-taupe);
}

.search-card__title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(1rem, 2.8vw, 1.45rem);
  line-height: var(--line-height-tight);
  color: var(--color-charcoal);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}

.search-card__price {
  margin: 0;
  color: var(--color-espresso);
  font-size: var(--font-size-sm);
}

.search-empty {
  margin-top: var(--space-4);
  border: var(--border-thin);
  border-radius: var(--radius-md);
  background: var(--color-shell-surface-strong);
  padding: var(--space-4);
  text-align: center;
  display: none;
}

.search-empty.is-visible {
  display: block;
}

.search-empty__title {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  color: var(--color-espresso);
}

.search-empty__copy {
  margin: var(--space-2) auto var(--space-3);
  max-width: 36rem;
  color: var(--color-taupe);
}

.search-empty__actions {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.search-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--touch-target-min);
  border: 1px solid var(--color-shell-category-active-border);
  border-radius: 100px;
  background: var(--color-espresso);
  color: var(--color-white);
  padding: 0 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: var(--font-size-sm);
}

.search-action-button:hover,
.search-action-button:focus-visible {
  background: var(--color-charcoal);
}

.search-action-button--ghost {
  background: var(--color-shell-surface-strong);
  color: var(--color-espresso);
}

.search-text-link {
  color: var(--color-taupe);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 0.15rem;
}

.search-text-link:hover,
.search-text-link:focus-visible {
  color: var(--color-metal);
  border-bottom-color: var(--color-metal);
}

.search-load-more-wrap {
  margin-top: var(--space-4);
  display: flex;
  justify-content: center;
}

.sf-search-form__field--minimal {
  position: relative;
  min-height: 2.4rem;
  padding: 0;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  background: transparent;
}

.sf-search-form__field--minimal input,
.sf-search-form__field--minimal input[type="search"] {
  text-transform: none;
}

.sf-search-suggestions {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 0.3rem);
  border: 1px solid var(--color-border);
  background: var(--color-shell-surface-strong);
  box-shadow: none;
  border-radius: var(--radius-sm);
  z-index: 220;
  overflow: hidden;
}

.sf-search-suggestion {
  width: 100%;
  text-align: left;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-charcoal);
  padding: 0.65rem 0.75rem;
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
}

.sf-search-suggestion:last-child {
  border-bottom: 0;
}

.sf-search-suggestion:hover,
.sf-search-suggestion:focus-visible,
.sf-search-suggestion.is-active {
  background: var(--color-bg);
  color: var(--color-espresso);
  outline: none;
}

.sf-search-suggestions--page {
  z-index: 12;
}

@media (min-width: 48rem) {
  .search-toolbar {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
  }

  .search-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.75rem;
  }
}

@media (min-width: 64rem) {
  .search-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 2rem;
  }
}
