/* ========================================================================
   Tutokupisz – Search Dropdown (2025/26)
   Desktop bez zmian • Mobile: GRID 2 kol. + extra-compact + większe CTA
   IMG 1:1 → Tytuł → Cena (glow) → CTA
   ======================================================================== */

/* ====== Pasek wyszukiwania (desktop i ogólne) ========================== */
.search-form{
  position:relative; display:grid; grid-template-columns:1fr auto; gap:8px;
  background:#fff; border:1px solid #dbe6ff; border-radius:999px;
  padding:10px 12px 10px 14px; box-shadow:0 1px 2px rgba(15,23,42,.05);
  transition: box-shadow .18s ease, border-color .18s ease;
  z-index: 5001; /* kotwica ponad tłem headera */
}
.search-form:focus-within{
  border-color: color-mix(in oklab, #2f6df6 45%, #fff);
  box-shadow: 0 2px 8px rgba(15,23,42,.08);
}
.search-field{ border:0; background:transparent; outline:0; font-size:16px; line-height:1.5; min-width:0; }
.search-submit-icon{ display:inline-grid; place-items:center; width:36px; height:36px; border:0; background:transparent; border-radius:50%; }

/* ===== Design tokens ==================================================== */
:root{
  --ink:#0f172a; --ink-muted:#5b6b85; --accent:#2f6df6;
  --surface:#fff; --border-soft:#e5e8f1;
  --border: color-mix(in oklab, var(--ink) 12%, #fff);

  /* rytm – desktop */
  --gap-edge: 10px;      /* = IMG→Tytuł = dolny margines karty */
  --gap-title-price: 4px;
  --gap-price-cta: 10px;

  --pad-x:12px; --card-radius:12px;

  /* CTA */
  --btn-h:30px; --btn-radius:9px; --btn-pad-x:12px; --btn-icon:16px;

  /* stany */
  --promo:#ef4444; --new:#2f6df6;

  /* glow ceny */
  --glow-neutral: rgba(15,23,42,.14);
  --glow-promo:   rgba(239,68,68,.26);

  /* elevacje */
  --elev-0: 0 1px 2px rgba(15,23,42,.06);
  --elev-1: 0 3px 12px rgba(15,23,42,.10);
  --elev-2: 0 10px 24px rgba(15,23,42,.12);
}

/* ===== Dropdown (ogólne – fallback w headerze) ========================== */
.tuto-search-suggest{
  position:absolute; left:0; right:0; top:calc(100% + 8px);
  background:var(--surface);
  border:1px solid var(--border-soft);
  border-radius:14px;
  box-shadow:0 12px 28px rgba(15,23,42,.12), 0 3px 6px rgba(15,23,42,.06);
  overflow:hidden; z-index:60;
}
.tuto-search-suggest[hidden]{ display:none !important; }
@media (prefers-reduced-motion:no-preference){
  .tuto-search-suggest{ animation:tutoSearchIn .18s ease both; }
  @keyframes tutoSearchIn{ from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:translateY(0)} }
}

/* ======= TRYB PORTALU (nad sticky catbarem) ============================ */
.tuto-search-suggest.is-portal{
  position: fixed !important;
  /* pozycję i szerokość ustawia JS (placeLayer) */
  left: 0; top: 0; width: auto;
  max-height: min(70vh, 720px);
  overflow: auto;
  z-index: 9002; /* > catbar i jego dropdowny */
  box-sizing: border-box;
}
.site-header .tuto-search-suggest.is-portal{
  position: fixed !important; /* wygasza stare 'absolute' gdy portal aktywny */
}

/* ===== Lista – DOMYŚLNIE multi-column (desktop) ========================= */
.tuto-search-suggest__list{
  --gap:12px; --col-gap:18px;
  --col-divider: color-mix(in oklab, var(--ink) 9%, #fff);
  padding:10px; max-height:min(60vh,560px); overflow:auto; -webkit-overflow-scrolling:touch;
  scrollbar-width:thin; scrollbar-color: color-mix(in oklab, var(--ink) 35%, #fff) transparent;
  columns:1; column-gap:var(--col-gap); column-rule:1px solid var(--col-divider);
}
@media (min-width:768px){ .tuto-search-suggest__list{ columns:2; } }
@media (min-width:1280px){ .tuto-search-suggest__list{ columns:3; } }
.tuto-search-suggest__list::-webkit-scrollbar{ width:10px; height:10px; }
.tuto-search-suggest__list::-webkit-scrollbar-thumb{ background: color-mix(in oklab, var(--ink) 18%, #fff); border-radius:999px; }
.tuto-search-suggest__row{ break-inside:avoid; margin:0 0 var(--gap); }

/* ===== Karta ============================================================ */
.tuto-search-card{
  position:relative;
  display:flex; flex-direction:column; align-items:center;
  background:#fff; border:1px solid var(--border); border-radius:var(--card-radius);
  box-shadow: var(--elev-0);
  overflow:hidden; transition: transform .12s, box-shadow .15s, border-color .15s;
  padding: 0 0 var(--gap-edge) 0; /* dół = góra od zdjęcia */
}
.tuto-search-card:hover{ transform:translateY(-1px); box-shadow:var(--elev-1); border-color: color-mix(in oklab, var(--accent) 28%, #fff); }
.tuto-search-card:focus-within{ box-shadow:var(--elev-2); outline:3px solid color-mix(in oklab, var(--accent) 45%, #fff); outline-offset:2px; }
.tuto-search-card__link{ position:absolute; inset:0; z-index:0; }

/* ===== IMG 1:1 + gradient top ========================================== */
.tuto-search-card__thumb{
  position:relative; display:block;
  aspect-ratio:1/1; width:100%; height:auto; object-fit:cover; background:#f3f4f7;
  border-bottom:1px solid color-mix(in oklab, var(--ink) 7%, #fff);
}
@media (hover:hover){
  .tuto-search-card__thumb{ transition: transform .28s ease; }
  .tuto-search-card:hover .tuto-search-card__thumb{ transform: scale(1.02); }
}
.tuto-search-card__thumb::after{
  content:""; position:absolute; inset:0 0 auto 0; height:64px; pointer-events:none;
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,0));
  border-top-left-radius: inherit; border-top-right-radius: inherit;
  opacity:.0; transition: opacity .25s ease;
}
@media (hover:hover){
  .tuto-search-card:hover .tuto-search-card__thumb::after{ opacity:.8; }
}

/* ===== Badge ============================================================ */
.tuto-search-suggest__badge{
  position:absolute; left:10px; top:10px; z-index:2;
  font-size:11px; line-height:1.8; padding:2px 8px; border-radius:999px; white-space:nowrap;
  color:#fff; box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
  border:1px solid rgba(255,255,255,.35);
}
.tuto-search-suggest__badge.is-sale{ background: linear-gradient(180deg, #f87171, #ef4444); }
.tuto-search-suggest__badge.is-new{  background: linear-gradient(180deg, #66a3ff, #2f6df6); }

/* ===== Tytuł ============================================================ */
.tuto-search-card__title{
  margin:0; padding: var(--gap-edge) var(--pad-x) 0 var(--pad-x);
  color:var(--ink); font-weight:700; font-size:14px; line-height:1.28;
  text-align:center;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; text-overflow:ellipsis;
}
.tuto-search-card__title mark{ background:none; color: color-mix(in oklab, var(--accent) 70%, #000); font-weight:800; }

/* ===== Cena (glow) ====================================================== */
.tuto-search-card__price{
  position:relative; margin: var(--gap-title-price) 0 0 0;
  display:inline-flex; align-items:baseline; gap:8px;
  font-size:14px; font-weight:700; color:var(--ink); white-space:nowrap;
  padding: 0 2px;
}
.tuto-search-card__price::before{
  content:""; position:absolute; inset:-2px -8px; border-radius:999px; pointer-events:none; z-index:-1;
  background: var(--glow-neutral); filter: blur(8px); opacity:.5;
}
.tuto-search-card__price:has(s)::before,
.tuto-search-card:has(.is-sale) .tuto-search-card__price::before{ background: var(--glow-promo); opacity:.58; }
.tuto-search-card__price s{
  color: var(--promo) !important; text-decoration-color: var(--promo) !important;
  opacity:1 !important; font-weight:600;
}
.tuto-search-card__price:has(s) ins,
.tuto-search-card__price:has(s) b,
.tuto-search-card__price:has(s) strong{ color: var(--promo); text-decoration:none; font-weight:800; }

.tuto-search-card__price:has(s)::after{
  content: " % Promocja";
  margin-left: 8px;
  font: 700 11px/1.8 Inter, system-ui, Segoe UI, Roboto, sans-serif;
  padding: 2px 8px; border-radius: 999px;
  color: #fff; background: #ef4444;
}

/* ===== CTA =============================================================== */
.tuto-search-card__actions{
  margin-top: var(--gap-price-cta);
  padding: 0 var(--pad-x);
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.tuto-search__btn{
  height:var(--btn-h); padding:0 var(--btn-pad-x);
  border-radius:var(--btn-radius);
  display:inline-flex; align-items:center; gap:8px;
  font:700 12px/1 Inter, system-ui, Segoe UI, Roboto, sans-serif;
  cursor:pointer; position:relative; z-index:3;
  transition: background-color .12s, border-color .12s, transform .1s, box-shadow .12s, color .12s, filter .12s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.tuto-search__btn .icon{ width:var(--btn-icon); height:var(--btn-icon); display:inline-block; }
.tuto-search__btn.add-cart{
  background:var(--accent); color:#fff;
  border:1px solid color-mix(in oklab, var(--accent) 60%, #fff);
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.25);
}
.tuto-search__btn.add-cart .icon{ filter: invert(1) brightness(1.1); }
.tuto-search__btn.add-cart:hover{ background: color-mix(in oklab, var(--accent) 86%, #000); }
.tuto-search__btn.add-wish{
  background:#fff; color:var(--promo);
  border:1px solid color-mix(in oklab, var(--promo) 60%, #fff);
  box-shadow: 0 1px 2px rgba(239,68,68,.15);
}
.tuto-search__btn.add-wish .icon{
  filter: invert(16%) sepia(94%) saturate(6350%) hue-rotate(-6deg) brightness(0.98) contrast(1.05);
}
.tuto-search__btn.add-wish:hover{
  background: color-mix(in oklab, var(--promo) 10%, #fff);
  border-color: color-mix(in oklab, var(--promo) 70%, #fff);
}
.tuto-search__btn:active{ transform: translateY(1px) scale(.995); }
.tuto-search__btn.ok{ box-shadow: inset 0 0 0 2px color-mix(in oklab, var(--accent) 55%, #fff); }

/* ===== Empty & footer ==================================================== */
.tuto-search-suggest__empty{ padding:14px; color:var(--ink-muted); font-size:14px; text-align:center; }
.tuto-search-suggest__footer{
  position:sticky; bottom:0; display:flex; gap:8px; align-items:center; justify-content:space-between;
  padding:8px 10px; background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.96) 30%, #fff 100%);
  border-top:1px solid var(--border-soft);
}
.tuto-search-suggest__footer[hidden]{ display:none !important; }
.tuto-search-suggest__footer-btn{
  display:inline-flex; align-items:center; gap:8px; padding:9px 12px; border-radius:9px; cursor:pointer; text-decoration:none;
  border:1px solid var(--border-soft); background:#fff; color:var(--ink);
  font:700 12.5px/1 Inter, system-ui, Segoe UI, Roboto, sans-serif;
  transition: background-color .12s, border-color .12s, transform .1s, box-shadow .12s;
}
.tuto-search-suggest__footer-btn.footer-btn--all{
  background:var(--new); color:#fff;
  border-color: color-mix(in oklab, var(--new) 60%, #fff);
}
.tuto-search-suggest__footer-btn:active{ transform:translateY(1px); }

/* =========================================================================
   MOBILE ≤640px — GRID 2 kolumny + extra-compact + WIĘKSZE CTA
   =======================================================================*/
@media (max-width:640px){

  .tuto-search-suggest__list{
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    padding: 6px;
    max-height: min(60vh, 300px);
    column-gap: initial; column-rule: initial; columns: initial;
  }

  .tuto-search-suggest{
    top: calc(100% + 4px);
    border-radius: 10px;
    box-shadow: 0 8px 18px rgba(15,23,42,.12), 0 2px 4px rgba(15,23,42,.06);
  }

  :root{
    --gap-edge: 3.4px;
    --gap-title-price: 1.4px;
    --gap-price-cta: 4px;

    --pad-x: 4px;
    --card-radius: 4px;

    --btn-h: 36px;
    --btn-pad-x: 10px;
    --btn-radius: 8px;
    --btn-icon: 14px;
  }

  .tuto-search-card{
    box-shadow: 0 1px 2px rgba(15,23,42,.06);
    padding-bottom: var(--gap-edge);
  }

  .tuto-search-card__thumb::after{ height: 22px; }

  .tuto-search-suggest__badge{
    left:4px; top:4px; font-size:8px; line-height:1.45; padding:1px 4px;
  }

  .tuto-search-card__title{ padding: var(--gap-edge) var(--pad-x) 0 var(--pad-x); }

  .tuto-search-card__price{ gap:4px; padding:0 .25px; }
  .tuto-search-card__price::before{ inset:-1px -3px; filter:blur(3.5px); }
  .tuto-search-card__price:has(s)::after{
    margin-left:4px; padding:1px 4px; font-size:9px; line-height:1.5;
  }

  .tuto-search-card__actions{
    gap:8px;
    padding: 0 var(--pad-x);
  }
  .tuto-search__btn{
    line-height:1;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }
}

/* ===== WCAG / systemowe ================================================= */
@media (prefers-reduced-motion:reduce){
  *{ transition:none !important; animation:none !important; }
}
@media (forced-colors: active){
  .tuto-search-card, .tuto-search__btn{ border:1px solid ButtonText; }
  .tuto-search__btn:focus-visible{ outline: 2px solid Highlight !important; outline-offset: 2px; }
}
