/* Listing v2 - paleta spójna z PDP v4 */
.s2 {
  --s2-teal: #ACE1D9;
  --s2-teal-dark: #2a8a7e;
  --s2-teal-bg: #f5fbfa;
  --s2-gold: #f5b945;
  --s2-gold-dark: #8B6914;
  --s2-dark: #1e1e1e;
  --s2-muted: #5b626d;
  --s2-border: #eaeaea;
  --s2-border-soft: #f3f4f6;
  --s2-sale: #c0392b;
  max-width: 1456px;
  margin: 0 auto;
  padding: 0 24px 70px;
  color: var(--s2-dark);
}

/* breadcrumbs + nagłówek */
.s2-crumbs { padding: 16px 0; font-size: 12.5px; color: var(--s2-muted); }
.s2-crumbs a:hover { color: var(--s2-dark); text-decoration: underline; }
.s2-crumbs__sep { margin: 0 7px; color: #d1d5db; }
.s2-crumbs__cur { color: var(--s2-dark); font-weight: 600; }
.s2-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; padding: 10px 0 4px; }
.s2-head h1 { font-size: 36px; font-weight: 700; letter-spacing: -1px; margin: 0 0 8px; }
.s2-head p { color: var(--s2-muted); font-size: 14px; line-height: 1.6; max-width: 640px; margin: 0; }
.s2-head__count { font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: var(--s2-teal-dark); font-weight: 700; white-space: nowrap; padding-bottom: 6px; }

/* chipy stanów */
.s2-chips { display: flex; gap: 10px; flex-wrap: wrap; margin: 18px 0 6px; }
.s2-chip { padding: 7px 16px; border: 1.5px solid var(--s2-border); border-radius: 22px; font-size: 12.5px; font-weight: 500; cursor: pointer; background: #fff; transition: all .15s; color: var(--s2-dark); -webkit-text-fill-color: var(--s2-dark); -webkit-appearance: none; appearance: none; }
.s2-chip:hover { border-color: var(--s2-teal-dark); }
.s2-chip--on { background: var(--s2-dark); color: #fff; -webkit-text-fill-color: #fff; border-color: var(--s2-dark); }

/* layout */
.s2-layout { display: grid; grid-template-columns: 300px 1fr; gap: 32px; align-items: start; margin-top: 16px; }

/* kraj dostawy + waluta (widget locale, stabilny - poza swapem AJAX) */
.s2-side { min-width: 0; }
.s2-country { background: #fff; border: 1px solid var(--s2-border); border-radius: 12px; padding: 14px 20px; margin-bottom: 16px; }
.s2-country .country-select-box { margin: 0 !important; display: flex; align-items: center; flex-wrap: wrap; gap: 8px 12px; }
.s2-country .country-select-box > p { margin: 0; font-size: 13.5px; font-weight: 700; }
/* flaga + PLN w jednym rzedzie (Pjax wrapper jest blokiem -> wymuszamy flex) */
.s2-country #nationalization-pjax { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.s2-country #countrySelectDropdown { display: inline-flex; align-items: center; }
/* flaga jako czyste kolko - biala gorna polowa PL gineła na bialym tle, dajemy ramke */
.s2-country .fi { width: 22px; height: 22px; border-radius: 50%; background-size: cover; background-position: center; border: 1px solid rgba(0,0,0,.18); flex: 0 0 auto; }

/* filtry */
.s2-filters { background: #fff; border: 1px solid var(--s2-border); border-radius: 12px; padding: 8px 24px 18px; }
.s2-main { min-width: 0; transition: opacity .15s; }
.s2-main.s2-loading { opacity: .5; pointer-events: none; }
.s2-fgroup { padding: 16px 0; border-bottom: 1px solid var(--s2-border-soft); }
.s2-fgroup:last-of-type { border-bottom: none; }
.s2-fgroup__label { font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 12px; }
.s2-fgroup__sub { font-size: 12px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--s2-muted); margin: 10px 0 6px; }
.s2-frange { display: flex; gap: 8px; align-items: center; }
.s2-frange input { width: 70px; padding: 7px 8px; border: 1px solid var(--s2-border); border-radius: 6px; font-size: 12.5px; }
.s2-frange__unit { font-size: 12px; color: var(--s2-muted); }
.s2-check { font-size: 15px; display: flex; align-items: center; gap: 10px; cursor: pointer; margin: 0 0 11px; font-weight: 400; line-height: 1.35; }
.s2-check input { width: 18px; height: 18px; accent-color: var(--s2-teal-dark); margin: 0; }
.s2-check__count { color: var(--s2-muted); margin-left: auto; font-size: 13px; }
/* opcja bez dopasowan przy biezacych filtrach - widoczna, ale wyszarzona (jak x-kom) */
.s2-check--muted { opacity: .4; }
.s2-check--muted:hover { opacity: .65; }
.s2-clear-btn { background: none; border: none; font-size: 12px; color: var(--s2-muted); text-decoration: underline; cursor: pointer; padding: 12px 0 0; }
/* "Wyczysc" w naglowku drawera (mobile) - pokazywane od razu po zaznaczeniu filtra */
.s2-filters__head-actions { display: flex; align-items: center; gap: 12px; }
.s2-filters__clear { background: none; border: none; color: var(--s2-teal-dark); font-size: 13px; font-weight: 600; text-decoration: underline; cursor: pointer; text-transform: none; letter-spacing: normal; padding: 4px; }
.s2-filters__clear[hidden] { display: none; }
/* przycisk "do gory" */
.s2-totop { position: fixed; right: 16px; bottom: 16px; width: 44px; height: 44px; border-radius: 50%; background: var(--s2-dark); color: #fff; border: none; font-size: 20px; line-height: 1; cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity .2s, transform .2s; z-index: 1030; box-shadow: 0 4px 14px rgba(0,0,0,.25); }
.s2-totop--on { opacity: 1; pointer-events: auto; transform: translateY(0); }
.s2-totop:focus-visible { outline: 2px solid var(--s2-teal-dark); outline-offset: 2px; }
/* gorny pasek sidebara: tytul + Wyczysc wszystkie (desktop) */
.s2-filters__top { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; padding: 6px 0 12px; margin-bottom: 8px; border-bottom: 1px solid var(--s2-border); }
.s2-filters__title { font-size: 15px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; }
.s2-clear-top { background: none; border: none; color: var(--s2-muted); font-size: 13px; cursor: pointer; text-decoration: underline; white-space: nowrap; padding: 0; }
.s2-clear-top:hover { color: var(--s2-teal-dark); }
#s2-clear { display: none; }
/* wyszukiwarka filtrow (znajdz kategorie/wskazanie po nazwie) */
.s2-fsearch { position: relative; margin-bottom: 16px; }
.s2-fsearch__input { width: 100%; padding: 10px 15px; border: 1px solid var(--s2-border); border-radius: 100px; font-size: 13.5px; background: #fff; }
.s2-fsearch__input:focus { outline: none; border-color: var(--s2-teal-dark); }
.s2-fsearch__suggest { display: none; position: absolute; top: calc(100% + 4px); left: 0; right: 0; background: #fff; border: 1px solid var(--s2-border); border-radius: 10px; box-shadow: 0 10px 28px rgba(30,30,30,.14); z-index: 40; max-height: 320px; overflow-y: auto; }
.s2-suggest__item { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; width: 100%; text-align: left; background: none; border: none; border-bottom: 1px solid var(--s2-border-soft); padding: 10px 14px; cursor: pointer; font-size: 13.5px; color: var(--s2-dark); }
.s2-suggest__item:last-child { border-bottom: none; }
.s2-suggest__item:hover, .s2-suggest__item--active { background: var(--s2-teal-bg); }
.s2-suggest__group { font-size: 10.5px; color: var(--s2-muted); text-transform: uppercase; letter-spacing: .5px; white-space: nowrap; }
.s2-suggest__empty { padding: 11px 14px; color: var(--s2-muted); font-size: 13px; }

/* elementy mobilne - na desktopie ukryte */
.s2-filters__head, .s2-filters__foot, .s2-filterbtn, .s2-backdrop { display: none; }

/* sortbar */
.s2-sortbar { display: flex; justify-content: space-between; align-items: center; gap: 14px; flex-wrap: wrap; padding: 0 0 16px; border-bottom: 1px solid var(--s2-border); margin-bottom: 24px; }
.s2-sortbar__res { font-size: 13px; color: var(--s2-muted); }
.s2-sortbar__sort { font-size: 12.5px; color: var(--s2-muted); display: flex; align-items: center; gap: 10px; margin: 0; font-weight: 400; }
.s2-select { padding: 8px 12px; border: 1px solid var(--s2-border); border-radius: 8px; background: #fff; font-size: 13px; }
.s2-sortbar__res { margin-right: auto; }
/* kompaktowa paginacja na gorze (jak x-kom): ‹ [1] z N › */
.s2-toppager { display: flex; align-items: center; gap: 8px; }
.s2-toppager__btn { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border: 1px solid var(--s2-border); border-radius: 8px; background: #fff; cursor: pointer; color: var(--s2-dark); font-size: 16px; line-height: 1; text-decoration: none; }
.s2-toppager__btn:hover { border-color: var(--s2-teal-dark); color: var(--s2-teal-dark); }
.s2-toppager__btn--off { opacity: .35; cursor: default; pointer-events: none; }
.s2-toppager__cur { min-width: 30px; text-align: center; border: 1px solid var(--s2-border); border-radius: 8px; padding: 5px 10px; font-weight: 700; font-size: 13px; }
.s2-toppager__total { font-size: 13px; color: var(--s2-muted); white-space: nowrap; }

/* grid */
/* karuzela "Polecane" nad siatka */
.s2-featured { margin-bottom: 28px; }
.s2-featured__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.s2-featured__title { font-size: 19px; font-weight: 700; margin: 0; }
.s2-featured__nav { display: flex; gap: 8px; position: relative; z-index: 60; }
.s2-featured__arrow { width: 38px; height: 38px; border: 1px solid #d1d5db; border-radius: 50%; background: #fff; cursor: pointer; font-size: 19px; line-height: 1; color: var(--s2-dark); display: flex; align-items: center; justify-content: center; box-shadow: 0 1px 4px rgba(30,30,30,.08); transition: all .15s; }
.s2-featured__arrow:hover { border-color: var(--s2-teal-dark); color: var(--s2-teal-dark); box-shadow: 0 3px 8px rgba(42,138,126,.18); }
.s2-featured__track { display: flex; gap: 20px; overflow-x: auto; scroll-behavior: smooth; scroll-snap-type: x mandatory; padding-bottom: 6px; -ms-overflow-style: none; scrollbar-width: none; }
.s2-featured__track::-webkit-scrollbar { display: none; }
.s2-featured__item { flex: 0 0 clamp(180px, 20%, 220px); scroll-snap-align: start; }
@media (max-width: 540px) { .s2-featured__item { flex-basis: 46%; } .s2-featured__track { gap: 10px; } .s2-featured__arrow { width: 32px; height: 32px; font-size: 17px; } }
/* kompaktowa karta polecanego: zdjecie, nazwa, cena, do koszyka */
.s2-fcard { display: flex; flex-direction: column; border: 1px solid var(--s2-border); border-radius: 12px; overflow: hidden; background: #fff; transition: box-shadow .2s; }
.s2-fcard:hover { box-shadow: 0 8px 22px rgba(30,30,30,.08); }
.s2-fcard__img { display: block; aspect-ratio: 1; background: #fafaf8; }
.s2-fcard__img img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.s2-fcard__body { padding: 10px 13px 13px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.s2-fcard__title { font-size: 13.5px; font-weight: 600; line-height: 1.3; margin: 0; min-height: 35px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.s2-fcard__title a { color: inherit; }
.s2-fcard__pline { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; margin-top: auto; }
.s2-fcard__price { font-size: 18px; font-weight: 800; color: var(--s2-teal-dark); }
.s2-fcard__old { font-size: 12.5px; color: var(--s2-muted); text-decoration: line-through; }
.s2-fcard__btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; background: var(--s2-teal-dark); color: #fff; border: none; padding: 11px 6px; border-radius: 100px; font-size: 13px; font-weight: 700; cursor: pointer; transition: background .2s; }
.s2-fcard__btn:hover { background: #1f6e64; color: #fff; }
.s2-fcard__btn .action-content { display: none; }
.s2-fcard__btn.in-action .main-content { display: none; }
.s2-fcard__btn.in-action .action-content { display: inline-flex; align-items: center; gap: 6px; }
.s2-fcard__btn--na { background: #fff; color: var(--s2-muted); border: 1.5px dashed var(--s2-border); cursor: default; }

.s2-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 1100px) { .s2-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 991px) { .s2-grid { grid-template-columns: repeat(2, 1fr); } .s2-layout { grid-template-columns: 1fr; } }
@media (max-width: 540px) { .s2-grid { grid-template-columns: 1fr 1fr; gap: 10px; } }

/* karta */
.s2-card { position: relative; border: 1px solid var(--s2-border); border-radius: 12px; background: #fff; overflow: hidden; display: flex; flex-direction: column; transition: box-shadow .2s, transform .2s; }
.s2-card:hover { box-shadow: 0 10px 30px rgba(30,30,30,.09); transform: translateY(-2px); }
.s2-card__img { position: relative; aspect-ratio: 1; background: #fafaf8; overflow: hidden; }
.s2-card__img-link { display: block; width: 100%; height: 100%; }
.s2-card__photo { width: 100%; height: 100%; object-fit: contain; padding: 14px; transition: transform .25s, opacity .25s; }
.s2-card:hover .s2-card__photo--main { transform: scale(1.045); }
.s2-card__photo--alt { position: absolute; inset: 0; opacity: 0; background: #fff; padding: 0; }
.s2-card:hover .s2-card__photo--alt { opacity: 1; }
.s2-card:hover .s2-card__photo--alt + .s2-card__qv { opacity: 1; }
.s2-card__qv { position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%); background: rgba(30,30,30,.88); color: #fff; padding: 7px 16px; border-radius: 20px; font-size: 10.5px; font-weight: 600; letter-spacing: .8px; text-transform: uppercase; opacity: 0; transition: opacity .2s; white-space: nowrap; z-index: 2; }
.s2-badge { position: absolute; top: 12px; left: 12px; font-size: 9.5px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; padding: 5px 10px; border-radius: 20px; background: var(--s2-dark); color: #fff; z-index: 2; }
.s2-badge--new, .s2-badge--set { background: var(--s2-teal-dark); }
.s2-badge--sale { background: var(--s2-sale); }
.s2-card__wish { position: absolute; top: 10px; right: 10px; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,.95); border: 1px solid var(--s2-border); display: flex; align-items: center; justify-content: center; font-size: 14px; cursor: pointer; z-index: 2; color: #9ca3af; }
.s2-card__wish:hover, .s2-card__wish--active { color: var(--s2-sale); border-color: var(--s2-sale); }

.s2-card__body { padding: 13px 15px 15px; display: flex; flex-direction: column; flex: 1; }
.s2-card__kick { font-size: 11px; letter-spacing: 1px; text-transform: uppercase; font-weight: 700; color: var(--s2-teal-dark); margin-bottom: 6px; display: flex; gap: 6px; flex-wrap: wrap; }
.s2-card__kick-form { color: var(--s2-muted); font-weight: 600; }
.s2-card__kick-form::before { content: '·'; margin-right: 6px; color: #d1d5db; }
.s2-card__rate { display: flex; gap: 6px; align-items: center; font-size: 13px; margin-bottom: 6px; }
.s2-card__rate i { color: var(--s2-gold); font-size: 13px; }
.s2-card__rate a { color: var(--s2-muted); text-decoration: underline; font-size: 12.5px; }
.s2-card__title { font-size: 16px; font-weight: 700; line-height: 1.3; min-height: 42px; margin: 0 0 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.s2-card__title a { color: inherit; }
.s2-card__slogan { font-size: 13px; color: var(--s2-muted); line-height: 1.45; min-height: 37px; margin: 0 0 10px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.s2-card__pricing { margin-top: auto; }
.s2-card__pline { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.s2-card__price { font-size: 21px; font-weight: 800; letter-spacing: -.3px; }
.s2-card__price--sale { color: var(--s2-sale); }
.s2-card__price--club { color: var(--s2-teal-dark); }
.s2-card__price-old { font-size: 13.5px; color: var(--s2-muted); text-decoration: line-through; }
.s2-card__per { font-size: 12px; color: var(--s2-muted); margin-left: auto; }
.s2-card__club-teaser { margin-top: 8px; padding-top: 8px; border-top: 1px dashed var(--s2-teal); font-size: 12.5px; line-height: 1.45; }
.s2-card__club-teaser b { color: var(--s2-gold-dark); }
.s2-card__pts-inline { color: var(--s2-teal-dark); font-weight: 700; }
.s2-card__club-row { display: flex; justify-content: space-between; align-items: center; font-size: 11.5px; margin-bottom: 3px; }
.s2-card__club-label { color: var(--s2-gold-dark); font-weight: 700; letter-spacing: .5px; text-transform: uppercase; font-size: 11px; }
.s2-card__pts { background: var(--s2-teal-bg); color: var(--s2-teal-dark); font-weight: 700; padding: 3px 9px; border-radius: 12px; font-size: 11.5px; }

/* przyciski - wzorzec PDP v4 (pill) */
.s2-card__btns { display: grid; grid-template-columns: 1.12fr 1fr; gap: 6px; margin-top: 11px; }
.s2-btn-more { display: inline-flex; align-items: center; justify-content: center; gap: 5px; background: #fff; color: var(--s2-dark); border: 1.5px solid var(--s2-border); padding: 11px 6px; border-radius: 100px; font-size: 12px; font-weight: 600; cursor: pointer; transition: all .15s; white-space: nowrap; }
.s2-btn-more:hover { border-color: var(--s2-teal-dark); color: var(--s2-teal-dark); }
.s2-btn-more svg { flex-shrink: 0; transition: transform .15s; }
.s2-btn-more:hover svg { transform: translateX(2px); }
.s2-btn-add { display: inline-flex; align-items: center; justify-content: center; gap: 6px; background: var(--s2-teal-dark); color: #fff; border: none; padding: 11px 6px; border-radius: 100px; font-size: 12px; font-weight: 700; cursor: pointer; transition: all .2s; box-shadow: 0 3px 9px rgba(42,138,126,.22); white-space: nowrap; }
.s2-btn-add:hover { background: #1f6e64; color: #fff; transform: translateY(-1px); box-shadow: 0 6px 14px rgba(42,138,126,.32); }
.s2-btn-add .action-content { display: none; }
.s2-btn-add.in-action .main-content { display: none; }
.s2-btn-add.in-action .action-content { display: inline-flex; align-items: center; gap: 6px; }
.s2-btn-na { display: inline-flex; align-items: center; justify-content: center; font-size: 12px; color: var(--s2-muted); border: 1.5px dashed var(--s2-border); border-radius: 100px; padding: 11px 6px; }

/* paginacja + pusty stan */
.s2-pager { margin-top: 40px; display: flex; justify-content: center; }
.s2-pager .pagination { display: flex; gap: 8px; list-style: none; padding: 0; margin: 0; }
.s2-pager .page-link { min-width: 38px; height: 38px; border: 1px solid var(--s2-border); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 500; color: var(--s2-dark); padding: 0 6px; background: #fff; }
.s2-pager .page-link:hover { border-color: var(--s2-teal-dark); }
.s2-pager .active .page-link { background: var(--s2-dark); color: #fff; border-color: var(--s2-dark); }
.s2-empty { text-align: center; padding: 60px 20px; color: var(--s2-muted); }
.s2-empty .s2-clear-btn { margin-top: 10px; font-size: 14px; color: var(--s2-teal-dark); }

/* suwak ceny - dwa uchwyty */
.s2-slider { position: relative; height: 16px; margin: 16px 4px 6px; }
.s2-slider__track { position: absolute; top: 6px; left: 0; right: 0; height: 4px; background: var(--s2-border); border-radius: 2px; }
.s2-slider__fill { position: absolute; top: 6px; height: 4px; background: var(--s2-teal-dark); border-radius: 2px; }
.s2-slider__range { position: absolute; top: 0; left: 0; width: 100%; height: 16px; margin: 0; -webkit-appearance: none; appearance: none; background: none; pointer-events: none; }
.s2-slider__range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; pointer-events: auto; width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 2.5px solid var(--s2-teal-dark); box-shadow: 0 1px 3px rgba(0,0,0,.15); cursor: pointer; }
.s2-slider__range::-moz-range-thumb { pointer-events: auto; width: 12px; height: 12px; border-radius: 50%; background: #fff; border: 2.5px solid var(--s2-teal-dark); box-shadow: 0 1px 3px rgba(0,0,0,.15); cursor: pointer; }
.s2-slider__range::-moz-range-track { background: none; }
.s2-check--sub { padding-left: 26px; font-size: 14px; }


/* ===== MOBILE ===== */
@media (max-width: 991px) {
  .s2 { padding: 0 14px 50px; }
  .s2-head h1 { font-size: 26px; }
  .s2-head__count { display: none; }

  /* chipy: poziomy scroll */
  .s2-chips { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; margin-left: -14px; margin-right: -14px; padding: 0 14px 6px; }
  .s2-chips::-webkit-scrollbar { display: none; }
  .s2-chip { flex: 0 0 auto; white-space: nowrap; }

  /* przycisk Filtry w sortbarze */
  .s2-filterbtn { display: inline-flex; align-items: center; gap: 7px; background: var(--s2-dark); color: #fff; border: none; border-radius: 100px; padding: 9px 16px; font-size: 12.5px; font-weight: 700; cursor: pointer; }
  .s2-filterbtn__n { font-style: normal; background: var(--s2-gold); color: var(--s2-dark); font-size: 10.5px; font-weight: 700; min-width: 17px; height: 17px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; padding: 0 4px; }
  /* sortbar przyklejony POD stalym naglowkiem strony (wysokosc mierzona w JS -> --s2-sticky-top) */
  .s2-sortbar { position: sticky; top: var(--s2-sticky-top, 0px); z-index: 30; background: #fff; padding: 10px 14px; margin: 0 -14px 18px; border-bottom: 1px solid var(--s2-border); }
  .s2-sortbar__res { display: none; }
  .s2-sortbar__sort { margin-left: auto; }
  .s2-select { max-width: 180px; }
  /* na mobile: gorny pager ukryty (paginacja na dole, gdzie user jej szuka po przewinieciu siatki) */
  .s2-toppager { display: none; }
  /* na mobile: karuzela "Polecane"/"Polecane w kategorii" wylaczona (zajmuje ekran, latwo ja pominac) */
  .s2-featured { display: none; }
  /* dolny pager - wyrazniejszy na mobile */
  .s2-pager { margin-top: 28px; }

  /* mniejszy odstep miedzy karta kraju a paskiem filtrow (bylo 48px) */
  .s2-layout { gap: 0; }
  .s2-country { margin-bottom: 12px; }

  /* filtry jako drawer */
  .s2-filters { position: fixed; inset: 0 18% 0 0; max-width: 360px; max-height: none; z-index: 1050; border: none; border-radius: 0; padding: 0 18px; overflow-y: auto; transform: translateX(-105%); transition: transform .25s ease; box-shadow: 4px 0 30px rgba(0,0,0,.18); display: flex; flex-direction: column; }
  .s2-filters__top { display: none; }
  /* dolny "Wyczysc wszystkie filtry" - wiekszy tap-target i odstep (bylo za ciasno do "Pokaz wyniki") */
  #s2-clear { display: block; font-size: 14px; padding: 16px 0; margin: 6px 0; text-align: center; width: 100%; }
  .s2-filters--open { transform: translateX(0); }
  .s2-filters__head { display: flex; justify-content: space-between; align-items: center; position: sticky; top: 0; background: #fff; padding: 16px 0 12px; border-bottom: 1px solid var(--s2-border); font-size: 14px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; z-index: 2; }
  .s2-filters__close { background: none; border: 1px solid var(--s2-border); border-radius: 8px; width: 32px; height: 32px; font-size: 15px; cursor: pointer; }
  .s2-filters__foot { display: block; position: sticky; bottom: 0; background: #fff; padding: 12px 0 16px; border-top: 1px solid var(--s2-border); margin-top: auto; z-index: 2; }
  .s2-apply { width: 100%; background: var(--s2-teal-dark); color: #fff; border: none; border-radius: 100px; padding: 14px; font-size: 14px; font-weight: 700; cursor: pointer; box-shadow: 0 3px 9px rgba(42,138,126,.25); }
  .s2-backdrop { position: fixed; inset: 0; background: rgba(20,20,20,.5); z-index: 1040; opacity: 0; pointer-events: none; transition: opacity .25s; display: block; }
  .s2-backdrop--open { opacity: 1; pointer-events: auto; }
  body.s2-noscroll { overflow: hidden; }

  /* karta: mniejsze fonty, przyciski w pionie */
  .s2-card__body { padding: 11px 12px 13px; }
  .s2-card__title { font-size: 14.5px; min-height: 38px; }
  .s2-card__slogan { font-size: 12px; min-height: 34px; }
  .s2-card__price { font-size: 19px; }
  .s2-card__per { width: 100%; margin-left: 0; }
  .s2-card__btns { grid-template-columns: 1fr; gap: 6px; }
  .s2-btn-more, .s2-btn-add, .s2-btn-na { font-size: 13px; padding: 11px 6px; }
  .s2-card__qv { display: none; }
}

/* telefony: odchudzenie karty (mniej elementow, ciasniejsze odstepy) - tablety zostaja z pelna karta */
@media (max-width: 540px) {
  .s2-card__body { padding: 10px 11px 12px; }
  .s2-card__slogan { display: none; }            /* slogan tylko na tablecie/desktopie */
  .s2-card__kick-form { display: none; }          /* tylko "SUPLEMENT DIETY" - bez lamiacego sie · KAPSULKI · 60 SZT. */
  .s2-card__kick { margin-bottom: 4px; }
  .s2-card__rate { margin-bottom: 4px; }
  .s2-card__title { min-height: 0; margin-bottom: 8px; }
  .s2-card__club-row { margin-bottom: 1px; }
  .s2-card__club-teaser { margin-top: 6px; padding-top: 6px; }
}

@media (max-width: 400px) {
  .s2-grid { gap: 8px; }
  .s2-card__kick { font-size: 10px; }
}
