@font-face {
  font-family: "Titular";
  src:
    url("../assets/fonts/Titular/Titular-Regular.woff2") format("woff2"),
    url("../assets/fonts/Titular/Titular-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Titular";
  src:
    url("../assets/fonts/Titular/Titular-Bold.woff2") format("woff2"),
    url("../assets/fonts/Titular/Titular-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Titular";
  src:
    url("../assets/fonts/Titular/Titular-Light.woff2") format("woff2"),
    url("../assets/fonts/Titular/Titular-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Titular";
  src:
    url("../assets/fonts/Titular/Titular-Heavy.woff2") format("woff2"),
    url("../assets/fonts/Titular/Titular-Heavy.woff") format("woff");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Titular";
  src:
    url("../assets/fonts/Titular/Titular-Black.woff2") format("woff2"),
    url("../assets/fonts/Titular/Titular-Black.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --green: #077d64;
  --orange: #f6a400;
  --navy: #060b1d;
  --font-body: "Poppins", system-ui, sans-serif;
  --font-display: "Titular", sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
body.chrapka-body { background: var(--green); color: #fff; font-family: var(--font-body); }
a { color: inherit; text-decoration: none; }

.site-main { min-height: 60vh; }
.container { width: min(1280px, 100% - 32px); margin: 0 auto; }
.container.narrow { width: min(1100px, 100% - 32px); }
.center { text-align: center; }
.display { font-family: var(--font-display); text-transform: uppercase; letter-spacing: .01em; }

.site-header { position: absolute; left: 0; right: 0; top: 0; z-index: 10000; }
.header-inner {
  width: min(1360px, 100% - 140px);
  margin: 0 auto;
  padding: 24px 40px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 32px;
}
.brand-logo { height: 46px; width: auto; }

@media (min-width: 330px) and (max-width: 440px) {
  .brand-logo {
    height: clamp(38px, calc(14px + 7.2727vw), 46px);
  }
}
.desktop-nav {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-self: end;
  gap: 40px;
  min-height: 32px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0;
  color: rgba(255,255,255,.92);
}
.kontakt-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
  border-radius: 999px;
  padding: 7px 26px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .28em;
  font-weight: 600;
}
.kontakt-btn-top { justify-self: end; }
.hamburger { display: none; }

.mobile-menu { position: fixed; inset: 0; z-index: 10010; pointer-events: none; opacity: 0; transition: opacity .25s ease; }
.mobile-menu.open { pointer-events: auto; opacity: 1; }
.mobile-menu::before { content: ""; position: absolute; inset: 0; background: rgba(0,0,0,.45); }
.mobile-panel { position: absolute; right: 0; top: 0; height: 100%; width: min(86vw, 420px); background: var(--green); padding: 24px; transform: translateX(100%); transition: transform .28s ease; }
.mobile-menu.open .mobile-panel { transform: translateX(0); }
.mobile-nav { margin-top: 16px; display: grid; gap: 12px; }
.mobile-nav a { border: 1px solid rgba(255,255,255,.35); border-radius: 18px; padding: 18px 20px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }

.hero-section { position: relative; z-index: 10; }
.hero-stage { position: relative; z-index: 200; height: clamp(560px, 54vw, 780px); overflow: hidden; --hero-shift: 80px; }
.hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center top; }
.hero-title-text {
  position: absolute;
  left: 50%;
  top: calc(110px + var(--hero-shift));
  width: min(984px, 78%);
  transform: translateX(-50%);
  z-index: 10;
  margin: 0;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
  line-height: .78;
  font-size: 128px;
  color: #fff;
}
.hero-sandwiches { position: absolute; left: 50%; bottom: calc(-9% - var(--hero-shift)); width: 100vw; max-width: none; transform: translateX(-50%); z-index: 300; }
.hero-sandwich-person { position: absolute; z-index: 400; height: auto; width: auto; pointer-events: none; }
.hero-sandwich-person-1,
.hero-sandwich-person-2 { left: 50%; width: auto; height: 210px; }
.hero-sandwich-person-1 { bottom: calc(130px - var(--hero-shift)); transform: translateX(-340px); }
.hero-sandwich-person-2 { bottom: calc(116px - var(--hero-shift)); transform: translateX(170px); }

.hero-orange {
  position: relative;
  z-index: 1;
  overflow: visible;
  background-color: #FF9D02;
  background-size: 1600px auto;
  background-position: center top;
  background-repeat: no-repeat;
  --hero-orange-pad-top: 80px;
  padding: var(--hero-orange-pad-top) 0 380px;
  margin-top: -1px;
}
.hero-orange-patterns { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.hero-orange-pattern { position: absolute; width: auto; height: auto; max-width: none; }
.hero-orange-pattern-1 { left: 0; top: 10px; }
.hero-orange-pattern-2 { left: calc(50% + 140px); top: 180px; transform: translateX(-50%); }
.hero-orange-pattern-3 { right: 0; bottom: 280px; }
.hero-orange-inner {
  position: relative;
  width: min(1840px, 100% - 16px);
  margin: 0 auto;
  padding: 0 0 32px;
  z-index: 2;
}
.hero-subtitle-text {
  display: block;
  width: min(980px, 92%);
  margin: calc(-1 * var(--hero-orange-pad-top)) auto 0;
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .02em;
  line-height: .95;
  font-size: 64px;
  color: #fff;
}
.hero-subtitle-text span {
  font-weight: 300;
}
.hero-subtitle-text span strong { font-weight: 800; }
.hero-copy {
  margin: 18px auto 0;
  width: min(520px, 90%);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 300;
  line-height: 1.45;
  color: #fff;
}
.hero-copy span { display: block; }
.hero-copy strong { font-weight: 700; }
.hero-illu { position: absolute; top: calc(-8px + var(--hero-shift)); z-index: 20; height: auto; }
.hero-illu-left { left: 6%; width: 303px; }
.hero-illu-right { right: 12%; width: 126px; top: calc(12px + var(--hero-shift)); }
.hero-chrapka-wrap { position: relative; z-index: 0; margin-top: -32px; margin-bottom: -160px; overflow: visible; }
.hero-chrapka-layer { position: relative; z-index: 0; display: block; width: 100vw; max-width: none; height: auto; object-fit: contain; margin-left: calc(50% - 50vw); transform: translateY(330px); }
.features-chrapka-wrap {
  position: absolute;
  left: 0;
  right: 0;
  top: -490px;
  pointer-events: none;
  margin: 0;
}
.features-chrapka-wrap .hero-chrapka-layer { transform: none; }

.features-section { position: relative; z-index: 300; margin-top: -160px; background: var(--green); padding: 200px 10px 0; overflow: visible; }
.features-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: center; z-index: 120; position: relative; margin-top: 100px; }
.feature-col { text-align: center; }
.feature-col:first-of-type { text-align: right; }
.feature-col:last-of-type { text-align: left; padding-left: 0; }
.feature-col:last-of-type article { margin-bottom: 70px; }
.feature-col article { margin-bottom: 60px; }
.feature-col h3 { font-family: var(--font-display); text-transform: uppercase; font-size: 38px; margin: 0; color: #EFF4E0; }
.feature-col p { margin: 6px 0 0; color: rgba(255,255,255,.85); font-size: 14px; line-height: 1.4; }
.feature-mid { z-index: 50; position: relative; display: flex; justify-content: center; }
.feature-mid .feature-sandwich { width: 100%; max-width: 720px; height: auto; display: block; margin: 0 auto; position: relative; z-index: 50; }
.feature-mid .feature-arrows { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; z-index: 9999; pointer-events: none; transform: translateY(-70px); }
.feature-mid .feature-arrow-extra { position: absolute; left: -20px; top: 410px; height: auto; z-index: 10000; pointer-events: none; }

.about-section { background: var(--green); padding: 0; }
.about-stage { position: relative; min-height: 760px; }
.about-section .container { width: calc(100% - 30px); max-width: none; }
.about-title { position: absolute; left: 56%; top: 102px; width: min(1081px, 96%); transform: translateX(-50%); z-index: 80; margin: 0; font-family: var(--font-display); font-size: clamp(42px, 8.5vw, 108px); line-height: .88; letter-spacing: .02em; text-align: left; text-transform: none; color: #F2EEE8; font-weight: 800; }
.about-title-line { display: block; }
.about-title-line-indent-2 { padding-left: 80px; }
.about-title-line-indent { padding-left: 140px; }
.about-lettuce { position: absolute; right: 0; top: -20px; width: 295px; height: 371px; object-fit: cover; border-radius: 18px; z-index: 10; }
.about-farmer { position: absolute; left: 0; top: 210px; width: 452px; height: 535px; object-fit: cover; object-position: top; border-radius: 18px; z-index: 20; }
.about-orange-box { position: absolute; left: 472px; right: 0; top: 385px; height: 202px; border-radius: 18px; z-index: 20; display: flex; align-items: center; padding: 24px 32px; overflow: hidden; }
.about-orange-box-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.about-orange-box-content { position: relative; z-index: 2; display: flex; align-items: center; justify-content: center; gap: 150px; width: 100%; }
.about-orange-box-text { margin: 0; font-family: var(--font-body); font-size: 14px; line-height: 1.45; font-weight: 400; color: #F2EEE8; max-width: 480px; }
.about-orange-box-text strong { font-weight: 700; }
.about-orange-box-text span { display: block; }
.about-orange-box-bus { width: 220px; height: auto; flex-shrink: 0; }

.categories-section { background: var(--green); padding: 28px 0 96px; }
.categories-badge { display: flex; align-items: center; justify-content: center; gap: 14px; margin-bottom: 34px; }
.categories-badge-round { height: 123px; width: auto; }
.categories-badge-title { margin: 0; font-family: var(--font-display); font-size: 44px; line-height: .9; text-transform: uppercase; letter-spacing: .02em; color: #EFF4E0; font-weight: 300; }
.categories-badge-title span { display: block; font-weight: 900; }
.home-cards-grid { display: grid; grid-template-columns: repeat(3, 296px); justify-content: center; gap: 24px 28px; }
.home-card { position: relative; border: none; border-radius: 0; overflow: visible; background: transparent; cursor: pointer; transition: transform .2s ease; }
.home-card:hover { transform: scale(1.05); }
.home-card img { width: 100%; display: block; }
.home-card-copy {
  position: absolute;
  left: 10%;
  right: 10%;
  top: 58%;
  color: #EFF4E0;
}
.home-card-copy h4 {
  margin: 0 0 18px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 50px;
  line-height: .88;
  text-transform: uppercase;
}
.home-card-copy p {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  line-height: 1.4;
}

.home-cta { position: relative; overflow: hidden; background: #f45a00; padding: 32px 0 40px; min-height: 340px; clip-path: polygon(0 20%, 100% 0, 100% 100%, 0 100%); }
.home-cta-pattern { position: absolute; inset: -20px; z-index: 10; opacity: .7; background-size: cover; background-position: center; background-repeat: no-repeat; }
.home-cta-inner { position: relative; z-index: 20; display: grid; grid-template-columns: 260px minmax(0, 520px); justify-content: center; align-items: center; gap: 32px; min-height: 340px; max-width: 920px; margin: 48px auto 0; transform: translateX(80px); }
.home-cta-illu { width: 280px; height: 240px; margin: 0; display: block; justify-self: start; margin-left: -60px; }
.home-cta-copy { text-align: left; }
.home-cta-copy .display { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: 50px; line-height: .9; text-transform: uppercase; color: #F2EEE8; }
.home-cta-copy p { margin: 16px 0 0; max-width: 38ch; color: #F2EEE8; font-family: var(--font-body); font-weight: 300; font-size: 14px; line-height: 1.45; }
.home-cta-btn { margin-top: 24px; display: inline-flex; width: 260px; justify-content: center; border: 1px solid #fff; border-radius: 999px; padding: 10px 20px; font-family: var(--font-body); font-weight: 700; font-size: 12px; letter-spacing: .3em; text-transform: uppercase; transition: background .2s ease, color .2s ease; }
.home-cta-btn:hover { background: #fff; color: #ef4600; }

.lista-page { background: var(--green); padding: 140px 0 80px; }
.zam-page { background: var(--green); padding: 180px 0 0; }
.zam-title { text-align: center; margin: 0 0 40px; }
.lista-title-wrap { position: relative; width: fit-content; margin: 0 auto 24px; }
.lista-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 128px;
  font-weight: 800;
  line-height: .85;
  letter-spacing: 0;
  text-transform: uppercase;
  text-align: center;
  max-width: min(900px, 92vw);
}
.lista-badge { position: absolute; right: -40px; top: 35%; width: 120px; }
.filters { display: flex; justify-content: center; gap: 12px; margin: 32px 0 44px; }
.filters button { border: 1px solid rgba(255,255,255,.6); background: transparent; color: #fff; padding: 12px 28px; border-radius: 999px; text-transform: uppercase; letter-spacing: .34em; font-size: 10px; font-family: var(--font-body); font-weight: 700; cursor: pointer; }
.filters button.active { background: #fff; color: var(--green); }
.cards-grid { display: grid; grid-template-columns: repeat(3, 360px); justify-content: center; gap: 18px; }
.product-card {
  position: relative;
  border: none;
  overflow: visible;
  cursor: auto;
  transition: box-shadow .25s ease;
  /* Defer heavy SVG rendering until the card is near the viewport. */
  content-visibility: auto;
  contain-intrinsic-size: 360px 520px;
}
.product-card:hover { box-shadow: 0 16px 30px rgba(0,0,0,.24); }
.product-card img { width: 100%; display: block; }
.product-card--cms {
  width: min(100%, 650px);
  aspect-ratio: 650 / 1018;
  container-type: inline-size;
  /* Base 650x1018 -> scaled percentages */
  --image-width: 135.38%; /* 880 / 650 */
  --image-left: 42%;
  --title-top: 60.02%; /* 611 / 1018 */
  --content-bottom: 5.5%;
}
.product-card--cms .product-card-ui {
  position: relative;
  height: 100%;
  min-height: 0;
  background: url('../assets/lista/card-base.svg') center/100% 100% no-repeat;
  overflow: hidden;
  isolation: isolate;
}
.product-card-badge {
  position: absolute;
  left: 18px;
  top: 16px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 7px 14px;
  border-radius: 999px;
  background: #F34A28;
  color: #fff;
  font-family: var(--font-body);
  font-size: 9px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.product-card--cms .product-card-media {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 64%;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.product-card--cms .product-card-media img {
  position: absolute;
  left: var(--image-left);
  transform: translateX(-47%);
  width: var(--image-width);
  max-width: none;
  height: auto;
  max-height: 122%;
  object-fit: contain;
  object-position: center center;
}
.product-card--cms .product-card-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  padding: 0;
  font-family: var(--font-body);
  font-size: 14px;
  letter-spacing: 0.01em;
}
.product-card--cms .product-card-title {
  position: absolute;
  left: 10%;
  right: 10%;
  top: var(--title-top);
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(28px, 10cqw, 38px);
  font-weight: 800;
  line-height: .9;
  text-transform: uppercase;
  color: #EFF4E0;
  max-width: 78%;
}
.product-card--cms .product-card-title-line-1,
.product-card--cms .product-card-title-line-2 {
  display: block;
}
.product-card--cms .product-card-details {
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: var(--content-bottom);
}
.product-card--cms .product-card-details p {
  margin: 0 0 6px;
  font-family: var(--font-body);
  font-size: clamp(12px, 4.2cqw, 14px);
  line-height: 1.4;
  color: #EFF4E0;
}
.product-card--cms .product-card-details p:last-child { margin-bottom: 0; }
.product-card-content p strong { font-weight: 700; }
.product-card--custom .product-card-title {
  max-width: 82%;
}
.product-card--custom .product-card-details p {
  margin-bottom: 0;
  font-size: clamp(11px, 3.8cqw, 13px);
  line-height: 1.34;
}
.product-card--custom .product-card-media {
  height: 63%;
}

@supports not (font-size: 1cqw) {
  .product-card--cms .product-card-title {
    font-size: clamp(28px, 5.6vw, 38px);
  }
  .product-card--cms .product-card-details p {
    font-size: clamp(12px, 2.5vw, 14px);
  }
}

.lista-page.has-reveal .product-card {
  opacity: 0;
  transform: translateY(14px) scale(.99);
  transition:
    opacity .5s ease,
    transform .6s cubic-bezier(.2,.9,.2,1),
    box-shadow .25s ease;
  will-change: opacity, transform;
}
.lista-page.has-reveal .product-card.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
  .lista-page.has-reveal .product-card,
  .lista-page.has-reveal .product-card.is-visible {
    transition: none;
    transform: none;
  }
}

.home-cards-grid.has-reveal .home-card,
.home-cards-grid.has-reveal .home-card.is-visible {
  opacity: 1;
  transition: transform .2s ease;
}

.home-cards-grid.has-reveal {
  touch-action: pan-x;
}

@media (prefers-reduced-motion: reduce) {
  .home-cards-grid.has-reveal .home-card,
  .home-cards-grid.has-reveal .home-card.is-visible {
    transition: none !important;
    transform: none !important;
  }
}
.product-card-btn {
  position: absolute;
  left: 50%;
  bottom: 25px;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border: 1px solid #fff;
  border-radius: 999px;
  padding: 7px 24px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0,0,0,.08);
  backdrop-filter: blur(2px);
  transition: background .2s ease, transform .2s ease;
}
.product-card-btn:hover { background: rgba(255,255,255,.14); transform: translateX(-50%) translateY(-1px); }

.lista-cta {
  position: relative;
  overflow: hidden;
  /* Slightly lighter base so the tone-on-tone pattern stays readable */
  background: #FF9D00;
  padding: 90px 0 120px;
  clip-path: polygon(0 22%, 100% 0, 100% 100%, 0 100%);
}
 .lista-cta::before {
  content: "";
  position: absolute;
  /* Slight overdraw to avoid 1px seams at clipped edges. */
  inset: -34px;
  z-index: 1;
  background-image: url("../assets/lista/bg-orange-pattern-ff7300.svg");
  background-repeat: no-repeat;
  /* Pull pattern down so the bottom isn't a solid strip. */
  background-position: center -30px;
  background-size: cover;
  opacity: .92;
  filter: brightness(.92) contrast(1.2);
}
.lista-cta-inner {
  position: relative;
  z-index: 2;
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 18px;
  padding-top: 90px;
}
.lista-cta-illu {
  height: auto;
  margin: -10px 0 6px;
  display: block;
  pointer-events: none;
}
.lista-cta-title {
  margin: 0;
  font-family: "Titular", var(--font-display);
  font-size: 64px;
  font-weight: 300;
  line-height: .95;
  text-transform: uppercase;
  color: #fff;
}
.lista-cta-title strong { font-weight: 800; }
.lista-cta-copy {
  margin: 0;
  max-width: 62ch;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 300;
  line-height: 1.45;
  color: rgba(255,255,255,.95);
}
.lista-cta-btn {
  margin-top: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 260px;
  border: 1px solid #fff;
  border-radius: 999px;
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: #fff;
  background: transparent;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.lista-cta-btn:hover {
  background: #fff;
  color: #FF7300;
  transform: translateY(-2px);
}

.zam-steps { max-width: 960px; margin: 0 auto; padding-bottom: 32px; }
.zam-steps .zam-title { margin-bottom: 40px; text-align: center; font-size: 64px; font-weight: 600; letter-spacing: 0; }

.zam-steps-mobile { margin-top: 32px; display: flex; flex-direction: column; gap: 32px; }
.zam-step-card { display: grid; grid-template-columns: 130px 1fr; align-items: center; gap: 16px; }
.zam-step-card-illu { width: 100%; height: auto; object-fit: contain; display: block; }
.zam-step-card-number { height: 23px; width: auto; margin: 0 0 4px; filter: brightness(0); opacity: .4; display: block; }
.zam-step-card-title { margin: 0; font-family: var(--font-display); font-size: 30px; font-weight: 700; text-transform: uppercase; }
.zam-step-card-text { margin: 4px 0 0; font-family: var(--font-body); font-size: 14px; font-weight: 400; color: #EFF4E0; }

.zam-steps-desktop-shell { display: none; position: relative; margin-top: 40px; }
.zam-steps-desktop { position: relative; margin-top: 0; height: 780px; display: none; }
.zam-steps-arrow { position: absolute; z-index: 20; opacity: .95; pointer-events: none; }
.zam-steps-arrow.arrow-1 { left: 170px; top: 150px; width: 192px; height: 192px; object-fit: contain; }
.zam-steps-arrow.arrow-2 { left: 350px; top: 352px; width: 99px; height: 99px; object-fit: contain; }
.zam-steps-arrow.arrow-3 { left: 446px; top: 518px; width: 56px; height: 110px; object-fit: contain; }

.zam-step-desktop { position: absolute; color: #fff; }
.zam-step-desktop h2 { margin: 0; font-family: var(--font-display); text-transform: uppercase; font-size: 36px; line-height: 1; font-weight: 700; color: #EFF4E0; }
.zam-step-desktop p { margin: 8px 0 0; font-family: var(--font-body); font-size: 14px; font-weight: 400; line-height: 1.4; color: #EFF4E0; }

.zam-step-desktop .zam-step-desktop-media { position: relative; }
.zam-step-desktop-number { position: absolute; width: 84px; height: auto; filter: brightness(0); opacity: .4; z-index: 10; pointer-events: none; }
.zam-step-desktop-illu { height: auto; object-fit: contain; position: relative; z-index: 20; display: block; }

.zam-step-desktop.step-1 {
  left: 50%;
  top: 16px;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 40px;
  width: 620px;
}
.zam-step-desktop.step-1 .zam-step-desktop-copy { max-width: 280px; text-align: right; }
.zam-step-desktop.step-1 .zam-step-desktop-illu { width: 250px; }
.zam-step-desktop.step-1 .zam-step-desktop-number { left: -32px; top: -32px; }

.zam-step-desktop.step-2 {
  left: 32px;
  top: 356px;
  width: 360px;
}
.zam-step-desktop.step-2 .zam-step-desktop-media { width: fit-content; }
.zam-step-desktop.step-2 .zam-step-desktop-illu { width: 250px; margin-left: 24px; }
.zam-step-desktop.step-2 .zam-step-desktop-number { left: -16px; top: 50%; transform: translateY(-50%); }
.zam-step-desktop.step-2 h2 { margin-top: 8px; }
.zam-step-desktop.step-2 p { margin-top: 8px; }

.zam-step-desktop.step-3 {
  right: 40px;
  top: 356px;
  width: 470px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.zam-step-desktop.step-3 .zam-step-desktop-media { margin-left: 48px; }
.zam-step-desktop.step-3 .zam-step-desktop-illu { width: 167px; }
.zam-step-desktop.step-3 .zam-step-desktop-number { left: -40px; top: -56px; }

.zam-step-desktop.step-4 {
  left: 57%;
  bottom: -48px;
  transform: translateX(-50%);
  width: 680px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
}
.zam-step-desktop.step-4 .zam-step-desktop-media { width: 350px; display: flex; justify-content: center; }
.zam-step-desktop.step-4 .zam-step-desktop-illu { width: 330px; }
.zam-step-desktop.step-4 .zam-step-desktop-number { right: 24px; top: -32px; }
.zam-step-desktop.step-4 .zam-step-desktop-copy { max-width: 230px; }

@media (max-width: 770px) {
  .pack-copy {
    width: min(440px, calc(100% - 24px));
    max-width: 440px;
    margin-left: auto;
    margin-right: auto;
  }

  .zam-steps-mobile {
    width: 100%;
    max-width: 620px;
    margin: 32px auto 0;
    padding: 0;
    align-items: center;
  }

  .zam-step-card {
    width: min(520px, calc(100% - 24px));
    max-width: 520px;
    margin: 0 auto;
  }
}

.pack-row { margin-top: 80px; display: grid; grid-template-columns: 360px 1fr; gap: 56px; align-items: center; }
.pack-media {
  --pack-media-width: 250px;
  --pack-item-width: 264%;
  --pack-item-right: -133%;
  --pack-item-top: -50%;
  position: relative;
  width: min(100%, var(--pack-media-width));
  max-width: 100%;
}
.pack-photo { width: 100%; display: block; }
.pack-copy { position: relative; left: 180px; }
.pack-item {
  position: absolute;
  right: var(--pack-item-right);
  top: var(--pack-item-top);
  width: var(--pack-item-width);
  transform: rotate(-12deg);
  filter: drop-shadow(0 18px 30px rgba(0,0,0,.25));
}
.pack-copy h2 { font-family: var(--font-display); text-transform: uppercase; font-size: 64px; font-weight: 700; line-height: .95; margin: 0 0 10px; }
.pack-intro { margin: 0; font-size: 14px; color: #F2EEE8; }
.pack-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 0; font-size: 13px; color: #F2EEE8; }
.pack-list li { display: flex; align-items: flex-start; }
.pack-list li::before { content: "\2192"; margin-right: 8px; }
.pack-mushrooms { position: relative; height: 0; z-index: -1; pointer-events: none; top: -20px; }
.pack-mushroom { position: absolute; width: 228px; height: auto; filter: none; }
.pack-mushroom-1 { left: 60px; top: 18px; }
.pack-mushroom-2 { left: 260px; top: -80px; }

.pack-copy { position: relative; z-index: 1; isolation: isolate; }

.faq-title { margin-top: 200px; font-size: 64px; font-weight: 600; line-height: .95; }
.faq-list { display: grid; gap: 16px; }
.faq-list { padding-bottom: 50px; }
.faq-item { position: relative; border: 1px solid rgba(255,255,255,.6); border-radius: 20px; padding: 40px 56px 40px 45px; }
.faq-trigger::after {
  content: "\2193";
  position: absolute;
  right: 22px;
  top: 42px;
  font-size: 25px;
  font-weight: 600;
  pointer-events: auto;
  transform-origin: 50% 50%;
  transition: transform .22s ease;
}
.faq-item.is-open .faq-trigger::after { transform: rotate(180deg); }
.faq-q { margin: 0; font-family: var(--font-display); text-transform: uppercase; font-size: 36px; font-weight: 700; letter-spacing: .02em; color: #EFF4E0; }
.faq-trigger {
  display: block;
  width: 100%;
  padding: 0;
  padding-right: 70px;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-transform: inherit;
  letter-spacing: inherit;
  cursor: pointer;
  text-align: left;
}
.faq-body {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transition: grid-template-rows .28s ease, opacity .2s ease;
}
.faq-body-inner { overflow: hidden; }
.faq-body p { margin: 20px 0 0; font-family: var(--font-body); font-size: 14px; font-weight: 400; color: #EFF4E0; line-height: 1.4; }
.faq-item.is-open .faq-body { grid-template-rows: 1fr; opacity: 1; }

.cta-zam {
  padding: 0 0 180px;
  position: relative;
  overflow: visible;
  isolation: isolate;
  background: transparent;
  z-index: 10;
  clip-path: none;
}
.cta-zam::before {
  content: "";
  position: absolute;
  /* Slight overdraw so the clipped background doesn't leave a solid strip at the bottom edge. */
  left: -2px;
  right: -2px;
  top: -2px;
  bottom: -2px;
  background-color: #E83D00;
  background-image: url("/wp-content/themes/chrapka-theme/assets/assets/home/bg-orange-pattern-cta-zam-2.svg");
  background-position: center -100px;
  background-repeat: no-repeat;
  background-size: cover;
  background-blend-mode: multiply;
  opacity: 1;
  clip-path: polygon(0 10%, 100% 0, 100% 100%, 0 100%);
  z-index: 0;
  outline: none;
}
.cta-zam::after { content: none; }
.cta-zam-inner { position: relative; z-index: 2; display: grid; gap: 42px; justify-items: center; text-align: center; padding-top: 110px; }
.cta-illu { width: 220px; height: auto; position: relative; z-index: 9999; margin-top: -110px; isolation: isolate; }
.cta-zam .display { font-size: 44px; line-height: .95; margin: 0; }
.cta-lead { margin: 0; max-width: 58ch; font-family: var(--font-body); font-size: 14px; font-weight: 400; line-height: 1.4; color: rgba(255,255,255,.95); }
.cta-lead strong { font: inherit; font-weight: 700; }
.cta-contact, .cta-form-lead { display: grid; gap: 4px; justify-items: center; }
.cta-label { font-family: var(--font-display); text-transform: uppercase; letter-spacing: .22em; font-size: 13px; }
.cta-label.cta-label-big { font-size: 42px; font-weight: 700; letter-spacing: 0; text-transform: uppercase; }
.cta-label.cta-label-form { font-family: var(--font-body); font-size: 14px; font-weight: 700; letter-spacing: 0; text-transform: none; }
.cta-email {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
  padding: 6px 22px;
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4em;
  transition: background .2s ease, color .2s ease;
}
.cta-email:hover { background: #fff; color: #ef4600; }
.cta-form-lead p { margin: 0; font-size: 12px; color: rgba(255,255,255,.9); max-width: none; white-space: nowrap; }
.cta-form-shell { margin-top: 10px; position: relative; width: min(780px, 100%); }
.contact-form-status {
  margin: 0 0 12px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.35;
}
.contact-form-status--success {
  background: rgba(27, 121, 68, 0.22);
  color: #e9fff2;
  border: 1px solid rgba(146, 244, 194, 0.55);
}
.contact-form-status--error {
  background: rgba(161, 30, 30, 0.25);
  color: #ffeaea;
  border: 1px solid rgba(255, 183, 183, 0.55);
}
.contact-form-cf7 .wpcf7-not-valid-tip {
  position: absolute;
  left: 0;
  top: -18px;
  margin-top: 0;
  margin: 0;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.2;
  color: #1f1f1f;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateY(-2px);
  transition: max-height .22s ease, opacity .18s ease, transform .22s ease, margin-top .22s ease;
}
.contact-form-cf7 .wpcf7 {
  margin: 0;
}
.contact-form-cf7 .wpcf7 form {
  margin: 0;
}
.contact-form-cf7 .wpcf7 form .wpcf7-response-output {
  display: none;
  margin: 8px 0 0;
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 11px;
  line-height: 1.3;
  order: 1;
}
.contact-form-cf7 .wpcf7 form p:has(.wpcf7-submit) {
  order: 2;
}
.contact-form-cf7 .wpcf7 form .wpcf7-response-output:empty {
  display: none;
}
.contact-form-cf7 .wpcf7 form.invalid .wpcf7-response-output,
.contact-form-cf7 .wpcf7 form.unaccepted .wpcf7-response-output,
.contact-form-cf7 .wpcf7 form.failed .wpcf7-response-output,
.contact-form-cf7 .wpcf7 form.spam .wpcf7-response-output {
  display: block;
  border-color: rgba(182, 24, 24, 0.5);
  background: rgba(182, 24, 24, 0.12);
  color: #8d1414;
}
.contact-form-cf7 .wpcf7 form.sent .wpcf7-response-output {
  display: block;
  border-color: rgba(27, 121, 68, 0.5);
  background: rgba(27, 121, 68, 0.12);
  color: #17613b;
}
.contact-form { background: #d9d9d9; border-radius: 18px; padding: 24px 30px 40px; display: grid; gap: 16px; text-align: left; color: #CE2618; box-shadow: 0 18px 30px rgba(0,0,0,.18); }
.contact-form label {
  position: relative;
  display: grid;
  gap: 0;
  font-size: 12px;
  letter-spacing: .02em;
  cursor: pointer;
  padding: 0 0 10px;
  transition: padding-bottom .2s ease;
}
.contact-form label > span { display: block; padding: 10px 0 8px; }
.contact-form label::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(206,38,24,.6);
  transform-origin: left center;
  transform: scaleX(.85);
  transition: transform .22s ease, height .22s ease, opacity .22s ease;
  opacity: .9;
}
.contact-form label.is-open::after {
  height: 2px;
  transform: scaleX(1);
  opacity: 1;
}
.contact-form input, .contact-form textarea {
  width: 100%;
  border: none;
  border-bottom: none;
  background: transparent;
  padding: 6px 0 10px;
  font: inherit;
  color: #3b1b12;
  outline: none;
  box-shadow: none;
  appearance: none;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form input:focus-visible,
.contact-form textarea:focus-visible { outline: none; box-shadow: none; }
.contact-form textarea { resize: none; min-height: 70px; }
.contact-form label input,
.contact-form label textarea {
  max-height: 0;
  opacity: 0;
  padding: 0;
  margin: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: max-height .22s ease, opacity .18s ease, transform .22s ease, padding .22s ease;
}
.contact-form label.is-open input,
.contact-form label.is-open textarea {
  max-height: 120px;
  opacity: 1;
  padding: 6px 0 0;
  pointer-events: auto;
  transform: translateY(0);
}
.contact-form label.is-open textarea { max-height: 170px; }
.contact-form button {
  justify-self: start;
  border-radius: 999px;
  border: 1px solid rgba(206,38,24,.8);
  background: transparent;
  color: #CE2618;
  font-family: var(--font-body);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .35em;
  padding: 6px 25px;
  font-size: 12px;
  cursor: pointer;
  transform: translateZ(0);
  transition: transform .16s ease, background-color .16s ease, color .16s ease, border-color .16s ease;
}
.contact-form button:hover {
  background: #CE2618;
  border-color: #CE2618;
  color: #d9d9d9;
  transform: translateY(-1px);
}
.contact-form button:active {
  transform: translateY(0) scale(.98);
}
.contact-form .wpcf7-submit {
  justify-self: start;
  display: inline-block;
  width: auto;
  min-width: 0;
  max-width: none;
  border-radius: 999px;
  border: 1px solid rgba(206,38,24,.8);
  background: transparent;
  color: #CE2618;
  font-family: var(--font-body);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .35em;
  padding: 6px 25px;
  font-size: 12px;
  cursor: pointer;
  transform: translateZ(0);
  transition: transform .16s ease, background-color .16s ease, color .16s ease, border-color .16s ease;
}
.contact-form .wpcf7-submit:hover {
  background: #CE2618;
  border-color: #CE2618;
  color: #d9d9d9;
  transform: translateY(-1px);
}
.contact-form .wpcf7-submit:active {
  transform: translateY(0) scale(.98);
}
.contact-form .wpcf7-form p {
  margin: 0;
  text-align: left;
  display: contents;
}
.contact-form .wpcf7-form-control-wrap {
  display: block;
  margin: 0;
  padding: 0;
  min-height: 0;
}
.contact-form-cf7 .wpcf7-form-control-wrap {
  position: relative;
  display: block;
}
.contact-form .wpcf7-spinner {
  margin: 0 0 0 10px;
}
.contact-form .wpcf7-form-control-wrap > .wpcf7-not-valid-tip {
  margin-top: 0;
  right: 0;
  max-height: 22px;
  white-space: nowrap;
  text-overflow: ellipsis;
  pointer-events: none;
  z-index: 2;
}
.contact-form label.has-error {
  padding-bottom: 10px;
}
.contact-form label.has-error .wpcf7-not-valid-tip {
  max-height: 22px;
  opacity: 1;
  margin-top: 0;
  transform: translateY(0);
}
.contact-form label:has(.wpcf7-not-valid),
.contact-form label:has(.wpcf7-not-valid-tip) {
  padding-bottom: 10px;
}
.contact-form label:has(.wpcf7-not-valid-tip) .wpcf7-not-valid-tip {
  max-height: 22px;
  opacity: 1;
  margin-top: 0;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .contact-form button { transition: none; }
  .contact-form .wpcf7-submit { transition: none; }
}
.cta-badge { position: absolute; left: 50%; bottom: -120px; transform: translateX(-50%); width: 180px; height: auto; }

.site-footer { background: var(--navy); padding: 72px 0; color: #EFF4E0; position: relative; }
.footer-inner {
  width: min(1060px, 100% - 160px);
  margin: 0 auto;
  padding-left: 0;
  position: relative;
  display: grid;
  grid-template-columns: 240px 240px 190px;
  column-gap: 40px;
  row-gap: 0;
  align-items: start;
  justify-content: start;
}
.footer-logo { width: 150px; }
.footer-logo-overlap { position: absolute; top: -112px; left: 0; z-index: 200; transform: none; margin-bottom: 0; }
.footer-col { display: grid; gap: 0; font-size: 12px; color: #EFF4E0; line-height: 1.2; }
.footer-col:first-of-type { gap: 12px; }
.footer-col h4 { margin: 0 0 8px; font-family: var(--font-display); text-transform: uppercase; font-size: 22px; letter-spacing: .02em; color: #EFF4E0; }
.footer-col p { margin: 0; }

@media (max-width: 1023px) {
  .header-inner { width: min(1280px, 100% - 32px); padding: 20px 0; grid-template-columns: auto 1fr; }
  .desktop-nav { display: none; }
  .kontakt-btn-top { display: none; }
.hamburger { display: inline-flex; flex-direction: column; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 999px; border: 1px solid rgba(255,255,255,.6); background: rgba(0,0,0,.1); position: fixed; right: 16px; top: 16px; z-index: 10020; gap: 3px; }
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: #fff;
  border-radius: 1px;
  transform-origin: center;
  transition: transform .2s ease, opacity .2s ease;
}

.hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(.2); }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

  .hero-stage { --hero-shift: 70px; }
  .hero-stage { height: clamp(500px, 76vw, 700px); }
  .hero-bg { background-position: center 20%; }
  .hero-title-text { top: calc(110px + var(--hero-shift)); width: min(820px, 86%); }
  .hero-sandwiches { width: 100vw; bottom: calc(-12% - var(--hero-shift)); }
  .hero-orange { padding: 24px 0 200px; }
  .hero-orange-inner { padding: 8px 0 24px; }
  .hero-subtitle-text { width: min(820px, 92%); font-size: clamp(22px, 4vw, 32px); }
  .hero-illu-left { width: 220px; left: 4%; top: calc(-12px + var(--hero-shift)); }
  .hero-illu-right { width: 96px; right: 8%; top: calc(8px + var(--hero-shift)); }
  .hero-chrapka-wrap { margin-bottom: -140px; }
  .hero-chrapka-layer { width: 100vw; height: auto; object-fit: contain; margin-left: calc(50% - 50vw); }

  .features-section { margin-top: -140px; padding: 160px 24px 80px; }
  .features-grid { grid-template-columns: 1fr; gap: 28px; margin-top: 0; }
  .feature-col h3 { font-size: 32px; }
  .feature-mid .feature-sandwich { width: 100%; max-width: 600px; }
  .about-stage { min-height: auto; display: grid; gap: 16px; }
  .about-title, .about-lettuce, .about-farmer, .about-orange-box { position: static; transform: none; width: 100%; height: auto; border-radius: 16px; }
  .home-cards-grid { grid-template-columns: repeat(2, minmax(0, 296px)); }
  .categories-badge-round { height: 96px; }
  .categories-badge-title { font-size: 32px; }
  .home-cta-inner { grid-template-columns: 1fr; min-height: auto; gap: 20px; transform: translateX(0); }
  .home-cta-illu { width: 240px; height: auto; margin-left: -12px; }
  .home-cta-copy .display { font-size: 50px; }
  .home-cta-copy p { font-size: 14px; }
  .home-cta-btn { width: 260px; }

  .cards-grid { grid-template-columns: 1fr 1fr; }
  .lista-badge { width: 84px; right: -34px; }
  .lista-title { font-size: 72px; }
  .lista-cta { padding: 80px 0 96px; }
  .lista-cta-inner {
    padding-top: 30px;
    transform: scale(.9);
    transform-origin: center;
  }
  .lista-cta-title { font-size: 34px; }
  .zam-step-card { grid-template-columns: 110px 1fr; }

  .pack-row { grid-template-columns: 1fr; gap: 32px; }
  .pack-media { margin: 0 auto; }
  .pack-item { right: -18px; top: -18px; width: 220px; }
  .pack-copy { left: 160px; }
  .faq-title { font-size: 34px; font-weight: 600; }
  .faq-item h3 { font-size: 18px; }
  .cta-zam { padding: 182px 0 0px; }
  .cta-zam::before, .cta-zam::after { clip-path: polygon(0 10%, 100% 0, 100% 100%, 0 100%); }
  .cta-zam-inner {
    transform: scale(.9);
    transform-origin: top center;
  }
  .cta-zam .display { font-size: 36px; }
  .cta-illu { width: 180px; margin-top: -170px; }
  .contact-form { padding: 22px 20px 36px; }
  .cta-badge { width: 160px; }

  .footer-inner { width: min(640px, 100% - 32px); grid-template-columns: 1fr; row-gap: 16px; }
}

@media (max-width: 1023px) and (min-width: 681px) {
  .hero-stage { height: clamp(520px, 78vw, 700px); }
  .hero-title-text { top: calc(92px + var(--hero-shift)); width: min(680px, 86%); font-size: clamp(46px, 7.2vw, 72px); }
  .hero-sandwiches { bottom: calc(21% - var(--hero-shift)); }
  .hero-sandwich-person-1, .hero-sandwich-person-2 { width: 110px; bottom: calc(96px - var(--hero-shift)); }
  .hero-sandwich-person-1 { transform: translateX(-220px); }
  .hero-sandwich-person-2 { transform: translateX(140px); }
  .lista-cta::before { background-position: -100px; }
}

@media (min-width: 771px) and (max-width: 1023px) {
  :root {
    --tablet-fluid-scale: clamp(.8, calc(.8 + ((100vw - 768px) / 255) * .2), 1);
    --tablet-fluid-shift: clamp(20px, calc(70px - ((100vw - 768px) / 255) * 50px), 70px);
  }
  .hero-stage { --hero-shift: 170px; }
  .hero-stage { height: clamp(380px, 52vw, 460px); }
  .hero-title-text { z-index: 300; top: calc(-60px + var(--hero-shift)) !important; }
  .hero-sandwich-person-1,
  .hero-sandwich-person-2 {
    width: 75px;
    bottom: calc(146px - var(--hero-shift));
  }
  .hero-sandwich-person-1 { transform: translateX(-180px); }
  .features-chrapka-wrap { top: -240px; }
  .hero-chrapka-layer { transform: translateY(140px); }
  .hero-orange { padding-top: 130px; padding-bottom: 140px; }
  .hero-copy { margin-top: 6px; }
  .hero-copy { font-size: 9.5px; }
  .hero-subtitle-text,
  .hero-copy { transform: translateY(-50px); }
  .features-section { margin-top: -100px; }
  .features-section { padding-bottom: 0; }
  .hero-orange-pattern-3 { bottom: -30px; }
  .hero-orange-patterns {
    transform: scale(.6667);
    transform-origin: top left;
    width: 150%;
  }
  .features-grid {
    grid-template-columns: 1fr 320px 1fr;
    gap: 10px;
    margin-top: 20px;
    align-items: start;
  }
  .features-grid h3 { font-size: 19px; }
  .features-grid p { font-size: 8px; line-height: 1.35; }
  .feature-mid .feature-sandwich { max-width: 420px; }
  .feature-mid .feature-arrows { width: 100%; transform: translateY(-40px); }
  .feature-mid .feature-arrow-extra { width: 70px; top: 220px; left: -10px; }
  .feature-col article { margin-bottom: 30px; }
  .feature-col:first-of-type { padding-top: 20px; }
  .feature-col:last-of-type article { margin-bottom: 30px; }
  .feature-col:last-of-type { padding-top: 20px; }

  /* About section: desktop-like layout scaled down for 768 */
  .about-stage {
    position: relative;
    min-height: 620px;
    display: block;
    gap: 0;
    width: 100%;
    max-width: 747px;
    margin-left: auto;
    margin-right: auto;
  }
  .about-section .container { width: calc(100% - 24px); }
  .about-title,
  .about-lettuce,
  .about-farmer,
  .about-orange-box {
    position: absolute;
    transform: none;
    width: auto;
    height: auto;
    border-radius: 18px;
  }
  .about-title {
    left: 10%;
    top: 140px;
    width: min(720px, 94%);
    font-size: 56px;
    line-height: .9;
  }
  .about-title-line-indent { padding-left: 110px; }
  .about-title-line-indent-2 { padding-left: 60px; }
  .about-lettuce { right: 0; top: 10px; width: 220px; height: 280px; }
  .about-farmer { left: 0; top: 170px; width: 320px; height: 380px; }
  .about-orange-box { left: 330px; right: 0; top: 300px; height: 130px; padding: 18px 24px; }
  .about-orange-box-content { gap: 80px; }
  .about-orange-box-text { font-size: 9px; line-height: 1.35; }
  .about-orange-box-bus { width: 100px; }
  .categories-section { padding-top: 0; }
  .home-cards-grid { grid-template-columns: repeat(3, 200px); gap: 15px 0; }
  .home-card img { max-width: 180px; margin: 0 auto; }
  .home-cta-inner {
    grid-template-columns: 220px minmax(0, 360px);
    gap: 20px;
    transform: translateY(var(--tablet-fluid-shift)) scale(var(--tablet-fluid-scale));
    transform-origin: top center;
    margin-top: 60px;
  }
  .home-cta { padding: 32px 0 150px; }
  .home-cta-illu { width: 200px; height: auto; margin-left: 0; }
  .home-cta-copy .display { font-size: 38px; }
  .home-cta-copy p { font-size: 14px; }
  .home-cta-btn { width: 200px; }
  .footer-inner { grid-template-columns: 220px 220px 170px; column-gap: 0; row-gap: 0; width: min(820px, 100% - 40px); }
  .footer-col { font-size: 10px; }
  .footer-col h4 { font-size: 18px; }
  .site-footer { padding-left: 0; }
  .cards-grid { grid-template-columns: repeat(3, 200px); gap: 14px; }
  .product-card-btn { bottom: 15px; font-size: 7px; }

  /* Keep desktop composition and scale it down on 768px. */
  .pack-row {
    margin-top: 120px;
    grid-template-columns: 360px 1fr;
    gap: 56px;
    align-items: center;
    transform: scale(clamp(.6, calc(.6 + ((100vw - 768px) / 255) * .4), 1));
    transform-origin: top center;
    width: 125%;
    margin-left: -14%;
  }
  .pack-media { margin: 0; max-width: 360px; }
  .pack-copy { left: 180px; }
  .pack-item {
    right: -332px;
    top: -124px;
    width: 660px;
    transform: rotate(-12deg);
  }
  .zam-steps-mobile { display: none; }
  .zam-steps-desktop-shell {
    display: flex;
    justify-content: center;
    width: 100%;
    overflow: hidden;
    margin-top: 40px;
    min-height: 414px;
  }
  .zam-steps-desktop {
    display: block;
    width: 960px;
    max-width: none;
    height: 780px;
    margin: 0;
    flex: 0 0 auto;
    transform-origin: top center;
  }
  .faq-list {
    transform: scale(clamp(.8, calc(.8 + ((100vw - 768px) / 255) * .2), 1));
    transform-origin: top center;
  }
  .faq-title { margin-top: 0; margin-left: 75px; }
  .faq-trigger::after { top: 32px; }
}

@media (min-width: 771px) and (max-width: 1023px) {
  body.home .hero-stage {
    height: clamp(400.906px, 52vw, 532px);
  }

  body.home .hero-sandwiches {
    bottom: calc(21% - var(--hero-shift) - 12px);
  }

  body.home .hero-sandwich-person-1,
  body.home .hero-sandwich-person-2 {
    bottom: clamp(-24px, calc(56.7vw - 461px), 119px);
  }

  body.home .features-chrapka-wrap {
    top: -300px;
  }

  body.home .features-grid {
    margin-top: clamp(94px, calc(-459px + 71.8vw), 276px);
  }
}

@media (min-width: 1024px) {
  .zam-steps { padding-bottom: 48px; }
  .zam-steps .zam-title { margin-bottom: 56px; font-size: 64px; }
  .zam-steps-mobile { display: none; }
  .zam-steps-desktop-shell { display: block; overflow: visible; }
  .zam-steps-desktop { display: block; }
}

@media (min-width: 1280px) {
  .home-cta {
    width: calc(100% + 223px);
    margin-left: -124px;
    min-height: 700px;
  }
  .home-cta-inner {
    min-height: 700px;
    margin-top: 80px;
  }

  /* Keep About section from stretching too wide on large screens. */
  .about-section .container {
    max-width: 1200px;
  }
}

@media (width: 1280px) {
  .hero-sandwich-person-1,
  .hero-sandwich-person-2 { bottom: calc(90px - var(--hero-shift)); }
  .hero-sandwich-person-1 { transform: translateX(-300px); }
  .hero-subtitle-text { margin-top: -50px; }
  .hero-sandwiches { bottom: calc(-12% - var(--hero-shift)); }
}

@media (min-width: 1440px) {
  .features-grid { margin-top: 130px; }
  .cta-zam::before { background-position: center -100px; }
  .lista-cta::before { background-position: center -90px; }
  .hero-orange-inner { margin: 10px auto; }
}

@media (min-width: 1536px) {
  .hero-sandwiches {
    position: absolute;
    left: 50%;
    bottom: calc(-13% - var(--hero-shift));
  }
  .lista-cta::before { background-position: center -100px; }
  .cta-zam::before { background-position: center -120px; }
}

@media (min-width: 1680px) {
  .hero-sandwiches { bottom: calc(-18% - var(--hero-shift)); }
  .hero-title-text {
    position: absolute;
    left: 50%;
    top: calc(90px + var(--hero-shift));
  }
  .features-section {
    position: relative;
    z-index: 300;
    margin-top: -240px;
    padding: 200px 10px 0;
    overflow: visible;
    background: transparent;
  }
  .features-grid { margin-top: 300px; }
  .lista-cta::before { background-position: center -120px; }
  .cta-zam::before { background-position: center -140px; }
}

@media (min-width: 1920px) {
  .hero-stage { --hero-shift: 60px; }
  .cta-zam::before { background-position: center -180px; }
  .lista-cta::before { background-position: center -150px; }
  .features-grid { margin-top: 370px; }
  .hero-sandwiches { bottom: calc(-21% - var(--hero-shift)); }
  .hero-stage {
    position: relative;
    z-index: 200;
    height: clamp(560px, 54vw, 880px);
  }
  .hero-title-text {
    position: absolute;
    left: 50%;
    top: calc(130px + var(--hero-shift));
  }
  .hero-sandwich-person-1,
  .hero-sandwich-person-2 {
    left: 50%;
    width: auto;
    height: 310px;
  }
  .hero-sandwich-person-2 { bottom: calc(100px - var(--hero-shift)); }
  .hero-sandwich-person-1 {
    bottom: calc(90px - var(--hero-shift));
    transform: translateX(-400px);
  }
}

@media (max-width: 1366px) and (min-width: 1024px) {
  .hero-title-text { top: calc(95px + var(--hero-shift)); }
  .lista-cta::before { background-position: center -100px; }
}

/* Tablet / small desktop tuning (eg ~1024px wide). Keep it scoped to 1024–1279px. */
@media (max-width: 1279px) and (min-width: 1024px) {
  .hero-title-text { top: calc(72px + var(--hero-shift)); }
  .hero-stage { height: clamp(590px, 57vw, 800px); }

  /* Subtitle in the orange section a bit lower vs desktop. */
  .hero-subtitle-text { margin-top: -40px; }

  /* Keep the overlay characters proportional on smaller screens. */
  .hero-sandwich-person-1,
  .hero-sandwich-person-2 {
    width: 112px;
    bottom: calc(86px - var(--hero-shift));
  }
  .hero-sandwich-person-1 { transform: translateX(-260px); }
  .hero-sandwich-person-2 { transform: translateX(150px); }

  /* About: orange box — keep content inside the pill at 1024px. */
  .about-orange-box-content { gap: 90px; }
  .about-orange-box-bus { width: 180px; }
  .about-orange-box-text { font-size: 14px; line-height: 1.45; }

  .features-grid { margin-top: -100px; }

  .about-farmer { width: 380px; }
  .about-orange-box { left: 420px; }

  /* Lista page card sizing is handled by the fluid 768-1279 cards rules. */
  .filters { gap: 18px; margin: 20px 0 30px; }
  .filters button { padding: 10px 20px; font-size: 10px; letter-spacing: .28em; }
  .lista-cta { padding-bottom: 60px; }

  /* Zamówienie: keep desktop steps layout but make everything smaller (x1.5). */
  .zam-steps-desktop {
    transform: scale(.6666667);
    transform-origin: top center;
    height: 520px; /* 780px / 1.5 */
  }
  .zam-step-desktop.step-4 { bottom: -350px; }

  /* Pack layout handled by dedicated two-model breakpoints below. */

  /* More breathing room between sections on this breakpoint. */
  .faq-title { margin-top: 100px; padding: 0 40px; }

  /* FAQ list: scale down ~1.5x for 1024px layouts without using transforms. */
  .faq-list { gap: 10px; padding: 0 40px 50px 0; }
  .faq-item { border-radius: 13px; padding: 27px 37px 27px 30px; }
  .faq-trigger::after { right: 16px; top: 30px; font-size: 17px; }
  .faq-q { font-size: 24px; }
  .faq-trigger { padding-right: 46px; }
  .faq-body p { margin-top: 13px; font-size: 12px; }

  /* CTA pattern position: keep previous offset on 1024px layouts. */
  .cta-zam::before { background-position: center -140px; }
}

@media (width: 1240px) {
  .hero-subtitle-text { margin-top: -60px; }
  .hero-sandwiches { bottom: calc(-4% - var(--hero-shift)); }
  .hero-sandwich-person-1,
  .hero-sandwich-person-2 { bottom: calc(130px - var(--hero-shift)); }
}

@media (width: 1024px) {
  .hero-title-text { top: calc(65px + var(--hero-shift)); }
  .hero-sandwich-person-1,
  .hero-sandwich-person-2 {
    width: 95px;
    bottom: calc(70px - var(--hero-shift));
  }
  .hero-sandwich-person-1 { transform: translateX(-220px); }
  .hero-sandwich-person-2 { transform: translateX(120px); }
  .lista-cta::before { background-position: center -30px; }
}

@media (min-width: 840px) and (max-width: 1120px) {
  .lista-cta::before {
    background-position: center bottom !important;
    background-size: cover;
    background-repeat: no-repeat;
  }
}

@media (max-width: 680px) {
  .hero-stage { --hero-shift: 55px; }
  .hero-stage { height: clamp(460px, 112vw, 600px); }
  .hero-bg { background-position: center 18%; }
  .hero-title-text { top: calc(96px + var(--hero-shift)); width: min(640px, 88%); font-size: clamp(38px, 9vw, 72px); }
  .hero-sandwiches { width: 100vw; bottom: calc(-10% - var(--hero-shift)); }

  .hero-orange { padding: 28px 0 180px; }
  .hero-orange-inner { padding: 0 0 16px; }
  .hero-subtitle-text { width: min(520px, 92%); font-size: clamp(20px, 5.2vw, 28px); }
  .hero-illu-left { width: 180px; left: 2%; top: calc(-6px + var(--hero-shift)); }
  .hero-illu-right { width: 80px; right: 4%; top: calc(6px + var(--hero-shift)); }
  .hero-chrapka-wrap { margin-top: -20px; margin-bottom: -120px; }
  .hero-chrapka-layer { width: 100vw; height: auto; object-fit: contain; margin-left: calc(50% - 50vw); }

  .home-cards-grid { grid-template-columns: 296px; justify-content: center; }
}

@media (max-width: 430px) {
  body.home .header-inner { width: calc(100% - 20px); padding: 12px 0; }
  body.home .logo { width: 110px; }
  body.home .hamburger { right: 10px; top: 10px; width: 40px; height: 40px; }

  body.home .hero-stage { --hero-shift: 40px; height: 420px; }
  body.home .hero-bg { inset: 0 0 100px 0; }
  body.home .hero-title-text {
    top: calc(86px + var(--hero-shift));
    width: min(420px, 86%);
    font-size: clamp(30px, 11vw, 54px);
    z-index: 250;
  }
  body.home .hero-sandwiches { bottom: calc(24% - var(--hero-shift)); }
  body.home .hero-sandwich-person-1,
  body.home .hero-sandwich-person-2 {
    width: 44px;
    bottom: calc(85px - var(--hero-shift));
  }
  body.home .hero-sandwich-person-1 { transform: translateX(-95px); }
  body.home .hero-sandwich-person-2 { transform: translateX(65px); }

  body.home .hero-orange {
    --hero-orange-pad-top: 0px;
    padding: 10px 0 120px;
    margin-top: -120px;
  }
  body.home .hero-orange-inner { padding: 0 0 6px; }
  body.home .hero-orange-patterns {
    transform: translateX(-30%) scale(.5);
    transform-origin: top center;
    width: 200%;
  }
  body.home .hero-orange-pattern-3 {
    right: clamp(-120px, calc(-279.5166px + 36.2538vw), 0px);
    bottom: -140px;
  }
  body.home .hero-subtitle-text {
    width: min(380px, 90%);
    font-size: clamp(18px, 6.2vw, 30px);
    margin: 12px auto 0;
  }
  body.home .hero-copy { font-size: 9px; line-height: 1.35; }
  body.home .hero-illu-left,
  body.home .hero-illu-right { display: none; }

  body.home .hero-chrapka-wrap {
    display: block;
    margin-top: -70px;
    margin-bottom: -70px;
  }
  body.home .features-chrapka-wrap { top: -120px; }
  body.home .hero-chrapka-layer {
    width: 108vw;
    margin-left: calc(50% - 54vw);
    transform: translateY(0);
  }

  body.home .features-section { margin-top: 0; }
  body.home .features-grid { gap: 14px; }
  body.home .feature-col,
  body.home .feature-col:first-of-type,
  body.home .feature-col:last-of-type { text-align: center; padding-left: 0; }
  body.home .feature-col article,
  body.home .feature-col:last-of-type article { margin-bottom: 18px; }
  body.home .feature-col h3 { font-size: 24px; }
  body.home .feature-col p { font-size: 13px; line-height: 1.35; }
  body.home .feature-mid .feature-sandwich { max-width: 260px; }
  body.home .feature-mid .feature-arrows { width: 92%; transform: translateY(-10px); }
  body.home .feature-mid .feature-arrow-extra {
    display: block;
    width: 56px;
    left: 10%;
    top: 80%;
    bottom: auto;
    transform: none;
  }

  body.home .about-section .container { width: calc(100% - 16px); }
  body.home .about-stage {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: auto;
  }
  body.home .about-title {
    order: 1;
    font-size: 46px;
    line-height: .9;
    text-align: center;
    margin-bottom: 10px;
  }
  body.home .about-lettuce { display: none; }
  body.home .about-farmer {
    display: block;
    order: 2;
    width: calc(100% - 24px);
    margin: 0 auto;
    height: auto;
    border-radius: 16px;
  }
  body.home .about-title-line-indent,
  body.home .about-title-line-indent-2 { padding-left: 0; }
  body.home .about-orange-box {
    order: 3;
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    height: auto;
    background: #ff7a1a;
    width: calc(100% - 24px);
    margin: 12px auto 18px;
    padding: 28px 18px 84px;
    overflow: visible;
  }
  body.home .about-orange-box-bg { display: none; }
  body.home .about-orange-box-content {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    text-align: center;
  }
  body.home .about-orange-box-text {
    font-size: 0;
    line-height: 0;
  }
  body.home .about-orange-box-text::before {
    content: "Być może już je znasz!";
    display: block;
    font-size: 12px;
    line-height: 1.35;
    font-weight: 700;
  }
  body.home .about-orange-box-text::after {
    content: "Dowozimy je do sklepów, punktów gastronomicznych,\Astacji paliw, zakładów produkcyjnych, biur i szkół.";
    display: block;
    font-size: 12px;
    line-height: 1.35;
    font-weight: 400;
    white-space: pre-line;
  }
  body.home .about-orange-box-bus {
    width: 128px;
    position: absolute;
    left: 50%;
    bottom: -140px;
    transform: translateX(-50%);
    z-index: 3;
  }

  body.home .categories-section { padding: 16px 0 40px; }
  body.home .categories-badge { gap: 10px; margin: 50px 0 20px 0; }
  body.home .categories-badge-round { height: 72px; }
  body.home .categories-badge-title { font-size: 30px; }
  body.home .home-cards-grid {
    display: grid;
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: 290px;
    justify-items: center;
    justify-content: start;
    gap: 12px;
    padding-inline: calc((100% - min(290px, 100%)) / 2);
    padding-bottom: 8px;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: calc((100% - min(290px, 100%)) / 2);
    scrollbar-width: none;
  }
  body.home .home-cards-grid.has-reveal { overflow-y: hidden; }
  body.home .home-cards-grid::-webkit-scrollbar { display: none; }
  body.home .home-card {
    width: 290px;
    max-width: min(290px, 100%);
    min-width: min(290px, 100%);
    margin: 0;
    scroll-snap-align: center;
  }
  body.home .home-card-copy p {
    font-size: 13px;
    line-height: 1.3;
  }

  body.home .home-cta { padding: 88px 0 44px; min-height: auto; }
  body.home .home-cta-inner {
    grid-template-columns: 1fr;
    transform: none;
    margin: 22px auto 0;
    gap: 20px;
    max-width: 320px;
  }
  body.home .home-cta-illu {
    width: 152px;
    height: auto;
    margin: 0 auto;
    justify-self: center;
  }
  body.home .home-cta-copy { text-align: center; }
  body.home .home-cta-copy .display { font-size: 28px; }
  body.home .home-cta-copy p { margin: 10px auto 10px; font-size: 14px; line-height: 1.35; text-align: center; }
  body.home .home-cta-copy .home-cta-btn { margin-left: auto; margin-right: auto; }
  body.home .home-cta-btn { width: 160px; padding: 8px 12px; font-size: 10px; letter-spacing: .2em; margin-top: 12px; }

  body.home .site-footer { padding: 40px 16px 24px; }
  body.home .footer-logo-overlap { top: -68px; }
  body.home .footer-logo { width: 108px; }
  body.home .footer-inner {
    width: 100%;
    grid-template-columns: 1fr;
    column-gap: 0;
    row-gap: 18px;
    padding-left: 0;
  }
  body.home .footer-col:first-of-type { gap: 10px; }
  body.home .footer-col h4 { font-size: 16px; margin: 0 0 6px; }
  body.home .footer-col { font-size: 13px; line-height: 1.35; }

  body.home .zam-steps {
    padding: 0 16px 24px;
  }
  body.home .zam-steps-mobile { gap: 22px; padding: 0 4px; }

  .pack-mushrooms { z-index: 0; }
  .faq-title,
  .faq-list { position: relative; z-index: 2; }
  body.home .zam-step-card {
    grid-template-columns: 92px 1fr;
    gap: 12px;
    padding: 18px 18px 20px;
    border-radius: 18px;
    background: rgba(255,255,255,.04);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.05);
    position: relative;
    overflow: hidden;
  }
  body.home .zam-step-card:nth-child(even) {
    grid-template-columns: 1fr 92px;
  }
  body.home .zam-step-card:nth-child(even) .zam-step-card-copy { text-align: right; }
  body.home .zam-step-card:nth-child(even) .zam-step-card-illu { justify-self: end; }
  body.home .zam-step-card-illu {
    width: 100%;
    max-width: 92px;
    height: auto;
    z-index: 1;
  }
  body.home .zam-step-card-copy { z-index: 1; }
  body.home .zam-step-card::after {
    content: "";
    position: absolute;
    font-family: var(--font-display);
    font-size: 120px;
    font-weight: 700;
    color: rgba(255,255,255,.08);
    top: -18px;
    right: 18px;
    z-index: 0;
    pointer-events: none;
  }

  body.home .zam-step-card:nth-child(1)::after { content: "1"; }
  body.home .zam-step-card:nth-child(2)::after { content: "2"; }
  body.home .zam-step-card:nth-child(3)::after { content: "3"; }
  body.home .zam-step-card:nth-child(4)::after { content: "4"; }

  .pack-row {
    grid-template-columns: 1fr;
    gap: 20px;
    width: calc(100% - 32px);
    margin: 40px auto 20px;
    transform: none;
  }
  .pack-media {
    margin: 0 auto;
    max-width: 360px;
    position: relative;
  }
  .pack-item {
    position: absolute;
    right: -46px;
    top: -40px;
    width: 400px;
    transform: none;
    z-index: 2;
  }
  .pack-copy {
    left: -20px;
    padding: 60px 12px;
    text-align: center;
  }

  /* Lista page mobile */
  .lista-page { padding: 96px 0 44px; }
  .lista-title-wrap {
    width: calc(100% - 24px);
    margin: 10px auto 16px;
    display: grid;
    justify-items: center;
  }
  .lista-title {
    width: 100%;
    max-width: 360px;
    font-size: clamp(54px, 14vw, 72px);
    text-align: center;
  }
  .lista-badge {
    width: 54px;
    right: -1px;
    top: 32%;
  }

  .filters {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
    gap: 10px;
    margin: 36px auto 36px;
    padding: 0 12px;
    width: min(520px, calc(100% - 24px));
  }
  .filters button {
    width: 100%;
    min-height: 40px;
    padding: 10px 12px;
    font-size: 10px;
    letter-spacing: .14em;
  }

  .cards-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 100%;
    justify-items: center;
    justify-content: start;
    gap: 12px;
    margin-top: 8px;
    padding: 8px 0 8px;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }
  .cards-grid::-webkit-scrollbar { display: none; }
  .product-card,
  .product-card--cms {
    width: min(320px, calc(100% - 24px));
    max-width: none;
    margin: 0;
    scroll-snap-align: center;
  }
  .product-card--cms { --image-width: 132%; --image-left: 42%; --title-top: 60%; --content-bottom: 5.5%; }
  .product-card--cms .product-card-ui { height: 100%; min-height: 0; }
  .product-card--cms .product-card-media { height: 62%; }
  .product-card--cms .product-card-media img { max-height: 120%; }
  .product-card--cms .product-card-title { max-width: 80%; }

  .cta-zam-inner {
    padding-top: 80px;
    gap: 28px;
    transform: scale(.8);
  }
  .cta-zam .display { font-size: 28px; }
  .contact-form {
    width: calc(100% - 24px);
    max-width: 400px;
    padding: 18px 16px 28px;
    border-radius: 16px;
  }
  .contact-form label > span { padding: 8px 0 6px; font-size: 12px; }
  .contact-form textarea { min-height: 90px; }
}


@media (max-width: 390px) {
  body.home .hero-title-text { top: calc(110px + var(--hero-shift)); }
  .pack-item { right: -96px; }
  .container.narrow { margin-right: 0px; }
  .faq-list { margin-right: 30px; }
  body.home .home-cta { padding: 28px 0 64px; }
  body.home .site-footer { padding: 60px 16px 24px; }
  body.home .footer-logo { width: 150px; }
  body.home .footer-logo-overlap { top: -98px; }
}

@media (max-width: 350px) {
  .cards-grid .product-card--cms .product-card-title {
    font-size: clamp(25.8px, 7.9vw, 27.6px);
    line-height: 0.92;
  }

  .cards-grid .product-card--cms .product-card-details p,
  .cards-grid .product-card--custom .product-card-details p {
    font-size: clamp(11.4px, 3.4vw, 11.9px);
    line-height: 1.26;
    margin-bottom: 5px;
  }
}

@media (max-width: 480px) {
  .cards-grid .product-card--cms .product-card-media {
    left: 5%;
  }
}

@media (max-width: 393px) {
  body.home .hero-title-text { top: calc(106px + var(--hero-shift)); }
}

@media (min-width: 430px) and (max-width: 740px) {
  body.home .hero-stage {
    --hero-shift: 40px;
    height: 420px;
  }

  body.home .hero-bg {
    top: 0;
    right: 0;
    bottom: clamp(0px, calc(232.93px - 30.2115vw), 100px);
    left: 0;
  }

  body.home .hero-title-text {
    top: calc(86px + var(--hero-shift));
    width: min(420px, 86%);
    font-size: clamp(30px, 8vw, 42px);
    z-index: 250;
  }

  body.home .hero-sandwiches {
    bottom: calc(24% - var(--hero-shift));
  }

  body.home .hero-sandwich-person-1,
  body.home .hero-sandwich-person-2 {
    width: 44px;
    bottom: calc(85px - var(--hero-shift));
  }

  body.home .hero-sandwich-person-1 {
    transform: translateX(-95px);
  }

  body.home .hero-sandwich-person-2 {
    transform: translateX(65px);
  }

  body.home .hero-orange {
    --hero-orange-pad-top: 0px;
    padding: 10px 0 120px;
    margin-top: -120px;
  }

  body.home .hero-orange-inner {
    padding: 0 0 6px;
  }

  body.home .hero-orange-patterns {
    transform: translateX(-30%) scale(.5);
    transform-origin: top center;
    width: 200%;
  }

  body.home .hero-orange-pattern-3 {
    right: clamp(-120px, calc(-279.5166px + 36.2538vw), 0px);
    bottom: -140px;
  }

  body.home .hero-subtitle-text {
    width: min(380px, 90%);
    font-size: clamp(18px, 4.8vw, 24px);
    margin: 12px auto 0;
  }

  body.home .hero-copy {
    font-size: 9px;
    line-height: 1.35;
  }

  body.home .hero-illu-left,
  body.home .hero-illu-right {
    display: none;
  }

  body.home .hero-chrapka-wrap {
    display: block;
    margin-top: -70px;
    margin-bottom: -70px;
  }

  body.home .hero-chrapka-layer {
    width: 108vw;
    margin-left: calc(50% - 54vw);
    transform: translateY(0);
  }

  .pack-copy {
    left: 0;
    padding: 60px 12px 0;
    text-align: left;
  }

  .pack-copy h2,
  .pack-intro,
  .pack-list {
    text-align: left;
  }

  .filters {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px 12px;
    margin: 32px auto 36px;
    padding: 0 16px;
    width: min(760px, calc(100% - 24px));
  }

  .filters button {
    flex: 0 1 auto;
    min-height: 40px;
    padding: 10px 18px;
    font-size: 10px;
    letter-spacing: .18em;
  }
}

@media (min-width: 431px) and (max-width: 770px) {
  body.home .header-inner {
    width: calc(100% - 20px);
    padding: 12px 0;
  }

  body.home .logo {
    width: 110px;
  }

  body.home .hamburger {
    right: 10px;
    top: 10px;
    width: 40px;
    height: 40px;
  }

  body.home .hero-stage {
    --hero-shift: 40px;
    height: 420px;
  }

  body.home .hero-bg {
    top: 0;
    right: 0;
    bottom: clamp(0px, calc(232.93px - 30.2115vw), 100px);
    left: 0;
  }

  body.home .hero-title-text {
    top: calc(86px + var(--hero-shift));
    width: min(420px, 86%);
    font-size: clamp(30px, 8vw, 42px);
    z-index: 250;
  }

  body.home .hero-sandwiches {
    bottom: calc(24% - var(--hero-shift));
  }

  body.home .hero-sandwich-person-1,
  body.home .hero-sandwich-person-2 {
    width: 44px;
    bottom: calc(85px - var(--hero-shift));
  }

  body.home .hero-sandwich-person-1 {
    transform: translateX(-95px);
  }

  body.home .hero-sandwich-person-2 {
    transform: translateX(65px);
  }

  body.home .hero-orange {
    --hero-orange-pad-top: 0px;
    padding: 10px 0 120px;
    margin-top: -120px;
  }

  body.home .hero-orange-inner {
    padding: 0 0 6px;
  }

  body.home .hero-orange-patterns {
    transform: translateX(-30%) scale(.5);
    transform-origin: top center;
    width: 200%;
  }

  body.home .hero-orange-pattern-3 {
    right: clamp(-145px, calc(-86.5px - 7.6vw), -120px);
    bottom: -140px;
  }

  body.home .hero-subtitle-text {
    width: min(380px, 90%);
    font-size: clamp(18px, 4.8vw, 24px);
    margin: 12px auto 0;
  }

  body.home .hero-copy {
    font-size: 9px;
    line-height: 1.35;
  }

  body.home .hero-illu-left,
  body.home .hero-illu-right {
    display: none;
  }

  body.home .hero-chrapka-wrap {
    display: block;
    margin-top: -70px;
    margin-bottom: -70px;
  }

  body.home .features-chrapka-wrap {
    top: -120px;
  }

  body.home .hero-chrapka-layer {
    width: 108vw;
    margin-left: calc(50% - 54vw);
    transform: translateY(0);
  }

  body.home .features-section {
    margin-top: 0;
  }

  body.home .features-grid {
    gap: 14px;
  }

  body.home .feature-col,
  body.home .feature-col:first-of-type,
  body.home .feature-col:last-of-type {
    text-align: center;
    padding-left: 0;
  }

  body.home .feature-col article,
  body.home .feature-col:last-of-type article {
    margin-bottom: 18px;
  }

  body.home .feature-col h3 {
    font-size: 24px;
  }

  body.home .feature-col p {
    font-size: 13px;
    line-height: 1.35;
  }

  body.home .feature-mid .feature-sandwich {
    max-width: 260px;
  }

  body.home .feature-mid .feature-arrows {
    width: 92%;
    transform: translateY(-10px);
  }

  body.home .feature-mid .feature-arrow-extra {
    display: block;
    width: 56px;
    left: 10%;
    top: 80%;
    bottom: auto;
    transform: none;
  }

  body.home .about-section .container {
    width: calc(100% - 16px);
  }

  body.home .about-stage {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: auto;
  }

  body.home .about-title {
    order: 1;
    font-size: 46px;
    line-height: .9;
    text-align: center;
    margin-bottom: 10px;
  }

  body.home .about-lettuce {
    display: none;
  }

  body.home .about-farmer {
    display: block;
    order: 2;
    width: calc(100% - 24px);
    margin: 0 auto;
    height: auto;
    border-radius: 16px;
  }

  body.home .about-title-line-indent,
  body.home .about-title-line-indent-2 {
    padding-left: 0;
  }

  body.home .about-orange-box {
    order: 3;
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    height: auto;
    background: #ff7a1a;
    width: calc(100% - 24px);
    margin: 12px auto 18px;
    padding: 28px 18px 84px;
    overflow: visible;
  }

  body.home .about-orange-box-bg {
    display: none;
  }

  body.home .about-orange-box-content {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    text-align: center;
  }

  body.home .about-orange-box-text {
    font-size: 0;
    line-height: 0;
  }

  body.home .about-orange-box-text::before {
    content: "Być może już je znasz!";
    display: block;
    font-size: 12px;
    line-height: 1.35;
    font-weight: 700;
  }

  body.home .about-orange-box-text::after {
    content: "Dowozimy je do sklepów, punktów gastronomicznych,\Astacji paliw, zakładów produkcyjnych, biur i szkół.";
    display: block;
    font-size: 12px;
    line-height: 1.35;
    font-weight: 400;
    white-space: pre-line;
  }

  body.home .about-orange-box-bus {
    width: 128px;
    position: absolute;
    left: 50%;
    bottom: -140px;
    transform: translateX(-50%);
    z-index: 3;
  }

  body.home .categories-section {
    padding: 16px 0 40px;
  }

  body.home .categories-badge {
    gap: 10px;
    margin: 50px 0 20px 0;
  }

  body.home .categories-badge-round {
    height: 72px;
  }

  body.home .categories-badge-title {
    font-size: 30px;
  }

  body.home .home-cards-grid {
    display: grid;
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: 290px;
    justify-items: center;
    justify-content: start;
    gap: 12px;
    padding-inline: calc((100% - min(290px, 100%)) / 2);
    padding-bottom: 8px;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: calc((100% - min(290px, 100%)) / 2);
    scrollbar-width: none;
  }
  body.home .home-cards-grid.has-reveal {
    overflow-y: hidden;
  }

  body.home .home-cards-grid::-webkit-scrollbar {
    display: none;
  }

  body.home .home-card {
    width: 290px;
    max-width: min(290px, 100%);
    min-width: min(290px, 100%);
    margin: 0;
    scroll-snap-align: center;
  }

  body.home .home-card-copy p {
    font-size: 13px;
    line-height: 1.3;
  }

  body.home .home-cta {
    padding: 88px 0 44px;
    min-height: auto;
  }

  body.home .home-cta-inner {
    grid-template-columns: 1fr;
    transform: none;
    margin: 22px auto 0;
    gap: 20px;
    max-width: 320px;
  }

  body.home .home-cta-illu {
    width: 152px;
    height: auto;
    margin: 0 auto;
    justify-self: center;
  }

  body.home .home-cta-copy {
    text-align: center;
  }

  body.home .home-cta-copy .display {
    font-size: 28px;
  }

  body.home .home-cta-copy p {
    margin: 10px auto 10px;
    font-size: 14px;
    line-height: 1.35;
    text-align: center;
  }

  body.home .home-cta-copy .home-cta-btn {
    margin-left: auto;
    margin-right: auto;
  }

  body.home .home-cta-btn {
    width: 160px;
    padding: 8px 12px;
    font-size: 10px;
    letter-spacing: .2em;
    margin-top: 12px;
  }
}

@media (min-width: 460px) and (max-width: 770px) {
  body.home .hero-stage {
    --hero-shift: clamp(46px, calc(46px + ((100vw - 460px) / 310) * 18), 64px);
    height: clamp(430px, calc(430px + ((100vw - 460px) / 310) * 56), 486px);
  }

  body.home .hero-title-text {
    top: calc(clamp(82px, calc(82px - ((100vw - 460px) / 310) * 8), 74px) + var(--hero-shift));
    width: min(clamp(430px, calc(430px + ((100vw - 460px) / 310) * 120), 550px), 88%);
    font-size: clamp(32px, calc(32px + ((100vw - 460px) / 310) * 12), 44px);
  }

  body.home .hero-sandwiches {
    width: clamp(92vw, 80vw + 12vw, 100vw);
    bottom: calc(clamp(18%, 25.45% - 0.97vw, 21%) - var(--hero-shift));
    transform: translateX(-50%) scale(clamp(.88, 0.7613 + 0.0258vw, .96));
    transform-origin: top center;
  }

  body.home .hero-sandwich-person-1,
  body.home .hero-sandwich-person-2 {
    width: clamp(48px, calc(48px + ((100vw - 460px) / 310) * 18), 66px);
    bottom: calc(clamp(92px, calc(92px + ((100vw - 460px) / 310) * 22), 114px) - var(--hero-shift));
  }

  body.home .hero-sandwich-person-1 {
    transform: translateX(clamp(-112px, calc(-112px - ((100vw - 460px) / 310) * 38), -150px));
  }

  body.home .hero-sandwich-person-2 {
    transform: translateX(clamp(78px, calc(78px + ((100vw - 460px) / 310) * 34), 112px));
  }

  body.home .hero-chrapka-wrap {
    margin-top: clamp(-62px, -76.8387px + 3.2258vw, -52px);
    margin-bottom: clamp(-76px, -46.1935px - 3.871vw, -64px);
  }

  body.home .hero-chrapka-layer {
    width: clamp(96vw, 105.9355vw - 45.7013px, 100vw);
    margin-left: auto;
    margin-right: auto;
    transform: translateY(clamp(4px, -13.8065px + 3.871vw, 16px));
  }

  body.home .features-section {
    padding-top: clamp(240px, 50vw, 380px);
  }

  body.home .features-grid {
    margin-top: clamp(0px, calc((100vw - 700px) * 0.5), 20px);
  }
}

@media (min-width: 460px) and (max-width: 650px) {
  body.home .hero-title-text {
    top: calc(clamp(78px, calc(78px - ((100vw - 460px) / 190) * 4), 74px) + var(--hero-shift));
  }

  body.home .hero-sandwiches {
    transform: translateX(-50%) scale(clamp(.88, calc(.88 + ((100vw - 460px) / 190) * .06), .94));
  }
}

@media (min-width: 441px) and (max-width: 770px) {
  body.home .hero-stage {
    --hero-shift: clamp(40px, calc(-132.8097px + 39.2749vw), 170px);
    height: clamp(400.906px, calc(445.3818px - 5.7686vw), 420px);
  }

  body.home .hero-bg {
    top: 0;
    right: 0;
    bottom: clamp(0px, calc(232.93px - 30.2115vw), 100px);
    left: 0;
  }

  body.home .hero-title-text {
    top: clamp(110px, calc(147.2689px - 4.8338vw), 126px);
    width: 86%;
    max-width: 820px;
    font-size: clamp(35.2px, calc(8.1992px + 6.1366vw), 55.512px);
    z-index: 300;
  }

  body.home .hero-sandwiches {
    width: 100vw;
    bottom: clamp(-85.7969px, calc(255.6648px - 44.2882vw), 60.7969px);
    transform: translateX(-50%);
  }

  body.home .hero-sandwich-person-1,
  body.home .hero-sandwich-person-2 {
    width: clamp(44px, calc(2.7915px + 9.3656vw), 75px);
    bottom: clamp(-24px, calc(136.7221px - 20.8459vw), 45px);
  }

  body.home .hero-sandwich-person-1 {
    transform: translateX(clamp(-180px, calc(17.9909px - 25.6798vw), -95px));
  }

  body.home .hero-sandwich-person-2 {
    transform: translateX(clamp(65px, calc(-34.6979px + 22.6586vw), 140px));
  }

  body.home .hero-orange {
    --hero-orange-pad-top: clamp(0px, calc(-172.8097px + 39.2749vw), 130px);
    padding-bottom: clamp(120px, calc(93.4139px + 6.0423vw), 140px);
    margin-top: clamp(-120px, calc(-278.1873px + 35.9517vw), -1px);
  }

  body.home .hero-orange-inner {
    padding: 0 0 6px;
  }

  body.home .container.hero-orange-inner.center {
    width: min(clamp(424px, calc(424px + ((100vw - 440px) / 330) * 331), 755px), calc(100% - 16px));
    margin-left: auto;
    margin-right: auto;
    padding: 0 0 6px;
  }

  body.home .hero-orange-patterns {
    width: clamp(200%, calc(-155.56px + 255.56vw), 266.67%);
    transform: translateX(clamp(-30%, calc(-36.67% + 1.52vw), -25%))
      scale(clamp(.5, calc(.278 + .05vw), .6667));
    transform-origin: top center;
  }

  body.home .hero-orange-pattern-3 {
    right: clamp(-120px, calc(-280px + 36.36vw), 0px);
    bottom: clamp(-140px, calc(-286.67px + 33.33vw), -30px);
  }

  body.home .hero-subtitle-text {
    width: min(clamp(380px, calc(-57.7668px + 99.4924vw), 709.32px), 92%);
    font-size: clamp(21.12px, calc(8.1992px + 2.9366vw), 30.84px);
    margin-top: 12px;
    transform: none;
  }

  body.home .hero-copy {
    margin-top: 18px;
    font-size: clamp(9px, calc(8.3353px + 0.1511vw), 9.5px);
    line-height: 1.35;
    transform: none;
  }

  body.home .hero-chrapka-wrap {
    display: block;
    margin-top: clamp(-70px, calc(-120.5136px + 11.4804vw), -32px);
    margin-bottom: clamp(-140px, calc(23.0514px - 21.148vw), -70px);
  }

  body.home .features-chrapka-wrap {
    top: clamp(-240px, calc(39.5166px - 36.2538vw), -120px);
  }

  body.home .hero-chrapka-layer {
    width: clamp(475.1875px, calc(81.9624px + 89.3693vw), 771px);
    margin-left: clamp(-17.5938px, calc(-40.9812px + 5.3153vw), 0px);
    margin-right: 0;
    transform: translateY(0);
  }

  body.home .features-section {
    margin-top: clamp(-100px, calc(132.93px - 30.2115vw), 0px);
    padding-top: 160px;
  }

  body.home .features-grid {
    margin-top: clamp(0px, calc(-162.6667px + 36.9697vw), 122px);
  }

  body.home .feature-mid {
    width: min(100%, 360px);
    margin-left: auto;
    margin-right: auto;
  }

  body.home .about-farmer,
  body.home .about-orange-box {
    width: min(calc(100% - 24px), 416px);
    max-width: 416px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 441px) and (max-width: 469px) {
  body.home .container.hero-orange-inner.center {
    margin-top: 10px;
  }

  body.home .hero-subtitle-text {
    margin-top: clamp(44px, calc(140.36px - 18.68vw), 58px);
    transform: translateY(0);
  }
}

@media (min-width: 430px) and (max-width: 440px) {
  body.home .hero-title-text {
    font-size: clamp(35.2px, calc(567.6px - 121vw), 47.3px);
  }

  body.home .hero-subtitle-text {
    font-size: clamp(21.12px, calc(264.88px - 55.4vw), 26.66px);
  }
}

@media (min-width: 650px) and (max-width: 770px) {
  body.home .hero-orange {
    z-index: 310;
  }

  body.home .container.hero-orange-inner.center {
    margin-top: 14px;
    z-index: 320;
  }

  body.home .hero-subtitle-text {
    margin-top: 8px;
    transform: translateY(-28px);
    position: relative;
    z-index: 321;
  }

  body.home .hero-copy {
    margin-top: 10px;
    transform: translateY(-28px);
    position: relative;
    z-index: 321;
  }
}

@media (min-width: 431px) and (max-width: 740px) {
  .cards-grid {
    grid-template-columns: 1fr;
    justify-content: center;
    gap: 14px;
    width: calc(100% - 24px);
    margin: 8px auto 0;
    overflow-x: hidden;
  }

  .product-card,
  .product-card--cms {
    width: 100%;
    max-width: 420px;
    justify-self: center;
    margin: 0 auto;
  }

  .cards-grid .product-card--cms .product-card-media {
    left: 4%;
    right: 4%;
    height: 62%;
  }

  .cards-grid .product-card--cms .product-card-media img {
    left: 50%;
    transform: translateX(-49%);
    width: clamp(112%, calc(108% + 1vw), 118%);
    max-height: 112%;
    object-position: center center;
  }

  .cards-grid .product-card--cms img[src*="lista-card-02.webp"] {
    --image-left: 42%;
    width: clamp(110%, calc(106% + 1vw), 116%);
  }

  .cards-grid .product-card--cms .product-card-title {
    max-width: 82%;
    font-size: clamp(31px, 4.8vw, 36px);
    line-height: 1.03;
  }

  .cards-grid .product-card--cms .product-card-details p,
  .cards-grid .product-card--custom .product-card-details p {
    font-size: clamp(12px, 1.9vw, 14px);
    line-height: 1.35;
  }
}

@media (min-width: 771px) and (max-width: 1279px) {
  body.home .home-cards-grid {
    width: 100%;
    max-width: 930px;
    margin-left: auto;
    margin-right: auto;
    grid-template-columns: repeat(3, minmax(220px, 260px));
    justify-content: center;
    gap: clamp(12px, 1.6vw, 20px);
  }

  body.home .home-card {
    width: 100%;
    max-width: 260px;
    justify-self: center;
  }

  body.home .home-card img {
    max-width: 100%;
  }

  body.home .home-card-copy {
    left: 8%;
    right: 8%;
    top: 56%;
  }

  body.home .home-card-copy h4 {
    margin-bottom: clamp(12px, 1.2vw, 18px);
    font-size: clamp(42px, 3.8vw, 50px);
  }

  body.home .home-card-copy p {
    font-size: 12px;
    line-height: 1.32;
  }

  .cards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(14px, 1.4vw, 18px);
  }

  .product-card,
  .product-card--cms {
    width: 100%;
    max-width: clamp(240px, 28.2vw, 360px);
    justify-self: center;
  }

  .product-card--cms .product-card-title {
    max-width: 82%;
    top: 58%;
    font-size: clamp(27px, 2.3vw, 38px);
    line-height: 1.06;
    text-wrap: balance;
  }

  .product-card--cms .product-card-details p,
  .product-card--custom .product-card-details p {
    font-size: clamp(9px, .95vw, 14px);
    line-height: 1.34;
    margin-bottom: clamp(4px, .45vw, 6px);
  }

  .product-card--custom .product-card-details {
    bottom: 11%;
  }

  .product-card-btn {
    bottom: 12px;
    font-size: 8px;
    letter-spacing: .28em;
    padding: 6px 14px;
  }
}

@media (min-width: 770px) and (max-width: 1023px) {
  .cards-grid .product-card--cms .product-card-title {
    font-size: 36px;
    line-height: .9;
  }

  .cards-grid .product-card--cms .product-card-details p,
  .cards-grid .product-card--custom .product-card-details p {
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 6px;
  }

  body.home .about-stage {
    display: block;
    gap: 0;
    min-height: 620px;
    width: 100%;
    max-width: 747px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 771px) and (max-width: 1023px) {
  .cards-grid .product-card--cms .product-card-title {
    top: 60.8%;
  }

  .cards-grid .product-card--custom .product-card-btn {
    bottom: 20px;
  }
}

@media (min-width: 431px) and (max-width: 1023px) {
  .cards-grid .product-card--cms .product-card-title {
    font-size: 36px;
    line-height: .9;
  }

  .cards-grid .product-card--cms .product-card-details p,
  .cards-grid .product-card--custom .product-card-details p {
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 6px;
  }
}

@media (min-width: 1024px) and (max-width: 1279px) {
  body.home .about-stage {
    width: 100%;
    max-width: 1024px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 1024px) and (max-width: 1279px) {
  .cards-grid .product-card--cms .product-card-title {
    font-size: clamp(28px, calc(6px + 2.2vw), 34px);
    line-height: 1.08;
  }

  .cards-grid .product-card--cms .product-card-details p,
  .cards-grid .product-card--custom .product-card-details p {
    font-size: clamp(10.5px, calc(2.2px + .92vw), 13.8px);
    line-height: 1.36;
  }
}

@media (min-width: 1020px) and (max-width: 1279px) {
  .cards-grid {
    grid-template-columns: repeat(3, max-content);
    justify-content: center;
    column-gap: clamp(14px, 1.4vw, 18px);
  }
}

@media (min-width: 770px) and (max-width: 1024px) {
  body.home .hero-sandwich-person.hero-sandwich-person-1,
  body.home .hero-sandwich-person.hero-sandwich-person-2 {
    width: clamp(75px, calc(-0.79px + 9.843vw), 100px);
    bottom: clamp(-24px, calc(-114.95px + 11.811vw), 6px);
  }

  body.home .hero-sandwich-person.hero-sandwich-person-1 {
    transform: translateX(clamp(-220px, calc(-58.74px - 15.748vw), -180px));
  }

  body.home .hero-sandwich-person.hero-sandwich-person-2 {
    transform: translateX(clamp(120px, calc(200.64px - 7.874vw), 140px));
  }
}

@media (max-width: 375px) {
  .lista-badge { right: -15px; }
  body.home .hero-title-text { top: calc(116px + var(--hero-shift)); }
  .pack-copy { text-align: left; }
  .cta-illu {
    margin-top: -250px;
    right: 20px;
  }
  .zam-step-card-text {
    margin: 4px 1px 0;
  }
}

@media (max-width: 430px) {
  .lista-badge { right: -5px; }
  .cta-zam { padding: 200px 0 130px; }
  .cta-zam-inner { padding: 0; }
  .cta-illu { margin-top: -200px; }
  .cta-lead { margin: 0 16px; }
  .cta-form-lead p { max-width: 28ch; white-space: normal; }

  .lista-cta-title { font-weight: 800; }

  .cta-zam-inner {
    padding: 80px 0 16px;
    gap: 28px;
    transform: none !important;
    width: 100%;
    max-width: none;
    margin: 0;
    box-sizing: border-box;
    text-align: center;
  }
  .cta-zam .display,
  .cta-lead,
  .cta-contact,
  .cta-zam .display,
  .cta-lead,
  .cta-form-lead,
  .cta-contact,
  .cta-form-shell {
    max-width: 340px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  .contact-form {
    width: 100%;
    max-width: 340px;
  }
  .cta-zam .container.narrow {
    width: 100%;
    padding: 0 16px !important;
    box-sizing: border-box;
    margin: 0 auto !important;
  }
  .faq-title { margin-top: 0; }
  .faq-item h3 { font-size: 25px; }
  .faq-item {
    position: relative;
    border: 1px solid rgba(255, 255, 255, .6);
    border-radius: 20px;
    padding: 20px 56px 20px 45px;
  }
  .faq-trigger::after { font-size: 20px; }

}

/* Pack: two-model responsive system only */
@media (min-width: 430px) and (max-width: 1023px) {
  .pack-row {
    width: min(760px, calc(100% - 24px));
    margin: clamp(40px, 6vw, 56px) auto 20px;
    grid-template-columns: 1fr;
    gap: clamp(20px, 3vw, 28px);
  }

  .pack-media {
    --pack-media-width: clamp(250px, calc(250px + ((100vw - 413px) * .09)), 300px);
    margin: 0 auto;
    transform: none;
  }
}

@media (min-width: 431px) and (max-width: 500px) {
  .lista-badge {
    width: clamp(56px, calc(56px + ((100vw - 431px) / 69) * 28), 84px);
    right: clamp(-6px, calc(-5px - ((100vw - 431px) / 69) * 1), -5px);
    top: clamp(22%, calc(35% - ((100vw - 431px) / 69) * 13), 35%);
  }
}

@media (min-width: 430px) and (max-width: 740px) {
  .pack-media {
    transform: none;
  }
}

@media (min-width: 741px) and (max-width: 1023px) {
  .pack-row {
    width: min(920px, calc(100% - 48px));
    margin-top: clamp(88px, 10vw, 112px);
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: clamp(28px, 4vw, 44px);
    align-items: center;
    position: relative;
    z-index: 1;
    isolation: isolate;
    background: var(--green);
  }

  .pack-media {
    margin: 0;
  }

  .pack-copy {
    left: 0;
    transform: translateX(12px);
    padding: 0;
    text-align: left;
    max-width: 440px;
  }

  .pack-copy h2 {
    font-size: clamp(52px, 5.8vw, 64px);
  }

  .pack-intro,
  .pack-list {
    font-size: clamp(14px, 1.55vw, 16px);
    line-height: 1.42;
  }

  .faq-title {
    margin-top: clamp(124px, 15vw, 150px);
  }
}

@media (min-width: 771px) and (max-width: 1023px) {
  body.home .features-section {
    margin-top: -100px;
    padding-top: 160px;
    padding-bottom: 0;
  }

  body.home .features-grid {
    grid-template-columns: 1fr;
    align-items: center;
    gap: clamp(14px, calc(14px + ((100vw - 771px) / 252) * 14), 28px);
    margin-top: clamp(122px, calc(122px + ((100vw - 771px) / 252) * 50), 172px);
  }

  body.home .feature-col,
  body.home .feature-col:first-of-type,
  body.home .feature-col:last-of-type {
    text-align: center;
    padding-left: 0;
  }

  body.home .feature-col article,
  body.home .feature-col:last-of-type article {
    margin-bottom: 18px;
  }

  body.home .features-grid h3 {
    font-size: clamp(24px, calc(24px + ((100vw - 771px) / 252) * 14), 38px);
  }

  body.home .features-grid p {
    font-size: clamp(13px, calc(13px + ((100vw - 771px) / 252) * 1), 14px);
  }

  body.home .feature-mid .feature-sandwich {
    max-width: clamp(260px, calc(260px + ((100vw - 771px) / 252) * 460), 720px);
  }

  body.home .feature-mid .feature-arrows {
    width: clamp(92%, calc(92% + ((100vw - 771px) / 252) * 8%), 100%);
    transform: translateY(clamp(-10px, calc(-10px + ((100vw - 771px) / 252) * -30), -40px));
  }

  body.home .feature-mid .feature-arrow-extra {
    --feature-sandwich-size: clamp(260px, calc(260px + ((100vw - 771px) / 252) * 460), 720px);
    width: calc(var(--feature-sandwich-size) * 0.2153846);
    left: calc(50% - (var(--feature-sandwich-size) * 0.5538462));
    top: calc(var(--feature-sandwich-size) * 0.6923077);
  }
}

@media (width: 1024px) {
  body.home .feature-mid .feature-arrow-extra {
    --feature-sandwich-size: 588px;
    width: calc(var(--feature-sandwich-size) * 0.2153846);
    left: calc(50% - (var(--feature-sandwich-size) * 0.5538462));
    top: calc(var(--feature-sandwich-size) * 0.6923077);
  }
}

@media (min-width: 1024px) and (max-width: 1239px) {
  .pack-row {
    width: min(960px, calc(100% - 48px));
    margin: clamp(100px, 10vw, 140px) auto 0;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 56px;
    align-items: center;
  }

  .pack-media {
    margin: 0;
    justify-self: end;
    transform: translateX(28px);
  }

  .pack-photo {
    width: 100%;
  }
}

@media (min-width: 1240px) and (max-width: 1279px) {
  .pack-row {
    margin-bottom: 180px;
  }
}

@media (max-width: 429px) {
  .pack-media {
    --pack-media-width: clamp(210px, 60vw, 250px);
  }
}

@media (min-width: 430px) and (max-width: 430px) {
  .filters button {
    width: auto;
  }
}

@media (max-width: 1239px) {
  .pack-photo {
    width: 100%;
  }

  .pack-item {
    width: 160%;
    right: -62.4%;
    top: -16%;
    transform: rotate(-12deg);
  }
}

@media (min-width: 370px) and (max-width: 769px) {
  body.home .hero-title-text {
    margin-top: 8px;
  }
}

@media (min-width: 1120px) and (max-width: 1279px) {
  body.home .hero-title-text {
    margin-top: 8px;
  }
}

@media (min-width: 1120px) and (max-width: 1280px) {
  body.home .container.features-grid {
    margin-top: 15px;
  }
}

@media (min-width: 1024px) and (max-width: 1280px) {
  body.home .feature-mid .feature-arrow-extra {
    left: -12px;
  }
}

@media (min-width: 710px) and (max-width: 1023px) {
  .filters {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    gap: 10px;
    width: min(760px, calc(100% - 24px));
    margin: 32px auto 36px;
    padding: 0 16px;
    overflow-x: clip;
  }

  .filters button {
    flex: 0 0 auto;
    min-height: 40px;
    padding: 10px 18px;
    font-size: 10px;
    letter-spacing: .18em;
    white-space: nowrap;
  }
}

@media (max-width: 1023px) {
  .cards-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: min(360px, calc(100% - 24px));
    grid-template-columns: none;
    justify-content: start;
    justify-items: center;
    gap: 12px;
    width: calc(100% - 24px);
    margin: 8px auto 0;
    padding: 8px 0;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    touch-action: pan-x;
  }

  .cards-grid::-webkit-scrollbar {
    display: none;
  }

  .cards-grid .product-card,
  .cards-grid .product-card--cms {
    width: 100%;
    max-width: none;
    margin: 0;
    justify-self: center;
    scroll-snap-align: center;
    touch-action: pan-x;
  }
}
