:root{
  --topbar-h: var(--menu-h, clamp(44px, 7.2vh, 56px));
  --radius: 10px;
  --gap: clamp(6px, 1.6vw, 10px);

  --brand: #3e7ec8;
  --ink: #0a0a0a;
  --muted-ink: #2f3640;
  --border-strong: #9ca3af;
  --border-soft:   #d1d5db;
  --bg-input: #eef2f6;
  --bg-chip:  #eef2f6;
  --bg-chip-hover:#e6ebf2;
  --bg-control: #e9ecef;

  --fs-base: clamp(12px, 1.6vw, 14px);
  --fs-sm:   clamp(11px, 1.4vw, 13px);
  --fs-xs:   clamp(10px, 1.2vw, 12px);

  --pad-x: clamp(8px, 2.2vw, 12px);
  --pad-y: clamp(6px, 1.6vh, 8px);

  --sb-h: calc(var(--topbar-h) - 14px); 

  
  --fs-input: var(--fs-base);
}

.top-menu{ overflow: visible; }

nav.top-menu .search-inline{
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: center;
  gap: var(--gap);
  width: 100%;
  min-width: 0;
}

nav.top-menu .search-inline .search-box{
  position: relative;
  min-width: 0;
  margin-right: 0;
  z-index: 2;
}

nav.top-menu .search-inline .search-input{
  width: 100%;
  box-sizing: border-box;
  height: var(--sb-h);
  line-height: var(--sb-h);
  padding: 0 calc(30px + var(--pad-x)) 0 var(--pad-x);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  background-color: var(--bg-input, #e0e0e0) !important;

  
  font-size: var(--fs-input);

  color: var(--ink);
  outline: none; box-shadow: none;
  min-width: 0; overflow: hidden; text-overflow: ellipsis;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

nav.top-menu .search-inline .search-input::placeholder { color: transparent; }

#searchClear.clear-inside{
  position:absolute;
  right: clamp(8px, 2vw, 12px);
  top:50%;
  transform: translateY(-50%);
  width: clamp(18px, 3.6vw, 22px);
  height: clamp(18px, 3.6vw, 22px);
  border-radius:50%;
  border:1px solid var(--border-soft);
  background:#cfcfcf;
  color:#444;
  font-size: clamp(12px, 2.8vw, 16px);
  line-height:1;
  display:flex; align-items:center; justify-content:center;
  padding:0; cursor:pointer;
  transition:background .15s ease, transform .1s ease;
  visibility:hidden;
  z-index: 999;
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
#searchClear.clear-inside:hover{ background:#e1e5ea; }


nav.top-menu .search-actions{
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  position: static;
  z-index: auto;
  margin: 0;
}

nav.top-menu .search-actions .search-action{
  position: static;
  transform: none;
  height: var(--sb-h);
  width:  var(--sb-h);
  border-radius: 12px;
  border: 1px solid var(--border-strong);
  background:#d4d6db;
  display:flex; align-items:center; justify-content:center;
  font-size: clamp(14px, 2.8vw, 16px);
  color: var(--ink);
  padding:0; cursor:pointer;
  outline:none; box-shadow:none;
  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .06s ease;
}
nav.top-menu .search-actions .search-action:active{ transform: scale(.98); }
nav.top-menu .search-actions .search-action.primary{
  background: var(--brand);
  border-color: var(--brand);
  color:#fff;
}
nav.top-menu .search-actions .search-action.primary:hover{ filter: brightness(0.92); }
nav.top-menu .search-actions .search-action:disabled{ opacity:.7; cursor: default; }

.search-history{
  position: fixed;
  top: calc(var(--topbar-h) + clamp(6px, 1.2vh, 10px));
  left: clamp(6px, 2vw, 12px);
  right: clamp(6px, 2vw, 12px);
  max-width: 720px;
  margin: 0 auto;
  background:#fff;
  border:1px solid var(--border-soft);
  border-radius:14px;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  padding: clamp(10px, 2.4vw, 14px) clamp(10px, 2.4vw, 12px);
  z-index: 9999;
  display: none;
  transition: opacity 0.25s ease, transform 0.25s ease;
  opacity: 0;
  transform: translateY(-5px);
  pointer-events: none;
}
.search-history.show{
  display:block;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.search-section{ margin-bottom: clamp(8px, 2vh, 12px); }
.search-section:last-child{ margin-bottom: 0; }

.search-history h4{
  margin: 6px 6px 8px;
  font-size: var(--fs-sm);
  font-weight: 400;
  color:#6b7280;
}

.search-history .chips{
  display:flex; flex-wrap:wrap; gap: clamp(6px, 1.4vw, 8px);
  max-height: 42vh; overflow:auto;
}

.search-chip{
  display:inline-block;
  padding: clamp(6px, 1.2vh, 8px) clamp(8px, 2.2vw, 12px);
  background: var(--bg-chip);
  border:1px solid var(--border-soft);
  border-radius:999px;
  font-size: var(--fs-sm);
  font-weight: 400;
  color: var(--ink);
  cursor:pointer; user-select:none;
}
.search-chip:hover{ background: var(--bg-chip-hover); }

.search-chip.has-close {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding-right: clamp(22px, 4vw, 28px);
}
.search-chip .chip-close {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(16px, 3.4vw, 18px);
  height: clamp(16px, 3.4vw, 18px);
  border: none; border-radius: 50%;
  background: #cfcfcf; color: #444;
  font-size: clamp(11px, 2.6vw, 13px); line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; padding: 0;
  transition: background .2s ease, color .2s ease, transform .06s ease;
}
.search-chip .chip-close:hover { background: #d7dbe0; color: var(--ink); }
.search-chip .chip-close:active{ transform: scale(.96); }

.search-divider{ height:1px; background:#eef0f3; margin: clamp(8px, 2vh, 12px) 0; }

.search-history-close {
  position: absolute;
  top: 8px; right: 8px;
  width: clamp(26px, 4.8vw, 28px);
  height: clamp(26px, 4.8vw, 28px);
  border: 1px solid var(--border-soft);
  border-radius: 50%;
  background: #d8d8d8;
  font-size: clamp(16px, 3.4vw, 18px);
  line-height: 1; color: #000000;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .2s ease, border-color .2s ease;
}
.search-history-close:hover { background: var(--bg-control); }

.search-box { position: relative; }

input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

.search-no-results{
  text-align:center;
  font-weight:600;
  color: var(--ink);
  margin: 2px 6px 8px;
  font-size: var(--fs-base);
}

#searchBackdrop{ z-index: 9998; }

nav.top-menu .search-inline{
  display: grid !important;
  grid-template-columns: minmax(0,1fr) auto !important;
  align-items: center !important;
  gap: var(--gap) !important;
  width: 100% !important;
  min-width: 0 !important;
}

nav.top-menu .search-inline .search-box{
  position: relative !important;
  min-width: 0 !important;
  margin-right: 0 !important;
  z-index: auto !important;
}

nav.top-menu .search-actions{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: static !important;
  margin: 0 !important;
  z-index: auto !important;
}

nav.top-menu .search-actions .search-action{
  position: static !important;
  transform: none !important;
  height: var(--sb-h) !important;
  width:  var(--sb-h) !important;
  border-radius: 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  top: auto !important; right: auto !important; bottom: auto !important; left: auto !important;
}

nav.top-menu .search-inline .search-input{
  height: var(--sb-h) !important;
  line-height: var(--sb-h) !important;
  width: 100% !important;
}

nav.top-menu .search-inline form.search-inline-form{
  display: contents !important;
}

@media (max-width: 420px){
  nav.top-menu .search-inline{ gap: 6px; }
}


@supports (-webkit-touch-callout: none) {
  :root { --fs-input: 16px; }
}


@media (hover: hover) and (pointer: fine) {
  .search-chip .chip-close {
    position: absolute;
    top: 50%;
    right: 4px;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    border-radius: 50%;
    background: transparent;
  }

  .search-chip.has-close {
    position: relative;
    padding-right: 28px; 
  }

  .search-chip .chip-close:hover {
    background-color: rgba(0, 0, 0, 0.05);
  }
}
