:host,
*,
::before,
::after {
  box-sizing: border-box;
}

*:focus:focus-visible {
  box-shadow: var(--shadow-focus-primary);
  outline: none;
}

button {
  all: unset;
  cursor: pointer;
}

.searchbar {
  --searchbar-button-x-padding: 14px;
  --searchbar-button-icon-width: 1.75rem;

  /* button horizontal padding + icon size + left border */
  --closed-searchbar-width: calc((var(--searchbar-button-x-padding) * 2) + var(--searchbar-button-icon-width) + 1px);

  position: absolute;
  z-index: 5;
  top: 0;
  right: 0;
  display: flex;
  width: var(--closed-searchbar-width);
  height: 3rem;
  justify-content: flex-end;
  transition: width 0.4s ease-in-out;
}

.searchbar.searchbar-open {
  width: 100%;
}

.searchbar .input-wrapper {
  display: flex;
  overflow: hidden;
  width: 100%;
  align-items: center;
  padding: 8px;
  padding-left: var(--grid-margin);
  background-color: #fff;
  gap: 8px;
  transition-duration: 0.4s;
  transition-property: padding-right, padding-left, width;
  transition-timing-function: ease-in-out;
}

.searchbar:not(.searchbar-open) .input-wrapper {
  overflow: hidden;
  width: 0;
  padding: 0;
}

.searchbar button[type='reset'] {
  --z-icon-width: 1rem;
  --z-icon-height: 1rem;

  display: flex;
  align-items: center;
  cursor: pointer;
}

.searchbar input {
  z-index: 1;
  width: 100%;
  height: 100%;
  padding: 0;
  border: none;
  background-color: #fff;
  font-family: var(--font-family-sans);
  font-size: 1rem;
}

.searchbar.searchbar-open input:first-child {
  padding-left: 4px;
  margin-left: -4px; /* per evitare che la focus shadow vada fuori dallo schermo */
}

.searchbar input[type='search']::-webkit-search-cancel-button,
.searchbar input[type='search']::-webkit-search-decoration {
  appearance: none;
}

.searchbar input::placeholder {
  color: var(--gray500);
}

.searchbar .searchbar-button {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px var(--searchbar-button-x-padding);
  border-left: 1px solid #000;
  background: var(--zanit-accent-color);
  font-family: inherit;
  font-size: inherit;
  gap: 64px;
  line-height: 1;
}

.searchbar .searchbar-button:focus-visible {
  z-index: 1;
}

.searchbar-button z-icon {
  --z-icon-width: var(--searchbar-button-icon-width);
  --z-icon-height: var(--searchbar-button-icon-width);
}

.suggestions-wrapper {
  position: absolute;
  z-index: 4;
  top: 3rem;
  left: 50%;
  width: 100vw;
  border-top: 1px solid var(--gray200);
  margin-left: -50vw;
  background: #fff;
  box-shadow: var(--shadow-1);
}

.suggestions-wrapper.hidden {
  display: none;
}

.suggestions {
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: stretch;
  padding: var(--space-unit);
  margin: 0 auto;
}

.suggestion-head {
  padding: calc(var(--space-unit) * 0.75) var(--space-unit);
  color: var(--gray700);
  font-size: 0.875rem;
  font-weight: var(--font-md);
  line-height: 1.125rem;
}

.suggestion {
  display: flex;
  padding: calc(var(--space-unit) * 0.75) var(--space-unit);
  color: var(--gray900);
  cursor: pointer;
  font-size: 1rem;
  gap: var(--space-unit);
  line-height: 1.5rem;
}

.suggestion:hover,
.suggestion[aria-selected='true'] {
  background: var(--gray100);
}

.suggestion strong {
  font-weight: var(--font-bd);
}

.suggestion mark {
  background-color: var(--red50);
}

.suggestion z-icon {
  --z-icon-height: 1.125rem;

  margin-top: 0.125rem;
}

.suggestions z-divider {
  margin: var(--space-unit) 0;
}

@media (width < 1152px) {
  .searchbar .searchbar-button > .searchbar-button-label {
    display: none;
  }
}

@media (width >= 768px) {
  .searchbar {
    --searchbar-button-x-padding: 16px;
    --searchbar-button-icon-width: 2rem;
  }

  .searchbar .input-wrapper {
    gap: 14px;
  }

  .searchbar button[type='reset'] {
    --z-icon-width: 1.5rem;
    --z-icon-height: 1.5rem;
  }

  .searchbar input,
  .searchbar .searchbar-button {
    font-size: 1.5rem;
  }

  .searchbar .searchbar-button {
    padding: 8px var(--searchbar-button-x-padding);
  }

  .suggestions {
    padding: var(--space-unit) calc(var(--space-unit) * 2);
  }
}

@media (width >= 1152px) {
  .searchbar {
    --closed-searchbar-width: 190px;
  }
}

@media (width >= 1366px) {
  .searchbar .searchbar-button {
    border-right: 1px solid #000;
  }

  .suggestions {
    max-width: 1366px;
    padding: var(--space-unit) calc(var(--space-unit) * 3);
  }
}
