/*
Theme Name: VONSACE Clean
Author: VONSACE Studio
Description: Clean premium WooCommerce theme. v24.0 — mobile social icons fix, mobile cart overflow fix.
Version: 24.0.0
Text Domain: vonsace
WC requires at least: 7.0
WC tested up to: 9.9
*/

/* ═══════════════════════════ TOKENS ═══════════════════════════ */
:root {
  --w:    #FFFFFF;
  --bg:   #F8F7F5;
  --bg2:  #F2F0EC;
  --line: #E8E4DE;
  --lne2: #D4CFC7;
  --ink:  #1A1714;
  --mid:  #5C5650;
  --soft: #9C9690;
  --cop:  #B8722E;
  --cop2: #D4904A;
  --red:  #B33030;
  --grn:  #2A6040;

  --fd: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --fb: 'Lato', system-ui, sans-serif;

  --rad: 3px;
  --t:   .2s ease;
  --pad: 60px;
  --max: 1340px;
  --sh:  0 2px 16px rgba(26,23,20,.08);
}

/* ═══════════════════════════ RESET ═══════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; overflow-x: hidden; }
/* WAŻNE: overflow-x musi być na html, NIE na body.
   body z overflow tworzy nowy stacking context który łamie position:fixed
   używane przez modal mapy InPost — mapa renderuje się poza ekranem. */
body {
  font-family: var(--fb);
  background: var(--w);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--cop); text-decoration: none; transition: color var(--t); }
a:hover { color: var(--ink); }
h1,h2,h3,h4,h5 { font-family: var(--fd); font-weight: 500; line-height: 1.2; color: var(--ink); }
p { color: var(--mid); line-height: 1.8; margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }
ul { list-style: none; }
::selection { background: var(--ink); color: var(--w); }

/* ═══════════════════════════ UTILS ═══════════════════════════ */
.container { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.tag { display: inline-block; font-size: .65rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--cop); margin-bottom: 10px; }
.tag::before { content: '— '; }

.btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--fb); font-size: .8rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 14px 32px; border-radius: var(--rad); border: none; cursor: pointer; transition: background var(--t), color var(--t), transform var(--t); text-decoration: none; line-height: 1; }
.btn:active { transform: scale(.98); }
.btn-primary { background: var(--ink); color: var(--w); }
.btn-primary:hover { background: var(--cop); color: var(--w); }
.btn-secondary { background: var(--w); color: var(--ink); border: 1.5px solid var(--lne2); }
.btn-secondary:hover { border-color: var(--ink); }
.link-arrow { font-size: .78rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--ink); display: inline-flex; align-items: center; gap: 6px; }
.link-arrow::after { content: '→'; }
.link-arrow:hover { color: var(--cop); }

/* ═══════════════════════════ PROMO BAR ═══════════════════════════ */
#vons-promo {
  background: var(--ink);
  color: rgba(255,255,255,.7);
  text-align: center;
  padding: 9px 48px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  position: relative;
}
#vons-promo-close {
  position: absolute;
  right: 16px; top: 50%;
  transform: translateY(-50%);
  background: none; border: none;
  color: rgba(255,255,255,.35);
  font-size: 1.1rem; line-height: 1;
  cursor: pointer;
  transition: color .2s;
}
#vons-promo-close:hover { color: rgba(255,255,255,.85); }

/* ═══════════════════════════ HEADER / NAV ═══════════════════════════ */
#vons-nav {
  background: rgba(255,255,255,.97);
  /* backdrop-filter USUNIĘTY — tworzy nowy stacking context przez co
     position:fixed elementów potomnych (mapa InPost) jest relatywne
     do nav, nie do viewport. Mapa pakczomatów była niewidoczna. */
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 900;
  transition: box-shadow .3s;
}
#vons-nav.scrolled { box-shadow: 0 2px 20px rgba(26,23,20,.09); }

.vons-nav-wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
  height: 68px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

/* ── Logo ── */
.vons-logo { flex-shrink: 0; justify-self: start; }
.vons-logo a {
  display: flex; flex-direction: column; align-items: flex-start;
  text-decoration: none; line-height: 1;
}
.vons-logo-name {
  font-family: var(--fd);
  font-size: 1.5rem; font-weight: 700;
  letter-spacing: .16em; color: var(--ink); text-transform: uppercase;
}
.vons-logo-sub {
  font-size: .5rem; font-weight: 700;
  letter-spacing: .38em; text-transform: uppercase;
  color: var(--cop); margin-top: 1px;
}
/* custom logo image */
.vons-logo .custom-logo,
.vons-logo-img {
  display: block;
  height: 38px !important;
  width: auto !important;
  max-height: 38px !important;
  max-width: 200px !important;
  object-fit: contain;
}

/* ── Desktop menu ── */
.vons-menu {
  display: flex; align-items: center; justify-content: center;
  height: 68px; gap: 0; list-style: none; margin: 0; padding: 0;
}
.vons-item {
  position: relative; height: 100%;
  display: flex; align-items: center;
}
/* Link / span główny */
.vons-item > a,
.vons-item > span {
  display: flex; align-items: center; gap: 5px;
  height: 100%; padding: 0 14px;
  font-size: .72rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--mid); white-space: nowrap;
  cursor: pointer; border: none; background: none;
  position: relative; transition: color var(--t);
}
.vons-item > a::after,
.vons-item > span::after {
  content: ''; position: absolute;
  bottom: 0; left: 14px; right: 14px;
  height: 2px; background: var(--cop);
  border-radius: 1px 1px 0 0;
  transform: scaleX(0);
  transition: transform .25s cubic-bezier(.4,0,.2,1);
}
.vons-item:hover > a,
.vons-item:hover > span { color: var(--ink); }
.vons-item:hover > a::after,
.vons-item:hover > span::after { transform: scaleX(1); }
.vons-shop-link { color: var(--cop) !important; }
.vons-shop-link::after { background: var(--cop) !important; }

/* Strzałka */
.vons-arrow {
  width: 10px; height: 10px; flex-shrink: 0;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  transition: transform .2s;
}
.vons-item:hover .vons-arrow { transform: rotate(180deg); }

/* ── Dropdown ── */
.vons-drop {
  position: absolute;
  top: 100%; left: 0;
  min-width: 260px;
  background: var(--w);
  border: 1px solid var(--line);
  border-top: 2px solid var(--cop);
  border-radius: 0 0 var(--rad) var(--rad);
  box-shadow: 0 12px 40px rgba(26,23,20,.12);
  padding: 8px 0;
  opacity: 0; visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
  z-index: 910;
}
.vons-item:hover .vons-drop {
  opacity: 1; visibility: visible; transform: none;
}
.vons-drop-header {
  padding: 8px 20px 6px;
  font-size: .58rem; font-weight: 700;
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--cop);
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}
.vons-drop a {
  display: flex; align-items: center; gap: 0;
  padding: 9px 20px;
  font-size: .8rem; font-weight: 600;
  color: var(--mid); text-decoration: none;
  transition: background .14s, color .14s, padding-left .14s;
}
.vons-drop a:hover {
  background: var(--bg); color: var(--ink); padding-left: 26px;
}
.vons-drop-all { border-top: 1px solid var(--line); margin-top: 4px; }
.vons-drop-all a { color: var(--cop) !important; font-weight: 700; font-size: .76rem; }
.vons-drop-all a:hover { color: var(--ink) !important; }

/* ── Akcje ── */
.vons-actions {
  display: flex; align-items: center;
  gap: 2px; flex-shrink: 0; justify-self: end; margin-left: 0;
}
.vons-icon-btn {
  width: 40px; height: 40px; border-radius: 50%;
  border: none; background: none;
  color: var(--mid); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--t), color var(--t);
  text-decoration: none; position: relative;
}
.vons-icon-btn:hover { background: var(--bg2); color: var(--ink); }
.vons-icon-btn svg {
  width: 18px; height: 18px;
  stroke: currentColor; fill: none;
  stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round;
  display: block;
}

/* ── Cart hover preview ── */
.vons-cart-hover {
  position: relative;
}
.vons-cart-preview {
  position: absolute;
  top: calc(100% + 2px);
  right: 0;
  width: 320px;
  background: var(--w);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  box-shadow: 0 8px 32px rgba(26,23,20,.12);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
  z-index: 1000;
  pointer-events: none;
}
.vons-cart-hover:hover .vons-cart-preview,
.vons-cart-preview:hover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
/* Mostek — wypełnia lukę między przyciskiem a dropdownem */
.vons-cart-hover::after {
  content: '';
  position: absolute;
  top: 100%;
  right: 0;
  width: 100%;
  height: 10px;
}
.mini-cart-ttl {
  font-family: var(--fb);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink);
  padding: 14px 18px 10px;
  border-bottom: 1px solid var(--line);
}
.mini-cart-inner .woocommerce-mini-cart { list-style: none; padding: 0; margin: 0; max-height: 260px; overflow-y: auto; }
.mini-cart-inner .woocommerce-mini-cart__empty-message { padding: 20px 18px; color: var(--soft); font-size: .85rem; margin: 0; text-align: center; }
.mini-cart-inner .woocommerce-mini-cart-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  font-size: .82rem;
  color: var(--ink);
}
.mini-cart-inner .woocommerce-mini-cart-item img { width: 44px; height: 44px; object-fit: contain; border-radius: 2px; border: 1px solid var(--line); flex-shrink: 0; background: var(--bg); }
.mini-cart-inner .woocommerce-mini-cart-item a { color: var(--ink); text-decoration: none; font-weight: 600; line-height: 1.3; }
.mini-cart-inner .woocommerce-mini-cart-item a:hover { color: var(--cop); }
.mini-cart-inner .woocommerce-mini-cart-item .remove_from_cart_button { color: var(--soft); text-decoration: none; font-size: 1rem; float: none; margin-left: auto; flex-shrink: 0; }
.mini-cart-inner .woocommerce-mini-cart-item .quantity { color: var(--soft); font-size: .78rem; display: block; margin-top: 2px; }
.mini-cart-inner .woocommerce-mini-cart__total {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px;
  font-size: .82rem; font-weight: 700;
  border-bottom: 1px solid var(--line);
}
.mini-cart-inner .woocommerce-mini-cart__total .woocommerce-Price-amount { color: var(--cop); }
.mini-cart-inner .woocommerce-mini-cart__buttons {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  padding: 12px 18px;
}
.mini-cart-inner .woocommerce-mini-cart__buttons a {
  display: block; text-align: center;
  padding: 9px 12px;
  font-family: var(--fb); font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  border-radius: 2px; text-decoration: none;
  transition: background .2s, color .2s;
}
.mini-cart-inner .woocommerce-mini-cart__buttons .button:first-child { background: var(--bg2); color: var(--ink); border: 1px solid var(--line); }
.mini-cart-inner .woocommerce-mini-cart__buttons .button:first-child:hover { background: var(--ink); color: var(--w); }
.mini-cart-inner .woocommerce-mini-cart__buttons .checkout { background: var(--cop); color: var(--w); border: 1px solid var(--cop); }
.mini-cart-inner .woocommerce-mini-cart__buttons .checkout:hover { background: var(--ink); border-color: var(--ink); }
@media (max-width: 768px) {
  .vons-cart-preview { display: none !important; }
}

.vons-cart-count {
  position: absolute; top: 4px; right: 4px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--cop); color: var(--w);
  font-size: .5rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.vons-cart-count:empty { display: none; }

/* ── Hamburger — domyślnie ukryty, widoczny na mobile ── */
.vons-hamburger {
  display: none; flex-direction: column;
  gap: 5px; background: none; border: none;
  padding: 6px; cursor: pointer; margin-left: 8px;
}
.vons-hamburger span {
  display: block; width: 22px; height: 1.5px;
  background: var(--ink); border-radius: 1px;
  transition: all .28s ease;
}
.vons-hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.vons-hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.vons-hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 1100px) {
  /* Chowaj desktop menu, pokazuj hamburger */
  .vons-menu       { display: none !important; }
  .vons-hamburger  { display: flex !important; }
  /* Na mobilce: logo lewa, akcje prawa — bez środkowej kolumny menu */
  .vons-nav-wrap {
    display: flex !important;
    justify-content: space-between !important;
  }
}

@media (max-width: 480px) {
  /* Na bardzo małych ekranach drawer na pełną szerokość */
  .vons-mobile { width: 100% !important; max-width: 100% !important; }
}

/* ── Mobile overlay ── */
.vons-mob-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(26,23,20,.4);
  backdrop-filter: blur(2px);
  z-index: 980;
}
.vons-mob-overlay.open { display: block; }

/* ── Mobile drawer ── */
.vons-mobile {
  display: block; position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 320px; max-width: 100vw;
  background: var(--w);
  box-shadow: -12px 0 48px rgba(26,23,20,.16);
  z-index: 990;
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
  overflow-y: auto; overscroll-behavior: contain;
}
.vons-mobile.open { transform: none; }
.vons-mobile-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px; height: 64px;
  border-bottom: 1px solid var(--line);
}
.vons-mobile-logo {
  font-family: var(--fd); font-size: 1.3rem;
  font-weight: 700; letter-spacing: .14em;
  color: var(--ink); text-transform: uppercase;
}
.vons-mobile-close {
  width: 36px; height: 36px; border-radius: 50%;
  border: none; background: var(--bg); color: var(--mid);
  font-size: 1.2rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.vons-mobile-close:hover { background: var(--bg2); color: var(--ink); }
.vons-mob-section { border-bottom: 1px solid var(--line); }
.vons-mob-trigger {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 15px 20px; background: none; border: none;
  font-family: var(--fb); font-size: .78rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink); cursor: pointer; text-align: left;
}
.vons-mob-trigger svg {
  width: 14px; height: 14px;
  stroke: var(--soft); fill: none;
  stroke-width: 2; stroke-linecap: round; flex-shrink: 0;
  transition: transform .22s;
}
.vons-mob-trigger.open svg { transform: rotate(180deg); }
.vons-mob-sub { display: none; background: var(--bg); padding: 4px 0 10px; }
.vons-mob-sub.open { display: block; }
.vons-mob-sub a {
  display: block; padding: 9px 20px 9px 32px;
  font-size: .8rem; color: var(--mid); font-weight: 600;
  text-decoration: none; transition: color .15s, padding-left .15s;
}
.vons-mob-sub a:hover { color: var(--cop); padding-left: 38px; }
.vons-mob-all { color: var(--cop) !important; font-weight: 700 !important; }
.vons-mob-link {
  display: block; padding: 15px 20px;
  font-family: var(--fb); font-size: .78rem; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  color: var(--ink); text-decoration: none;
  border-bottom: 1px solid var(--line);
  transition: color .2s;
}
.vons-mob-link:hover { color: var(--cop); }
.vons-mob-link--cop { color: var(--cop) !important; }
.vons-mob-bottom {
  padding: 16px 20px; display: flex; flex-direction: column; gap: 8px;
  border-top: 1px solid var(--line); margin-top: 8px;
}
.vons-mob-bottom a {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; font-size: .78rem; font-weight: 700;
  color: var(--mid); background: var(--bg);
  border-radius: var(--rad); text-decoration: none;
  transition: background .2s, color .2s;
}
.vons-mob-bottom a:hover { background: var(--bg2); color: var(--ink); }
.vons-mob-bottom a svg {
  width: 16px; height: 16px;
  stroke: var(--cop); fill: none;
  stroke-width: 1.8; stroke-linecap: round; flex-shrink: 0;
}

/* ═══════════════════════════ HERO ═══════════════════════════ */
/* ── Hero — pełny ekran ── */
.hero-screen {
  display: flex;
  flex-direction: column;
  height: calc(100dvh - 68px); /* 68px = wysokość navbara */
  min-height: 560px;
  border-bottom: 1px solid var(--line);
}
.hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  flex: 1;          /* zajmuje całą pozostałą wysokość */
  overflow: hidden;
}
.hero-content { display: flex; flex-direction: column; justify-content: center; padding: 80px var(--pad); border-right: 1px solid var(--line); }
.hero-kicker { font-size: .7rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--cop); margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.hero-kicker::before { content: ''; width: 32px; height: 1.5px; background: var(--cop); }
.hero-h1 { font-family: var(--fd); font-size: clamp(2.6rem, 4.5vw, 5.2rem); font-weight: 400; line-height: 1.05; color: var(--ink); margin-bottom: 24px; }
.hero-lead { font-size: .95rem; color: var(--mid); line-height: 1.85; max-width: 400px; margin-bottom: 40px; }
.hero-cta { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.hero-visual { background: var(--bg); display: flex; flex-direction: column; overflow: hidden; }
.hero-img-main { flex: 1; overflow: hidden; }
.hero-img-main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-placeholder { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; font-family: var(--fd); font-size: 1.4rem; color: var(--soft); font-style: italic; }

/* ── Pasek dolny — trust + statystyki ── */
.hero-bottom {
  display: flex;
  align-items: stretch;
  border-top: 1px solid var(--line);
  background: var(--bg);
  flex-shrink: 0;
}
.hero-bottom-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 28px;
  height: 58px;
  font-size: .78rem;
  font-weight: 600;
  color: var(--mid);
  border-right: 1px solid var(--line);
  flex: 1;
  white-space: nowrap;
}
.hero-bottom-item svg { width: 18px; height: 18px; stroke: var(--cop); flex-shrink: 0; }
.hero-bottom-sep { width: 1px; background: var(--line); flex-shrink: 0; display: none; }
.hero-bottom-stat {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  text-align: center;
  flex: 0 0 120px;
}
.hero-bottom-stat strong { font-family: var(--fd); font-size: 1.5rem; font-weight: 400; color: var(--ink); line-height: 1; }
.hero-bottom-stat span { font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--soft); }
.hero-bottom-item:last-child { border-right: none; }

/* Trust bar */
.trust-bar { display: flex; justify-content: center; align-items: stretch; border-bottom: 1px solid var(--line); border-top: 1px solid var(--line); background: var(--bg); }
.trust-item { flex: 1; display: flex; align-items: center; gap: 12px; padding: 18px 32px; border-right: 1px solid var(--line); font-size: .78rem; font-weight: 700; color: var(--mid); }
.trust-item:last-child { border-right: none; }
.trust-item svg { width: 20px; height: 20px; stroke: var(--cop); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }

/* ═══════════════════════════ SECTIONS ═══════════════════════════ */
.section { padding: 72px 0; }
.section-inner { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.section-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; }
.section-title { font-family: var(--fd); font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 400; }

/* ═══════════════════════════ WC PRODUCT GRID ═══════════════════════════ */
/* ═══ SIATKA PRODUKTÓW — strona główna (vons-prod-*) ═══ */
.vons-prod-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: 100%;
}
.vons-prod-card {
  background: var(--w);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .2s, box-shadow .2s;
}
.vons-prod-card:hover {
  border-color: var(--lne2);
  box-shadow: 0 4px 24px rgba(26,23,20,.07);
}
.vons-prod-img-wrap {
  display: block;
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.vons-prod-img-wrap img,
.vons-prod-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 12px !important;
  display: block !important;
  transition: transform .4s !important;
}
.vons-prod-card:hover .vons-prod-img { transform: scale(1.04); }
.vons-prod-body { padding: 12px 14px 8px; flex: 1; }
.vons-prod-name {
  display: block;
  font-size: .88rem;
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  line-height: 1.4;
  margin-bottom: 6px;
  transition: color .2s;
}
.vons-prod-name:hover { color: var(--cop); }
.vons-prod-price {
  font-family: var(--fb);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink);
}
.vons-prod-btn {
  display: block !important;
  width: 100% !important;
  padding: 12px !important;
  background: var(--ink) !important;
  color: var(--w) !important;
  font-family: var(--fb) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  text-decoration: none !important;
  border: none !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  transition: background .2s !important;
  margin-top: auto !important;
}
.vons-prod-btn:hover { background: var(--cop) !important; color: var(--w) !important; }

/* Responsive */
@media (max-width: 1100px) { .vons-prod-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .vons-prod-grid { grid-template-columns: repeat(1, 1fr); } }

/* ═══ SIATKA PRODUKTÓW — WooCommerce (ul.products) ═══ */
   WooCommerce generuje: <div class="woocommerce columns-4"><ul class="products columns-4">
   Musimy nadpisać oba elementy */
.woocommerce,
.woocommerce-page .woocommerce {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  clear: both !important;
}
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  clear: both !important;
  width: 100% !important;
  float: none !important;
  /* domyślnie 4 kolumny */
  grid-template-columns: repeat(4, 1fr) !important;
}
/* Respektuj klasę .columns-X którą WooCommerce dodaje */
.woocommerce ul.products.columns-1 { grid-template-columns: repeat(1, 1fr) !important; }
.woocommerce ul.products.columns-2 { grid-template-columns: repeat(2, 1fr) !important; }
.woocommerce ul.products.columns-3 { grid-template-columns: repeat(3, 1fr) !important; }
.woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, 1fr) !important; }
.woocommerce ul.products.columns-5 { grid-template-columns: repeat(5, 1fr) !important; }
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product { float: none !important; width: auto !important; margin: 0 !important; padding: 0 !important; background: var(--w) !important; border: 1px solid var(--line) !important; border-radius: var(--rad) !important; display: flex !important; flex-direction: column !important; overflow: hidden !important; transition: border-color .2s, box-shadow .2s !important; }
.woocommerce ul.products li.product:hover { border-color: var(--lne2) !important; box-shadow: 0 4px 24px rgba(26,23,20,.07) !important; }
.woocommerce ul.products li.product a.woocommerce-loop-product__link { display: flex !important; flex-direction: column !important; flex: 1 !important; text-decoration: none !important; }
.woocommerce ul.products li.product img { width: 100% !important; aspect-ratio: 1/1 !important; height: auto !important; object-fit: contain !important; background: var(--bg) !important; border-bottom: 1px solid var(--line) !important; padding: 12px !important; display: block !important; transition: transform .4s !important; }
.woocommerce ul.products li.product:hover img { transform: scale(1.04) !important; }
.woocommerce span.onsale { background: var(--cop) !important; color: var(--w) !important; border-radius: var(--rad) !important; font-size: .6rem !important; font-weight: 700 !important; padding: 4px 10px !important; min-width: auto !important; top: 10px !important; left: 10px !important; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: var(--fb) !important; font-size: .88rem !important; font-weight: 600 !important; color: var(--ink) !important; padding: 12px 14px 4px !important; margin: 0 !important; line-height: 1.4 !important; }
.woocommerce ul.products li.product .price { font-family: var(--fd) !important; font-size: 1rem !important; color: var(--ink) !important; padding: 2px 14px 12px !important; display: block !important; margin: 0 !important; }
.woocommerce ul.products li.product .price del { color: var(--soft) !important; font-size: .82rem !important; }
.woocommerce ul.products li.product .price ins { text-decoration: none !important; color: var(--cop) !important; }
.woocommerce ul.products li.product .button, .woocommerce ul.products li.product a.button { display: block !important; width: 100% !important; margin: auto 0 0 !important; padding: 12px !important; background: var(--ink) !important; color: var(--w) !important; font-family: var(--fb) !important; font-size: .72rem !important; font-weight: 700 !important; letter-spacing: .06em !important; text-transform: uppercase !important; text-align: center !important; border: none !important; border-radius: 0 !important; cursor: pointer !important; transition: background .2s !important; text-decoration: none !important; }
.woocommerce ul.products li.product .button:hover { background: var(--cop) !important; color: var(--w) !important; }

/* Shop archive page */
.woocommerce-shop .woocommerce, .tax-product_cat .woocommerce { max-width: var(--max) !important; margin: 0 auto !important; padding: 40px var(--pad) 80px !important; }
.woocommerce .woocommerce-result-count { font-size: .72rem !important; color: var(--soft) !important; float: none !important; display: inline-block !important; margin-bottom: 20px !important; }
.woocommerce .woocommerce-ordering { float: none !important; display: inline-block !important; margin: 0 0 20px 12px !important; }
.woocommerce .woocommerce-ordering select { background: var(--w) !important; border: 1px solid var(--lne2) !important; color: var(--ink) !important; font-family: var(--fb) !important; font-size: .8rem !important; padding: 8px 14px !important; border-radius: var(--rad) !important; outline: none !important; }

/* ═══════════════════════════════════════════════════════════
   ★★★ SINGLE PRODUCT — DEFINITYWNY FIX ★★★
   FLEXBOX + EXPLICIT WIDTH — brak contain, brak sticky height
═══════════════════════════════════════════════════════════ */

/* Breadcrumb */
.vp-page .woocommerce-breadcrumb { font-size: .68rem !important; letter-spacing: .1em !important; text-transform: uppercase !important; color: var(--soft) !important; border-bottom: 1px solid var(--line) !important; padding: 14px var(--pad) !important; margin: 0 !important; display: block !important; }
.vp-page .woocommerce-breadcrumb a { color: var(--soft) !important; }
.vp-page .woocommerce-breadcrumb a:hover { color: var(--cop) !important; }

/* Wrapper */
.vp-page { display: block; min-height: 60vh; }

/* ★ KLUCZOWE: Flexbox layout z EXPLICIT WIDTH ★ */
.vp-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  width: 100%;
  /* NIE grid, NIE contain */
}

/* ★ Galeria — FIXED 50% WIDTH ★ */
.vp-gallery {
  flex: 0 0 50%;
  width: 50%;
  max-width: 50%;
  min-width: 0;
  background: var(--bg);
  border-right: 1px solid var(--line);
  position: sticky;
  top: 68px;
  align-self: flex-start;
}

/* Wewnętrzna siatka: miniatury | główne zdjęcie */
.vp-gallery-inner {
  display: flex;
  align-items: stretch;
}

/* Pionowy rail miniatur */
.vp-thumbrail {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 76px;
  flex: 0 0 76px;
  width: 76px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 4px;
  padding: 20px 0 20px 16px;
  border-right: 1px solid var(--line);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--lne2) transparent;
}
.vp-thumb { width: 56px; height: 68px; border: 1.5px solid var(--line); background: var(--w); cursor: pointer; overflow: hidden; flex-shrink: 0; transition: border-color .2s; border-radius: 2px; }
.vp-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 4px; display: block; }
.vp-thumb.is-active { border-color: var(--ink); }
.vp-thumb:hover:not(.is-active) { border-color: var(--cop); }

/* Główny widok zdjęcia */
.vp-mainview {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  min-width: 0;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 32px 24px;
  overflow: hidden;
  flex: 1;
  align-items: center;
}
.vp-mainview-wm { position: absolute; bottom: -60px; right: -20px; font-family: var(--fd); font-size: 38vmin; font-weight: 900; color: transparent; -webkit-text-stroke: 1px rgba(26,23,20,.04); pointer-events: none; user-select: none; z-index: 0; }
.vp-sale-badge { position: absolute; top: 20px; right: 20px; z-index: 3; background: var(--cop); color: var(--w); font-size: .56rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; padding: 6px 14px; border-radius: 2px; }
.vp-zoom-hint { position: absolute; top: 20px; left: 20px; z-index: 3; display: flex; align-items: center; gap: 6px; font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: var(--soft); }

/* Kontener + zdjęcie główne */
.vp-img-stage { position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; width: 100%; overflow: hidden; }
.vp-main-img { width: 100%; height: auto; max-height: 480px; object-fit: contain; display: block; transition: opacity .2s ease, transform .2s ease; cursor: zoom-in; }
.vp-img-stage:hover .vp-main-img { transform: scale(1.02); }

/* Certyfikaty */
.vp-certs { position: absolute; bottom: 20px; left: 20px; z-index: 3; display: flex; flex-direction: column; gap: 5px; }
.vp-cert { display: flex; align-items: center; gap: 7px; background: rgba(248,247,245,.9); backdrop-filter: blur(6px); border: 1px solid var(--line); padding: 5px 11px; font-size: .58rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink); border-radius: 2px; }

/* ★ Summary — FIXED 50% WIDTH ★ */
.vp-info {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  width: 50%;
  max-width: 50%;
  min-width: 0;
  padding: 48px 52px 80px;
  overflow-y: auto;
}

/* Topbar */
.vp-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; gap: 16px; }
.vp-brand-tag { font-size: .58rem; letter-spacing: .36em; text-transform: uppercase; color: var(--cop); font-weight: 700; }
.vp-rating-row { display: flex; align-items: center; gap: 7px; }
.vp-stars { color: var(--cop); font-size: .75rem; letter-spacing: 2px; }
.vp-rating-val { font-size: .8rem; font-weight: 600; color: var(--ink); }
.vp-rating-link { font-size: .65rem; color: var(--soft); text-decoration: none; }
.vp-rating-link:hover { color: var(--cop); }

/* Tytuł */
.vp-title { font-family: var(--fd) !important; font-size: clamp(1.7rem, 2.8vw, 2.6rem) !important; font-weight: 400 !important; line-height: 1.1 !important; color: var(--ink) !important; margin: 0 0 8px !important; }

/* Podtytuł */
.vp-subtitle { font-size: .76rem; letter-spacing: .06em; color: var(--mid); line-height: 1.6; margin-bottom: 0; }

/* Divider */
.vp-hr { width: 100%; height: 1px; background: var(--line); margin: 22px 0; }

/* Cena */
.vp-price-block { margin-bottom: 4px; }
.vp-price-main .woocommerce-Price-amount { font-family: var(--fb) !important; font-size: 2.4rem !important; font-weight: 300 !important; color: var(--ink) !important; line-height: 1 !important; letter-spacing: .01em !important; }
.vp-price-main ins { text-decoration: none !important; }
.vp-price-main del .woocommerce-Price-amount { font-size: 1.1rem !important; color: var(--soft) !important; text-decoration: line-through !important; }
.vp-price-note { font-size: .65rem; color: var(--soft); letter-spacing: .06em; }

/* Krótki opis */
.vp-short-desc { font-size: .9rem; line-height: 1.85; color: var(--mid); margin-bottom: 20px; }
.vp-short-desc p { font-size: .9rem; color: var(--mid); margin-bottom: .5em; }

/* Profil zapachowy */
.vp-scent-block { background: var(--bg); border: 1px solid var(--line); padding: 16px 20px; margin-bottom: 20px; border-radius: 2px; }
.vp-scent-label { font-size: .58rem; letter-spacing: .3em; text-transform: uppercase; color: var(--cop); margin-bottom: 12px; display: flex; align-items: center; gap: 10px; font-weight: 700; }
.vp-scent-label::before { content: ''; width: 16px; height: 1px; background: var(--cop); }
.vp-scent-notes { display: flex; }
.vp-scent-note { flex: 1; display: flex; align-items: center; justify-content: center; padding: 0 10px; text-align: center; }
.vp-scent-note:not(:last-child) { border-right: 1px solid var(--line); }
.vp-scent-name { font-family: var(--fd); font-size: .9rem; font-style: italic; color: var(--ink); }

/* Warianty WooCommerce */
.vp-variations { width: 100%; border-collapse: collapse; margin-bottom: 16px; }
.vp-variations td { padding: 6px 0; }
.vp-variations .label label { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink); font-weight: 700; padding-right: 14px; }
.vp-variations select { background: var(--bg); border: 1.5px solid var(--lne2); color: var(--ink); font-family: var(--fb); font-size: .85rem; padding: 10px 14px; border-radius: 2px; outline: none; cursor: pointer; min-width: 160px; -webkit-appearance: none; }
.vp-variations select:focus { border-color: var(--ink); }

/* Wiersz kupna */
.vp-buy-row { display: flex; gap: 10px; align-items: stretch; margin-bottom: 10px; }

/* Ilość */
.vp-qty { display: flex; border: 1.5px solid var(--lne2); border-radius: 2px; overflow: hidden; flex-shrink: 0; }
.vp-qty-btn { width: 44px; height: 54px; background: var(--bg); border: none; cursor: pointer; font-size: 1.2rem; color: var(--ink); transition: background .2s; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.vp-qty-btn:hover { background: var(--bg2); }
.vp-qty-input { width: 52px; height: 54px; text-align: center; border: none; border-left: 1.5px solid var(--lne2); border-right: 1.5px solid var(--lne2); background: var(--w); font-family: var(--fd); font-size: 1.05rem; color: var(--ink); outline: none; -moz-appearance: textfield; }
.vp-qty-input::-webkit-outer-spin-button, .vp-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Przycisk Dodaj do koszyka */
.vp-add-btn { flex: 1; height: 54px; background: var(--ink); color: var(--w); border: none; cursor: pointer; font-family: var(--fb); font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; gap: 6px; text-decoration: none !important; padding: 0 20px; border-radius: 2px; transition: background .25s; }
.vp-add-btn:hover { background: var(--cop); color: var(--w) !important; }
/* Override WooCommerce .button.alt purple — must beat their specificity */
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce div.product form.cart button[type="submit"],
.woocommerce div.product .cart .button,
.vp-cart-form .single_add_to_cart_button,
.vp-cart-form button.alt,
.vp-add-btn.button,
.vp-add-btn.alt,
.vp-add-btn.button.alt {
  background: var(--ink) !important;
  color: var(--w) !important;
  border-color: var(--ink) !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.vp-cart-form .single_add_to_cart_button:hover,
.vp-add-btn.button:hover,
.vp-add-btn.alt:hover {
  background: var(--cop) !important;
  border-color: var(--cop) !important;
  color: var(--w) !important;
}
.vp-add-label, .vp-add-price { position: relative; z-index: 1; }
.vp-add-price { opacity: .7; font-size: .65rem; font-weight: 400; }
.vp-add-btn--oos { background: var(--soft) !important; cursor: not-allowed !important; }

/* Wishlist */
.vp-wish-btn { width: 54px; height: 54px; border: 1.5px solid var(--lne2); background: none; cursor: pointer; color: var(--soft); display: flex; align-items: center; justify-content: center; transition: all .25s; flex-shrink: 0; border-radius: 2px; }
.vp-wish-btn:hover, .vp-wish-btn.is-active { border-color: var(--cop); color: var(--cop); }
.vp-wish-btn.is-active svg { fill: var(--cop); }

/* Kup teraz */
.vp-buynow-btn { width: 100%; padding: 14px; background: transparent; border: 1.5px solid var(--lne2); color: var(--mid); font-family: var(--fb); font-size: .7rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; transition: border-color .2s, color .2s; margin-bottom: 20px; display: block; border-radius: 2px; }
.vp-buynow-btn:hover { border-color: var(--ink); color: var(--ink); }

/* Trust strip */
.vp-trust { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); margin-bottom: 24px; border: 1px solid var(--line); border-radius: 2px; overflow: hidden; }
.vp-trust-item { background: var(--bg); padding: 12px 8px; display: flex; flex-direction: column; align-items: center; gap: 5px; text-align: center; }
.vp-trust-item svg { color: var(--cop); flex-shrink: 0; }
.vp-trust-item span { font-size: .55rem; letter-spacing: .1em; text-transform: uppercase; color: var(--mid); line-height: 1.4; font-weight: 600; }

/* Meta */
.vp-meta-strip { display: flex; flex-direction: column; gap: 5px; }
.vp-meta-row { font-size: .68rem; color: var(--soft); }
.vp-meta-key { font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink); margin-right: 8px; font-weight: 700; }
.vp-meta-row a { color: var(--cop) !important; }
.vp-meta-row a:hover { color: var(--ink) !important; }

/* ── Taby ── */
.vp-tabs-wrap { border-top: 1px solid var(--line); padding: 0 var(--pad) 60px; max-width: var(--max); margin: 0 auto; }
.vp-tabs-nav { display: flex; border-bottom: 1px solid var(--line); margin-bottom: 36px; overflow-x: auto; }
.vp-tab-btn { padding: 16px 24px; background: none; border: none; cursor: pointer; font-family: var(--fb); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--soft); position: relative; white-space: nowrap; font-weight: 700; transition: color .2s; }
.vp-tab-btn:hover { color: var(--ink); }
.vp-tab-btn.is-active { color: var(--ink); }
.vp-tab-btn.is-active::after { content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 2px; background: var(--cop); border-radius: 1px; }
.vp-tab-panel { display: none; }
.vp-tab-panel.is-active { display: block; }
.vp-desc-body { max-width: 780px; margin: 0 auto; }
.vp-desc-body p, .vp-desc-body li { font-size: .9rem; line-height: 1.9; color: var(--mid); margin-bottom: .75em; }
.vp-desc-body h2, .vp-desc-body h3 { font-family: var(--fd); color: var(--ink); margin: 1.5em 0 .5em; }
.vp-desc-body strong { color: var(--ink); font-weight: 600; }
.vp-desc-body ul, .vp-desc-body ol { padding-left: 1.2em; margin-bottom: 1em; }
.vp-empty-msg { color: var(--soft); font-size: .9rem; padding: 32px 0; }
.vp-spec-table { width: 100%; border-collapse: collapse; max-width: 640px; }
.vp-spec-table tr { border-bottom: 1px solid var(--line); }
.vp-spec-table tr:last-child { border-bottom: none; }
.vp-spec-table th { text-align: left; padding: 14px 20px 14px 0; font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--soft); font-weight: 700; width: 200px; vertical-align: top; }
.vp-spec-table td { padding: 14px 0; font-size: .9rem; color: var(--ink); }
#reviews { padding: 0; }
.woocommerce-Reviews-title { display: none !important; }
#reviews .woocommerce-review { padding: 20px 0; border-bottom: 1px solid var(--line); }
#reviews .woocommerce-review:last-child { border-bottom: none; }
#reviews .star-rating { color: var(--cop) !important; margin-bottom: 6px; }
#reviews .woocommerce-review .description p { font-size: .9rem; color: var(--mid); line-height: 1.8; }
.woocommerce #review_form #respond input[type="text"],
.woocommerce #review_form #respond input[type="email"],
.woocommerce #review_form #respond textarea { background: var(--bg) !important; border: 1.5px solid var(--lne2) !important; color: var(--ink) !important; font-family: var(--fb) !important; font-size: .88rem !important; padding: 10px 14px !important; border-radius: 2px !important; outline: none !important; }
.woocommerce #review_form #respond input#submit { background: var(--ink) !important; color: var(--w) !important; padding: 12px 28px !important; font-family: var(--fb) !important; font-size: .7rem !important; font-weight: 700 !important; letter-spacing: .12em !important; text-transform: uppercase !important; border: none !important; border-radius: 2px !important; cursor: pointer !important; }
.woocommerce #review_form #respond input#submit:hover { background: var(--cop) !important; }

/* ── Powiązane ── */
.vp-related { padding: 64px 0; background: var(--bg); border-top: 1px solid var(--line); max-width: 100%; }
.vp-related-head { margin-bottom: 28px; max-width: var(--max); margin-left: auto; margin-right: auto; padding: 0 var(--pad); }
.vp-related-head h2 { font-family: var(--fd); font-size: clamp(1.6rem, 2.8vw, 2.4rem); font-weight: 400; color: var(--ink); margin: 8px 0 0; line-height: 1.15; }
.vp-related-head h2 em { font-style: italic; color: var(--cop); }
.vp-rel-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.vp-rel-card { background: var(--w); text-decoration: none; display: block; overflow: hidden; border: 1px solid var(--line); border-radius: 2px; transition: border-color .2s, box-shadow .2s; }
.vp-rel-card:hover { border-color: var(--lne2); box-shadow: 0 4px 20px rgba(26,23,20,.07); }
.vp-rel-img { aspect-ratio: 1/1; background: var(--bg); position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.vp-rel-img img { width: 100%; height: 100%; object-fit: contain; padding: 8px; display: block; transition: transform .4s ease; }
.vp-rel-card:hover .vp-rel-img img { transform: scale(1.04); }
.vp-rel-quick { position: absolute; bottom: 0; left: 0; right: 0; padding: 11px; background: var(--ink); color: var(--w); font-family: var(--fb); font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; border: none; cursor: pointer; opacity: 0; transform: translateY(4px); transition: opacity .25s, transform .25s; }
.vp-rel-card:hover .vp-rel-quick { opacity: 1; transform: none; }
.vp-rel-info { padding: 14px 16px; border-top: 1px solid var(--line); }
.vp-rel-brand { font-size: .54rem; letter-spacing: .28em; text-transform: uppercase; color: var(--cop); margin-bottom: 5px; font-weight: 700; }
.vp-rel-name { font-size: .9rem; color: var(--ink); margin-bottom: 6px; line-height: 1.3; font-weight: 600; }
.vp-rel-price .woocommerce-Price-amount { font-family: var(--fd); font-size: 1rem; color: var(--ink); }

/* ═══════════════════════════ CART ═══════════════════════════ */
.woocommerce-cart .woo-main,
.woocommerce-cart .woo-main > .woocommerce {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}
.woocommerce table.shop_table { border-collapse: collapse !important; width: 100% !important; border: 1px solid var(--line) !important; border-radius: var(--rad) !important; overflow: hidden !important; }
.woocommerce table.shop_table th { padding: 12px 16px !important; font-size: .72rem !important; font-weight: 700 !important; letter-spacing: .08em !important; text-transform: uppercase !important; color: var(--soft) !important; background: var(--bg) !important; border-bottom: 1px solid var(--line) !important; text-align: left !important; }
.woocommerce table.shop_table td { padding: 16px !important; vertical-align: middle !important; border-bottom: 1px solid var(--line) !important; background: var(--w) !important; }
.woocommerce table.shop_table tbody tr:last-child td { border-bottom: none !important; }
.woocommerce table.shop_table tbody tr:hover td { background: var(--bg) !important; }
.woocommerce table.shop_table .product-thumbnail { width: 88px !important; }
.woocommerce table.shop_table .product-thumbnail img { width: 68px !important; height: 68px !important; object-fit: contain !important; background: var(--bg) !important; border: 1px solid var(--line) !important; border-radius: var(--rad) !important; padding: 4px !important; }
.woocommerce table.shop_table .product-name a { font-size: .95rem !important; font-weight: 600 !important; color: var(--ink) !important; }
.woocommerce table.shop_table .product-name a:hover { color: var(--cop) !important; }
.woocommerce table.shop_table input.qty { width: 60px !important; padding: 8px !important; text-align: center !important; border: 1.5px solid var(--lne2) !important; background: var(--bg) !important; border-radius: var(--rad) !important; font-size: .95rem !important; color: var(--ink) !important; outline: none !important; -moz-appearance: textfield !important; }
.woocommerce table.shop_table .remove { display: flex !important; align-items: center !important; justify-content: center !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; color: var(--soft) !important; font-size: 1.2rem !important; text-decoration: none !important; transition: all .2s !important; border: 1px solid transparent !important; }
.woocommerce table.shop_table .remove:hover { color: var(--red) !important; border-color: var(--red) !important; background: rgba(179,48,48,.06) !important; }
.woocommerce .cart .actions { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 14px 16px !important; background: var(--bg) !important; border-top: 1px solid var(--line) !important; }
.woocommerce .coupon { display: flex !important; }
.woocommerce .coupon input#coupon_code { padding: 10px 14px !important; width: 200px !important; background: var(--w) !important; border: 1.5px solid var(--lne2) !important; border-right: none !important; border-radius: var(--rad) 0 0 var(--rad) !important; font-size: .85rem !important; color: var(--ink) !important; outline: none !important; }
.woocommerce .coupon button[name="apply_coupon"] { padding: 10px 18px !important; background: var(--ink) !important; color: var(--w) !important; font-size: .72rem !important; font-weight: 700 !important; letter-spacing: .06em !important; text-transform: uppercase !important; border: none !important; border-radius: 0 var(--rad) var(--rad) 0 !important; cursor: pointer !important; }
.woocommerce .coupon button[name="apply_coupon"]:hover { background: var(--cop) !important; }
.woocommerce .actions button[name="update_cart"] { padding: 10px 18px !important; background: var(--w) !important; border: 1.5px solid var(--lne2) !important; border-radius: var(--rad) !important; font-size: .72rem !important; font-weight: 700 !important; letter-spacing: .06em !important; text-transform: uppercase !important; cursor: pointer !important; color: var(--mid) !important; }
.woocommerce .cart-collaterals { display: flex !important; gap: 40px !important; align-items: flex-start !important; margin-top: 32px !important; float: none !important; width: 100% !important; }
.woocommerce .cross-sells { flex: 1 !important; float: none !important; }
.woocommerce .cross-sells h2 { font-family: var(--fd) !important; font-size: 1.4rem !important; font-weight: 400 !important; margin-bottom: 20px !important; }
.woocommerce .cart_totals { flex: 0 0 360px !important; float: none !important; width: 360px !important; background: var(--bg) !important; border: 1px solid var(--line) !important; border-radius: var(--rad) !important; padding: 24px !important; }
.woocommerce .cart_totals h2 { font-family: var(--fd) !important; font-size: 1.1rem !important; font-weight: 600 !important; margin-bottom: 18px !important; }
.woocommerce .cart_totals table { border: none !important; width: 100% !important; }
.woocommerce .cart_totals table th, .woocommerce .cart_totals table td { border: none !important; border-bottom: 1px solid var(--line) !important; padding: 10px 0 !important; font-size: .85rem !important; background: transparent !important; color: var(--mid) !important; }
.woocommerce .cart_totals table tr.order-total td .woocommerce-Price-amount { font-family: var(--fd) !important; font-size: 1.7rem !important; color: var(--ink) !important; }
.woocommerce .wc-proceed-to-checkout { margin-top: 16px !important; }
.woocommerce .wc-proceed-to-checkout a.checkout-button { display: block !important; width: 100% !important; padding: 16px !important; background: var(--ink) !important; color: var(--w) !important; font-family: var(--fb) !important; font-size: .8rem !important; font-weight: 700 !important; letter-spacing: .08em !important; text-transform: uppercase !important; text-align: center !important; text-decoration: none !important; border-radius: var(--rad) !important; transition: background .25s !important; }
.woocommerce .wc-proceed-to-checkout a.checkout-button:hover { background: var(--cop) !important; }

/* ═══════════════════════════ CHECKOUT ═══════════════════════════ */

/* Sekcja koszyk w checkout */
.vons-checkout-cart {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  overflow: hidden;
  margin-bottom: 28px;
}
.vons-checkout-cart-title {
  padding: 11px 16px;
  background: var(--ink);
  color: var(--w);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}
.vons-checkout-cart-title .vons-co-num,
.vons-checkout-cart-title span.step-no {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--cop); color: var(--w);
  font-size: .62rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.vons-checkout-cart table { width: 100%; border-collapse: collapse; }
.vons-checkout-cart table th {
  padding: 9px 14px; font-size: .6rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--soft);
  border-bottom: 1px solid var(--line); text-align: left; background: var(--w);
}
.vons-checkout-cart table td { padding: 11px 14px; vertical-align: middle; border-bottom: 1px solid var(--line); background: var(--w); }
.vons-checkout-cart table tbody tr:last-child td { border-bottom: 1px solid var(--line); }

/* ═══════════════════════════════════════════════
   CHECKOUT — vons-co-form layout
   ═══════════════════════════════════════════════ */

/* Wrapper */
.woocommerce-checkout .woocommerce {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
}
.woocommerce-checkout #page-wrap > .woo-main {
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.woocommerce-checkout h1.page-title,
.woocommerce-checkout .entry-title { display: none !important; }
/* Ukryj domyślny toggle kuponu WooCommerce — mamy własny */
.woocommerce-checkout .woocommerce-form-coupon-toggle { display: none !important; }

/* ── Karta krok 1: koszyk na górze ── */
.vons-co-cart-section {
  margin-bottom: 16px;
}

/* ── Dół: 2 kolumny — lewa szersza, prawa węższa ── */
.vons-co-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 16px;
  align-items: start;
}
.vons-co-left { display: flex; flex-direction: column; gap: 12px; }
.vons-co-right { position: sticky; top: 80px; }

/* ── Sekcja — karta ── */
.vons-co-section {
  background: var(--w);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  overflow: hidden;
}

/* Nagłówek sekcji */
.vons-co-section-head {
  background: var(--ink);
  color: var(--w);
  padding: 9px 14px;
  font-family: var(--fb);
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}
.vons-co-num {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--cop); color: var(--w);
  font-size: .6rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

/* Body sekcji */
.vons-co-section-body { padding: 12px 14px; }

/* ── Tabela koszyka ── */
.vons-co-cart-table { width: 100%; border-collapse: collapse; }
.vons-co-cart-table th {
  padding: 7px 10px;
  font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--soft); border-bottom: 1px solid var(--line);
  text-align: left; background: var(--bg);
}
.vons-co-cart-table th.text-center { text-align: center; }
.vons-co-cart-table th.text-right  { text-align: right; }
.vons-co-cart-table td { padding: 9px 10px; vertical-align: middle; border-bottom: 1px solid var(--line); background: var(--w); font-size: .86rem; }
.vons-co-cart-table tbody tr:last-child td { border-bottom: 1px solid var(--line); }
.vons-co-cart-table td.text-center { text-align: center; }
.vons-co-cart-table td.text-right  { text-align: right; font-weight: 700; color: var(--ink); }

.vons-co-td-img { width: 52px; padding: 8px 0 8px 12px !important; }
.vons-co-td-img img { width: 42px; height: 42px; object-fit: contain; background: var(--bg); border: 1px solid var(--line); border-radius: 2px; padding: 3px; display: block; }
.vons-co-td-name a { font-weight: 600; color: var(--ink); text-decoration: none; font-size: .9rem; }
.vons-co-td-name a:hover { color: var(--cop); }
.vons-co-variant { display: block; font-size: .72rem; color: var(--soft); margin-top: 2px; }
.vons-co-td-ship { color: var(--mid); font-size: .82rem; }
.vons-co-td-qty  { color: var(--mid); }
.vons-co-td-price { color: var(--mid); white-space: nowrap; }
.vons-co-td-total { font-weight: 700; color: var(--ink) !important; white-space: nowrap; padding-right: 8px !important; }
.vons-co-td-remove { width: 32px; padding: 0 10px 0 0 !important; }
.vons-co-remove { color: var(--soft); display: flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 50%; transition: background .15s, color .15s; }
.vons-co-remove:hover { background: #fee2e2; color: #dc2626; }


/* ── Stepper ilości w tabeli checkout ── */
.vco-qty-wrap {
  display: inline-flex; align-items: center;
  background: var(--bg); border: 1.5px solid var(--lne2);
  border-radius: 4px; overflow: hidden;
}
.vco-qty-btn {
  width: 28px; height: 28px; background: none; border: none;
  color: var(--mid); font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; user-select: none;
  flex-shrink: 0;
}
.vco-qty-btn:hover { background: var(--lne2); color: var(--ink); }
.vco-qty-num {
  width: 32px; height: 28px; text-align: center;
  border: none; border-left: 1.5px solid var(--lne2); border-right: 1.5px solid var(--lne2);
  background: var(--w); font-family: var(--fd); font-size: .95rem;
  color: var(--ink); outline: none; -moz-appearance: textfield;
}
.vco-qty-num::-webkit-outer-spin-button,
.vco-qty-num::-webkit-inner-spin-button { -webkit-appearance: none; }
.vco-td-qty-ctrl { white-space: nowrap; }

/* Pasek kuponu */
.vons-co-coupon-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 11px 14px; background: var(--bg); border-top: 1px solid var(--line);
}
.vons-co-coupon-bar > svg { color: var(--soft); flex-shrink: 0; }
.vons-co-coupon-bar > span { font-size: .78rem; color: var(--mid); white-space: nowrap; }
#vons-coupon-code {
  border: 1.5px solid var(--lne2); border-radius: 2px;
  padding: 7px 12px; font-family: var(--fb); font-size: .85rem;
  outline: none; width: 180px; transition: border-color .2s;
}
#vons-coupon-code:focus { border-color: var(--ink); }
#vons-coupon-apply {
  padding: 7px 18px; background: var(--ink); color: var(--w);
  border: none; border-radius: 2px; font-size: .66rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; cursor: pointer;
  transition: background .2s;
}
#vons-coupon-apply:hover { background: var(--cop); }
.vons-co-coupon-active {
  background: var(--bg2); color: var(--ink); padding: 4px 10px;
  border-radius: 2px; font-size: .72rem; font-weight: 700;
}
.vons-co-coupon-active a { color: var(--soft); text-decoration: none; margin-left: 4px; }
.vons-co-free-ship { color: var(--cop); font-size: .75rem; font-weight: 700; }
.vons-co-ship-progress { font-size: .75rem; color: var(--mid); display: flex; align-items: center; gap: 5px; }
.vons-co-ship-progress strong { color: var(--ink); }

/* ── Pola formularza ── */
.vons-co-section-body .form-row,
.vons-co-section-body p.form-row { margin: 0 0 12px; }
.vons-co-section-body label,
.vons-co-section-body .woocommerce-input-wrapper label {
  font-size: .6rem !important; letter-spacing: .12em !important;
  text-transform: uppercase !important; font-weight: 700 !important;
  color: var(--ink) !important; margin-bottom: 5px !important; display: block !important;
}
.vons-co-section-body .required { color: var(--cop) !important; }
.vons-co-section-body input[type="text"],
.vons-co-section-body input[type="email"],
.vons-co-section-body input[type="tel"],
.vons-co-section-body input[type="password"],
.vons-co-section-body textarea,
.vons-co-section-body select {
  width: 100% !important; border: 1.5px solid var(--lne2) !important;
  border-radius: 2px !important; padding: 10px 13px !important;
  font-family: var(--fb) !important; font-size: .9rem !important;
  color: var(--ink) !important; background: var(--w) !important;
  outline: none !important; box-sizing: border-box !important;
  transition: border-color .2s !important;
}
.vons-co-section-body input:focus,
.vons-co-section-body select:focus { border-color: var(--ink) !important; }
.vons-co-section-body .form-row-first,
.vons-co-section-body .form-row-last {
  width: 48% !important; display: inline-block !important; box-sizing: border-box !important; vertical-align: top !important;
}
.vons-co-section-body .form-row-first { margin-right: 4% !important; }
.vons-co-section-body .select2-container { width: 100% !important; }
.vons-co-section-body .select2-selection {
  border: 1.5px solid var(--lne2) !important; border-radius: 2px !important;
  height: 42px !important; display: flex !important; align-items: center !important;
}
.vons-co-section-body .select2-selection__rendered { line-height: 42px !important; padding: 0 13px !important; font-size: .9rem !important; }

/* ── Shipping methods ── */
.woocommerce-shipping-fields h3 { display: none !important; }
#shipping_method { list-style: none !important; padding: 0 !important; margin: 0 !important; }
/* ── Lista metod wysyłki (shipping_method) ── */
ul.woocommerce-shipping-methods, #shipping_method {
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}
/* Globalne reguły dla <li> metod dostawy — używane POZA stroną kasy (np. koszyk).
   Na stronie kasy (vco-shipping-wrap) te reguły są nadpisane niżej z wyższą specyficznością.
   NIE używamy !important żeby reguły ze scope .vco-shipping-wrap mogły je zastąpić. */
ul.woocommerce-shipping-methods li, #shipping_method li {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid var(--line);
  cursor: pointer;
}
ul.woocommerce-shipping-methods li:last-child, #shipping_method li:last-child { border-bottom: none; }
ul.woocommerce-shipping-methods li input[type="radio"], #shipping_method li input[type="radio"] {
  width: 16px; height: 16px; flex-shrink: 0;
  accent-color: var(--cop); cursor: pointer; margin: 0;
}
ul.woocommerce-shipping-methods li label, #shipping_method li label {
  font-size: .9rem; color: var(--ink); cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px; flex: 1; margin: 0;
}
ul.woocommerce-shipping-methods li label .woocommerce-Price-amount,
#shipping_method li label .woocommerce-Price-amount { font-weight: 700; color: var(--cop); }
/* Logo InPost w etykietach */
ul.woocommerce-shipping-methods li label img, #shipping_method li label img {
  display: inline-block !important; vertical-align: middle !important;
  height: 22px !important; width: auto !important; max-width: 90px !important;
  margin: 0 !important; border: none !important; border-bottom: none !important;
}

/* ── Easypack geowidget — nie blokuj widoczności globalnie ── */
.easypack_show_geowidget,
div.easypack_show_geowidget,
#easypack_js_type_geowidget {
  /* NIE ustawiamy display — InPost JS zarządza sam przez .show()/.hide() */
  pointer-events: auto !important;
  clip: auto !important;
  clip-path: none !important;
  max-height: none !important;
}

/* Schowaj duplikat shipping w billing */
#customer_details .woocommerce-shipping-fields { display: none !important; }

/* ── Płatność ── */
.vons-co-payment-body { padding: 0 !important; }
.woocommerce-checkout #payment { background: none !important; border: none !important; padding: 0 !important; border-radius: 0 !important; }
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none !important; padding: 0 !important; margin: 0 !important; border: none !important;
}
.woocommerce-checkout #payment ul.payment_methods li {
  padding: 10px 14px !important; border-bottom: 1px solid var(--line) !important;
  display: flex !important; align-items: center !important; gap: 10px !important;
}
.woocommerce-checkout #payment ul.payment_methods li:last-child { border-bottom: none !important; }
.woocommerce-checkout #payment ul.payment_methods li label {
  font-size: .9rem !important; color: var(--ink) !important;
  cursor: pointer !important; margin: 0 !important;
  display: flex !important; align-items: center !important; gap: 8px !important; flex-wrap: wrap !important;
}
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
  accent-color: var(--cop) !important; width: 16px !important; height: 16px !important;
  flex-shrink: 0 !important; cursor: pointer !important;
}
.woocommerce-checkout #payment ul.payment_methods li img { height: 22px !important; width: auto !important; }
.woocommerce-checkout #payment .payment_box {
  padding: 12px 16px !important; background: var(--bg) !important;
  border-top: 1px solid var(--line) !important; font-size: .82rem !important; color: var(--mid) !important;
}
/* Ukryj TYLKO WC submit button (mamy własny). Terms checkbox MUSI być widoczny! */
.woocommerce-checkout #payment .place-order { display: none !important; }

/* ── Podsumowanie (prawa) ── */
.vons-co-order-review { }
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; }
.woocommerce-checkout-review-order-table th {
  background: var(--bg) !important; border-bottom: 1px solid var(--line) !important;
  padding: 7px 12px !important; font-size: .6rem !important; font-weight: 700 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important; color: var(--soft) !important;
}
.woocommerce-checkout-review-order-table td {
  background: var(--w) !important; border-bottom: 1px solid var(--line) !important;
  padding: 9px 12px !important; vertical-align: middle !important; font-size: .85rem !important;
}
.woocommerce-checkout-review-order-table .product-name { color: var(--ink) !important; font-weight: 600 !important; }
.woocommerce-checkout-review-order-table .product-name .product-quantity { color: var(--soft) !important; font-weight: 400 !important; }
.woocommerce-checkout-review-order-table .product-total { font-weight: 700 !important; text-align: right !important; white-space: nowrap !important; }
.woocommerce-checkout-review-order-table tfoot tr th,
.woocommerce-checkout-review-order-table tfoot tr td {
  background: var(--bg) !important; border-bottom: 1px solid var(--line) !important;
  padding: 10px 14px !important; font-size: .85rem !important;
}
.woocommerce-checkout-review-order-table tr.order-total th,
.woocommerce-checkout-review-order-table tr.order-total td {
  border-bottom: none !important; padding: 14px !important;
}
.woocommerce-checkout-review-order-table tr.order-total td .woocommerce-Price-amount {
  font-family: var(--fd) !important; font-size: 1.5rem !important; font-weight: 500 !important;
}
/* Terms */
.woocommerce-terms-and-conditions-wrapper { padding: 12px 14px 6px !important; }
.woocommerce-terms-and-conditions-wrapper label { font-size: .78rem !important; color: var(--mid) !important; }
.woocommerce-terms-and-conditions-wrapper input { accent-color: var(--cop) !important; margin-right: 7px !important; }

/* ZAMAWIAM przycisk — ukryty (mamy vco_place_order w prawym panelu) */
#place_order {
  display: none !important;
}
#place_order:hover { background: var(--ink) !important; }

/* Logowanie opcjonalne */
.woocommerce-form-login-toggle,
.woocommerce-form-coupon-toggle {
  background: var(--bg);
  padding: 9px 14px;
  font-size: .8rem; color: var(--mid);
  border-bottom: 1px solid var(--line); display: block;
}

/* ── Responsywność ── */
@media (max-width: 1000px) {
  .vons-co-body { grid-template-columns: 1fr; }
  .vons-co-right { position: static; }
}
@media (max-width: 700px) {
  .vons-co-cart-table th:nth-child(3),
  .vons-co-cart-table td.vons-co-td-ship,
  .vons-co-cart-table th:nth-child(5),
  .vons-co-cart-table td.vons-co-td-price { display: none; }
  .vons-co-section-body .form-row-first,
  .vons-co-section-body .form-row-last { width: 100% !important; margin-right: 0 !important; display: block !important; }
}

/* Checkbox firma */
.vons-firma-toggle-wrap {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 13px 16px !important;
  margin: 16px 0 0 !important;
  background: var(--bg) !important;
  border: 1.5px solid var(--lne2) !important;
  border-radius: var(--rad) !important;
  cursor: pointer !important;
}
.vons-firma-toggle-wrap input[type="checkbox"] {
  width: 18px !important; height: 18px !important;
  accent-color: var(--cop) !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  padding: 0 !important; margin: 0 !important;
  border: none !important;
}
.vons-firma-toggle-wrap label {
  font-size: .85rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  cursor: pointer !important;
  margin: 0 !important;
}
.vons-firma-fields {
  display: none;
  margin-top: 14px;
  padding: 20px;
  background: var(--bg);
  border: 1.5px solid var(--lne2);
  border-radius: var(--rad);
}
.vons-firma-fields.open { display: block; }
.vons-firma-fields h4 {
  font-family: var(--fb) !important;
  font-size: .64rem !important;
  font-weight: 700 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  color: var(--cop) !important;
  margin: 0 0 14px !important;
}

/* ══════════════════════════════════════════════════════════
   INPOST — pełna kompatybilność
   ══════════════════════════════════════════════════════════ */

/* Radio shipping — NIE chowamy przez display:none, InPost JS musi je widzieć */

/* 2. Logo InPost w etykietach — POZA kasą (np. koszyk, widżety).
   Na kasie (vco-shipping-wrap) logo jest podmienione przez CSS background-image
   na .inpost_pl-shipping-method-meta-wrap::before — oryginalny img jest tam ukryty. */
.woocommerce-shipping-methods li label img,
#shipping_method li label img {
    display: inline-block !important;
    vertical-align: middle !important;
    width: auto !important;
    max-width: 70px !important;
    height: auto !important;
    max-height: 24px !important;
    object-fit: contain !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    border-bottom: none !important;
    background: none !important;
}
/* Na kasie — ukryte (zastąpione przez ::before pseudo-element) */
.vco-shipping-wrap ul.woocommerce-shipping-methods li label img {
    display: none !important;
}

/* ══ Elementy wstrzykiwane przez InPost — widoczność ══ */
.woocommerce-shipping-fields > *:not(#shipping_method),
#shipping_method + *,
#shipping_method ~ * {
    pointer-events: auto !important;
}

/* ══ Modal mapy InPost — zawsze nad wszystkim ══ */
#easypack-map,
#easypack-overlay,
.easypack-widget,
.easypack-modal,
[id^="easypack"],
[class*="easypack-modal"],
[class*="easypack-overlay"],
.inpost_geowidget_wrapper,
.inpost_geowidget_overlay,
#inpost_geowidget_wrapper,
[class*="inpost-modal"],
[class*="inpost-map"] {
    z-index: 2147483647 !important;
    position: fixed !important;
}

/* ══ Info o wybranym paczkomacie (globalne) ══ */
.inpost_locker_id_info,
.inpost-selected-point-info {
    display: block !important;
    margin: 6px 14px 10px !important;
    padding: 8px 12px !important;
    background: rgba(26,23,20,.03) !important;
    border: 1.5px solid var(--cop) !important;
    border-radius: 3px !important;
    font-size: .82rem !important;
    color: var(--ink) !important;
    font-family: var(--fb) !important;
    line-height: 1.45 !important;
}



/* Form fields */
.woocommerce form.checkout h3 { font-family: var(--fd) !important; font-size: 1rem !important; font-weight: 600 !important; margin: 0 0 18px !important; padding-bottom: 12px !important; border-bottom: 1px solid var(--line) !important; background: transparent !important; border-top: none !important; border-left: none !important; border-right: none !important; border-radius: 0 !important; }
.woocommerce form.checkout h3:not(:first-child) { margin-top: 28px !important; }
.woocommerce form.checkout .form-row { margin-bottom: 14px !important; float: none !important; clear: none !important; width: 100% !important; }
.woocommerce form.checkout .form-row-first { float: left !important; width: calc(50% - 8px) !important; clear: left !important; }
.woocommerce form.checkout .form-row-last { float: right !important; width: calc(50% - 8px) !important; }
.woocommerce form.checkout .form-row-wide { clear: both !important; }
.woocommerce form.checkout .form-row label { display: block !important; font-size: .72rem !important; font-weight: 700 !important; color: var(--mid) !important; margin-bottom: 6px !important; }
.woocommerce form.checkout label abbr[title] { color: var(--cop) !important; border: none !important; text-decoration: none !important; }
.woocommerce form.checkout input.input-text,
.woocommerce form.checkout select,
.woocommerce form.checkout textarea { width: 100% !important; padding: 11px 14px !important; background: var(--w) !important; border: 1.5px solid var(--lne2) !important; color: var(--ink) !important; font-family: var(--fb) !important; font-size: .88rem !important; border-radius: var(--rad) !important; outline: none !important; -webkit-appearance: none !important; transition: border-color .2s !important; }
.woocommerce form.checkout input.input-text:focus,
.woocommerce form.checkout select:focus { border-color: var(--ink) !important; }
.woocommerce form.checkout .woocommerce-invalid input.input-text { border-color: var(--red) !important; }
.woocommerce form.checkout .woocommerce-valid input.input-text { border-color: var(--grn) !important; }

/* Payment box */
#payment { background: var(--bg) !important; border: 1.5px solid var(--lne2) !important; border-radius: var(--rad) !important; overflow: hidden !important; }
#payment .payment_methods { list-style: none !important; margin: 0 !important; padding: 0 !important; border-bottom: 1px solid var(--line) !important; }
#payment .payment_methods li { padding: 14px 18px !important; border-top: 1px solid var(--line) !important; display: flex !important; align-items: flex-start !important; gap: 10px !important; }
#payment .payment_methods li:first-child { border-top: none !important; }
#payment .payment_methods li label { font-size: .88rem !important; color: var(--ink) !important; cursor: pointer !important; font-weight: 500 !important; }
#payment .payment_box { padding: 12px 18px !important; background: var(--w) !important; border-top: 1px solid var(--line) !important; font-size: .8rem !important; color: var(--mid) !important; }
/* Ukryj standardowy przycisk tylko na kasie — form-pay.php ma własny */
#payment .place-order { display: none !important; }
.woocommerce-checkout #place_order { display: none !important; }

/* ═══════════════════════════ HOME SECTIONS ═══════════════════════════ */
.cats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; max-width: 1100px; margin: 0 auto; }
.cats-grid--5 { grid-template-columns: repeat(5, 1fr); }
.cat-card { background: var(--bg); border: 1px solid var(--line); border-radius: var(--rad); padding: 28px 20px; text-align: center; text-decoration: none; color: var(--ink); transition: border-color .2s, box-shadow .2s, transform .2s; display: flex; flex-direction: column; align-items: center; gap: 10px; overflow: hidden; position: relative; }
.cat-card:hover { border-color: var(--cop); box-shadow: 0 4px 20px rgba(184,114,46,.12); transform: translateY(-2px); color: var(--ink); }
.cat-card--has-img { padding-top: 0; }
.cat-card-img { width: 100%; aspect-ratio: 4/3; background-size: cover; background-position: center; border-bottom: 1px solid var(--line); margin-bottom: 4px; }
.cat-icon { width: 44px; height: 44px; stroke: var(--cop); fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.cat-name { font-family: var(--fd); font-size: 1.05rem; font-weight: 500; }
.cat-desc { font-size: .72rem; color: var(--soft); line-height: 1.5; }
.cat-count { font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--cop); opacity: .7; }

/* Wyróżniona karta Vonsace */
.cat-card--brand {
  background: var(--ink); border: 1.5px solid var(--cop); color: var(--w);
  position: relative; overflow: hidden; padding: 28px 20px;
}
.cat-card--brand:hover { border-color: var(--cop); box-shadow: 0 6px 28px rgba(184,114,46,.25); color: var(--w); }
.cat-card-brand-logo {
  height: 28px; width: auto; display: block;
  filter: brightness(0) invert(1); opacity: .9;
  margin-bottom: 8px;
}
.cat-card--brand .cat-desc { color: rgba(255,255,255,.45); font-size: .7rem; }
.cat-card--brand .cat-count { color: var(--cop); opacity: 1; }

/* Strzałka scroll na piluskach kategorii (mobile) */
.vshop-cats { position: relative; }
@media (max-width: 1100px) {
  .vshop-toolbar-inner::after {
    content: '→';
    position: absolute; right: var(--pad); top: 12px;
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem; color: var(--cop);
    background: linear-gradient(to right, transparent, var(--w) 30%);
    padding-left: 12px;
    animation: scroll-hint-pulse 1.5s ease-in-out infinite;
    pointer-events: none; z-index: 2;
  }
  .vshop-toolbar-inner { position: relative; }
}

@media (max-width: 768px) {
  .cats-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .cats-grid--5 { grid-template-columns: repeat(2, 1fr) !important; }
  .cat-card--brand { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .cats-grid { grid-template-columns: 1fr !important; }
  .cats-grid--5 { grid-template-columns: 1fr !important; }
  .cat-card--brand { grid-column: auto; }
}
.about-split { display: grid; grid-template-columns: 1fr 1fr; min-height: 440px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.about-visual { background: var(--bg2); display: flex; align-items: center; justify-content: center; padding: 60px; overflow: hidden; position: relative; }
.about-monogram { font-family: var(--fd); font-size: 16rem; font-weight: 700; color: var(--line); line-height: .8; user-select: none; }
.about-visual-img { width: 100%; height: 100%; object-fit: cover; display: block; position: absolute; top: 0; left: 0; }
.about-content { padding: 72px var(--pad); display: flex; flex-direction: column; justify-content: center; }
.about-content h2 { font-family: var(--fd); font-size: clamp(1.8rem,3vw,2.4rem); margin-bottom: 16px; }
.testimonials-section { background: var(--bg); padding: 72px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 36px; }
.testi-card { background: var(--w); border: 1px solid var(--line); border-radius: var(--rad); padding: 28px; }
.testi-stars { color: var(--cop); font-size: .8rem; letter-spacing: 2px; margin-bottom: 14px; }
.testi-quote { font-size: .9rem; color: var(--mid); line-height: 1.75; margin-bottom: 18px; font-style: italic; }
.testi-author { font-size: .78rem; font-weight: 700; color: var(--ink); }
.testi-city { font-size: .7rem; color: var(--soft); margin-top: 2px; }

/* Newsletter */
.nl-section { background: var(--ink); padding: 72px 0; }
.nl-inner { max-width: 640px; margin: 0 auto; text-align: center; padding: 0 var(--pad); }
.nl-eyebrow { font-size: .7rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--cop); margin-bottom: 14px; }
.nl-title { font-family: var(--fd); font-size: clamp(1.8rem,3vw,2.6rem); color: var(--w); margin-bottom: 8px; font-weight: 400; }
.nl-sub { font-size: .88rem; color: rgba(255,255,255,.5); margin-bottom: 28px; }
.nl-form { display: flex; max-width: 440px; margin: 0 auto; }
.nl-input { flex: 1; background: rgba(255,255,255,.08); border: 1.5px solid rgba(255,255,255,.15); border-right: none; color: var(--w); font-size: .88rem; padding: 14px 16px; border-radius: var(--rad) 0 0 var(--rad); outline: none; }
.nl-input::placeholder { color: rgba(255,255,255,.3); }
.nl-input:focus { border-color: var(--cop); }
.nl-btn { padding: 14px 24px; background: var(--cop); color: var(--w); font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; border: none; border-radius: 0 var(--rad) var(--rad) 0; cursor: pointer; }
.nl-btn:hover { background: var(--cop2); }

/* Footer */
.site-footer {
  background: var(--ink);
  position: relative;
  overflow: hidden;
}
/* Subtelna tekstura — linia dekoracyjna na górze */
.site-footer::before {
  content: '';
  position: absolute; top: 0; left: var(--pad); right: var(--pad);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cop), transparent);
  opacity: .5;
}

/* ── GÓRNA CZĘŚĆ: 4 kolumny ── */
.footer-top {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1.2fr;
  gap: 48px;
  padding: 60px var(--pad) 44px;
  max-width: var(--max);
  margin: 0 auto;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

/* Kolumna 1: logo + opis + social */
.footer-brand { }
.footer-logo-img {
  height: 34px; width: auto;
  opacity: .9; filter: brightness(0) invert(1);
  display: block; margin-bottom: 18px;
}
.footer-tagline {
  font-size: .82rem; color: rgba(255,255,255,.38);
  line-height: 1.9; max-width: 240px; margin: 0 0 22px;
}
.footer-socials { display: flex; gap: 8px; margin-bottom: 0; }
.f-soc {
  width: 34px !important; height: 34px !important;
  min-width: 34px !important; max-width: 34px !important;
  min-height: 34px !important; max-height: 34px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: rgba(255,255,255,.45); font-size: .6rem; font-weight: 700;
  letter-spacing: .06em; text-decoration: none;
  transition: border-color .2s, color .2s, background .2s;
  padding: 0 !important; box-sizing: border-box !important;
  flex-shrink: 0 !important;
}
.f-soc svg { width: 18px !important; height: 18px !important; display: block !important; flex-shrink: 0 !important; }
.f-soc:hover { border-color: var(--cop) !important; color: var(--cop) !important; background: rgba(193,140,73,.08) !important; }

/* Kolumny 2-3: nawigacja */
.footer-col h4 {
  font-family: var(--fb);
  font-size: .6rem; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(255,255,255,.5);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 9px; padding: 0; margin: 0; }
.footer-col ul li a {
  font-size: .82rem; color: rgba(255,255,255,.38);
  text-decoration: none; transition: color .2s;
  display: flex; align-items: center; gap: 6px;
}
.footer-col ul li a::before {
  content: ''; width: 3px; height: 3px; border-radius: 50%;
  background: var(--cop); opacity: 0; flex-shrink: 0;
  transition: opacity .2s;
}
.footer-col ul li a:hover { color: rgba(255,255,255,.85); }
.footer-col ul li a:hover::before { opacity: 1; }

/* Kolumna 4: dane firmy */
.footer-address h4 {
  font-family: var(--fb);
  font-size: .6rem; font-weight: 700; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(255,255,255,.5);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.footer-address-block {
  display: flex; flex-direction: column; gap: 14px;
}
.footer-address-row {
  display: flex; flex-direction: column; gap: 2px;
}
.footer-address-label {
  font-size: .56rem; font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--cop); opacity: .8;
}
.footer-address-val {
  font-size: .82rem; color: rgba(255,255,255,.38); line-height: 1.6;
}
.footer-address-val a {
  color: rgba(255,255,255,.38); text-decoration: none; transition: color .2s;
}
.footer-address-val a:hover { color: var(--cop); }

/* ── DOLNA CZĘŚĆ ── */
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px var(--pad); flex-wrap: wrap; gap: 12px;
  max-width: var(--max); margin: 0 auto;
}
.footer-copy { font-size: .68rem; color: rgba(255,255,255,.22); letter-spacing: .04em; }
.footer-copy strong { color: rgba(255,255,255,.38); font-weight: 500; }
.footer-links { display: flex; gap: 20px; }
.footer-links a { font-size: .68rem; color: rgba(255,255,255,.22); text-decoration: none; transition: color .2s; }
.footer-links a:hover { color: var(--cop); }

/* Responsive */
@media (max-width: 1100px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 36px 40px; }
}
@media (max-width: 640px) {
  .footer-top { grid-template-columns: 1fr; gap: 28px; padding: 40px var(--pad) 32px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 8px; }
}

@media (max-width: 768px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .vp-trust { grid-template-columns: repeat(2, 1fr); }
  .vp-thumbrail { display: none !important; }
  .vp-gallery-inner { grid-template-columns: 1fr !important; }
  .vp-gallery { max-height: 380px !important; }
  .vp-gallery-inner { height: 350px !important; max-height: 350px !important; }
  .vp-info { padding: 24px 16px 48px !important; }
  .vp-title { font-size: 1.65rem !important; }
  .vp-tabs-wrap { padding: 0 16px 44px; }
  .vp-related { padding: 44px 16px; }
  .hero-content { padding: 48px var(--pad); }
  .hero-bottom-item { padding: 0 16px; font-size: .72rem; }
  .hero-bottom-stat { flex: 1 1 50%; }
  /* Blog mobile */
  .bl-grid { grid-template-columns: 1fr; }
  .bs-related-grid { grid-template-columns: 1fr; }
  .bl-featured-body { padding: 22px; }
  .bs-hero { min-height: 360px; }
  .bs-wrap { padding: 36px var(--pad) 32px; }
  .bs-lead { font-size: 1.05rem; }

  .woocommerce form.checkout .form-row-first, .woocommerce form.checkout .form-row-last { float: none !important; width: 100% !important; clear: both !important; }
  .woocommerce table.shop_table .product-price { display: none !important; }
}

/* ═══════════════════════════════════════════════════════
   STRONA KATEGORII — sekcje pod produktami
   ═══════════════════════════════════════════════════════ */

/* 1. Dlaczego warto */
.cat-why-section { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg); margin-top: 60px; }
.cat-why-inner { max-width: var(--max); margin: 0 auto; padding: 48px var(--pad); display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.cat-why-item { display: flex; flex-direction: column; gap: 12px; }
.cat-why-item svg { width: 32px; height: 32px; stroke: var(--cop); flex-shrink: 0; }
.cat-why-item strong { font-family: var(--fb); font-size: .9rem; font-weight: 700; color: var(--ink); letter-spacing: .02em; }
.cat-why-item span { font-size: .82rem; color: var(--mid); line-height: 1.7; }

/* 2. Opis kategorii — przewodnik */
.cat-desc-section { padding: 60px 0; background: var(--bg); border-top: 1px solid var(--line); }
.cat-desc-inner {
  max-width: 800px; margin: 0 auto; padding: 36px var(--pad);
  background: var(--w); border: 1px solid var(--line); border-radius: var(--rad);
  border-left: 3px solid var(--cop);
}
.cat-desc-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 20px;
  padding-bottom: 16px; border-bottom: 1px solid var(--line);
}
.cat-desc-icon { color: var(--cop); flex-shrink: 0; }
.cat-desc-title { font-family: var(--fd); font-size: clamp(1.2rem, 2.5vw, 1.6rem); font-weight: 400; color: var(--ink); margin: 0; }
.cat-desc-body { font-size: .88rem; color: var(--mid); line-height: 1.85; }
.cat-desc-body p { margin-bottom: 14px; }
.cat-desc-body h2, .cat-desc-body h3 { font-family: var(--fd); font-weight: 400; color: var(--ink); margin: 24px 0 10px; font-size: 1.15rem; }
.cat-desc-body a { color: var(--cop); text-decoration: underline; }

/* 3. Powiązane kategorie */
.cat-related-section { padding: 60px 0; border-top: 1px solid var(--line); background: var(--bg); }
.cat-related-inner { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.cat-related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.cat-related-card { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--rad); overflow: hidden; text-decoration: none; transition: border-color .2s, box-shadow .2s; background: var(--w); }
.cat-related-card:hover { border-color: var(--lne2); box-shadow: 0 4px 20px rgba(26,23,20,.07); }
.cat-related-img { aspect-ratio: 4/3; background-size: cover; background-position: center; background-color: var(--bg); }
.cat-related-img--empty { background-image: none; }
.cat-related-body { padding: 14px 16px; }
.cat-related-name { display: block; font-size: .88rem; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
.cat-related-count { font-size: .72rem; color: var(--soft); letter-spacing: .04em; }

@media (max-width: 1100px) {
  .cat-why-inner { grid-template-columns: 1fr; gap: 28px; }
  .cat-related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .cat-related-grid { grid-template-columns: 1fr; }
}

/* Woo-main layout */
/* woo-main already defined above */
/* Koszyk i kasa — woo-main bez ograniczeń, własny wrapper zarządza szerokością */
.woocommerce-cart .woo-main,
.woocommerce-checkout .woo-main {
  max-width: 100% !important; width: 100% !important;
  padding: 0 !important; margin: 0 !important;
}

/* Opis produktu — wycentrowany */
.woocommerce-product-details__short-description,
.vp-summary .woocommerce-product-details__short-description { text-align: left; }
.woocommerce div.product div.summary,
.vp-summary { max-width: 560px; }

/* ═══════════════════════════════════════════════
   BEAUTIFUL CART — Vonsace aesthetic
   ═══════════════════════════════════════════════ */

/* Wrapper */
/* ═══════════════════════════════════════════════════
   KOSZYK v2 — vc2-*
   ═══════════════════════════════════════════════════ */

/* Zero all WC wrappers on cart page */
.woocommerce-cart .woo-main,
.woocommerce-cart .woo-main > .woocommerce {
  max-width: 100% !important; width: 100% !important;
  margin: 0 !important; padding: 0 !important; float: none !important;
}
.woo-main--cart { max-width: 100% !important; padding: 0 !important; margin: 0 !important; }

/* ── GŁÓWNY WRAPPER ── */
.vc2-wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding: 36px var(--pad) 0;
  box-sizing: border-box;
  width: 100%;
}

/* ── HEADER ── */
.vc2-header {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 20px; margin-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.vc2-title {
  font-family: var(--fd); font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 300; color: var(--ink); letter-spacing: -.02em;
  display: flex; align-items: center; gap: 12px; margin: 0;
}
.vc2-title-badge {
  background: var(--cop); color: var(--w);
  width: 28px; height: 28px; border-radius: 50%;
  font-family: var(--fb); font-size: .72rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.vc2-back {
  font-size: .78rem; color: var(--soft); text-decoration: none;
  display: flex; align-items: center; gap: 6px; transition: color .2s;
}
.vc2-back:hover { color: var(--cop); }
.vc2-back svg { transition: transform .2s; }
.vc2-back:hover svg { transform: translateX(-3px); }

/* ── PASEK DOSTAWY ── */
.vc2-ship-bar {
  background: var(--w); border: 1px solid var(--line);
  border-radius: var(--rad); padding: 16px 22px;
  margin-bottom: 24px; transition: border-color .5s, background .5s;
}
.vc2-ship-bar.vc2-ship-free { border-color: #4caf82; background: rgba(76,175,130,.05); }
.vc2-ship-info {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .84rem; color: var(--mid); margin-bottom: 10px; min-height: 22px;
}
.vc2-ship-text { display: flex; align-items: center; gap: 7px; }
.vc2-ship-text strong { color: var(--ink); }
.vc2-ship-threshold { color: var(--soft); font-size: .75rem; white-space: nowrap; }
.vc2-ship-done { display: flex; align-items: center; gap: 7px; color: #4caf82; font-weight: 600; }
.vc2-ship-track { height: 4px; background: var(--lne2); border-radius: 99px; overflow: hidden; }
.vc2-ship-fill {
  height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, var(--cop), #e0b06a);
  transition: width .7s cubic-bezier(.4,0,.2,1);
}
.vc2-ship-bar.vc2-ship-free .vc2-ship-fill { background: linear-gradient(90deg, #4caf82, #66bb6a); }

/* ════════════════════════════════════════
   GŁÓWNY GRID:
   LEWA = sticky podsumowanie
   PRAWA = lista produktów + kupon
   ════════════════════════════════════════ */
.vc2-grid {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 28px;
  align-items: start;
}
/* sidebar jest PIERWSZY w HTML → lewa */
.vc2-sidebar { position: sticky; top: 84px; grid-column: 1; }
.vc2-left    { grid-column: 2; min-width: 0; }

/* ── SIDEBAR (LEWA) ── */
.vc2-summary {
  background: var(--w); border: 1px solid var(--line);
  border-radius: var(--rad); overflow: hidden;
}
.vc2-summary-head {
  background: var(--ink); color: var(--w); padding: 14px 22px;
  font-family: var(--fb); font-size: .6rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
}
.vc2-sum-rows { padding: 18px 22px 4px; }
.vc2-sum-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .86rem; color: var(--mid); padding: 9px 0;
  border-bottom: 1px solid var(--line);
}
.vc2-sum-row:last-child { border-bottom: none; }
.vc2-sum-row span:last-child { color: var(--ink); font-weight: 500; }
.vc2-sum-discount span:last-child { color: #4caf82; }
.vc2-free { color: #4caf82 !important; font-weight: 700 !important; }
.vc2-sum-total {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 16px 22px; border-top: 2px solid var(--ink);
  font-family: var(--fd); font-size: 1.5rem; font-weight: 400; color: var(--ink);
}
.vc2-sum-total span:first-child {
  font-family: var(--fb); font-size: .82rem; font-weight: 400; color: var(--mid);
  text-transform: uppercase; letter-spacing: .08em;
}
.vc2-checkout-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin: 0 16px 14px; padding: 15px;
  background: var(--cop); color: var(--w) !important; text-decoration: none;
  border-radius: 2px; font-family: var(--fb); font-size: .7rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; transition: background .2s;
  border: none; cursor: pointer;
}
.vc2-checkout-btn:hover { background: var(--ink); }
.vc2-trust {
  display: flex; justify-content: center; gap: 12px; flex-wrap: wrap;
  padding: 10px 16px 14px; border-top: 1px solid var(--line);
}
.vc2-trust-item {
  display: flex; align-items: center; gap: 5px; font-size: .67rem; color: var(--soft);
}
.vc2-trust-item svg { color: var(--cop); }

/* ── LISTA PRODUKTÓW (PRAWA) ── */
.vc2-items {
  background: var(--w); border: 1px solid var(--line);
  border-radius: var(--rad) var(--rad) 0 0; overflow: hidden;
}

/* Jeden wiersz produktu */
.vc2-item {
  display: grid;
  grid-template-columns: 100px 1fr 160px;
  border-bottom: 1px solid var(--line);
  position: relative; transition: background .15s; min-height: 100px;
}
.vc2-item:last-child { border-bottom: none; }
.vc2-item::after {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, var(--cop), transparent);
  opacity: 0; transition: opacity .2s;
}
.vc2-item:hover::after { opacity: 1; }
.vc2-item:hover { background: rgba(248,247,245,.5); }

/* Zdjęcie */
.vc2-item-img {
  width: 100px; align-self: stretch; overflow: hidden;
  background: var(--bg); border-right: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  text-decoration: none; position: relative; flex-shrink: 0;
}
.vc2-item-img img {
  width: 76px; height: 76px; object-fit: contain;
  transition: transform .35s ease; display: block;
}
.vc2-item:hover .vc2-item-img img { transform: scale(1.06); }
.vc2-item-badge {
  position: absolute; top: 6px; left: 6px;
  background: var(--cop); color: var(--w);
  font-size: .48rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: 2px 6px; border-radius: 2px;
}

/* Info */
.vc2-item-info {
  padding: 16px 20px; display: flex; flex-direction: column;
  gap: 5px; min-width: 0; overflow: hidden;
}
.vc2-item-cat {
  font-size: .55rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--cop); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vc2-item-name {
  font-size: .93rem; font-weight: 600; color: var(--ink); text-decoration: none;
  line-height: 1.4; transition: color .18s;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.vc2-item-name:hover { color: var(--cop); }
.vc2-item-chips { display: flex; gap: 5px; flex-wrap: wrap; }
.vc2-chip {
  background: var(--bg); border: 1px solid var(--lne2);
  padding: 2px 8px; border-radius: 3px; font-size: .65rem; color: var(--mid);
}
.vc2-item-acts { display: flex; gap: 12px; margin-top: auto; padding-top: 4px; }
.vc2-act-del {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .68rem; color: var(--soft); text-decoration: none;
  transition: color .18s; cursor: pointer; background: none; border: none; padding: 0;
}
.vc2-act-del:hover { color: #c0392b; }

/* Prawa kolumna: cena + stepper */
.vc2-item-right {
  padding: 16px 18px; display: flex; flex-direction: column;
  align-items: flex-end; justify-content: center; gap: 12px;
  border-left: 1px solid var(--line); flex-shrink: 0;
}
.vc2-item-price { text-align: right; }
.vc2-price-old {
  font-size: .72rem; color: var(--soft); text-decoration: line-through; display: block;
}
.vc2-price-cur {
  font-family: var(--fd); font-size: 1.15rem; font-weight: 500; color: var(--ink);
  display: block; line-height: 1; white-space: nowrap;
}
.vc2-pop { animation: vc2Pop .3s ease; }
@keyframes vc2Pop {
  0%   { transform: scale(1); }
  45%  { transform: scale(1.12); color: var(--cop); }
  100% { transform: scale(1); }
}

/* Stepper */
.vc2-stepper {
  display: inline-flex; align-items: center;
  border: 1.5px solid var(--lne2); border-radius: 4px; overflow: hidden;
  background: var(--bg);
}
.vc2-step-btn {
  width: 32px; height: 32px; background: none; border: none;
  color: var(--mid); font-size: 1.1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; user-select: none;
}
.vc2-step-btn:hover { background: var(--lne2); color: var(--ink); }
.vc2-step-input {
  width: 38px; height: 32px; text-align: center; border: none;
  border-left: 1.5px solid var(--lne2); border-right: 1.5px solid var(--lne2);
  background: var(--w); font-family: var(--fd); font-size: .95rem; color: var(--ink);
  outline: none; -moz-appearance: textfield;
}
.vc2-step-input::-webkit-outer-spin-button,
.vc2-step-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Kupon */
.vc2-coupon {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--bg); border: 1px solid var(--line);
  border-top: none; border-radius: 0 0 var(--rad) var(--rad);
  padding: 12px 18px;
}
.vc2-coupon > svg { color: var(--soft); flex-shrink: 0; }
.vc2-coupon-label { font-size: .78rem; color: var(--mid); white-space: nowrap; }
.vc2-coupon-input {
  flex: 1; min-width: 120px; max-width: 200px;
  border: 1.5px solid var(--lne2); border-radius: 2px;
  padding: 8px 12px; font-family: var(--fb); font-size: .85rem;
  color: var(--ink); background: var(--w); outline: none; transition: border-color .2s;
}
.vc2-coupon-input:focus { border-color: var(--ink); }
.vc2-coupon-btn {
  padding: 8px 18px; background: var(--ink); color: var(--w); border: none;
  border-radius: 2px; font-family: var(--fb); font-size: .66rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: background .18s;
}
.vc2-coupon-btn:hover { background: var(--cop); }
.vc2-coupon-tag {
  background: rgba(193,140,73,.1); border: 1px solid rgba(193,140,73,.3);
  color: var(--cop); font-size: .7rem; font-weight: 700; letter-spacing: .08em;
  padding: 3px 9px; border-radius: 3px; display: inline-flex; align-items: center; gap: 5px;
}
.vc2-coupon-tag a { color: var(--cop); text-decoration: none; }

/* ── PUSTY KOSZYK ── */
.vc2-empty {
  text-align: center; padding: 80px 24px 60px;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.vc2-empty svg { color: var(--soft); opacity: .4; }
.vc2-empty h2 { font-family: var(--fd); font-size: 2rem; font-weight: 300; color: var(--ink); margin: 0; }
.vc2-empty p { color: var(--soft); font-size: .9rem; margin: 0; }
.vc2-empty-btn {
  margin-top: 8px; padding: 12px 28px;
  border: 1.5px solid var(--lne2); border-radius: 2px;
  color: var(--ink); text-decoration: none; font-size: .78rem;
  font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  transition: border-color .2s, background .2s;
}
.vc2-empty-btn:hover { border-color: var(--cop); background: rgba(193,140,73,.05); }

/* ── REKOMENDACJE ── */
.vc2-recs {
  background: var(--bg);
  margin: 44px calc(-1 * var(--pad)) 0;
  padding: 48px var(--pad) 70px;
}
.vc2-recs-head {
  display: flex; align-items: center; gap: 20px; margin-bottom: 30px;
}
.vc2-recs-title {
  font-family: var(--fd); font-size: 1.7rem; font-weight: 300;
  color: var(--ink); letter-spacing: -.02em; margin: 0; white-space: nowrap;
}
.vc2-recs-rule { flex: 1; height: 1px; background: var(--line); }
.vc2-recs-link {
  display: flex; align-items: center; gap: 6px;
  font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--soft); text-decoration: none; white-space: nowrap; transition: color .2s;
}
.vc2-recs-link svg { transition: transform .2s; }
.vc2-recs-link:hover { color: var(--cop); }
.vc2-recs-link:hover svg { transform: translateX(3px); }
.vc2-recs .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important; margin: 0 !important; float: none !important;
}

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .vc2-grid { grid-template-columns: 1fr; }
  .vc2-sidebar { position: static; grid-column: auto; order: 2; }
  .vc2-left    { grid-column: auto; order: 1; }
}
@media (max-width: 640px) {
  .vc2-item { grid-template-columns: 80px 1fr; }
  .vc2-item-right {
    grid-column: 1 / -1; border-left: none; border-top: 1px solid var(--line);
    flex-direction: row; justify-content: space-between; width: 100%; padding: 10px 16px;
  }
  .vc2-recs .products { grid-template-columns: repeat(2,1fr) !important; gap: 12px !important; }
  .vc2-wrap { padding: 24px 16px 0; }
  .vc2-recs { margin: 32px -16px 0; padding: 36px 16px 48px; }
}


/* ═══════════ TOAST ═══════════ */
#vons-toast {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 99999;
  width: 360px;
  background: var(--w);
  border: 1.5px solid var(--line);
  border-top: 3px solid var(--cop);
  border-radius: var(--rad);
  box-shadow: 0 16px 60px rgba(26,23,20,.22);
  overflow: hidden;
  transform: translateX(110%);
  opacity: 0;
  pointer-events: none;
  transition: transform .4s cubic-bezier(.34,1.26,.64,1), opacity .3s ease;
}
#vons-toast.show {
  transform: translateX(0) !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
.vons-toast-inner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
}
.vons-toast-icon {
  width: 34px; height: 34px;
  border-radius: 50%;
  background: var(--cop);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.vons-toast-icon svg {
  width: 15px !important; height: 15px !important;
  stroke: #fff; fill: none;
  stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round;
  display: block;
}
.vons-toast-body { flex: 1; min-width: 0; }
.vons-toast-title { font-size: .76rem; font-weight: 700; color: var(--ink); letter-spacing: .04em; }
.vons-toast-name { font-size: .7rem; color: var(--mid); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.vons-toast-actions {
  display: flex;
  border-top: 1px solid var(--line);
}
.vons-toast-actions a {
  flex: 1; padding: 12px;
  text-align: center;
  font-size: .67rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--mid);
  text-decoration: none;
  transition: color .2s, background .2s;
}
.vons-toast-actions a:hover { color: var(--ink); background: var(--bg); }
.vons-toast-actions a.to-checkout { 
  background: var(--cop); 
  color: var(--w) !important; 
  font-size: .68rem;
}
.vons-toast-actions a.to-checkout:hover { background: var(--ink); }
.vons-toast-actions a + a { border-left: 1px solid var(--line); }
.vons-toast-bar {
  height: 3px;
  background: var(--cop);
  transform-origin: left;
  display: block;
}
#vons-toast.show .vons-toast-bar { animation: vonsToastBar 3.5s linear forwards; }
@keyframes vonsToastBar { from { transform: scaleX(1); } to { transform: scaleX(0); } }

/* ═══════════ SEARCH OVERLAY ═══════════ */
#search-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 98000;
  background: rgba(26,23,20,.55);
  /* display:none/flex toggle — NIE opacity, żeby nie psuć layoutu */
}
#search-overlay.open { display: flex; align-items: flex-start; justify-content: center; padding-top: 100px; }
.search-box {
  width: 100%;
  max-width: 600px;
  margin: 0 24px;
  background: var(--w);
  border-radius: var(--rad);
  box-shadow: 0 20px 60px rgba(26,23,20,.22);
  overflow: hidden;
  animation: searchSlideIn .2s ease;
}
@keyframes searchSlideIn { from { transform: translateY(-10px); opacity: .4; } to { transform: none; opacity: 1; } }
.search-box-row {
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.search-box-icon {
  padding: 0 14px 0 18px;
  color: var(--soft);
  flex-shrink: 0;
  display: flex;
}
.search-box-icon svg {
  width: 18px !important; height: 18px !important;
  stroke: currentColor; fill: none;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
  display: block;
}
#search-input {
  flex: 1;
  padding: 18px 12px;
  font-family: var(--fb);
  font-size: 1rem;
  color: var(--ink);
  border: none;
  outline: none;
  background: transparent;
}
#search-input::placeholder { color: var(--soft); }
#search-close-btn {
  width: 50px; height: 56px;
  background: none; border: none; cursor: pointer;
  color: var(--soft); font-size: 1.4rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: color .2s; flex-shrink: 0;
}
#search-close-btn:hover { color: var(--ink); }
#search-results {
  max-height: 420px;
  overflow-y: auto;
}
#search-results:empty { display: none; }
.search-hint {
  padding: 14px 20px;
  font-size: .72rem;
  color: var(--soft);
}
.search-hint:empty { display: none; }
/* wyniki */
.search-result-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  text-decoration: none;
  transition: background .15s;
}
.search-result-item:last-child { border-bottom: none; }
.search-result-item:hover { background: var(--bg); }
.search-result-img {
  width: 52px; height: 52px;
  object-fit: contain;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 3px;
  flex-shrink: 0;
  display: block;
}
.search-result-name {
  font-size: .88rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  flex: 1;
}
.search-result-name em { font-style: normal; background: rgba(184,114,46,.18); border-radius: 2px; padding: 0 2px; }
.search-result-price {
  font-family: var(--fd);
  font-size: .95rem;
  color: var(--cop);
  font-weight: 500;
  white-space: nowrap;
}
.search-no-results { padding: 20px 20px; font-size: .85rem; color: var(--soft); text-align: center; }
.search-loading { padding: 20px; text-align: center; color: var(--soft); font-size: .8rem; }

/* ═══════════════════════════════════════════════════════
   BLOG — archiwum, home, single post
   Klasy: bl-* (lista/karty), bs-* (single artykuł)
═══════════════════════════════════════════════════════ */

/* ── Wspólne ── */
.bs-dot { opacity: .3; margin: 0 6px; }
.bl-cat {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  display: inline-block;
  padding: 4px 11px;
  background: var(--cop); color: var(--w);
  font-size: .58rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  border-radius: 2px; text-decoration: none;
}
a.bl-cat:hover { background: var(--ink); }

/* ── Header bloga ── */
#blog-wrap { background: var(--w); min-height: 60vh; }
.blog-header {
  background: var(--ink); color: var(--w);
  padding: 72px var(--pad); text-align: center;
}
.blog-header-inner { max-width: var(--max); margin: 0 auto; }
.blog-header-eyebrow {
  display: inline-block;
  font-size: .6rem; font-weight: 700;
  letter-spacing: .32em; text-transform: uppercase;
  color: var(--cop2); margin-bottom: 14px;
}
.blog-header-title {
  font-family: var(--fd);
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  font-weight: 400; color: var(--w);
  margin-bottom: 12px; line-height: 1.1;
}
.blog-header-sub { font-size: .9rem; color: rgba(255,255,255,.45); max-width: 460px; margin: 0 auto; line-height: 1.7; }

/* ── Featured post ── */
.bl-featured { max-width: var(--max); margin: 56px auto 0; padding: 0 var(--pad); }
.bl-featured-inner {
  display: grid; grid-template-columns: 1.15fr 1fr;
  border: 1px solid var(--line); border-radius: var(--rad);
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(26,23,20,.07);
  transition: box-shadow .3s;
}
.bl-featured-inner:hover { box-shadow: 0 8px 48px rgba(26,23,20,.12); }
.bl-featured-img-wrap {
  display: block; position: relative;
  overflow: hidden; aspect-ratio: 16/10;
  text-decoration: none;
}
.bl-featured-img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .6s ease;
}
.bl-featured-img-wrap:hover .bl-featured-img { transform: scale(1.04); }
.bl-featured-img--empty { width: 100%; height: 100%; background: linear-gradient(135deg, var(--bg2), var(--lne2)); }
.bl-featured-body {
  padding: 44px 48px;
  display: flex; flex-direction: column; justify-content: center;
  background: var(--w);
}
.bl-featured-meta { font-size: .72rem; color: var(--soft); margin-bottom: 14px; display: flex; align-items: center; }
.bl-featured-ttl {
  font-family: var(--fd);
  font-size: clamp(1.5rem, 2.4vw, 2.2rem);
  font-weight: 400; line-height: 1.2;
  color: var(--ink); margin-bottom: 16px;
}
.bl-featured-ttl a { color: inherit; text-decoration: none; transition: color .2s; }
.bl-featured-ttl a:hover { color: var(--cop); }
.bl-featured-exc { font-size: .9rem; color: var(--mid); line-height: 1.75; margin-bottom: 28px; flex: 1; }
.bl-read-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  background: var(--ink); color: var(--w);
  font-size: .7rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  text-decoration: none; border-radius: var(--rad);
  align-self: flex-start; transition: background .2s;
}
.bl-read-btn svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: transform .2s; }
.bl-read-btn:hover { background: var(--cop); }
.bl-read-btn:hover svg { transform: translateX(3px); }

/* ── Siatka kart ── */
.bl-grid-section { max-width: var(--max); margin: 48px auto 0; padding: 0 var(--pad); }
.bl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.bl-card {
  background: var(--w); border: 1px solid var(--line);
  border-radius: var(--rad); overflow: hidden;
  display: flex; flex-direction: column;
  transition: box-shadow .3s, border-color .3s;
}
.bl-card:hover { box-shadow: 0 6px 28px rgba(26,23,20,.09); border-color: var(--lne2); }
.bl-card-img-wrap {
  display: block; position: relative;
  overflow: hidden; aspect-ratio: 16/9;
  text-decoration: none; flex-shrink: 0;
}
.bl-card-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.bl-card-img-wrap:hover .bl-card-img { transform: scale(1.05); }
.bl-card-img--empty { width: 100%; height: 100%; background: linear-gradient(135deg, var(--bg2), var(--lne2)); }
.bl-card-body { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.bl-card-meta { font-size: .68rem; color: var(--soft); margin-bottom: 9px; display: flex; align-items: center; }
.bl-card-ttl { font-family: var(--fd); font-size: 1.2rem; font-weight: 500; line-height: 1.3; color: var(--ink); margin-bottom: 10px; }
.bl-card-ttl a { color: inherit; text-decoration: none; transition: color .2s; }
.bl-card-ttl a:hover { color: var(--cop); }
.bl-card-exc { font-size: .82rem; color: var(--mid); line-height: 1.7; flex: 1; margin-bottom: 14px; }
.bl-card-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: var(--cop); text-decoration: none; transition: gap .2s, color .2s;
}
.bl-card-link svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2.2; stroke-linecap: round; }
.bl-card-link:hover { color: var(--ink); gap: 10px; }

/* ── Paginacja bloga ── */
.bl-pagination, .blog-pagination {
  max-width: var(--max); margin: 56px auto 72px; padding: 0 var(--pad);
  display: flex; justify-content: center;
}
.bl-pagination .page-numbers,
.blog-pagination .page-numbers {
  list-style: none; display: flex; gap: 6px; align-items: center; padding: 0; margin: 0;
}
.bl-pagination .page-numbers li a,
.bl-pagination .page-numbers li span,
.blog-pagination .page-numbers li a,
.blog-pagination .page-numbers li span {
  display: flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 10px;
  font-size: .8rem; font-weight: 700; color: var(--mid);
  border: 1.5px solid var(--lne2); border-radius: var(--rad);
  text-decoration: none; transition: background .2s, color .2s, border-color .2s;
}
.bl-pagination .page-numbers li a:hover,
.blog-pagination .page-numbers li a:hover { background: var(--ink); color: var(--w); border-color: var(--ink); }
.bl-pagination .page-numbers li span.current,
.blog-pagination .page-numbers li span.current { background: var(--ink); color: var(--w); border-color: var(--ink); }

/* ══════════════════════════════════════════════════════
   SINGLE POST (bs-*)
══════════════════════════════════════════════════════ */

/* Hero — background-image na divie */
.bs-hero {
  position: relative;
  min-height: 520px;
  background: var(--ink) center/cover no-repeat;
  display: flex;
  align-items: flex-end;
}
.bs-hero--no-img { background: var(--ink); }
.bs-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(26,23,20,.15) 0%, rgba(26,23,20,.82) 100%);
  pointer-events: none;
}
.bs-hero-body {
  position: relative; z-index: 1;
  width: 100%; padding: 0 var(--pad) 64px;
}
.bs-hero-inner { max-width: 800px; margin: 0 auto; }

.bs-cat-badge {
  display: inline-block;
  padding: 4px 12px; margin-bottom: 14px;
  background: rgba(255,255,255,.15); color: var(--w);
  font-size: .6rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 2px; text-decoration: none;
  backdrop-filter: blur(4px);
  transition: background .2s;
}
.bs-cat-badge:hover { background: var(--cop); border-color: var(--cop); }

.bs-title {
  font-family: var(--fd);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 400; line-height: 1.15;
  color: var(--w); letter-spacing: .01em;
  margin: 0 0 18px;
}
.bs-meta {
  display: flex; align-items: center; flex-wrap: wrap; gap: 2px;
  font-size: .78rem; color: rgba(255,255,255,.55);
}

/* Treść artykułu */
.bs-wrap { background: var(--w); padding: 60px var(--pad) 48px; }
.bs-inner { max-width: 740px; margin: 0 auto; }

.bs-lead {
  font-family: var(--fd); font-size: 1.22rem;
  line-height: 1.78; color: var(--mid);
  margin-bottom: 40px; padding-bottom: 36px;
  border-bottom: 1px solid var(--line);
}

.bs-body h2 { font-family: var(--fd); font-size: 1.8rem; font-weight: 500; color: var(--ink); margin: 48px 0 16px; line-height: 1.2; }
.bs-body h3 { font-family: var(--fd); font-size: 1.3rem; font-weight: 500; color: var(--ink); margin: 36px 0 12px; }
.bs-body p { font-size: .96rem; line-height: 1.85; color: var(--mid); margin-bottom: 22px; }
.bs-body a { color: var(--cop); text-decoration: underline; text-underline-offset: 3px; }
.bs-body a:hover { color: var(--ink); }
.bs-body ul, .bs-body ol { padding-left: 1.5em; margin-bottom: 22px; }
.bs-body li { font-size: .96rem; line-height: 1.85; color: var(--mid); margin-bottom: 6px; }
.bs-body blockquote {
  margin: 36px 0; padding: 22px 26px;
  border-left: 3px solid var(--cop);
  background: var(--bg); border-radius: 0 var(--rad) var(--rad) 0;
}
.bs-body blockquote p { font-family: var(--fd); font-size: 1.1rem; font-style: italic; color: var(--ink); margin: 0; }
.bs-body img { width: 100%; height: auto; border-radius: var(--rad); margin: 28px 0; display: block; }
.bs-body figure { margin: 32px 0; }
.bs-body figcaption { font-size: .76rem; color: var(--soft); text-align: center; margin-top: 8px; }
.bs-body strong { color: var(--ink); font-weight: 700; }
.bs-body hr { border: none; border-top: 1px solid var(--line); margin: 40px 0; }
.bs-body pre { background: var(--ink); color: rgba(255,255,255,.8); padding: 18px 22px; border-radius: var(--rad); font-size: .82rem; overflow-x: auto; margin: 24px 0; }

/* Tagi */
.bs-tags {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin-top: 40px; padding-top: 26px; border-top: 1px solid var(--line);
}
.bs-tags-lbl { font-size: .64rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--soft); }
.bs-tag {
  display: inline-block; padding: 5px 12px;
  background: var(--bg); border: 1px solid var(--lne2);
  border-radius: 20px; font-size: .72rem; color: var(--mid);
  text-decoration: none; transition: background .2s, color .2s, border-color .2s;
}
.bs-tag:hover { background: var(--ink); color: var(--w); border-color: var(--ink); }

/* Share */
.bs-share {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  margin-top: 24px; padding-top: 22px; border-top: 1px solid var(--line);
}
.bs-share-lbl { font-size: .64rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--soft); margin-right: 4px; }
.bs-share-fb, .bs-share-wa {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: var(--rad);
  font-size: .72rem; font-weight: 700; text-decoration: none;
  transition: opacity .2s, transform .15s;
}
.bs-share-fb:hover, .bs-share-wa:hover { opacity: .82; transform: translateY(-1px); }
.bs-share-fb svg, .bs-share-wa svg { width: 14px; height: 14px; }
.bs-share-fb { background: #1877F2; color: #fff; }
.bs-share-wa { background: #25D366; color: #fff; }

/* Nawigacja prev/next */
.bs-nav { background: var(--bg); border-top: 1px solid var(--line); }
.bs-nav-inner { display: grid; grid-template-columns: 1fr 1fr; max-width: var(--max); margin: 0 auto; }
.bs-nav-item {
  display: flex; flex-direction: column; gap: 8px;
  padding: 28px var(--pad); text-decoration: none;
  border-right: 1px solid var(--line);
  transition: background .2s;
}
.bs-nav-item:last-child { border-right: none; }
.bs-nav-item:hover { background: var(--bg2); }
.bs-nav-right { align-items: flex-end; text-align: right; }
.bs-nav-dir {
  display: flex; align-items: center; gap: 6px;
  font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--soft);
}
.bs-nav-dir svg { width: 14px; height: 14px; stroke: var(--cop); }
.bs-nav-ttl { font-family: var(--fd); font-size: 1.05rem; font-weight: 500; color: var(--ink); line-height: 1.3; transition: color .2s; }
.bs-nav-item:hover .bs-nav-ttl { color: var(--cop); }

/* Powiązane artykuły */
.bs-related { background: var(--w); border-top: 1px solid var(--line); padding: 56px 0 72px; }
.bs-related-inner { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.bs-related-ttl { font-family: var(--fd); font-size: 1.7rem; font-weight: 400; color: var(--ink); margin-bottom: 28px; }
.bs-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }

/* Reveal */

/* Reveal */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .55s, transform .55s; }
.reveal.in { opacity: 1; transform: none; }

/* ═══════════════════════════ RESPONSIVE ═══════════════════════════ */
@media (max-width: 1100px) {
  :root { --pad: 28px; }
  .hero-screen { height: auto; min-height: auto; }
  .hero { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .hero-bottom { flex-wrap: wrap; }
  .hero-bottom-item { flex: 1 1 50%; border-bottom: 1px solid var(--line); }
  .hero-bottom-stat { flex: 1 1 50%; }
  .about-split { grid-template-columns: 1fr; }
  .about-visual { display: none; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .trust-bar { flex-wrap: wrap; }
  .trust-item { flex: 1 1 50%; }
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }

  /* Product: stack galeria i info pionowo */
  .vp-layout {
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
  }
  .vp-gallery {
    -webkit-box-flex: 0 !important;
    -ms-flex: 0 0 100% !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    position: static !important;
    max-height: 500px !important;
    border-right: none !important;
    border-bottom: 1px solid var(--line) !important;
  }
  .vp-gallery-inner { height: 460px !important; max-height: 460px !important; }
  .vp-info {
    -webkit-box-flex: 0 !important;
    -ms-flex: 0 0 100% !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 36px 32px 60px !important;
  }

  /* Blog */
  .bl-featured-inner { grid-template-columns: 1fr; }
  .bl-featured-img-wrap { aspect-ratio: 16/7; }
  .bl-featured-body { padding: 32px; }
  .bl-grid { grid-template-columns: repeat(2, 1fr); }
  .bs-related-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .bs-nav-inner { grid-template-columns: 1fr; }
  .bs-nav-item { border-right: none; border-bottom: 1px solid var(--line); }
  .bs-nav-item:last-child { border-bottom: none; }
  .bs-nav-right { align-items: flex-start; text-align: left; }


  .woocommerce .cart-collaterals { flex-direction: column !important; }
  .woocommerce .cart_totals { width: 100% !important; flex: none !important; }

  /* Checkout */
  .woocommerce form.checkout { grid-template-columns: 1fr !important; }
  .woocommerce form.checkout #customer_details { grid-column: 1 !important; grid-row: 1 !important; }
  .woocommerce form.checkout #order_review { grid-column: 1 !important; grid-row: 3 !important; position: static !important; }
  .woocommerce form.checkout #payment { grid-column: 1 !important; grid-row: 2 !important; }
}

@media (max-width: 768px) {
  :root { --pad: 16px; }
  .footer-top { grid-template-columns: 1fr; }
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .vp-trust { grid-template-columns: repeat(2, 1fr); }
  .vp-thumbrail { display: none !important; }
  .vp-gallery-inner { grid-template-columns: 1fr !important; }
  .vp-gallery { max-height: 380px !important; }
  .vp-gallery-inner { height: 350px !important; max-height: 350px !important; }
  .vp-info { padding: 24px 16px 48px !important; }
  .vp-title { font-size: 1.65rem !important; }
  .vp-tabs-wrap { padding: 0 16px 44px; }
  .vp-related { padding: 44px 16px; }
  .hero-content { padding: 48px var(--pad); }
  .hero-bottom-item { padding: 0 16px; font-size: .72rem; }
  .hero-bottom-stat { flex: 1 1 50%; }
  /* Blog mobile */
  .bl-grid { grid-template-columns: 1fr; }
  .bs-related-grid { grid-template-columns: 1fr; }
  .bl-featured-body { padding: 22px; }
  .bs-hero { min-height: 360px; }
  .bs-wrap { padding: 36px var(--pad) 32px; }
  .bs-lead { font-size: 1.05rem; }

  .woocommerce form.checkout .form-row-first, .woocommerce form.checkout .form-row-last { float: none !important; width: 100% !important; clear: both !important; }
  .woocommerce table.shop_table .product-price { display: none !important; }
  .vp-rel-grid { grid-template-columns: repeat(2, 1fr); }

}

/* ═══════════════════════════════════════════════════════
   STRONA KATEGORII — sekcje pod produktami
   ═══════════════════════════════════════════════════════ */

/* 1. Dlaczego warto */
.cat-why-section { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg); margin-top: 60px; }
.cat-why-inner { max-width: var(--max); margin: 0 auto; padding: 48px var(--pad); display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.cat-why-item { display: flex; flex-direction: column; gap: 12px; }
.cat-why-item svg { width: 32px; height: 32px; stroke: var(--cop); flex-shrink: 0; }
.cat-why-item strong { font-family: var(--fb); font-size: .9rem; font-weight: 700; color: var(--ink); letter-spacing: .02em; }
.cat-why-item span { font-size: .82rem; color: var(--mid); line-height: 1.7; }

/* 2. Opis kategorii — see above */

/* 3. Powiązane kategorie */
.cat-related-section { padding: 60px 0; border-top: 1px solid var(--line); background: var(--bg); }
.cat-related-inner { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.cat-related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.cat-related-card { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--rad); overflow: hidden; text-decoration: none; transition: border-color .2s, box-shadow .2s; background: var(--w); }
.cat-related-card:hover { border-color: var(--lne2); box-shadow: 0 4px 20px rgba(26,23,20,.07); }
.cat-related-img { aspect-ratio: 4/3; background-size: cover; background-position: center; background-color: var(--bg); }
.cat-related-img--empty { background-image: none; }
.cat-related-body { padding: 14px 16px; }
.cat-related-name { display: block; font-size: .88rem; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
.cat-related-count { font-size: .72rem; color: var(--soft); letter-spacing: .04em; }

@media (max-width: 1100px) {
  .cat-why-inner { grid-template-columns: 1fr; gap: 28px; }
  .cat-related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .cat-related-grid { grid-template-columns: 1fr; }
}

/* Woo-main layout */
.woo-main { padding: 40px var(--pad) 60px; max-width: var(--max); margin: 0 auto; }

/* Opis produktu — wycentrowany */
.woocommerce-product-details__short-description,
.vp-summary .woocommerce-product-details__short-description { text-align: left; }
.woocommerce div.product div.summary,
.vp-summary { max-width: 560px; }

/* ═══════════════════════════════════════════════
   BEAUTIFUL CART — Vonsace aesthetic
   ═══════════════════════════════════════════════ */

/* Wrapper */
.vc-cart-wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding: 40px var(--pad) 80px;
  box-sizing: border-box;
}

/* Header */
.vc-cart-header {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.vc-cart-title {
  font-family: var(--fd);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 300;
  letter-spacing: -.02em;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 12px;
}
.vc-cart-qty {
  font-family: var(--fb);
  font-size: .78rem;
  font-weight: 700;
  background: var(--cop);
  color: var(--w);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0;
}
.vc-cart-back {
  margin-left: auto;
  font-size: .78rem;
  color: var(--soft);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  letter-spacing: .04em;
  transition: color .2s;
}
.vc-cart-back:hover { color: var(--cop); }
.vc-cart-back svg { transition: transform .2s; }
.vc-cart-back:hover svg { transform: translateX(-3px); }

/* Shipping bar */
.vc-ship-bar {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  padding: 14px 18px;
  margin-bottom: 28px;
}
.vc-ship-bar-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .82rem;
  color: var(--mid);
  margin-bottom: 9px;
  gap: 10px;
}
.vc-ship-bar-top svg { vertical-align: middle; margin-right: 4px; color: var(--cop); }
.vc-ship-bar-top strong { color: var(--ink); }
.vc-ship-threshold { font-size: .72rem; color: var(--soft); flex-shrink: 0; }
.vc-ship-done { color: var(--cop); font-weight: 700; font-size: .85rem; }
.vc-ship-track { height: 3px; background: var(--lne2); border-radius: 99px; overflow: hidden; }
.vc-ship-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--cop2, #b87833), var(--cop));
  border-radius: 99px;
  transition: width 1s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.vc-ship-fill::after {
  content: '';
  position: absolute; right: 0; top: 50%; transform: translateY(-50%);
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--cop);
  box-shadow: 0 0 8px var(--cop);
}

/* Grid */
.vc-cart-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 24px;
  align-items: start;
}
.vc-cart-left { display: flex; flex-direction: column; gap: 0; }
.vc-section-label {
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--soft);
  margin-bottom: 12px;
  font-weight: 700;
}

/* ── Cart Item ── */
.vc-cart-item {
  background: var(--w);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  padding: 16px;
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: 20px;
  align-items: center;
  margin-bottom: 10px;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
  width: 100%;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  animation: vcFadeUp .35s ease both;
}
.vc-cart-item::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, var(--cop), transparent);
  opacity: 0;
  transition: opacity .2s;
}
.vc-cart-item:hover { border-color: rgba(193,140,73,.3); transform: translateY(-1px); box-shadow: 0 4px 20px rgba(26,23,20,.06); }
.vc-cart-item:hover::before { opacity: 1; }
.vc-cart-item:nth-child(1) { animation-delay: .04s; }
.vc-cart-item:nth-child(2) { animation-delay: .1s; }
.vc-cart-item:nth-child(3) { animation-delay: .16s; }
.vc-cart-item:nth-child(4) { animation-delay: .22s; }

@keyframes vcFadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Image */
.vc-ci-img {
  width: 90px; height: 90px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--bg);
  border: 1px solid var(--line);
  flex-shrink: 0;
  position: relative;
}
.vc-ci-img img {
  width: 100%; height: 100%;
  object-fit: contain;
  padding: 4px;
  transition: transform .35s ease;
}
.vc-cart-item:hover .vc-ci-img img { transform: scale(1.04); }
.vc-ci-badge {
  position: absolute; top: 6px; left: 6px;
  background: var(--cop); color: var(--w);
  font-size: .52rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 2px;
}

/* Info */
.vc-ci-info { min-width: 0; }
.vc-ci-brand {
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--cop);
  margin-bottom: 2px;
  font-weight: 700;
}
.vc-ci-name {
  font-family: var(--fd);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  display: block;
  line-height: 1.3;
  margin-bottom: 6px;
  word-break: break-word;
  overflow-wrap: break-word;
  transition: color .2s;
}
.vc-ci-name:hover { color: var(--cop); }
.vc-ci-variants { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.vc-ci-chip {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 2px 9px;
  font-size: .7rem;
  color: var(--mid);
}
.vc-ci-actions { display: flex; gap: 6px; align-items: center; }
.vc-ci-act {
  font-size: .7rem;
  color: var(--soft);
  background: none; border: none; cursor: pointer;
  display: flex; align-items: center; gap: 4px;
  text-decoration: none;
  transition: color .2s;
  letter-spacing: .02em;
}
.vc-ci-act.danger:hover { color: #dc2626; }
.vc-ci-act:hover { color: var(--ink); }

/* Right: price + qty */
.vc-ci-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}
.vc-ci-price { text-align: right; }
.vc-ci-old {
  display: block;
  font-size: .75rem;
  color: var(--soft);
  text-decoration: line-through;
  margin-bottom: 1px;
}
.vc-ci-cur {
  font-family: var(--fd);
  font-size: 1.3rem;
  font-weight: 500;
  color: var(--ink);
  display: block;
  white-space: nowrap;
  transition: transform .2s;
}
@keyframes vcPricePop {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.1); color: var(--cop); }
  100% { transform: scale(1); }
}
.vc-price-pop { animation: vcPricePop .3s ease; }

/* Qty stepper */
.vc-qty-wrap {
  display: flex;
  align-items: center;
  background: var(--bg);
  border: 1.5px solid var(--lne2);
  border-radius: 6px;
  overflow: hidden;
}
.vc-qty-btn {
  width: 32px; height: 32px;
  background: none; border: none; cursor: pointer;
  font-size: 1.05rem; color: var(--mid);
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
  user-select: none;
}
.vc-qty-btn:hover { background: var(--lne2); color: var(--ink); }
.vc-qty-input {
  width: 36px; height: 32px;
  text-align: center; border: none;
  border-left: 1.5px solid var(--lne2);
  border-right: 1.5px solid var(--lne2);
  background: var(--w); font-family: var(--fd);
  font-size: 1rem; color: var(--ink); outline: none;
  -moz-appearance: textfield;
}
.vc-qty-input::-webkit-outer-spin-button,
.vc-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Coupon row */
.vc-coupon-row {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--rad);
  padding: 11px 14px; margin-top: 4px;
}
.vc-coupon-row > svg { color: var(--soft); flex-shrink: 0; }
#coupon_code {
  flex: 1; min-width: 150px;
  border: 1.5px solid var(--lne2); border-radius: 2px;
  padding: 7px 12px; font-family: var(--fb); font-size: .85rem;
  outline: none; background: var(--w);
  transition: border-color .2s;
}
#coupon_code:focus { border-color: var(--ink); }
.vc-coupon-btn {
  padding: 7px 16px; background: var(--ink); color: var(--w) !important;
  border: none; border-radius: 2px; font-size: .66rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; cursor: pointer;
  transition: background .2s;
}
.vc-coupon-btn:hover { background: var(--cop) !important; }
.vc-coupon-tag {
  background: rgba(193,140,73,.1); color: var(--cop);
  padding: 4px 10px; border-radius: 2px;
  font-size: .72rem; font-weight: 700;
  border: 1px solid rgba(193,140,73,.2);
}
.vc-coupon-tag a { color: var(--soft); text-decoration: none; margin-left: 4px; }

/* ── Sidebar ── */
.vc-cart-sidebar {
  position: sticky; top: 88px;
  display: flex; flex-direction: column; gap: 16px;
}

.vc-summary-card {
  background: var(--w);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  padding: 24px;
  animation: vcFadeUp .4s .2s ease both;
}
.vc-summary-title {
  font-family: var(--fd);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.vc-summary-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .85rem; color: var(--mid); margin-bottom: 10px;
}
.vc-summary-row span:last-child { color: var(--ink); }
.vc-row-discount span:last-child { color: var(--cop) !important; font-weight: 700; }
.vc-summary-total {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--fd); font-size: 1.4rem; color: var(--ink); font-weight: 400;
  margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--line);
}
.vc-summary-total span:first-child { font-family: var(--fb); font-size: .8rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--soft); align-self: center; }

.vc-checkout-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; margin-top: 16px; padding: 15px;
  background: var(--cop); color: var(--w) !important;
  border: none; border-radius: 2px; text-decoration: none;
  font-family: var(--fb); font-size: .72rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  transition: background .2s, transform .2s, box-shadow .2s;
  position: relative; overflow: hidden;
}
.vc-checkout-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.12), transparent);
  opacity: 0; transition: opacity .2s;
}
.vc-checkout-btn:hover { background: var(--ink) !important; transform: translateY(-1px); box-shadow: 0 8px 24px rgba(26,23,20,.14); }
.vc-checkout-btn:hover::before { opacity: 1; }

.vc-trust-row {
  display: flex; justify-content: center; gap: 14px; flex-wrap: wrap;
  margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line);
}
.vc-trust-item {
  display: flex; align-items: center; gap: 5px;
  font-size: .68rem; color: var(--soft);
}
.vc-trust-item svg { color: var(--cop); }

/* Upsell */
.vc-upsell-card {
  background: var(--w);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  padding: 20px;
  animation: vcFadeUp .4s .3s ease both;
}
.vc-upsell-title {
  font-size: .62rem; text-transform: uppercase; letter-spacing: .14em;
  color: var(--soft); font-weight: 700; margin-bottom: 14px;
}
.vc-upsell-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-top: 1px solid var(--line);
  transition: opacity .2s;
}
.vc-upsell-item:hover { opacity: .82; }
.vc-upsell-img { width: 48px; height: 48px; border-radius: 6px; overflow: hidden; background: var(--bg); flex-shrink: 0; border: 1px solid var(--line); }
.vc-upsell-img img { width: 100%; height: 100%; object-fit: contain; padding: 3px; }
.vc-upsell-info { flex: 1; min-width: 0; }
.vc-upsell-name { font-size: .82rem; color: var(--ink); line-height: 1.3; margin-bottom: 2px; }
.vc-upsell-price { font-size: .78rem; color: var(--cop); font-weight: 700; }
.vc-upsell-add {
  width: 30px; height: 30px; border-radius: 6px;
  border: 1.5px solid var(--lne2); background: none;
  color: var(--mid); font-size: 1.1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; text-decoration: none;
  transition: background .2s, color .2s, border-color .2s;
}
.vc-upsell-add:hover { background: rgba(193,140,73,.08); color: var(--cop); border-color: var(--cop); }

/* Empty state */
.vc-cart-empty {
  text-align: center; padding: 80px 24px;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.vc-cart-empty svg { color: var(--soft); opacity: .5; margin-bottom: 8px; }
.vc-cart-empty h2 { font-family: var(--fd); font-size: 2rem; font-weight: 300; color: var(--ink); }
.vc-cart-empty p { color: var(--soft); font-size: .9rem; }
.vc-empty-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 28px;
  border: 1.5px solid var(--lne2); border-radius: 2px;
  color: var(--ink); text-decoration: none;
  font-size: .78rem; letter-spacing: .1em; text-transform: uppercase;
  transition: border-color .2s, background .2s;
  margin-top: 6px;
}
.vc-empty-btn:hover { border-color: var(--cop); background: rgba(193,140,73,.04); }

/* Responsive */
@media (max-width: 900px) {
  .vc-cart-grid { grid-template-columns: 1fr; }
  .vc-cart-sidebar { position: static; }
}
@media (max-width: 600px) {
  .vc-cart-item { grid-template-columns: 80px 1fr; grid-template-rows: auto auto; gap: 20px; overflow: visible; padding: 14px; }
  .vc-ci-info { min-width: 0; }
  .vc-ci-name { white-space: normal; word-break: break-word; }
  .vc-ci-right { grid-column: 2; flex-direction: row; align-items: center; justify-content: space-between; }
  .vc-cart-wrap { padding: 20px 16px 60px; }
}


/* ═══════════════════════════════════════════════════════════════
   MOJE KONTO — pełne ostylowanie
   ═══════════════════════════════════════════════════════════════ */

/* Wrapper — pełna szerokość jak reszta sklepu */
.woocommerce-account .woo-main,
.woocommerce-account .woo-main > .woocommerce {
  max-width: var(--max) !important;
  margin: 0 auto !important;
  padding: 48px var(--pad) 80px !important;
  float: none !important;
  width: 100% !important;
}

/* Ukryj domyślny WC tytuł h1 na stronie logowania */
.woocommerce-account .woo-main > .woocommerce > h2:first-child { display: none !important; }

/* ══════════════════════════════════════════════
   STRONA LOGOWANIA — vma-page layout
   ══════════════════════════════════════════════ */
.woocommerce-account:not(.logged-in) .woo-main > .woocommerce {
  max-width: 100% !important;
  padding: 0 !important;
  display: block !important;
  background: none !important;
  border: none !important;
  float: none !important;
}

/* Wrapper całej strony */
.vma-page {
  max-width: 960px;
  margin: 0 auto;
  padding: 56px 24px 80px;
}

/* Tytuł strony */
.vma-page-title {
  font-family: var(--fd);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 400;
  text-align: center;
  margin: 0 0 40px;
  color: var(--ink);
}

/* Grid kolumn */
.vma-columns {
  display: grid;
  gap: 28px;
  align-items: start;
}
.vma-columns--two {
  grid-template-columns: 1fr 1fr;
}
.vma-columns--one {
  grid-template-columns: 1fr;
  max-width: 500px;
  margin: 0 auto;
}

/* Karta formularza */
.vma-box {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  padding: 32px;
}

/* Tytuł karty */
.vma-box-title {
  font-family: var(--fb);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 24px;
  padding: 0;
}

/* Formularz wewnątrz karty */
.vma-box form {
  padding: 0;
}

/* Pola */
.vma-field {
  margin-bottom: 12px;
}
.vma-input {
  width: 100% !important;
  border: 1.5px solid var(--lne2) !important;
  border-radius: 8px !important;
  padding: 13px 16px !important;
  font-family: var(--fb) !important;
  font-size: .95rem !important;
  color: var(--ink) !important;
  background: var(--w) !important;
  outline: none !important;
  transition: border-color .2s !important;
  box-sizing: border-box !important;
  display: block !important;
}
.vma-input:focus {
  border-color: var(--cop) !important;
  background: var(--w) !important;
}
.vma-input::placeholder { color: var(--soft) !important; }

/* Hasło + toggle */
.vma-pass-wrap { position: relative; }
.vma-pass-wrap .vma-input { padding-right: 46px !important; }
.vma-pass-toggle {
  position: absolute; right: 13px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--soft);
  padding: 0; line-height: 1; transition: color .2s;
}
.vma-pass-toggle:hover { color: var(--cop); }

/* Zapamiętaj + link hasło */
.vma-remember-row {
  display: flex; align-items: center; justify-content: space-between;
  margin: 6px 0 20px;
}
.vma-check-label {
  display: flex; align-items: center; gap: 8px;
  font-size: .85rem; color: var(--mid); cursor: pointer;
}
.vma-check-label input[type="checkbox"] {
  width: 15px; height: 15px; accent-color: var(--cop);
}
.vma-lost-pass {
  font-size: .82rem; color: var(--mid);
  text-decoration: none; transition: color .2s;
}
.vma-lost-pass:hover { color: var(--cop); }

/* Przycisk submit */
.vma-submit-btn {
  display: block; width: 100%;
  padding: 14px 24px;
  background: var(--cop); color: var(--w);
  border: none; border-radius: 8px;
  font-family: var(--fb); font-size: .75rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  cursor: pointer; transition: background .2s;
}
.vma-submit-btn:hover { background: var(--ink); }

/* Hint + privacy */
.vma-hint {
  font-size: .82rem; color: var(--mid);
  background: var(--bg2); border: 1px solid var(--line); border-radius: 8px;
  padding: 12px 14px; line-height: 1.6; margin: 0 0 16px;
}
.vma-privacy {
  font-size: .75rem; color: var(--soft);
  line-height: 1.7; margin: 0 0 20px;
}
.vma-privacy a { color: var(--cop); }

/* Nadpisz domyślne WC style — TYLKO na stronie logowania */
.woocommerce-account:not(.logged-in) .woocommerce-form-login,
.woocommerce-account:not(.logged-in) .woocommerce-form-register {
  padding: 0 !important;
  border: none !important;
  background: none !important;
}
.woocommerce-account:not(.logged-in) .u-column1,
.woocommerce-account:not(.logged-in) .u-column2 {
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
.woocommerce-account:not(.logged-in) .u-column1 h2,
.woocommerce-account:not(.logged-in) .u-column2 h2 { display: none !important; }
/* Ukryj labele TYLKO wewnątrz vma-box (nie globalne!) */
.vma-box label:not(.vma-check-label):not([for="rememberme"]) {
  display: none !important;
}

/* Responsive */
@media (max-width: 720px) {
  .vma-columns--two { grid-template-columns: 1fr; }
  .vma-page { padding: 36px 16px 60px; }
  .vma-box { padding: 24px 20px; }
}


/* ── DASHBOARD (zalogowany) ── */

/* Clearfix + tło — klucz do naprawy ciemnego tła */
.woocommerce-account.logged-in .woo-main > .woocommerce {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 32px !important;
  background: var(--w) !important;
}
.woocommerce-account.logged-in .woo-main > .woocommerce::after {
  content: none !important;
}

.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
  width: 220px !important;
  flex-shrink: 0 !important;
  float: none !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-content {
  flex: 1 !important;
  min-width: 0 !important;
  float: none !important;
  width: auto !important;
  background: var(--w) !important;
}

/* Nawigacja */
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  background: var(--w) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--rad) !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  position: sticky !important;
  top: 84px !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li a {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 13px 18px !important;
  font-size: .8rem !important;
  color: var(--mid) !important;
  text-decoration: none !important;
  border-bottom: 1px solid var(--line) !important;
  transition: background .15s, color .15s !important;
  letter-spacing: .04em !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none !important; }
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--bg) !important;
  color: var(--ink) !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li.is-active a {
  border-left: 3px solid var(--cop) !important;
  color: var(--cop) !important;
}

/* ── Content area: tabele, formularze, adresy ── */
.woocommerce-account.logged-in .woocommerce-MyAccount-content {
  color: var(--mid) !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-content h2,
.woocommerce-account.logged-in .woocommerce-MyAccount-content h3 {
  font-family: var(--fd) !important;
  color: var(--ink) !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-content p {
  color: var(--mid) !important;
  font-size: .9rem !important;
  line-height: 1.7 !important;
}
.woocommerce-account.logged-in .woocommerce-MyAccount-content a {
  color: var(--cop) !important;
}

/* Tabele zamówień */
.woocommerce-account .woocommerce-orders-table,
.woocommerce-account .shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--rad) !important;
  overflow: hidden !important;
  background: var(--w) !important;
}
.woocommerce-account .woocommerce-orders-table th,
.woocommerce-account .shop_table th {
  background: var(--bg) !important;
  color: var(--soft) !important;
  font-family: var(--fb) !important;
  font-size: .6rem !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--line) !important;
  text-align: left !important;
}
.woocommerce-account .woocommerce-orders-table td,
.woocommerce-account .shop_table td {
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--line) !important;
  font-size: .88rem !important;
  color: var(--mid) !important;
  background: var(--w) !important;
  vertical-align: middle !important;
}
.woocommerce-account .shop_table tr:last-child td { border-bottom: none !important; }

/* ── Akcje w tabeli zamówień (Moje konto) ── */
.woocommerce-account .woocommerce-orders-table__cell-order-actions a,
.woocommerce-account .shop_table td.order-actions a {
  display: inline-block !important;
  margin: 2px 4px 2px 0 !important;
  padding: 5px 11px !important;
  border: 1.5px solid var(--line) !important;
  border-radius: var(--rad) !important;
  font-size: .68rem !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  text-decoration: none !important;
  transition: background .15s, color .15s, border-color .15s !important;
  white-space: nowrap !important;
}
.woocommerce-account .woocommerce-orders-table__cell-order-actions a:hover,
.woocommerce-account .shop_table td.order-actions a:hover {
  background: var(--gold) !important;
  color: #fff !important;
  border-color: var(--gold) !important;
}

/* Szczegóły zamówienia */
.woocommerce-account .woocommerce-order-details,
.woocommerce-account .woocommerce-customer-details {
  background: var(--w) !important;
  margin-bottom: 24px !important;
}
.woocommerce-account .woocommerce-order-details h2,
.woocommerce-account .woocommerce-customer-details h2 {
  font-size: 1.3rem !important;
  margin: 0 0 16px !important;
}

/* Adresy */
.woocommerce-account .woocommerce-customer-details address,
.woocommerce-account .woocommerce-Addresses address {
  font-style: normal !important;
  font-size: .88rem !important;
  color: var(--mid) !important;
  line-height: 1.8 !important;
  background: var(--bg) !important;
  padding: 20px !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--rad) !important;
}

/* Formularz szczegółów konta */
.woocommerce-account .woocommerce-EditAccountForm,
.woocommerce-account .edit-account {
  background: var(--w) !important;
}
.woocommerce-account .woocommerce-EditAccountForm fieldset {
  border: 1px solid var(--line) !important;
  border-radius: var(--rad) !important;
  padding: 24px !important;
  margin: 24px 0 !important;
  background: var(--bg) !important;
}
.woocommerce-account .woocommerce-EditAccountForm legend {
  font-family: var(--fb) !important;
  font-size: .68rem !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--ink) !important;
  padding: 0 8px !important;
}
.woocommerce-account .woocommerce-EditAccountForm em {
  font-size: .78rem !important;
  color: var(--soft) !important;
  display: block !important;
  margin-top: 4px !important;
}
/* ── Pola formularza szczegółów konta ── */
.woocommerce-account .woocommerce-EditAccountForm .form-row {
  margin-bottom: 16px !important;
}
.woocommerce-account .woocommerce-EditAccountForm .form-row label {
  display: block !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color: var(--soft) !important;
  margin-bottom: 6px !important;
}
.woocommerce-account .woocommerce-EditAccountForm input[type="text"],
.woocommerce-account .woocommerce-EditAccountForm input[type="email"],
.woocommerce-account .woocommerce-EditAccountForm input[type="password"],
.woocommerce-account .woocommerce-EditAccountForm input[type="tel"] {
  width: 100% !important;
  padding: 11px 14px !important;
  border: 1.5px solid var(--line) !important;
  border-radius: var(--rad) !important;
  font-size: .88rem !important;
  color: var(--ink) !important;
  background: var(--w) !important;
  font-family: var(--fb) !important;
  box-sizing: border-box !important;
  transition: border-color .18s !important;
  outline: none !important;
}
.woocommerce-account .woocommerce-EditAccountForm input:focus {
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--gold) 12%, transparent) !important;
}
/* Przycisk save na koncie — nie full width */
.woocommerce-account .woocommerce-EditAccountForm button[type="submit"] {
  width: auto !important;
  padding: 13px 32px !important;
  background: var(--gold) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--rad) !important;
  font-family: var(--fb) !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background .18s !important;
  margin-top: 8px !important;
}
.woocommerce-account .woocommerce-EditAccountForm button[type="submit"]:hover {
  background: var(--ink) !important;
}

/* Adresy — karty na gridzie */
.woocommerce-account .woocommerce-Addresses {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 20px !important;
}
.woocommerce-account .woocommerce-Address {
  background: var(--w) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--rad) !important;
  padding: 20px !important;
}
.woocommerce-account .woocommerce-Address-title {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 12px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--line) !important;
}
.woocommerce-account .woocommerce-Address-title h3 {
  font-size: .9rem !important;
  margin: 0 !important;
}
.woocommerce-account .woocommerce-Address-title a {
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

/* Responsive — moje konto */
@media (max-width: 768px) {
  .woocommerce-account.logged-in .woo-main > .woocommerce {
    flex-direction: column !important;
    gap: 20px !important;
  }
  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
    width: 100% !important;
  }
  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul {
    position: static !important;
    display: flex !important;
    overflow-x: auto !important;
    white-space: nowrap !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul::-webkit-scrollbar { display: none !important; }
  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li a {
    border-bottom: none !important;
    border-right: 1px solid var(--line) !important;
    padding: 10px 16px !important;
    font-size: .72rem !important;
    white-space: nowrap !important;
  }
  .woocommerce-account.logged-in .woocommerce-MyAccount-navigation ul li.is-active a {
    border-left: none !important;
    border-bottom: 3px solid var(--cop) !important;
  }
  .woocommerce-account.logged-in .woocommerce-MyAccount-content {
    width: 100% !important;
  }
  .woocommerce-account .woocommerce-Addresses {
    grid-template-columns: 1fr !important;
  }
  /* Login grid */
  .woocommerce-account:not(.logged-in) .woo-main > .woocommerce {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   CHECKOUT — napraw szerokość kontenerów i pola formularza
   ═══════════════════════════════════════════════════════════════ */

/* Kluczowy fix — żaden wrapper WC nie może zawężać checkout */
.woocommerce-checkout #page-wrap,
.woocommerce-checkout #page-wrap > *,
.woocommerce-checkout .woo-main,
.woocommerce-checkout .site-content,
.woocommerce-checkout .content-area {
  max-width: 100% !important;
  width: 100% !important;
  float: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
/* ═══════════════════════════════════════════════════
   ONE-STEP CHECKOUT — vco-*
   ═══════════════════════════════════════════════════ */

/* Zero wszelkich WC wrapperów */
.woocommerce-checkout .woo-main,
.woocommerce-checkout .woo-main > .woocommerce,
.woocommerce-checkout #page-wrap > .woo-main {
  max-width: 100% !important; width: 100% !important;
  margin: 0 !important; padding: 0 !important; float: none !important;
}

/* Główny wrapper */
.vco-wrap {
  max-width: var(--max); margin: 0 auto;
  padding: 36px var(--pad) 80px; box-sizing: border-box; width: 100%;
}

/* ── HEADER ── */
.vco-header {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 20px; margin-bottom: 24px; border-bottom: 1px solid var(--line);
}
.vco-header-left { display: flex; align-items: baseline; gap: 14px; }
.vco-title {
  font-family: var(--fd); font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 300; color: var(--ink); letter-spacing: -.02em; margin: 0;
}
.vco-title-sub { font-size: .84rem; color: var(--soft); }
.vco-back {
  font-size: .78rem; color: var(--soft); text-decoration: none;
  display: flex; align-items: center; gap: 6px; transition: color .2s;
}
.vco-back:hover { color: var(--cop); }
.vco-back:hover svg { transform: translateX(-3px); }
.vco-back svg { transition: transform .2s; }

/* ── PASEK DOSTAWY ── */
.vco-ship-bar {
  background: var(--w); border: 1px solid var(--line); border-radius: var(--rad);
  padding: 14px 20px; margin-bottom: 24px; transition: border-color .4s, background .4s;
}
.vco-ship-bar.vco-ship-free { border-color: #4caf82; background: rgba(76,175,130,.05); }
.vco-ship-info {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .83rem; color: var(--mid); margin-bottom: 8px; min-height: 20px;
}
.vco-ship-info span { display: flex; align-items: center; gap: 7px; }
.vco-ship-info strong { color: var(--ink); }
.vco-ship-thresh { color: var(--soft); font-size: .74rem; }
.vco-ship-done { color: #4caf82 !important; font-weight: 600; }
.vco-ship-track { height: 4px; background: var(--lne2); border-radius: 99px; overflow: hidden; }
.vco-ship-fill {
  height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, var(--cop), #e0b06a);
  transition: width .7s cubic-bezier(.4,0,.2,1);
}
.vco-ship-bar.vco-ship-free .vco-ship-fill { background: linear-gradient(90deg,#4caf82,#66bb6a); }

/* ════ GŁÓWNY GRID ════ */
.vco-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: start;
}

/* ══ SEKCJA — wspólny styl ══ */
.vco-section {
  background: var(--w); border: 1px solid var(--line);
  border-radius: var(--rad); overflow: visible; margin-bottom: 16px;
}
/* Zaokrąglone rogi zachowujemy przez clip na nagłówku i body, nie na całym section */
.vco-section-head {
  border-radius: var(--rad) var(--rad) 0 0;
}
.vco-section:last-of-type { margin-bottom: 0; }
.vco-section-head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 22px; border-bottom: 1px solid var(--line);
  background: var(--bg);
}
.vco-snum {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--ink); color: var(--w);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fb); font-size: .65rem; font-weight: 700; flex-shrink: 0;
}
.vco-section--note .vco-snum {
  background: none; border: 1px solid var(--lne2); color: var(--soft);
}
.vco-sname {
  font-family: var(--fb); font-size: .78rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--ink); margin: 0;
}
.vco-optional { font-weight: 400; color: var(--soft); text-transform: none; letter-spacing: 0; font-size: .75rem; }
.vco-section-body { padding: 22px 22px; }

/* ── POLA FORMULARZA ── */
.vco-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* Resetuj WC form_row do naszego stylu */
.vco-section-body .form-row,
.vco-field.form-row {
  display: block !important; float: none !important;
  width: 100% !important; padding: 0 !important; margin: 0 0 14px !important;
}
.vco-row-2 .form-row { margin-bottom: 0 !important; }
.vco-section-body .form-row label {
  display: block !important; font-size: .6rem !important; font-weight: 700 !important;
  letter-spacing: .16em !important; text-transform: uppercase !important;
  color: var(--mid) !important; margin-bottom: 6px !important;
}
.vco-section-body .form-row label .required { color: var(--cop) !important; }
.vco-section-body .form-row input[type="text"],
.vco-section-body .form-row input[type="email"],
.vco-section-body .form-row input[type="tel"],
.vco-section-body .form-row input[type="number"],
.vco-section-body .form-row select,
.vco-section-body .form-row textarea {
  width: 100% !important; padding: 12px 15px !important;
  border: 1.5px solid var(--lne2) !important; border-radius: 3px !important;
  font-family: var(--fb) !important; font-size: .9rem !important; color: var(--ink) !important;
  background: var(--w) !important; outline: none !important;
  transition: border-color .2s, background .2s !important;
  -webkit-appearance: none !important; appearance: none !important;
}
.vco-section-body .form-row input:focus,
.vco-section-body .form-row select:focus,
.vco-section-body .form-row textarea:focus {
  border-color: var(--ink) !important; background: var(--w) !important;
}
.vco-section-body .select2-container .select2-selection--single {
  height: 46px !important; border: 1.5px solid var(--lne2) !important;
  border-radius: 3px !important; background: var(--w) !important; outline: none !important;
}
.vco-section-body .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 44px !important; padding: 0 15px !important; color: var(--ink) !important;
}
.vco-section-body .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 44px !important;
}
.vco-section-body .form-row.woocommerce-invalid input { border-color: #e74c3c !important; }
.vco-section-body .form-row.woocommerce-validated input { border-color: #4caf82 !important; }

/* Login hint */
.vco-login-hint {
  background: var(--bg); border: 1px solid var(--line); border-radius: 3px;
  padding: 10px 14px; font-size: .82rem; color: var(--soft); margin-bottom: 18px;
}
.vco-login-hint a { color: var(--cop); text-decoration: none; }

/* FV toggle */
.vco-fv-toggle {
  margin-bottom: 4px; padding: 12px 16px;
  border: 1.5px solid var(--lne2); border-radius: 3px; cursor: pointer;
  transition: border-color .2s, background .2s;
}
.vco-fv-toggle:has(input:checked) { border-color: var(--cop); background: rgba(193,140,73,.04); }
.vco-fv-label {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  font-size: .84rem; color: var(--mid); user-select: none;
}
.vco-fv-box {
  width: 18px; height: 18px; flex-shrink: 0; border: 1.5px solid var(--lne2);
  border-radius: 3px; display: flex; align-items: center; justify-content: center;
  background: var(--w); transition: background .2s, border-color .2s;
}
.vco-fv-box svg { color: transparent; transition: color .2s; }
.vco-fv-label input { display: none; }
.vco-fv-label input:checked ~ .vco-fv-box { background: var(--cop); border-color: var(--cop); }
.vco-fv-label input:checked ~ .vco-fv-box svg { color: var(--w); }
.vco-fv-label input { display: none; }
/* Fix: checkbox jest przed .vco-fv-box w HTML */
.vco-fv-label { flex-direction: row; }
.vco-fv-fields { margin-top: 12px; }
.vco-fv-inner { padding: 16px; background: rgba(193,140,73,.03); border: 1px solid rgba(193,140,73,.2); border-radius: 3px; }

/* ── METODY DOSTAWY ── */
.vco-ship-option {
  border: 1.5px solid var(--lne2); border-radius: 3px;
  margin-bottom: 8px; transition: border-color .2s, background .2s;
  padding: 0;
}
.vco-ship-option:last-child { margin-bottom: 0; }
.vco-ship-option.is-chosen { border-color: var(--ink); background: rgba(26,23,20,.02); }
.vco-ship-option input.shipping_method { display: none; }
.vco-ship-label {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; cursor: pointer; width: 100%;
}
.vco-ship-check {
  width: 18px; height: 18px; border-radius: 50%; border: 1.5px solid var(--lne2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; background: var(--w); transition: background .2s, border-color .2s;
}
.vco-ship-check svg { color: transparent; transition: color .2s; }
.vco-ship-option.is-chosen .vco-ship-check { background: var(--ink); border-color: var(--ink); }
.vco-ship-option.is-chosen .vco-ship-check svg { color: var(--w); }
.vco-ship-name { flex: 1; font-size: .88rem; color: var(--ink); font-weight: 500; }
.vco-ship-cost { font-family: var(--fd); font-size: .95rem; color: var(--ink); }
.vco-gratis { color: #4caf82; font-weight: 700; }
.vco-shipping-wrap ul.woocommerce-shipping-methods li label .vco-gratis {
  margin-left: auto !important;
  flex-shrink: 0 !important;
}
.vco-locker-info {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 14px 10px;
  padding: 8px 12px;
  background: rgba(26,23,20,.03);
  border: 1.5px solid var(--cop);
  border-radius: 3px;
  font-size: .82rem;
  color: var(--ink);
  font-family: var(--fb);
}

/* ══════════════════════════════════════════════════════════════════════
   METODY DOSTAWY — Vonsace premium design
   ══════════════════════════════════════════════════════════════════════ */

.vco-shipping-wrap ul.woocommerce-shipping-methods {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Karta metody */
.vco-shipping-wrap ul.woocommerce-shipping-methods li {
  display: block !important;
  position: relative;
  border: 1.5px solid var(--lne2);
  border-radius: 3px;
  margin-bottom: 6px;
  transition: border-color .18s, background .18s;
  overflow: visible;     /* visible — InPost elementy (geowidget, info paczkomat) wewnątrz li */
  background: var(--w);
}
.vco-shipping-wrap ul.woocommerce-shipping-methods li:has(input:checked) {
  border-color: var(--cop);
  border-bottom-color: var(--cop);
  background: rgba(26,23,20,.018);
  overflow: visible !important;   /* WAŻNE: visible żeby InPost elementy nie były ucięte */
}

/* Radio — ukryty ale jQuery-visible */
.vco-shipping-wrap ul.woocommerce-shipping-methods li input[type="radio"],
.vco-shipping-wrap #shipping_method li input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  pointer-events: none !important;
  margin: 0 !important;
}

/* Label — belka */
.vco-shipping-wrap ul.woocommerce-shipping-methods li label {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  gap: 10px !important;
  padding: 13px 16px !important;
  cursor: pointer !important;
  margin: 0 !important;
  font-size: .87rem !important;
  font-weight: 500 !important;
  font-family: var(--fb) !important;
  color: var(--ink) !important;
  line-height: 1.2 !important;
  user-select: none;
  min-height: 48px;
}

/* Fake radio */
.vco-shipping-wrap ul.woocommerce-shipping-methods li label::before {
  content: '';
  flex-shrink: 0;
  display: block;
  width: 17px; height: 17px;
  border-radius: 50%;
  border: 1.5px solid var(--lne2);
  background: var(--w);
  transition: background .18s, border-color .18s;
}
.vco-shipping-wrap ul.woocommerce-shipping-methods li:has(input:checked) label::before {
  border-color: var(--ink);
  background: var(--ink)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='9' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")
    center/9px no-repeat;
}

/* ── Meta-wrap (logo + czas) — generowany przez InPost POZA <label>, po nim w <li>
   Ukrywamy go i zastępujemy logo przez label::after (pseudo-element).
   Oryginalny wrapper jest po </label> więc renderuje się pod tekstem — chowamy go. */
.vco-shipping-wrap .inpost_pl-shipping-method-meta-wrap {
  display: none !important;
}
/* Ukryj też oryginalne img wewnątrz labela (na wypadek innej struktury) */
.vco-shipping-wrap label img {
  display: none !important;
}
/* Logo przez ::after na label — pojawia się inline po tekście nazwy, przed ceną */
.vco-shipping-wrap ul.woocommerce-shipping-methods li label::after {
  content: '';
  display: inline-block;
  flex-shrink: 0;
  width: 66px;
  height: 22px;
  background: url('https://vonsace.pl/wp-content/uploads/2026/03/InPost_logotype_2024_RGB_white_bg.png')
    center/contain no-repeat;
  margin-left: 4px;
}
/* Nie pokazuj ::after na metodach bez logo InPost — ogranicz do klas inpost */
/* Wszystkie metody są InPost więc zostawiamy globalnie dla .vco-shipping-wrap */


/* Cena — po prawej, prosta (Lato nie Cormorant) */
.vco-shipping-wrap ul.woocommerce-shipping-methods li label .woocommerce-Price-amount {
  margin-left: auto !important;
  font-family: var(--fb) !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  white-space: nowrap !important;
  letter-spacing: 0 !important;
}
.vco-shipping-wrap ul.woocommerce-shipping-methods li label .woocommerce-Price-currencySymbol {
  font-weight: 400 !important;
  font-size: .78rem !important;
}

/* ── Geowidget (przycisk ZMIEŃ/WYBIERZ PACZKOMAT) — wewnątrz <li> po przeniesieniu JS ── */
.vco-shipping-wrap li div.easypack_show_geowidget,
.vco-shipping-wrap li div#easypack_js_type_geowidget,
.vco-shipping-wrap li div[id*="easypack"][id*="geowidget"],
.vco-shipping-wrap ul > div.easypack_show_geowidget,
.vco-shipping-wrap #shipping_method > div.easypack_show_geowidget {
  display: block !important;
  pointer-events: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
  clip: auto !important;
  clip-path: none !important;
  background: #FCC905 !important;
  color: #1A1714 !important;
  border: none !important;
  border-radius: 3px !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  font-family: var(--fb, sans-serif) !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  cursor: pointer !important;
  box-shadow: none !important;
  line-height: 1.3 !important;
  max-width: none !important;
  width: auto !important;
  margin: 0 14px 8px !important;
  padding: 10px 16px !important;
}

/* Info o wybranym paczkomacie — KAŻDY div wewnątrz li z danymi InPost */
.vco-shipping-wrap li .inpost_locker_id_info,
.vco-shipping-wrap li [class*="locker-id"],
.vco-shipping-wrap li [class*="locker_id"],
.vco-shipping-wrap li [class*="selected-point"],
.vco-shipping-wrap li [class*="easypack-locker"],
.vco-shipping-wrap li [id*="easypack"][id*="locker"],
.vco-shipping-wrap li [id*="easypack"][id*="details"],
.vco-shipping-wrap .inpost_locker_id_info,
.vco-shipping-wrap [class*="locker-id"],
.vco-shipping-wrap [class*="locker_id"],
.vco-shipping-wrap [class*="selected-point"],
.vco-shipping-wrap [id*="easypack"][id*="locker"],
.vco-shipping-wrap [id*="easypack"][id*="details"] {
  display: block !important;
  margin: 0 14px 10px !important;
  padding: 9px 12px !important;
  background: rgba(26,23,20,.03) !important;
  border: 1.5px solid var(--cop) !important;
  border-radius: 3px !important;
  font: 500 .82rem/1.55 var(--fb) !important;
  color: var(--ink) !important;
}

/* Globalne */
.vco-shipping-wrap * { pointer-events: auto !important; }

/* Catch-all: KAŻDY div wewnątrz li (oprócz label) to element InPost — pokaż go */
.vco-shipping-wrap ul.woocommerce-shipping-methods li > div {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  position: relative !important;
  clip: auto !important;
  clip-path: none !important;
  max-height: none !important;
  overflow: visible !important;
}



/* ── METODY PŁATNOŚCI ── */
.vco-pay-method {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px; border: 1.5px solid var(--lne2); border-radius: 3px;
  margin-bottom: 8px; cursor: pointer; transition: border-color .2s, background .2s;
}
.vco-pay-method input { display: none; }
.vco-pay-method.is-chosen { border-color: var(--cop); background: rgba(193,140,73,.03); }
.vco-pay-check {
  width: 18px; height: 18px; border-radius: 50%; border: 1.5px solid var(--lne2);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  background: var(--w); transition: background .2s, border-color .2s;
}
.vco-pay-check svg { color: transparent; transition: color .2s; }
.vco-pay-method.is-chosen .vco-pay-check { background: var(--cop); border-color: var(--cop); }
.vco-pay-method.is-chosen .vco-pay-check svg { color: var(--w); }
.vco-pay-name { flex: 1; font-size: .88rem; color: var(--ink); font-weight: 500; }
.vco-pay-icon img { max-height: 22px; width: auto; }
.vco-pay-desc {
  padding: 14px 16px; margin: -8px 0 8px;
  background: rgba(193,140,73,.03); border: 1px solid rgba(193,140,73,.15);
  border-top: none; border-radius: 0 0 3px 3px;
  font-size: .84rem; color: var(--mid); line-height: 1.7;
}
.vco-pay-desc p { margin: 0; }

/* Textarea uwagi */
.vco-textarea {
  width: 100%; padding: 12px 15px;
  border: 1.5px solid var(--lne2); border-radius: 3px;
  font-family: var(--fb); font-size: .9rem; color: var(--ink);
  background: var(--w); resize: vertical; outline: none;
  transition: border-color .2s;
}
.vco-textarea:focus { border-color: var(--ink); }

/* Terms */
.vco-terms { margin-top: 12px; }
.vco-terms .woocommerce-terms-and-conditions-wrapper { display: none; } /* ukryj oryginalne WC, mamy własne */
.vco-terms-info { font-size: .8rem; color: var(--soft); margin: 0 0 12px; line-height: 1.5; }
.vco-terms-info a { color: var(--cop); text-decoration: underline; }

/* Checkbox */
.vco-terms-accept { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; user-select: none; }
.vco-terms-chk { position: absolute; opacity: 0; width: 0; height: 0; }
.vco-terms-box {
  flex-shrink: 0; width: 18px; height: 18px; margin-top: 1px;
  border: 1.5px solid var(--lne2); border-radius: 3px;
  background: var(--w); transition: border-color .15s, background .15s;
  display: flex; align-items: center; justify-content: center;
}
.vco-terms-chk:checked + .vco-terms-box {
  background: var(--ink); border-color: var(--ink);
}
.vco-terms-chk:checked + .vco-terms-box::after {
  content: '';
  display: block; width: 5px; height: 9px;
  border: 2px solid var(--w); border-top: none; border-left: none;
  transform: rotate(45deg) translate(-1px, -1px);
}
.vco-terms-label { font-size: .82rem; color: var(--mid); line-height: 1.5; }
.vco-terms-label a { color: var(--cop); text-decoration: underline; }

/* ══ PRAWA: podsumowanie sticky ══ */
.vco-right { position: sticky; top: 84px; }
.vco-summary {
  background: var(--w); border: 1px solid var(--line); border-radius: var(--rad);
  overflow: hidden;
}
.vco-sum-head {
  background: var(--ink); color: var(--w); padding: 13px 20px;
  font-family: var(--fb); font-size: .6rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
}

/* Produkty w podsumowaniu */
.vco-sum-products { padding: 14px 18px; border-bottom: 1px solid var(--line); }
.vco-sum-item {
  display: grid; grid-template-columns: 56px 1fr auto;
  gap: 12px; align-items: center; padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.vco-sum-item:last-child { border-bottom: none; padding-bottom: 0; }

/* Miniaturka bez badge — teraz mamy stepper */
.vco-sum-img {
  width: 54px; height: 54px; flex-shrink: 0;
  border: 1px solid var(--line); border-radius: 3px;
  background: var(--bg); overflow: visible; position: relative;
}
.vco-sum-img img { width: 100%; height: 100%; object-fit: contain; padding: 4px; display: block; }

/* Kolumna środkowa: nazwa + stepper */
.vco-sum-iinfo { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.vco-sum-iname { font-size: .78rem; color: var(--mid); line-height: 1.3;
  overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }

/* Mini stepper */
.vco-sum-stepper {
  display: inline-flex; align-items: center;
  border: 1.5px solid var(--lne2); border-radius: 3px;
  overflow: hidden; width: fit-content;
}
.vco-sq-btn {
  width: 26px; height: 24px; background: none; border: none;
  color: var(--mid); font-size: .95rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; user-select: none; flex-shrink: 0;
  line-height: 1;
}
.vco-sq-btn:hover { background: var(--lne2); color: var(--ink); }
.vco-sq-num {
  min-width: 28px; height: 24px; text-align: center;
  border-left: 1.5px solid var(--lne2); border-right: 1.5px solid var(--lne2);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fd); font-size: .88rem; color: var(--ink);
  background: var(--w);
}

/* Cena po prawej */
.vco-sum-iprice {
  font-family: var(--fb); font-size: .88rem; font-weight: 600;
  color: var(--ink); white-space: nowrap; text-align: right;
  align-self: center;
}

/* Kupon */
.vco-sum-coupon {
  display: flex; gap: 8px; padding: 12px 18px; border-bottom: 1px solid var(--line);
}
.vco-coupon-inp {
  flex: 1; padding: 9px 12px; border: 1.5px solid var(--lne2); border-radius: 2px;
  font-family: var(--fb); font-size: .82rem; color: var(--ink); background: var(--bg);
  outline: none; transition: border-color .2s;
}
.vco-coupon-inp:focus { border-color: var(--ink); background: var(--w); }
.vco-coupon-go {
  padding: 9px 16px; background: var(--ink); color: var(--w); border: none;
  border-radius: 2px; font-family: var(--fb); font-size: .64rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: background .18s;
  white-space: nowrap;
}
.vco-coupon-go:hover { background: var(--cop); }
.vco-active-coupon {
  display: flex; align-items: center; gap: 7px;
  padding: 6px 18px; background: rgba(193,140,73,.07);
  font-size: .74rem; font-weight: 700; color: var(--cop); letter-spacing: .06em;
  border-bottom: 1px solid rgba(193,140,73,.15);
}
.vco-active-coupon a { color: var(--soft); text-decoration: none; font-weight: 400; margin-left: auto; }
.vco-active-coupon a:hover { color: #c0392b; }

/* Kwoty */
.vco-sum-rows { padding: 14px 20px 6px; }
.vco-sum-row {
  display: flex; justify-content: space-between; align-items: center;
  font-size: .84rem; color: var(--mid); padding: 7px 0; border-bottom: 1px solid var(--line);
}
.vco-sum-row:last-child { border-bottom: none; }
.vco-sum-row span:last-child { color: var(--ink); font-weight: 500; }
.vco-sum-row--green span:last-child { color: #4caf82; }
.vco-gratis { color: #4caf82 !important; font-weight: 700 !important; }

.vco-sum-total {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 14px 20px; border-top: 2px solid var(--ink);
  font-family: var(--fd); font-size: 1.5rem; color: var(--ink);
}
.vco-sum-total span:first-child {
  font-family: var(--fb); font-size: .8rem; font-weight: 400; color: var(--mid);
  text-transform: uppercase; letter-spacing: .1em;
}

/* Submit */
.vco-submit {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: calc(100% - 32px); margin: 0 16px 14px; padding: 16px;
  background: var(--cop); color: var(--w); border: none; border-radius: 2px;
  font-family: var(--fb); font-size: .72rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase; cursor: pointer;
  transition: background .2s; box-shadow: 0 4px 18px rgba(193,140,73,.3);
}
.vco-submit:hover { background: var(--ink); box-shadow: none; }
.vco-submit:disabled { opacity: .6; cursor: not-allowed; }

/* Trust */
.vco-trust {
  display: flex; justify-content: center; gap: 12px; flex-wrap: wrap;
  padding: 8px 16px 14px; border-top: 1px solid var(--line);
}
.vco-trust span {
  display: flex; align-items: center; gap: 5px;
  font-size: .66rem; color: var(--soft);
}
.vco-trust svg { color: var(--cop); }

/* WC error notices na kasie */
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-info {
  max-width: var(--max) !important; margin: 0 auto 20px !important;
  padding: 14px 20px !important; font-size: .88rem !important;
  border-radius: var(--rad) !important;
}

/* ── Responsive ── */
@media (max-width: 960px) {
  .vco-grid { grid-template-columns: 1fr; }
  .vco-right { position: static; }
}
@media (max-width: 640px) {
  .vco-wrap { padding: 20px 16px 60px; }
  .vco-row-2 { grid-template-columns: 1fr; }
  .vco-section-body { padding: 16px; }
}


/* ═══════════════════════════════════════════
   STRONY WORDPRESS — vpage
   ═══════════════════════════════════════════ */
.vpage-main { background: var(--w); }

.vpage-hero {
  background: var(--ink);
  position: relative; overflow: hidden;
  padding: 60px var(--pad) 52px;
}
.vpage-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 50%, rgba(193,140,73,.12) 0%, transparent 60%);
  pointer-events: none;
}
.vpage-hero::after {
  content: '';
  position: absolute; bottom: 0; left: var(--pad); right: var(--pad);
  height: 1px; background: linear-gradient(90deg,transparent,var(--cop),transparent);
  opacity: .4;
}
.vpage-hero-inner { max-width: var(--max); margin: 0 auto; position: relative; }
.vpage-eyebrow {
  font-size: .58rem; font-weight: 700; letter-spacing: .28em;
  text-transform: uppercase; color: var(--cop); margin-bottom: 10px;
}
.vpage-title {
  font-family: var(--fd); font-size: clamp(2.2rem, 4vw, 3.8rem);
  font-weight: 300; letter-spacing: -.03em; color: var(--w); line-height: 1.1;
  margin: 0;
}
.vpage-lead {
  font-size: 1rem; color: rgba(255,255,255,.45); margin-top: 14px;
  max-width: 560px; line-height: 1.7;
}

.vpage-body {
  max-width: var(--max); margin: 0 auto;
  padding: 52px var(--pad) 80px;
  display: grid;
  grid-template-columns: 1fr min(680px, 100%);
  gap: 60px;
  align-items: start;
}
/* Jeden content — pełna kolumna */
.vpage-body:has(.vpage-content:only-child) {
  grid-template-columns: 1fr;
  max-width: 820px;
}
.vpage-content {
  min-width: 0;
}

/* Typography wewnętrzna */
.vpage-content h2 {
  font-family: var(--fd); font-size: 1.7rem; font-weight: 400;
  color: var(--ink); margin: 2em 0 .6em;
  padding-bottom: .4em; border-bottom: 1px solid var(--line);
  letter-spacing: -.02em;
}
.vpage-content h3 {
  font-family: var(--fd); font-size: 1.25rem; font-weight: 500;
  color: var(--ink); margin: 1.8em 0 .5em;
}
.vpage-content h2:first-child, .vpage-content h3:first-child { margin-top: 0; }
.vpage-content p {
  font-size: .95rem; line-height: 1.85; color: var(--mid); margin-bottom: 1.2em;
}
.vpage-content p strong { color: var(--ink); font-weight: 600; }
.vpage-content ul, .vpage-content ol {
  margin: 0 0 1.2em 0; padding-left: 0; list-style: none;
}
.vpage-content li {
  font-size: .95rem; line-height: 1.8; color: var(--mid);
  padding: 6px 0 6px 20px; position: relative;
  border-bottom: 1px solid var(--line);
}
.vpage-content ul li::before {
  content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 6px; height: 6px; border-radius: 50%; background: var(--cop);
}
.vpage-content ol { counter-reset: ol-counter; }
.vpage-content ol li::before {
  content: counter(ol-counter); counter-increment: ol-counter;
  position: absolute; left: 0; top: 7px;
  font-size: .6rem; font-weight: 700; color: var(--cop); letter-spacing: .08em;
}
.vpage-content a { color: var(--cop); text-decoration: none; border-bottom: 1px solid rgba(193,140,73,.3); transition: border-color .2s; }
.vpage-content a:hover { border-color: var(--cop); }
.vpage-content blockquote {
  border-left: 3px solid var(--cop); padding: 14px 20px;
  background: var(--bg); margin: 1.5em 0; border-radius: 0 var(--rad) var(--rad) 0;
  font-style: italic; color: var(--mid); font-size: 1rem;
}
.vpage-content table {
  width: 100%; border-collapse: collapse; font-size: .88rem; margin-bottom: 1.5em;
}
.vpage-content th {
  background: var(--ink); color: var(--w); padding: 10px 14px;
  font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 700; text-align: left;
}
.vpage-content td {
  padding: 10px 14px; border-bottom: 1px solid var(--line); color: var(--mid); vertical-align: top;
}
.vpage-content tr:nth-child(even) td { background: var(--bg); }

/* ═══════════════════════════════════════════
   KOSZYK — fix szerokości + rekomendacje
   ═══════════════════════════════════════════ */
.vc-cart-wrap { max-width: var(--max) !important; padding: 40px var(--pad) 80px !important; }
@media (max-width: 600px) {
  .vc-cart-wrap { padding: 20px 16px 60px !important; box-sizing: border-box !important; overflow-x: hidden !important; }
}

/* Rekomendacje */
.vc-recs {
  margin-top: 48px; padding-top: 48px;
  border-top: 1px solid var(--line);
}
.vc-recs-head {
  display: flex; align-items: baseline; gap: 16px; margin-bottom: 24px;
}
.vc-recs-title {
  font-family: var(--fd); font-size: 1.7rem; font-weight: 300;
  letter-spacing: -.02em; color: var(--ink);
}
.vc-recs-line {
  flex: 1; height: 1px; background: var(--line); margin-bottom: 4px;
}
.vc-recs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 900px) { .vc-recs-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 540px) { .vc-recs-grid { grid-template-columns: 1fr 1fr; gap: 10px; } }

.vc-rec-card {
  background: var(--w); border: 1px solid var(--line); border-radius: var(--rad);
  overflow: hidden; position: relative;
  transition: border-color .2s, box-shadow .2s, transform .2s;
  animation: vcoFadeUp .4s ease both;
}
.vc-rec-card:nth-child(1) { animation-delay: .06s; }
.vc-rec-card:nth-child(2) { animation-delay: .12s; }
.vc-rec-card:nth-child(3) { animation-delay: .18s; }
.vc-rec-card:nth-child(4) { animation-delay: .24s; }
.vc-rec-card:hover { border-color: var(--lne2); box-shadow: 0 6px 28px rgba(26,23,20,.08); transform: translateY(-2px); }

.vc-rec-img-wrap {
  aspect-ratio: 1; overflow: hidden; background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.vc-rec-img-wrap img {
  width: 100%; height: 100%; object-fit: contain; padding: 14px;
  transition: transform .4s ease; display: block;
}
.vc-rec-card:hover .vc-rec-img-wrap img { transform: scale(1.05); }
.vc-rec-badge {
  position: absolute; top: 10px; right: 10px;
  background: var(--cop); color: var(--w);
  font-size: .52rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 2px;
}
.vc-rec-body { padding: 14px 14px 0; }
.vc-rec-cat {
  font-size: .58rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cop); margin-bottom: 4px;
}
.vc-rec-name {
  font-size: .88rem; font-weight: 600; color: var(--ink);
  line-height: 1.3; margin-bottom: 6px; text-decoration: none; display: block;
}
.vc-rec-name:hover { color: var(--cop); }
.vc-rec-price {
  font-family: var(--fd); font-size: 1.1rem; color: var(--ink); font-weight: 500;
}
.vc-rec-price del { font-size: .78rem; color: var(--soft); margin-right: 4px; font-family: var(--fb); font-weight: 300; }
.vc-rec-price ins { text-decoration: none; color: var(--cop); }
.vc-rec-btn {
  display: block; width: 100%; margin-top: 12px; padding: 11px;
  background: var(--ink); color: var(--w) !important; text-align: center;
  font-family: var(--fb); font-size: .64rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; text-decoration: none;
  border: none; cursor: pointer; transition: background .2s;
}
.vc-rec-btn:hover { background: var(--cop) !important; }

/* gallery override removed */

/* ═══════════════════════════════════════════════════════════
   SKLEP — vshop + vsp (product cards)
   ═══════════════════════════════════════════════════════════ */

.vshop-wrap { background: var(--bg); }

/* ── Hero nagłówka sklepu ── */
.vshop-hero {
  background: var(--ink);
  position: relative; overflow: hidden;
  padding: 52px var(--pad) 44px;
}
.vshop-hero::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--cop) 30%, var(--cop) 70%, transparent 100%);
  opacity: .35;
}
.vshop-hero-inner {
  max-width: var(--max); margin: 0 auto; position: relative; z-index: 1;
}
.vshop-hero-tag {
  font-size: .58rem; font-weight: 700; letter-spacing: .3em; text-transform: uppercase;
  color: var(--cop); margin-bottom: 10px;
}
.vshop-hero-title {
  font-family: var(--fd); font-size: clamp(2.4rem, 5vw, 4.2rem);
  font-weight: 300; letter-spacing: -.03em; color: var(--w);
  line-height: 1.05; margin: 0 0 12px;
}
.vshop-hero-desc {
  font-size: .9rem; color: rgba(255,255,255,.38); max-width: 480px;
  line-height: 1.7; margin: 0 0 18px;
}
.vshop-breadcrumb .woocommerce-breadcrumb {
  font-size: .65rem !important; color: rgba(255,255,255,.28) !important;
  letter-spacing: .08em !important; padding: 0 !important; border: none !important;
  margin: 0 !important;
}
.vshop-breadcrumb .woocommerce-breadcrumb a { color: rgba(255,255,255,.38) !important; text-decoration: none; }
.vshop-breadcrumb .woocommerce-breadcrumb a:hover { color: var(--cop) !important; }
.vshop-bc-sep { opacity: .3; margin: 0 6px; }

/* Dekoracyjny tekst bg */
.vshop-hero-deco {
  position: absolute; right: calc(var(--pad) - 20px); top: 50%; transform: translateY(-50%);
  font-family: var(--fd); font-size: clamp(5rem, 10vw, 11rem);
  font-weight: 900; color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.05);
  user-select: none; pointer-events: none; letter-spacing: .05em;
  white-space: nowrap; z-index: 0;
}

/* ── Toolbar ── */
.vshop-toolbar {
  background: var(--w); border-bottom: 1px solid var(--line);
  position: sticky; top: 68px; z-index: 40;
}
.vshop-toolbar-inner {
  max-width: var(--max); margin: 0 auto; padding: 0 var(--pad);
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}

/* Category pills — pełna szerokość, scrollowalne */
.vshop-cats {
  display: flex; align-items: center; gap: 6px; flex-wrap: nowrap;
  overflow-x: auto; flex: 1 1 100%; min-width: 0;
  padding: 12px 0 8px; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.vshop-cats::-webkit-scrollbar { display: none; }
.vshop-cat-pill {
  white-space: nowrap; padding: 7px 16px;
  border: 1.5px solid var(--lne2); border-radius: 20px;
  font-size: .68rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--mid); text-decoration: none;
  transition: background .18s, border-color .18s, color .18s;
  flex-shrink: 0;
}
.vshop-cat-pill:hover, .vshop-cat-pill.is-active {
  background: var(--ink); border-color: var(--ink); color: var(--w);
}
.vshop-cat-pill.is-active { background: var(--cop); border-color: var(--cop); }

/* Prawa część toolbar — na tym samym wierszu z liczbą i sortowaniem */
.vshop-toolbar-right {
  display: flex; align-items: center; gap: 14px; margin-left: auto; flex-shrink: 0;
  padding-bottom: 10px;
}
.vshop-count {
  font-size: .72rem; color: var(--soft); letter-spacing: .06em; white-space: nowrap;
}
.vshop-toolbar-right .woocommerce-ordering { float: none !important; margin: 0 !important; }
.vshop-toolbar-right .woocommerce-ordering select {
  border: 1.5px solid var(--lne2) !important; border-radius: 2px !important;
  padding: 7px 12px !important; font-size: .72rem !important; color: var(--ink) !important;
  background: var(--bg) !important; font-family: var(--fb) !important; cursor: pointer;
}
.vshop-view-toggle { display: flex; gap: 4px; }
.vshop-view-btn {
  width: 32px; height: 32px; border-radius: 2px;
  border: 1.5px solid var(--lne2); background: none;
  color: var(--soft); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, border-color .15s, color .15s;
}
.vshop-view-btn.is-active,
.vshop-view-btn:hover { background: var(--ink); border-color: var(--ink); color: var(--w); }

/* ── Siatka produktów ── */
.vshop-products-wrap {
  max-width: var(--max); margin: 0 auto;
  padding: 36px var(--pad) 0;
}
.vshop-products-wrap .woocommerce {
  max-width: 100% !important; padding: 0 !important; margin: 0 !important;
}
.vshop-products-wrap ul.products {
  display: grid !important; float: none !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  padding: 0 !important; margin: 0 !important; list-style: none !important;
}
.vshop-products-wrap ul.products.columns-2 { grid-template-columns: repeat(2,1fr) !important; }
.vshop-products-wrap ul.products.columns-3 { grid-template-columns: repeat(3,1fr) !important; }

/* ── KARTA PRODUKTU vsp ── */
.vsp-card {
  background: var(--w) !important; border: 1px solid var(--line) !important;
  border-radius: var(--rad) !important; overflow: hidden !important;
  display: flex !important; flex-direction: column !important;
  float: none !important; width: auto !important; margin: 0 !important; padding: 0 !important;
  transition: border-color .22s, box-shadow .22s, transform .22s !important;
  position: relative !important;
}
.vsp-card:hover {
  border-color: var(--lne2) !important;
  box-shadow: 0 8px 40px rgba(26,23,20,.1) !important;
  transform: translateY(-3px) !important;
}

/* Zdjęcie */
.vsp-img-wrap {
  position: relative; overflow: hidden;
  background: var(--bg); aspect-ratio: 1 / 1;
  border-bottom: 1px solid var(--line);
}
.vsp-img-wrap a { display: block; width: 100%; height: 100%; }
.vsp-img {
  width: 100% !important; height: 100% !important;
  object-fit: contain !important; padding: 16px !important;
  display: block !important;
  transition: transform .45s cubic-bezier(.25,.46,.45,.94) !important;
}
.vsp-card:hover .vsp-img { transform: scale(1.06) !important; }

/* Badges */
.vsp-badge {
  position: absolute; top: 12px; left: 12px; z-index: 3;
  font-size: .56rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 2px;
}
.vsp-badge--sale { background: var(--cop); color: var(--w); }
.vsp-badge--new  { background: var(--ink); color: var(--w); }

/* Hover overlay z akcją */
.vsp-hover-actions {
  position: absolute; bottom: 12px; right: 12px; z-index: 3;
  display: flex; gap: 6px;
  opacity: 0; transform: translateY(6px);
  transition: opacity .2s, transform .2s;
}
.vsp-card:hover .vsp-hover-actions { opacity: 1; transform: translateY(0); }
.vsp-quick-btn {
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,.95); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink); text-decoration: none;
  transition: background .15s, color .15s;
}
.vsp-quick-btn:hover { background: var(--ink); color: var(--w); }

/* Body */
.vsp-body { padding: 14px 16px 6px; flex: 1; }
.vsp-cat {
  font-size: .58rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cop); margin-bottom: 5px;
}
.vsp-name {
  font-size: .9rem !important; font-weight: 600 !important; line-height: 1.35 !important;
  margin: 0 0 6px !important; padding: 0 !important; color: var(--ink) !important;
  font-family: var(--fb) !important;
}
.vsp-name a { color: inherit; text-decoration: none; }
.vsp-name a:hover { color: var(--cop); }

.vsp-rating {
  display: flex; align-items: center; gap: 5px; margin-bottom: 6px;
}
.vsp-stars { color: var(--cop); display: flex; gap: 1px; }
.vsp-rc { font-size: .7rem; color: var(--soft); }

.vsp-price-row { margin-bottom: 4px; }
.vsp-price {
  font-family: var(--fb) !important; font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--ink) !important; display: block !important; padding: 0 !important;
}
.vsp-price del, .vsp-price .woocommerce-Price-amount.amount:first-child:not(:last-child) {
  color: var(--soft) !important; font-size: .85rem !important; font-family: var(--fb) !important; font-weight: 400 !important;
}
.vsp-price ins { text-decoration: none !important; color: #b44 !important; font-weight: 700 !important; }

/* ATC button */
.vsp-atc {
  display: flex !important; align-items: center !important; justify-content: center !important;
  gap: 8px !important; width: 100% !important; padding: 13px !important;
  background: var(--ink) !important; color: var(--w) !important;
  font-family: var(--fb) !important; font-size: .65rem !important;
  font-weight: 700 !important; letter-spacing: .1em !important; text-transform: uppercase !important;
  text-decoration: none !important; border: none !important; cursor: pointer !important;
  border-radius: 0 !important; border-top: 1px solid var(--line) !important;
  transition: background .18s !important; margin-top: auto !important;
}
.vsp-atc:hover { background: var(--cop) !important; }

/* ── Paginacja sklepu ── */
.vshop-pagination {
  max-width: var(--max); margin: 0 auto; padding: 36px var(--pad) 60px;
}
.vshop-pagination .woocommerce-pagination ul {
  display: flex; gap: 6px; list-style: none; padding: 0; margin: 0;
  justify-content: center;
}
.vshop-pagination .woocommerce-pagination .page-numbers {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border: 1.5px solid var(--lne2); border-radius: 2px;
  font-size: .78rem; color: var(--mid); text-decoration: none;
  transition: background .15s, border-color .15s, color .15s;
}
.vshop-pagination .woocommerce-pagination .page-numbers.current,
.vshop-pagination .woocommerce-pagination .page-numbers:hover {
  background: var(--ink); border-color: var(--ink); color: var(--w);
}

/* ── "Brak produktów" ── */
.vshop-products-wrap .woocommerce-info {
  border: 1px solid var(--line) !important; background: var(--w) !important;
  border-radius: var(--rad) !important; padding: 32px 24px !important;
  font-size: .9rem !important; color: var(--mid) !important;
  margin: 0 !important;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .vshop-products-wrap ul.products { grid-template-columns: repeat(3,1fr) !important; }
  .vshop-hero-deco { display: none; }
}
@media (max-width: 760px) {
  .vshop-products-wrap ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 12px !important; }
  .vshop-toolbar { position: static; }
  .vshop-cats { padding: 8px 0; }
  .vshop-toolbar-right .woocommerce-ordering select { font-size: .68rem !important; }
  .vshop-count { display: none; }
}
@media (max-width: 460px) {
  .vshop-hero { padding: 36px var(--pad) 32px; }
  .vshop-hero-title { font-size: 2rem; }
}

/* ── Koszyk: rekomendacje — dopełnienie ── */
.vc-recs {
  background: var(--bg);
  margin: 48px calc(-1 * var(--pad)) 0;
  padding: 44px var(--pad) 56px;
}
.vc-recs-more {
  display: flex; align-items: center; gap: 6px;
  font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--soft); text-decoration: none; flex-shrink: 0;
  transition: color .2s;
}
.vc-recs-more svg { transition: transform .2s; }
.vc-recs-more:hover { color: var(--cop); }
.vc-recs-more:hover svg { transform: translateX(3px); }

/* Galeria: override duplikatów z poprzednich sesji */
.vp-gallery, .vp-gallery-inner, .vp-main-img { transition: opacity .22s ease, transform .22s ease !important; }

.vco-page-header-left { display: flex; align-items: baseline; gap: 14px; }
.vco-page-qty { background: var(--bg); color: var(--soft); border: 1px solid var(--line); padding: 3px 10px; border-radius: 20px; font-family: var(--fb); font-size: .72rem; font-weight: 600; display: inline-flex; align-items: center; vertical-align: baseline; flex-shrink: 0; letter-spacing: .04em; }

/* Koszyk — woo-main bez własnego paddingu */
.woo-main--cart {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ═══════════════════════════════════════════════
   NUKLEARNY FIX SZEROKOŚCI — koszyk i kasa
   Musi być NA KOŃCU CSS żeby wygrał ze wszystkim
   ═══════════════════════════════════════════════ */

/* Usuń KAŻDE ograniczenie szerokości na kasie i koszyku */
.woocommerce-cart #page-wrap,
.woocommerce-cart #page-wrap > *,
.woocommerce-cart .woo-main,
.woocommerce-cart .woo-main > *,
.woocommerce-cart .woo-main > .woocommerce,
.woocommerce-checkout #page-wrap,
.woocommerce-checkout #page-wrap > *,
.woocommerce-checkout .woo-main,
.woocommerce-checkout .woo-main > *,
.woocommerce-checkout .woo-main > .woocommerce {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  float: none !important;
  box-sizing: border-box !important;
}

/* vc2-wrap i vco-wrap są JEDYNYMI zarządcami szerokości */
.vc2-wrap,
.vco-wrap {
  max-width: var(--max) !important;
  margin: 0 auto !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.vc2-wrap { padding: 36px var(--pad) 0 !important; }
.vco-wrap { padding: 36px var(--pad) 80px !important; }

/* Grid koszyka — full width */
.vc2-grid {
  display: grid !important;
  grid-template-columns: 340px 1fr !important;
  gap: 28px !important;
  width: 100% !important;
}

/* Grid checkout — full width */
.vco-grid {
  display: grid !important;
  grid-template-columns: 1fr 360px !important;
  gap: 28px !important;
  width: 100% !important;
}

@media (max-width: 960px) {
  .vc2-grid { grid-template-columns: 1fr !important; }
  .vco-grid { grid-template-columns: 1fr !important; }
}

.woo-main--checkout {
  max-width: 100% !important; width: 100% !important;
  padding: 0 !important; margin: 0 !important;
}

/* ═══════════════════════════════
   LIGHTBOX — powiększenie zdjęcia
   ═══════════════════════════════ */
.vp-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.92);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .25s, visibility .25s;
}
.vp-lightbox.is-open { opacity: 1; visibility: visible; }
.vp-lightbox-img {
  max-width: 90vw; max-height: 90vh;
  object-fit: contain; display: block;
  border-radius: 2px;
  transform: scale(.96);
  transition: transform .25s;
}
.vp-lightbox.is-open .vp-lightbox-img { transform: scale(1); }
.vp-lightbox-close {
  position: fixed; top: 24px; right: 28px;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: #fff; font-size: 1.4rem; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .18s;
}
.vp-lightbox-close:hover { background: rgba(255,255,255,.2); }
.vp-lightbox-prev,
.vp-lightbox-next {
  position: fixed; top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: #fff; font-size: 1.3rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .18s;
}
.vp-lightbox-prev { left: 20px; }
.vp-lightbox-next { right: 20px; }
.vp-lightbox-prev:hover,
.vp-lightbox-next:hover { background: rgba(255,255,255,.25); }
.vp-lightbox-counter {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,.6); font-size: .78rem; letter-spacing: .12em;
}

/* ═══════════════════════════════════════════════════════
   VALOR — Program lojalnościowy
   ═══════════════════════════════════════════════════════ */

/* ── Banner w koszyku ── */
.valor-cart-banner {
  padding: 14px 20px; border-radius: var(--rad); margin-bottom: 20px;
  font-size: .85rem; line-height: 1.6;
}
.valor-cart-banner a { font-weight: 700; }
.valor-cart-banner--member {
  background: rgba(26,23,20,.04); border: 1px solid var(--line); color: var(--mid);
}
.valor-cart-banner--member strong { color: var(--ink); }
.valor-cart-banner--guest {
  background: linear-gradient(135deg, rgba(184,114,46,.06), rgba(184,114,46,.02));
  border: 1px solid rgba(184,114,46,.2); color: var(--mid);
}
.valor-cart-banner--guest a { color: var(--cop); }

/* ── Sekcja na stronie głównej ── */
.valor-home {
  padding: 72px 0; border-top: 1px solid var(--line);
  background: var(--ink);
}
.valor-home .tag { color: var(--cop); }
.valor-home .section-title { color: var(--w); }
.valor-home .section-title em { color: var(--cop); font-style: italic; }
.valor-home-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: center;
}
.valor-home-left { display: flex; flex-direction: column; }
.valor-home-desc { font-size: .92rem; color: rgba(255,255,255,.45); line-height: 1.8; margin: 0 0 8px; max-width: 420px; }
.valor-home-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.valor-home-card {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--rad); padding: 24px 20px;
  transition: border-color .2s, background .2s;
}
.valor-home-card:hover { border-color: rgba(184,114,46,.3); background: rgba(255,255,255,.05); }
.valor-home-card-icon { margin-bottom: 12px; color: var(--cop); display: flex; align-items: center; }
.valor-home-card-icon svg { width: 24px; height: 24px; stroke: var(--cop); }
.valor-home-card h4 {
  font-family: var(--fb); font-size: .78rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--w); margin: 0 0 8px;
}
.valor-home-card p { font-size: .78rem; color: rgba(255,255,255,.4); line-height: 1.6; margin: 0; }

@media (max-width: 1100px) {
  .valor-home-grid { grid-template-columns: 1fr; gap: 36px; }
  .valor-home-left { align-items: center; text-align: center; }
  .valor-home-desc { max-width: 100%; }
  .valor-home-cards { max-width: 600px; margin: 0 auto; width: 100%; }
}
@media (max-width: 640px) {
  .valor-home-cards { grid-template-columns: 1fr; max-width: 100%; }
  .valor-home { padding: 48px 0; }
  .valor-home-left { align-items: flex-start; text-align: left; }
}

/* ── Strona /program-valor ── */
.valor-page { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad) 80px; }
.valor-page-inner { max-width: 900px; margin: 0 auto; }

/* Status bar */
.vp-status-bar {
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
  padding: 22px 28px; margin: 40px 0 48px;
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--rad);
}
.vp-status-bar--prompt {
  justify-content: space-between;
}
.vp-status-bar--prompt p { margin: 0; font-size: .88rem; color: var(--mid); }
.vp-status-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px; border-radius: 20px;
  font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
}
.vp-badge--valor { background: var(--ink); color: var(--w); }
.vp-badge--elite { background: var(--cop); color: var(--w); }
.vp-status-pts { font-size: .88rem; color: var(--mid); }
.vp-status-pts strong { font-family: var(--fd); font-size: 1.3rem; color: var(--ink); margin-right: 4px; }

/* Section spacing */
.vp-section { margin-bottom: 60px; }
.vp-section-title {
  font-family: var(--fd); font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 400; color: var(--ink); margin: 8px 0 32px;
}

/* Steps */
.vp-steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.vp-step-card {
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--rad);
  padding: 28px 24px; text-align: center;
}
.vp-step-num {
  width: 44px; height: 44px; border-radius: 50%; margin: 0 auto 16px;
  display: flex; align-items: center; justify-content: center;
  background: var(--ink); color: var(--w);
  font-family: var(--fd); font-size: 1.1rem; font-weight: 500;
}
.vp-step-card h4 {
  font-family: var(--fb); font-size: .82rem; font-weight: 700; color: var(--ink);
  letter-spacing: .06em; text-transform: uppercase; margin: 0 0 10px;
}
.vp-step-card p { font-size: .84rem; color: var(--mid); line-height: 1.7; margin: 0; }

/* Levels comparison */
.vp-levels-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.vp-level-card {
  border: 1px solid var(--line); border-radius: var(--rad); overflow: hidden;
  background: var(--w);
}
.vp-level-card--elite { border-color: var(--cop); box-shadow: 0 4px 24px rgba(184,114,46,.1); }
.vp-level-head {
  padding: 28px 24px; text-align: center;
}
.vp-level--valor { background: var(--ink); color: var(--w); }
.vp-level--elite { background: linear-gradient(135deg, var(--cop), #D4904A); color: var(--w); }
.vp-level-icon { margin-bottom: 8px; display: flex; justify-content: center; }
.vp-level-icon svg { stroke: rgba(255,255,255,.85); }
.vp-level-head h3 {
  font-family: var(--fb); font-size: .9rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; margin: 0 0 6px;
}
.vp-level-req { font-size: .72rem; opacity: .65; margin: 0; }
.vp-level-perks {
  list-style: none; padding: 20px 24px; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.vp-level-perks li {
  font-size: .84rem; color: var(--mid); line-height: 1.5;
  padding: 8px 0; border-bottom: 1px solid var(--line);
}
.vp-level-perks li:last-child { border-bottom: none; }
.vp-level-perks li strong { color: var(--ink); }
.vp-perk-disabled { color: var(--soft) !important; opacity: .5; }

/* FAQ */
.vp-faq { display: flex; flex-direction: column; gap: 0; }
.vp-faq-item {
  border-bottom: 1px solid var(--line);
}
.vp-faq-q {
  padding: 18px 0; cursor: pointer;
  font-size: .88rem; font-weight: 600; color: var(--ink);
  list-style: none; display: flex; justify-content: space-between; align-items: center;
}
.vp-faq-q::after { content: '+'; font-size: 1.2rem; color: var(--cop); transition: transform .2s; }
.vp-faq-item[open] .vp-faq-q::after { content: '−'; }
.vp-faq-q::-webkit-details-marker { display: none; }
.vp-faq-a p { font-size: .85rem; color: var(--mid); line-height: 1.8; padding: 0 0 18px; margin: 0; }

/* CTA bottom */
.vp-cta-bottom {
  text-align: center; padding: 48px 32px;
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--rad);
  margin-top: 20px;
}
.vp-cta-bottom h3 {
  font-family: var(--fd); font-size: 1.6rem; font-weight: 400; color: var(--ink); margin: 0 0 10px;
}
.vp-cta-bottom p { font-size: .88rem; color: var(--mid); margin: 0 0 24px; }

@media (max-width: 768px) {
  .vp-steps-grid { grid-template-columns: 1fr; }
  .vp-levels-grid { grid-template-columns: 1fr; }
  .vp-status-bar { flex-direction: column; align-items: flex-start; gap: 12px; }
  .valor-page { padding: 0 16px 60px; }
}

/* ── Moje konto: VALOR tab ── */
.valor-account { max-width: 720px; }

.valor-status {
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
  padding: 24px 28px; margin-bottom: 28px;
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--rad);
}
.valor-status-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 18px; border-radius: 20px;
  font-size: .78rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
}
.valor-badge--valor { background: var(--ink); color: var(--w); }
.valor-badge--elite { background: var(--cop); color: var(--w); }
.valor-badge--none { background: var(--bg2); color: var(--soft); }
.valor-pts-number { font-family: var(--fd); font-size: 2rem; font-weight: 400; color: var(--ink); line-height: 1; }
.valor-pts-label { font-size: .72rem; color: var(--soft); margin-top: 2px; }

/* Progress */
.valor-progress { margin-bottom: 28px; }
.valor-progress-label {
  display: flex; justify-content: space-between; font-size: .75rem; color: var(--mid); margin-bottom: 8px;
}
.valor-progress-bar {
  height: 6px; background: var(--line); border-radius: 3px; overflow: hidden;
}
.valor-progress-fill {
  height: 100%; border-radius: 3px;
  background: linear-gradient(90deg, var(--cop), #D4904A);
  transition: width .8s cubic-bezier(.4,0,.2,1);
}
.valor-progress-note { font-size: .78rem; color: var(--soft); margin-top: 8px; }
.valor-elite-note {
  padding: 18px 22px; background: rgba(184,114,46,.06); border: 1px solid rgba(184,114,46,.15);
  border-radius: var(--rad); margin-bottom: 28px;
}
.valor-elite-note p { font-size: .85rem; color: var(--mid); margin: 0; }
.valor-elite-note strong { color: var(--cop); }
.valor-join-prompt { margin-bottom: 28px; }
.valor-join-prompt p { color: var(--mid); font-size: .88rem; margin-bottom: 12px; }

/* Redeem */
.valor-redeem {
  padding: 24px 28px; background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--rad); margin-bottom: 28px;
}
.valor-redeem h3 { font-family: var(--fb); font-size: .9rem; font-weight: 700; color: var(--ink); margin: 0 0 6px; }
.valor-redeem-rate { font-size: .78rem; color: var(--cop); font-weight: 600; margin: 0 0 16px; }
.valor-redeem-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.valor-redeem-select {
  flex: 1; min-width: 200px; padding: 10px 14px; border: 1.5px solid var(--lne2);
  border-radius: var(--rad); background: var(--w); font-family: var(--fb);
  font-size: .85rem; color: var(--ink); outline: none;
}
.valor-redeem-msg { margin-top: 12px; font-size: .82rem; min-height: 1.2em; }
.valor-msg--ok { color: var(--grn); }
.valor-msg--err { color: var(--red); }

/* Benefits */
.valor-benefits-summary { margin-bottom: 28px; }
.valor-benefits-summary h3 { font-family: var(--fb); font-size: .9rem; font-weight: 700; color: var(--ink); margin: 0 0 14px; }
.valor-perks { display: flex; flex-direction: column; gap: 0; }
.valor-perk {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; border-bottom: 1px solid var(--line);
  font-size: .84rem; color: var(--soft);
}
.valor-perk:last-child { border-bottom: none; }
.valor-perk.active { color: var(--mid); }
.valor-perk.active .valor-perk-icon { opacity: 1; color: var(--cop); }
.valor-perk-icon { color: var(--soft); opacity: .4; display: flex; align-items: center; flex-shrink: 0; }
.valor-perk-icon svg { stroke: currentColor; }

/* History */
.valor-history { margin-top: 8px; }
.valor-history h3 { font-family: var(--fb); font-size: .9rem; font-weight: 700; color: var(--ink); margin: 0 0 14px; }
.valor-history-table { width: 100%; border-collapse: collapse; font-size: .82rem; }
.valor-history-table th {
  text-align: left; padding: 10px 12px; background: var(--bg);
  font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: var(--soft); font-weight: 700;
  border-bottom: 1px solid var(--line);
}
.valor-history-table td {
  padding: 10px 12px; border-bottom: 1px solid var(--line); color: var(--mid);
}
.valor-pts-plus { color: var(--grn); font-weight: 600; }
.valor-pts-minus { color: var(--red); font-weight: 600; }

/* ═══════════════════════════════════════════════════════
   STRONA KONTAKTOWA — vk-*
   ═══════════════════════════════════════════════════════ */
.vk-body {
  max-width: var(--max); margin: 0 auto;
  padding: 52px var(--pad) 80px;
}
.vk-inner {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 52px;
  align-items: start;
}

/* ── Sekcja formularza ── */
.vk-section-title {
  font-family: var(--fd); font-size: 1.6rem; font-weight: 400;
  color: var(--ink); margin: 0 0 8px; letter-spacing: -.02em;
}
.vk-section-desc {
  font-size: .88rem; color: var(--soft); margin: 0 0 32px; line-height: 1.7;
}

/* ── Formularz ── */
.vk-form { display: flex; flex-direction: column; gap: 20px; }
.vk-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.vk-field { display: flex; flex-direction: column; gap: 6px; }
.vk-field label {
  font-size: .68rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink);
}
.vk-field label abbr {
  color: var(--cop); text-decoration: none; margin-left: 2px;
}
.vk-field input,
.vk-field select,
.vk-field textarea {
  font-family: var(--fb); font-size: .9rem; color: var(--ink);
  background: var(--bg); border: 1.5px solid var(--line);
  padding: 12px 16px; border-radius: var(--rad);
  outline: none; transition: border-color .2s, background .2s;
  width: 100%; box-sizing: border-box;
}
.vk-field input:focus,
.vk-field select:focus,
.vk-field textarea:focus {
  border-color: var(--cop); background: var(--w);
}
.vk-field input::placeholder,
.vk-field textarea::placeholder {
  color: var(--soft); font-size: .85rem;
}
.vk-field textarea { resize: vertical; min-height: 140px; line-height: 1.7; }
.vk-field select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235C5650' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
  cursor: pointer;
}

/* ── Zgoda ── */
.vk-consent {
  display: flex; align-items: flex-start; gap: 10px;
}
.vk-consent input[type="checkbox"] {
  width: 18px; height: 18px; margin-top: 2px; flex-shrink: 0;
  accent-color: var(--cop); cursor: pointer;
}
.vk-consent label {
  font-size: .78rem; color: var(--mid); line-height: 1.6; cursor: pointer;
}
.vk-consent label a { color: var(--cop); text-decoration: underline; }

/* ── Przycisk ── */
.vk-submit {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 15px 36px; align-self: flex-start;
  background: var(--ink); color: var(--w); border: none;
  font-family: var(--fb); font-size: .72rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  border-radius: var(--rad); cursor: pointer;
  transition: background .2s, transform .1s;
}
.vk-submit:hover { background: var(--cop); }
.vk-submit:active { transform: scale(.98); }
.vk-submit:disabled { opacity: .6; cursor: wait; }
.vk-submit-arrow { transition: transform .2s; }
.vk-submit:hover .vk-submit-arrow { transform: translateX(3px); }

/* ── Komunikat ── */
.vk-msg {
  display: none; padding: 14px 18px; border-radius: var(--rad);
  font-size: .85rem; font-weight: 500; line-height: 1.5;
}
.vk-msg--success {
  background: rgba(42,96,64,.08); border: 1px solid rgba(42,96,64,.2);
  color: var(--grn);
}
.vk-msg--error {
  background: rgba(179,48,48,.06); border: 1px solid rgba(179,48,48,.15);
  color: var(--red);
}

/* ── Prawa kolumna: karty info ── */
.vk-info-col { display: flex; flex-direction: column; gap: 16px; }
.vk-info-card {
  background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--rad); padding: 22px 24px;
}
.vk-info-card-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.vk-info-card-head svg { color: var(--cop); flex-shrink: 0; }
.vk-info-card-head h3 {
  font-family: var(--fb); font-size: .7rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink); margin: 0;
}
.vk-info-link {
  display: block; font-size: 1rem; font-weight: 600;
  color: var(--ink); text-decoration: none;
  transition: color .2s; margin-bottom: 4px;
}
.vk-info-link:hover { color: var(--cop); }
.vk-info-note {
  font-size: .75rem; color: var(--soft); margin: 0;
}
.vk-info-address {
  font-size: .88rem; color: var(--mid); line-height: 1.7; margin: 0;
}

/* ── Social ── */
.vk-social { padding-top: 8px; }
.vk-social-label {
  font-size: .6rem; font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--soft); margin-bottom: 10px;
}
.vk-social-icons { display: flex; gap: 8px; }
.vk-soc-btn {
  width: 40px; height: 40px; border-radius: 50%;
  border: 1.5px solid var(--line); background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  color: var(--mid); text-decoration: none;
  transition: border-color .2s, color .2s, background .2s;
}
.vk-soc-btn:hover {
  border-color: var(--cop); color: var(--cop);
  background: rgba(193,140,73,.05);
}

/* ── Responsive ── */
@media (max-width: 960px) {
  .vk-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .vk-info-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  .vk-social { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .vk-inner { gap: 32px; }
  .vk-row { grid-template-columns: 1fr; }
  .vk-info-col { grid-template-columns: 1fr; }
  .vk-body { padding: 32px var(--pad) 60px; }
  .vk-submit { width: 100%; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════
   WHATSAPP — przycisk pływający
   ═══════════════════════════════════════════════════════ */
.vons-wa {
  position: fixed; bottom: 28px; left: 28px; z-index: 9990;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(37,211,102,.35);
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  opacity: 0; transform: scale(.6) translateY(20px);
  pointer-events: none;
}
.vons-wa.is-visible {
  opacity: 1; transform: scale(1) translateY(0);
  pointer-events: auto;
}
.vons-wa:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(37,211,102,.45);
}
.vons-wa:active { transform: scale(.96); }

/* Tooltip */
.vons-wa::before {
  content: 'Napisz do nas';
  position: absolute; left: calc(100% + 12px); top: 50%; transform: translateY(-50%);
  background: var(--ink); color: var(--w);
  font-family: var(--fb); font-size: .68rem; font-weight: 700;
  letter-spacing: .04em; white-space: nowrap;
  padding: 8px 14px; border-radius: var(--rad);
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.vons-wa:hover::before { opacity: 1; }

/* Pulsujący pierścień */
.vons-wa::after {
  content: '';
  position: absolute; inset: -4px; border-radius: 50%;
  border: 2px solid #25D366;
  animation: vons-wa-pulse 2.5s ease-out infinite;
}
@keyframes vons-wa-pulse {
  0% { transform: scale(1); opacity: .5; }
  70% { transform: scale(1.35); opacity: 0; }
  100% { transform: scale(1.35); opacity: 0; }
}

@media (max-width: 768px) {
  .vons-wa { bottom: 20px; left: 20px; width: 52px; height: 52px; }
  .vons-wa::before { display: none; }
  .vons-wa svg { width: 24px; height: 24px; }
}

/* ═══════════════════════════════════════════════════════
   QUICK LINKS — szybkie wejścia pod hero
   ═══════════════════════════════════════════════════════ */
.quick-links {
  background: var(--w); border-bottom: 1px solid var(--line);
  padding: 0;
}
.quick-links-inner {
  max-width: var(--max); margin: 0 auto; padding: 0 var(--pad);
  display: flex; align-items: center; justify-content: center; gap: 0;
  overflow-x: auto; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.quick-links-inner::-webkit-scrollbar { display: none; }
.quick-link {
  display: flex; align-items: center; gap: 8px;
  padding: 16px 22px;
  font-size: .78rem; font-weight: 600; color: var(--mid);
  text-decoration: none; white-space: nowrap;
  border-right: 1px solid var(--line);
  transition: background .15s, color .15s;
}
.quick-link:last-child { border-right: none; }
.quick-link:hover { background: var(--bg); color: var(--ink); }
.quick-link-icon { color: var(--cop); display: flex; align-items: center; flex-shrink: 0; }
.quick-link-icon svg { stroke: var(--cop); }
.quick-link-label { letter-spacing: .04em; }

@media (max-width: 768px) {
  .quick-links-inner { justify-content: flex-start; gap: 0; }
  .quick-link { padding: 12px 16px; font-size: .72rem; }
  .quick-links-inner {
    mask-image: linear-gradient(to right, black 88%, transparent);
    -webkit-mask-image: linear-gradient(to right, black 88%, transparent);
  }
}

/* ═══════════════════════════════════════════════════════
   QUICK FACTS — "Najważniejsze w 10 sekund"
   ═══════════════════════════════════════════════════════ */
.vp-quick-facts {
  background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--rad); padding: 20px 24px;
  margin: 20px 0 4px;
}
.vp-qf-label {
  font-size: .58rem; font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--cop); margin-bottom: 14px;
}
.vp-qf-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; border-bottom: 1px solid var(--line);
  font-size: .82rem;
}
.vp-qf-row:last-child { border-bottom: none; }
.vp-qf-icon { font-size: .9rem; width: 22px; text-align: center; flex-shrink: 0; }
.vp-qf-key {
  font-weight: 700; color: var(--ink); min-width: 80px;
  font-size: .68rem; letter-spacing: .06em; text-transform: uppercase;
}
.vp-qf-val { color: var(--mid); flex: 1; }

@media (max-width: 768px) {
  .vp-quick-facts { padding: 16px; margin: 16px 0 4px; }
  .vp-qf-row { font-size: .78rem; gap: 8px; }
  .vp-qf-key { min-width: 70px; font-size: .62rem; }
}

/* ═══════════════════════════════════════════════════════
   BESTSELLER BADGE + CHIPY ATRYBUTÓW
   ═══════════════════════════════════════════════════════ */
.vsp-badge--best { background: var(--ink); color: var(--w); }

.vsp-chips {
  display: flex; gap: 4px; flex-wrap: wrap; margin: 4px 0 6px;
}
.vsp-chip {
  display: inline-block;
  padding: 2px 7px; border-radius: 10px;
  background: var(--bg); border: 1px solid var(--line);
  font-size: .6rem; color: var(--soft); line-height: 1.5;
  white-space: nowrap; max-width: 140px; overflow: hidden; text-overflow: ellipsis;
}

@media (max-width: 768px) {
  .vsp-chips { display: none; }
}

/* ═══════════════════════════════════════════════════════
   MOBILE FIX v17 — poprawki na telefon
   ═══════════════════════════════════════════════════════ */

/* ── 1. STOPKA: czytelność, rozmiar tekstu, wycentrowanie menu ── */
@media (max-width: 768px) {
  .site-footer { overflow: visible; }
  .footer-top {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding: 36px 20px 28px !important;
  }
  /* Wycentruj kolumny menu */
  .footer-brand { text-align: center; }
  .footer-brand a { display: inline-block; }
  .footer-logo-img { margin: 0 auto 18px !important; }
  .footer-tagline {
    max-width: 100%;
    margin-left: auto; margin-right: auto;
    font-size: .88rem;
    color: rgba(255,255,255,.50);
    text-align: center;
  }
  .footer-socials { justify-content: center; width: 100%; }
  .footer-col,
  .footer-address { text-align: center; }
  .footer-col h4,
  .footer-address h4 {
    font-size: .68rem;
    color: rgba(255,255,255,.6);
    text-align: center;
  }
  .footer-col ul {
    align-items: center;
  }
  .footer-col ul li a {
    font-size: .88rem;
    color: rgba(255,255,255,.50);
    justify-content: center;
  }
  .footer-col ul li a::before { display: none; }
  .footer-address-row { align-items: center; }
  .footer-address-label {
    font-size: .6rem;
    text-align: center;
  }
  .footer-address-val {
    font-size: .88rem;
    color: rgba(255,255,255,.50);
    text-align: center;
  }
  .footer-address-val a {
    color: rgba(255,255,255,.50);
  }
  .footer-bottom {
    flex-direction: column; align-items: center; gap: 10px;
    padding: 16px 20px;
    text-align: center;
  }
  .footer-links { flex-wrap: wrap; gap: 12px 18px; justify-content: center; }
  .footer-links a { font-size: .72rem; color: rgba(255,255,255,.32); }
  .footer-copy { font-size: .72rem; text-align: center; }
  .nl-section { padding: 48px 0; }
  .nl-title { font-size: 1.6rem !important; }
}

/* ── 2. GALERIA PRODUKTU: certyfikaty nie nachodzą na zdjęcie ── */
@media (max-width: 768px) {
  .vp-certs {
    position: static !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    padding: 8px 12px;
    gap: 4px;
    background: var(--bg);
    border-top: 1px solid var(--line);
  }
  .vp-cert {
    font-size: .52rem;
    padding: 4px 8px;
    backdrop-filter: none;
    background: var(--w);
  }
  .vp-mainview { padding: 16px 12px; }
  .vp-zoom-hint { display: none; }
  .vp-main-img { max-height: 320px !important; }
  .vp-gallery {
    max-height: none !important;
    height: auto !important;
  }
  .vp-gallery-inner {
    height: auto !important;
    max-height: none !important;
    flex-direction: column;
  }
}

/* ── 3. STRONA PRODUKTU: przyciski Dodaj/Kup na telefonie ── */
@media (max-width: 768px) {
  .vp-buy-row {
    flex-wrap: wrap;
  }
  .vp-qty {
    flex: 0 0 auto;
  }
  .vp-add-btn {
    flex: 1 1 0%;
    min-width: 0;
    height: 50px;
    padding: 0 14px !important;
    font-size: .62rem !important;
    gap: 4px !important;
  }
  .vp-add-price { display: none; }
  .vp-wish-btn {
    width: 50px; height: 50px;
  }
  .vp-qty-btn { width: 40px; height: 50px; }
  .vp-qty-input { width: 44px; height: 50px; font-size: .95rem; }
  .vp-buynow-btn {
    font-size: .65rem;
    padding: 12px;
    letter-spacing: .1em;
  }
  .vp-trust {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .vp-trust-item span {
    font-size: .5rem;
    letter-spacing: .06em;
  }
  .vp-info {
    padding: 24px 16px 40px !important;
  }
  .vp-title {
    font-size: 1.5rem !important;
    line-height: 1.25 !important;
  }
  .vp-price-main {
    font-size: 1.8rem;
  }
}

/* ── 4. POWIĄZANE PRODUKTY: 2 kolumny zamiast 4 na telefonie ── */
@media (max-width: 768px) {
  .vp-rel-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
    padding: 0 16px !important;
  }
  .vp-rel-info { padding: 10px 12px; }
  .vp-rel-name { font-size: .8rem; }
  .vp-rel-brand { font-size: .48rem; letter-spacing: .2em; }
  .vp-related { padding: 36px 0 !important; }
  .vp-related-head { padding: 0 16px !important; }
}

/* ── 5. SIATKA PRODUKTÓW SKLEPU: czytelność na telefonie ── */
@media (max-width: 768px) {
  /* Ukryj przełącznik widoku — na telefonie zawsze 2 kolumny */
  .vshop-view-toggle { display: none !important; }

  /* Toolbar: kategorie + sortowanie lepiej na mobile */
  .vshop-toolbar-inner {
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px var(--pad) !important;
    min-height: auto;
  }
  .vshop-cats {
    order: 2;
    flex: 1 1 100%;
    padding: 4px 0 8px;
    gap: 6px;
    -webkit-overflow-scrolling: touch;
    mask-image: linear-gradient(to right, black 90%, transparent);
    -webkit-mask-image: linear-gradient(to right, black 90%, transparent);
  }
  .vshop-cat-pill {
    padding: 8px 16px;
    font-size: .7rem;
    border-radius: 20px;
    letter-spacing: .06em;
  }
  .vshop-toolbar-right {
    order: 1;
    flex: 1 1 100%;
    margin-left: 0;
    justify-content: flex-start;
  }
  .vshop-toolbar-right .woocommerce-ordering select {
    width: 100%;
    padding: 9px 14px !important;
    font-size: .76rem !important;
  }
  .vshop-count { display: none; }

  /* Wymuszenie 2 kolumn niezależnie od klasy columns-X ustawionej przez JS */
  .vshop-products-wrap ul.products,
  .vshop-products-wrap ul.products.columns-2,
  .vshop-products-wrap ul.products.columns-3,
  .vshop-products-wrap ul.products.columns-4,
  .vshop-products-wrap ul.products.columns-5,
  .woocommerce ul.products,
  .woocommerce ul.products.columns-2,
  .woocommerce ul.products.columns-3,
  .woocommerce ul.products.columns-4,
  .woocommerce ul.products.columns-5,
  .woo-main ul.products,
  .woo-main ul.products.columns-4 {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .vsp-body { padding: 10px 12px 4px; }
  .vsp-name {
    font-size: .78rem !important;
    line-height: 1.3 !important;
  }
  .vsp-cat { font-size: .5rem; margin-bottom: 3px; }
  .vsp-price { font-size: .95rem !important; font-weight: 700 !important; }
  .vsp-atc {
    font-size: .58rem !important;
    padding: 10px !important;
    gap: 4px !important;
  }
  .vsp-img { padding: 10px !important; }
  .vshop-hero { padding: 28px 16px 24px !important; }
  .vshop-hero-title { font-size: 1.8rem !important; }
}

/* ── 6. STRONA GŁÓWNA: karty produktów i kategorie na telefonie ── */
@media (max-width: 768px) {
  .vons-prod-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .vons-prod-body { padding: 10px 12px 6px; }
  .vons-prod-name { font-size: .8rem; }
  .vons-prod-btn {
    font-size: .58rem;
    padding: 10px 12px;
  }
  .section { padding: 48px 0; }
  .section-head { margin-bottom: 24px; flex-direction: column; align-items: flex-start; gap: 8px; }
  .hero-bottom {
    flex-wrap: wrap !important;
  }
  .hero-bottom-item {
    flex: 1 1 auto !important;
    min-width: 0;
    font-size: .65rem;
    padding: 0 12px;
    height: 48px;
    justify-content: center;
  }
  .hero-bottom-stat {
    flex: 1 1 50% !important;
    min-width: 0;
  }
  .hero-bottom-stat strong { font-size: 1.2rem; }
}

/* ── 7. KOSZYK — rekomendacje na telefonie ── */
@media (max-width: 768px) {
  .vc2-recs .products,
  .vc-recs-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .vc-recs { padding: 32px 16px 40px; margin: 32px -16px 0; }
  .vc2-recs { padding: 36px 16px 48px; margin: 32px -16px 0; }
  .vc2-recs-head { padding: 0; gap: 12px; }
  .vc2-recs-title { font-size: 1.3rem; white-space: normal; }
  .vc2-recs-link { font-size: .6rem; }
}

/* ── 8. OGÓLNE — tekst nie może dotykać krawędzi ── */
@media (max-width: 768px) {
  /* Sekcje z negatywnym marginem - zapewnij wewnętrzny padding */
  .vc2-recs .vsp-body,
  .vc-recs .vsp-body,
  .vc2-recs .vons-prod-body { padding: 10px 10px 4px; }
  .vc2-recs .vsp-name,
  .vc-recs .vsp-name { font-size: .76rem !important; }

  /* Kontener — zapewnij padding na ekranach dotykowych */
  .container { padding: 0 16px !important; }
  .section-inner { padding: 0 16px !important; }
  .woo-main { padding-left: 16px !important; padding-right: 16px !important; }

  /* Nagłówki sekcji, które uciekają za ekran */
  .vc2-header { padding-left: 0; padding-right: 0; }
  .vc2-ship-bar { margin-left: 0; margin-right: 0; }

  /* Breadcrumb */
  .woocommerce-breadcrumb {
    padding: 12px 16px !important;
    font-size: .7rem;
  }

  /* Sekcja "Może Cię zainteresować" — header */
  .vc-recs-head { flex-wrap: wrap; gap: 8px; }
  .vc-recs-title {
    font-size: 1.3rem !important;
    white-space: normal !important;
  }

  /* Taby produktu */
  .vp-tabs-wrap { padding: 0 16px 40px !important; }
  .vp-tab-btn { padding: 14px 16px; font-size: .64rem; }
}

/* ── 9. BARDZO MAŁY EKRAN (< 400px) ── */
@media (max-width: 400px) {
  :root { --pad: 14px; }
  .footer-top { padding: 32px 14px 24px !important; }
  .footer-bottom { padding: 14px; }
  .vp-buy-row {
    gap: 6px;
  }
  .vp-add-btn {
    flex: 1 1 100%;
    order: 3;
    height: 48px;
  }
  .vp-qty { order: 1; }
  .vp-wish-btn { order: 2; width: 48px; height: 48px; }
  .vp-rel-grid { gap: 8px !important; }
  .vons-prod-grid { gap: 8px !important; }
  .hero-bottom-item { font-size: .58rem; padding: 0 8px; }
}

/* ══════════════════════════════════════════════════════════════════════
   SEKCJA SEO — tekst pod opiniami na stronie głównej
   ══════════════════════════════════════════════════════════════════════ */
.vonsace-seo-section {
  padding: 48px 0 56px;
  border-top: 1px solid var(--line);
  background: var(--bg);
}
.vonsace-seo-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 var(--pad);
}
.vonsace-seo-content h2 {
  font-family: var(--fd);
  font-size: 1.35rem;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 20px;
  letter-spacing: -.01em;
}
.vonsace-seo-content p {
  font-size: .88rem;
  line-height: 1.75;
  color: var(--mid);
  margin: 0 0 14px;
}
.vonsace-seo-content p:last-child {
  margin-bottom: 0;
}
.vonsace-seo-content strong {
  color: var(--ink);
  font-weight: 600;
}
.vonsace-seo-content a {
  color: var(--cop);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.vonsace-seo-content a:hover {
  color: var(--ink);
}
@media (max-width: 600px) {
  .vonsace-seo-section { padding: 36px 0 40px; }
  .vonsace-seo-content h2 { font-size: 1.15rem; }
  .vonsace-seo-content p { font-size: .84rem; }
}

/* ══════════════════════════════════════════════════════════════════════
   PUSTY KOSZYK — rich empty state z bestsellerami
   ══════════════════════════════════════════════════════════════════════ */
.vc2-empty-rich {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px 0 40px;
}

/* Hero section */
.vc2-empty-hero {
  text-align: center;
  padding: 40px 20px 32px;
}
.vc2-empty-icon {
  color: var(--lne2);
  margin-bottom: 16px;
}
.vc2-empty-title {
  font-family: var(--fd);
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 10px;
  letter-spacing: -.01em;
}
.vc2-empty-desc {
  font-size: .9rem;
  color: var(--mid);
  line-height: 1.6;
  max-width: 440px;
  margin: 0 auto;
}

/* Motivator bar */
.vc2-empty-motivator {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 20px;
  background: rgba(193,140,73,.06);
  border: 1px solid rgba(193,140,73,.15);
  border-radius: 3px;
  margin: 0 0 32px;
  font-size: .82rem;
  color: var(--mid);
}
.vc2-empty-motivator svg { flex-shrink: 0; color: var(--cop); }
.vc2-empty-motivator strong { color: var(--ink); }

/* Recs grid */
.vc2-empty-recs { margin-bottom: 28px; }
.vc2-empty-recs-title {
  font-family: var(--fb);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--soft);
  margin: 0 0 16px;
}
.vc2-empty-recs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.vc2-empty-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  border-radius: 3px;
  background: var(--w);
  overflow: hidden;
  transition: border-color .2s;
}
.vc2-empty-card:hover { border-color: var(--cop); }
.vc2-empty-card-img {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--bg);
}
.vc2-empty-card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 10px;
  transition: transform .3s;
}
.vc2-empty-card:hover .vc2-empty-card-img img { transform: scale(1.04); }
.vc2-empty-card-body {
  padding: 10px 12px 8px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.vc2-empty-card-name {
  font-size: .8rem;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 4px;
}
.vc2-empty-card-name:hover { color: var(--cop); }
.vc2-empty-card-price {
  font-family: var(--fd);
  font-size: .95rem;
  font-weight: 500;
  color: var(--ink);
  margin-top: auto;
}
.vc2-empty-card-price del { color: var(--soft); font-size: .8rem; }
.vc2-empty-card-price ins { text-decoration: none; color: #b44; }
.vc2-empty-card-btn {
  display: block;
  width: 100%;
  padding: 11px 10px;
  background: var(--ink);
  color: var(--w) !important;
  font-family: var(--fb);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: background .2s;
}
.vc2-empty-card-btn:hover { background: var(--cop); }

/* Category links */
.vc2-empty-cats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  padding: 20px 0 0;
  border-top: 1px solid var(--line);
}
.vc2-empty-cats-label {
  font-size: .78rem;
  color: var(--soft);
  font-weight: 600;
  margin-right: 4px;
}
.vc2-empty-cats a {
  font-size: .8rem;
  color: var(--ink);
  text-decoration: none;
  padding: 6px 14px;
  border: 1px solid var(--lne2);
  border-radius: 99px;
  transition: border-color .2s, background .2s;
  white-space: nowrap;
}
.vc2-empty-cats a:hover {
  border-color: var(--cop);
  background: rgba(193,140,73,.04);
  color: var(--cop);
}
.vc2-empty-cats a:last-child {
  border-color: var(--cop);
  color: var(--cop);
  font-weight: 600;
}

/* Responsive */
@media (max-width: 700px) {
  .vc2-empty-recs-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .vc2-empty-hero { padding: 28px 16px 24px; }
  .vc2-empty-title { font-size: 1.3rem; }
  .vc2-empty-motivator { flex-wrap: wrap; font-size: .78rem; text-align: center; }
}
@media (max-width: 400px) {
  .vc2-empty-recs-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .vc2-empty-card-name { font-size: .75rem; }
}

/* Fallback: ukryj domyślny WC empty cart message gdyby remove_action nie zadziałał */
.woocommerce-info.wc-empty-cart-message,
.cart-empty.woocommerce-info,
p.cart-empty,
.woocommerce .cart-empty,
.woocommerce-page .cart-empty {
  display: none !important;
}
/* Ukryj też domyślny link "Wróć do sklepu" pod pustym koszykiem */
p.return-to-shop,
.woocommerce .return-to-shop,
.woocommerce-page .return-to-shop {
  display: none !important;
}

/* ══════════════════════════════════════════════════════════════════════
   IKONY W KAFELKACH "INNE KATEGORIE" (archiwum)
   ══════════════════════════════════════════════════════════════════════ */
.cat-related-img--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
}
.cat-related-icon {
  width: 48px;
  height: 48px;
  color: var(--cop);
  opacity: .6;
  transition: opacity .25s, transform .25s;
}
.cat-related-card:hover .cat-related-icon {
  opacity: 1;
  transform: scale(1.1);
}
/* Usuń count z kafelków (gdyby jeszcze gdzieś był) */
.cat-related-count { display: none !important; }

/* ══════════════════════════════════════════════════════════════════════
   WISHLISTA — serduszko na kartach i stronie produktu
   ══════════════════════════════════════════════════════════════════════ */
/* Karta produktu */
.vsp-wish-btn {
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,.95); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink); cursor: pointer; padding: 0;
  transition: background .15s, color .15s, transform .15s;
}
.vsp-wish-btn:hover { background: var(--ink); color: var(--w); }
.vsp-wish-btn.is-wished {
  background: #e74c3c !important; border-color: #e74c3c !important; color: #fff !important;
}
.vsp-wish-btn.is-wished svg { fill: #fff; }
.vsp-wish-btn.vsp-wish-pop { animation: wishPop .4s ease; }
@keyframes wishPop {
  0% { transform: scale(1); }
  40% { transform: scale(1.3); }
  100% { transform: scale(1); }
}

/* Single product wish button */
.vp-wish-btn.is-wished {
  background: #e74c3c !important; border-color: #e74c3c !important; color: #fff !important;
}
.vp-wish-btn.is-wished svg { fill: #fff; stroke: #fff; }

/* ══════════════════════════════════════════════════════════════════════
   STRONA ULUBIONYCH
   ══════════════════════════════════════════════════════════════════════ */
/* Override wąskiego vpage-body gdy jest wishlista */
.vpage-body:has(.vwish-wrap) {
  max-width: var(--max) !important;
  grid-template-columns: 1fr !important;
}
.vwish-wrap { max-width: 100%; margin: 0 auto; }
.vwish-header { margin-bottom: 32px; }
.vwish-title { font-family: var(--fd); font-size: 2rem; font-weight: 500; color: var(--ink); margin: 0 0 8px; }
.vwish-desc { font-size: .9rem; color: var(--mid); }
.vwish-empty { text-align: center; padding: 60px 20px; }
.vwish-empty svg { color: var(--lne2); margin-bottom: 16px; }
.vwish-empty h2 { font-family: var(--fd); font-size: 1.4rem; color: var(--ink); margin: 0 0 8px; }
.vwish-empty p { color: var(--mid); font-size: .9rem; margin: 0 0 20px; }
.vwish-empty-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; background: var(--ink); color: var(--w);
  font-family: var(--fb); font-size: .75rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
  border-radius: 2px; transition: background .2s;
}
.vwish-empty-btn:hover { background: var(--cop); }
.vwish-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.vwish-card {
  border: 1px solid var(--line); border-radius: 3px; background: var(--w);
  overflow: hidden; display: flex; flex-direction: column; transition: border-color .2s;
}
.vwish-card:hover { border-color: var(--cop); }
.vwish-card-img {
  display: block; aspect-ratio: 1; overflow: hidden; background: var(--bg);
}
.vwish-card-img img {
  width: 100%; height: 100%; object-fit: contain; padding: 12px;
  transition: transform .3s;
}
.vwish-card:hover .vwish-card-img img { transform: scale(1.04); }
.vwish-card-body { padding: 14px 16px 12px; flex: 1; display: flex; flex-direction: column; }
.vwish-card-name {
  font-size: .85rem; font-weight: 600; color: var(--ink); text-decoration: none;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  line-height: 1.35; margin-bottom: 6px;
}
.vwish-card-name:hover { color: var(--cop); }
.vwish-card-price {
  font-family: var(--fb); font-size: 1.05rem; font-weight: 700; color: var(--ink);
  margin-top: auto;
}
.vwish-card-acts { display: flex; border-top: 1px solid var(--line); }
.vwish-card-acts a, .vwish-card-acts button {
  flex: 1; padding: 12px 10px; text-align: center; font-family: var(--fb);
  font-size: .65rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  text-decoration: none; border: none; cursor: pointer; transition: background .15s, color .15s;
  line-height: 1.2;
}
.vwish-card-atc { background: var(--ink); color: var(--w) !important; }
.vwish-card-atc:hover { background: var(--cop); }
.vwish-card-remove { background: var(--bg); color: var(--soft) !important; border-left: 1px solid var(--line) !important; }
.vwish-card-remove:hover { color: #e74c3c !important; background: rgba(231,76,60,.05); }
@media (max-width: 900px) { .vwish-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .vwish-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }

/* Nav wishlist icon */
.vons-wish-count {
  position: absolute; top: 2px; right: 0px;
  background: #e74c3c; color: #fff; font-size: .5rem; font-weight: 700;
  min-width: 14px; height: 14px; line-height: 14px; text-align: center;
  border-radius: 99px; padding: 0 3px; pointer-events: none;
}
.vons-wish-count:empty { display: none; }

/* ══════════════════════════════════════════════════════════════════════
   PORADNIKI — sekcja na stronie głównej
   ══════════════════════════════════════════════════════════════════════ */
.vons-guides-section {
  padding: 56px 0 64px;
  border-top: 1px solid var(--line);
}
.vons-guides-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  margin-top: 4px;
}
.vons-guide-card {
  display: flex; flex-direction: column;
  border: 1px solid var(--line); border-radius: 3px;
  background: var(--w); overflow: hidden; text-decoration: none;
  transition: border-color .2s, box-shadow .2s;
}
.vons-guide-card:hover { border-color: var(--cop); box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.vons-guide-card-img {
  aspect-ratio: 16/9; overflow: hidden; background: var(--bg);
}
.vons-guide-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .3s;
}
.vons-guide-card:hover .vons-guide-card-img img { transform: scale(1.04); }
.vons-guide-card-body { padding: 16px 18px 20px; flex: 1; display: flex; flex-direction: column; }
.vons-guide-card-date {
  font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--cop); margin-bottom: 8px;
}
.vons-guide-card-title {
  font-family: var(--fd); font-size: 1.1rem; font-weight: 500;
  color: var(--ink); line-height: 1.35; margin: 0 0 8px;
}
.vons-guide-card-excerpt {
  font-size: .82rem; color: var(--mid); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
  margin: 0; flex: 1;
}
.vons-guide-card-more {
  margin-top: 12px; font-size: .7rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink);
}
.vons-guide-card:hover .vons-guide-card-more { color: var(--cop); }
@media (max-width: 800px) {
  .vons-guides-grid { grid-template-columns: 1fr; gap: 16px; }
}

/* ═══════════════════════════════════════════════════
   VALOR — odznaka punktów przy ikonie konta
═══════════════════════════════════════════════════ */
.vons-valor-badge {
    position: absolute;
    bottom: -4px;
    right: -8px;
    background: var(--cop);
    color: var(--w);
    font-family: var(--fb);
    font-size: .55rem;
    font-weight: 700;
    letter-spacing: .04em;
    padding: 2px 5px;
    border-radius: 20px;
    white-space: nowrap;
    line-height: 1.4;
    pointer-events: none;
}
.vons-mob-pts {
    font-size: .7rem;
    color: var(--cop);
    font-weight: 700;
    margin-left: 4px;
}

/* ═══════════════════════════════════════════════════
   VALOR — baner na checkoucie (niezalogowany)
═══════════════════════════════════════════════════ */
.vco-valor-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #FDF6EE;
    border: 1px solid #E8C89A;
    border-left: 3px solid var(--cop);
    border-radius: var(--rad);
    padding: 12px 16px;
    margin-bottom: 16px;
    font-size: .8rem;
    color: var(--mid);
    line-height: 1.5;
    flex-wrap: wrap;
}
.vco-valor-icon {
    color: var(--cop);
    flex-shrink: 0;
}
.vco-valor-body { flex: 1; min-width: 200px; }
.vco-valor-body strong { color: var(--ink); display: block; margin-bottom: 2px; font-size: .82rem; }
.vco-valor-link {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--cop);
    white-space: nowrap;
    text-decoration: none;
    flex-shrink: 0;
}
.vco-valor-link:hover { color: var(--ink); }

/* ═══════════════════════════════════════════════════
   VALOR — baner na stronie logowania / rejestracji
═══════════════════════════════════════════════════ */
.vma-valor-teaser {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: #FDF6EE;
    border: 1px solid #E8C89A;
    border-left: 3px solid var(--cop);
    border-radius: var(--rad);
    padding: 14px 18px;
    margin-bottom: 28px;
    font-size: .82rem;
    color: var(--mid);
    line-height: 1.6;
}
.vma-valor-teaser-icon { color: var(--cop); flex-shrink: 0; margin-top: 2px; }
.vma-valor-teaser-body strong { color: var(--ink); display: block; margin-bottom: 3px; font-size: .88rem; }
.vma-valor-teaser-body a { color: var(--cop); font-weight: 700; }

/* ═══════════════════════════════════════════════════════════════
   FIX PayU: #payment (z checkout/payment.php) wewnątrz Vonsace.
   Neutralizuje stare box-style, zachowuje design Vonsace.
   ═══════════════════════════════════════════════════════════════ */
.vco-payment-body #payment.woocommerce-checkout-payment {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  box-shadow: none !important;
}
.vco-payment-body #payment .payment_methods {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}
.vco-payment-body #payment .payment_methods > li {
  list-style: none !important;
  padding: 11px 14px !important;
  border: 1.5px solid var(--lne2, #E8E4DE) !important;
  border-radius: 4px !important;
  margin-bottom: 6px !important;
  cursor: pointer !important;
  transition: border-color .2s !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
.vco-payment-body #payment .payment_methods > li:has(input:checked) {
  border-color: var(--cop, #C18C49) !important;
  background: rgba(193,140,73,.03) !important;
}
.vco-payment-body #payment .payment_methods li label {
  font-size: .88rem !important;
  color: var(--ink, #1A1714) !important;
  cursor: pointer !important;
  font-weight: 500 !important;
  font-family: var(--fb, sans-serif) !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
}
.vco-payment-body #payment .payment_methods li input[type="radio"] {
  accent-color: var(--cop, #C18C49) !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
  margin: 0 !important;
}
.vco-payment-body #payment .payment_methods li img {
  max-height: 22px !important;
  width: auto !important;
}
.vco-payment-body #payment .payment_box {
  padding: 12px 14px 6px !important;
  background: rgba(26,23,20,.02) !important;
  border-top: 1px solid var(--lne2, #E8E4DE) !important;
  font-size: .82rem !important;
  color: var(--mid, #706B64) !important;
  margin-top: 8px !important;
  border-radius: 0 0 4px 4px !important;
  width: 100% !important;
}
.vco-payment-body #payment .payment_box p { margin: 0 0 8px !important; }
/* PayU / bramki — form-row musi być widoczny */
.vco-payment-body #payment .payment_box .form-row {
  display: block !important;
  padding: 0 !important;
  margin: 0 0 8px !important;
}
.vco-payment-body #payment .payment_box input,
.vco-payment-body #payment .payment_box select {
  font-family: var(--fb, sans-serif) !important;
  font-size: .85rem !important;
  border: 1.5px solid var(--lne2, #E8E4DE) !important;
  border-radius: 3px !important;
  padding: 10px 12px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
/* .place-order z payment.php — ukryty (mamy własny przycisk + terms po polsku) */
.vco-payment-body #payment .place-order {
  display: none !important;
}
.vco-payment-body .woocommerce-terms-and-conditions-wrapper {
  display: none !important;
}
.vco-payment-body .woocommerce-privacy-policy-text {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════
   STICKY MOBILE "DODAJ DO KOSZYKA"
   Pojawia się gdy oryginalny przycisk znika z ekranu.
   Tylko na mobile (< 768px).
   ═══════════════════════════════════════════════════════════════ */
.vp-sticky-bar {
  display: none;
}

@media (max-width: 768px) {
  .vp-sticky-bar {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 899;
    background: var(--w, #fff);
    border-top: 1px solid var(--line, #E8E4DE);
    box-shadow: 0 -4px 20px rgba(26,23,20,.1);
    padding: 10px 16px;
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    transform: translateY(100%);
    transition: transform .3s ease;
  }
  .vp-sticky-bar.is-visible {
    transform: translateY(0);
  }
  .vp-sticky-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
    flex: 1;
  }
  .vp-sticky-name {
    font-family: var(--fb, sans-serif);
    font-size: .75rem;
    color: var(--mid, #706B64);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .vp-sticky-price {
    font-family: var(--fb, sans-serif);
    font-size: .85rem;
    font-weight: 700;
    color: var(--ink, #1A1714);
  }
  .vp-sticky-btn {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 12px 20px;
    background: var(--ink, #1A1714);
    color: var(--w, #fff);
    border: none;
    border-radius: 2px;
    font-family: var(--fb, sans-serif);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .25s;
    white-space: nowrap;
  }
  .vp-sticky-btn:active {
    background: var(--cop, #C18C49);
  }

  /* Dodaj padding na dole strony żeby sticky bar nie zasłaniał treści */
  .vp-page { padding-bottom: 70px; }
}

/* ═══════════════════════════════════════════════════════════════
   FIX: MOBILE MENU — zapobiegaj overflow ale nie ucinaj badge'y
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  #vons-nav { overflow: visible; }
  .vons-nav-wrap {
    overflow: visible !important;
  }
  .vons-actions {
    gap: 0 !important;
    flex-shrink: 1 !important;
    overflow: visible !important;
  }
  .vons-icon-btn {
    width: 36px !important;
    height: 36px !important;
    overflow: visible !important;
  }
  .vons-icon-btn svg {
    width: 16px !important;
    height: 16px !important;
  }
  /* Badge'y — mniejsze na mobile */
  .vons-wish-count,
  .vons-cart-count {
    min-width: 12px !important;
    height: 12px !important;
    line-height: 12px !important;
    font-size: .45rem !important;
    top: 2px !important;
    right: 0 !important;
  }
  /* Ukryj etykietę quizu na mobile — za dużo miejsca */
  .vsq-nav-label { display: none !important; }
  .vsq-nav-btn {
    width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    justify-content: center !important;
  }
  .vsq-nav-btn svg {
    width: 16px !important;
    height: 16px !important;
  }
  /* Chowaj desktop menu */
  .vons-menu { display: none !important; }
  .vons-hamburger { display: flex !important; }
}

@media (max-width: 380px) {
  .vons-icon-btn {
    width: 32px !important;
    height: 32px !important;
  }
  .vons-icon-btn svg {
    width: 15px !important;
    height: 15px !important;
  }
  .vons-hamburger {
    margin-left: 2px !important;
    padding: 4px !important;
  }
  .vons-logo-img {
    max-width: 110px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   STRONA PODZIĘKOWANIA (order-received) + ZAPŁAĆ (order-pay)
   ═══════════════════════════════════════════════════════════════ */

/* ── Wspólne: wrapper ── */
.woocommerce-order,
.woocommerce-checkout.woocommerce-checkout-pay {
  max-width: 700px;
  margin: 40px auto;
  padding: 0 var(--pad, 20px);
  font-family: var(--fb, sans-serif);
  color: var(--ink, #1A1714);
}

/* ── THANK YOU PAGE ── */
.woocommerce-order .woocommerce-thankyou-order-received {
  font-family: var(--fh, 'Cormorant Garamond', serif);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--ink, #1A1714);
  text-align: center;
  margin: 0 0 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line, #E8E4DE);
}

.woocommerce-order .woocommerce-order-overview {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 30px !important;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  background: var(--bg, #FAF8F5);
  border: 1px solid var(--line, #E8E4DE);
  border-radius: 6px;
  padding: 24px !important;
}
.woocommerce-order .woocommerce-order-overview li {
  margin: 0 !important;
  padding: 0 !important;
  font-size: .85rem;
  color: var(--mid, #706B64);
  border: none !important;
}
.woocommerce-order .woocommerce-order-overview li strong {
  display: block;
  font-size: .95rem;
  color: var(--ink, #1A1714);
  margin-top: 2px;
}

/* Tabela zamówienia na thankyou */
.woocommerce-order table.woocommerce-table--order-details,
.woocommerce-order table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 20px 0 !important;
  font-size: .85rem !important;
  border: 1px solid var(--line, #E8E4DE) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
}
.woocommerce-order table.shop_table th {
  background: var(--bg, #FAF8F5) !important;
  font-family: var(--fb, sans-serif) !important;
  font-size: .65rem !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: var(--soft, #9C9690) !important;
  padding: 12px 16px !important;
  text-align: left !important;
  border-bottom: 1px solid var(--line, #E8E4DE) !important;
}
.woocommerce-order table.shop_table td {
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--line, #E8E4DE) !important;
  color: var(--ink, #1A1714) !important;
  vertical-align: middle !important;
}
.woocommerce-order table.shop_table tr:last-child td {
  border-bottom: none !important;
}
.woocommerce-order table.shop_table tfoot th {
  text-transform: none !important;
  font-size: .85rem !important;
  letter-spacing: 0 !important;
  color: var(--ink, #1A1714) !important;
}
.woocommerce-order table.shop_table tfoot td {
  font-weight: 700 !important;
}

/* Customer details na thankyou */
.woocommerce-order .woocommerce-customer-details {
  margin-top: 30px;
  padding-top: 20px;
  border-top: 1px solid var(--line, #E8E4DE);
}
.woocommerce-order .woocommerce-customer-details h2,
.woocommerce-order .woocommerce-order-details h2 {
  font-family: var(--fh, 'Cormorant Garamond', serif) !important;
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  margin: 0 0 16px !important;
}
.woocommerce-order .woocommerce-customer-details address {
  font-style: normal;
  font-size: .85rem;
  line-height: 1.7;
  color: var(--mid, #706B64);
  padding: 16px;
  background: var(--bg, #FAF8F5);
  border: 1px solid var(--line, #E8E4DE);
  border-radius: 6px;
}

/* ── ORDER-PAY PAGE ── */
.woocommerce-checkout-pay table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 0 0 24px !important;
  font-size: .85rem !important;
  border: 1px solid var(--line, #E8E4DE) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
}
.woocommerce-checkout-pay table.shop_table th {
  background: var(--bg, #FAF8F5) !important;
  font-family: var(--fb, sans-serif) !important;
  font-size: .65rem !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: var(--soft, #9C9690) !important;
  padding: 12px 16px !important;
  text-align: left !important;
  border-bottom: 1px solid var(--line, #E8E4DE) !important;
}
.woocommerce-checkout-pay table.shop_table td {
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--line, #E8E4DE) !important;
  color: var(--ink, #1A1714) !important;
}
.woocommerce-checkout-pay table.shop_table tr:last-child td {
  border-bottom: none !important;
}

/* Payment methods na order-pay */
.woocommerce-checkout-pay #payment {
  background: var(--bg, #FAF8F5) !important;
  border: 1px solid var(--line, #E8E4DE) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  margin-top: 24px !important;
}
.woocommerce-checkout-pay #payment .payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.woocommerce-checkout-pay #payment .payment_methods li {
  padding: 14px 18px !important;
  border-bottom: 1px solid var(--line, #E8E4DE) !important;
}
.woocommerce-checkout-pay #payment .payment_methods li:last-child {
  border-bottom: none !important;
}
.woocommerce-checkout-pay #payment .payment_methods li label {
  font-size: .88rem !important;
  color: var(--ink, #1A1714) !important;
  font-family: var(--fb, sans-serif) !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.woocommerce-checkout-pay #payment .payment_methods li input[type="radio"] {
  accent-color: var(--cop, #C18C49) !important;
}
.woocommerce-checkout-pay #payment .payment_methods li img {
  max-height: 24px !important;
  width: auto !important;
}
.woocommerce-checkout-pay #payment .payment_box {
  padding: 12px 18px !important;
  background: var(--w, #fff) !important;
  border-top: 1px solid var(--line, #E8E4DE) !important;
  font-size: .82rem !important;
  color: var(--mid, #706B64) !important;
}

/* Submit button na order-pay */
.woocommerce-checkout-pay #payment .place-order {
  padding: 18px !important;
  display: block !important;
}
.woocommerce-checkout-pay #place_order {
  display: block !important;
  width: 100% !important;
  padding: 16px 24px !important;
  background: var(--ink, #1A1714) !important;
  color: var(--w, #fff) !important;
  border: none !important;
  border-radius: 2px !important;
  font-family: var(--fb, sans-serif) !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background .25s !important;
}
.woocommerce-checkout-pay #place_order:hover {
  background: var(--cop, #C18C49) !important;
}

/* Privacy text na order-pay — styl Vonsace */
.woocommerce-checkout-pay .woocommerce-privacy-policy-text {
  font-size: .78rem !important;
  color: var(--soft, #9C9690) !important;
  padding: 12px 18px !important;
  line-height: 1.5 !important;
}
.woocommerce-checkout-pay .woocommerce-privacy-policy-text a {
  color: var(--cop, #C18C49) !important;
}

/* ── Mobile ── */
@media (max-width: 600px) {
  .woocommerce-order,
  .woocommerce-checkout.woocommerce-checkout-pay {
    margin: 24px auto;
    padding: 0 16px;
  }
  .woocommerce-order .woocommerce-thankyou-order-received {
    font-size: 1.3rem;
  }
  .woocommerce-order .woocommerce-order-overview {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 18px !important;
  }
}
