/* ── Textti Search v1.0 ─────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Questrial&display=swap');

:root {
  --sn-bg:             #f5f5f7;
  --sn-surface:        #ffffff;
  --sn-border:         #d2d2d7;
  --sn-text:           #1d1d1f;
  --sn-text-secondary: #6e6e73;
  --sn-text-muted:     #86868b;
  --sn-primary:        #2563eb;
  --sn-primary-light:  #eff6ff;
  --sn-primary-hover:  #1d4ed8;
  --sn-accent:         #2563eb;
  --sn-accent-light:   #eff6ff;
  --sn-ai-gradient:    linear-gradient(135deg, #2563eb, #1e40af);
  --sn-sale:           #2563eb;
  --sn-sale-light:     #eff6ff;
  --sn-danger:         #dc4a4a;
  --sn-warning:        #f59e0b;
  --sn-warning-light:  #fffbeb;
  --sn-success:        #23a455;
  --sn-shadow-sm:      0 1px 3px rgba(0,0,0,.06);
  --sn-shadow-md:      0 4px 16px rgba(0,0,0,.10);
  --sn-shadow-xl:      0 20px 64px rgba(0,0,0,.20);
  --sn-radius:         12px;
  --sn-radius-sm:      8px;
  --sn-radius-lg:      16px;
  --sn-font:           'Questrial', system-ui, sans-serif;
}

/* ── Trigger ───────────────────────────────────────────────────────────────── */
.sn-trigger-bar {
  display: flex; align-items: center; gap: 10px;
  background: var(--sn-surface); border: 1.5px solid var(--sn-border);
  border-radius: var(--sn-radius); padding: 12px 18px;
  cursor: pointer; transition: all .2s ease;
  width: 100%;
  box-shadow: var(--sn-shadow-sm); font-family: var(--sn-font);
}
.sn-trigger-bar:hover { border-color: var(--sn-primary); box-shadow: var(--sn-shadow-md); transform: translateY(-1px); }
.sn-trigger-bar svg  { flex-shrink: 0; color: var(--sn-text-muted); }
.sn-trigger-bar span { color: var(--sn-text-muted); font-size: 15px; flex: 1; }
.sn-trigger-bar kbd  {
  font-family: var(--sn-font); font-size: 11px; font-weight: 600;
  background: var(--sn-bg); border: 1px solid var(--sn-border);
  border-radius: 5px; padding: 2px 7px; color: var(--sn-text-muted);
}

/* ── Overlay & Modal ───────────────────────────────────────────────────────── */
.sn-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  z-index: 999999; display: flex; align-items: flex-start; justify-content: center;
  padding-top: min(10vh, 90px); animation: sn-fade-in .15s ease;
}
.sn-overlay--hidden { display: none; }

.sn-modal {
  background: var(--sn-surface); border-radius: var(--sn-radius-lg);
  box-shadow: var(--sn-shadow-xl); width: 95%; max-width: 700px;
  max-height: 82vh; display: flex; flex-direction: column;
  animation: sn-slide-up .2s ease; overflow: hidden;
  font-family: var(--sn-font);
}

/* ── Header ────────────────────────────────────────────────────────────────── */
.sn-search-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 20px; border-bottom: 1px solid var(--sn-border); flex-shrink: 0;
}
.sn-search-header svg { flex-shrink: 0; color: var(--sn-primary); }
.sn-search-input {
  flex: 1; border: none; outline: none; font-size: 16px;
  font-family: var(--sn-font); color: var(--sn-text);
  background: transparent; font-weight: 400;
}
.sn-search-input::placeholder { color: var(--sn-text-muted); }
.sn-clear-btn {
  background: none; border: none; cursor: pointer;
  color: var(--sn-text-muted); font-size: 16px; line-height: 1;
  padding: 2px 6px; border-radius: 50%; display: none;
  transition: background .15s;
}
.sn-clear-btn:hover { background: var(--sn-bg); }
.sn-clear-btn--visible { display: block; }

/* Close modal button */
.sn-close-btn {
  background: none; border: none; cursor: pointer; color: var(--sn-text-muted);
  padding: 8px; border-radius: 50%; display: flex; align-items: center;
  transition: color .15s, background .15s; flex-shrink: 0; min-width: 44px; min-height: 44px;
  justify-content: center;
}
.sn-close-btn:hover { color: var(--sn-text); background: var(--sn-bg); }
.sn-close-btn:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; }

.sn-mic-btn {
  background: none; border: none; cursor: pointer; color: var(--sn-text-muted);
  padding: 8px; border-radius: 50%; display: flex; align-items: center;
  transition: color .15s, background .15s; flex-shrink: 0;
}
.sn-mic-btn--hidden { display: none; }
.sn-mic-btn:hover { color: var(--sn-primary); background: var(--sn-primary-light); }
.sn-mic-btn--active { color: #ef4444 !important; background: #fee2e2 !important; animation: sn-pulse 1s infinite; }
.sn-mic-btn:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; }

/* ── Controls ──────────────────────────────────────────────────────────────── */
.sn-controls {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 16px; border-bottom: 1px solid var(--sn-border);
  flex-shrink: 0; flex-wrap: wrap;
}

.sn-ai-toggle {
  display: flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 700; cursor: pointer;
  padding: 5px 12px; border-radius: 20px; border: none;
  transition: all .2s; letter-spacing: .4px; font-family: var(--sn-font);
  text-transform: uppercase;
}
.sn-ai-toggle--active  { background: var(--sn-ai-gradient); color: #fff; }
.sn-ai-toggle--inactive { background: var(--sn-bg); color: var(--sn-text-muted); border: 1px solid var(--sn-border); }
.sn-ai-dot {
  width: 6px; height: 6px; border-radius: 50%; background: currentColor;
}
.sn-ai-toggle--active .sn-ai-dot { animation: sn-pulse 1.5s ease infinite; }

.sn-filter-btn {
  display: flex; align-items: center; gap: 5px;
  font-size: 12px; font-weight: 500; cursor: pointer;
  padding: 5px 12px; border-radius: 20px;
  background: var(--sn-bg); color: var(--sn-text-secondary);
  border: 1px solid var(--sn-border); transition: all .2s;
  font-family: var(--sn-font);
}
.sn-filter-btn:hover { border-color: var(--sn-primary); color: var(--sn-primary); }
.sn-filter-btn--active { background: var(--sn-primary-light); border-color: var(--sn-primary); color: var(--sn-primary); }
.sn-filter-badge {
  background: var(--sn-primary); color: #fff; font-size: 10px;
  width: 16px; height: 16px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-weight: 700;
}

.sn-sort-wrap {
  position: relative; display: inline-flex; align-items: center; margin-left: auto;
}
.sn-sort-select {
  -webkit-appearance: none; appearance: none;
  font-family: var(--sn-font); font-size: 12px; font-weight: 500;
  color: var(--sn-text-secondary); background: var(--sn-bg);
  border: 1px solid var(--sn-border); border-radius: 20px;
  padding: 5px 28px 5px 12px; cursor: pointer;
  transition: border-color .2s, color .2s; line-height: 1.5;
}
.sn-sort-select:hover { border-color: var(--sn-primary); color: var(--sn-primary); }
.sn-sort-wrap::after {
  content: ''; position: absolute; right: 11px; top: 50%;
  width: 6px; height: 6px; pointer-events: none;
  border-right: 1.5px solid var(--sn-text-muted);
  border-bottom: 1.5px solid var(--sn-text-muted);
  transform: translateY(-65%) rotate(45deg);
}

.sn-text-btn {
  background: none; border: none; cursor: pointer;
  font-size: 12px; font-weight: 500; color: var(--sn-text-muted);
  font-family: var(--sn-font); padding: 5px 8px; border-radius: 6px;
  transition: all .15s;
}
.sn-text-btn:hover { color: var(--sn-primary); background: var(--sn-primary-light); }
.sn-text-btn--muted { font-size: 11px; }

/* ── Filters panel ─────────────────────────────────────────────────────────── */
.sn-filters-panel {
  padding: 12px 20px; border-bottom: 1px solid var(--sn-border);
  background: var(--sn-bg); display: none; animation: sn-fade-in .15s;
  flex-shrink: 0;
}
.sn-filters-panel--visible { display: block; }
.sn-filter-section  { margin-bottom: 10px; }
.sn-filter-section:last-child { margin-bottom: 0; }
.sn-filter-label {
  font-size: 10px; font-weight: 700; color: var(--sn-text-muted);
  text-transform: uppercase; letter-spacing: .9px; margin-bottom: 6px;
}
.sn-filter-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.sn-chip {
  font-size: 12px; padding: 4px 12px; border-radius: 20px;
  border: 1px solid var(--sn-border); cursor: pointer;
  background: var(--sn-surface); color: var(--sn-text-secondary);
  transition: all .15s; font-family: var(--sn-font);
}
.sn-chip:hover  { border-color: var(--sn-primary); color: var(--sn-primary); }
.sn-chip--active { background: var(--sn-primary); color: #fff; border-color: var(--sn-primary); }
.sn-clear-filters-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; color: var(--sn-danger); cursor: pointer;
  background: none; border: none; font-weight: 500; margin-top: 8px;
  font-family: var(--sn-font);
}

/* ── Results area ──────────────────────────────────────────────────────────── */
.sn-results {
  flex: 1; overflow-y: auto; padding: 6px 10px;
  scrollbar-width: thin; scrollbar-color: var(--sn-border) transparent;
}

/* ── AI response ───────────────────────────────────────────────────────────── */
.sn-ai-response {
  margin: 8px 6px 4px; padding: 10px 14px;
  background: linear-gradient(135deg,#eff6ff,#f0f7ff);
  border-radius: var(--sn-radius); border-left: 3px solid var(--sn-accent);
  animation: sn-fade-in .3s; font-size: 13px; color: var(--sn-text);
  line-height: 1.5; display: flex; align-items: flex-start; gap: 8px;
  word-break: break-word; overflow-wrap: break-word;
}
.sn-ai-icon { flex-shrink: 0; font-size: 14px; }

.sn-count { font-size: 11px; color: var(--sn-text-muted); padding: 4px 16px 2px; }

/* ── Result item ───────────────────────────────────────────────────────────── */
.sn-result-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; margin: 1px 0; border-radius: var(--sn-radius-sm);
  cursor: pointer; transition: all .15s; border: 1px solid transparent;
  outline: none;
}
.sn-result-item:hover,
.sn-result-item--focused {
  background: var(--sn-primary-light); border-color: var(--sn-border);
}
.sn-result-item--focused { box-shadow: 0 0 0 2px var(--sn-primary); }

/* Thumbnail */
.sn-result-thumb {
  position: relative; flex-shrink: 0; width: 52px; height: 52px;
}
.sn-result-img {
  width: 52px; height: 52px; border-radius: var(--sn-radius-sm);
  object-fit: contain; background: var(--sn-bg); border: 1px solid var(--sn-border);
}
.sn-result-img-ph {
  width: 52px; height: 52px; border-radius: var(--sn-radius-sm);
  background: var(--sn-bg); border: 1px solid var(--sn-border);
  display: flex; align-items: center; justify-content: center; font-size: 22px;
}

/* Discount badge on image */
.sn-discount-badge {
  position: absolute; bottom: -4px; right: -4px;
  background: var(--sn-text); color: #fff;
  font-size: 9px; font-weight: 700; padding: 2px 5px;
  border-radius: 4px; line-height: 1.4; letter-spacing: .2px;
  pointer-events: none;
}
/* Mini product — larger badge */
.sn-mini-img-wrap .sn-discount-badge {
  font-size: 12px; padding: 4px 9px; border-radius: 6px;
  bottom: -6px; right: -6px;
}

/* Pin badge */
.sn-pin-badge {
  position: absolute; top: -5px; left: -5px;
  font-size: 10px; line-height: 1; pointer-events: none;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.2));
}

/* Info */
.sn-result-info { flex: 1; min-width: 0; }
.sn-result-name {
  font-size: 13.5px; font-weight: 500; color: var(--sn-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  line-height: 1.3;
}
.sn-result-meta {
  display: flex; align-items: center; gap: 6px; margin-top: 2px;
  font-size: 11.5px; color: var(--sn-text-muted);
}
.sn-result-specs {
  font-size: 11px; color: var(--sn-text-muted); margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sn-result-brand {
  font-weight: 600; color: var(--sn-primary); text-decoration: none;
}
.sn-result-brand:hover { text-decoration: underline; }
.sn-result-sep  { color: var(--sn-border); }
.sn-result-cat  { color: var(--sn-text-muted); }

.sn-result-extras {
  display: flex; align-items: center; gap: 8px; margin-top: 3px;
}

/* Rating */
.sn-rating {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px; font-weight: 600; color: var(--sn-warning);
}
.sn-rating svg { flex-shrink: 0; }
.sn-rating em  { font-style: normal; font-weight: 400; color: var(--sn-text-muted); }

/* Stock badges */
.sn-stock { font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 10px; letter-spacing: .2px; }
.sn-stock--out      { color: var(--sn-danger); background: #fef2f2; }
.sn-stock--critical { color: #c2410c; background: #fff7ed; animation: sn-pulse 2s ease infinite; }
.sn-stock--low      { color: var(--sn-warning); background: var(--sn-warning-light); }

/* Right side: price + cart */
.sn-result-right {
  display: flex; flex-direction: column; align-items: flex-end;
  gap: 6px; flex-shrink: 0;
}
.sn-result-price { text-align: right; line-height: 1.2; }
.sn-price-current { font-size: 14px; font-weight: 700; color: var(--sn-text); }
.sn-price-regular { font-size: 11px; color: var(--sn-text-muted); text-decoration: line-through; display: block; }
.sn-price-sale    { font-size: 14px; font-weight: 700; color: var(--sn-text); }
.sn-price-badge   {
  display: inline-block; background: var(--sn-text); color: #fff;
  font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 4px;
  letter-spacing: .3px;
}

/* Cart button */
.sn-cart-btn {
  width: 30px; height: 30px; border-radius: 8px; border: none; cursor: pointer;
  background: var(--sn-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s; flex-shrink: 0;
}
.sn-cart-btn:hover    { background: var(--sn-primary-hover); transform: scale(1.08); }
.sn-cart-btn:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.sn-cart-btn--added   { background: var(--sn-success); }
.sn-cart-btn--error   { background: var(--sn-danger); }
.sn-spinner-sm {
  width: 12px; height: 12px; border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff; border-radius: 50%; animation: sn-spin .6s linear infinite;
}

/* ── Cart notification ──────────────────────────────────────────────────────── */
.sn-cart-notif {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 0 20px; max-height: 0; overflow: hidden;
  border-top: 0 solid transparent;
  transition: max-height .3s ease, padding .3s ease, border .3s ease;
  background: var(--sn-primary-light); font-size: 13px; color: var(--sn-text);
  flex-shrink: 0;
}
.sn-cart-notif--visible {
  max-height: 60px; padding: 10px 20px;
  border-top: 1px solid var(--sn-border);
}
.sn-cart-notif svg  { color: var(--sn-success); flex-shrink: 0; }
.sn-cart-notif span { display: flex; align-items: center; gap: 6px; flex: 1; }
.sn-notif-link {
  font-size: 12px; font-weight: 600; color: var(--sn-primary); text-decoration: none;
  white-space: nowrap;
}
.sn-notif-link:hover { text-decoration: underline; }
.sn-notif-cta {
  background: var(--sn-primary); color: #fff;
  font-size: 12px; font-weight: 600; padding: 5px 14px; border-radius: 20px;
  text-decoration: none; white-space: nowrap; transition: background .2s;
}
.sn-notif-cta:hover { background: var(--sn-primary-hover); }

/* ── Empty / Loading ────────────────────────────────────────────────────────── */
.sn-empty {
  display: flex; flex-direction: column; align-items: center;
  padding: 40px 20px; color: var(--sn-text-muted);
}
.sn-empty svg     { margin-bottom: 12px; opacity: .4; }
.sn-empty p       { font-size: 14px; text-align: center; }
.sn-empty-hint    { font-size: 12px; margin-top: 4px; }

/* ── Zero results ────────────────────────────────────────────────────────── */
.sn-zero-results {
  display: flex; flex-direction: column; align-items: center;
  padding: 32px 20px; text-align: center; gap: 12px;
}
.sn-zero-icon { font-size: 36px; }
.sn-zero-title { font-size: 15px; color: var(--sn-text); margin: 0; }
.sn-zero-hint { font-size: 13px; color: var(--sn-text-muted); margin: 0; }
.sn-zero-ai-btn {
  background: var(--sn-primary); color: #fff;
  border: none; border-radius: var(--sn-radius);
  font-size: 14px; font-weight: 600; padding: 10px 22px;
  cursor: pointer; font-family: var(--sn-font); transition: background .15s;
}
.sn-zero-ai-btn:hover { background: var(--sn-primary-hover); }
.sn-zero-ai-btn:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; }
.sn-zero-suggestions { width: 100%; }

.sn-loading {
  display: flex; align-items: center; justify-content: center;
  padding: 36px; gap: 10px; color: var(--sn-text-muted); font-size: 13px;
}
.sn-spinner {
  width: 20px; height: 20px; border: 2px solid var(--sn-border);
  border-top-color: var(--sn-primary); border-radius: 50%;
  animation: sn-spin .6s linear infinite; flex-shrink: 0;
}

/* ── Autocomplete ───────────────────────────────────────────────────────────── */
.sn-autocomplete { padding: 12px 10px 4px; }
.sn-ac-label {
  font-size: 10px; font-weight: 700; color: var(--sn-text-muted);
  text-transform: uppercase; letter-spacing: .8px; margin-bottom: 8px;
}
.sn-ac-chips { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.sn-ac-chip {
  font-size: 12px; padding: 5px 14px; border-radius: 20px;
  border: 1px solid var(--sn-border); cursor: pointer;
  background: var(--sn-surface); color: var(--sn-text-secondary);
  transition: all .15s; font-family: var(--sn-font);
  display: flex; align-items: center; gap: 5px;
}
.sn-ac-chip:hover { background: var(--sn-primary-light); border-color: var(--sn-primary); color: var(--sn-primary); }
.sn-ac-loading {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--sn-text-muted); padding: 4px 2px 8px;
}
.sn-ac-loading .sn-spinner { width: 14px; height: 14px; }

/* ── Discovery / Empty state ────────────────────────────────────────────────── */
.sn-discover-section { padding: 14px 10px 6px; }
.sn-discover-header  {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11px; font-weight: 700; color: var(--sn-text-muted);
  text-transform: uppercase; letter-spacing: .8px; margin-bottom: 10px;
}
.sn-discover-header span { display: flex; align-items: center; gap: 5px; }
.sn-discover-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.sn-recent-chip {
  font-size: 13px; padding: 6px 14px; border-radius: 20px;
  border: 1px solid var(--sn-border); cursor: pointer;
  background: var(--sn-surface); color: var(--sn-text-secondary);
  transition: all .15s; font-family: var(--sn-font);
}
.sn-recent-chip:hover { background: var(--sn-primary-light); border-color: var(--sn-primary); color: var(--sn-primary); }

.sn-trending-chip {
  font-size: 13px; padding: 6px 14px; border-radius: 20px;
  border: 1px solid var(--sn-border); cursor: pointer;
  background: var(--sn-surface); color: var(--sn-text-secondary);
  transition: all .15s; font-family: var(--sn-font);
}
.sn-trending-chip:hover { background: var(--sn-primary-light); border-color: var(--sn-primary); color: var(--sn-primary); }

/* Objectives grid */
.sn-objectives-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 8px;
}
.sn-obj-chip {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px; padding: 12px 8px; border-radius: var(--sn-radius);
  border: 1.5px solid var(--sn-border); cursor: pointer;
  background: var(--sn-surface); transition: all .2s;
  font-family: var(--sn-font);
}
.sn-obj-chip:hover {
  border-color: var(--sn-primary); background: var(--sn-primary-light);
  transform: translateY(-2px); box-shadow: var(--sn-shadow-sm);
}
.sn-obj-icon  { font-size: 22px; line-height: 1; }
.sn-obj-label { font-size: 11.5px; font-weight: 600; color: var(--sn-text); text-align: center; }

/* ── Vistos recientemente ───────────────────────────────────────────────── */
.sn-rv-list {
  display: flex; gap: 10px; overflow-x: auto; padding-bottom: 4px;
  scrollbar-width: none;
}
.sn-rv-list::-webkit-scrollbar { display: none; }
.sn-rv-item {
  display: flex; flex-direction: column; align-items: center;
  text-decoration: none; color: inherit; flex-shrink: 0;
  width: 88px; transition: transform .15s;
}
.sn-rv-item:hover { transform: translateY(-2px); }
.sn-rv-item:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; border-radius: 8px; }
.sn-rv-img-wrap {
  position: relative; width: 80px; height: 80px;
  border-radius: var(--sn-radius); border: 1px solid var(--sn-border);
  background: var(--sn-bg); overflow: hidden; margin-bottom: 6px;
}
.sn-rv-img { width: 100%; height: 100%; object-fit: contain; }
.sn-rv-img-ph {
  width: 100%; height: 100%; display: flex;
  align-items: center; justify-content: center; font-size: 28px;
}
.sn-rv-badge {
  position: absolute; bottom: 3px; right: 3px;
  background: var(--sn-text); color: #fff;
  font-size: 9px; font-weight: 700; padding: 2px 5px; border-radius: 4px;
}
.sn-rv-name {
  font-size: 11px; color: var(--sn-text); text-align: center; line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  margin-bottom: 2px; width: 100%;
}
.sn-rv-price {
  font-size: 11px; font-weight: 700; color: var(--sn-text-secondary);
}

/* ── Mini producto ──────────────────────────────────────────────────────────── */
.sn-mini { padding: 12px 16px 16px; display: flex; flex-direction: column; gap: 16px; }
.sn-mini-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500; color: var(--sn-text-muted);
  background: none; border: none; cursor: pointer;
  font-family: var(--sn-font); padding: 4px 0; transition: color .15s;
}
.sn-mini-back:hover { color: var(--sn-primary); }

.sn-mini-body {
  display: flex; gap: 24px; align-items: flex-start;
}
.sn-mini-img-wrap {
  position: relative; flex-shrink: 0;
  width: 140px; display: flex; align-items: center; justify-content: center;
  border-radius: var(--sn-radius); border: 1px solid var(--sn-border);
  background: var(--sn-surface); padding: 12px; transition: opacity .15s;
  text-decoration: none;
}
.sn-mini-img-wrap:hover { opacity: .88; }
.sn-mini-img {
  width: 116px; height: 116px; object-fit: contain;
  display: block;
}
.sn-mini-img-ph {
  width: 116px; height: 116px;
  display: flex; align-items: center; justify-content: center; font-size: 48px;
}
.sn-mini-info { flex: 1; min-width: 0; }
.sn-mini-brand {
  font-size: 11px; font-weight: 700; color: var(--sn-primary);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 5px;
}
.sn-mini-name-link { text-decoration: none; display: block; }
.sn-mini-name-link:hover .sn-mini-name { color: var(--sn-primary); }
.sn-mini-name-link:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; border-radius: 4px; }
.sn-mini-name {
  font-size: 16px; font-weight: 600; color: var(--sn-text);
  line-height: 1.35; margin: 0 0 8px; transition: color .15s;
}
.sn-mini-desc {
  font-size: 13px; color: var(--sn-text-secondary); line-height: 1.5;
  margin: 0 0 10px; display: -webkit-box; -webkit-line-clamp: 3;
  -webkit-box-orient: vertical; overflow: hidden;
}
.sn-mini-rating {
  display: flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 600; color: var(--sn-warning); margin-bottom: 10px;
}
.sn-mini-rating svg { flex-shrink: 0; }

/* Precios (mini) */
.sn-price {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin-bottom: 8px;
}
.sn-price--current { font-size: 18px; font-weight: 700; color: var(--sn-text); }
.sn-price--regular { font-size: 13px; color: var(--sn-text-muted); text-decoration: line-through; }
.sn-price--sale    { font-size: 18px; font-weight: 700; color: var(--sn-text); }
.sn-price--badge   {
  background: var(--sn-text); color: #fff;
  font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px;
}

.sn-mini-stock   { margin-bottom: 8px; }
.sn-mini-tags    { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 4px; }
.sn-mini-tag {
  font-size: 11px; padding: 3px 10px; border-radius: 20px;
  background: var(--sn-primary-light); color: var(--sn-primary); font-weight: 500;
}

/* ── Selector cantidad ───────────────────────────────────────────────────── */
.sn-qty-wrap {
  display: inline-flex; align-items: center; gap: 0;
  border: 1.5px solid var(--sn-border); border-radius: var(--sn-radius);
  overflow: hidden; flex-shrink: 0;
}
.sn-qty-btn {
  background: var(--sn-bg); border: none; cursor: pointer;
  font-size: 18px; font-weight: 400; color: var(--sn-text);
  width: 38px; height: 44px; display: flex; align-items: center; justify-content: center;
  font-family: var(--sn-font); transition: background .15s; line-height: 1;
}
.sn-qty-btn:hover { background: var(--sn-border); }
.sn-qty-btn:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: -2px; }
.sn-qty-val {
  min-width: 32px; text-align: center; font-size: 15px; font-weight: 600;
  color: var(--sn-text); padding: 0 4px;
}

.sn-mini-actions {
  display: flex; flex-direction: row; gap: 8px; align-items: stretch;
  padding-top: 14px; border-top: 1px solid var(--sn-border);
}
.sn-mini-cart-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--sn-primary); color: #fff; flex: 1; min-width: 0;
  border: none; border-radius: var(--sn-radius); cursor: pointer;
  font-size: 14px; font-weight: 600; padding: 13px 12px;
  font-family: var(--sn-font); transition: all .2s;
}
.sn-mini-cart-btn:hover { background: var(--sn-primary-hover); transform: translateY(-1px); }
.sn-mini-cart-btn--added { background: var(--sn-success); }
.sn-mini-cart-btn--error { background: var(--sn-danger); }
.sn-mini-cart-btn--out   { background: var(--sn-bg); color: var(--sn-text-muted); border: 1px solid var(--sn-border); cursor: not-allowed; flex: 1; }
.sn-mini-buy-btn {
  display: flex; align-items: center; justify-content: center; gap: 6px; flex: 1; min-width: 0;
  background: transparent; color: var(--sn-primary);
  border: 1.5px solid var(--sn-primary); border-radius: var(--sn-radius);
  cursor: pointer; font-size: 14px; font-weight: 600; padding: 12px 12px;
  font-family: var(--sn-font); transition: all .2s;
}
.sn-mini-buy-btn:hover { background: var(--sn-primary); color: #fff; transform: translateY(-1px); }
.sn-mini-buy-btn:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; }
.sn-mini-link {
  display: flex; align-items: center; justify-content: center; width: 100%;
  font-size: 14px; font-weight: 500; color: var(--sn-text-secondary);
  border: 1.5px solid var(--sn-border); border-radius: var(--sn-radius);
  padding: 10px 18px; text-decoration: none; transition: all .2s;
  font-family: var(--sn-font); margin-top: 10px;
}
.sn-mini-link:hover { border-color: var(--sn-text-secondary); color: var(--sn-text); }
.sn-mini-link:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; }

/* ── "Did you mean?" suggestions ──────────────────────────────────────────── */
.sn-suggestions { width: 100%; text-align: center; margin-top: 4px; }
.sn-suggestions-label {
  font-size: 13px; color: var(--sn-text-muted); margin: 0 0 8px;
}
.sn-suggestions-chips {
  display: flex; gap: 8px; justify-content: center; flex-wrap: wrap;
}
.sn-suggestion-chip {
  font-size: 13px; padding: 7px 18px; border-radius: 20px;
  border: 1.5px solid var(--sn-primary); cursor: pointer;
  background: var(--sn-primary-light); color: var(--sn-primary);
  font-weight: 600; font-family: var(--sn-font); transition: all .15s;
}
.sn-suggestion-chip:hover {
  background: var(--sn-primary); color: #fff;
}
.sn-suggestion-chip:focus-visible {
  outline: 2px solid var(--sn-primary); outline-offset: 2px;
}

/* ── Footer ────────────────────────────────────────────────────────────────── */
.sn-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 20px; border-top: 1px solid var(--sn-border);
  font-size: 11px; color: var(--sn-text-muted); flex-shrink: 0;
  background: var(--sn-bg);
}
.sn-footer-keys { display: flex; gap: 12px; flex-wrap: wrap; }
.sn-footer-keys span { display: flex; align-items: center; gap: 4px; }
.sn-footer-keys kbd {
  font-family: var(--sn-font); font-size: 10px;
  background: var(--sn-surface); border: 1px solid var(--sn-border);
  border-radius: 4px; padding: 1px 5px; font-weight: 600;
}
.sn-footer-brand { font-weight: 600; }
.sn-footer-right { display: flex; align-items: center; gap: 10px; }

/* ── Accessibility ─────────────────────────────────────────────────────────── */
.sn-sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
/* Focus visible — visible ring for keyboard users, hidden for mouse */
.sn-trigger-bar:focus-visible,
.sn-ai-toggle:focus-visible,
.sn-filter-btn:focus-visible,
.sn-sort-select:focus-visible,
.sn-chip:focus-visible,
.sn-recent-chip:focus-visible,
.sn-obj-chip:focus-visible,
.sn-text-btn:focus-visible,
.sn-clear-btn:focus-visible,
.sn-cart-btn:focus-visible,
.sn-mini-cart-btn:focus-visible,
.sn-mini-back:focus-visible,
.sn-suggestion-chip:focus-visible,
.sn-share-btn:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 2px; }
.sn-result-item:focus-visible { outline: 2px solid var(--sn-primary); outline-offset: 1px; }

/* ── Animations ────────────────────────────────────────────────────────────── */
@keyframes sn-fade-in  { from { opacity: 0 } to { opacity: 1 } }
@keyframes sn-slide-up { from { opacity: 0; transform: translateY(16px) } to { opacity: 1; transform: translateY(0) } }
@keyframes sn-spin     { to { transform: rotate(360deg) } }
@keyframes sn-pulse    { 0%,100% { opacity: 1 } 50% { opacity: .45 } }

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .sn-objectives-grid { grid-template-columns: repeat(3, 1fr); }
  .sn-mini-body { flex-direction: column; gap: 16px; }
  .sn-mini-img-wrap { width: 100%; max-width: 100%; }
  .sn-mini-img, .sn-mini-img-ph { width: 140px; height: 140px; }
  .sn-footer-keys { display: none !important; }
  .sn-trigger-bar kbd { display: none; }
  .sn-trigger-bar span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  /* Touch-friendly targets — min 44px */
  .sn-chip, .sn-ac-chip, .sn-recent-chip, .sn-trending-chip { min-height: 44px; display: inline-flex; align-items: center; border-radius: 8px !important; }
  .sn-close-btn { color: var(--sn-text-muted) !important; }
  .sn-clear-btn { min-width: 44px; min-height: 44px; display: flex; align-items: center; justify-content: center; }
  .sn-cart-btn { width: 44px; height: 44px; }
  .sn-mini-actions { flex-direction: column; }
  .sn-mini-actions .sn-qty-wrap { width: 100%; }
  .sn-mini-actions .sn-qty-wrap .sn-qty-btn { flex: 1; }
  .sn-mini-actions .sn-qty-wrap .sn-qty-val { flex: 1; }
  .sn-qty-btn { min-height: 44px; }
  .sn-mini-cart-btn, .sn-mini-buy-btn { min-height: 48px; }
  .sn-suggestion-chip { min-height: 44px; max-width: 100%; }
  .sn-mini-name { font-size: 14px; }
  .sn-mini-desc { font-size: 12px; }
}

@keyframes sn-sheet-up {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

@media (max-width: 640px) {
  .sn-overlay:not(.sn-overlay--hidden) {
    align-items: stretch;
    padding: 0;
  }
  .sn-modal {
    width: 100% !important;
    max-width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    border-radius: 0 !important;
    margin: 0 !important;
    animation: none !important;
  }
  /* Input font-size >= 16px to prevent iOS zoom */
  .sn-search-input { font-size: 16px !important; }
  /* Show close button on mobile */
  .sn-close-btn { display: flex; }
}
