/* ============================================================
   AFINA AI Search — Mobile Overlay (≤768px)
   Patrón Doofinder: overlay separado, fullscreen nativo,
   todos los estilos con !important para sobrevivir a Astra.
   ============================================================ */

/* ── Reset nuclear del overlay mobile ─────────────────────── */
#afina-mobile-overlay,
#afina-mobile-overlay * {
  box-sizing: border-box !important;
  -webkit-box-sizing: border-box !important;
  font-family: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif !important;
  -webkit-tap-highlight-color: transparent !important;
  -webkit-text-size-adjust: 100% !important;
}

/* ── Overlay: fixed fullscreen, z-index máximo ─────────────── */
#afina-mobile-overlay {
  display: none !important;          /* hidden por defecto */
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 2147483647 !important;    /* máximo z-index posible */
  background: #ffffff !important;
  overflow: hidden !important;
  flex-direction: column !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  transform: none !important;
  border-radius: 0 !important;
}

#afina-mobile-overlay.afina-mob--open {
  display: flex !important;
}

/* Animación de entrada slide-down */
@keyframes afinaMobSlideIn {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}
#afina-mobile-overlay.afina-mob--open {
  animation: afinaMobSlideIn .2s cubic-bezier(.4,0,.2,1) both !important;
}

/* ── Header ────────────────────────────────────────────────── */
.afina-mob__header {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  background: #2E508A !important;
  flex-shrink: 0 !important;
  min-height: 56px !important;
  width: 100% !important;
  border-bottom: 2px solid #FFD931 !important;
}

/* Botón volver */
.afina-mob__back {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: none !important;
  border: none !important;
  color: #ffffff !important;
  cursor: pointer !important;
  padding: 8px !important;
  min-width: 40px !important;
  min-height: 40px !important;
  flex-shrink: 0 !important;
  border-radius: 50% !important;
  transition: background .15s !important;
}
.afina-mob__back:hover,
.afina-mob__back:active {
  background: rgba(255,255,255,.15) !important;
}

/* Input wrapper */
.afina-mob__input-wrap {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: rgba(255,255,255,.15) !important;
  border: 1.5px solid rgba(255,255,255,.3) !important;
  border-radius: 6px !important;
  padding: 0 12px !important;
  min-height: 40px !important;
  transition: border-color .15s !important;
}
.afina-mob__input-wrap:focus-within {
  border-color: #FFD931 !important;
  background: rgba(255,255,255,.2) !important;
}

.afina-mob__input {
  flex: 1 !important;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  color: #ffffff !important;
  font-size: 16px !important;  /* ≥16px = no zoom en iOS */
  font-weight: 500 !important;
  line-height: 1.4 !important;
  height: 38px !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.afina-mob__input::placeholder {
  color: rgba(255,255,255,.6) !important;
}
.afina-mob__input::-webkit-search-cancel-button,
.afina-mob__input::-webkit-search-decoration {
  display: none !important;
  -webkit-appearance: none !important;
}

/* Lupa icono */
.afina-mob__search-icon {
  color: rgba(255,255,255,.7) !important;
  flex-shrink: 0 !important;
  width: 18px !important;
  height: 18px !important;
}

/* Botón limpiar */
.afina-mob__clear {
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255,255,255,.2) !important;
  border: none !important;
  color: #ffffff !important;
  cursor: pointer !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  padding: 0 !important;
}
.afina-mob__clear.afina-mob--visible {
  display: flex !important;
}

/* Spinner */
.afina-mob__spinner {
  display: none !important;
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
}
.afina-mob__spinner.afina-mob--visible {
  display: block !important;
}
@keyframes afinaMobSpin { to { transform: rotate(360deg); } }
.afina-mob__spinner-ring {
  width: 18px !important;
  height: 18px !important;
  border: 2.5px solid rgba(255,255,255,.25) !important;
  border-top-color: #FFD931 !important;
  border-radius: 50% !important;
  animation: afinaMobSpin .7s linear infinite !important;
  display: block !important;
}

/* ── Banner top ────────────────────────────────────────────── */
.afina-mob__banner {
  display: none !important;
  padding: 9px 14px !important;
  background: #FFD931 !important;
  color: #1a1a1a !important;
  font-size: 12.5px !important;
  font-weight: 700 !important;
  text-align: center !important;
  flex-shrink: 0 !important;
  width: 100% !important;
}
.afina-mob__banner.afina-mob--visible {
  display: block !important;
}

/* ── Categorías como chips horizontales ────────────────────── */
.afina-mob__cats {
  display: none !important;
  flex-shrink: 0 !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  padding: 10px 14px !important;
  gap: 8px !important;
  background: #f7f9fc !important;
  border-bottom: 1px solid #e5e8ee !important;
  scrollbar-width: none !important;
  white-space: nowrap !important;
  width: 100% !important;
}
.afina-mob__cats::-webkit-scrollbar {
  display: none !important;
}
.afina-mob__cats.afina-mob--visible {
  display: flex !important;
}

.afina-mob__cat-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: #ffffff !important;
  border: 1.5px solid #d0d8e8 !important;
  border-radius: 20px !important;
  padding: 6px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #2E508A !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
  transition: all .15s !important;
  min-height: 34px !important;
}
.afina-mob__cat-chip:hover,
.afina-mob__cat-chip:active {
  background: #2E508A !important;
  color: #ffffff !important;
  border-color: #2E508A !important;
}
.afina-mob__cat-count {
  background: #e8eef6 !important;
  color: #2E508A !important;
  border-radius: 10px !important;
  padding: 1px 6px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
}
.afina-mob__cat-chip:hover .afina-mob__cat-count,
.afina-mob__cat-chip:active .afina-mob__cat-count {
  background: rgba(255,255,255,.25) !important;
  color: #ffffff !important;
}

/* ── Cuerpo scrollable ─────────────────────────────────────── */
.afina-mob__body {
  flex: 1 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  padding: 14px !important;
  width: 100% !important;
  background: #ffffff !important;
  /* Espacio para el botón sticky de abajo */
  padding-bottom: 80px !important;
}

/* ── Estado inicial ────────────────────────────────────────── */
.afina-mob__state-initial {
  display: none !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding: 24px 0 !important;
  gap: 20px !important;
  width: 100% !important;
}
.afina-mob__state-initial.afina-mob--visible {
  display: flex !important;
}

.afina-mob__state-hint {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 8px !important;
  color: #999 !important;
}
.afina-mob__state-hint svg {
  opacity: .3 !important;
  color: #2E508A !important;
}
.afina-mob__state-hint p {
  font-size: 13.5px !important;
  color: #999 !important;
  text-align: center !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0 20px !important;
}

/* Sugerencias iniciales */
.afina-mob__suggestions-title {
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: #686868 !important;
  width: 100% !important;
  padding: 0 2px !important;
  margin: 0 !important;
}
.afina-mob__suggestions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  width: 100% !important;
}
.afina-mob__suggestion-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  background: #f0f4fa !important;
  border: 1px solid #d0d8e8 !important;
  border-radius: 20px !important;
  padding: 7px 14px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: #2E508A !important;
  cursor: pointer !important;
  text-decoration: none !important;
  min-height: 36px !important;
}
.afina-mob__suggestion-chip:active {
  background: #2E508A !important;
  color: #ffffff !important;
}

/* ── Estado sin resultados ─────────────────────────────────── */
.afina-mob__state-empty {
  display: none !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 40px 20px !important;
  gap: 12px !important;
  min-height: 200px !important;
  width: 100% !important;
}
.afina-mob__state-empty.afina-mob--visible {
  display: flex !important;
}
.afina-mob__state-empty svg {
  color: #FFD931 !important;
  opacity: .8 !important;
}
.afina-mob__state-empty p {
  font-size: 14px !important;
  color: #686868 !important;
  text-align: center !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}
.afina-mob__state-empty strong {
  color: #2E508A !important;
}

/* ── Grid de productos ─────────────────────────────────────── */
.afina-mob__results {
  display: none !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 10px !important;
  width: 100% !important;
}
.afina-mob__results.afina-mob--visible {
  display: grid !important;
}

/* ── Tarjeta de producto ───────────────────────────────────── */
.afina-mob-card {
  display: flex !important;
  flex-direction: column !important;
  background: #ffffff !important;
  border: 1.5px solid #e5e8ee !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  text-decoration: none !important;
  color: #111111 !important;
  transition: border-color .15s, box-shadow .15s !important;
  position: relative !important;
  -webkit-tap-highlight-color: transparent !important;
}
.afina-mob-card:active {
  border-color: #2E508A !important;
  box-shadow: 0 2px 12px rgba(46,80,138,.15) !important;
}

/* Imagen */
.afina-mob-card__img {
  width: 100% !important;
  aspect-ratio: 1 / 0.9 !important;
  background: #f4f5f7 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
  position: relative !important;
}
.afina-mob-card__img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 8px !important;
  display: block !important;
}

/* Badges */
.afina-mob-card__badge-oos {
  position: absolute !important;
  top: 6px !important;
  left: 6px !important;
  background: #e53e3e !important;
  color: #ffffff !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  padding: 2px 6px !important;
  border-radius: 3px !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  z-index: 2 !important;
}
.afina-mob-card__badge-ai {
  position: absolute !important;
  top: 6px !important;
  right: 6px !important;
  background: #2E508A !important;
  color: #FFD931 !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  padding: 2px 7px !important;
  border-radius: 10px !important;
  letter-spacing: .06em !important;
  z-index: 2 !important;
}
.afina-mob-card__badge-sale {
  position: absolute !important;
  top: 6px !important;
  right: 6px !important;
  background: #FFD931 !important;
  color: #111111 !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  padding: 2px 6px !important;
  border-radius: 3px !important;
  z-index: 2 !important;
}

/* Cuerpo de la tarjeta */
.afina-mob-card__body {
  padding: 8px 10px 10px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  flex: 1 !important;
}
.afina-mob-card__cat {
  font-size: 9.5px !important;
  font-weight: 700 !important;
  letter-spacing: .09em !important;
  text-transform: uppercase !important;
  color: #2E508A !important;
  opacity: .8 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  margin: 0 !important;
}
.afina-mob-card__name {
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
  color: #111111 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  margin: 0 !important;
}
.afina-mob-card__name mark {
  background: #FFD931 !important;
  color: #111 !important;
  border-radius: 2px !important;
  padding: 0 1px !important;
}
.afina-mob-card__sku {
  font-size: 9px !important;
  color: #999 !important;
  font-family: monospace !important;
  letter-spacing: .04em !important;
  margin: 0 !important;
}
.afina-mob-card__price {
  font-size: 13.5px !important;
  font-weight: 800 !important;
  color: #2E508A !important;
  margin-top: 4px !important;
}
.afina-mob-card__price del {
  font-size: 11px !important;
  font-weight: 400 !important;
  color: #aaa !important;
  margin-right: 4px !important;
  text-decoration: line-through !important;
}
.afina-mob-card__price ins {
  text-decoration: none !important;
  color: #c0392b !important;
}

/* ── Sección IA ────────────────────────────────────────────── */
.afina-mob__ai-section {
  display: none !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin-top: 22px !important;
  padding-top: 18px !important;
  border-top: 2px dashed #e5e8ee !important;
  width: 100% !important;
}
.afina-mob__ai-section.afina-mob--visible {
  display: flex !important;
}

.afina-mob__ai-header {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.afina-mob__ai-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  background: #2E508A !important;
  color: #FFD931 !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  padding: 3px 9px !important;
  border-radius: 20px !important;
  letter-spacing: .08em !important;
}
.afina-mob__ai-title {
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: #686868 !important;
}

/* Banner IA competidor */
.afina-mob__competitor-banner {
  display: none !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  background: linear-gradient(135deg, #1e3d70, #2E508A) !important;
  border-radius: 6px !important;
  color: #ffffff !important;
  margin-bottom: 4px !important;
  border-left: 4px solid #FFD931 !important;
}
.afina-mob__competitor-banner.afina-mob--visible {
  display: flex !important;
}
.afina-mob__competitor-banner p {
  font-size: 12.5px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  color: #ffffff !important;
}

/* ── Botón "Ver todos" sticky al fondo ─────────────────────── */
.afina-mob__footer {
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  display: none !important;
  padding: 12px 14px !important;
  background: linear-gradient(to top, #ffffff 70%, rgba(255,255,255,0)) !important;
  z-index: 10 !important;
}
.afina-mob__footer.afina-mob--visible {
  display: block !important;
}
.afina-mob__view-all {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  width: 100% !important;
  background: #2E508A !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 6px !important;
  border-bottom: 3px solid rgba(0,0,0,.2) !important;
  padding: 13px 20px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  cursor: pointer !important;
  -webkit-tap-highlight-color: transparent !important;
  touch-action: manipulation !important;
  box-shadow: 0 -4px 20px rgba(46,80,138,.2) !important;
}
.afina-mob__view-all:active {
  background: #1e3d70 !important;
  transform: translateY(1px) !important;
}

/* ── Safe area (iPhone notch / home indicator) ─────────────── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .afina-mob__footer {
    padding-bottom: calc(12px + env(safe-area-inset-bottom)) !important;
  }
  .afina-mob__body {
    padding-bottom: calc(80px + env(safe-area-inset-bottom)) !important;
  }
}

/* ── Solo mostramos el overlay mobile en pantallas ≤768px ───── */
/* El overlay desktop se oculta en ≤768px */
@media (max-width: 768px) {
  /* Ocultar overlay desktop */
  #afina-search-overlay {
    display: none !important;
  }
}

/* ── El overlay mobile NO se muestra en desktop ─────────────── */
@media (min-width: 769px) {
  #afina-mobile-overlay {
    display: none !important;
  }
}
