/* WP Static Search - comportamento: POPUP abaixo do input, acompanha rolagem, scrollbar interno */

/* Contexto do formulário: referência posicional preferencial */
#wp-static-search-form,
.wp-static-search-form {
  position: relative !important; /* referência para preview absolute */
  z-index: 0;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 8px;
  width: 100%;
  align-items: stretch;
  margin: 0;
  box-sizing: border-box;
  min-width: 0;
}

/* Container de preview - ABSOLUTE (relativo ao form) */
/* NOTA: se o preview estiver fora do form, o JS abaixo vai posicioná-lo corretamente */
#wp-static-search-preview,
.wp-static-search-preview-container {
  position: absolute !important;           /* importante: não fixed */
  z-index: 2147483647 !important;
  top: calc(100% + 6px);                   /* sempre abaixo do form (6px gap) */
  left: 0;                                 /* alinhado ao início do form */
  right: auto;
  width: auto;
  max-width: min(600px, 100%);             /* nunca maior que 600px nem ultrapassa o contexto */
  box-sizing: border-box;
  max-height: min(60vh, calc(var(--wps-item-h,64px) * 5 + 12px)); /* até 5 itens visíveis por padrão */
  overflow-y: auto;                        /* scroll interno natural quando tiver >5 itens */
  overflow-x: hidden;
  background: #fff;
  border: 1px solid #e6e6e6;
  box-shadow: 0 12px 48px rgba(0,0,0,0.35) !important;
  border-radius: 6px;
  padding: 6px;
  display: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
  transform-origin: top left;
  overflow-wrap: break-word;
  word-break: break-word;
  min-width: 0;
  -webkit-overflow-scrolling: touch; /* suaviza scroll em iOS */
}

/* fallback quando for injetado no body e você não puder mover pro form via PHP/JS */
body .wp-static-search-preview-container[data-position="fallback"] {
  position: absolute !important;
  box-sizing: border-box;
  left: 10px !important;
  right: 10px !important;
  width: calc(100vw - 20px) !important;
  max-width: calc(100vw - 20px) !important;
}

/* visível */
.wp-static-search-preview-container.visible {
  display: block !important;
}

/* Itens e conteúdo do preview */
.wps-item-preview {
  padding: 0;
  border-bottom: 1px solid #f0f0f0;
  cursor: pointer;
  transition: background 0.18s;
  box-sizing: border-box;
  min-width: 0;
}

.wps-item-preview:hover { background: #fff5f5; }
.wps-item-preview:last-child { border-bottom: none; }

.wps-item-preview a {
  display: block;
  padding: 8px 10px;
  text-decoration: none;
  color: inherit;
  box-sizing: border-box;
  word-break: break-word;
}

.wps-item-preview h4 {
  margin: 0 0 4px;
  font-size: 14px;
  color: #222;
  font-weight: 600;
  pointer-events: none;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.wps-item-preview a:hover h4 { color: #ec0000; }

.wps-excerpt {
  margin: 0;
  color: #666;
  font-size: 13px;
  line-height: 1.4;
  pointer-events: none;
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* Fotos / embeds não estouram a largura */
#wp-static-search-preview img,
.wp-static-search-preview-container img,
#wp-static-search-preview iframe,
.wp-static-search-preview-container iframe {
  max-width: 100%;
  height: auto;
  display: block;
  box-sizing: border-box;
}

/* Mensagens internas */
.wps-no-results,
.wps-tip,
.wps-loading {
  padding: 12px;
  color: #666;
  text-align: center;
  font-size: 14px;
  box-sizing: border-box;
}

.wps-loading { color: #ec0000; }

/* Full results (se houver página completa) */
#wp-static-search-full {
  margin: 20px auto;
  max-width: 980px;
  padding: 12px;
  box-sizing: border-box;
}

/* Paginação */
.wps-pagination { margin: 24px 0 12px; }
.wps-pagination ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  margin: 12px 0;
  justify-content: center;
}
.wps-page-btn {
  padding: 6px 12px;
  background: #f0f0f0;
  border: 1px solid #ddd;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
  color: #333;
  transition: all 0.18s;
  white-space: nowrap;
  box-sizing: border-box;
}

/* Botão do form */
.search-submit,
#wp-static-search-form button,
.wp-static-search-form button,
#wp-static-search-form .search-submit,
.wp-static-search-form .search-submit {
  flex: 0 0 auto !important;
  padding: 8px 16px !important;
  background: #ec0000 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px !important;
  white-space: nowrap;
  transition: background 0.18s;
  align-self: stretch;
  box-sizing: border-box;
}

/* Reforço do form e inputs */
#wp-static-search-input,
.wp-static-search-form input[type="search"],
.wp-static-search-form input[name="s"] {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  min-width: 0;
  box-sizing: border-box;
}

/* ===== Responsividade: mobile e tablet ===== */

/* Mobile: margem lateral forçada para evitar overflow à direita */
@media (max-width: 640px) {
  #wp-static-search-preview,
  .wp-static-search-preview-container {
    left: 10px !important;
    right: 10px !important;
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    min-width: 0 !important;
    max-height: calc(5 * var(--wps-item-h,64px)); /* mostra ~5 itens na altura screen-friendly */
    box-sizing: border-box;
    transform-origin: top center;
  }

  /* garante que mesmo que o form esteja deslocado à direita o preview não vaze */
  body .wp-static-search-preview-container {
    left: 10px !important;
    right: 10px !important;
    width: calc(100vw - 20px) !important;
  }

  .wps-item-preview a { padding: 10px 8px; min-height: 44px; }
}

/* Tablet: margem lateral mais generosa */
@media (min-width: 641px) and (max-width: 1024px) {
  #wp-static-search-preview,
  .wp-static-search-preview-container {
    max-width: min(500px, 90vw);
    left: 10px;
    right: 10px;
    width: calc(100vw - 20px);
    box-sizing: border-box;
  }
}

/* Desktop grande */
@media (min-width: 1025px) {
  #wp-static-search-preview,
  .wp-static-search-preview-container {
    max-width: 600px;
    left: 0;
    right: auto;
    width: auto;
  }
}

/* Touch devices */
@media (hover: none) and (pointer: coarse) {
  .wps-item-preview a { padding: 12px 10px; min-height: 48px; }
  .wps-page-btn { min-width: 44px; min-height: 44px; }
  .search-submit { min-height: 44px; }
}

/* Print */
@media print {
  #wp-static-search-preview,
  .wp-static-search-preview-container { display: none !important; }
}