/* Controls */
.mc-grid-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.mc-grid-controls__search-wrap {
  flex: 1;
  min-width: 0;
  max-width: 100%;
}

.mc-grid-control-skeleton {
  position: relative;
  display: block;
  width: 100%;
  overflow: hidden;
  background: #e8edf0;
}

.mc-grid-control-skeleton::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.5),
    transparent
  );
  animation: mc-product-skeleton-shimmer 1.2s infinite;
}

.mc-grid-controls__search-wrap--skeleton {
  display: block;
}

.mc-grid-control-skeleton--search {
  min-height: 48px;
  clip-path: polygon(
    8px 0,
    100% 0,
    100% calc(100% - 8px),
    calc(100% - 8px) 100%,
    0 100%,
    0 8px
  );
}

.mc-grid-controls__search {
  position: relative;
  display: block;
}

.mc-grid-controls__search-shell {
  position: relative;
  display: flex;
  align-items: center;
}

.mc-grid-controls__search-input-wrap {
  width: 100%;
}

.mc-grid-controls__search input {
  width: 100%;
  min-height: 48px;
  background: var(--mc-color-surface);
  padding: 0 18px;
  display: flex;
  align-items: center;
  clip-path: polygon(
    8px 0,
    100% 0,
    100% calc(100% - 8px),
    calc(100% - 8px) 100%,
    0 100%,
    0 8px
  );
  border: 0;
  font-size: 16px;
  color: var(--mc-color-black);
}
.mc-grid-controls__search input:focus-visible {
  outline: 0;
}

/* Hide native search clear/buttons so only custom clear control is visible. */
.mc-grid-controls__search input[type="search"]::-webkit-search-cancel-button,
.mc-grid-controls__search input[type="search"]::-webkit-search-decoration,
.mc-grid-controls__search input[type="search"]::-webkit-search-results-button,
.mc-grid-controls__search
  input[type="search"]::-webkit-search-results-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

.mc-grid-controls__search input[type="search"]::-ms-clear,
.mc-grid-controls__search input[type="search"]::-ms-reveal {
  display: none;
  width: 0;
  height: 0;
}

.mc-grid-controls__search-clear {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  color: var(--mc-color-icon-muted);
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
}

.mc-grid-controls__sort {
  position: relative;
  --mc-grid-sort-width: 225px;
  --mc-sort-indicator-offset: 0px;
  flex: 0 0 var(--mc-grid-sort-width);
  width: var(--mc-grid-sort-width);
  min-width: var(--mc-grid-sort-width);
}

.mc-grid-controls__sort--skeleton {
  display: flex;
  align-items: center;
}

.mc-grid-control-skeleton--sort {
  width: 100%;
  min-height: 24px;
  clip-path: polygon(
    6px 0,
    100% 0,
    100% calc(100% - 6px),
    calc(100% - 6px) 100%,
    0 100%,
    0 6px
  );
}

.mc-grid-controls__sort::after {
  content: "";
  display: none;
  position: absolute;
  right: var(--mc-sort-indicator-offset);
  top: 50%;
  transform: translateY(-25%);
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--mc-color-text);
  pointer-events: none;
}

.mc-grid-controls__sort select {
  width: 100%;
  min-height: auto;
  padding: 0 1rem 0 0;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--mc-color-black);
  font-weight: 700;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  outline: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mc-grid-controls__sort select:focus-visible {
  outline: 0;
}

.mc-grid-controls__sort select option {
  background: var(--mc-color-surface, #fff);
  color: var(--mc-color-black, #0c0308);
  font-weight: 500;
  padding: 10px 12px;
}

.mc-grid-controls__sort select option:checked {
  background: #e9eef0;
  color: var(--mc-color-black, #0c0308);
  font-weight: 600;
}

.mc-grid-controls__sort select option:not(:checked):hover {
  background: #f2f5f7;
  color: var(--mc-color-black, #0c0308);
}

/* Progressive enhancement for browsers that support styling native pickers. */
@supports (appearance: base-select) {
  .mc-grid-controls__sort select {
    appearance: base-select;
  }

  .mc-grid-controls__sort select::picker(select) {
    appearance: base-select;
    border: 1px solid #8ca4ab;
    background: var(--mc-color-surface, #fff);
    box-shadow: 0 12px 28px rgba(2, 39, 62, 0.16);
    padding: 6px;
  }

  .mc-grid-controls__sort select option {
    border-radius: 4px;
    margin: 2px 0;
  }

  .mc-grid-controls__sort select option::checkmark {
    display: none;
  }
}
