/* ==========================================================================
   CIASTKA IRENKI — design "POSTER" (Anton + Lato, kolor-bloki, naklejki)
   Spis: 1. Tokeny  2. Fonty/Bazowe  3. Typografia  4. Przyciski
         5. Nagłówek  6. Hero  7. Marquee  8. Fale (dividery)
         9. Certyfikaty  10. O nas  11. Produkty  12. Bez mąki
         13. Gdzie kupić  14. B2B  15. Eko  16. Nagrody  17. FAQ
         18. Kontakt  19. Stopka  20. Animacje  21. RWD
   ========================================================================== */

/* 1. TOKENY ------------------------------------------------------------- */
:root {
  /* paleta plakatowa — bursztyn z logo + czekolada + krem + butelkowa zieleń */
  --orange:      #F39200;
  --orange-deep: #D27A00;
  --orange-text: #9C5800;  /* do drobnych linków — kontrast AA na kremie */
  --choco:       #2E1A0A;   /* tekst, ciemne sekcje, obrysy */
  --cream:       #FFF4E2;   /* tło strony */
  --paper:       #FFFBF2;   /* karty */
  --butter:      #FFD479;   /* akcent maślany */
  --green:       #14523F;   /* butelkowa zieleń — BIO / "bez mąki" */
  --mint:        #CBE6CF;
  --ink-soft:    #6B5132;   /* tekst pomocniczy na kremie */

  /* kolory linii produktowych (półka z pudełkami) */
  --c-owsiane:   #FFE2B0;
  --c-jaglane:   #FFEFC2;
  --c-bio:       #D8EBD2;
  --c-oatlanki:  #FFD9BE;
  --c-lan:       #DCE9F7;
  --c-vegan:     #CFEADF;
  --c-amarantki: #EFDCC4;
  --c-theone:    #EAE2D5;

  --font-display: "Anton", "Arial Narrow", Impact, sans-serif;
  --font-body: "Lato", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;

  --text-base: clamp(1.02rem, 0.96rem + 0.28vw, 1.16rem);
  --text-h1: clamp(2.9rem, 1.6rem + 6.2vw, 7rem);
  --text-h2: clamp(2.1rem, 1.5rem + 2.8vw, 3.9rem);
  --text-h3: clamp(1.2rem, 1.05rem + 0.6vw, 1.55rem);

  --space-section: clamp(4rem, 2.6rem + 5vw, 8rem);
  --container: 74rem;

  --radius: 26px;
  --radius-soft: 16px;
  --border: 2.5px solid var(--choco);
  --shadow-pop: 6px 6px 0 var(--choco);        /* twardy cień plakatowy */
  --shadow-pop-sm: 4px 4px 0 var(--choco);

  --duration: 220ms;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

/* 2. FONTY / BAZOWE ------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }

@font-face {
  font-family: "Anton";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/fonts/anton-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Anton";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/fonts/anton-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Lato";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/fonts/lato-400-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Lato";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/fonts/lato-400-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Lato";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/fonts/lato-700-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Lato";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/fonts/lato-700-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

html { scroll-behavior: smooth; scroll-padding-top: 5.5rem; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--choco);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
figure { margin: 0; }
ul { padding: 0; margin: 0; }

a { color: var(--orange-text); text-decoration-thickness: 2px; text-underline-offset: 3px; font-weight: 700; }
a:hover { color: var(--choco); }

:focus-visible {
  outline: 3px solid var(--orange);
  outline-offset: 3px;
  border-radius: 4px;
}

.container {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}
.narrow { max-width: 48rem; }

.sr-only {
  position: absolute; width: 1px; height: 1px;
  clip-path: inset(50%); overflow: hidden; white-space: nowrap;
}

/* 3. TYPOGRAFIA ---------------------------------------------------------- */
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 400;
  text-transform: uppercase;
  line-height: 0.98;
  letter-spacing: 0.01em;
  margin: 0 0 0.55em;
  text-wrap: balance;
}
h1 { font-size: var(--text-h1); }
h2 { font-size: var(--text-h2); }
h3 { font-size: var(--text-h3); letter-spacing: 0.03em; }
p  { margin: 0 0 1em; }

.eyebrow {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--choco);
  color: var(--cream);
  padding: 0.38rem 0.95rem;
  border-radius: 999px;
  margin: 0 0 1.3rem;
}
.eyebrow-invert { background: var(--cream); color: var(--choco); }

.lead { font-size: clamp(1.12rem, 1rem + 0.6vw, 1.35rem); max-width: 34em; font-weight: 700; }
.section-intro { color: var(--ink-soft); max-width: 40em; margin-bottom: 2.6rem; font-size: 1.05em; }

/* tekst konturowy — plakatowy akcent */
.outline-text {
  color: transparent;
  -webkit-text-stroke: 2.5px var(--cream);
  text-stroke: 2.5px var(--cream);
}
@supports not ((-webkit-text-stroke: 1px black) or (text-stroke: 1px black)) {
  .outline-text { color: var(--cream); }
}

/* 4. PRZYCISKI ------------------------------------------------------------ */
.btn {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 1.05rem;
  text-decoration: none;
  border-radius: 999px;
  padding: 0.85rem 1.9rem 0.78rem;
  border: var(--border);
  box-shadow: var(--shadow-pop-sm);
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out),
              background-color var(--duration), color var(--duration);
}
.btn:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--choco); }
.btn:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--choco); }

.btn-primary { background: var(--choco); color: var(--cream); box-shadow: 4px 4px 0 rgba(46, 26, 10, 0.35); }
.btn-primary:hover { background: var(--choco); color: var(--butter); box-shadow: 6px 6px 0 rgba(46, 26, 10, 0.35); }
.btn-ghost { background: var(--cream); color: var(--choco); }
.btn-ghost:hover { background: var(--butter); color: var(--choco); }
.btn-light { background: var(--butter); color: var(--choco); }
.btn-light:hover { background: var(--cream); }
.btn-small { font-size: 0.92rem; padding: 0.55rem 1.3rem 0.5rem; background: var(--orange); color: var(--choco); }
.btn-small:hover { background: var(--butter); }

/* 5. NAGŁÓWEK ------------------------------------------------------------ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--cream);
  border-bottom: var(--border);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 4.3rem;
}
.brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: var(--choco);
}
.brand img { border-radius: 50%; border: 2px solid var(--choco); }
.brand-name {
  font-family: var(--font-display);
  font-size: 1.45rem;
  letter-spacing: 0.16em;
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: clamp(0.8rem, 1.6vw, 1.5rem);
  list-style: none;
}
.nav-menu a:not(.btn) {
  text-decoration: none;
  color: var(--choco);
  font-weight: 700;
  font-size: 0.97rem;
  padding: 0.35rem 0.1rem;
  border-bottom: 3px solid transparent;
  transition: border-color var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}
.nav-menu a:not(.btn):hover { color: var(--orange-deep); border-bottom-color: var(--orange); }

.nav-toggle {
  display: none;
  background: var(--paper);
  border: var(--border);
  border-radius: 12px;
  width: 46px; height: 42px;
  cursor: pointer;
  position: relative;
  box-shadow: var(--shadow-pop-sm);
}
.nav-toggle-bar,
.nav-toggle-bar::before,
.nav-toggle-bar::after {
  content: "";
  position: absolute;
  left: 11px;
  width: 21px; height: 2.5px;
  background: var(--choco);
  border-radius: 2px;
  transition: transform var(--duration) var(--ease-out), opacity var(--duration);
}
.nav-toggle-bar { top: 19px; }
.nav-toggle-bar::before { left: 0; top: -6px; }
.nav-toggle-bar::after  { left: 0; top: 6px; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar { transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar::before { transform: rotate(-90deg) translateX(-6px); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bar::after { opacity: 0; }

/* 6. HERO — pomarańczowy kolor-blok z latającymi ciastkami ----------------- */
.hero {
  position: relative;
  background: var(--orange);
  color: var(--choco);
  overflow: clip;
}
.hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  padding-block: clamp(3.6rem, 3rem + 4.5vw, 7.5rem) clamp(4.5rem, 4rem + 4vw, 8rem);
}
.hero h1 { margin-bottom: 0.45em; }
.hero h1 .h1-line { display: block; }
.hero .lead { color: var(--choco); }

.cert-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  list-style: none;
  margin: 1.5rem 0 2.2rem;
}
.cert-chips li {
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.45rem 1rem 0.42rem;
  border: 2px solid var(--choco);
  border-radius: 999px;
  background: var(--cream);
  color: var(--choco);
  box-shadow: 3px 3px 0 var(--choco);
}
.cert-chips li::before { content: "✓ "; font-weight: 900; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; }

/* packshot w hero + naklejka */
.hero-visual {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
}
.hero-pack {
  width: min(78%, 380px);
  rotate: 4deg;
  border: var(--border);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-pop);
  transition: rotate 400ms var(--ease-out), transform 400ms var(--ease-out);
}
.hero-pack:hover { rotate: 0deg; transform: scale(1.02); }
.hero-sticker {
  position: absolute;
  top: -4%;
  right: 2%;
  width: clamp(120px, 13vw, 175px);
  rotate: 12deg;
  z-index: 3;
  filter: drop-shadow(4px 4px 0 rgba(46, 26, 10, 0.3));
  animation: sticker-wobble 6s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) { .hero-sticker { animation: none; } }
@keyframes sticker-wobble {
  0%, 100% { rotate: 12deg; }
  50% { rotate: 7deg; }
}

/* latające elementy (SVG, parallax z app.js przez --py) */
.floaty {
  position: absolute;
  z-index: 1;
  color: var(--choco);
  opacity: 0.95;
  translate: 0 calc(var(--py, 0) * 1px);
  pointer-events: none;
}
.floaty-cream { color: var(--cream); }
.floaty-butter { color: var(--butter); }
.f-1 { top: 9%;  left: 4%;  width: 64px; rotate: -14deg; }
.f-2 { top: 64%; left: 2%;  width: 44px; rotate: 20deg; opacity: .8; }
.f-3 { top: 13%; right: 7%; width: 52px; rotate: 24deg; }
.f-4 { bottom: 14%; right: 4%; width: 70px; rotate: -8deg; }
.f-5 { top: 42%; left: 44%; width: 38px; rotate: 0deg; opacity: .7; }
.f-6 { bottom: 8%; left: 30%; width: 50px; rotate: 14deg; opacity: .85; }

/* 7. MARQUEE — przesuwający się pasek haseł --------------------------------- */
.marquee {
  background: var(--choco);
  color: var(--butter);
  border-block: var(--border);
  overflow: hidden;
  padding-block: 0.65rem;
}
.marquee-track {
  display: flex;
  gap: 0;
  width: max-content;
  animation: marquee 28s linear infinite;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
}
.marquee-track span {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 0.95rem + 0.7vw, 1.5rem);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
  padding-inline: 0.9rem;
}
.marquee-track span::after { content: "✦"; color: var(--orange); padding-left: 1.8rem; }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* 8. FALE — dividery między kolor-blokami ----------------------------------- */
/* nazewnictwo: w-[kolor fali]-on-[kolor tła kolejnej sekcji] */
.wave {
  display: block;
  width: 100%;
  height: clamp(36px, 6vw, 84px);
  margin-bottom: -1px;
}
.w-cream-on-green { background: var(--green); color: var(--cream); }
.w-green-on-cream { background: var(--cream); color: var(--green); }
.w-cream-on-choco { background: var(--choco); color: var(--cream); }
.w-choco-on-mint  { background: var(--mint);  color: var(--choco); }
.w-mint-on-cream  { background: var(--cream); color: var(--mint); }

/* 9. SEKCJE / CERTYFIKATY ----------------------------------------------------- */
.section { padding-block: var(--space-section); }

.cert-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2.2vw, 1.8rem);
}
.cert-card {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-pop-sm);
  padding: 1.8rem 1.5rem 1.6rem;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), rotate 300ms var(--ease-out);
}
.cert-grid .cert-card:nth-child(odd)  { rotate: -1.3deg; }
.cert-grid .cert-card:nth-child(even) { rotate: 1.2deg; }
.cert-card:hover { rotate: 0deg; transform: translate(-3px, -3px); box-shadow: var(--shadow-pop); }
.cert-card h3 { margin-top: 1rem; }
.cert-card p { margin: 0; color: var(--ink-soft); font-size: 0.95rem; }
.cert-icon {
  display: inline-grid;
  place-items: center;
  width: 64px; height: 64px;
  border-radius: 50%;
  border: 2.5px dashed var(--choco);
  color: var(--orange-deep);
  background: var(--cream);
}
.cert-icon-green { color: var(--green); }

/* 10. O NAS --------------------------------------------------------------------- */
.about-grid {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
}
.about-photo { position: relative; }
.about-photo img {
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-pop);
  max-height: 540px;
  width: 100%;
  object-fit: cover;
  rotate: 1.5deg;
}
.about-badge {
  position: absolute;
  z-index: 2;
  top: -1.6rem;
  left: -1.2rem;
  rotate: -9deg;
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: 1.05rem;
  letter-spacing: 0.06em;
  background: var(--butter);
  border: var(--border);
  border-radius: 999px;
  box-shadow: var(--shadow-pop-sm);
  padding: 0.5rem 1.1rem 0.42rem;
}
.about-photo figcaption {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--ink-soft);
  margin-top: 1.1rem;
  text-align: center;
}
.without-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  list-style: none;
  margin-top: 1.4rem;
}
.without-list li {
  font-size: 0.88rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--cream);
  background: var(--green);
  border-radius: 999px;
  padding: 0.42rem 0.95rem;
}
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-top: clamp(2.6rem, 5vw, 4.2rem);
  padding-top: clamp(1.8rem, 3vw, 2.6rem);
  border-top: var(--border);
}
.stat { text-align: center; }
.stat strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 1.5rem + 2.2vw, 3.4rem);
  color: var(--orange-deep);
}
.stat span { font-size: 0.92rem; font-weight: 700; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.05em; }

/* 11. PRODUKTY — karty w kolorach linii ------------------------------------------- */
.section-products { background: var(--cream); }
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1.1rem, 2.2vw, 1.7rem);
}
.product-card {
  border: var(--border);
  border-radius: var(--radius);
  overflow: clip;
  display: flex;
  flex-direction: column;
  background: var(--paper);
  box-shadow: var(--shadow-pop-sm);
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}
.product-card:hover { transform: translate(-3px, -3px); box-shadow: var(--shadow-pop); }
.product-media {
  display: grid;
  place-items: center;
  padding: 1.4rem 1.4rem 1.1rem;
  border-bottom: var(--border);
}
.product-media img {
  width: 78%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  rotate: -3deg;
  transition: rotate 320ms var(--ease-out), transform 320ms var(--ease-out);
  filter: drop-shadow(5px 6px 0 rgba(46, 26, 10, 0.18));
}
.product-card:nth-child(even) .product-media img { rotate: 3deg; }
.product-card:hover .product-media img { rotate: 0deg; transform: scale(1.06); }
/* kolory półki */
.product-card.is-owsiane   .product-media { background: var(--c-owsiane); }
.product-card.is-jaglane   .product-media { background: var(--c-jaglane); }
.product-card.is-bio       .product-media { background: var(--c-bio); }
.product-card.is-oatlanki  .product-media { background: var(--c-oatlanki); }
.product-card.is-lan       .product-media { background: var(--c-lan); }
.product-card.is-vegan     .product-media { background: var(--c-vegan); }
.product-card.is-amarantki .product-media { background: var(--c-amarantki); }
.product-card.is-theone    .product-media { background: var(--c-theone); }

.product-body { padding: 1.25rem 1.3rem 1.45rem; display: flex; flex-direction: column; flex: 1; }
.product-body h3 { margin-bottom: 0.4rem; }
.product-body p { color: var(--ink-soft); font-size: 0.94rem; flex: 1; }
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  list-style: none;
  margin-top: 0.5rem;
}
.tags li {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--cream);
  background: var(--choco);
  padding: 0.3rem 0.72rem;
  border-radius: 999px;
}
.tags .tag-green { background: var(--green); }
.products-cta { text-align: center; margin: 3rem 0 0; }

/* 12. BEZ MĄKI — zielony plakat -------------------------------------------------- */
.section-flourless {
  background: var(--green);
  color: var(--cream);
  position: relative;
  overflow: clip;
}
.section-flourless .eyebrow { background: var(--cream); color: var(--green); }
.section-flourless h2 { color: var(--cream); font-size: clamp(2.4rem, 1.7rem + 3.4vw, 4.6rem); }
.section-flourless h2 em { font-style: normal; color: var(--butter); }
.section-flourless p { color: rgba(255, 244, 226, 0.88); }
.section-flourless strong { color: var(--butter); }
.flourless-floaty { position: absolute; color: rgba(255, 244, 226, 0.16); pointer-events: none; }
.ff-1 { top: 10%; right: 5%; width: 130px; rotate: 18deg; }
.ff-2 { bottom: 8%; left: 3%; width: 90px; rotate: -12deg; }

/* 13. GDZIE KUPIĆ ------------------------------------------------------------------ */
.retailer-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(1rem, 2.6vw, 2rem);
  list-style: none;
  margin: 2.4rem 0 3rem;
}
.retailer-strip li {
  background: #fff;
  border: var(--border);
  border-radius: var(--radius-soft);
  box-shadow: var(--shadow-pop-sm);
  padding: 0.7rem 1.2rem;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), rotate var(--duration) var(--ease-out);
}
.retailer-strip li:nth-child(odd) { rotate: -1.6deg; }
.retailer-strip li:nth-child(even) { rotate: 1.4deg; }
.retailer-strip li:hover { rotate: 0deg; transform: translate(-2px, -2px); box-shadow: var(--shadow-pop); }
.retailer-strip img { height: 54px; width: auto; }

.where-online {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.4rem;
  max-width: 54rem;
  margin-inline: auto;
}
.online-card {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  text-decoration: none;
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius-soft);
  box-shadow: var(--shadow-pop-sm);
  padding: 1.4rem 1.6rem;
  color: var(--choco);
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), background-color var(--duration);
}
.online-card:hover { transform: translate(-3px, -3px); box-shadow: var(--shadow-pop); background: var(--butter); color: var(--choco); }
.online-card strong { font-family: var(--font-display); font-weight: 400; text-transform: uppercase; font-size: 1.2rem; letter-spacing: 0.04em; }
.online-card span { color: var(--ink-soft); font-size: 0.95rem; font-weight: 700; }

/* 14. B2B — czekoladowy blok -------------------------------------------------------- */
.section-b2b {
  background: var(--choco);
  color: var(--cream);
}
.section-b2b .eyebrow { background: var(--orange); color: var(--choco); }
.section-b2b h2 { color: var(--cream); }
.section-b2b h2 em { font-style: normal; color: var(--orange); }
.section-b2b p { color: rgba(255, 244, 226, 0.85); }
.b2b-grid {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
}
.b2b-list {
  list-style: none;
  margin-top: 1.3rem;
  display: grid;
  gap: 0.6rem;
}
.b2b-list li { padding-left: 1.7rem; position: relative; font-weight: 700; }
.b2b-list li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.45em;
  width: 0.62rem; height: 0.62rem;
  border-radius: 50%;
  background: var(--orange);
  border: 2px solid var(--cream);
}
.b2b-contact {
  background: var(--orange);
  color: var(--choco);
  border: 2.5px solid var(--cream);
  border-radius: var(--radius);
  box-shadow: 6px 6px 0 rgba(255, 244, 226, 0.25);
  padding: 2rem 1.8rem;
  rotate: 1.5deg;
}
.b2b-contact-label {
  font-family: var(--font-display);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}
.b2b-contact-email a { color: var(--choco); font-weight: 700; font-size: 1.08rem; word-break: break-word; }
.b2b-contact-email a:hover { color: #fff; }
.b2b-contact-note { font-size: 0.9rem; font-weight: 700; margin: 0.6rem 0 1.4rem; }

/* 15. EKOIRENKI ----------------------------------------------------------------------- */
.section-eko { background: var(--mint); }
.section-eko .eyebrow { background: var(--green); }
.eko-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 54rem;
}
.eko-card {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-pop-sm);
  padding: 1.9rem 1.7rem;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}
.eko-card:hover { transform: translate(-3px, -3px); box-shadow: var(--shadow-pop); }
.eko-icon {
  display: inline-grid;
  place-items: center;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--green);
  color: var(--mint);
  margin-bottom: 1rem;
}
.eko-card h3 { color: var(--green); }
.eko-card p { margin: 0; color: var(--ink-soft); }

/* 16. NAGRODY ------------------------------------------------------------------------- */
.awards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.award-card {
  text-align: center;
  border: var(--border);
  border-radius: var(--radius);
  padding: 2.2rem 1.5rem 1.9rem;
  background: var(--paper);
  box-shadow: var(--shadow-pop-sm);
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), rotate var(--duration) var(--ease-out);
}
.awards-grid .award-card:nth-child(1) { rotate: -1.2deg; }
.awards-grid .award-card:nth-child(3) { rotate: 1.2deg; }
.award-card:hover { rotate: 0deg; transform: translate(-3px, -3px); box-shadow: var(--shadow-pop); }
.award-year {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--choco);
  background: var(--butter);
  border: 2px solid var(--choco);
  border-radius: 999px;
  padding: 0.3rem 1.05rem 0.2rem;
  margin-bottom: 1.1rem;
}
.award-card p { margin: 0; color: var(--ink-soft); font-size: 0.94rem; font-weight: 700; }

/* 17. FAQ --------------------------------------------------------------------------------- */
.faq-item {
  border: var(--border);
  border-radius: var(--radius-soft);
  background: var(--paper);
  box-shadow: var(--shadow-pop-sm);
  margin-bottom: 0.9rem;
}
.faq-item summary {
  cursor: pointer;
  font-weight: 700;
  font-size: 1.02rem;
  padding: 1.1rem 1.4rem;
  list-style: none;
  display: block;
  position: relative;
  padding-right: 3.2rem;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:focus-visible { outline-offset: -3px; border-radius: var(--radius-soft); }
.faq-item summary::after {
  content: "+";
  position: absolute;
  right: 1.2rem;
  top: 50%;
  translate: 0 -50%;
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--orange-deep);
  transition: rotate var(--duration) var(--ease-out);
}
.faq-item[open] summary::after { rotate: 45deg; }
.faq-item p { padding: 0 1.4rem 1.3rem; margin: 0; color: var(--ink-soft); }

/* 18. KONTAKT ------------------------------------------------------------------------------ */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.contact-card {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-pop-sm);
  padding: 1.9rem 1.7rem;
  transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}
.contact-card:hover { transform: translate(-3px, -3px); box-shadow: var(--shadow-pop); }
.contact-card p { margin: 0 0 0.3rem; color: var(--ink-soft); font-size: 0.94rem; }
.contact-email { margin-bottom: 0.6rem !important; }
.contact-email a, .contact-card-social a { font-weight: 700; font-size: 1.02rem; }
.company-data {
  display: block;
  font-style: normal;
  text-align: center;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--ink-soft);
  margin-top: 3rem;
  padding-top: 1.9rem;
  border-top: var(--border);
}

/* 19. STOPKA -------------------------------------------------------------------------------- */
.site-footer {
  background: var(--choco);
  color: var(--cream);
  padding-block: clamp(2.6rem, 5vw, 4.2rem) 1.6rem;
}
.footer-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2rem;
  align-items: flex-start;
  padding-bottom: 2.2rem;
}
.footer-brand { display: flex; gap: 1rem; align-items: center; }
.footer-brand img { border-radius: 50%; background: #fff; border: 2px solid var(--cream); }
.footer-brand p { margin: 0; font-family: var(--font-display); text-transform: uppercase; font-size: 1.05rem; line-height: 1.3; letter-spacing: 0.04em; }
.footer-nav { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.footer-nav a {
  color: var(--cream);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 700;
}
.footer-nav a:hover { color: var(--orange); }
.footer-eu {
  border-top: 2px solid rgba(255, 244, 226, 0.25);
  padding-top: 2rem;
  text-align: center;
}
.footer-eu img {
  background: #fff;
  border-radius: 12px;
  padding: 0.6rem 1rem;
  max-width: min(100%, 680px);
  margin-inline: auto;
  height: auto;
}
.footer-eu p { font-size: 0.87rem; margin: 1rem 0 0; color: rgba(255, 244, 226, 0.8); }
.footer-eu a { color: var(--cream); }
.footer-eu a:hover { color: var(--orange); }
.footer-legal {
  padding-top: 1.6rem;
  text-align: center;
  font-size: 0.82rem;
  color: rgba(255, 244, 226, 0.6);
}
.footer-legal p { margin: 0; }

/* 20. ANIMACJE (reveal — szanuje reduced-motion) -------------------------------------------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity 550ms var(--ease-out), transform 550ms var(--ease-out);
  }
  .reveal.is-visible { opacity: 1; transform: none; }
}

/* 21. RWD ------------------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .cert-grid, .product-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-visual { margin-top: 1.5rem; }
  .hero-pack { width: min(64%, 330px); }
  .hero-sticker { top: -2%; right: 6%; }
  .b2b-grid { grid-template-columns: 1fr; }
  .f-5 { display: none; }
}

@media (max-width: 720px) {
  .nav-toggle { display: block; }
  .nav-menu {
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: var(--cream);
    border-bottom: var(--border);
    padding: 0.5rem 1.25rem 1.2rem;
    display: none;
  }
  .nav-menu.is-open { display: flex; }
  .nav-menu li { border-bottom: 1.5px solid rgba(46, 26, 10, 0.18); }
  .nav-menu li:last-child { border-bottom: none; }
  .nav-menu a:not(.btn) { display: block; padding: 0.95rem 0.2rem; border-bottom: none; }
  .nav-cta { padding-top: 1rem; }
  .nav-cta .btn { display: block; text-align: center; }

  .about-grid { grid-template-columns: 1fr; }
  .about-badge { left: 0; }
  .stats-row { grid-template-columns: repeat(2, 1fr); row-gap: 1.7rem; }
  .awards-grid, .contact-grid, .where-online, .eko-grid { grid-template-columns: 1fr; }
  .retailer-strip { gap: 0.9rem; }
  .retailer-strip img { height: 40px; }
  .retailer-strip li { padding: 0.55rem 0.9rem; }
  .floaty { display: none; }
  .ff-1, .ff-2 { width: 70px; opacity: 0.5; }
}

@media (max-width: 480px) {
  .cert-grid, .product-grid { grid-template-columns: 1fr; }
  .hero-actions .btn { width: 100%; text-align: center; }
  .hero-sticker { width: 110px; }
}
