/* ================================================================
   SEARCH OVERLAY
   Full-screen search modal with input, categories, results.
   ================================================================ */

.search-overlay {
  position: fixed;
  inset: 0;
  background: var(--clr-green-deep);
  z-index: 600;
  display: none;
  flex-direction: column;
  padding: 80px 64px;
}

.search-overlay[aria-hidden="false"] {
  display: flex;
  animation: reveal .3s ease;
}

@keyframes reveal {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

.search-overlay__close {
  position: absolute;
  top: 28px;
  right: 56px;
  font-family: var(--ff-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(200, 240, 0, .5);
  cursor: pointer;
  transition: color var(--speed-fast);
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
}

.search-overlay__close:hover,
.search-overlay__close:focus-visible {
  color: var(--clr-chartreuse);
}

.search-overlay__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(200, 240, 0, .4);
  margin-bottom: 20px;
}

.search-overlay__input {
  background: transparent;
  border: none;
  border-bottom: 2px solid rgba(200, 240, 0, .3);
  font-family: var(--ff-display);
  font-size: clamp(40px, 7vw, 80px);
  letter-spacing: .04em;
  color: var(--clr-chartreuse);
  outline: none;
  width: 100%;
  padding-bottom: 16px;
  caret-color: var(--clr-chartreuse);
}

.search-overlay__input::placeholder {
  color: rgba(200, 240, 0, .15);
}

.search-overlay__input:focus-visible {
  border-bottom-color: var(--clr-chartreuse);
}

.search-overlay__cats {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 28px 0;
}

.search-cat {
  padding: 8px 18px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  background: rgba(200, 240, 0, .07);
  border: 1px solid rgba(200, 240, 0, .15);
  color: rgba(200, 240, 0, .6);
  cursor: pointer;
  transition: all var(--speed-fast);
  border-radius: var(--radius);
  text-decoration: none;
  display: inline-block;
}

.search-cat:hover,
.search-cat:focus-visible {
  background: rgba(200, 240, 0, .15);
  color: var(--clr-chartreuse);
  border-color: rgba(200, 240, 0, .4);
}

.search-results {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex: 1;
}

.search-result {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(200, 240, 0, .08);
  cursor: pointer;
  transition: all var(--speed-fast);
  text-decoration: none;
  color: inherit;
}

.search-result:hover,
.search-result:focus-visible {
  padding-left: 12px;
}

.search-result__num {
  font-family: var(--ff-display);
  font-size: 16px;
  letter-spacing: .06em;
  color: rgba(200, 240, 0, .2);
  width: 32px;
  flex-shrink: 0;
}

.search-result__cat {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--clr-chartreuse-muted);
  margin-bottom: 3px;
}

.search-result__title {
  font-family: var(--ff-display);
  font-size: 20px;
  letter-spacing: .04em;
  color: rgba(255, 255, 255, .85);
}

.search-result__arrow {
  margin-left: auto;
  font-size: 20px;
  color: rgba(200, 240, 0, .2);
  transition: all var(--speed-fast);
}

.search-result:hover .search-result__arrow {
  color: var(--clr-chartreuse);
}

/* --- No results state --- */
.search-empty {
  color: rgba(200, 240, 0, .3);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 40px 0;
  text-align: center;
  display: none;
}
