/* ============================================================
   skinspecialist.cz / bioby.cz — ss-cart-12.css — v12 (PRODUCTION)
   Cart /kosik/ — VARIANTA A.
   v11→v12 (2 mobilní opravy):
     1) krok-indikátor (.cart-header) se na mobilu (≤767) schovával za fixed header —
        Shoptet native main.css ho dělá position:fixed top:0. Fix (konec souboru) ho vrací do toku.
     2) řádek položky (@media ≤900) přestavěn z gridu na flex: foto+název nahoře (název přes
        plnou šířku, ne 7řádkový sloupeček), množství vlevo + cena/× vpravo na 2. řádku.
        (Pozn.: <td> table-cell se v gridu nepřetáhnou přes sloupce → flex; availability musí
        zůstat display:none, NEcílit blanket td:not(.p-total).)
   v11: h1.sr-only "Nákupní košík" skryté (SEO) + step bar border-radius 10px + border.
   Pár s ss-cart-3.js (beze změny od v10).
   ============================================================ */

/* ============================================================
   PREVIEW CART BASE — společný layout + opravené bugy
   Skinuje se přes --ck-* knoby (nastavují skin-a/b/c).
   Barvy VŽDY var(--ss-*) (BASELINE). Žádné transition:all,
   žádné `.Ns var(--ss-ease)` (delay bug). Cílí reálný DOM
   z /tmp/cart_inner.html (ověřeno 2026-05-31).
   ============================================================ */

body.in-kosik {
  /* ---- SKIN KNOBY (default = Skin A; skiny přepisují) ---- */
  --ck-head-font: var(--ss-serif, Georgia, serif);
  --ck-head-weight: 400;
  --ck-head-style: italic;

  --ck-name-font: var(--ss-sans, sans-serif);
  --ck-name-weight: 600;
  --ck-name-size: 16px;
  --ck-name-style: normal;
  --ck-name-transform: none;

  --ck-price-font: var(--ss-sans, sans-serif);
  --ck-price-weight: 700;
  --ck-price-size: 19px;

  --ck-eyebrow-transform: uppercase;
  --ck-eyebrow-spacing: .3em;
  --ck-eyebrow-size: 10.5px;

  --ck-card-bg: #FAF6EE;
  --ck-card-bg-hover: #FFFFFF;
  --ck-card-radius: 10px;
  --ck-summary-bg: var(--ss-cream, #E8DDC8);
  --ck-help-bg: var(--ss-white, #FFFFFF);
  --ck-divider: rgba(15, 15, 15, .12);
  --ck-cta-radius: 4px;

  background: var(--ss-canvas, #F2EBDB) !important;
}
body.in-kosik .breadcrumbs-wrapper { display: none !important; }
body.in-kosik #content-wrapper,
body.in-kosik .content-inner { background: var(--ss-canvas, #F2EBDB) !important; }

body.in-kosik #content.content {
  max-width: 1500px;
  margin: 0 auto;
  padding: 24px 32px 60px;
}

/* h1 (sr-only) → viditelný nadpis pokud existuje */
body.in-kosik #content h1.sr-only {
  /* skrýt vizuálně, zůstává v DOM pro SEO/čtečky (krok "NÁKUPNÍ KOŠÍK" v indikátoru stačí) */
  position: absolute !important; width: 1px !important; height: 1px !important;
  overflow: hidden !important; clip: rect(0 0 0 0) !important; white-space: nowrap !important;
  border: 0 !important; padding: 0 !important; margin: -1px !important;
}

/* ============================================================ LAYOUT GRID */
body.in-kosik #cart-wrapper { background: transparent; padding: 0; }
body.in-kosik #cart-wrapper .cart-inner { padding: 0; }
body.in-kosik #cart-wrapper .row.cart-row {
  display: grid; grid-template-columns: 1fr 380px; gap: 40px;
  align-items: start; margin: 0;
}
body.in-kosik #cart-wrapper .col-md-8 {
  grid-column: 1; width: 100%; max-width: 100%; min-width: 0; padding: 0; flex: 1 1 auto;
}
body.in-kosik #cart-wrapper .col-md-4 {
  grid-column: 2; width: 100%; max-width: 100%; padding: 0; flex: 1 1 auto;
}
body.in-kosik #cart-wrapper .col-md-8 > .cart-content { background: transparent; padding: 0 !important; } /* kill native 40px padding → step band zarovnán nahoře se sidebarem */

/* ============================================================ STEP INDICATOR */
body.in-kosik .cart-header {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  list-style: none !important; list-style-type: none !important;
  padding: 26px 16px 22px; margin: 0 0 32px;
  background: var(--ss-paper, #FAF5E8);
  border: 1px solid var(--ss-border, rgba(15, 15, 15, .10)); border-radius: 10px;
  counter-reset: step;
}
body.in-kosik .cart-header .step { list-style: none !important; }
body.in-kosik .cart-header .step::marker { display: none; content: ''; }
body.in-kosik .cart-header .step span::before,
body.in-kosik .cart-header .step strong::before,
body.in-kosik .cart-header .step a::before { content: none !important; display: none !important; }
body.in-kosik .cart-header .step {
  display: flex; align-items: center; gap: 10px;
  color: var(--ss-muted, rgba(15, 15, 15, .62));
  font-family: var(--ss-sans, sans-serif); font-size: 12.5px; letter-spacing: .14em;
  text-transform: uppercase; font-weight: 600; position: relative; counter-increment: step;
}
body.in-kosik .cart-header .step::before {
  content: counter(step); width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--ss-border, rgba(15, 15, 15, .10));
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11.5px; background: var(--ss-white, #FFFFFF);
  color: var(--ss-muted, rgba(15, 15, 15, .62)); letter-spacing: 0; flex-shrink: 0;
}
body.in-kosik .cart-header .step + .step::after {
  content: ''; position: absolute; left: -18px; width: 18px; height: 1px;
  background: var(--ss-border, rgba(15, 15, 15, .10));
}
body.in-kosik .cart-header .step.active { color: var(--ss-black, #0F0F0F); }
body.in-kosik .cart-header .step.active::before {
  background: var(--ss-sage, #6B8B85); color: var(--ss-white, #FFFFFF);
  border-color: var(--ss-sage, #6B8B85);
}
body.in-kosik .cart-header .step.completed::before {
  content: '✓'; background: var(--ss-sage-deep, #5A7E78); color: var(--ss-white, #FFFFFF);
  border-color: var(--ss-sage-deep, #5A7E78);
}
body.in-kosik .cart-header .step strong,
body.in-kosik .cart-header .step a {
  font-weight: inherit !important; color: inherit; text-decoration: none;
  border-bottom-color: var(--ss-black, #0F0F0F) !important;
}

/* ============================================================ CART TABLE */
body.in-kosik .cart-table { width: 100%; border-collapse: collapse; background: transparent; }
body.in-kosik .cart-table thead { display: none; }
body.in-kosik .cart-table tr.removeable {
  display: grid; grid-template-columns: 92px 1fr auto auto; gap: 24px;
  align-items: center; padding: 18px 22px; margin-bottom: 12px;
  background: #FAF6EE;
  border: 1px solid rgba(15, 15, 15, .06);
  border-radius: 10px;
  box-shadow: 0 6px 18px rgba(15, 15, 15, .03);
}
body.in-kosik .cart-table tr.removeable:first-child { padding-top: 18px; }
body.in-kosik .cart-table tr.removeable td {
  padding: 0; border: 0; background: transparent; vertical-align: middle;
}
body.in-kosik .cart-table .p-label { display: none; }
body.in-kosik .cart-table .p-availability { display: none; }
body.in-kosik .cart-table .p-price { display: none !important; }

/* Image */
body.in-kosik .cart-table .cart-p-image { width: 92px; }
body.in-kosik .cart-table .cart-p-image a {
  display: block; width: 92px; height: 92px; border-radius: 6px;
  background: var(--ss-canvas, #F2EBDB);
  border: 1px solid var(--ss-border, rgba(15, 15, 15, .10)); overflow: hidden;
}
body.in-kosik .cart-table .cart-p-image img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Name */
body.in-kosik .cart-table .p-name { min-width: 0; }
body.in-kosik .cart-table .p-name .main-link {
  font-family: var(--ck-name-font); font-weight: var(--ck-name-weight);
  font-style: var(--ck-name-style); font-size: var(--ck-name-size);
  line-height: 1.3; letter-spacing: -.01em; text-transform: var(--ck-name-transform);
  color: var(--ss-black, #0F0F0F) !important; text-decoration: none !important; display: block;
}
body.in-kosik .cart-table .p-name .main-link:hover { color: var(--ss-sage-deep, #5A7E78) !important; }

/* ---- QUANTITY STEPPER (BUG FIX: horizontal − [n] +, žádný overflow) ---- */
body.in-kosik .cart-table .p-quantity .quantity {
  position: relative; display: inline-flex; flex-direction: row; align-items: stretch;
  height: 40px; padding: 0 !important; border: 1px solid var(--ss-border-mid, rgba(15, 15, 15, .16));
  border-radius: 8px; overflow: hidden; background: var(--ss-white, #FFFFFF);
}
/* skryj native tooltip spany */
body.in-kosik .cart-table .p-quantity .quantity .increase-tooltip,
body.in-kosik .cart-table .p-quantity .quantity .decrease-tooltip { display: none !important; }
body.in-kosik .cart-table .p-quantity .quantity label {
  display: flex; align-items: stretch; margin: 0; order: 0; padding: 0;
}
body.in-kosik .cart-table .p-quantity .amount {
  width: 46px; height: 100%; text-align: center; padding: 0;
  border: 0; border-left: 1px solid var(--ss-border, rgba(15, 15, 15, .10));
  border-right: 1px solid var(--ss-border, rgba(15, 15, 15, .10));
  background: transparent; color: var(--ss-black, #0F0F0F);
  font-family: var(--ss-sans, sans-serif); font-size: 14px; font-weight: 600;
  -moz-appearance: textfield; appearance: textfield;
}
body.in-kosik .cart-table .p-quantity .amount::-webkit-inner-spin-button,
body.in-kosik .cart-table .p-quantity .amount::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
body.in-kosik .cart-table .p-quantity .increase,
body.in-kosik .cart-table .p-quantity .decrease {
  position: static !important; float: none !important;
  width: 38px; height: 100%; align-self: stretch; margin: 0; padding: 0; border: 0;
  background: var(--ss-white, #FFFFFF); color: var(--ss-muted, rgba(15, 15, 15, .62));
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  font-size: 17px; line-height: 1;
  transition: background .2s cubic-bezier(.4, 0, .2, 1), color .2s cubic-bezier(.4, 0, .2, 1);
}
body.in-kosik .cart-table .p-quantity .decrease { order: -1; }
body.in-kosik .cart-table .p-quantity .increase { order: 1; }
body.in-kosik .cart-table .p-quantity .increase:hover,
body.in-kosik .cart-table .p-quantity .decrease:hover {
  background: var(--ss-canvas, #F2EBDB); color: var(--ss-black, #0F0F0F);
}
/* native +/- glyfy (shoptet font ▲▼ absolutně nahoře = to "××") pryč;
   ukážeme skutečné textové __sign (+ / −), které Shoptet defaultně skrývá */
body.in-kosik .cart-table .p-quantity .increase::before,
body.in-kosik .cart-table .p-quantity .decrease::before { content: none !important; }
body.in-kosik .cart-table .p-quantity .increase__sign,
body.in-kosik .cart-table .p-quantity .decrease__sign {
  display: inline-block !important; font-size: 18px; line-height: 1; font-weight: 400;
  font-family: var(--ss-sans, sans-serif); pointer-events: none; color: inherit;
}
body.in-kosik .cart-table .p-quantity form { margin: 0; }

/* Total + remove */
body.in-kosik .cart-table .p-total {
  display: flex; align-items: center; justify-content: flex-end; gap: 16px;
  white-space: nowrap; position: relative;
}
body.in-kosik .cart-table .p-total .price-final {
  font-family: var(--ck-price-font); font-weight: var(--ck-price-weight);
  font-size: var(--ck-price-size); letter-spacing: -.01em; color: var(--ss-black, #0F0F0F) !important;
}
body.in-kosik .cart-table .p-total form.inline { margin: 0; }

/* ---- REMOVE × (BUG FIX: vždy viditelný, native ho schovává do hoveru) ---- */
body.in-kosik .cart-table .remove-item {
  opacity: 1 !important; visibility: visible !important;
  position: static !important; float: none !important;
  width: 34px; height: 34px; border: 0; background: transparent; border-radius: 50%;
  color: var(--ss-muted, rgba(15, 15, 15, .62)); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto;
  font-size: 0; padding: 0;
  transition: background .2s cubic-bezier(.4, 0, .2, 1), color .2s cubic-bezier(.4, 0, .2, 1);
}
body.in-kosik .cart-table .remove-item::before {
  content: '×' !important; font-family: var(--ss-sans, sans-serif) !important;
  font-size: 22px !important; line-height: 1 !important; font-weight: 400 !important; speak: none;
}
body.in-kosik .cart-table .remove-item:hover {
  background: var(--ss-canvas, #F2EBDB); color: var(--ss-black, #0F0F0F);
}
body.in-kosik .cart-table .remove-item .sr-only {
  position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0);
}

/* ============================================================ CROSS-SELL CAROUSEL */
body.in-kosik .ss-cart-crosssell { margin: 36px 0 28px; }
body.in-kosik .ss-cart-crosssell[data-state="hidden"] { display: none; }
body.in-kosik .ss-cart-crosssell__head { margin: 0 0 18px; }
body.in-kosik .ss-cart-crosssell__eyebrow {
  display: block; font-family: var(--ss-sans, sans-serif); font-size: var(--ck-eyebrow-size);
  font-weight: 600; letter-spacing: var(--ck-eyebrow-spacing); text-transform: var(--ck-eyebrow-transform);
  color: var(--ss-sage-deep, #5A7E78); margin: 0 0 6px;
}
body.in-kosik .ss-cart-crosssell__title {
  margin: 0; font-family: var(--ck-head-font); font-weight: var(--ck-head-weight);
  font-style: var(--ck-head-style); font-size: 26px; letter-spacing: -.02em;
  color: var(--ss-black, #0F0F0F); line-height: 1.15;
}
body.in-kosik .ss-cart-crosssell__grid {
  display: flex; gap: 16px; max-width: 100%; min-width: 0; overflow-x: auto;
  scroll-snap-type: x proximity; padding-bottom: 10px; -webkit-overflow-scrolling: touch;
  scrollbar-width: thin; scrollbar-color: rgba(15, 15, 15, .3) rgba(15, 15, 15, .06);
}
body.in-kosik .ss-cart-crosssell__grid::-webkit-scrollbar { height: 8px; }
body.in-kosik .ss-cart-crosssell__grid::-webkit-scrollbar-thumb { background: rgba(15, 15, 15, .3); border-radius: 999px; }
body.in-kosik .ss-cart-crosssell__grid::-webkit-scrollbar-thumb:hover { background: rgba(15, 15, 15, .42); }
body.in-kosik .ss-cart-crosssell__grid::-webkit-scrollbar-track { background: rgba(15, 15, 15, .06); border-radius: 999px; }
body.in-kosik .ss-cart-crosssell__card {
  display: flex; flex-direction: column; flex: 0 0 220px; scroll-snap-align: start;
  padding: 14px; background: var(--ck-card-bg); border: 1px solid rgba(15, 15, 15, .07);
  border-radius: var(--ck-card-radius); box-shadow: 0 6px 18px rgba(15, 15, 15, .04);
  transition: transform .35s cubic-bezier(.4, 0, .2, 1), box-shadow .35s cubic-bezier(.4, 0, .2, 1),
              border-color .35s cubic-bezier(.4, 0, .2, 1), background .35s cubic-bezier(.4, 0, .2, 1);
  position: relative; text-decoration: none;
}
body.in-kosik .ss-cart-crosssell__card:hover {
  transform: translateY(-3px); background: var(--ck-card-bg-hover);
  border-color: rgba(15, 15, 15, .12); box-shadow: 0 14px 36px rgba(15, 15, 15, .08);
}
body.in-kosik .ss-cart-crosssell__media-link { display: block; text-decoration: none; }
body.in-kosik .ss-cart-crosssell__media {
  position: relative; aspect-ratio: 1 / 1; background: var(--ss-cream, #E8DDC8); /* čtverec = jako category karta (v24) */
  border-radius: 6px; overflow: hidden; margin-bottom: 12px;
}
body.in-kosik .ss-cart-crosssell__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .5s cubic-bezier(.4, 0, .2, 1);
}
body.in-kosik .ss-cart-crosssell__card:hover .ss-cart-crosssell__media img { transform: scale(1.03); }
body.in-kosik .ss-cart-crosssell__name {
  font-family: var(--ss-sans, sans-serif); font-size: 13px; font-weight: 500; line-height: 1.35;
  color: var(--ss-black, #0F0F0F); text-decoration: none; display: block;
  overflow: visible; min-height: 0; /* celé názvy (bez clampu); karty se srovnají na nejvyšší přes align-items:stretch */
  margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid rgba(15, 15, 15, .06);
}
body.in-kosik .ss-cart-crosssell__name:hover { color: var(--ss-sage-deep, #5A7E78); }
body.in-kosik .ss-cart-crosssell__price {
  font-family: var(--ck-price-font); font-size: 16px; font-weight: var(--ck-price-weight);
  color: var(--ss-black, #0F0F0F); margin: 0 0 10px;
}
body.in-kosik .ss-cart-crosssell__add {
  appearance: none; border: 0; background: var(--ss-terracotta, #9A7A5F);
  color: var(--ss-white, #FFFFFF); font-family: var(--ss-sans, sans-serif); font-size: 13px;
  font-weight: 600; letter-spacing: .04em; border-radius: 6px; /* = .ss-cat-card__add */
  cursor: pointer; text-decoration: none; text-align: center;
  display: flex; align-items: center; justify-content: center;
  height: 36px; width: 100%; padding: 0 12px; line-height: 1;
  transition: background .25s cubic-bezier(.4, 0, .2, 1); margin-top: auto;
}
body.in-kosik .ss-cart-crosssell__add:hover { background: var(--ss-terracotta-deep, #7E6248); }

/* ============================================================ DÁRKY A SLEVY (coupon + freeship) */
body.in-kosik .cart-summary {
  margin-top: 28px; padding: 24px; background: var(--ss-cream, #E8DDC8); border-radius: 6px;
}
body.in-kosik .cart-summary .h4 {
  font-family: var(--ss-sans, sans-serif); font-size: var(--ck-eyebrow-size);
  letter-spacing: var(--ck-eyebrow-spacing); text-transform: var(--ck-eyebrow-transform);
  color: var(--ss-sage-deep, #5A7E78); font-weight: 600; margin: 0 0 16px;
}
/* full-width stack, ať text "rozpíná" kam má */
body.in-kosik .cart-summary .extras-wrapper { display: flex; flex-direction: column; gap: 16px; }
body.in-kosik .cart-summary .extras-col { width: 100%; max-width: none; } /* native cap max-width:350px → plná šířka */
body.in-kosik .cart-summary .extras-col + .extras-col { padding-left: 0; } /* zruš native indent 2. sloupce */
body.in-kosik .cart-summary .discount-coupon::before { content: none !important; } /* kill nezarovnaný native -% glyf */

/* Coupon = SIGNATURE brand "form pill" (1:1 s ss-newsletter__form):
   vnější pill (border + 6px radius + 6px padding) obaluje TRANSPARENTNÍ input + PLNÝ button uvnitř, výška 48px.
   Barvy do cream kontextu: bílý pill, terracotta button (brand CTA na světlém). */
body.in-kosik .cart-summary .discount-coupon {
  padding-left: 0 !important; /* zruš native 60px odsazení po smazané -% ikoně → zarovná s eyebrow + ikonou auta */
  margin: 0;
}
body.in-kosik .cart-summary .input-group {
  display: flex; align-items: stretch; gap: 8px; margin: 0; max-width: 520px;
  padding: 6px;
  background: var(--ss-white, #FFFFFF);
  border: 1px solid var(--ss-border-mid, rgba(15, 15, 15, .16));
  border-radius: 6px;
  transition: border-color .25s cubic-bezier(.4, 0, .2, 1);
}
body.in-kosik .cart-summary .input-group:focus-within { border-color: var(--ss-terracotta, #9A7A5F); }
body.in-kosik .cart-summary input.form-control[name="discountCouponCode"] {
  flex: 1 1 auto; min-width: 0; height: 48px; padding: 0 18px; margin: 0 !important;
  background: transparent !important; color: var(--ss-black, #0F0F0F);
  border: 0 !important; outline: 0 !important; box-shadow: none !important; border-radius: 0 !important;
  font-family: var(--ss-sans, sans-serif); font-size: 14px;
  -webkit-appearance: none; appearance: none;
}
body.in-kosik .cart-summary input.form-control[name="discountCouponCode"]::placeholder { color: var(--ss-hint, rgba(15, 15, 15, .46)); }
body.in-kosik .cart-summary .input-group .btn {
  flex: 0 0 auto; height: 48px; padding: 0 28px;
  font-family: var(--ss-sans, sans-serif); font-size: 13px !important; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase !important; color: var(--ss-white, #FFFFFF) !important;
  background: var(--ss-terracotta, #9A7A5F) !important; border: 0 !important;
  border-radius: 6px !important; cursor: pointer; white-space: nowrap;
  transition: background .25s cubic-bezier(.4, 0, .2, 1), transform .25s cubic-bezier(.4, 0, .2, 1);
}
body.in-kosik .cart-summary .input-group .btn:hover {
  background: var(--ss-terracotta-deep, #7E6248) !important;
}
body.in-kosik .cart-summary .input-group .btn:active { transform: scale(.98); }

/* free-shipping line: ikona INLINE na řádku textu (ne nad ním), text plná šířka, progress bar full-width pod tím.
   vše zarovnané na levou hranu karty (žádné padding-left odsazení). */
body.in-kosik .cart-summary .extra.delivery { position: relative; padding-left: 0; margin-top: 4px; }
body.in-kosik .cart-summary .extra.delivery::before { content: none !important; } /* kill native 36px truck glyf */
body.in-kosik .cart-summary .extra.delivery > span {
  display: block;
  font-family: var(--ck-head-font); font-style: var(--ck-head-style); font-weight: var(--ck-head-weight);
  font-size: 16px; line-height: 1.5; color: var(--ss-black, #0F0F0F);
}
body.in-kosik .cart-summary .extra.delivery > span::before {
  content: ''; display: inline-block; vertical-align: -5px; width: 22px; height: 22px; margin-right: 10px;
  background: no-repeat center / contain
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239A7A5F' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 3h13v11H1zM14 7h4l3 3v4h-7z'/%3E%3Ccircle cx='5.5' cy='17.5' r='1.8'/%3E%3Ccircle cx='17.5' cy='17.5' r='1.8'/%3E%3C/svg%3E");
}
body.in-kosik .cart-summary .extra.delivery > span > strong {
  font-family: var(--ss-sans, sans-serif); font-style: normal; font-weight: 700;
  color: var(--ss-sage-deep, #5A7E78);
}
body.in-kosik .cart-summary .extra.delivery .price-range {
  display: block; height: 6px; margin-top: 10px; background: var(--ss-cream-deep, #DCCFB6);
  border-radius: 999px; overflow: hidden; width: 100%;
}
body.in-kosik .cart-summary .extra.delivery .price-range > div {
  height: 100%; background: var(--ss-sage, #6B8B85); border-radius: 999px;
}

/* ============================================================ SIDEBAR */
body.in-kosik .sidebar-in-cart {
  position: sticky; top: 20px; display: flex; flex-direction: column; gap: 14px;
}
/* HELP card */
body.in-kosik .sidebar-in-cart .cart-content.checkout-box-wrapper {
  background: var(--ck-help-bg); border: 1px solid var(--ss-border, rgba(15, 15, 15, .10));
  border-radius: 6px; padding: 24px; margin: 0;
}
body.in-kosik .sidebar-in-cart .checkout-box-wrapper .h4 {
  font-family: var(--ss-sans, sans-serif); font-size: var(--ck-eyebrow-size);
  letter-spacing: var(--ck-eyebrow-spacing); text-transform: var(--ck-eyebrow-transform);
  color: var(--ss-sage-deep, #5A7E78); font-weight: 600; margin: 0 0 14px;
}
body.in-kosik .sidebar-in-cart .checkout-box-wrapper .box {
  background: transparent !important; border: 0 !important; padding: 0 !important;
  margin: 0 !important; box-shadow: none !important;
}
body.in-kosik .sidebar-in-cart .contact-box ul { list-style: none !important; padding: 0 !important; margin: 0 !important; display: flex; flex-direction: column; gap: 8px; }
body.in-kosik .sidebar-in-cart .contact-box ul li { list-style: none !important; padding: 0; margin: 0; font-size: 13.5px; }
body.in-kosik .sidebar-in-cart .contact-box ul a {
  color: var(--ss-terracotta-deep, #7E6248) !important; text-decoration: none !important;
  border-bottom: 1px solid currentColor; font-family: var(--ss-sans, sans-serif) !important;
  font-weight: 500 !important; font-size: 13.5px !important; padding-bottom: 1px;
}

/* SUMMARY card */
body.in-kosik .sidebar-in-cart .cart-content.summary-wrapper {
  background: var(--ck-summary-bg); border: 0; border-radius: 6px;
  padding: 28px 24px 24px; margin: 0; position: relative;
}
body.in-kosik .sidebar-in-cart .summary-wrapper::before {
  content: 'Souhrn objednávky.'; display: block; font-family: var(--ck-head-font);
  font-weight: var(--ck-head-weight); font-style: var(--ck-head-style); font-size: 23px;
  letter-spacing: -.02em; color: var(--ss-black, #0F0F0F); margin: 0 0 18px;
}
body.in-kosik .sidebar-in-cart .summary-wrapper .box {
  background: transparent !important; border: 0 !important; padding: 0 !important;
  margin: 0 !important; box-shadow: none !important;
}
/* price-wrapper má 2 řádky (label+value)×2 → grid */
body.in-kosik .sidebar-in-cart .summary-wrapper .price-wrapper {
  display: grid; grid-template-columns: 1fr auto; gap: 8px 12px; align-items: baseline;
  margin: 0 0 20px; padding-top: 18px; border-top: 1px dashed rgba(15, 15, 15, .22);
}
body.in-kosik .sidebar-in-cart .summary-wrapper .price-label {
  font-family: var(--ss-sans, sans-serif) !important; font-weight: 500 !important; font-size: 14px !important;
  color: var(--ss-muted, rgba(15, 15, 15, .62)) !important; text-transform: none !important; letter-spacing: 0 !important;
}
body.in-kosik .sidebar-in-cart .summary-wrapper .price {
  text-align: right; font-family: var(--ck-price-font) !important; font-weight: var(--ck-price-weight) !important;
  color: var(--ss-black, #0F0F0F) !important; letter-spacing: -.01em !important;
}
body.in-kosik .sidebar-in-cart .summary-wrapper .price.price-primary { font-size: 22px !important; }
body.in-kosik .sidebar-in-cart .summary-wrapper .price-label.price-primary { font-weight: 600 !important; color: var(--ss-black, #0F0F0F) !important; }
body.in-kosik .sidebar-in-cart .summary-wrapper .price.price-secondary,
body.in-kosik .sidebar-in-cart .summary-wrapper .price-label.price-secondary { font-size: 13px !important; }
body.in-kosik .sidebar-in-cart .summary-wrapper .price.price-secondary { font-family: var(--ss-sans, sans-serif) !important; font-weight: 500 !important; color: var(--ss-muted, rgba(15, 15, 15, .62)) !important; }

/* CTA */
body.in-kosik .sidebar-in-cart .summary-wrapper .next-step {
  display: flex !important; flex-direction: column !important; gap: 10px !important;
  margin: 0 !important; padding: 0 !important; border: 0 !important;
}
body.in-kosik .next-step .next-step-forward {
  padding: 11px 14px !important; background: var(--ss-sage, #6B8B85) !important;
  color: var(--ss-white, #FFFFFF) !important; border: 0 !important; border-radius: var(--ck-cta-radius) !important;
  font-family: var(--ss-sans, sans-serif) !important; font-size: 12px !important; font-weight: 600 !important;
  letter-spacing: .04em !important; text-transform: none !important; cursor: pointer; line-height: 1 !important; /* bez caps locku; line-height:36 native = příčina 58px */
  text-decoration: none !important; transition: background .25s cubic-bezier(.4, 0, .2, 1), transform .25s cubic-bezier(.4, 0, .2, 1);
  width: 100% !important; text-align: center !important; display: flex !important;
  align-items: center !important; justify-content: center !important; min-height: 48px !important;
}
body.in-kosik .next-step .next-step-forward:hover { background: var(--ss-sage-deep, #5A7E78) !important; }
body.in-kosik .next-step .order-button-text { color: inherit !important; line-height: 1 !important; }
body.in-kosik .next-step .next-step-back {
  font-family: var(--ss-sans, sans-serif) !important; font-size: 13px !important;
  color: var(--ss-muted, rgba(15, 15, 15, .62)) !important; text-decoration: none !important;
  background: transparent !important; border: 0 !important; padding: 6px 0 !important;
  text-align: center !important; font-weight: 500 !important; letter-spacing: 0 !important;
  text-transform: none !important; width: 100% !important;
}
body.in-kosik .next-step .next-step-back:hover { color: var(--ss-black, #0F0F0F) !important; }
body.in-kosik .next-step .continue-shopping::before { content: '← '; }

/* ============================================================ RESPONSIVE */
@media (max-width: 1024px) {
  body.in-kosik #cart-wrapper .row.cart-row { grid-template-columns: 1fr !important; gap: 24px; }
  body.in-kosik #cart-wrapper .col-md-8, body.in-kosik #cart-wrapper .col-md-4 { grid-column: auto !important; }
  body.in-kosik .sidebar-in-cart { position: static; }
}
@media (max-width: 900px) {
  body.in-kosik #content.content { padding: 16px 16px 40px; }
  body.in-kosik .cart-header { padding: 18px 12px 16px; margin: 0 0 24px; gap: 10px; }
  /* Položka: ř.1 [foto | název přes zbytek šířky], ř.2 [množství ......... cena + ×] přes celou šířku.
     Řeší "vše se cpe kam chce" — jasná 2řádková struktura, vejde se i na 320px, stepper zůstává touch-friendly. */
  /* tabulka/tbody/buňky → block: <td> jsou table-cell a uvnitř gridu tvoří anonymní table-box,
     který rozbíjí layout (název se nepřetáhne, stepper se roztáhne). Po de-tableizaci grid funguje. */
  body.in-kosik .cart-table,
  body.in-kosik .cart-table tbody { display: block; width: 100%; }
  /* jen tyto 3 buňky → block. NEcílit blanket td:not(.p-total): přebilo by .p-availability{display:none}
     → „Skladem" by vyskočilo a z availability by se stal stray flex item. */
  body.in-kosik .cart-table .cart-p-image,
  body.in-kosik .cart-table .p-name,
  body.in-kosik .cart-table .p-quantity,
  body.in-kosik .cart-table .p-total { display: block; min-width: 0; }
  /* Řádek = FLEX wrap (grid <tr> nerespektuje width:100% a span <td> nefunguje; flex šířku zvládá).
     ř.1 [foto | název přes zbytek]; ř.2 množství; ř.3 cena+× — množství i cena zarovnané POD názvem (padding-left = foto+gap). */
  body.in-kosik .cart-table tr.removeable {
    display: flex; flex-wrap: wrap; align-items: center;
    column-gap: 14px; row-gap: 12px; padding: 16px;
    width: 100%; box-sizing: border-box;
  }
  body.in-kosik .cart-table .cart-p-image,
  body.in-kosik .cart-table .cart-p-image a { width: 64px; height: 64px; }
  body.in-kosik .cart-table .cart-p-image { flex: 0 0 64px; align-self: start; }
  body.in-kosik .cart-table .p-name { flex: 1 1 calc(100% - 78px); align-self: center; }
  /* ř.2 = stepper vlevo + cena/× vpravo na STEJNÉM řádku (cena flex-basis:0 → vždy se vejde vedle stepperu a doroste) */
  body.in-kosik .cart-table .p-quantity { flex: 0 0 auto; display: flex; justify-content: flex-start; }
  body.in-kosik .cart-table .p-total {
    flex: 1 1 0; display: flex; justify-content: flex-end; align-items: center; gap: 14px;
  }
  body.in-kosik .ss-cart-crosssell__card { flex-basis: 170px; }
}
@media (max-width: 480px) {
  body.in-kosik .ss-cart-crosssell__card { flex-basis: 78%; }
}

/* ============================================================ REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
  body.in-kosik .ss-cart-crosssell__card,
  body.in-kosik .ss-cart-crosssell__media img,
  body.in-kosik .cart-table .remove-item,
  body.in-kosik .cart-table .p-quantity .increase,
  body.in-kosik .cart-table .p-quantity .decrease { transition: none; }
  body.in-kosik .ss-cart-crosssell__card:hover { transform: none; }
  body.in-kosik .ss-cart-crosssell__card:hover .ss-cart-crosssell__media img { transform: none; }
}

/* ====== VARIANTA A — skin ====== */
/* ============================================================
   SKIN A — "Stejné DNA, ale pevné"
   Warm editorial (cream/sage/terracotta + Rigane), ale heavier:
   Rigane 400 (z 300), název produktu solidní Manrope 600,
   ceny Manrope 700. Drží 1:1 s homepage/PDP. Konec "žiletky".
   ============================================================ */
body.in-kosik {
  --ck-head-font: var(--ss-serif, Georgia, serif);
  --ck-head-weight: 400;
  --ck-head-style: italic;

  --ck-name-font: var(--ss-serif, Georgia, serif); /* náš Rigane */
  --ck-name-weight: 400;
  --ck-name-size: 17px;
  --ck-name-style: italic; /* POZOR: nahraná je jen italic varianta Rigane; normal = Georgia fallback (= ta "žiletka") */
  --ck-name-transform: none;

  --ck-price-font: var(--ss-serif, Georgia, serif); /* ceny → Rigane (volba: ceny do Rigane) */
  --ck-price-weight: 400;
  --ck-price-size: 20px;

  --ck-eyebrow-transform: uppercase;
  --ck-eyebrow-spacing: .24em;
  --ck-eyebrow-size: 10.5px;

  --ck-card-bg: #FAF6EE;
  --ck-card-bg-hover: #FFFFFF;
  --ck-card-radius: 10px;
  --ck-summary-bg: var(--ss-cream, #E8DDC8);
  --ck-help-bg: var(--ss-white, #FFFFFF);
  --ck-cta-radius: 4px;
}

/* ── Rigane italic na obsahový text: cross-sell názvy + ceny + hlavní souhrn ──
   (volba "Názvy + ceny + souhrn"). Tlačítka / eyebrow / step / "Cena bez DPH" zůstávají Manrope.
   Rigane má nahranou JEN italic → font-style:italic je nutný, jinak Georgia fallback. */
body.in-kosik .ss-cart-crosssell__name {
  font-family: var(--ss-serif, Georgia, serif); font-style: italic; font-weight: 400;
  font-size: 14.5px; line-height: 1.3;
}
body.in-kosik .cart-table .p-total .price-final,
body.in-kosik .ss-cart-crosssell__price,
body.in-kosik .sidebar-in-cart .summary-wrapper .price.price-primary {
  font-style: italic !important;
}
body.in-kosik .sidebar-in-cart .summary-wrapper .price.price-primary { font-size: 24px !important; }

/* ============================================================
   v12 FIX — krok-indikátor (.cart-header) se schovával za fixed header na mobilu.
   Příčina: Shoptet native main.css → @media (max-width:767px){ ol.cart-header{ position:fixed; top:0 } }
   Krok-bar se přilepí na top:0 a náš custom fixed header (ss-header-27) ho překryje.
   Fix: vrátit krok-indikátor do normálního toku (chová se pak jako na desktopu).
   Cart-scoped, headeru se nedotýká. Selektor specificitou poráží nativní ol.cart-header (0,1,1).
   ============================================================ */
@media (max-width: 767px) {
  body.in-kosik ol.cart-header,
  body.in-kosik .cart-header {
    position: static !important;
    top: auto !important; left: auto !important; right: auto !important;
    z-index: auto !important;
  }
}

/* v12: po un-fixu se 3 popisky kroků (~485px) na úzkém mobilu nevejdou do řádku
   → tlačily by horizontální scroll. Kompaktní varianta (≤520): kroky 1/3 šířky,
   menší kolečko/font, popisek se zalomí, spojovníky skryté. Drží všechny 3 labely
   (strukturální řešení, ne fixní px — viz lekce #5). */
@media (max-width: 520px) {
  body.in-kosik .cart-header { gap: 4px; padding: 14px 8px 12px; }
  body.in-kosik .cart-header .step {
    flex: 1 1 0; min-width: 0; justify-content: center;
    gap: 6px; font-size: 9.5px; letter-spacing: .03em; line-height: 1.2;
  }
  body.in-kosik .cart-header .step::before {
    width: 22px; height: 22px; font-size: 10.5px;
  }
  body.in-kosik .cart-header .step + .step::after { display: none; }
}
