/* ============================================
   Drewnianysklep v3 — Cart (redesign v0.6)
   ============================================ */

.ds-cart-page {
  max-width: var(--ds-max-shop);
  margin: 0 auto;
  padding: 32px 32px 80px;
}

/* ─── Top banner: tytul + shipbar w jednym bloku ─────────────── */
.ds-cart-banner {
  margin-bottom: 28px;
  padding: 24px 28px;
  background: linear-gradient(135deg,
    var(--ds-paper) 0%,
    color-mix(in oklab, var(--ds-sand) 18%, var(--ds-paper)) 100%);
  border: 1px solid var(--ds-line);
  border-radius: 18px;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02), 0 8px 24px -16px rgba(42,39,34,0.12);
}
.ds-cart-banner-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;
}
.ds-cart-banner-title-wrap {
  min-width: 0;
}
.ds-cart-title {
  font-family: var(--ds-font-display);
  font-weight: 500;
  font-size: clamp(26px, 3.2vw, 38px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ds-ink);
  margin: 8px 0 0;
}

/* Shipbar w bannerze — kompaktowa wersja (override globalnych w theme.css) */
.ds-cart-banner .ds-cart-shipbar {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  gap: 8px;
}
.ds-cart-banner .ds-cart-shipbar-head {
  font-size: 13.5px;
  gap: 10px;
}
.ds-cart-banner .ds-cart-shipbar-ico {
  width: 36px;
  height: 36px;
  background: var(--ds-paper);
  border: 1px solid color-mix(in oklab, var(--ds-olive) 25%, var(--ds-line));
}
.ds-cart-banner .ds-cart-shipbar-track {
  height: 6px;
  background: color-mix(in oklab, var(--ds-sand) 30%, var(--ds-paper));
}

/* v0.14.7: nota o tym ze darmowa dostawa nie obejmuje pobrania */
.ds-cart-shipbar-note {
  display: block;
  font-size: 11.5px;
  color: var(--ds-ink-muted);
  line-height: 1.4;
  margin-top: 6px;
  font-style: italic;
}

@media (max-width: 800px) {
  .ds-cart-banner-head {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}

/* ─── Grid: items + summary ──────────────────────────────────── */
.ds-cart-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 32px;
  align-items: start;
}

/* ─── Lewa: items ────────────────────────────────────────────── */
.ds-cart-items {
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}

/* Lista produktow — wspolna karta zamiast kazdy item w osobnym pudelku */
.ds-cart-items-list {
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: 18px;
  overflow: hidden;
}

.ds-cart-item {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  gap: 20px;
  padding: 22px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--ds-line);
  border-radius: 0;
  transition: background .15s;
}
.ds-cart-item:last-child { border-bottom: 0; }
.ds-cart-item:hover {
  background: color-mix(in oklab, var(--ds-sand) 8%, var(--ds-paper));
}

.ds-cart-item-thumb {
  width: 110px;
  height: 110px;
  background: var(--ds-stone);
  border-radius: 14px;
  overflow: hidden;
  flex-shrink: 0;
}
.ds-cart-item-thumb a,
.ds-cart-item-thumb img {
  display: block;
  width: 100%;
  height: 100%;
}
.ds-cart-item-thumb img {
  object-fit: cover;
}

.ds-cart-item-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.ds-cart-item-name {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 8px;
}
.ds-cart-item-name a {
  color: var(--ds-ink);
  text-decoration: none;
}
.ds-cart-item-name a:hover { color: var(--ds-olive-deep); }

.ds-cart-item-meta {
  font-size: 13px;
  color: var(--ds-ink-muted);
  line-height: 1.5;
  margin-bottom: 12px;
}
/* Atrybuty produktu (Grawer, Wzor, Pojemnosc itp.) — kompaktowy podglad jak w mini-cart panelu (label: value, kazda para w nowej linii). */
.ds-cart-item-meta dl.variation,
.ds-cart-item-meta .variation {
  display: block !important;
  margin: 4px 0 0 !important;
  padding: 0 !important;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ds-ink-soft);
}
.ds-cart-item-meta dl.variation dt,
.ds-cart-item-meta .variation dt {
  display: inline !important;
  float: none !important;
  clear: none !important;
  font-weight: 600;
  color: var(--ds-ink-muted);
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  width: auto !important;
}
.ds-cart-item-meta dl.variation dt::after { content: " "; }
.ds-cart-item-meta dl.variation dd,
.ds-cart-item-meta .variation dd {
  display: inline !important;
  float: none !important;
  clear: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  width: auto !important;
  color: var(--ds-ink);
  font-weight: 700;
}
.ds-cart-item-meta dl.variation dd p,
.ds-cart-item-meta .variation dd p {
  display: inline !important;
  margin: 0 !important;
  padding: 0 !important;
}
.ds-cart-item-meta dl.variation dd::after {
  content: "\A";
  white-space: pre;
}

.ds-cart-item-backorder {
  font-size: 12px;
  color: var(--ds-error);
  margin: 4px 0 8px;
}

.ds-cart-item-foot {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 16px;
  align-items: center;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px dashed var(--ds-line);
}

/* WC quantity input */
.ds-cart-item-qty .quantity {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--ds-line);
  border-radius: 999px;
  background: var(--ds-cream);
  overflow: hidden;
}
.ds-cart-item-qty input.qty {
  width: 50px;
  height: 36px;
  border: 0;
  background: transparent;
  font-family: inherit;
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  color: var(--ds-ink);
  -moz-appearance: textfield;
}
.ds-cart-item-qty input.qty::-webkit-outer-spin-button,
.ds-cart-item-qty input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.ds-cart-item-qty .quantity:focus-within {
  border-color: var(--ds-olive);
}

/* ─── Stepper +/− buttons (JS-injected po enhanceQty) ───────────── */
.ds-cart-item-qty.ds-qty-stepper .quantity { padding: 0; }
.ds-qty-btn {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  background: transparent;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ds-ink-soft);
  transition: background .15s, color .15s;
}
.ds-qty-btn:hover {
  background: color-mix(in oklab, var(--ds-olive) 14%, var(--ds-cream));
  color: var(--ds-olive);
}
.ds-qty-btn:active { transform: scale(0.94); }
.ds-qty-btn:focus-visible {
  outline: 2px solid var(--ds-olive);
  outline-offset: -2px;
}
.ds-cart-item-qty.ds-qty-stepper input.qty {
  width: 38px;
  border-left: 1px solid var(--ds-line);
  border-right: 1px solid var(--ds-line);
}


.ds-cart-item-price-block {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
  line-height: 1.3;
}
.ds-cart-item-unit {
  font-size: 12px;
  color: var(--ds-ink-muted);
}
.ds-cart-item-unit small {
  margin-left: 4px;
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ds-cart-item-subtotal {
  font-size: 17px;
  font-weight: 800;
  color: var(--ds-ink);
}

.ds-cart-item-remove {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--ds-line);
  background: var(--ds-paper);
  color: var(--ds-ink-soft);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1;
  text-decoration: none;
  transition: background .15s, color .15s, border-color .15s;
  flex-shrink: 0;
}
.ds-cart-item-remove-ico { flex-shrink: 0; }
.ds-cart-item-remove-label { white-space: nowrap; }
.ds-cart-item-remove:hover {
  background: color-mix(in oklab, var(--ds-error) 8%, var(--ds-paper));
  border-color: var(--ds-error);
  color: var(--ds-error);
}
@media (max-width: 640px) {
  .ds-cart-item-remove {
    width: 34px;
    padding: 0;
    justify-content: center;
    gap: 0;
  }
  .ds-cart-item-remove-label { display: none; }
}

/* ─── Extras (kupon, łączenie, update) — wspolna lekka grupa ─── */
.ds-cart-extras {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: 18px;
  overflow: hidden;
}
.ds-cart-extra {
  border-bottom: 1px solid var(--ds-line);
}
.ds-cart-extra:last-of-type {
  border-bottom: 0;
}
.ds-cart-extra > summary {
  cursor: pointer;
  padding: 16px 22px;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ds-ink);
  transition: background .15s;
}
.ds-cart-extra > summary::-webkit-details-marker { display: none; }
.ds-cart-extra > summary:hover {
  background: color-mix(in oklab, var(--ds-sand) 10%, var(--ds-paper));
}
.ds-cart-extra-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--ds-olive) 10%, var(--ds-paper));
  color: var(--ds-olive-deep);
  flex-shrink: 0;
}
.ds-cart-extra-label {
  flex: 1 1 auto;
  min-width: 0;
}
.ds-cart-extra-chevron {
  color: var(--ds-ink-muted);
  transition: transform .2s;
  flex-shrink: 0;
}
.ds-cart-extra[open] .ds-cart-extra-chevron {
  transform: rotate(180deg);
}
.ds-cart-extra-body {
  padding: 0 22px 18px;
  border-top: 1px dashed var(--ds-line);
  margin-top: -1px;
  padding-top: 16px;
}

/* Coupon row */
.ds-cart-coupon-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.ds-cart-coupon-row input {
  flex: 1 1 200px;
  height: 44px;
  padding: 0 16px;
  border: 1px solid var(--ds-line);
  border-radius: 999px;
  background: var(--ds-cream);
  font-family: inherit;
  font-size: 14px;
  color: var(--ds-ink);
}
.ds-cart-coupon-row input:focus-visible {
  outline: 2px solid var(--ds-olive);
  outline-offset: 2px;
}

/* Stepper +/- w cart.js auto-submituje (debounce 700ms), kupon ma własny "Zastosuj" — ten button jest fallbackiem dla JS-off */
.ds-cart-update {
  flex-shrink: 0;
  display: none;
  margin: 0 22px 18px;
}
.no-js .ds-cart-update { display: inline-flex; }

/* ─── Prawa: summary ─────────────────────────────────────────── */
.ds-cart-summary-wrap {
  position: sticky;
  top: 110px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Promo chip „Dodaj odbitki" w summary (nad cartem totals) */
.ds-cart-promo {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px 18px;
  border-radius: 16px;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--ds-olive) 14%, var(--ds-paper)) 0%,
    color-mix(in oklab, var(--ds-sand) 30%, var(--ds-paper)) 100%);
  border: 1px solid color-mix(in oklab, var(--ds-olive) 28%, var(--ds-line));
}
.ds-cart-promo[hidden] { display: none; }
.ds-cart-promo-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.ds-cart-promo-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--ds-olive);
  color: var(--ds-paper);
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ds-cart-promo-badge-ico {
  display: inline-flex;
}
.ds-cart-promo-save {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ds-olive-deep);
}
.ds-cart-promo-save .woocommerce-Price-amount {
  color: var(--ds-olive-deep);
}
.ds-cart-promo-text {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
  color: var(--ds-ink);
}
.ds-cart-promo-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 14px;
  border-radius: 999px;
  background: var(--ds-paper);
  border: 1px solid color-mix(in oklab, var(--ds-olive) 35%, var(--ds-line));
  color: var(--ds-olive-deep) !important;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none !important;
  transition: background .15s, color .15s, border-color .15s, transform .15s;
}
.ds-cart-promo-cta:hover {
  background: var(--ds-olive);
  color: var(--ds-paper) !important;
  border-color: var(--ds-olive);
  transform: translateY(-1px);
}

.ds-cart-summary {
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: 18px;
  padding: 24px;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02), 0 12px 32px -20px rgba(42,39,34,0.18);
}

.ds-cart-totals-title {
  font-family: var(--ds-font-display);
  font-weight: 600;
  font-size: 20px;
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--ds-line);
  color: var(--ds-ink);
}

.ds-cart-totals-list {
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
}
.ds-cart-totals-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 6px 0;
  font-size: 14px;
  color: var(--ds-ink-soft);
}
.ds-cart-totals-row > span:last-child {
  font-weight: 700;
  color: var(--ds-ink);
}
.ds-cart-totals-row.is-discount > span:last-child,
.ds-cart-totals-row.cart-discount > span:last-child {
  color: var(--ds-success);
}

/* Sekcje (Produkty / Dostawa / Suma) */
.ds-cart-totals-row.ds-summary-section-head {
  padding: 14px 0 4px;
  border-top: 1px solid var(--ds-line);
  margin-top: 6px;
}
.ds-cart-totals-row.ds-summary-section-head:first-child {
  border-top: 0;
  margin-top: 0;
  padding-top: 0;
}
.ds-summary-section-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ds-olive-deep);
}
.ds-cart-totals-row.ds-summary-section-item {
  padding: 5px 0;
}

/* SUMA - mocno wyrozniona karta na koncu */
.ds-cart-totals-row.ds-summary-section-total {
  margin-top: 14px;
  padding: 16px 16px 14px !important;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(180deg, color-mix(in oklab, var(--ds-olive) 8%, var(--ds-paper)), color-mix(in oklab, var(--ds-olive) 4%, var(--ds-paper)));
  align-items: center;
  display: flex !important;
}
.ds-summary-total-label {
  font-family: var(--ds-font-display);
  font-weight: 600;
  font-size: 15px;
  color: var(--ds-ink);
  letter-spacing: 0.01em;
}
.ds-summary-total-value {
  display: flex !important;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  font-weight: 800 !important;
  font-size: 26px !important;
  color: var(--ds-olive-deep) !important;
  font-family: var(--ds-font-display);
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.ds-summary-total-value .includes_tax,
.ds-summary-total-value small,
.ds-summary-total-suffix {
  font-family: inherit;
  font-size: 10.5px;
  font-weight: 500;
  color: var(--ds-ink-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1;
}

/* Stara order-total reguła - cofamy dla niezgrupowanego layoutu */
.ds-cart-totals-row.order-total:not(.ds-summary-section-total) {
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--ds-line);
  font-size: 16px;
  color: var(--ds-ink);
}
.ds-cart-totals-row.order-total:not(.ds-summary-section-total) > span:last-child {
  font-size: 24px;
  font-weight: 800;
  color: var(--ds-olive-deep);
}

/* Trust mini pod CTA */
.ds-cart-trust-mini {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px 16px;
  font-size: 11.5px;
  color: var(--ds-ink-muted);
}
.ds-cart-trust-mini li {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.ds-cart-trust-mini svg {
  color: var(--ds-olive);
  flex-shrink: 0;
}

/* Shipping calculator inline */
.ds-cart-totals-row .shipping-calculator-form {
  margin-top: 8px;
}
.ds-cart-totals-row .shipping-calculator-button {
  font-size: 12px;
  color: var(--ds-olive-deep);
  text-decoration: underline;
}

/* ─── Shipping methods — radio cards w summary ──────────────────── */
.ds-cart-totals-row.ds-cart-totals-shipping {
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  padding: 12px 0;
}
.ds-cart-totals-row.ds-cart-totals-shipping > span:first-child {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ds-ink-muted);
}
.ds-cart-totals-row.ds-cart-totals-shipping > span:last-child {
  font-weight: 400;
  color: inherit;
}
/* Shipping method radio cards — style w theme.css (cart + checkout) */
.ds-cart-totals .woocommerce-shipping-destination,
.ds-cart-totals p.woocommerce-shipping-destination,
.ds-cart-totals-shipping p {
  font-size: 11.5px;
  color: var(--ds-ink-muted);
  margin: 6px 0 0;
}

/* Proceed to checkout — mocniejszy CTA */
.ds-cart-checkout-wrap {
  margin-top: 12px;
}
.ds-cart-checkout-wrap .button,
.ds-cart-checkout-wrap .checkout-button {
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 60px;
  padding: 0 24px;
  border-radius: 999px;
  font-family: inherit;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.02em;
  border: 1px solid var(--ds-olive-deep) !important;
  background: linear-gradient(135deg, var(--ds-olive) 0%, var(--ds-olive-deep) 100%) !important;
  color: var(--ds-paper) !important;
  text-decoration: none !important;
  box-shadow: 0 8px 20px -10px color-mix(in oklab, var(--ds-olive-deep) 60%, transparent),
              0 2px 4px -2px rgba(42,39,34,0.2);
  transition: transform .15s, box-shadow .15s, filter .15s;
}
.ds-cart-checkout-wrap .button::after,
.ds-cart-checkout-wrap .checkout-button::after {
  content: '';
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
  margin-left: 2px;
  opacity: 0.85;
  transition: transform .2s, margin .2s;
}
.ds-cart-checkout-wrap .button:hover,
.ds-cart-checkout-wrap .checkout-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px -12px color-mix(in oklab, var(--ds-olive-deep) 70%, transparent),
              0 4px 6px -2px rgba(42,39,34,0.25);
  filter: brightness(1.04);
}
.ds-cart-checkout-wrap .button:hover::after,
.ds-cart-checkout-wrap .checkout-button:hover::after {
  margin-left: 6px;
}
.ds-cart-checkout-wrap .button:active,
.ds-cart-checkout-wrap .checkout-button:active {
  transform: translateY(0);
}

.ds-cart-continue {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--ds-ink-soft);
  text-decoration: none;
  align-self: center;
}
.ds-cart-continue:hover { color: var(--ds-olive-deep); }
.ds-cart-continue svg { transform: rotate(180deg); }

/* ─── Empty state ────────────────────────────────────────────── */
.ds-cart-empty {
  text-align: center;
  padding: 80px 24px;
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: var(--ds-radius-lg);
  margin: 32px auto;
  max-width: 600px;
}
.ds-cart-empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: var(--ds-cream);
  color: var(--ds-olive-deep);
  margin-bottom: 16px;
}
.ds-cart-empty h2 {
  font-family: var(--ds-font-display);
  font-weight: 600;
  font-size: 28px;
  margin: 0 0 8px;
}
.ds-cart-empty p {
  color: var(--ds-ink-soft);
  max-width: 48ch;
  margin: 0 auto 24px;
}

/* ─── Cross-sells (na dole pod cart) ─────────────────────────── */
.cross-sells {
  margin-top: 64px;
}
.cross-sells > h2 {
  font-family: var(--ds-font-display);
  font-weight: 500;
  font-size: clamp(24px, 3vw, 36px);
  margin: 0 0 24px;
  color: var(--ds-ink);
}
.cross-sells .products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* WC notice container w cart */
.ds-cart-page .woocommerce-message,
.ds-cart-page .woocommerce-error,
.ds-cart-page .woocommerce-info {
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: var(--ds-radius);
  padding: 14px 18px;
  margin-bottom: 16px;
  font-size: 14px;
  list-style: none;
}
.ds-cart-page .woocommerce-error { border-color: var(--ds-error); color: var(--ds-error); }
.ds-cart-page .woocommerce-message { border-color: var(--ds-success); color: var(--ds-ink); }

/* ─── Responsive ─────────────────────────────────────────────── */
@media (max-width: 960px) {
  .ds-cart-grid {
    grid-template-columns: 1fr;
  }
  .ds-cart-summary-wrap {
    position: static;
  }
}

@media (max-width: 600px) {
  .ds-cart-page { padding: 16px 14px 80px; }
  .ds-cart-banner {
    margin-bottom: 18px;
    padding: 16px 16px;
    border-radius: 14px;
  }
  .ds-cart-title { font-size: 22px; margin-top: 4px; }
  .ds-cart-banner-head { gap: 14px; }
  .ds-cart-item {
    grid-template-columns: 80px minmax(0, 1fr);
    gap: 12px;
    padding: 16px;
  }
  .ds-cart-item-thumb {
    width: 80px;
    height: 80px;
  }
  .ds-cart-item-name { font-size: 14px; }
  .ds-cart-item-foot {
    grid-template-columns: 1fr auto;
    gap: 12px;
    grid-template-areas:
      "qty remove"
      "price price";
  }
  .ds-cart-item-qty { grid-area: qty; }
  .ds-cart-item-remove { grid-area: remove; }
  .ds-cart-item-price-block {
    grid-area: price;
    align-items: flex-start;
    text-align: left;
    flex-direction: row;
    justify-content: space-between;
    width: 100%;
  }
  .ds-cart-extra > summary {
    padding: 14px 18px;
  }
  .ds-cart-extra-body {
    padding: 14px 18px 16px;
  }
  .ds-cart-update {
    margin: 0 18px 16px;
    width: calc(100% - 36px);
  }
  .ds-cart-summary { padding: 18px; }
  .ds-cart-totals-title { font-size: 18px; }
  .ds-cart-promo { padding: 14px 14px; }
  .ds-cart-checkout-wrap .button,
  .ds-cart-checkout-wrap .checkout-button {
    height: 56px;
    font-size: 15px;
  }
  /* Wysylka destination — dluga linia "Wysylka do Ulica..., 41-500 Chorzow" lamala layout.
     Mniejszy font + word-break zeby nie wybijala karty na waskich ekranach. */
  .ds-cart-totals .woocommerce-shipping-destination,
  .ds-cart-totals p.woocommerce-shipping-destination,
  .ds-cart-totals-shipping p.woocommerce-shipping-destination {
    font-size: 11px;
    line-height: 1.4;
    word-break: break-word;
  }
  /* Sticky bottom CTA — JS-injected; widoczny tylko gdy oryginalny CTA poza viewport.
     Padding kompensowany przez body padding-bottom (set w JS). */
  .ds-cart-sticky-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9000;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px));
    background: var(--ds-paper);
    border-top: 1px solid var(--ds-line);
    box-shadow: 0 -8px 24px -12px rgba(42, 39, 34, 0.18);
    transform: translateY(100%);
    transition: transform .25s ease;
  }
  .ds-cart-sticky-cta.is-visible { transform: translateY(0); }
  .ds-cart-sticky-cta-total {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
    flex-shrink: 0;
  }
  .ds-cart-sticky-cta-total-label {
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ds-ink-muted);
    margin-bottom: 2px;
  }
  .ds-cart-sticky-cta-total-amount {
    font-size: 18px;
    font-weight: 800;
    color: var(--ds-olive-deep);
  }
  .ds-cart-sticky-cta-btn {
    flex: 1 1 auto;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 50px;
    padding: 0 16px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--ds-olive) 0%, var(--ds-olive-deep) 100%);
    color: var(--ds-paper) !important;
    border: 1px solid var(--ds-olive-deep);
    font-family: inherit;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.02em;
    text-decoration: none !important;
    box-shadow: 0 6px 14px -8px color-mix(in oklab, var(--ds-olive-deep) 70%, transparent);
  }
  .ds-cart-sticky-cta-btn::after {
    content: '';
    width: 8px;
    height: 8px;
    border-top: 2px solid currentColor;
    border-right: 2px solid currentColor;
    transform: rotate(45deg);
    opacity: 0.85;
  }
  body.ds-cart-sticky-active { padding-bottom: 80px; }
  /* Cross-sells: cala karta jest klikalna (link wrapuje wszystko), CTA "Zobacz produkt"
     jest redundantne na mobile i marnuje ~50px na karte. Ukrywamy. */
  .ds-cart-crosssell-cta { display: none; }
  .ds-cart-crosssell-body { padding-bottom: 14px; }
}

/* Sticky CTA — desktop nie potrzebuje (summary jest sticky w prawej kolumnie).
   Display none jako safety jezeli JS odpalilby na szerszym viewport. */
@media (min-width: 601px) {
  .ds-cart-sticky-cta { display: none !important; }
}

/* Free shipping progress bar — globalne w theme.css; w cart.css overridujemy
   tylko wariant w bannerze (.ds-cart-banner .ds-cart-shipbar) wyzej. */

/* ─── Łączenie zamówień (collapsible jak kupon) — w obrebie .ds-cart-extras ── */
.ds-cart-join-order {
  /* dziedziczy style .ds-cart-extra przez wspolna klase */
}
.ds-cart-join-order summary {
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--ds-ink);
  padding: 16px 22px;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: background .15s;
}
.ds-cart-join-order summary::-webkit-details-marker { display: none; }
.ds-cart-join-order summary:hover {
  background: color-mix(in oklab, var(--ds-sand) 10%, var(--ds-paper));
}
/* Ikona + chevron dla join-order, żeby pasowal wzorem kuponu — wstrzykujemy via ::before */
.ds-cart-join-order summary::before {
  content: '';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--ds-olive) 10%, var(--ds-paper));
  color: var(--ds-olive-deep);
  flex-shrink: 0;
  /* SVG inline: paczki/box */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236f6f43' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z'/><polyline points='3.27 6.96 12 12.01 20.73 6.96'/><line x1='12' y1='22.08' x2='12' y2='12'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px 16px;
  background-color: color-mix(in oklab, var(--ds-olive) 10%, var(--ds-paper));
  transition: none;
}
.ds-cart-join-order summary::after {
  content: '';
  margin-left: auto;
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a826f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat center / contain;
  transition: transform .2s;
  flex-shrink: 0;
}
.ds-cart-join-order[open] summary::after {
  transform: rotate(180deg);
}
.ds-cart-join-order-row {
  display: flex;
  gap: 8px;
  padding: 16px 22px 4px;
  flex-wrap: wrap;
  border-top: 1px dashed var(--ds-line);
}
.ds-cart-join-order-input {
  flex: 1 1 200px;
  height: 44px;
  padding: 0 16px;
  border: 1px solid var(--ds-line);
  border-radius: 999px;
  background: var(--ds-cream);
  font-family: inherit;
  font-size: 14px;
  color: var(--ds-ink);
}
.ds-cart-join-order-input:focus-visible {
  outline: 2px solid var(--ds-olive);
  outline-offset: 2px;
}
.ds-cart-join-order-help {
  margin: 0;
  padding: 0 22px 16px;
  font-size: 11.5px;
  color: var(--ds-ink-muted);
  line-height: 1.4;
}

/* ─── Wysyłka Express (collapsible w obrebie .ds-cart-extras) ─────────── */
.ds-cart-express summary {
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--ds-ink);
  padding: 16px 22px;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: background .15s;
}
.ds-cart-express summary::-webkit-details-marker { display: none; }
.ds-cart-express summary:hover {
  background: color-mix(in oklab, var(--ds-sand) 10%, var(--ds-paper));
}
.ds-cart-express summary::before {
  content: '';
  display: inline-flex;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: color-mix(in oklab, var(--ds-olive) 10%, var(--ds-paper));
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236f6f43' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><polygon points='13 2 3 14 12 14 11 22 21 10 12 10 13 2'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px 16px;
  flex-shrink: 0;
}
.ds-cart-express-price {
  margin-left: 6px;
  font-weight: 700;
  color: var(--ds-olive-deep);
  font-size: 13px;
}
.ds-cart-express summary::after {
  content: '';
  margin-left: auto;
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a826f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat center / contain;
  transition: transform .2s;
  flex-shrink: 0;
}
.ds-cart-express[open] summary::after { transform: rotate(180deg); }
.ds-cart-express-body {
  padding: 14px 22px 16px;
  border-top: 1px dashed var(--ds-line);
}
.ds-cart-express-desc {
  margin: 0 0 12px;
  font-size: 13px;
  color: var(--ds-ink-soft);
  line-height: 1.5;
}
.ds-cart-express-toggle {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--ds-ink);
  line-height: 1.35;
  padding: 8px 12px;
  border-radius: 10px;
  background: var(--ds-cream);
  transition: background .15s;
}
.ds-cart-express-toggle:hover {
  background: color-mix(in oklab, var(--ds-olive) 8%, var(--ds-cream));
}
.ds-cart-express-toggle input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: var(--ds-olive);
  width: 16px;
  height: 16px;
  cursor: pointer;
}
.ds-cart-express-help {
  margin: 8px 0 0;
  font-size: 11.5px;
  color: var(--ds-ink-muted);
  line-height: 1.4;
}

/* Express delivery — opis pod nazwą metody (flex item z flex-basis 100% wymusza nową linię) */
.woocommerce ul#shipping_method li label { flex-wrap: wrap; }
.ds-express-desc {
  flex-basis: 100%;
  display: block;
  margin: 2px 0 0;
  font-size: 11px;
  font-weight: 400;
  color: var(--ds-ink-muted);
  line-height: 1.3;
  order: 99; /* zawsze na końcu, nawet gdy cena ma margin-left:auto */
}

/* ─── Cross-sells „Zobacz inne równie interesujące" ───────────────────── */
.ds-cart-crosssells {
  margin: 56px 0 24px;
  padding: 32px 0 0;
  border-top: 1px solid var(--ds-line);
}
.ds-cart-crosssells-head {
  text-align: center;
  margin: 0 0 28px;
}
.ds-cart-crosssells-title {
  margin: 0 0 6px;
  font-size: 22px;
  font-weight: 700;
  color: var(--ds-ink);
  letter-spacing: -0.01em;
}
.ds-cart-crosssells-sub {
  margin: 0;
  font-size: 13px;
  color: var(--ds-ink-muted);
}
.ds-cart-crosssells-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.ds-cart-crosssell {
  display: flex;
  flex-direction: column;
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.ds-cart-crosssell:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--ds-olive) 35%, var(--ds-line));
  box-shadow: 0 8px 24px -8px rgba(0,0,0,.12);
}
.ds-cart-crosssell-thumb {
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--ds-cream);
}
.ds-cart-crosssell-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity .35s ease, transform .5s ease;
}
/* Hover image: na początku przezroczysty, fade-in na hover karty */
.ds-cart-crosssell-thumb-hover {
  opacity: 0;
  z-index: 2;
}
.ds-cart-crosssell.has-hover-img:hover .ds-cart-crosssell-thumb img:first-of-type {
  opacity: 0;
}
.ds-cart-crosssell.has-hover-img:hover .ds-cart-crosssell-thumb-hover {
  opacity: 1;
}
/* Bez hover-img — robimy soft zoom zamiast swapa */
.ds-cart-crosssell:not(.has-hover-img):hover .ds-cart-crosssell-thumb img {
  transform: scale(1.05);
}
.ds-cart-crosssell-sale {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--ds-olive);
  color: var(--ds-paper);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ds-cart-crosssell-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 14px 16px;
  flex: 1;
}
.ds-cart-crosssell-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--ds-ink);
  line-height: 1.3;
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}
.ds-cart-crosssell-name:hover { color: var(--ds-olive-deep); }
.ds-cart-crosssell-price {
  font-size: 14px;
  font-weight: 700;
  color: var(--ds-olive-deep);
  margin: auto 0 0;
}
.ds-cart-crosssell-price del { color: var(--ds-ink-muted); font-weight: 400; font-size: 12px; margin-right: 4px; }
.ds-cart-crosssell-price ins { text-decoration: none; }
.ds-cart-crosssell-cta {
  margin-top: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: transparent;
  color: var(--ds-olive-deep) !important;
  border: 1.5px solid color-mix(in oklab, var(--ds-olive) 40%, var(--ds-line));
  font-size: 13px;
  font-weight: 700;
  text-decoration: none !important;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
}
.ds-cart-crosssell-cta:hover,
.ds-cart-crosssell-cta.added {
  background: var(--ds-olive);
  border-color: var(--ds-olive);
  color: var(--ds-paper) !important;
}
.ds-cart-crosssell-cta.loading { opacity: .6; pointer-events: none; }

@media (max-width: 1024px) {
  .ds-cart-crosssells-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .ds-cart-crosssells-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .ds-cart-crosssells { margin-top: 36px; padding-top: 24px; }
  .ds-cart-crosssells-title { font-size: 18px; }
}
@media (max-width: 400px) {
  .ds-cart-crosssells-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .ds-cart-crosssell-body { padding: 10px 10px 12px; }
  .ds-cart-crosssell-name { font-size: 12px; }
}

/* ─── Confirm modal (qty=0 → potwierdź usunięcie) ─────────────────────── */
.ds-confirm-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: color-mix(in oklab, var(--ds-ink) 60%, transparent);
  backdrop-filter: blur(2px);
  animation: ds-confirm-fade-in .15s ease-out;
}
.ds-confirm-overlay[hidden] { display: none; }
body.ds-confirm-open { overflow: hidden; }
@keyframes ds-confirm-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes ds-confirm-pop { from { transform: scale(.96); opacity: 0; } to { transform: scale(1); opacity: 1; } }

.ds-confirm-dialog {
  background: var(--ds-paper);
  border-radius: 18px;
  padding: 28px;
  max-width: 420px;
  width: 100%;
  box-shadow: 0 20px 50px -10px rgba(0, 0, 0, .25);
  border: 1px solid var(--ds-line);
  animation: ds-confirm-pop .18s ease-out;
}
.ds-confirm-title {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 700;
  color: var(--ds-ink);
  line-height: 1.25;
}
.ds-confirm-text {
  margin: 0 0 22px;
  font-size: 14px;
  color: var(--ds-ink-soft);
  line-height: 1.5;
}
.ds-confirm-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.ds-confirm-actions .ds-btn { min-width: 110px; justify-content: center; }
@media (max-width: 480px) {
  .ds-confirm-actions { flex-direction: column-reverse; }
  .ds-confirm-actions .ds-btn { width: 100%; }
}

/* ─── InPost paczkomat row w koszyku — wybor punktu odbioru ─── */

/* Wrap w `<li>` w `.ds-cart-totals-list` — pelna szerokosc, bez split label/value. */
.ds-cart-totals .ds-cart-inpost-row {
  display: block !important;
  padding: 12px 0 !important;
  border-top: 1px dashed var(--ds-line);
}
.ds-cart-inpost-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

/* Gdy wrap zostal przeniesiony pod chosen radio shipping method (mounted) -
   tighter spacing, mniejszy padding, indent pod label aby wizualnie laczyl sie z metoda. */
.ds-cart-totals ul.shipping_method li .ds-cart-inpost-wrap-mounted,
.ds-cart-totals ul#shipping_method li .ds-cart-inpost-wrap-mounted,
.ds-cart-totals ul.woocommerce-shipping-methods li .ds-cart-inpost-wrap-mounted {
  margin-top: 8px;
  padding: 10px 12px;
  background: color-mix(in oklab, var(--ds-olive) 4%, var(--ds-paper));
  border: 1px dashed color-mix(in oklab, var(--ds-olive) 30%, var(--ds-line));
  border-radius: 10px;
  gap: 8px;
}
.ds-cart-totals ul.shipping_method li .ds-cart-inpost-wrap-mounted #easypack_show_geowidget,
.ds-cart-totals ul#shipping_method li .ds-cart-inpost-wrap-mounted #easypack_show_geowidget,
.ds-cart-totals ul.woocommerce-shipping-methods li .ds-cart-inpost-wrap-mounted #easypack_show_geowidget {
  padding: 9px 16px !important;
  font-size: 13px !important;
}

/* Trigger button - olive jak nasze CTA. */
.ds-cart-totals #easypack_show_geowidget,
.ds-cart-totals .easypack_show_geowidget {
  background: var(--ds-olive) !important;
  color: var(--ds-paper) !important;
  border: 1px solid var(--ds-olive) !important;
  border-radius: 999px !important;
  padding: 11px 18px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.01em !important;
  cursor: pointer !important;
  box-shadow: none !important;
  text-transform: none !important;
  transition: background .15s, border-color .15s !important;
  width: 100% !important;
  max-width: 100% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  text-align: center !important;
  text-decoration: none !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  height: auto !important;
  line-height: 1.2 !important;
}
.ds-cart-totals #easypack_show_geowidget:hover,
.ds-cart-totals .easypack_show_geowidget:hover {
  background: var(--ds-olive-deep) !important;
  border-color: var(--ds-olive-deep) !important;
  color: var(--ds-paper) !important;
}
.ds-cart-totals #easypack_show_geowidget svg {
  flex-shrink: 0;
  stroke-width: 2;
}

/* Card "Wybrany paczkomat: ABC123" pod buttonem. */
.ds-cart-paczkomat-info {
  margin-top: 10px;
  padding: 10px 12px;
  background: color-mix(in oklab, var(--ds-olive) 6%, var(--ds-paper));
  border: 1px solid color-mix(in oklab, var(--ds-olive) 25%, var(--ds-line));
  border-radius: 10px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ds-ink);
  display: block;
}
.ds-cart-paczkomat-info.hidden-paczkomat-data {
  display: none !important;
}
.ds-cart-paczkomat-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ds-olive-deep);
  margin-bottom: 2px;
}
.ds-cart-paczkomat-info #selected-parcel-machine-id {
  font-weight: 600;
  word-break: break-word;
}
.ds-cart-paczkomat-info small {
  display: block;
  font-weight: 400;
  color: var(--ds-ink-soft, #6b6b6b);
  margin-top: 2px;
}

/* jBox modal z geowidgetem - upewnij sie ze jest powyzej wszystkiego. */
.jBox-Modal,
.jBox-wrapper { z-index: 99999 !important; }
.jBox-Modal inpost-geowidget { display: block; width: 100%; height: 100%; min-height: 500px; }

/* Ukryj "Wysyłka do: ulica X. Zmień adres" — przy paczkomacie myli usera. */
.ds-cart-page .woocommerce-shipping-destination,
.ds-cart-totals .woocommerce-shipping-destination,
.ds-cart-page .shipping-calculator-button,
.ds-cart-totals .shipping-calculator-button,
.ds-cart-page .shipping-calculator-form,
.ds-cart-totals .shipping-calculator-form {
  display: none !important;
}

/* CTA "Przejdz do podsumowania" disabled gdy brak paczkomatu */
.ds-cart-totals .checkout-button.ds-checkout-blocked,
.ds-cart-totals .ds-cart-cta.ds-checkout-blocked {
  opacity: 0.55 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
.ds-cart-paczkomat-required {
  margin-top: 8px;
  padding: 10px 12px;
  background: color-mix(in oklab, var(--ds-warning, #d97706) 8%, var(--ds-paper));
  border: 1px solid color-mix(in oklab, var(--ds-warning, #d97706) 30%, var(--ds-line));
  border-radius: 10px;
  color: var(--ds-warning-deep, #92400e);
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ds-cart-paczkomat-required svg { flex-shrink: 0; }

/* ─── v0.14.7: Shipping methods grouped (prepaid / cod) ──────── */
.ds-shipping-groups {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ds-shipping-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ds-shipping-group-head {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0 4px;
  border-left: 3px solid var(--ds-olive);
  padding-left: 10px;
}
.ds-shipping-group:nth-child(2) .ds-shipping-group-head {
  border-left-color: color-mix(in oklab, var(--ds-warning, #d97706) 60%, var(--ds-olive));
}
.ds-shipping-group-title {
  font-family: var(--ds-font-display);
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ds-ink);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.ds-shipping-group-sub {
  font-size: 11.5px;
  color: var(--ds-ink-muted);
  line-height: 1.3;
  font-style: italic;
}
.ds-shipping-methods-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* ─── WC handpicked products block (fallback styles) ──────────────────────
   Sekcja "Mozesz tez lubic" / "Polecane" itp. dodawana przez klienta
   blokiem Gutenberg `wp:woocommerce/handpicked-products` - na pustym koszyku.
   WP Rocket Remove Unused CSS strippuje natywne style WC blocks i tytuly
   spadaja do 8px + grid layout sie nie aplikuje. Wlasne style zachowuja
   widocznosc niezaleznie od WC core CSS. */
.ds-wc-page .wp-block-handpicked-products,
.ds-wc-page .wc-block-grid {
  margin: 36px 0 12px;
}

/* Heading bezposrednio nad handpicked - poprawiona widocznosc */
.ds-wc-page .wp-block-heading {
  font-family: var(--ds-font-display, 'Nunito', sans-serif);
  font-size: 24px;
  font-weight: 700;
  color: var(--ds-ink);
  letter-spacing: -0.01em;
  margin: 36px 0 18px;
  text-align: center;
}

.wc-block-grid__products {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 20px;
}
.wc-block-grid.has-6-columns .wc-block-grid__products { grid-template-columns: repeat(6, 1fr); }
.wc-block-grid.has-5-columns .wc-block-grid__products { grid-template-columns: repeat(5, 1fr); }
.wc-block-grid.has-4-columns .wc-block-grid__products { grid-template-columns: repeat(4, 1fr); }
.wc-block-grid.has-3-columns .wc-block-grid__products { grid-template-columns: repeat(3, 1fr); }
.wc-block-grid.has-2-columns .wc-block-grid__products { grid-template-columns: repeat(2, 1fr); }
.wc-block-grid.has-1-columns .wc-block-grid__products { grid-template-columns: 1fr; }

/* WC defaults narzucaja max-width:16.6667% + flex-basis:16.6667% na .wc-block-grid__product
   (z `wc-blocks.css`), co w grid container z `1fr` tracks (~298px) daje 16.6667% z 298 = 49px
   - karty mikroskopijne. Override calego flex/max-width zeby grid templating dzialal. */
.wc-block-grid__products .wc-block-grid__product,
.wc-block-grid .wc-block-grid__product,
ul.wc-block-grid__products li.wc-block-grid__product {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  max-width: none !important;
  flex: 1 1 auto !important;
  flex-basis: auto !important;
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  display: flex !important;
  flex-direction: column !important;
}
.wc-block-grid__product:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--ds-olive) 35%, var(--ds-line));
  box-shadow: 0 8px 24px -8px rgba(0,0,0,.12);
}
.wc-block-grid__product-link {
  display: flex;
  flex-direction: column;
  text-decoration: none !important;
  color: inherit;
  height: 100%;
}
.wc-block-grid__product-image,
.wc-block-grid__products .wc-block-grid__product .wc-block-grid__product-image {
  display: block !important;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ds-cream);
  width: 100% !important;
  height: auto !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
.wc-block-grid__product-image img,
.wc-block-grid__products .wc-block-grid__product .wc-block-grid__product-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .35s ease;
  border-radius: 0 !important;
  border: 0 !important;
  max-width: 100% !important;
}
.wc-block-grid__product:hover .wc-block-grid__product-image img {
  transform: scale(1.04);
}
.wc-block-grid__product-title {
  font-family: var(--ds-font-display, 'Nunito', sans-serif);
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  color: var(--ds-ink) !important;
  margin: 12px 14px 8px !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}
.wc-block-grid__product-price {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--ds-olive-deep) !important;
  margin: auto 14px 14px !important;
  display: block;
}
.wc-block-grid__product-price del {
  color: var(--ds-ink-muted);
  font-weight: 400;
  font-size: 12px;
  margin-right: 4px;
}
.wc-block-grid__product-price ins {
  text-decoration: none;
}
.wc-block-grid__product-onsale {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--ds-olive);
  color: var(--ds-paper);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  z-index: 2;
}

@media (max-width: 1100px) {
  .wc-block-grid.has-6-columns .wc-block-grid__products,
  .wc-block-grid.has-5-columns .wc-block-grid__products,
  .wc-block-grid.has-4-columns .wc-block-grid__products {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 720px) {
  .wc-block-grid.has-6-columns .wc-block-grid__products,
  .wc-block-grid.has-5-columns .wc-block-grid__products,
  .wc-block-grid.has-4-columns .wc-block-grid__products,
  .wc-block-grid.has-3-columns .wc-block-grid__products {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .ds-wc-page .wp-block-heading { font-size: 20px; margin: 28px 0 14px; }
  .wc-block-grid__product-title { font-size: 13px !important; margin: 10px 12px 6px !important; }
  .wc-block-grid__product-price { font-size: 13px !important; margin: auto 12px 12px !important; }
}

/* ─── Bestsellery na pustym koszyku (custom, bez WC blocks) ───────
   Zastepuje stary block wp:woocommerce/handpicked-products zeby
   1) nie polegac na zewnetrznych klasach .wc-block-grid* (UCSS strippowal)
   2) zawsze pokazywac 12 produktow zamiast 6 hardcoded
   3) dynamicznie - top sprzedaz zamiast statyczna lista IDs */
.ds-cart-recommend {
  margin: 48px auto 24px;
  max-width: 1280px;
  padding: 0 16px;
}
.ds-cart-recommend-title {
  font-family: var(--ds-font-display, 'Nunito', sans-serif);
  font-size: 26px;
  font-weight: 700;
  color: var(--ds-ink);
  text-align: center;
  margin: 0 0 28px;
  letter-spacing: -0.01em;
}
.ds-cart-recommend-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px;
}
.ds-cart-recommend-card {
  list-style: none;
  margin: 0;
  padding: 0;
  background: var(--ds-paper);
  border: 1px solid var(--ds-line);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.ds-cart-recommend-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--ds-olive) 35%, var(--ds-line));
  box-shadow: 0 10px 28px -10px rgba(0,0,0,.14);
}
.ds-cart-recommend-link {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.ds-cart-recommend-imgwrap {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ds-cream);
}
.ds-cart-recommend-img,
.ds-cart-recommend-imgwrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
  border-radius: 0;
}
.ds-cart-recommend-card:hover .ds-cart-recommend-img,
.ds-cart-recommend-card:hover .ds-cart-recommend-imgwrap img {
  transform: scale(1.04);
}
.ds-cart-recommend-imgph {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--ds-cream), var(--ds-line));
}
.ds-cart-recommend-sale {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--ds-olive-deep);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  letter-spacing: 0.04em;
  z-index: 2;
  text-transform: uppercase;
}
.ds-cart-recommend-name {
  font-family: var(--ds-font-display, 'Nunito', sans-serif);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  color: var(--ds-ink);
  margin: 12px 14px 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}
.ds-cart-recommend-price {
  font-size: 14px;
  font-weight: 700;
  color: var(--ds-olive-deep);
  margin: auto 14px 14px;
  display: block;
}
.ds-cart-recommend-price del {
  color: var(--ds-ink-muted, #999);
  font-weight: 400;
  font-size: 12px;
  margin-right: 4px;
}
.ds-cart-recommend-price ins {
  text-decoration: none;
}

@media (max-width: 1100px) {
  .ds-cart-recommend-grid { grid-template-columns: repeat(4, 1fr); }
  .ds-cart-recommend-card:nth-child(n+9) { display: none; }
}
@media (max-width: 720px) {
  .ds-cart-recommend { margin: 32px auto 16px; }
  .ds-cart-recommend-title { font-size: 20px; margin: 0 0 18px; }
  .ds-cart-recommend-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .ds-cart-recommend-card:nth-child(n+7) { display: none; }
  .ds-cart-recommend-name { font-size: 13px; margin: 10px 12px 4px; }
  .ds-cart-recommend-price { font-size: 13px; margin: auto 12px 12px; }
}
