/* =====================================================================
   Polski Żłób — motyw sklepu (paleta „Las polski”, Newsreader + Geist)
   Struktura przeniesiona z designu (styles.css + views-standalone.css),
   kolory wpieczone w warstwie PALETTE APPLICATION poniżej.
   ===================================================================== */

:root {
  --bg: #ffffff;          /* tło strony — białe */
  --surface: #ffffff;
  --ink: #141414;         /* napisy — czarne */
  --ink-soft: #5c5c5c;
  --line: #cacaca;        /* neutralne, jasnoszare ramki */
  --band: #161412;        /* ciemne pasy sekcji (filozofia / newsletter) */
  --brand: #b81d2b;       /* CZERWONY — kolor wiodący */
  --brand-ink: #ffffff;
  --accent: #b81d2b;      /* czerwony akcent */
  --accent2: #8a1420;     /* ciemna czerwień (etykiety, badge) */
  --gold: #f2d9a6;        /* jasny ton na ciemnych pasach */
  --font-display: 'Newsreader', Georgia, serif;
  --font-body: 'Geist', system-ui, sans-serif;
  --max: 1280px;
  --pad-x: clamp(20px, 4vw, 56px);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; }
.container { max-width: var(--max); margin: 0 auto; padding-left: var(--pad-x); padding-right: var(--pad-x); }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
em { font-style: italic; }
.pz-ic { display: inline-block; vertical-align: middle; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap; }
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 12px; top: 12px; background: var(--surface); padding: 10px 16px; z-index: 999; border-radius: 4px; }

/* show desktop / mobile header globally at 720px */
.desktop-only { display: block; }
.mobile-only { display: none; }
@media (max-width: 720px) { .desktop-only { display: none; } .mobile-only { display: block; } }

/* =====================================================================
   HEADER / TOP BAR
   ===================================================================== */
.topbar-fullbleed { width: 100%; position: sticky; top: 0; z-index: 30; }
.sm-header { border-bottom: 1px solid var(--line); background: var(--surface); }
.sm-header-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px; padding-top: 16px; padding-bottom: 16px; }
.sm-logo img, .pz-logo-link img { display: block; }
.sm-search { padding: 11px 16px; border: 1px solid var(--line); border-radius: 999px; display: flex; align-items: center; gap: 10px; font-size: 13px; width: 100%; max-width: 560px; justify-self: center; color: var(--ink-soft); }
.sm-search svg { color: var(--ink-soft); flex: none; }
.sm-search input { border: 0; outline: 0; background: transparent; font-family: inherit; font-size: 13px; color: var(--ink); width: 100%; }
.sm-search input::placeholder { color: var(--ink-soft); opacity: 1; }
.sm-mainnav-row { border-top: 0; }
.sm-mainnav { display: flex; gap: 0; align-items: center; justify-content: center; flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; padding-top: 0; padding-bottom: 0; }
.sm-mainnav::-webkit-scrollbar { display: none; }
.smnav-item { padding: 14px 12px; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; border-bottom: 2px solid transparent; display: inline-flex; align-items: center; gap: 5px; transition: color .15s, border-color .15s; white-space: nowrap; color: var(--ink); }
.smnav-item:hover { opacity: .7; }
.smnav-item.is-active { font-weight: 700; color: var(--brand); border-bottom-color: var(--brand); }
.smnav-caret { font-size: 7px; opacity: .6; }
.sm-actions { display: flex; align-items: center; gap: 18px; font-size: 13px; color: var(--ink); }
.sm-icon-btn { position: relative; display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 6px; transition: background .15s; }
.sm-icon-btn:hover { background: rgba(0,0,0,.04); }
.sm-cart-count { position: absolute; top: -4px; right: -6px; display: inline-grid; place-items: center; min-width: 18px; height: 18px; padding: 0 5px; border-radius: 999px; font-size: 10px; font-weight: 700; background: var(--brand); color: var(--brand-ink); }
.sm-cart-count .pz-cn { font-weight: 700; }

/* mobile header */
.m-topbar { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-bottom: 1px solid var(--line); min-height: 64px; background: var(--surface); color: var(--ink); }
.m-topbar .m-logo { display: flex; align-items: center; pointer-events: auto; }
.m-topbar .m-logo img { height: 32px; width: auto; }
.m-topbar .m-icons { display: flex; align-items: center; gap: 4px; margin-left: auto; }
/* wszystkie ikony (button i a) wyśrodkowane jednakowo; position:relative też dla <a>,
   żeby badge koszyka trzymał się ikony, a nie uciekał do rogu paska */
.m-topbar .m-icons button,
.m-topbar .m-icons a { width: 36px; height: 36px; display: grid; place-items: center; position: relative; color: var(--ink); }
.m-topbar .m-cartn { position: absolute; top: 4px; right: 4px; min-width: 16px; height: 16px; border-radius: 999px; background: var(--brand); color: var(--brand-ink); font-size: 9px; font-weight: 700; display: grid; place-items: center; padding: 0 4px; }
.m-burger { color: var(--ink); }

/* mobile menu drawer */
.pz-mobile-menu { position: fixed; inset: 0; z-index: 60; background: rgba(0,0,0,.45); opacity: 0; pointer-events: none; transition: opacity .2s; }
.pz-mobile-menu.is-open { opacity: 1; pointer-events: auto; }
.pz-mobile-menu .pz-mm-panel { position: absolute; top: 0; bottom: 0; left: 0; width: min(86%, 360px); background: var(--bg); padding: 20px 18px; overflow-y: auto; transform: translateX(-100%); transition: transform .25s; }
.pz-mobile-menu.is-open .pz-mm-panel { transform: none; }
.pz-mm-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.pz-mm-panel nav { display: flex; flex-direction: column; }
.pz-mm-panel .smnav-item { border-bottom: 1px solid var(--line); border-radius: 0; justify-content: space-between; padding: 14px 4px; }

/* ---------- MOBILE MENU — akordeon ---------- */
.pz-mm-nav { list-style: none; margin: 0; padding: 0; }
.pz-mm-li { border-bottom: 1px solid var(--line); }
.pz-mm-link { display: block; padding: 14px 4px; font-size: 16px; font-weight: 500; color: var(--ink); }
.pz-mm-link.is-active { color: var(--brand); }
/* wiersz rodzica: link + przycisk rozwijania */
.pz-mm-row { display: flex; align-items: center; }
.pz-mm-row .pz-mm-link { flex: 1; }
.pz-mm-toggle { flex: none; width: 48px; align-self: stretch; display: grid; place-items: center; border: 0; background: none; cursor: pointer; color: var(--ink); border-left: 1px solid var(--line); }
.pz-mm-chev { font-size: 14px; line-height: 1; transition: transform .25s ease; }
.pz-mm-li.is-open > .pz-mm-row .pz-mm-chev { transform: rotate(180deg); color: var(--brand); }
/* płynne rozwijanie bez magicznych wysokości (grid 0fr → 1fr) */
.pz-mm-sub { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .28s ease; }
.pz-mm-li.is-open > .pz-mm-sub { grid-template-rows: 1fr; }
.pz-mm-inner { overflow: hidden; min-height: 0; padding-left: 8px; }
.pz-mm-li.is-open > .pz-mm-sub > .pz-mm-inner { padding-bottom: 8px; }
/* pozycje podmenu */
.pz-mm-subitem { display: block; padding: 11px 4px; font-size: 15px; color: var(--ink-soft); }
.pz-mm-ghead { display: block; padding: 12px 4px 4px; font-size: 11px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 700; color: var(--brand); }
.pz-mm-leaves { list-style: none; margin: 0 0 4px; padding: 0; }
.pz-mm-leaves a { display: block; padding: 9px 4px 9px 12px; font-size: 14.5px; color: var(--ink-soft); }
.pz-mm-subitem:hover, .pz-mm-leaves a:hover, .pz-mm-ghead:hover { color: var(--brand); }

/* =====================================================================
   HOMEPAGE — hero slider
   ===================================================================== */
.sm-slider-fullbleed { position: relative; width: 100%; height: clamp(420px,56vw,620px); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; color: #fff; overflow: hidden; }
.sm-slider-fullbleed .sm-bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity .9s ease; }
.sm-slider-fullbleed .sm-bg.on { opacity: 1; }
.sm-slider-fullbleed .sm-fade { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.5) 100%); z-index: 1; }
.sm-slider-fullbleed .sm-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 999px; display: grid; place-items: center; font-size: 22px; z-index: 3; box-shadow: 0 4px 16px rgba(0,0,0,.25); border: 0; cursor: pointer; background: var(--surface); color: var(--ink); }
.sm-slider-fullbleed .sm-arrow.l { left: clamp(16px,4vw,56px); }
.sm-slider-fullbleed .sm-arrow.r { right: clamp(16px,4vw,56px); }
.sm-slide { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; text-align: center; max-width: 900px; }
.sm-eyebrow { font-size: 11px; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 18px; opacity: .95; color: #fff; }
.sm-title { font-family: var(--font-display); font-size: clamp(40px,5.5vw,72px); font-weight: 400; line-height: 1.05; text-align: center; margin-bottom: 14px; letter-spacing: -.015em; animation: smfade .6s ease; }
.sm-subtitle { font-size: 13px; letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 28px; opacity: .95; }
.sm-btn { padding: 14px 32px; border-radius: 999px; font-size: 12px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; border: 0; cursor: pointer; background: var(--accent); color: var(--brand); }
.sm-dots { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 3; }
.sm-dotbtn { width: 28px; height: 3px; border-radius: 2px; background: rgba(255,255,255,.4); transition: background .2s, width .2s; padding: 0; border: 0; cursor: pointer; }
.sm-dotbtn.on { background: #fff; width: 44px; }
@keyframes smfade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* hero band */
.hero-band { padding: 14px 0; font-size: 13px; background: var(--brand); color: var(--brand-ink); }
.hero-band-row { display: flex; align-items: center; gap: 16px; }
.hb-eyebrow { font-family: var(--font-display); font-style: italic; font-size: 16px; }
.hb-bar { width: 24px; height: 1px; background: var(--accent); }
.hb-text { flex: 1; opacity: .85; }
.hb-link { display: inline-flex; align-items: center; gap: 8px; font-weight: 500; }
.hb-link svg { transition: transform .2s; }
.hb-link:hover svg { transform: translateX(3px); }

/* =====================================================================
   SHARED — intro, section heads
   ===================================================================== */
.intro { padding: 80px 0 60px; }
.intro-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 80px; align-items: end; }
.kicker { font-size: 13px; letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 22px; font-weight: 600; color: var(--accent2); }
.intro-title { font-family: var(--font-display); font-size: clamp(34px,4.4vw,50px); font-weight: 400; line-height: 1.08; letter-spacing: -.015em; margin: 0; text-wrap: pretty; color: var(--ink); }
.intro-title em { color: var(--brand); font-style: italic; }
.intro-right { position: relative; top: 40px; }
.intro-right p { font-size: 16px; line-height: 1.65; margin: 0 0 32px; color: var(--ink-soft); }
.intro-meta { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; padding-top: 24px; border-top: 2px solid var(--line); }
.intro-meta div { display: flex; flex-direction: column; gap: 2px; }
.intro-meta b { font-family: var(--font-display); font-size: 28px; font-weight: 500; line-height: 1; color: var(--brand); }
.intro-meta span { font-size: 12px; letter-spacing: .5px; color: var(--ink-soft); }

.section-head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 48px; flex-wrap: wrap; }
.section-num { font-family: var(--font-display); font-style: italic; font-size: 14px; opacity: .5; margin-right: 14px; color: var(--ink-soft); }
.section-title { display: inline; font-family: var(--font-display); font-size: clamp(28px,3.5vw,44px); font-weight: 400; letter-spacing: -.015em; line-height: 1.1; margin: 0; color: var(--ink); }

/* category hub */
.cathub { padding: 60px 0; }
.axis-switch { display: inline-flex; padding: 4px; border: 1px solid var(--line); border-radius: 999px; }
.axis-btn { padding: 8px 18px; font-size: 13px; font-weight: 500; border-radius: 999px; transition: all .15s; color: var(--ink-soft); }
.axis-btn.is-on { font-weight: 600; background: var(--brand); color: var(--brand-ink); }
.cathub-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.cat-tile { position: relative; display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 6px; overflow: hidden; height: var(--tile-h,320px); transition: transform .25s, box-shadow .25s; background: var(--surface); }
.cat-tile:hover { transform: translateY(-4px); box-shadow: 0 12px 32px -16px rgba(0,0,0,.18); }
.cat-num { position: absolute; top: 14px; right: 16px; font-family: var(--font-display); font-style: italic; font-size: 13px; z-index: 2; color: var(--ink-soft); }
.cat-art { flex: 1; position: relative; overflow: hidden; }
.cat-art .cat-art-pat { position: absolute; inset: 0; background-image: repeating-linear-gradient(40deg, rgba(255,255,255,.16) 0 1px, transparent 1px 6px); }
.cat-art .cat-art-dot { position: absolute; top: 22%; right: 22%; width: 28%; padding-top: 28%; border-radius: 999px; background: rgba(255,255,255,.12); }
.cat-body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 4px; }
.cat-label { font-family: var(--font-display); font-size: 22px; font-weight: 500; letter-spacing: -.01em; color: var(--ink); }
.cat-sub { font-size: 13px; color: var(--ink-soft); }
.cat-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 12px; font-size: 13px; color: var(--ink-soft); }
.cat-go { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; color: var(--brand); }
.cat-go svg { transition: transform .2s; }
.cat-tile:hover .cat-go svg { transform: translateX(4px); }

.stage-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.stage-tile { display: grid; grid-template-columns: 140px 1fr; border: 1px solid var(--line); border-radius: 6px; overflow: hidden; transition: transform .2s, border-color .2s; min-height: 160px; background: var(--surface); }
.stage-tile:hover { transform: translateY(-3px); }
.stage-art { padding: 24px; display: grid; place-items: center; border-right: 1px solid var(--line); }
.stage-meta { padding: 22px 20px; display: flex; flex-direction: column; gap: 6px; }
.stage-years { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; color: var(--accent2); }
.stage-name { font-family: var(--font-display); font-size: 24px; font-weight: 500; line-height: 1.15; letter-spacing: -.01em; color: var(--ink); }
.stage-foot { display: flex; justify-content: space-between; align-items: center; font-size: 13px; margin-top: auto; color: var(--ink-soft); }

.type-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 12px; }
.type-tile { display: flex; flex-direction: column; gap: 10px; padding: 22px 20px 20px; border: 1px solid var(--line); border-radius: 6px; min-height: 160px; transition: transform .2s; background: var(--surface); }
.type-tile:hover { transform: translateY(-3px); }
.type-num { font-family: var(--font-display); font-style: italic; font-size: 28px; font-weight: 500; color: var(--accent); }
.type-name { font-family: var(--font-display); font-size: 22px; font-weight: 500; margin-top: auto; letter-spacing: -.01em; color: var(--ink); }
.type-foot { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--ink-soft); }
.type-arrow { color: var(--brand); }

/* =====================================================================
   PRODUCT CARDS (.pc)
   ===================================================================== */
.best { padding: 80px 0 60px; }
.best-filters { display: flex; gap: 8px; flex-wrap: wrap; }
.chip { padding: 7px 14px; border: 1px solid var(--line); border-radius: 999px; font-size: 12px; font-weight: 500; transition: all .15s; color: var(--ink-soft); }
.chip.is-on { border-color: transparent; background: var(--ink); color: var(--bg); }
.best-grid { display: grid; grid-template-columns: repeat(3,1fr); grid-auto-rows: 1fr; gap: 24px; }
.best-foot { margin-top: 48px; text-align: center; }
.all-link { display: inline-flex; align-items: center; gap: 10px; padding: 14px 28px; border: 1px solid var(--brand); border-radius: 999px; font-weight: 500; font-size: 14px; transition: all .2s; color: var(--brand); }
.all-link:hover { transform: translateY(-2px); }

.pc { border-radius: 6px; transition: transform .25s, box-shadow .25s; }
.pc.tile { display: flex; flex-direction: column; height: 100%; border: 1px solid var(--line); overflow: hidden; position: relative; background: var(--surface); color: var(--ink); }
.pc.tile:hover { transform: translateY(-4px); box-shadow: 0 16px 40px -20px rgba(0,0,0,.18); }
.pc-tag { position: absolute; top: 14px; left: 14px; padding: 4px 10px; border: 1px solid var(--line); border-radius: 999px; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; background: rgba(255,255,255,.85); backdrop-filter: blur(4px); z-index: 2; color: var(--ink-soft); }
.pc-tag.is-badge { border-color: transparent; font-weight: 600; }
.pc-tag.badge-brand { background: var(--brand); color: var(--brand-ink); }
.pc-tag.badge-accent { background: var(--accent); color: var(--brand); }
.pc-tag.badge-accent2 { background: var(--accent2); color: var(--brand-ink); }
.pc-img { aspect-ratio: 4/3; position: relative; overflow: hidden; display: block; }
.prod-img-wrap { position: absolute; inset: 0; display: grid; place-items: center; overflow: hidden; }
.prod-img-wrap img { max-width: 80%; max-height: 88%; object-fit: contain; mix-blend-mode: multiply; transition: transform .4s ease; }
.pc.tile:hover .prod-img-wrap img { transform: scale(1.04); }
.pc-body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 4px; flex: 1 1 auto; }
.pc-line { font-size: 10px; letter-spacing: 2px; font-weight: 700; color: var(--accent2); }
.pc-name { font-family: var(--font-display); font-size: 20px; font-weight: 500; line-height: 1.2; letter-spacing: -.01em; color: var(--ink); display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; min-height: calc(20px * 1.2 * 2); }
.pc-name a { color: inherit; }
.pc-sub { font-size: 13px; line-height: 1.45; color: var(--ink-soft); display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; min-height: calc(13px * 1.45 * 2); }
.pc-rating { display: flex; align-items: center; gap: 6px; font-size: 12px; margin-top: 4px; color: var(--ink-soft); }
.pc-rating .stars { color: var(--accent); letter-spacing: 1px; }
.pc-rating b { font-weight: 600; color: var(--ink); }
.pc-foot { display: flex; align-items: end; justify-content: space-between; margin-top: auto; padding-top: 14px; gap: 12px; }
.pc-price { font-family: var(--font-display); font-size: 24px; font-weight: 500; color: var(--ink); }
.pc-price span { font-size: 14px; opacity: .7; }
.pc-price del { font-size: 14px; opacity: .5; font-family: var(--font-body); margin-left: 8px; }
.pc-price ins { text-decoration: none; }
.pc-weight { font-size: 12px; color: var(--ink-soft); }
.pc-cta { display: inline-flex; align-items: center; gap: 6px; padding: 10px 14px; border: 1px solid var(--brand); border-radius: 999px; font-size: 12px; font-weight: 600; transition: all .2s; white-space: nowrap; color: var(--brand); background: transparent; cursor: pointer; }
.pc-cta:hover, .pc-cta.added, .pc-cta.loading { background: var(--brand); color: var(--brand-ink); }
.pc-cta.full { width: 100%; justify-content: center; padding: 12px 16px; margin-top: 10px; }
.pc-cta.loading { opacity: .7; }

/* =====================================================================
   PHILOSOPHY
   ===================================================================== */
.philo { padding: 100px 0; margin-top: 40px; background: var(--brand); color: var(--brand-ink); }
.philo-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 80px; align-items: center; }
.philo .kicker { color: var(--accent); }
.philo-title { font-family: var(--font-display); font-size: clamp(32px,4.5vw,56px); font-weight: 400; line-height: 1.05; letter-spacing: -.02em; margin: 0 0 24px; }
.philo-left p { font-size: 16px; line-height: 1.7; opacity: .85; max-width: 540px; }
.philo-lines { display: flex; flex-direction: column; gap: 8px; margin-top: 32px; }
.line-pill { display: flex; align-items: center; gap: 12px; padding: 12px 16px; border: 1px solid rgba(255,255,255,.18); border-radius: 4px; font-size: 13px; }
.line-dot { width: 10px; height: 10px; border-radius: 999px; flex: none; }
.line-pill b { letter-spacing: 2px; font-size: 12px; }
.line-pill span.desc { opacity: .7; }
.cycle-card { padding: 40px; border: 1px solid rgba(255,255,255,.12); border-radius: 8px; background: rgba(255,255,255,.04); }
.cycle-ring { aspect-ratio: 1/1; max-width: 360px; margin: 0 auto 24px; }
.cycle-legend { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px 20px; font-size: 13px; opacity: .9; }
.cl-row { display: flex; align-items: center; gap: 10px; line-height: 1.35; }
.cl-row span:first-child { width: 10px; height: 10px; border-radius: 999px; flex: none; }

/* cta strip */
.ctastrip { padding: 80px 0; }
.strip-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.strip-card { display: flex; flex-direction: column; gap: 12px; padding: 32px 28px 28px; border: 1px solid var(--line); border-radius: 6px; min-height: 220px; transition: transform .2s; background: var(--surface); }
.strip-card:hover { transform: translateY(-4px); }
.strip-num { font-family: var(--font-display); font-size: 36px; line-height: 1; }
.strip-title { font-family: var(--font-display); font-size: 24px; font-weight: 500; margin: 0; letter-spacing: -.01em; color: var(--ink); }
.strip-card p { font-size: 14px; line-height: 1.55; margin: 0; flex: 1; color: var(--ink-soft); }
.strip-cta { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; font-size: 13px; margin-top: 8px; color: var(--brand); }
.strip-cta svg { transition: transform .2s; }
.strip-card:hover .strip-cta svg { transform: translateX(4px); }

/* roots */
.roots { padding: 60px 0 80px; }
.roots-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.roots-left p { margin-top: 24px; line-height: 1.7; color: var(--ink-soft); max-width: 520px; }
.roots-list { list-style: none; padding: 0; margin: 28px 0 0; display: grid; gap: 12px; }
.roots-list li { display: flex; align-items: center; gap: 10px; font-size: 14px; }
.roots-list svg { color: var(--brand); flex: none; }
.land-card { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.land-img { aspect-ratio: 4/3; position: relative; }
.land-stamp { position: absolute; top: 24px; right: 24px; padding: 12px 16px; border-radius: 4px; font-size: 11px; line-height: 1.4; text-align: center; transform: rotate(-3deg); box-shadow: 0 8px 20px -8px rgba(0,0,0,.4); background: var(--accent2); color: var(--brand-ink); }
.land-stamp b { font-family: var(--font-display); font-size: 16px; letter-spacing: 1px; }
.land-cap { padding: 16px 20px; display: flex; justify-content: space-between; font-size: 13px; }
.land-cap .c1 { color: var(--ink-soft); }
.land-cap .c2 { color: var(--brand); font-weight: 600; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.foot { margin-top: 60px; padding: 80px 0 0; background: var(--ink); color: var(--bg); }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 60px; }
.foot-grid > * { min-width: 0; }
.foot-logo { display: flex; align-items: center; gap: 12px; }
.foot-brand > p { opacity: .7; max-width: 320px; margin-top: 24px; line-height: 1.6; font-size: 14px; }
.foot-contact { margin-top: 24px; font-size: 13px; display: grid; gap: 6px; opacity: .85; }
.foot-contact span.lbl { opacity: .5; }
.foot-addr { margin-top: 4px; }
.foot-col-h { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; opacity: .5; margin-bottom: 16px; }
.foot-col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; font-size: 14px; }
.foot-col a { opacity: .85; transition: opacity .15s; }
.foot-col a:hover { opacity: 1; text-decoration: underline; text-underline-offset: 4px; }
.foot-news .nl-h { font-size: 12px; opacity: .6; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 12px; }
.foot-news .nl-title { font-family: var(--font-display); font-size: 22px; line-height: 1.2; margin-bottom: 20px; }
.news-form { display: flex; gap: 6px; }
.news-form input { flex: 1; min-width: 0; padding: 12px 14px; border: 1px solid rgba(255,255,255,.2); border-radius: 4px; font-family: inherit; font-size: 13px; outline: none; background: transparent; color: var(--bg); }
.news-form button { padding: 12px 18px; border-radius: 4px; font-size: 13px; font-weight: 600; display: inline-flex; align-items: center; gap: 6px; background: var(--accent); color: var(--ink); }
.foot-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; padding-bottom: 28px; border-top: 1px solid rgba(255,255,255,.1); font-size: 12px; flex-wrap: wrap; gap: 12px; }
.foot-bottom .c-mid { opacity: .5; }
.foot-flag { letter-spacing: 1px; }

/* =====================================================================
   VIEW WRAPPER (inner pages)
   ===================================================================== */
.view { background: var(--bg); color: var(--ink); width: 100%; }
.crumbs { padding: 16px 0 8px; font-size: 12px; letter-spacing: .2px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; color: var(--ink-soft); }
.crumbs a { opacity: .7; }
.crumbs a:hover { opacity: 1; }
.crumbs .sep { opacity: .4; }
.crumbs .now { font-weight: 600; color: var(--ink); }

.page-head { padding: 40px 0 28px; }
.page-head .kicker { margin-bottom: 16px; }
.page-head h1 { font-family: var(--font-display); font-size: clamp(36px,5vw,64px); font-weight: 400; line-height: 1.05; letter-spacing: -.02em; margin: 0; text-wrap: pretty; color: var(--ink); }
.page-head .ph-foot { display: flex; justify-content: space-between; align-items: end; gap: 24px; flex-wrap: wrap; margin-top: 24px; }
.page-head .ph-lead { max-width: 560px; font-size: 15px; line-height: 1.6; opacity: .85; margin: 0; color: var(--ink-soft); }
.page-head .ph-link { color: var(--brand); font-size: 13px; font-weight: 600; display: inline-flex; align-items: center; gap: 8px; }

/* category chips */
.cat-chips { display: flex; gap: 8px; flex-wrap: wrap; padding: 0 0 32px; overflow-x: auto; scrollbar-width: none; }
.cat-chips::-webkit-scrollbar { display: none; }
.cat-chip { padding: 9px 16px; border: 1px solid var(--line); border-radius: 999px; font-size: 13px; font-weight: 500; white-space: nowrap; transition: all .15s; color: var(--ink); max-width: 100%; }
.cat-chip.is-on { border-color: transparent; background: var(--brand); color: var(--brand-ink); }
/* Licznik: większa nieprzezroczystość dla czytelności (WCAG). */
.cat-chip .n { font-family: var(--font-display); font-style: italic; opacity: .8; margin-left: 4px; font-size: 12px; }
/* Widoczny focus klawiatury (dostępność) — chipy i wiersze filtrów są linkami. */
.cat-chip:focus-visible, .filter-row:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }

/* =====================================================================
   SHOP / ARCHIVE
   ===================================================================== */
.shop-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 32px; flex-wrap: wrap; font-size: 13px; color: var(--ink); }
.shop-toolbar .left { display: flex; gap: 18px; align-items: center; }
.shop-toolbar .results { color: var(--ink-soft); }
.shop-toolbar .results b { color: var(--ink); font-weight: 600; }
.shop-toolbar .filter-btn { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border: 1px solid var(--line); border-radius: 999px; font-weight: 500; color: var(--ink); }
.shop-toolbar .filter-btn .cnt { background: var(--brand); color: var(--brand-ink); padding: 2px 7px; border-radius: 999px; font-size: 11px; margin-left: 4px; }
.shop-toolbar .right { display: flex; gap: 16px; align-items: center; }
/* Zeruj domyślny margines WooCommerce na formularzu sortowania. */
.shop-toolbar .woocommerce-ordering, .shop-toolbar form.pz-ordering { margin: 0; display: inline-flex; align-items: center; }
.shop-toolbar .sort-select, .shop-toolbar select.orderby { height: 38px; padding: 0 16px; border: 1px solid var(--line); border-radius: 999px; font-family: inherit; font-size: 13px; background: transparent; cursor: pointer; color: var(--ink); }

.shop-body { display: grid; grid-template-columns: 240px 1fr; gap: 40px; padding-bottom: 80px; }
.shop-filters { font-size: 14px; }
.filter-block { padding: 20px 0; border-bottom: 1px solid var(--line); }
.filter-block:first-child { padding-top: 0; }
.filter-h { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; margin-bottom: 14px; display: flex; justify-content: space-between; align-items: center; color: var(--ink); }
.filter-h .clear { font-weight: 400; letter-spacing: 0; text-transform: none; opacity: .6; font-size: 12px; text-decoration: underline; text-underline-offset: 2px; color: var(--ink-soft); }
.filter-list { display: flex; flex-direction: column; gap: 10px; font-size: 13px; }
.filter-row { display: flex; align-items: center; gap: 10px; cursor: pointer; color: var(--ink); }
.filter-row .fbox { width: 16px; height: 16px; border: 1px solid var(--line); border-radius: 3px; display: inline-grid; place-items: center; flex: none; }
.filter-row .fbox svg { opacity: 0; color: var(--brand-ink); }
.filter-row.is-on .fbox { border-width: 0; background: var(--brand); }
.filter-row.is-on .fbox svg { opacity: 1; }
.filter-row .fcount { margin-left: auto; opacity: .75; font-size: 12px; color: var(--ink); }
.price-range-track { position: relative; height: 4px; border-radius: 999px; margin: 26px 4px 8px; background: var(--line); }
.price-range-fill { position: absolute; top: 0; bottom: 0; border-radius: 999px; background: var(--brand); }
.price-range-thumb { position: absolute; top: 50%; width: 16px; height: 16px; border-radius: 999px; transform: translate(-50%,-50%); border: 2px solid var(--brand); background: var(--surface); cursor: pointer; }
.price-range-vals { display: flex; justify-content: space-between; font-size: 12px; margin-top: 6px; color: var(--ink-soft); }

.shop-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }

.shop-pager { display: flex; justify-content: center; align-items: center; padding: 48px 0 0; color: var(--ink); }
/* Zdejmij domyślną ramkę WooCommerce (obwódka ul + kreski border-right na li). */
.shop-pager nav.woocommerce-pagination { width: auto; }
.shop-pager .woocommerce-pagination ul,
.shop-pager .woocommerce-pagination ul li { border: 0 !important; margin: 0; padding: 0; }
.shop-pager .woocommerce-pagination ul { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px; list-style: none; }
.shop-pager .woocommerce-pagination ul li { overflow: visible; }
.shop-pager a, .shop-pager span.page-numbers { min-width: 40px; height: 40px; border: 0 !important; border-radius: 4px; font-size: 13px; font-weight: 500; display: inline-grid; place-items: center; padding: 0 8px; color: var(--ink); background: transparent; transition: color .15s, background .15s; }
.shop-pager a.page-numbers:hover { color: var(--brand); background: transparent; }
.shop-pager .woocommerce-pagination .page-numbers.current,
.shop-pager .page-numbers.current { font-weight: 700; background: transparent !important; color: var(--brand) !important; box-shadow: none !important; }
.shop-pager .page-numbers.dots { border: 0 !important; background: transparent; color: var(--ink-soft); min-width: 24px; }
.shop-pager .prev, .shop-pager .next { padding: 0 18px; color: var(--brand); }
.shop-pager .prev:hover, .shop-pager .next:hover { color: var(--accent2); }
.shop-pager a:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }

/* benefits strip */
.benefits { padding: 80px 0 60px; background: var(--surface); border-top: 1px solid var(--line); }
.benefits-head { text-align: center; margin-bottom: 40px; }
.benefits-head h2 { font-family: var(--font-display); font-size: clamp(28px,3.4vw,40px); font-weight: 400; letter-spacing: -.015em; margin: 0; color: var(--ink); }
.benefits-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.benefit-card { padding: 28px 22px; border: 1px solid var(--line); border-radius: 6px; display: flex; flex-direction: column; gap: 10px; min-height: 180px; background: var(--bg); }
.benefit-icon { width: 36px; height: 36px; border-radius: 999px; display: grid; place-items: center; margin-bottom: 6px; background: var(--brand); color: var(--brand-ink); }
.benefit-card h4 { font-family: var(--font-display); font-size: 20px; font-weight: 500; letter-spacing: -.01em; margin: 0; color: var(--ink); }
.benefit-card p { font-size: 13px; line-height: 1.5; margin: 0; color: var(--ink-soft); }

/* mobile filter sheet */
.pz-filter-sheet { position: fixed; inset: 0; z-index: 50; background: rgba(0,0,0,.45); display: none; }
.pz-filter-sheet.is-open { display: block; }
.pz-filter-sheet .pz-fs-panel { position: absolute; left: 0; right: 0; bottom: 0; top: 10%; background: var(--bg); border-radius: 12px 12px 0 0; padding: 20px 18px; overflow-y: auto; }
.pz-fs-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.pz-fs-head h3 { font-family: var(--font-display); font-size: 24px; margin: 0; }

/* =====================================================================
   SINGLE PRODUCT
   ===================================================================== */
.prod-page { padding: 8px 0 80px; }
.prod-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 56px; }
.prod-gallery { display: grid; grid-template-columns: 80px 1fr; gap: 16px; }
.prod-thumbs { display: flex; flex-direction: column; gap: 10px; }
.prod-thumb { aspect-ratio: 1/1; border: 1px solid var(--line); border-radius: 4px; overflow: hidden; cursor: pointer; position: relative; transition: border-color .15s; background: var(--surface); }
.prod-thumb.is-on { border-width: 2px; border-color: var(--brand); }
.prod-thumb-inner { position: absolute; inset: 0; display: grid; place-items: center; padding: 6px; }
.prod-thumb-inner img { max-width: 80%; max-height: 80%; object-fit: contain; mix-blend-mode: multiply; }
.prod-main { aspect-ratio: 1/1; border: 1px solid var(--line); border-radius: 8px; position: relative; overflow: hidden; background: var(--surface); }
.prod-main-inner { position: absolute; inset: 0; display: grid; place-items: center; }
.prod-main-inner img { max-width: 80%; max-height: 88%; object-fit: contain; mix-blend-mode: multiply; }
.prod-badge { position: absolute; top: 18px; left: 18px; padding: 6px 14px; border-radius: 999px; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; z-index: 2; background: var(--accent2); color: var(--brand-ink); }
.prod-zoom-hint { position: absolute; bottom: 16px; right: 16px; padding: 6px 12px; border-radius: 999px; font-size: 11px; letter-spacing: 1px; backdrop-filter: blur(4px); z-index: 2; background: rgba(255,255,255,.6); color: var(--ink); pointer-events: none; }

/* ---------- LIGHTBOX (powiększenie zdjęcia produktu) ---------- */
html.pz-lb-lock, html.pz-lb-lock body { overflow: hidden; }
.pz-lightbox { position: fixed; inset: 0; z-index: 9999; display: none; align-items: center; justify-content: center; background: rgba(10,10,10,.92); padding: 24px; }
.pz-lightbox.is-open { display: flex; }
.pz-lb-stage { display: flex; align-items: center; justify-content: center; max-width: 90vw; max-height: 90vh; }
.pz-lb-img { max-width: 90vw; max-height: 90vh; object-fit: contain; background: #fff; border-radius: 8px; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.pz-lb-close { position: absolute; top: 20px; right: 24px; width: 44px; height: 44px; border: 0; border-radius: 999px; background: rgba(255,255,255,.12); color: #fff; font-size: 28px; line-height: 1; cursor: pointer; display: grid; place-items: center; transition: background .15s; }
.pz-lb-close:hover { background: rgba(255,255,255,.25); }
.pz-lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border: 0; border-radius: 999px; background: rgba(255,255,255,.12); color: #fff; font-size: 32px; line-height: 1; cursor: pointer; display: grid; place-items: center; transition: background .15s; }
.pz-lb-nav:hover { background: rgba(255,255,255,.25); }
.pz-lb-prev { left: 24px; }
.pz-lb-next { right: 24px; }
@media (max-width: 640px) {
  .pz-lb-nav { width: 42px; height: 42px; font-size: 26px; }
  .pz-lb-prev { left: 10px; } .pz-lb-next { right: 10px; }
  .pz-lb-close { top: 12px; right: 12px; }
}

.prod-meta { display: flex; flex-direction: column; }
.prod-line { font-size: 11px; letter-spacing: 2.5px; font-weight: 700; margin-bottom: 12px; color: var(--accent2); }
.prod-name { font-family: var(--font-display); font-size: clamp(30px,3.6vw,44px); font-weight: 400; line-height: 1.05; letter-spacing: -.02em; margin: 0 0 10px; text-wrap: pretty; color: var(--ink); }
.prod-tagline { font-family: var(--font-display); font-style: italic; font-size: 18px; line-height: 1.4; margin: 0 0 24px; opacity: .85; color: var(--ink-soft); }
.prod-stars { display: flex; align-items: center; gap: 10px; font-size: 13px; margin-bottom: 28px; color: var(--ink-soft); }
.prod-stars .stars { letter-spacing: 1px; font-size: 14px; color: var(--accent); }
.prod-stars b { color: var(--ink); font-family: var(--font-display); font-size: 16px; }
.prod-stars .review-link { text-decoration: underline; text-underline-offset: 3px; opacity: .8; }
.prod-stars .instock { display: inline-flex; align-items: center; gap: 4px; }
.prod-stars .instock svg { color: var(--brand); }
.prod-stars .instock.is-out { color: #c0392b; }
.prod-stars .instock.is-out svg { color: #c0392b; }
.prod-price-row { display: flex; align-items: baseline; gap: 14px; margin-bottom: 6px; flex-wrap: wrap; }
.prod-price { font-family: var(--font-display); font-size: 44px; font-weight: 500; line-height: 1; color: var(--ink); }
.prod-price .amount { font-family: inherit; }
.prod-price del { font-size: 18px; opacity: .5; font-weight: 400; }
.prod-price ins { text-decoration: none; }
.prod-price-save { font-size: 12px; padding: 4px 10px; border-radius: 999px; font-weight: 600; letter-spacing: .5px; background: var(--accent2); color: var(--brand-ink); }
.prod-unit { font-size: 13px; opacity: .7; margin-bottom: 24px; color: var(--ink-soft); }

.prod-variants { display: flex; flex-direction: column; gap: 18px; padding: 24px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 20px; }
.prod-var-row { display: flex; flex-direction: column; gap: 10px; }
.prod-var-label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 600; display: flex; justify-content: space-between; color: var(--ink); }
.prod-var-label span { font-weight: 400; opacity: .7; letter-spacing: 0; text-transform: none; font-size: 13px; color: var(--ink-soft); }
.prod-var-opts { display: flex; gap: 8px; flex-wrap: wrap; }
.prod-var-opt { padding: 12px 18px; border: 1px solid var(--line); border-radius: 4px; font-size: 13px; font-weight: 500; cursor: pointer; transition: all .15s; min-width: 64px; text-align: center; color: var(--ink); background: transparent; }
.prod-var-opt.is-on { border-width: 2px; padding: 11px 17px; border-color: var(--brand); background: var(--surface); }
.prod-var-opt.is-disabled { opacity: .35; cursor: not-allowed; text-decoration: line-through; }
.prod-var-opt small { display: block; font-size: 11px; opacity: .6; font-weight: 400; margin-top: 2px; color: var(--ink-soft); }

.prod-cta-row { display: grid; grid-template-columns: auto 1fr; gap: 12px; margin-bottom: 16px; align-items: stretch; }
.qty-stepper { display: flex; align-items: center; border: 0px solid var(--line); border-radius: 4px; overflow: hidden; background: var(--surface); }
.qty-btn { width: 48px; height: 56px; font-size: 18px; font-weight: 500; color: var(--ink); display: grid; place-items: center; }
/* Reset wewnętrznego inputa: bez własnej obwódki/paddingu — inaczej reguły WooCommerce
   (.woocommerce .quantity input.qty) dorysowują drugą ramkę → „prostokąt w prostokącie". */
.woocommerce .qty-stepper .quantity, .qty-stepper .quantity { margin: 0; }
.woocommerce .qty-stepper .quantity input.qty, .qty-stepper input.qty { width: 48px; border: 0; border-radius: 0; padding: 0; text-align: center; font-family: var(--font-display); font-size: 22px; background: transparent; color: var(--ink); -moz-appearance: textfield; }
.qty-stepper input.qty::-webkit-outer-spin-button, .qty-stepper input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.prod-add { padding: 16px 24px; border-radius: 4px; font-size: 14px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; display: inline-flex; align-items: center; justify-content: center; gap: 10px; transition: filter .15s; background: var(--brand); color: var(--brand-ink); width: 100%; border: 0; cursor: pointer; }
.prod-add:hover { filter: brightness(1.08); }
.prod-secondary-row { display: flex; gap: 12px; margin-bottom: 24px; }
.prod-sec-btn { flex: 1; padding: 14px 20px; border: 1px solid var(--line); border-radius: 4px; font-size: 13px; font-weight: 500; display: inline-flex; align-items: center; justify-content: center; gap: 8px; color: var(--ink); }
.prod-sec-btn svg { color: var(--brand); }
.prod-trust { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px 20px; padding: 20px 0; border-top: 1px solid var(--line); font-size: 13px; }
.prod-trust-item { display: flex; align-items: flex-start; gap: 10px; }
.prod-trust-item svg { color: var(--brand); flex: none; }
.prod-trust-item b { display: block; font-weight: 600; margin-bottom: 1px; color: var(--ink); }
.prod-trust-item span { opacity: .75; font-size: 12px; line-height: 1.4; color: var(--ink-soft); }

.prod-details { padding: 80px 0 0; }
.prod-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--line); margin-bottom: 32px; overflow-x: auto; scrollbar-width: none; }
.prod-tabs::-webkit-scrollbar { display: none; }
.prod-tab { padding: 18px 4px; margin: 0 24px 0 0; font-size: 14px; font-weight: 500; border-bottom: 2px solid transparent; white-space: nowrap; color: var(--ink-soft); }
.prod-tab.is-on { font-weight: 700; color: var(--brand); border-bottom-color: var(--brand); }
.prod-tab-panel { display: none; }
.prod-tab-panel.is-on { display: block; }
.prod-tab-body { display: grid; grid-template-columns: 1.5fr 1fr; gap: 56px; }
.prod-desc { color: var(--ink-soft); font-size: 15px; line-height: 1.8; max-width: 70ch; }
.prod-desc > :first-child { margin-top: 0; }
.prod-desc h2, .prod-desc h3 { font-family: var(--font-display); font-size: 24px; font-weight: 500; letter-spacing: -.01em; margin: 28px 0 14px; color: var(--ink); }
.prod-desc h3 + * { margin-top: 0; }
.prod-desc p { font-size: 15px; line-height: 1.8; margin: 0 0 16px; color: var(--ink-soft); }
.prod-desc strong, .prod-desc b { color: var(--ink); font-weight: 600; }
/* Akapity-akcenty (w całości pogrubione, np. „Odkryj…!") — czerwień marki, jak w designie. */
.prod-desc p.pz-hl, .prod-desc p.pz-hl strong, .prod-desc p.pz-hl b { color: var(--brand); }
.prod-desc a { color: var(--brand); text-decoration: underline; text-underline-offset: 2px; }
.prod-desc a:hover { color: var(--accent2); }
.prod-desc img { max-width: 100%; height: auto; border-radius: 10px; margin: 8px 0; }
/* Nagłówek „CHARAKTERYSTYKA…" itp. (h4 w treści) */
.prod-desc h4 { font-family: var(--font-body); font-weight: 700; font-size: 15px; letter-spacing: .01em; color: var(--ink); margin: 24px 0 14px; }
/* Lista zalet jako checklista z ikonami ✓ w kółkach (jak w designie) */
.prod-desc ul { list-style: none; padding-left: 0; margin: 0 0 20px; color: var(--ink-soft); }
.prod-desc ul li { position: relative; padding-left: 32px; font-size: 14px; line-height: 1.6; margin-bottom: 11px; }
.prod-desc ul li::before {
  content: ""; position: absolute; left: 0; top: 0; width: 20px; height: 20px;
  background: no-repeat center / contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b81d2b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M8.3 12.4l2.6 2.6 4.8-5.4'/%3E%3C/svg%3E");
}
/* Listy zwykłe/numerowane poza checklistą */
.prod-desc ol { padding-left: 20px; margin: 0 0 20px; color: var(--ink-soft); }
.prod-desc ol li { font-size: 14px; line-height: 1.6; margin-bottom: 6px; }
.prod-spec { padding: 28px; border: 1px solid var(--line); border-radius: 6px; background: var(--surface); align-self: start; }
.prod-spec h4 { font-family: var(--font-display); font-style: italic; font-size: 16px; font-weight: 500; margin: 0 0 16px; }
.prod-spec dl { display: grid; grid-template-columns: 1fr auto; gap: 8px 16px; margin: 0; font-size: 13px; }
.prod-spec dt { opacity: .7; color: var(--ink-soft); }
.prod-spec dd { margin: 0; font-weight: 600; text-align: right; color: var(--ink); }
.prod-spec .note { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--line); font-size: 12px; color: var(--ink-soft); line-height: 1.5; }

.prod-reviews { padding: 80px 0 0; }
.reviews-head { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; align-items: center; margin-bottom: 40px; }
.reviews-summary .big-rating { font-family: var(--font-display); font-size: 80px; font-weight: 500; line-height: 1; letter-spacing: -.02em; color: var(--ink); }
.reviews-summary .big-rating sub { font-family: var(--font-body); font-size: 22px; opacity: .5; vertical-align: baseline; font-weight: 400; }
.reviews-summary .stars-row { font-size: 18px; letter-spacing: 2px; margin: 8px 0 6px; color: var(--accent); }
.reviews-summary .review-count { font-size: 13px; opacity: .75; color: var(--ink-soft); }
.reviews-bars { display: grid; gap: 8px; }
.review-bar-row { display: grid; grid-template-columns: 50px 1fr 32px; gap: 12px; align-items: center; font-size: 12px; color: var(--ink-soft); }
.review-bar-track { height: 6px; border-radius: 999px; overflow: hidden; background: rgba(0,0,0,.08); }
.review-bar-fill { height: 100%; border-radius: 999px; background: var(--brand); }
.review-list { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.review-card { padding: 24px; border: 1px solid var(--line); border-radius: 6px; background: var(--surface); }
.review-card .review-row1 { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; font-size: 13px; }
.review-card .review-stars { letter-spacing: 1px; font-size: 14px; color: var(--accent); }
.review-card .review-row1 .rdate { color: var(--ink-soft); }
.review-card h4 { font-family: var(--font-display); font-style: italic; font-size: 17px; font-weight: 500; margin: 0 0 8px; line-height: 1.3; color: var(--ink); }
.review-card p { font-size: 14px; line-height: 1.55; margin: 0; opacity: .85; color: var(--ink); }
.review-card .review-meta { display: flex; gap: 14px; margin-top: 14px; font-size: 12px; color: var(--ink-soft); }
.review-card .review-meta b { color: var(--ink); font-weight: 600; }
.review-card .verified { display: inline-flex; align-items: center; gap: 4px; color: var(--brand); margin-left: auto; }

.prod-similar { padding: 80px 0 0; }
.prod-similar-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.prod-sticky { position: sticky; bottom: 0; z-index: 20; padding: 12px 16px; border-top: 1px solid var(--line); display: none; align-items: center; gap: 12px; backdrop-filter: blur(8px); background: rgba(250,247,240,.95); }
.prod-sticky .ps-info { flex: 1; }
.prod-sticky .ps-name { font-size: 12px; color: var(--ink-soft); }
.prod-sticky .ps-price { font-family: var(--font-display); font-size: 22px; font-weight: 500; color: var(--ink); }
.prod-sticky button { padding: 14px 22px; border-radius: 4px; font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; background: var(--brand); color: var(--brand-ink); }

/* =====================================================================
   BLOG
   ===================================================================== */
.blog-hero { padding: 8px 0 56px; }
.blog-hero-grid { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: end; }
.blog-hero h1 { font-family: var(--font-display); font-size: clamp(40px,5.6vw,72px); font-weight: 400; line-height: 1.02; letter-spacing: -.02em; margin: 0 0 12px; text-wrap: pretty; color: var(--ink); }
.blog-hero .lead { font-size: 16px; line-height: 1.65; max-width: 480px; margin: 0; color: var(--ink-soft); }
.blog-search { display: flex; gap: 8px; margin-top: 24px; }
.blog-search input { flex: 1; padding: 14px 18px; border: 1px solid var(--line); border-radius: 999px; background: transparent; font-family: inherit; font-size: 14px; outline: none; color: var(--ink); }
.blog-search button { padding: 14px 22px; border-radius: 999px; font-size: 13px; font-weight: 600; letter-spacing: .5px; background: var(--brand); color: var(--brand-ink); }
.blog-meta-strip { display: flex; gap: 28px; padding-top: 24px; border-top: 1px solid var(--line); font-size: 13px; flex-wrap: wrap; color: var(--ink-soft); }
.blog-meta-strip b { font-family: var(--font-display); font-size: 22px; font-weight: 500; display: block; line-height: 1.1; margin-bottom: 2px; color: var(--ink); }

.feat-post { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; padding: 8px 0 64px; align-items: center; }
/* min-width:0 — bez tego kolumna „1fr" rozpycha się do szerokości treści (blowout) i kafel wychodzi poza ekran na wąskich widokach. */
.feat-post > * { min-width: 0; }
.feat-img { aspect-ratio: 4/3; border-radius: 8px; overflow: hidden; position: relative; border: 1px solid var(--line); }
.feat-img-inner { position: absolute; inset: 0; }
.feat-img-inner img { width: 100%; height: 100%; object-fit: cover; }
.feat-tag { position: absolute; top: 16px; left: 16px; padding: 6px 14px; border-radius: 999px; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; background: var(--accent2); color: var(--brand-ink); z-index: 2; }
.feat-cat { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 600; margin-bottom: 16px; color: var(--accent2); }
.feat-post h2 { font-family: var(--font-display); font-size: clamp(28px,3.6vw,44px); font-weight: 400; line-height: 1.1; letter-spacing: -.015em; margin: 0 0 18px; text-wrap: pretty; color: var(--ink); }
.feat-lead { font-size: 15px; line-height: 1.6; opacity: .85; margin: 0 0 28px; max-width: 480px; color: var(--ink-soft); }
.feat-meta { display: flex; flex-wrap: wrap; gap: 8px 18px; align-items: center; font-size: 13px; opacity: .75; margin-bottom: 24px; color: var(--ink-soft); }
.feat-meta .author { display: flex; align-items: center; gap: 8px; }
.feat-meta .avatar { width: 32px; height: 32px; border-radius: 999px; background: linear-gradient(135deg, var(--accent), var(--accent2)); overflow: hidden; }
.feat-meta b { color: var(--ink); font-weight: 600; }
.feat-cta { display: inline-flex; align-items: center; gap: 8px; padding: 14px 26px; border: 1px solid var(--brand); border-radius: 999px; font-size: 13px; font-weight: 600; letter-spacing: .5px; color: var(--brand); }

.articles { padding: 24px 0 80px; }
.articles-head { display: flex; justify-content: space-between; align-items: end; gap: 16px; margin-bottom: 40px; flex-wrap: wrap; }
.articles-head h2 { font-family: var(--font-display); font-size: clamp(24px,3vw,36px); font-weight: 400; letter-spacing: -.015em; margin: 0; color: var(--ink); }
.articles-head .sort { font-size: 13px; display: flex; align-items: center; gap: 8px; color: var(--ink-soft); }
.articles-head .sort select { background: transparent; border: 0; color: var(--ink); font-family: inherit; font-weight: 500; }
.articles-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px 24px; }
.article-card { display: flex; flex-direction: column; gap: 14px; cursor: pointer; }
.article-card .art-img { aspect-ratio: 4/3; border-radius: 6px; overflow: hidden; border: 1px solid var(--line); position: relative; transition: transform .25s; }
.article-card:hover .art-img { transform: translateY(-3px); }
.article-card .art-img-inner { position: absolute; inset: 0; }
.article-card .art-img-inner img { width: 100%; height: 100%; object-fit: cover; }
.article-card .art-cat { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; color: var(--accent2); }
.article-card h3 { font-family: var(--font-display); font-size: 22px; font-weight: 500; line-height: 1.2; letter-spacing: -.01em; margin: 0; text-wrap: pretty; color: var(--ink); }
.article-card .art-excerpt { font-size: 14px; line-height: 1.5; opacity: .75; margin: 0; color: var(--ink-soft); }
.article-card .art-foot { display: flex; justify-content: space-between; align-items: center; font-size: 12px; opacity: .65; margin-top: 4px; color: var(--ink-soft); }
.article-card .art-time { display: inline-flex; align-items: center; gap: 5px; }
.article-card.wide { grid-column: span 2; flex-direction: row; gap: 28px; }
.article-card.wide .art-img { aspect-ratio: 5/4; flex: none; width: 50%; }
.article-card.wide .art-meta-col { display: flex; flex-direction: column; justify-content: center; gap: 14px; }
.article-card.wide h3 { font-size: 28px; }

.bgph { position: absolute; inset: 0; display: grid; place-items: center; font-family: ui-monospace, Menlo, monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.65); background-size: cover; background-position: center; }
.bgph.striped::before { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 8px, transparent 8px 16px); }
.bgph .ph-label { position: relative; z-index: 1; padding: 6px 10px; border-radius: 2px; backdrop-filter: blur(2px); background: rgba(0,0,0,.18); }

.blog-news { padding: 80px 0; margin-top: 40px; background: var(--brand); color: var(--brand-ink); }
.blog-news-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: center; }
.blog-news-grid > * { min-width: 0; }
.blog-news .kicker { color: var(--accent); }
.blog-news h2 { font-family: var(--font-display); font-size: clamp(32px,4vw,48px); font-weight: 400; line-height: 1.05; letter-spacing: -.02em; margin: 0 0 16px; }
.blog-news p { font-size: 15px; line-height: 1.6; max-width: 440px; margin: 0; color: rgba(246,241,227,.85); }
.blog-news-form { display: flex; gap: 8px; }
.blog-news-form input { flex: 1; min-width: 0; padding: 16px 20px; border: 1px solid rgba(255,255,255,.2); border-radius: 4px; background: rgba(255,255,255,.06); font-family: inherit; font-size: 14px; outline: none; color: var(--brand-ink); }
.blog-news-form button { padding: 16px 24px; border-radius: 4px; font-size: 13px; font-weight: 600; letter-spacing: .5px; background: var(--accent); color: var(--brand); }
.blog-news-perks { list-style: none; padding: 0; margin: 24px 0 0; display: grid; gap: 10px; font-size: 13px; }
.blog-news-perks li { display: flex; align-items: center; gap: 10px; opacity: .85; }
.blog-news-perks svg { color: var(--accent); }

/* =====================================================================
   SINGLE POST / PAGE — editorial article
   ===================================================================== */
.pz-article { padding: 8px 0 80px; }
.pz-article-head { max-width: 760px; margin: 0 auto; padding: 16px 0 28px; text-align: center; }
.pz-article-head .art-cat { color: var(--accent2); margin-bottom: 16px; }
.pz-article-head h1 { font-family: var(--font-display); font-size: clamp(32px,4.4vw,56px); font-weight: 400; line-height: 1.08; letter-spacing: -.02em; margin: 0 0 16px; text-wrap: pretty; }
.pz-article-head .art-meta { display: inline-flex; gap: 14px; align-items: center; font-size: 13px; color: var(--ink-soft); flex-wrap: wrap; justify-content: center; }
.pz-article-cover { aspect-ratio: 16/8; border-radius: 10px; overflow: hidden; border: 1px solid var(--line); margin-bottom: 40px; position: relative; }
.pz-article-cover img { width: 100%; height: 100%; object-fit: cover; }
.entry-content { max-width: 720px; margin: 0 auto; font-size: 17px; line-height: 1.75; color: var(--ink); }
.entry-content > * { margin: 0 0 22px; }
.entry-content h2 { font-family: var(--font-display); font-size: 30px; font-weight: 500; letter-spacing: -.01em; margin: 40px 0 14px; }
.entry-content h3 { font-family: var(--font-display); font-size: 23px; font-weight: 500; margin: 32px 0 12px; }
.entry-content a { color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }
.entry-content img { border-radius: 8px; }
.entry-content blockquote { border-left: 3px solid var(--accent); padding-left: 20px; font-family: var(--font-display); font-style: italic; font-size: 22px; color: var(--ink); }
.entry-content ul, .entry-content ol { padding-left: 22px; }
.entry-content code { background: rgba(0,0,0,.05); padding: 2px 6px; border-radius: 4px; font-size: .9em; }
.pz-page-head { padding: 40px 0 8px; text-align: center; }
.pz-page-head h1 { font-family: var(--font-display); font-size: clamp(34px,4.4vw,56px); font-weight: 400; letter-spacing: -.02em; margin: 0; }

/* comments */
.pz-comments { max-width: 720px; margin: 64px auto 0; }
.pz-comments h2 { font-family: var(--font-display); font-size: 28px; font-weight: 500; margin: 0 0 24px; }
.pz-comments ol { list-style: none; padding: 0; margin: 0; display: grid; gap: 20px; }
.pz-comments .comment-body { border: 1px solid var(--line); border-radius: 8px; padding: 20px; background: var(--surface); }
.pz-comments .comment-author { font-weight: 600; }
.pz-comments .comment-meta { font-size: 12px; color: var(--ink-soft); margin-bottom: 8px; }
.pz-comments .comment-respond { margin-top: 32px; }
.pz-comments input[type=text], .pz-comments input[type=email], .pz-comments input[type=url], .pz-comments textarea { width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: 6px; font-family: inherit; background: var(--surface); margin-bottom: 12px; }
.pz-comments .submit, .pz-btn { background: var(--brand); color: var(--brand-ink); padding: 12px 24px; border-radius: 4px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; font-size: 13px; }
/* Opinie produktu — bramka i formularz z oceną */
.pz-review-gate { max-width: 640px; padding: 16px 18px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface); color: var(--ink-soft); font-size: 14px; line-height: 1.5; }
.pz-review-gate a { color: var(--brand); font-weight: 600; }
/* Gdy wyświetlamy tylko bramkę (brak prawa do opinii) — do lewej, nie centrujemy bloku. */
.pz-comments:has(> .pz-review-gate) { margin-left: 0; margin-right: auto; }
.pz-review-form .comment-reply-title, .pz-review-form-title { display: block; font-family: var(--font-display); font-size: 22px; font-weight: 500; margin: 0 0 16px; color: var(--ink); }
.pz-review-form .comment-form-rating { margin-bottom: 14px; }
.pz-review-form .comment-form-rating > label, .pz-review-form .comment-form-comment > label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; color: var(--ink); }
.pz-review-form select#rating { width: 100%; max-width: 260px; padding: 11px 14px; border: 1px solid var(--line); border-radius: 6px; font-family: inherit; font-size: 14px; background: var(--surface); color: var(--ink); cursor: pointer; }
.pz-review-form .required { color: var(--brand); }
.pz-review-form .comment-form-rating .stars { font-size: 18px; }

/* search results / archive list */
.pz-loop { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px 24px; padding: 24px 0 60px; }
.pz-empty { padding: 60px 0 80px; text-align: center; color: var(--ink-soft); }

/* =====================================================================
   WooCommerce native pages (cart / checkout / account / notices)
   ===================================================================== */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews { border-radius: 6px; padding: 14px 18px; margin: 0 0 24px; list-style: none; font-size: 14px; border: 1px solid var(--line); background: var(--surface); }
.woocommerce-message { border-left: 4px solid var(--brand); }
.woocommerce-error { border-left: 4px solid var(--accent2); }
.woocommerce-info { border-left: 4px solid var(--accent); }
.woocommerce .button, .woocommerce button.button, .woocommerce a.button, .woocommerce input.button, .woocommerce #respond input#submit {
  background: var(--brand); color: var(--brand-ink); border-radius: 4px; padding: 12px 22px; font-weight: 600; font-size: 13px; letter-spacing: .5px; border: 0; transition: filter .15s;
}
.woocommerce .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover { filter: brightness(1.08); background: var(--brand); color: var(--brand-ink); }
.woocommerce .button.alt, .woocommerce #place_order { background: var(--accent2); }
.woocommerce-page .container.pz-wc-wrap { padding-top: 32px; padding-bottom: 80px; }
.pz-wc-wrap h1, .woocommerce-account .container h1 { font-family: var(--font-display); font-weight: 400; letter-spacing: -.02em; font-size: clamp(30px,4vw,48px); margin: 8px 0 24px; }
.woocommerce table.shop_table { border: 1px solid var(--line); border-radius: 8px; border-collapse: separate; border-spacing: 0; }
.woocommerce table.shop_table th { font-weight: 600; }
.woocommerce-cart table.cart img { width: 64px; border-radius: 6px; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select, .select2-container .select2-selection { border: 1px solid var(--line); border-radius: 6px; padding: 10px 12px; }
.woocommerce .quantity input.qty { border: 1px solid var(--line); border-radius: 6px; padding: 8px; }
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product { list-style: none; }
.star-rating { color: var(--accent); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1024px) {
  .intro-grid { grid-template-columns: 1fr; gap: 32px; }
  .cathub-grid { grid-template-columns: repeat(2,1fr); }
  .stage-grid { grid-template-columns: repeat(2,1fr); }
  .type-grid { grid-template-columns: repeat(3,1fr); }
  .best-grid { grid-template-columns: repeat(2,1fr); }
  .strip-grid { grid-template-columns: 1fr; }
  .philo-grid, .roots-grid { grid-template-columns: 1fr; gap: 40px; }
  .foot-grid { grid-template-columns: repeat(2,1fr); }
  .feat-post { grid-template-columns: 1fr; }
  .articles-grid { grid-template-columns: repeat(2,1fr); }
  .prod-grid { grid-template-columns: 1fr; }
  .prod-tab-body { grid-template-columns: 1fr; }
  .reviews-head { grid-template-columns: 1fr; }
  .review-list { grid-template-columns: 1fr; }
  .shop-body { grid-template-columns: 200px 1fr; }
  .prod-similar-grid { grid-template-columns: repeat(3,1fr); }
  .benefits-grid { grid-template-columns: repeat(2,1fr); }
  .blog-news-grid { grid-template-columns: 1fr; gap: 32px; }
  .pz-loop { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 720px) {
  .blog-hero-grid { grid-template-columns: 1fr; gap: 24px; }
  .articles-grid { grid-template-columns: 1fr; }
  .article-card.wide { grid-column: auto; flex-direction: column; }
  .article-card.wide .art-img { width: 100%; }
  .shop-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .shop-body { grid-template-columns: 1fr; gap: 0; }
  .shop-filters.desktop-filters { display: none; }
  /* Długie nazwy kategorii (np. „Komponenty paszowe (Owies, …)") zawijają się w pigułce zamiast wychodzić poza ekran. */
  .cat-chip { white-space: normal; }
  .prod-similar-grid { grid-template-columns: repeat(2,1fr); }
  .cathub-grid, .stage-grid { grid-template-columns: 1fr; }
  .type-grid { grid-template-columns: repeat(2,1fr); }
  .best-grid { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr; }
  .stage-tile { grid-template-columns: 100px 1fr; }
  .pz-loop { grid-template-columns: 1fr; }
  .prod-sticky { display: flex; }
  /* większe zdjęcie produktu na mobilce: wyższy (kwadratowy) box + grafika wypełnia prawie cały */
  .pc-img { aspect-ratio: 1 / 1; }
  .prod-img-wrap img { max-width: 94%; max-height: 94%; }
  /* karta produktu: tytuł/opis dopasowane do mniejszego fontu + czytelny odstęp */
  .pc-body { gap: 6px; }
  .pc-name { font-size: 16px; min-height: calc(16px * 1.2 * 2); margin-bottom: 2px; }
  .pc-price { font-size: 20px; }
  /* stopka pionowo: cena/waga u góry, „Do koszyka" na całą szerokość (nie ucinany) */
  .pc-foot { flex-direction: column; align-items: stretch; gap: 8px; }
  .pc-cta { width: 100%; justify-content: center; }
  body { font-size: 15px; }
}

/* =====================================================================
   OVERRIDES — paleta biało-czarno-czerwona + topbar (v1.1)
   ===================================================================== */

/* Ciemne (czarne) pasy sekcji zamiast jednolitej czerwieni — czysty look. */
.philo, .blog-news { background: var(--band); }
.hero-band { background: var(--band); }
/* Akcenty na ciemnych pasach pozostają czerwone — dobry kontrast. */
.philo .kicker, .blog-news .kicker { color: var(--brand); }

/* Przyciski na ciemnym tle / na zdjęciu — czytelny kontrast. */
.sm-btn { background: var(--brand); color: #fff; }
.blog-news-form button { background: var(--brand); color: #fff; }
.news-form button { background: var(--brand); color: #fff; }
.pc-tag.badge-accent { background: var(--brand); color: #fff; }
.pc-cta.full { background: var(--brand); color: #fff; border-color: var(--brand); }

/* Czerwone ramki/akcenty na kartach (żeby „pasowało"). */
.pc.tile:hover { border-color: var(--brand); }
.cat-tile:hover { border-color: var(--brand); }
.strip-card:hover, .benefit-card:hover { border-color: var(--brand); }
.prod-main { border-color: var(--line); }
.feat-img:hover { border-color: var(--brand); }

/* ---------- TOPBAR: widoczność mobile vs desktop (twarde reguły) ---------- */
@media (min-width: 721px) {
  .pz .mobile-only,
  .pz .m-topbar,
  .pz .m-search-bar { display: none !important; }
  .pz .topbar-fullbleed.desktop-only { display: block !important; }
}
@media (max-width: 720px) {
  .pz .topbar-fullbleed.desktop-only,
  .pz .desktop-only { display: none !important; }
  .pz .m-topbar.mobile-only { display: flex !important; }
}

/* ---------- TOPBAR: większe ikonki, miejsce na przełącznik języka ---------- */
.sm-actions { gap: 14px;}
.sm-icon-btn { width: 46px; height: 46px; border-radius: 8px; }
.sm-icon-btn svg { width: 26px; height: 26px; }
.sm-cart-count { top: -2px; right: -4px; min-width: 20px; height: 20px; font-size: 11px; }

/* mobilny header — większe ikonki */
.m-topbar .m-icons { gap: 6px; }
.m-topbar .m-icons button,
.m-topbar .m-icons a { width: 42px; height: 42px; }
.m-topbar .m-icons svg { width: 24px; height: 24px; }

/* ---------- GTranslate: nie nachodzi na ikonki ---------- */
html body #gt_float_wrapper {
  top: 18px !important;
  right: clamp(20px, 4vw, 56px) !important;
  left: auto !important;
  bottom: auto !important;
}
@media (max-width: 720px) {
  /* GTranslate ma z-index max (2147483647) — w prawym górnym rogu przykrywał
     hamburger i przechwytywał kliknięcia (menu się nie otwierało).
     Spychamy go pod pasek nagłówka, żeby nie nachodził na ikony. */
  html body #gt_float_wrapper { top: 76px !important; right: 12px !important; }
  .m-topbar { padding-right: 16px; }
}

/* =====================================================================
   NAWIGACJA — rozwijane menu (mega + proste dropdowny), hover (v1.2)
   ===================================================================== */
.sm-mainnav-row { overflow: visible; }
.pz-nav { list-style: none; margin: 0; padding: 0; display: flex; justify-content: center; align-items: stretch; flex-wrap: nowrap; }
.pz-nav-item { position: relative; display: flex; align-items: stretch; }
.pz-nav-item > .smnav-item { cursor: pointer; }

.pz-dropdown {
  position: absolute; top: 100%; left: 0; z-index: 60;
  background: var(--surface); border: 1px solid var(--line); border-radius: 12px;
  box-shadow: 0 22px 60px -24px rgba(0,0,0,.32);
  padding: 16px 18px;
  opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity .16s ease, transform .16s ease; pointer-events: none;
}
.pz-nav-item:hover > .pz-dropdown,
.pz-nav-item:focus-within > .pz-dropdown { opacity: 1; visibility: visible; transform: none; pointer-events: auto; }
/* mostek nad przerwą, żeby najazd nie zamykał panelu */
.pz-nav-item > .pz-dropdown::before { content: ""; position: absolute; left: 0; right: 0; top: -12px; height: 12px; }

.pz-dropdown.pz-simple { min-width: 240px; }
.pz-dropdown ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 1px; }
.pz-dropdown.pz-simple a { display: block; padding: 10px 12px; border-radius: 7px; font-size: 14px; color: var(--ink); text-transform: none; letter-spacing: 0; font-weight: 500; }
.pz-dropdown.pz-simple a:hover { background: #fbeff1; color: var(--brand); }

.pz-dropdown.pz-mega { left: 0; width: min(900px, 90vw); max-width: calc(100vw - 32px); padding: 26px 30px; }
.pz-mega-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px 28px; }
.pz-mega-col .pz-mega-h { display: block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700; color: var(--brand); padding-bottom: 10px; margin-bottom: 8px; border-bottom: 1px solid var(--line); }
.pz-mega-col li a { display: block; padding: 6px 8px; border-radius: 6px; font-size: 13.5px; color: var(--ink); text-transform: none; letter-spacing: 0; font-weight: 500; line-height: 1.35; }
.pz-mega-col li a:hover { background: #fbeff1; color: var(--brand); }

@media (max-width: 1100px) {
  .pz-dropdown.pz-mega { width: min(720px, 92vw); }
  .pz-mega-grid { grid-template-columns: repeat(2, 1fr); }
}

/* =====================================================================
   WOOCOMMERCE — koszyk / checkout / konto (spójne z designem) (v1.2)
   ===================================================================== */
.pz-wc-wrap { padding-top: 28px; padding-bottom: 90px; }

/* nagłówki sekcji WC */
.woocommerce .cart_totals > h2,
.woocommerce .cross-sells > h2,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout h3#ship-to-different-address,
.woocommerce form.checkout h3 {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -.01em; font-size: 26px; margin: 0 0 18px;
}

/* tabele (koszyk + zamówienie) */
.woocommerce table.shop_table { border: 1px solid var(--line); border-radius: 12px; border-collapse: separate; border-spacing: 0; overflow: hidden; margin: 0 0 24px; }
.woocommerce table.shop_table thead th { background: #faf7f7; text-transform: uppercase; letter-spacing: 1px; font-size: 11px; font-weight: 700; color: var(--ink-soft); padding: 16px; border: 0; }
.woocommerce table.shop_table th, .woocommerce table.shop_table td { padding: 16px; border-top: 1px solid var(--line); }
.woocommerce table.shop_table tbody tr:first-child td { border-top: 0; }
.woocommerce-cart table.cart img { width: 64px; height: auto; border-radius: 8px; border: 1px solid var(--line); }
.woocommerce a.remove { color: var(--accent2) !important; border: 1px solid var(--line); font-weight: 400; }
.woocommerce a.remove:hover { background: var(--accent2) !important; color: #fff !important; border-color: var(--accent2); }
.woocommerce .product-name a { font-family: var(--font-display); font-size: 17px; color: var(--ink); }
.woocommerce .product-name a:hover { color: var(--brand); }
.woocommerce .quantity input.qty { width: 64px; padding: 10px 8px; border: 1px solid var(--line); border-radius: 8px; text-align: center; font-family: var(--font-body); }

/* pola formularzy + kupon */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce #add_coupon_code, .woocommerce #coupon_code,
.woocommerce .input-text, .select2-container--default .select2-selection--single {
  border: 1px solid var(--line) !important; border-radius: 8px; padding: 12px 14px; font-family: var(--font-body); background: var(--surface); min-height: 46px;
}
.woocommerce .cart .actions .coupon { display: flex; gap: 8px; align-items: center; }
.woocommerce .cart .actions .coupon input { border-radius: 999px; }

/* przyciski — czerwone CTA (nadpisuje fiolet CommerceKit) */
.woocommerce .button, .woocommerce button.button, .woocommerce a.button, .woocommerce input.button, .woocommerce #respond input#submit {
  background: var(--brand); color: #fff; border-radius: 8px; padding: 13px 22px; font-weight: 600; font-size: 13px; letter-spacing: .4px; border: 0; transition: filter .15s; text-transform: none; box-shadow: none;
}
.woocommerce .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover { filter: brightness(1.08); background: var(--brand); color: #fff; }
.woocommerce a.button.checkout-button,
.woocommerce a.checkout-button.button.alt,
.woocommerce .wc-proceed-to-checkout a.checkout-button,
.woocommerce #place_order, .woocommerce button#place_order, .woocommerce-checkout #place_order {
  background: var(--brand) !important; color: #fff !important; border: 0 !important;
  width: 100%; display: block; text-align: center; padding: 16px 24px; border-radius: 8px;
  font-size: 14px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
}
.woocommerce a.button.checkout-button:hover, .woocommerce #place_order:hover { filter: brightness(1.08); }
/* przycisk "zaktualizuj koszyk" / drugorzędne — wariant konturowy */
.woocommerce .cart .actions .button[name="update_cart"] {
  background: transparent; color: var(--brand); border: 1px solid var(--brand);
}
.woocommerce .cart .actions .button[name="update_cart"]:hover { background: var(--brand); color: #fff; }
.woocommerce .cart .actions .button[name="update_cart"][disabled], .woocommerce .button[disabled] { opacity: .45; }

/* podsumowanie / boxy */
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review,
.woocommerce .woocommerce-checkout-review-order-table {
  border: 1px solid var(--line); border-radius: 12px;
}
.woocommerce .cart_totals table.shop_table { border: 0; border-radius: 0; }
.woocommerce .cart_totals, .woocommerce-checkout #order_review { padding: 0; }
.woocommerce .cart_totals table tr th { background: transparent; }
.woocommerce ul#shipping_method li { margin: 6px 0; }
.woocommerce .order-total .amount, .woocommerce .cart-subtotal .amount { font-family: var(--font-display); }
.woocommerce-checkout #payment { background: #faf7f7; border-radius: 12px; }
.woocommerce-checkout #payment ul.payment_methods { border-bottom: 1px solid var(--line); }
.woocommerce-info, .woocommerce-message { border-radius: 10px; }
.woocommerce-message { border-left: 4px solid var(--brand); }

/* cross-sells / „Zobacz inne…” — używają kart .pc (content-product.php) */
.woocommerce .cross-sells ul.products, .woocommerce .cross-sells { margin-top: 8px; }

/* konto */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 4px; }
.woocommerce-account .woocommerce-MyAccount-navigation a { display: block; padding: 12px 16px; border: 1px solid var(--line); border-radius: 8px; color: var(--ink); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--brand); color: #fff; border-color: var(--brand); }

/* =====================================================================
   KOSZYK / CHECKOUT — zwarty układ 2-kolumnowy (v1.3)
   Produkty + podsumowanie obok siebie (widoczne razem), cross-selle
   kompaktowo na dole. Bez nadpisywania szablonów — sam CSS, więc
   wszystkie hooki pluginów (punkty, pasek darmowej dostawy) działają.
   ===================================================================== */

/* ---------- KOSZYK ---------- */
.woocommerce-cart .pz-wc-wrap > .woocommerce {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 8px 40px;
  align-items: start;
}
/* domyślnie wszystko w lewej kolumnie; podsumowanie = prawy sticky słupek */
.woocommerce-cart .pz-wc-wrap > .woocommerce > * { grid-column: 1; min-width: 0; }
.woocommerce-cart .pz-wc-wrap > .woocommerce > form.woocommerce-cart-form { grid-column: 1; margin-bottom: 0; }
.woocommerce-cart .pz-wc-wrap > .woocommerce > .cart-collaterals { display: contents; }
.woocommerce-cart .cart-collaterals > .cart_totals {
  grid-column: 2; grid-row: 1 / span 20; width: 100%; float: none; margin: 0;
  position: static; top: 96px; align-self: start;
}
/* cross-selle na PEŁNĄ szerokość, w wierszu pod koszykiem i podsumowaniem */
.woocommerce-cart .cart-collaterals > .cross-sells { grid-column: 1 / -1; grid-row: 21; width: 100%; float: none; margin: 32px 0 0; }

/* podsumowanie — wygląd boxu */
.woocommerce-cart .cart_totals { border: 1px solid var(--line); border-radius: 12px; padding: 6px 22px 22px; background: var(--surface); }
.woocommerce-cart .cart_totals > h2 { padding-top: 18px; }
.woocommerce-cart .cart_totals table.shop_table { border: 0; }
.woocommerce-cart .cart_totals table.shop_table th,
.woocommerce-cart .cart_totals table.shop_table td { padding: 12px 0; }
.woocommerce-cart .wc-proceed-to-checkout { padding-top: 8px; }

/* cross-selle / „Zobacz inne…” — kompaktowy rząd małych kart */
.woocommerce-cart .cross-sells > h2,
.woocommerce-cart [class*="cross-sell"] > h2 { font-family: var(--font-display); font-weight: 500; font-size: 22px; margin: 0 0 16px; }
.woocommerce-cart .cross-sells ul.products,
.woocommerce-cart .cross-sells .products,
.woocommerce-cart [class*="cross-sell"] ul.products,
.woocommerce-cart [class*="cross-sell"] .products {
  display: grid !important; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important; gap: 20px !important; float: none !important; width: 100% !important; margin: 0 !important;
}
/* WooCommerce dokleja do ul.products clearfix ::before/::after (content:" "; display:table) —
   w gridzie zajmują komórki (pierwszą!), przez co wyglądało jakby z przodu brakowało kafelka. */
.woocommerce-cart .cross-sells ul.products::before,
.woocommerce-cart .cross-sells ul.products::after,
.woocommerce-cart .cross-sells .products::before,
.woocommerce-cart .cross-sells .products::after,
.woocommerce-cart [class*="cross-sell"] ul.products::before,
.woocommerce-cart [class*="cross-sell"] ul.products::after,
.woocommerce-cart [class*="cross-sell"] .products::before,
.woocommerce-cart [class*="cross-sell"] .products::after { content: none !important; display: none !important; }
.woocommerce-cart .cross-sells .pc.tile .pc-img,
.woocommerce-cart [class*="cross-sell"] .pc.tile .pc-img { aspect-ratio: 1 / 1; }
.woocommerce-cart .cross-sells li.product, .woocommerce-cart [class*="cross-sell"] li.product { width: 100% !important; margin: 0 !important; float: none !important; }
/* zabezpieczenie: stopka karty może zawinąć, przycisk nigdy nie wychodzi poza kartę */
.woocommerce-cart .cross-sells .pc-foot, .woocommerce-cart [class*="cross-sell"] .pc-foot { flex-wrap: wrap; gap: 8px 10px; }
.woocommerce-cart .cross-sells .pc-cta, .woocommerce-cart [class*="cross-sell"] .pc-cta { white-space: nowrap; }

/* ---------- CHECKOUT ---------- */
.woocommerce-checkout .pz-wc-wrap form.checkout.woocommerce-checkout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 400px;
  gap: 12px 40px;
  align-items: start;
}
.woocommerce-checkout .pz-wc-wrap form.checkout > * { grid-column: 1 / -1; min-width: 0; }
.woocommerce-checkout .pz-wc-wrap form.checkout.woocommerce-checkout > #customer_details { grid-column: 1; }
.woocommerce-checkout .pz-wc-wrap form.checkout.woocommerce-checkout > .pz-checkout-side { grid-column: 2; position: static; top: 96px; align-self: start; }
.woocommerce-checkout .pz-checkout-side #order_review_heading { margin-top: 0; }
.woocommerce-checkout #order_review {
  border: 1px solid var(--line); border-radius: 12px; padding: 18px; background: var(--surface);
}
/* billing i shipping jeden pod drugim w lewej kolumnie (#customer_details == .col2-set) */
.woocommerce-checkout #customer_details.col2-set > .col-1,
.woocommerce-checkout #customer_details.col2-set > .col-2 { float: none; width: 100%; padding: 0; margin: 0 0 8px; }
.woocommerce-checkout #order_review .shop_table { border: 0; }
.woocommerce-checkout #payment { margin-top: 12px; }
.woocommerce-checkout #payment div.payment_box { background: #f7f3f3; }
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: #f7f3f3; }
.woocommerce-checkout #payment ul.payment_methods input[type="radio"]:checked + label { color: var(--brand); }

/* ---------- responsywnie: zwija się do 1 kolumny ---------- */
@media (max-width: 980px) {
  .woocommerce-cart .pz-wc-wrap > .woocommerce,
  .woocommerce-checkout .pz-wc-wrap form.checkout.woocommerce-checkout { grid-template-columns: 1fr; }
  .woocommerce-cart .cart-collaterals > .cart_totals,
  .woocommerce-checkout #order_review { position: static; grid-column: 1 / -1; }
  .woocommerce-checkout #order_review_heading { grid-column: 1 / -1; }
  /* reset jawnego przypisania kolumn — inaczej .pz-checkout-side (grid-column:2)
     wymusza dodatkową kolumnę i checkout zostaje 2-kolumnowy na mobilce */
  .woocommerce-checkout .pz-wc-wrap form.checkout.woocommerce-checkout > #customer_details,
  .woocommerce-checkout .pz-wc-wrap form.checkout.woocommerce-checkout > .pz-checkout-side { grid-column: 1 / -1; }
  .woocommerce-cart .cross-sells ul.products,
  .woocommerce-cart [class*="cross-sell"] .products { grid-template-columns: repeat(2, 1fr) !important; }
}

/* =====================================================================
   POPRAWKI v1.4
   ===================================================================== */

/* #1 — usuń artefakt ikony WooCommerce na powiadomieniach (info/message/error) */
.woocommerce-info::before, .woocommerce-message::before, .woocommerce-error::before, .woocommerce-noreviews::before,
.woocommerce-info::after, .woocommerce-message::after, .woocommerce-error::after, .woocommerce-noreviews::after {
  content: none !important; display: none !important;
}
.woocommerce-info, .woocommerce-message, .woocommerce-error, .woocommerce-noreviews {
  padding: 14px 18px !important; position: relative; min-height: 0 !important;
}

/* #3 — kafelki kategorii: czyste ramki tekstowe (bez zdjęć) */
.cathub .cat-tile--text {
  height: auto; min-height: 200px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 8px;
  padding: 26px 24px; display: flex; flex-direction: column; overflow: visible;
}
.cathub .cat-tile--text::before {
  content: ""; position: absolute; left: 0; top: 0; height: 3px; width: 0;
  background: var(--brand); border-radius: 8px 8px 0 0; transition: width .25s ease;
}
.cathub .cat-tile--text:hover::before { width: 100%; }
.cathub .cat-tile--text .cat-num {
  position: static; font-family: var(--font-display); font-style: italic; font-size: 34px;
  line-height: 1; color: var(--brand); margin-bottom: 16px; text-shadow: none;
}
.cathub .cat-tile--text .cat-body { padding: 0; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.cathub .cat-tile--text .cat-label { font-size: 23px; }
.cathub .cat-tile--text .cat-sub { color: var(--ink-soft); }
.cathub .cat-tile--text .cat-foot { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--line); }

/* #4 — siatka bestsellerów: ukrywanie kart przy filtrowaniu */
.best-grid .pz-best-item { display: flex; }
.best-grid .pz-best-item > .pc.tile { flex: 1 1 auto; width: 100%; }
.best-grid .pz-best-item.is-hidden { display: none; }
.best-filters .chip { cursor: pointer; }

/* FILTRY SKLEPU — funkcjonalne (checkboxy, suwak, akcje) */
.pz-filters-form .pz-fcheck { position: absolute; opacity: 0; width: 1px; height: 1px; pointer-events: none; }
.pz-filters-form label.filter-row { user-select: none; }
.pz-filters-form .pz-fcheck:checked + .fbox { background: var(--brand); border-color: var(--brand); }
.pz-filters-form .pz-fcheck:checked + .fbox svg { opacity: 1; }
.pz-filters-form .pz-fcheck:focus-visible + .fbox { outline: 2px solid var(--brand); outline-offset: 2px; }
.price-range-thumb { cursor: grab; padding: 0; z-index: 2; }
.price-range-thumb:active { cursor: grabbing; }
.price-range-track { cursor: pointer; }
.filter-actions { display: flex; gap: 14px; align-items: center; padding-top: 20px; }
.pz-filter-apply { background: var(--brand); color: #fff; border-radius: 6px; padding: 11px 22px; font-weight: 600; font-size: 13px; letter-spacing: .3px; transition: filter .15s; }
.pz-filter-apply:hover { filter: brightness(1.08); }
.pz-filter-clear { font-size: 13px; color: var(--ink-soft); text-decoration: underline; text-underline-offset: 3px; }
.pz-filter-clear:hover { color: var(--brand); }
.pz-ordering { margin: 0; }

/* strony informacyjne (nie wpisy bloga) — szerszy kontener treści */
.pz-page .pz-page-head { padding: 40px 0 16px; }
.pz-page .entry-content { max-width: none; }
.pz-page .entry-content > p,
.pz-page .entry-content > ul,
.pz-page .entry-content > ol,
.pz-page .entry-content > blockquote { max-width: 960px; }      /* sama proza w czytelnej szerokości… */
.pz-page .entry-content > .wp-block-columns,
.pz-page .entry-content > .wp-block-image,
.pz-page .entry-content > figure,
.pz-page .entry-content > .wp-block-gallery,
.pz-page .entry-content > table,
.pz-page .entry-content > h2,
.pz-page .entry-content > h3 { max-width: none; }                /* …a bloki/obrazy/tabele na pełną szerokość */
.pz-page .entry-content .wp-block-columns { display: flex; gap: 32px; flex-wrap: wrap; }
.pz-page .entry-content .wp-block-column { flex: 1 1 240px; }
.pz-page .entry-content img { border-radius: 8px; height: auto; }
@media (max-width: 720px) { .pz-page .entry-content .wp-block-column { flex-basis: 100%; } }

/* =====================================================================
   POPRAWKI v1.5 — strona „Moje konto" (przyciski + nawigacja)
   Layout konta jest natywny WooCommerce (floaty) — tu tylko kosmetyka CSS,
   bez nadpisywania szablonów, więc endpointy pluginów działają dalej.
   ===================================================================== */

/* Powiadomienia z przyciskiem (np. „Żadne zamówienia nie zostały złożone")
   — zamiast domyślnego float:right Woo używamy flexa: przycisk wyrównany
   w pionie do środka i NIGDY nie wychodzi poza zaokrągloną ramkę. */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error,
.woocommerce-account .woocommerce-noreviews {
  display: flex; align-items: center; gap: 12px 18px; flex-wrap: wrap;
}
.woocommerce-account .woocommerce-message > .button,
.woocommerce-account .woocommerce-message > a.button,
.woocommerce-account .woocommerce-info > .button,
.woocommerce-account .woocommerce-info > a.button,
.woocommerce-account .woocommerce-error > .button,
.woocommerce-account .woocommerce-error > a.button {
  float: none !important;
  margin: 0 0 0 auto !important;     /* dosuń do prawej, ale w obrębie paddingu */
  flex: 0 0 auto;
  white-space: nowrap;
  box-sizing: border-box; max-width: 100%;
}

/* Wszystkie przyciski w treści konta — równe paddingi, wyśrodkowany tekst,
   border-box i max-width żeby nic nie wyjeżdżało poza krawędź kolumny. */
.woocommerce-account .woocommerce-MyAccount-content .button,
.woocommerce-account .woocommerce-MyAccount-content button.button,
.woocommerce-account .woocommerce-MyAccount-content input.button,
.woocommerce-account .woocommerce-MyAccount-content a.button {
  box-sizing: border-box; max-width: 100%;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 13px 22px; line-height: 1.2; text-align: center;
}

/* Pełnoszerokie przyciski formularzy konta (logowanie, zapis adresu, hasło)
   — minimalna szerokość żeby nie były „malutkie", wyśrodkowane. */
.woocommerce-account .woocommerce-MyAccount-content form .button,
.woocommerce-account .woocommerce-MyAccount-content form button[type="submit"] {
  min-width: 180px;
}

/* Nawigacja konta — równe, spójne paddingi i wyrównanie w pionie. */
.woocommerce-account .woocommerce-MyAccount-navigation a {
  padding: 13px 18px; line-height: 1.3;
  display: flex; align-items: center;
  transition: background .15s, color .15s, border-color .15s;
}
.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
  border-color: var(--brand); color: var(--brand);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a:hover {
  color: #fff;
}

/* Na wąskich ekranach kolumny konta jedna pod drugą + przycisk powiadomienia
   na pełną szerokość (nigdy nie wystaje poza ekran). */
@media (max-width: 720px) {
  .woocommerce-account .woocommerce-MyAccount-navigation,
  .woocommerce-account .woocommerce-MyAccount-content {
    float: none; width: 100%;
  }
  .woocommerce-account .woocommerce-MyAccount-navigation { margin-bottom: 24px; }
  .woocommerce-account .woocommerce-message > .button,
  .woocommerce-account .woocommerce-message > a.button,
  .woocommerce-account .woocommerce-info > .button,
  .woocommerce-account .woocommerce-info > a.button {
    margin: 4px 0 0 0 !important; width: 100%;
  }
}

/* sekcja treści / SEO na homepage */
.pz-seo { padding: 40px 0 90px; }
.pz-seo-lead { font-family: var(--font-display); font-size: clamp(19px, 2.2vw, 24px); line-height: 1.5; letter-spacing: -.01em; max-width: 920px; margin: 0 0 40px; color: var(--ink); }
.pz-seo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
.pz-seo-col h3 { font-family: var(--font-display); font-size: 24px; font-weight: 500; letter-spacing: -.01em; margin: 0 0 14px; color: var(--ink); }
.pz-seo-col p { font-size: 15px; line-height: 1.75; margin: 0 0 16px; color: var(--ink-soft); }
.pz-seo-series { display: flex; flex-wrap: wrap; gap: 8px; margin: 18px 0 24px; }
.pz-serie { padding: 6px 14px; border: 1px solid var(--line); border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: 1.5px; color: var(--brand); }
@media (max-width: 860px) { .pz-seo-grid { grid-template-columns: 1fr; gap: 32px; } }

/* =====================================================================
   ABOUT — „O firmie" (page-o-firmie.php)
   ===================================================================== */
/* Kremowa sekcja styka się bezpośrednio ze stopką — bez białej szpary (margin-top .foot). */
.pz-page-about .foot { margin-top: 0; }
.pz-about {
  --pz-gold: #bb8a48;
  --pz-gold-deep: #a37e4d;
  --pz-cream: #fdf9f4;
  display: grid;
  grid-template-columns: 0.92fr 1fr;
  align-items: stretch;
  min-height: 620px;
  background: var(--pz-cream);
}
.pz-about-art {
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.pz-about-col {
  display: flex;
  align-items: center;
  background: transparent;
  padding: 56px clamp(28px, 5vw, 76px);
}
.pz-about-inner { width: 100%; max-width: 560px; }
.pz-about-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -.02em;
  margin: 0 0 22px;
  color: var(--ink);
}
.pz-about-lead {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(20px, 2.15vw, 25px);
  line-height: 1.45;
  letter-spacing: -.005em;
  color: var(--pz-gold-deep);
  margin: 0 0 26px;
}
.pz-about-rule {
  display: block;
  width: 72px;
  height: 1px;
  background: #e7ddcd;
  margin: 0 0 26px;
}
.pz-about-text {
  font-family: var(--font-body);
  font-size: 15.5px;
  line-height: 1.8;
  color: var(--ink-soft);
  margin: 0 0 42px;
}
.pz-about-stats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.pz-about-stat {
  position: relative;
  text-align: center;
  padding: 0 10px;
}
.pz-about-stat + .pz-about-stat::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 1px;
  background: var(--line);
}
.pz-about-ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  margin-bottom: 16px;
  border-radius: 999px;
  background: #f4ece1;
  color: var(--pz-gold);
}
.pz-about-ic .pz-ic { display: block; }
.pz-about-stat b {
  display: block;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(21px, 2.3vw, 26px);
  line-height: 1.1;
  margin-bottom: 5px;
  color: var(--pz-gold);
}
.pz-about-sub {
  display: block;
  font-family: var(--font-body);
  font-size: 13.5px;
  color: var(--ink-soft);
}
@media (max-width: 900px) {
  .pz-about { grid-template-columns: 1fr; min-height: 0; }
  .pz-about-art { min-height: 340px; background-position: center center; }
  .pz-about-col { justify-content: center; padding: 44px clamp(20px, 6vw, 44px) 56px; }
  .pz-about-inner { max-width: 620px; }
}
@media (max-width: 480px) {
  .pz-about-ic { width: 56px; height: 56px; }
  .pz-about-stat { padding: 0 6px; }
}

/* =====================================================================
   DOSTAWA — „Czas i koszty dostawy" (page-czas-i-koszty-dostawy.php)
   ===================================================================== */
.pz-ship { padding: 56px 0 80px; }
.pz-ship-head { text-align: center; max-width: 720px; margin: 0 auto 8px; }
.pz-ship-title { font-family: var(--font-display); font-weight: 500; font-size: clamp(34px, 5vw, 54px); letter-spacing: -.02em; line-height: 1.05; margin: 0; color: var(--ink); }
.pz-ship-horse { display: block; height: 40px; width: auto; margin: 14px auto 18px; }
.pz-ship-intro { font-size: 16px; line-height: 1.7; color: var(--ink-soft); margin: 0 auto; max-width: 580px; }

.pz-ship-rows { margin-top: 36px; }
.pz-ship-row { display: grid; grid-template-columns: 64px minmax(0, 1fr) 300px; align-items: start; gap: 28px; padding: 36px 0; border-top: 1px solid var(--line); }
.pz-ship-row:first-child { border-top: 0; }
.pz-ship-ic { color: var(--brand); display: flex; justify-content: center; padding-top: 2px; }
.pz-ship-ic .pz-ic { width: 40px; height: 40px; }

.pz-ship-text h2 { font-family: var(--font-body); font-weight: 700; font-size: 19px; letter-spacing: -.01em; margin: 0 0 16px; padding-bottom: 12px; color: var(--ink); position: relative; }
.pz-ship-text h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 34px; height: 2px; background: var(--brand); }
.pz-ship-text p { font-size: 15px; line-height: 1.75; color: var(--ink-soft); margin: 0 0 12px; }
.pz-ship-text p:last-child { margin-bottom: 0; }
.pz-ship-hl { color: var(--brand); font-weight: 700; }

.pz-ship-card { display: flex; align-items: center; gap: 16px; padding: 22px 24px; background: #f5f4f1; border: 1px solid #ececea; border-radius: 12px; }
.pz-ship-card > p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--ink-soft); }
.pz-ship-card-ic { flex: none; color: var(--brand); display: inline-flex; }
.pz-ship-card-ic .pz-ic { width: 34px; height: 34px; }
.pz-ship-card-sub { display: block; font-size: 13px; color: var(--ink-soft); margin-bottom: 4px; }
.pz-ship-card-big { display: block; font-family: var(--font-display); font-weight: 600; font-size: 20px; letter-spacing: -.01em; color: var(--brand); line-height: 1.1; }

/* odtworzone logo „InPost out of the box" (słoneczko + tekst) */
.pz-inpost-logo { display: inline-flex; align-items: center; gap: 9px; flex: none; }
.pz-inpost-sun { width: 36px; height: 36px; flex: none; }
.pz-inpost-word { display: flex; flex-direction: column; line-height: 1; font-family: var(--font-body); font-weight: 800; font-size: 22px; letter-spacing: -.02em; color: #2b2b2b; }
.pz-inpost-word small { font-weight: 500; font-size: 8px; letter-spacing: .14em; text-transform: lowercase; color: #7a7a7a; margin-top: 4px; }

.pz-ship-banner { display: block; margin: 44px auto 0; border-radius: 12px; overflow: hidden; max-width: 920px; }
.pz-ship-banner img { display: block; width: 100%; height: auto; }

@media (max-width: 880px) {
  .pz-ship-row { grid-template-columns: 48px 1fr; gap: 18px 16px; }
  .pz-ship-card { grid-column: 1 / -1; }
  .pz-ship-ic .pz-ic { width: 34px; height: 34px; }
}
@media (max-width: 520px) {
  .pz-ship-row { grid-template-columns: 1fr; }
  .pz-ship-ic { justify-content: flex-start; }
}



/* =====================================================================
   DIETA DLA KONI — kreator ankiety (page-ankieta.php), layout 1:1 z designu
   ===================================================================== */
.pz-diet { background: #faf7f0; padding: 48px 0 64px; }
.pz-diet .container { max-width: 1400px; }
.pz-diet h1, .pz-diet h2, .pz-diet h3 { font-family: var(--font-display); font-weight: 500; }

/* ---- HERO ---- */
.pz-diet-hero { display: grid; grid-template-columns: 1fr 1.18fr; gap: 56px; align-items: center; padding: 8px 0 48px; }
.pz-dh-title { font-size: 58px; line-height: 1.02; letter-spacing: -.01em; margin: 0; color: var(--ink); }
.pz-dh-rule { display: flex; align-items: center; gap: 14px; margin: 18px 0 22px; }
.pz-dh-rule span { width: 96px; height: 1px; background: #cbb89a; }
.pz-dh-rule img { width: 40px; height: 40px; object-fit: contain; }
.pz-dh-lead { font-size: 17px; line-height: 1.7; color: #5a5248; max-width: 460px; margin: 0 0 26px; }
.pz-dh-usp { list-style: none; margin: 0 0 30px; padding: 0; display: flex; gap: 28px; flex-wrap: wrap; }
.pz-dh-usp li { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 500; color: var(--ink); max-width: 150px; line-height: 1.3; }
.pz-dh-usp-ic { width: 40px; height: 40px; flex: none; border-radius: 999px; background: #fff; border: 1px solid #ece3d2; color: var(--brand); display: grid; place-items: center; }
.pz-dh-safe { display: flex; align-items: center; gap: 8px; margin: 16px 0 0; font-size: 13px; color: #8a8073; }
.pz-dh-safe .pz-ic { color: #b09a76; }

.pz-dh-right { background: #fff; border-radius: 18px; box-shadow: 0 24px 60px -28px rgba(40,30,20,.4); overflow: hidden; }
.pz-dh-video { display: block; width: 100%; position: relative; aspect-ratio: 16 / 9; background: #1d1a17 center/cover no-repeat; border: 0; padding: 0; cursor: pointer; font: inherit; color: inherit; }
.pz-dh-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.pz-dh-video.is-playing .pz-dh-play { display: none; }
.pz-dh-play { position: absolute; inset: 0; margin: auto; width: 72px; height: 72px; border-radius: 999px; background: #fff; color: var(--brand); display: grid; place-items: center; box-shadow: 0 10px 30px -8px rgba(0,0,0,.5); transition: transform .15s; }
.pz-dh-video:hover .pz-dh-play { transform: scale(1.06); }
.pz-dh-spec { padding: 18px 28px 22px; position: relative; text-align: right; }
.pz-dh-spec-k { display: block; font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: #9a9082; margin-bottom: 4px; }
.pz-dh-spec-n { display: block; font-family: var(--font-display); font-size: 22px; color: var(--ink); }
.pz-dh-spec-r { display: block; font-size: 13px; color: #6f6658; margin-top: 2px; }
.pz-dh-sign { display: inline-block; font-family: var(--font-display); font-style: italic; font-size: 32px; line-height: 1; color: #bb8a48; transform: rotate(-4deg); }

/* ---- MAIN ---- */
.pz-diet-main { display: grid; grid-template-columns: 1fr 320px; gap: 28px; align-items: start; }
.pz-diet-card { background: #fff; border: 1px solid #efe7d8; border-radius: 16px; padding: 34px 36px; box-shadow: 0 18px 50px -34px rgba(40,30,20,.45); }

.pz-df-head { display: flex; justify-content: space-between; align-items: baseline; font-size: 14px; color: #6f6658; }
.pz-df-stepno b { color: var(--ink); font-weight: 700; }
.pz-df-pct { font-weight: 600; color: var(--brand); }
.pz-df-bar { height: 5px; border-radius: 999px; background: #eee5d6; margin: 12px 0 26px; overflow: hidden; }
.pz-df-bar-fill { display: block; height: 100%; background: var(--brand); border-radius: 999px; transition: width .3s ease; }

.pz-df-steps { list-style: none; margin: 0 0 30px; padding: 0; display: flex; justify-content: space-between; position: relative; }
.pz-df-steps::before { content: ""; position: absolute; top: 16px; left: 7%; right: 7%; height: 2px; background: #ece3d2; z-index: 0; }
.pz-df-stepi { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; flex: 1; text-align: center; }
.pz-df-stepi .n { width: 32px; height: 32px; border-radius: 999px; background: #fff; border: 2px solid #e1d7c4; color: #a8907a; display: grid; place-items: center; font-size: 14px; font-weight: 600; }
.pz-df-stepi .l { font-size: 12px; color: #8a8073; }
.pz-df-stepi.is-done .n { background: #efe7d8; border-color: #efe7d8; color: var(--ink); }
.pz-df-stepi.is-on .n { background: var(--brand); border-color: var(--brand); color: #fff; }
.pz-df-stepi.is-on .l { color: var(--ink); font-weight: 600; }

.pz-df-panel { display: none; }
.pz-df-panel.is-on { display: block; }
.pz-df-h { display: flex; align-items: center; gap: 10px; font-size: 22px; color: var(--ink); margin: 6px 0 4px; }
.pz-df-h .pz-ic { color: var(--brand); }
.pz-df-horse { object-fit: contain; }
.pz-df-sub { font-size: 13px; color: #8a8073; margin: 0 0 20px; }

.pz-df-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px; }
.pz-df-field { display: flex; flex-direction: column; gap: 7px; }
.pz-df-field--full { grid-column: 1 / -1; margin-top: 16px; }
.pz-df-field > span { font-size: 13px; font-weight: 600; color: var(--ink); }
.pz-df-field i { color: var(--brand); font-style: normal; }
.pz-df-field input, .pz-df-field select, .pz-df-field textarea, .pz-df-tel input {
  width: 100%; border: 1px solid #e3dac9; border-radius: 9px; padding: 12px 14px; font-family: var(--font-body); font-size: 14px; color: var(--ink); background: #fdfbf7; transition: border-color .15s, box-shadow .15s;
}
.pz-df-field input::placeholder, .pz-df-field textarea::placeholder { color: #b3a791; }
.pz-df-field input:focus, .pz-df-field select:focus, .pz-df-field textarea:focus, .pz-df-tel input:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(184,29,43,.12); }
.pz-df-select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a7160' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.pz-df-tel { display: flex; gap: 8px; }
.pz-df-tel-pre { display: flex; align-items: center; gap: 4px; padding: 0 12px; border: 1px solid #e3dac9; border-radius: 9px; background: #fdfbf7; font-size: 14px; color: var(--ink); white-space: nowrap; }
.pz-df-date { display: grid; grid-template-columns: 1fr 1fr 1.2fr auto; gap: 8px; align-items: center; }
.pz-df-date-ic { color: #a8907a; display: grid; place-items: center; }

.pz-df-upload { margin-top: 22px; }
.pz-df-upload-h { display: block; font-size: 13px; font-weight: 600; color: var(--ink); }
.pz-df-upload-sub { display: block; font-size: 12px; color: #8a8073; margin: 2px 0 10px; }
.pz-df-drop { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 30px; border: 1.5px dashed #d8ccb6; border-radius: 12px; background: #fdfbf7; color: #a8907a; text-align: center; cursor: pointer; transition: border-color .15s, background .15s; }
.pz-df-drop:hover, .pz-df-drop.is-drag { border-color: var(--brand); background: #fbf6ef; }
.pz-df-drop .pz-ic { color: var(--brand); }
.pz-df-drop-t { font-size: 13px; color: #6f6658; font-weight: 500; }
.pz-df-drop-s { font-size: 12px; color: #a8907a; }
.pz-df-drop.has-file .pz-df-drop-t { color: var(--brand); font-weight: 600; }

.pz-df-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 20px; }
.pz-df-check, .pz-df-consent { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: 14px; color: var(--ink); }
.pz-df-consent { margin-top: 20px; font-size: 13px; color: #6f6658; align-items: flex-start; }
.pz-df-check input, .pz-df-consent input { position: absolute; opacity: 0; width: 0; height: 0; }
.pz-df-box { width: 20px; height: 20px; flex: none; border: 1px solid #d8ccb6; border-radius: 5px; background: #fff; display: grid; place-items: center; }
.pz-df-box .pz-ic { opacity: 0; color: #fff; }
.pz-df-check input:checked + .pz-df-box, .pz-df-consent input:checked + .pz-df-box { background: var(--brand); border-color: var(--brand); }
.pz-df-check input:checked + .pz-df-box .pz-ic, .pz-df-consent input:checked + .pz-df-box .pz-ic { opacity: 1; }
.pz-df-check input:focus-visible + .pz-df-box, .pz-df-consent input:focus-visible + .pz-df-box { outline: 2px solid var(--brand); outline-offset: 2px; }

.pz-df-foot { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-top: 30px; padding-top: 24px; border-top: 1px solid #efe7d8; flex-wrap: wrap; }
.pz-df-save { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: #6f6658; }
.pz-df-save:hover { color: var(--brand); }
.pz-df-nav { display: flex; gap: 10px; }
.pz-df-prev { display: inline-flex; align-items: center; gap: 8px; padding: 13px 22px; border: 1px solid #e3dac9; border-radius: 10px; font-weight: 500; color: var(--ink); background: #fff; }
.pz-df-prev:hover { border-color: var(--brand); color: var(--brand); }
.pz-df-next, .pz-df-submit { display: inline-flex; align-items: center; gap: 10px; padding: 14px 30px; border-radius: 10px; background: var(--brand); color: var(--brand-ink); font-weight: 600; font-size: 15px; }
.pz-df-next:hover, .pz-df-submit:hover { background: var(--accent2); }
.pz-df-prev[hidden], .pz-df-next[hidden], .pz-df-submit[hidden] { display: none; }

.pz-df-done { text-align: center; padding: 40px 10px; }
.pz-df-done .pz-ic { color: #fff; background: var(--brand); border-radius: 999px; padding: 10px; box-sizing: content-box; width: 30px; height: 30px; }
.pz-df-done h3 { font-size: 24px; color: var(--ink); margin: 18px 0 6px; }
.pz-df-done p { font-size: 14px; color: #6f6658; margin: 0; }

/* ---- SIDEBAR ---- */
.pz-diet-side { display: flex; flex-direction: column; gap: 18px; }
.pz-ds-card { background: #fff; border: 1px solid #efe7d8; border-radius: 14px; padding: 22px 22px; }
.pz-ds-h { display: flex; align-items: center; gap: 9px; font-size: 18px; color: var(--ink); margin: 0 0 16px; }
.pz-ds-h .pz-ic { color: var(--brand); }
.pz-ds-how { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.pz-ds-how li { display: flex; gap: 12px; }
.pz-ds-how .n { width: 26px; height: 26px; flex: none; border-radius: 999px; background: #f3ecdd; color: var(--brand); font-size: 13px; font-weight: 700; display: grid; place-items: center; }
.pz-ds-how b { display: block; font-size: 14px; color: var(--ink); }
.pz-ds-how span { display: block; font-size: 12.5px; color: #8a8073; line-height: 1.5; margin-top: 2px; }
.pz-ds-secure { background: #f6efe3; border-color: #ece0cc; text-align: left; }
.pz-ds-secure-ic { color: var(--brand); display: inline-grid; }
.pz-ds-secure b { display: block; font-size: 14px; color: var(--ink); margin: 8px 0 4px; }
.pz-ds-secure p { font-size: 12.5px; color: #6f6658; line-height: 1.55; margin: 0; }
.pz-ds-contact > b { display: block; font-family: var(--font-display); font-size: 18px; color: var(--ink); line-height: 1.3; margin-bottom: 14px; }
.pz-ds-contact ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.pz-ds-contact li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--ink); }
.pz-ds-contact .pz-ic { color: var(--brand); flex: none; }
.pz-ds-contact a:hover { color: var(--brand); }

/* ---- DOLNY PASEK ZAUFANIA ---- */
.pz-diet-trust { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px; padding: 24px 0; border-top: 1px solid #ece3d2; border-bottom: 1px solid #ece3d2; }
.pz-dt-item { display: flex; align-items: center; gap: 14px; justify-content: center; }
.pz-dt-item .pz-ic { color: var(--brand); flex: none; }
.pz-dt-item b { display: block; font-size: 14px; color: var(--ink); }
.pz-dt-item span { display: block; font-size: 12.5px; color: #8a8073; }
.pz-diet-ssl { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 20px 0 0; font-size: 12.5px; color: #8a8073; }
.pz-diet-ssl .pz-ic { color: #b09a76; }

/* ---- RESPONSYWNIE ---- */
@media (max-width: 1024px) {
  .pz-diet-main { grid-template-columns: 1fr; }
  .pz-diet-side { flex-direction: row; flex-wrap: wrap; }
  .pz-diet-side .pz-ds-card { flex: 1 1 260px; }
}
@media (max-width: 860px) {
  .pz-diet-hero { grid-template-columns: 1fr; gap: 32px; }
  .pz-dh-title { font-size: 44px; }
}
@media (max-width: 640px) {
  .pz-diet-card { padding: 24px 18px; }
  .pz-df-grid, .pz-df-checks { grid-template-columns: 1fr; }
  .pz-df-steps .l { display: none; }
  .pz-df-steps::before { left: 10%; right: 10%; }
  .pz-diet-trust { grid-template-columns: 1fr; gap: 14px; }
  .pz-dt-item { justify-content: flex-start; }
  .pz-df-foot { flex-direction: column-reverse; align-items: stretch; }
  .pz-df-nav { justify-content: space-between; }
}

/* Osadzony formularz WPForms na stronie „Dieta dla Koni" — dopasowanie do karty i palety. */
.pz-diet-formwrap .wpforms-container {
  margin: 0;
  --wpforms-button-background-color: var(--brand);
  --wpforms-button-background-color-alt: var(--accent2);
  --wpforms-button-text-color: #ffffff;
  --wpforms-field-border-radius: 9px;
  --wpforms-field-border-color: #e3dac9;
  --wpforms-field-background-color: #fdfbf7;
  --wpforms-label-color: var(--ink);
  --wpforms-page-break-color: var(--brand);
}
.pz-diet-formwrap .wpforms-form { font-family: var(--font-body); }
.pz-diet-formwrap .wpforms-field { padding: 0 0 16px; }
.pz-diet-formwrap .wpforms-field-label { font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 6px; }
.pz-diet-formwrap .wpforms-field-sublabel { color: #8a8073; font-weight: 400; }
.pz-diet-formwrap input[type="text"], .pz-diet-formwrap input[type="email"],
.pz-diet-formwrap input[type="tel"], .pz-diet-formwrap input[type="number"],
.pz-diet-formwrap input[type="url"], .pz-diet-formwrap input[type="date"],
.pz-diet-formwrap select, .pz-diet-formwrap textarea {
  width: 100%; border: 1px solid #e3dac9; border-radius: 9px; padding: 12px 14px;
  font-family: var(--font-body); font-size: 14px; color: var(--ink); background: #fdfbf7;
}
.pz-diet-formwrap input:focus, .pz-diet-formwrap select:focus, .pz-diet-formwrap textarea:focus {
  outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(184,29,43,.12);
}
.pz-diet-formwrap .wpforms-submit, .pz-diet-formwrap .wpforms-page-button {
  background: var(--brand) !important; border: 0 !important; color: #fff !important;
  border-radius: 10px !important; padding: 14px 30px !important; font-weight: 600 !important;
  font-size: 15px !important; font-family: var(--font-body) !important; cursor: pointer;
}
.pz-diet-formwrap .wpforms-submit:hover, .pz-diet-formwrap .wpforms-page-button:hover { background: var(--accent2) !important; }
.pz-diet-formwrap .wpforms-page-button.wpforms-page-prev { background: #fff !important; color: var(--ink) !important; border: 1px solid #e3dac9 !important; }
.pz-diet-formwrap .wpforms-confirmation-container-full {
  background: #f6efe3; border: 1px solid #ece0cc; border-radius: 12px; padding: 20px 22px; color: var(--ink);
}

/* Paginacja długiego formularza WPForms na stronie „Dieta dla Koni" (front-end wizard) */
.pz-wf-progress { margin: 0 0 26px; }
.pz-wf-bar { height: 6px; border-radius: 999px; background: #eee5d6; overflow: hidden; }
.pz-wf-bar span { display: block; height: 100%; width: 0; background: var(--brand); border-radius: 999px; transition: width .3s ease; }
.pz-wf-step { margin-top: 9px; font-size: 13px; font-weight: 600; color: #6f6658; }
.pz-wf-nav { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 22px 0 6px; }
.pz-wf-prev { padding: 13px 22px; border: 1px solid #e3dac9; border-radius: 10px; background: #fff; font-family: var(--font-body); font-weight: 500; font-size: 14px; color: var(--ink); cursor: pointer; }
.pz-wf-prev:hover { border-color: var(--brand); color: var(--brand); }
.pz-wf-next { margin-left: auto; padding: 14px 32px; border: 0; border-radius: 10px; background: var(--brand); color: #fff; font-family: var(--font-body); font-weight: 600; font-size: 15px; cursor: pointer; }
.pz-wf-next:hover { background: var(--accent2); }

/* =====================================================================
   POPRAWKI v1.10 — mobilka (frontend)
   ===================================================================== */

/* Homepage: większy oddech od krawędzi ekranu na mobilce.
   Domyślnie .container ma na telefonie tylko 20px (clamp min) — za ciasno.
   Ograniczone do body.home, żeby nie ruszać reszty sklepu.
   Slider hero jest full-bleed (.sm-slider-fullbleed) i pozostaje bez zmian. */
@media (max-width: 720px) {
  body.home .container { padding-left: 28px; padding-right: 28px; }
}
