/* =====================================================================
   Limestone Games — global command-palette search.
   Self-contained: injected into the page nav by global-search.js and
   searches the whole catalog from anywhere. Uses the site's --cat-*
   tokens (with fallbacks) so it retints per category automatically.
   ===================================================================== */

/* ---- Trigger (looks like a search field, opens the palette) ---- */
.gs-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  margin-right: 12px;
  padding: 7px 10px 7px 12px;
  border: 1px solid var(--nav-line, rgba(26,20,12,0.12));
  border-radius: 999px;
  background: var(--paper, #FBF7EE);
  color: var(--nav-ink3, #8A7E6F);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 12.5px;
  font-weight: 500;
  cursor: text;
  transition: border-color .15s, color .15s, box-shadow .15s;
  min-width: 168px;
}
.gs-trigger:hover {
  color: var(--nav-ink2, #4A4138);
  border-color: color-mix(in oklab, var(--cat-accent, #C77A2A) 45%, var(--nav-line, rgba(26,20,12,0.12)));
}
.gs-trigger:focus-visible {
  outline: none;
  border-color: var(--cat-accent, #C77A2A);
  box-shadow: 0 0 0 3px var(--cat-glow, rgba(199,122,42,0.30));
  color: var(--nav-ink2, #4A4138);
}
.gs-trigger .gs-t-icon { font-size: 14px; line-height: 1; color: var(--cat-accent, #C77A2A); }
.gs-trigger .gs-t-label { flex: 1; text-align: left; }
.gs-trigger .gs-t-kbd {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px;
  padding: 2px 6px;
  border-radius: 6px;
  background: var(--paper-soft, #F3ECDC);
  border: 1px solid var(--nav-line, rgba(26,20,12,0.10));
  color: var(--nav-ink3, #8A7E6F);
}

/* ---- Overlay ---- */
.gs-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 11vh 16px 16px;
  background: rgba(26,20,12,0.46);
  opacity: 0;
  transition: opacity .16s ease;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}
.gs-overlay[hidden] { display: none; }
.gs-overlay.gs-open { opacity: 1; }

/* ---- Panel ---- */
.gs-panel {
  width: 100%;
  max-width: 560px;
  background: #fff;
  border: 1px solid var(--nav-line, rgba(26,20,12,0.12));
  border-radius: 16px;
  box-shadow: 0 24px 60px -18px rgba(0,0,0,0.50), 0 2px 0 rgba(0,0,0,0.04);
  overflow: hidden;
  transform: translateY(-8px) scale(0.99);
  transition: transform .16s cubic-bezier(0.2,0.8,0.2,1);
  display: flex;
  flex-direction: column;
  max-height: 74vh;
}
.gs-open .gs-panel { transform: translateY(0) scale(1); }

/* ---- Search field ---- */
.gs-field {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--nav-line, rgba(26,20,12,0.10));
}
.gs-field .gs-f-icon { font-size: 17px; color: var(--cat-accent, #C77A2A); line-height: 1; }
.gs-input {
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  font: inherit;
  font-size: 16px; /* >=16px avoids iOS zoom-on-focus */
  color: var(--nav-ink, #1A140C);
}
.gs-input::placeholder { color: var(--nav-ink3, #8A7E6F); }
.gs-field .gs-esc {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px;
  padding: 3px 7px;
  border-radius: 6px;
  background: var(--paper-soft, #F3ECDC);
  border: 1px solid var(--nav-line, rgba(26,20,12,0.10));
  color: var(--nav-ink3, #8A7E6F);
}

/* ---- Results ---- */
.gs-results {
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 6px;
}
.gs-group-label {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--nav-ink3, #8A7E6F);
  padding: 10px 12px 6px;
}
.gs-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
.gs-row.active, .gs-row:hover {
  background: var(--cat-tint, #FBEFD8);
}
.gs-row-dot {
  flex: 0 0 auto;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--g, #C77A2A);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--g, #C77A2A) 16%, transparent);
}
.gs-row-main { flex: 1; min-width: 0; }
.gs-row-name {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 14px;
  font-weight: 600;
  color: var(--nav-ink, #1A140C);
}
.gs-row-new {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cat-accent, #C77A2A);
  border: 1px solid color-mix(in oklab, var(--cat-accent, #C77A2A) 40%, transparent);
  border-radius: 5px;
  padding: 1px 5px;
}
.gs-row-desc {
  font-size: 12px;
  color: var(--nav-ink3, #8A7E6F);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gs-row-cat {
  flex: 0 0 auto;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--nav-ink2, #4A4138);
  background: var(--paper-soft, #F3ECDC);
  border: 1px solid var(--nav-line, rgba(26,20,12,0.10));
  border-radius: 999px;
  padding: 3px 9px;
}
.gs-empty {
  padding: 28px 16px 34px;
  text-align: center;
  color: var(--nav-ink3, #8A7E6F);
}
.gs-empty strong { display: block; color: var(--nav-ink, #1A140C); font-size: 15px; margin-bottom: 4px; }
.gs-empty span { font-size: 13px; }

/* ---- Footer hint ---- */
.gs-foot {
  display: flex;
  gap: 16px;
  align-items: center;
  padding: 9px 16px;
  border-top: 1px solid var(--nav-line, rgba(26,20,12,0.10));
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10.5px;
  color: var(--nav-ink3, #8A7E6F);
}
.gs-foot b {
  font-weight: 600;
  color: var(--nav-ink2, #4A4138);
  background: var(--paper-soft, #F3ECDC);
  border: 1px solid var(--nav-line, rgba(26,20,12,0.10));
  border-radius: 5px;
  padding: 1px 5px;
  margin-right: 4px;
}

html.gs-locked { overflow: hidden; }

@media (max-width: 700px) {
  /* Keep the nav tidy when the trigger is added — wrap rather than overflow.
     site-nav.css already wraps casino/kids/strategy; nav.nav specificity also
     covers arcade, whose inline nav has no wrap rule of its own. */
  nav.nav { flex-wrap: wrap; }
  nav.nav .nav-left { flex-wrap: wrap; }
  nav.nav .nav-links { flex-wrap: wrap; }
  .gs-trigger { min-width: 0; margin-right: 0; padding: 8px 10px; }
  .gs-trigger .gs-t-label, .gs-trigger .gs-t-kbd { display: none; }
  .gs-overlay { padding-top: 8vh; }
  .gs-foot { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .gs-overlay, .gs-panel { transition: none; }
}
