/* =========================================================
   Dom Diego · Search Autocomplete · DS v5
   Dropdown que aparece embaixo do search-bar / dentro do overlay
   ========================================================= */

/* === Wrapper do dropdown === */
.dd-suggest {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  min-width: 340px;
  max-height: min(480px, calc(100vh - 160px));
  overflow-y: auto;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12),
              0 4px 12px rgba(0, 0, 0, 0.06);
  border: 1px solid var(--dd-line, #E3DDD0);
  z-index: 110;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 180ms ease, transform 180ms cubic-bezier(.2,.7,.2,1),
              visibility 0ms linear 180ms;
  font-family: var(--dd-font-sans, 'Montserrat', sans-serif);
  scrollbar-width: thin;
}
.dd-suggest.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 180ms ease, transform 180ms cubic-bezier(.2,.7,.2,1);
}
.dd-suggest::-webkit-scrollbar { width: 6px; }
.dd-suggest::-webkit-scrollbar-thumb { background: var(--dd-line-strong, #C9C1AE); border-radius: 3px; }

.dd-suggest-section {
  padding: 12px 16px 8px;
}
.dd-suggest-section + .dd-suggest-section {
  border-top: 1px solid var(--dd-line, #E3DDD0);
}
.dd-suggest-title {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dd-ink-40, #7A7873);
  margin: 0 0 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.dd-suggest-title-count {
  font-family: ui-monospace, monospace;
  color: var(--dd-ink-40, #7A7873);
  font-weight: 500;
  letter-spacing: 0.04em;
}

/* === Termo popular / sugestão === */
.dd-suggest-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  margin: 0 6px 6px 0;
  background: var(--dd-bg-soft, #F5F1E9);
  border: 1px solid var(--dd-line, #E3DDD0);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  color: var(--dd-ink, #0A0A0A);
  cursor: pointer;
  text-decoration: none;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
  letter-spacing: 0.02em;
  font-family: inherit;
}
.dd-suggest-pill:hover,
.dd-suggest-pill.is-focus {
  border-color: var(--dd-ink, #0A0A0A);
  background: #fff;
}
.dd-suggest-pill svg {
  width: 11px;
  height: 11px;
  color: var(--dd-ink-40, #7A7873);
}

/* === Resultado individual === */
.dd-suggest-item {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  margin: 0 -10px;
  border-radius: 4px;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: background 120ms ease;
}
.dd-suggest-item:hover,
.dd-suggest-item.is-focus {
  background: var(--dd-bg-soft, #F5F1E9);
}
.dd-suggest-item-thumb {
  width: 48px;
  height: 60px;
  background: var(--dd-bg-muted, #EEE9DE);
  border-radius: 3px;
  overflow: hidden;
}
.dd-suggest-item-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.dd-suggest-item-info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.dd-suggest-item-cat {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dd-ink-40, #7A7873);
}
.dd-suggest-item-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--dd-ink, #0A0A0A);
  letter-spacing: -0.005em;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dd-suggest-item-name mark {
  background: transparent;
  color: var(--dd-accent, #7A1F2B);
  font-weight: 700;
}
.dd-suggest-item-price {
  font-size: 13px;
  font-weight: 700;
  color: var(--dd-ink, #0A0A0A);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.005em;
}
.dd-suggest-item-price small {
  display: block;
  font-size: 9px;
  font-weight: 500;
  color: var(--dd-ink-40, #7A7873);
  text-decoration: line-through;
  margin-top: 1px;
}

/* === Empty state === */
.dd-suggest-empty {
  padding: 28px 16px;
  text-align: center;
  color: var(--dd-ink-40, #7A7873);
  font-size: 13px;
}
.dd-suggest-empty svg {
  color: var(--dd-ink-20, #C9C1AE);
  margin-bottom: 10px;
}
.dd-suggest-empty strong {
  display: block;
  color: var(--dd-ink, #0A0A0A);
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
}

/* === Skeleton loading === */
.dd-suggest-skeleton {
  padding: 10px 0;
}
.dd-suggest-skeleton-item {
  display: grid;
  grid-template-columns: 48px 1fr 40px;
  gap: 12px;
  padding: 8px 0;
}
.dd-suggest-skel {
  background: linear-gradient(90deg,
    var(--dd-bg-muted, #EEE9DE) 0%,
    var(--dd-bg-soft, #F5F1E9) 50%,
    var(--dd-bg-muted, #EEE9DE) 100%);
  background-size: 400% 100%;
  animation: dd-skel-shimmer 1.4s linear infinite;
  border-radius: 3px;
}
.dd-suggest-skel-thumb { width: 48px; height: 60px; }
.dd-suggest-skel-info { display: flex; flex-direction: column; gap: 6px; justify-content: center; }
.dd-suggest-skel-line { height: 10px; }
.dd-suggest-skel-line.w70 { width: 70%; }
.dd-suggest-skel-line.w40 { width: 40%; }
.dd-suggest-skel-price { height: 14px; align-self: center; }
@keyframes dd-skel-shimmer {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

/* === Footer com CTA "ver todos" === */
.dd-suggest-footer {
  padding: 12px 16px;
  border-top: 1px solid var(--dd-line, #E3DDD0);
  background: var(--dd-bg-soft, #F5F1E9);
  border-radius: 0 0 6px 6px;
}
.dd-suggest-footer-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--dd-ink, #0A0A0A);
  color: #fff;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 3px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: background 140ms ease;
}
.dd-suggest-footer-cta:hover {
  background: var(--dd-accent, #7A1F2B);
}
.dd-suggest-footer-cta::after {
  content: "→";
  transition: transform 160ms ease;
}
.dd-suggest-footer-cta:hover::after { transform: translateX(3px); }

/* === Integração com header search bar (desktop) === */
.dd-search { position: relative; }
.dd-search .dd-suggest { top: calc(100% + 8px); }

/* Mobile: dentro do overlay fullscreen */
.dd-search-overlay .dd-suggest {
  position: static;
  box-shadow: none;
  border: 0;
  border-top: 1px solid var(--dd-line, #E3DDD0);
  max-width: 640px;
  margin: 16px auto 0;
  border-radius: 0;
  max-height: none;
  visibility: visible;
  opacity: 1;
  transform: none;
  background: transparent;
}
.dd-search-overlay .dd-suggest-section {
  background: #fff;
  border-radius: 6px;
  margin-bottom: 10px;
  padding: 14px 16px 10px;
}
.dd-search-overlay .dd-suggest-section + .dd-suggest-section {
  border-top: 0;
}
.dd-search-overlay .dd-suggest-footer {
  background: transparent;
  border: 0;
  padding: 6px 0 20px;
}

@media (max-width: 640px) {
  .dd-suggest { min-width: 0; border-radius: 0 0 6px 6px; }
  .dd-suggest-item-name { font-size: 12px; }
  .dd-suggest-item-price { font-size: 12px; }
}
