/* ==========================================================================
   amine — storefront
   v1.0 / kwiecień 2026
   Brandbook AMINE compliant
   ========================================================================== */

/* ----- DESIGN TOKENS ---------------------------------------------------- */
:root {
  /* Brand */
  --c-brand: #1d2b1e;
  --c-brand-2: #2a3d2b;
  --c-brand-3: #0f1a10;
  --c-accent: #656d41;
  --c-accent-2: #8a9168;
  --c-accent-soft: #e8ead8;

  /* Surfaces */
  --c-bg: #ffffff;
  --c-bg-soft: #faf9f5;
  --c-bg-cream: #f3f1ea;
  --c-bg-warm: #ece9dc;
  --c-bg-dark: #1d2b1e;

  /* Ink */
  --c-ink: #0f1110;
  --c-ink-soft: #2a2c2b;
  --c-text: #1a1c1b;
  --c-text-muted: #5b605c;
  --c-text-soft: #82857f;
  --c-border: #ebe9e0;
  --c-border-2: #d8d5c8;

  /* States */
  --c-sale: #b8341c;
  --c-success: #4f7a39;

  /* Typography */
  --ff-serif: 'Fraunces', 'Times New Roman', Georgia, serif;
  --ff-display: 'Inter', -apple-system, BlinkMacSystemFont, system-ui, 'Segoe UI', sans-serif;
  --ff-body: 'Poppins', -apple-system, BlinkMacSystemFont, system-ui, 'Segoe UI', sans-serif;

  /* Type scale (fluid) */
  --fs-display: clamp(48px, 7.6vw, 104px);
  --fs-h1: clamp(40px, 5.5vw, 72px);
  --fs-h2: clamp(32px, 4vw, 52px);
  --fs-h3: clamp(22px, 2.4vw, 32px);
  --fs-h4: clamp(18px, 1.4vw, 22px);
  --fs-lg: 18px;
  --fs-md: 16px;
  --fs-sm: 14px;
  --fs-xs: 12px;
  --fs-mini: 11px;

  /* Spacing — 4pt grid */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 20px; --s-6: 24px; --s-7: 32px; --s-8: 40px;
  --s-9: 48px; --s-10: 64px; --s-11: 80px; --s-12: 96px;
  --s-13: 128px; --s-14: 160px;

  /* Layout */
  --container: 1280px;
  --container-pad: 32px;
  --header-h: 80px;
  --topbar-h: 36px;

  /* Radii */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-2xl: 36px;
  --r-full: 9999px;

  /* Shadows */
  --sh-1: 0 1px 2px rgba(15,17,16,0.04);
  --sh-2: 0 1px 2px rgba(15,17,16,0.04), 0 4px 12px rgba(15,17,16,0.04);
  --sh-3: 0 1px 2px rgba(15,17,16,0.04), 0 6px 20px rgba(15,17,16,0.06), 0 16px 40px rgba(15,17,16,0.06);
  --sh-4: 0 2px 4px rgba(15,17,16,0.04), 0 12px 32px rgba(15,17,16,0.10), 0 32px 64px rgba(15,17,16,0.10);
  --sh-card: 0 1px 2px rgba(29,43,30,0.04), 0 6px 16px rgba(29,43,30,0.06);
  --sh-card-hover: 0 6px 12px rgba(29,43,30,0.08), 0 28px 56px rgba(29,43,30,0.14);
  --sh-button: 0 1px 2px rgba(29,43,30,0.10), 0 4px 12px rgba(29,43,30,0.10);

  /* Easing */
  --ease-smooth: cubic-bezier(0.32, 0.72, 0, 1);
  --ease-snappy: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

  /* Timings */
  --t-fast: 200ms;
  --t-base: 320ms;
  --t-slow: 600ms;
}

/* ----- RESET ------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent; }
html, body { height: 100%; }
body {
  font-family: var(--ff-body);
  font-size: var(--fs-md);
  line-height: 1.6;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'kern', 'liga', 'calt';
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
svg { flex-shrink: 0; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
input, textarea, select { font: inherit; }
ul, ol { list-style: none; }
::selection { background: var(--c-brand); color: #fff; }

/* ----- A11Y ------------------------------------------------------------- */
.sr-only {
  position: absolute !important; width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important; overflow: hidden !important;
  clip: rect(0,0,0,0) !important; white-space: nowrap !important; border: 0 !important;
}
.skip-link {
  position: absolute; top: -40px; left: 16px; background: var(--c-brand); color: #fff;
  padding: 10px 16px; border-radius: var(--r-sm); z-index: 100; transition: top var(--t-fast) var(--ease-out);
}
.skip-link:focus { top: 16px; }

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

/* ----- LAYOUT ----------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}

.section {
  padding: var(--s-10) 0;
  position: relative;
}
.section--alt { background: var(--c-bg-soft); }
@media (max-width: 768px) {
  .section { padding: var(--s-9) 0; }
  :root { --container-pad: 20px; }
}

.section__head {
  margin-bottom: var(--s-8);
  max-width: 640px;
}
.section__head--center { margin-inline: auto; text-align: center; }
.section__head--row {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--s-7); flex-wrap: wrap; max-width: none;
}
.section__head-side {
  display: flex; align-items: center; gap: var(--s-6); flex-wrap: wrap;
}

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: var(--s-4);
}
.eyebrow::before {
  content: '';
  width: 24px; height: 1px;
  background: var(--c-accent);
}
.eyebrow--light { color: var(--c-accent-2); }
.eyebrow--light::before { background: var(--c-accent-2); }

.section__title {
  font-family: var(--ff-display);
  font-size: var(--fs-h2);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--c-ink);
}
.section__lead {
  margin-top: var(--s-5);
  font-size: var(--fs-lg);
  color: var(--c-text-muted);
  line-height: 1.55;
  max-width: 560px;
}
.section__head--center .section__lead { margin-inline: auto; }

/* ----- TOPBAR ----------------------------------------------------------- */
.topbar {
  background: var(--c-brand);
  color: #fff;
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  height: var(--topbar-h);
  display: flex; align-items: center;
  position: relative; z-index: 60;
}
.topbar__inner {
  display: flex; align-items: center; justify-content: center;
  gap: var(--s-5);
}
.topbar--split .topbar__inner { justify-content: space-between; }
.topbar__promos { display: flex; align-items: center; gap: var(--s-5); }
.topbar__item { opacity: 0.9; }
.topbar__item strong { color: var(--c-accent-2); font-weight: 600; }
.topbar__sep { width: 4px; height: 4px; border-radius: 50%; background: rgba(255,255,255,0.3); }

/* Infolinia — klikalny tel: (na mobile uruchamia połączenie) */
.topbar__phone {
  display: inline-flex; align-items: center; gap: var(--s-2);
  color: #fff; white-space: nowrap; flex-shrink: 0;
}
.topbar__phone-icon { width: 14px; height: 14px; }
.topbar__phone-label { opacity: 0.85; }
.topbar__phone-num { color: var(--c-accent-2); font-weight: 600; letter-spacing: 0.02em; transition: color var(--t-fast) var(--ease-out); }
.topbar__phone:hover .topbar__phone-num { color: #fff; }

/* Bezpiecznik: moduły język/waluta wstrzykują własny <style> jako dziecko .topbar__right;
   reguła .topbar__right>* nadawała im display:inline-flex i surowy CSS wyciekał jako tekst.
   Wyższa specyficzność przywraca ukrycie (reguły lang/curr nadal działają na dropdownach). */
.topbar style { display: none; }

@media (max-width: 640px) {
  .topbar__inner { font-size: 11px; gap: var(--s-3); }
  .topbar__promos { gap: var(--s-3); }
  /* na mobile zostaw pierwszy komunikat + infolinię po prawej */
  .topbar__promos .topbar__sep,
  .topbar__promos .topbar__item:not(:first-child) { display: none; }
  .topbar__phone-label { display: none; }
}

/* ----- HEADER ----------------------------------------------------------- */
.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.72);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid transparent;
  transition: background var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.header.is-scrolled {
  background: rgba(255,255,255,0.88);
  border-bottom-color: var(--c-border);
}
.header__inner {
  height: var(--header-h);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr); /* logo | menu (środek strony) | akcje — boki równe, menu trzyma środek */
  align-items: center;
  gap: var(--s-7);
}
.header__inner > .logo { justify-self: start; }
.header__inner > .nav { justify-self: center; align-self: end; padding-bottom: 12px; } /* menu wyśrodkowane i opuszczone niżej */
.header__inner > .header__actions { justify-self: end; }

/* Logo */
.logo {
  display: inline-flex; align-items: center; position: relative;
  color: var(--c-brand);
  flex-shrink: 0;
  font-size: 50px; /* sterownik rozmiaru logo — wordmark i kropelka skalują się w em */
}
.logo__wordmark {
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 1em;
  line-height: 1;
  font-feature-settings: 'ss01', 'ss02';
  letter-spacing: -0.012em;
}
.logo__drop {
  position: absolute;
  width: 0.333em; height: 0.4286em;
  top: -0.0476em;
  left: 50.5%;
  color: var(--c-accent);
  transform: rotate(8deg);
}
.logo__drop svg { width: 100%; height: 100%; }
.logo--light { color: #fff; }
.logo--light .logo__drop { color: var(--c-accent-2); }

/* Nav */
.nav__list {
  display: flex; align-items: center; gap: var(--s-7);
}
.nav__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text);
  padding: 8px 0;
  letter-spacing: -0.005em;
  transition: color var(--t-fast) var(--ease-out);
}
.nav__link::after {
  content: '';
  position: absolute; left: 0; bottom: 0;
  width: 100%; height: 1.5px;
  background: var(--c-brand);
  transform: scaleX(0); transform-origin: right;
  transition: transform 360ms var(--ease-smooth);
}
.nav__link:hover { color: var(--c-brand); }
.nav__link:hover::after { transform: scaleX(1); transform-origin: left; }
.nav__link--quiet { color: var(--c-text-muted); }

@media (max-width: 1080px) {
  .nav { display: none; }
}

/* Header actions */
.header__actions {
  display: flex; align-items: center; gap: var(--s-2);
}
.icon-btn {
  width: 40px; height: 40px;
  border-radius: var(--r-full);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-text);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
  position: relative;
}
.icon-btn svg { width: 20px; height: 20px; }
.icon-btn:hover { background: var(--c-bg-cream); color: var(--c-brand); }
.icon-btn:active { transform: scale(0.94); }
.icon-btn--cart { background: var(--c-bg-cream); }
.icon-btn--cart:hover { background: var(--c-brand); color: #fff; }
.cart-badge {
  position: absolute; top: -2px; right: -2px;
  min-width: 18px; height: 18px; padding: 0 5px;
  border-radius: var(--r-full);
  background: var(--c-accent); color: #fff;
  font-size: 10px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  letter-spacing: 0;
}

@media (max-width: 1080px) {
  .icon-btn--desktop { display: none; }
}

.hamburger {
  width: 40px; height: 40px;
  display: none; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px;
  border-radius: var(--r-full);
}
.hamburger span {
  width: 18px; height: 1.5px; background: currentColor;
  transition: transform var(--t-base) var(--ease-smooth), opacity var(--t-fast) var(--ease-out);
}
.hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
@media (max-width: 1080px) {
  .hamburger { display: inline-flex; }
}

/* Mobile nav drawer */
@media (max-width: 1080px) {
  .nav.is-open {
    display: block;
    position: fixed; top: calc(var(--header-h) + var(--topbar-h)); left: 0; right: 0;
    background: #fff;
    border-top: 1px solid var(--c-border);
    border-bottom: 1px solid var(--c-border);
    padding: var(--s-7) var(--container-pad);
  }
  .nav.is-open .nav__list {
    flex-direction: column; align-items: stretch; gap: 0;
  }
  .nav.is-open .nav__link {
    padding: var(--s-4) 0;
    border-bottom: 1px solid var(--c-border);
    font-size: var(--fs-md);
  }
}

/* ----- BUTTONS ---------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s-3);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: -0.005em;
  padding: 14px 26px;
  border-radius: var(--r-full);
  transition: transform var(--t-fast) var(--ease-out),
              background var(--t-base) var(--ease-out),
              color var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out);
  white-space: nowrap;
  cursor: pointer;
}
.btn svg { width: 16px; height: 16px; flex-shrink: 0; transition: transform var(--t-base) var(--ease-snappy); }
.btn:active { transform: scale(0.97); }
.btn--block { width: 100%; }

.btn--primary {
  background: var(--c-brand); color: #fff;
  box-shadow: var(--sh-button);
}
.btn--primary:hover {
  background: var(--c-brand-2);
  box-shadow: 0 2px 4px rgba(29,43,30,0.14), 0 8px 24px rgba(29,43,30,0.20);
}
.btn--primary:hover svg { transform: translateX(3px); }

.btn--ghost {
  color: var(--c-brand);
  background: transparent;
  border: 1px solid var(--c-border-2);
}
.btn--ghost:hover { background: var(--c-bg-cream); border-color: var(--c-brand); }

/* ----- HERO ------------------------------------------------------------- */
.hero {
  position: relative;
  padding: var(--s-7) 0 var(--s-10);
  overflow: hidden;
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
}
.hero__bg {
  position: absolute; inset: 0;
  pointer-events: none;
}
.hero__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.45;
}
.hero__blob--1 {
  width: 460px; height: 460px;
  background: var(--c-accent-soft);
  top: -120px; left: -120px;
}
.hero__blob--2 {
  width: 360px; height: 360px;
  background: #d6dcc0;
  bottom: -80px; right: -80px;
}

.hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: var(--s-12);
  align-items: center;
}
@media (max-width: 980px) {
  .hero { padding: var(--s-11) 0; }
  .hero__inner { grid-template-columns: 1fr; gap: var(--s-10); }
}

.hero__title {
  font-family: var(--ff-display);
  font-size: var(--fs-display);
  font-weight: 600;
  line-height: 0.96;
  letter-spacing: -0.035em;
  color: var(--c-ink);
  margin-top: var(--s-2);
}
.hero__title em {
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--c-accent);
  letter-spacing: -0.02em;
}
.hero__lead {
  margin-top: var(--s-7);
  font-size: var(--fs-lg);
  line-height: 1.55;
  color: var(--c-text-muted);
  max-width: 480px;
}
.hero__actions {
  margin-top: var(--s-9);
  display: flex; gap: var(--s-3); flex-wrap: wrap;
}
.hero__meta {
  margin-top: var(--s-11);
  display: flex; gap: var(--s-9);
  padding-top: var(--s-7);
  border-top: 1px solid var(--c-border);
}
.meta-item dt {
  font-family: var(--ff-display);
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 600;
  color: var(--c-brand);
  line-height: 1;
  letter-spacing: -0.02em;
}
.meta-item dt span { color: var(--c-text-soft); font-weight: 400; }
.meta-item dd {
  margin-top: var(--s-2);
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}
@media (max-width: 480px) {
  .hero__meta { gap: var(--s-6); }
}

.hero__visual {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  min-height: 540px;
}

/* Hero featured card */
.hero-card {
  position: relative;
  background: #fff;
  border-radius: var(--r-2xl);
  padding: var(--s-9) var(--s-9) var(--s-7);
  box-shadow: var(--sh-3);
  width: 100%; max-width: 460px;
  display: flex; flex-direction: column; align-items: center;
  overflow: hidden;
}
.hero-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top, rgba(232,234,216,0.5) 0%, transparent 60%);
  pointer-events: none;
}
.hero-card__bottle { position: relative; padding-bottom: var(--s-7); }
.hero-card__info {
  position: relative;
  text-align: center;
  margin-top: var(--s-6);
  padding-top: var(--s-6);
  border-top: 1px solid var(--c-border);
  width: 100%;
}
.hero-card__info h3 {
  font-family: var(--ff-display);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--c-ink);
}
.hero-card__info p {
  margin-top: 4px;
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.hero-card__row {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: var(--s-5);
}
.rating-pill {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--c-bg-cream);
  color: var(--c-brand);
  padding: 6px 12px;
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* ----- BADGES ----------------------------------------------------------- */
.badge {
  display: inline-flex; align-items: center;
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: var(--r-full);
  background: var(--c-bg-cream);
  color: var(--c-text);
}
.badge--accent { background: var(--c-brand); color: #fff; }
.badge--sale { background: var(--c-sale); color: #fff; }
.badge--floating {
  position: absolute;
  top: var(--s-6);
  right: var(--s-6);
  z-index: 2;
}

/* ----- BOTTLE (CSS-DRAWN PRODUCT) --------------------------------------- */
.bottle {
  position: relative;
  width: 180px; height: 280px;
  display: flex; flex-direction: column; align-items: center;
  margin: 0 auto;
  --bottle-cap: var(--c-brand);
  --bottle-body: linear-gradient(180deg, #fafaf3 0%, #efece1 100%);
  --bottle-label: linear-gradient(180deg, #fff 0%, #f8f7f1 100%);
  --bottle-accent: var(--c-accent);
}
.bottle--md { width: 170px; height: 260px; }
.bottle--lg { width: 220px; height: 340px; }
.bottle--xl { width: 260px; height: 400px; }

.bottle__shadow {
  position: absolute;
  bottom: -10px; left: 50%;
  width: 86%; height: 18px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse, rgba(29,43,30,0.18) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(2px);
}
.bottle__cap {
  width: 56%; height: 16%;
  background: var(--bottle-cap);
  border-radius: 6px 6px 4px 4px;
  position: relative;
  box-shadow: inset 0 -4px 0 rgba(0,0,0,0.18), inset 0 2px 0 rgba(255,255,255,0.05);
}
.bottle__cap::after {
  content: '';
  position: absolute; left: 8%; right: 8%; top: 22%;
  height: 1px;
  background: rgba(0,0,0,0.25);
}
.bottle__cap::before {
  content: '';
  position: absolute; left: 8%; right: 8%; top: 38%;
  height: 1px;
  background: rgba(0,0,0,0.18);
}
.bottle__neck {
  width: 40%; height: 4%;
  background: linear-gradient(180deg, #c8c4b1 0%, #a8a48e 100%);
  border-radius: 0 0 3px 3px;
}
.bottle__body {
  flex: 1;
  width: 90%;
  background: var(--bottle-body);
  border-radius: 16px 16px 14px 14px;
  position: relative;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.6),
    inset 0 -2px 0 rgba(0,0,0,0.04),
    inset 1px 0 0 rgba(255,255,255,0.4),
    inset -1px 0 0 rgba(0,0,0,0.05);
  display: flex; align-items: center; justify-content: center;
  padding: 6%;
}
.bottle__body::before {
  content: '';
  position: absolute; left: 6%; top: 6%; width: 28%; height: 60%;
  background: linear-gradient(110deg, rgba(255,255,255,0.6) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(8px);
  pointer-events: none;
}
.bottle__label {
  width: 100%; height: 78%;
  background: var(--bottle-label);
  border-radius: 4px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 8% 6%;
  text-align: center;
  position: relative;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03);
  border: 1px solid rgba(29,43,30,0.06);
}
.bottle__label-brand {
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  color: var(--c-brand);
  line-height: 1;
  letter-spacing: -0.01em;
}
.bottle--md .bottle__label-brand { font-size: 18px; }
.bottle--xl .bottle__label-brand { font-size: 26px; }
.bottle__label-divider {
  width: 32px; height: 1px;
  background: var(--bottle-accent);
  margin: 8px 0;
}
.bottle__label-product {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--c-ink);
  line-height: 1.2;
}
.bottle--md .bottle__label-product { font-size: 11px; }
.bottle--xl .bottle__label-product { font-size: 14px; }
.bottle__label-sub {
  font-family: var(--ff-display);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--c-accent);
  margin-top: 4px;
}
.bottle__label-meta {
  font-family: var(--ff-body);
  font-size: 9px;
  color: var(--c-text-soft);
  margin-top: 10px;
  letter-spacing: 0.04em;
}
.bottle--md .bottle__label-meta { font-size: 8px; }
.bottle--xl .bottle__label-meta { font-size: 10px; }

/* Variants per product */
.bottle[data-product="d3k2"] { --bottle-cap: #c89b3a; --bottle-accent: #c89b3a; }
.bottle[data-product="d3k2"] .bottle__label-divider { background: #c89b3a; }
.bottle[data-product="d3k2"] .bottle__label-sub { color: #a47a1f; }

.bottle[data-product="multi"] { --bottle-cap: var(--c-brand); --bottle-accent: var(--c-accent); }

.bottle[data-product="collagen"] { --bottle-cap: #a8576a; --bottle-accent: #a8576a; }
.bottle[data-product="collagen"] .bottle__label-divider { background: #a8576a; }
.bottle[data-product="collagen"] .bottle__label-sub { color: #8a4357; }

.bottle[data-product="vitaminc"] { --bottle-cap: #c87a3a; --bottle-accent: #c87a3a; }
.bottle[data-product="vitaminc"] .bottle__label-divider { background: #c87a3a; }
.bottle[data-product="vitaminc"] .bottle__label-sub { color: #a85e1f; }

.bottle--jar { }
.bottle--jar .bottle__cap { width: 78%; height: 12%; border-radius: 8px 8px 4px 4px; }
.bottle--jar .bottle__neck { display: none; }
.bottle--jar .bottle__body { width: 96%; border-radius: 12px; }

.bottle[data-product="electrolytes"] { --bottle-cap: #1d2b1e; --bottle-accent: #d3995e; }
.bottle[data-product="electrolytes"] .bottle__label-divider { background: #d3995e; }
.bottle[data-product="electrolytes"] .bottle__label-sub { color: #b67a3e; }

/* ----- PRODUCT PHOTO (real bottle photos) ------------------------------- */
.product-photo {
  display: block;
  width: auto;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  margin: 0 auto;
  user-select: none;
  -webkit-user-drag: none;
  filter: drop-shadow(0 14px 10px rgba(29,43,30,0.18));
}
.product-photo--md      { max-height: 240px; max-width: 240px; }
.product-photo--lg      { max-height: 300px; max-width: 300px; }
.product-photo--xl      { max-height: 380px; max-width: 380px; }
.product-photo--feature { max-height: 340px; max-width: 340px; }
.product-photo--mega    { max-height: 190px; max-width: 190px; }
.product-photo--thumb {
  aspect-ratio: auto;
  width: 100%;
  height: 100%;
  filter: none;
  border-radius: var(--r-sm);
}
.product-photo--mini {
  display: inline-block;
  width: 28px;
  height: 28px;
  aspect-ratio: 1 / 1;
  vertical-align: middle;
  filter: none;
  border-radius: 4px;
  background: var(--c-bg-cream);
  flex-shrink: 0;
}
.product__media .product-photo {
  transition: transform 600ms var(--ease-smooth);
}
.product:hover .product__media .product-photo {
  transform: translateY(-8px) scale(1.03);
}

/* ----- TRUST BAR -------------------------------------------------------- */
.trust {
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  padding: var(--s-6) 0;
  background: #fff;
}
.trust__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-7);
  flex-wrap: wrap;
}
.trust__item {
  display: inline-flex; align-items: center; gap: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  letter-spacing: -0.005em;
  white-space: nowrap;
}
.trust__item svg { width: 22px; height: 22px; color: var(--c-accent); flex-shrink: 0; }
.trust__item strong { color: var(--c-ink); font-weight: 600; }
@media (max-width: 880px) {
  .trust__inner { justify-content: center; gap: var(--s-5); }
}

/* ----- CATEGORIES ------------------------------------------------------- */
.cats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
}
@media (max-width: 980px) { .cats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .cats { grid-template-columns: 1fr; } }

.cat {
  position: relative;
  display: flex; flex-direction: column;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-7);
  transition: transform var(--t-base) var(--ease-smooth),
              border-color var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-smooth);
  overflow: hidden;
  min-height: 280px;
}
.cat::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at bottom right, rgba(232,234,216,0) 0%, rgba(232,234,216,0) 100%);
  transition: background var(--t-base) var(--ease-out);
  pointer-events: none;
}
.cat:hover {
  transform: translateY(-4px);
  border-color: transparent;
  box-shadow: var(--sh-card-hover);
}
.cat:hover::before { background: radial-gradient(ellipse at bottom right, rgba(232,234,216,0.55) 0%, rgba(232,234,216,0) 60%); }
.cat__icon-wrap { position: relative; z-index: 1; }
.cat__icon {
  width: 56px; height: 56px;
  border-radius: var(--r-md);
  background: var(--c-bg-cream);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--s-7);
  transition: background var(--t-base) var(--ease-out), color var(--t-base) var(--ease-out);
}
.cat__icon svg { width: 26px; height: 26px; }
.cat:hover .cat__icon { background: var(--c-brand); color: #fff; }

.cat__body { position: relative; z-index: 1; flex: 1; display: flex; flex-direction: column; }
.cat__count {
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-accent);
  font-weight: 500;
}
.cat__title {
  margin-top: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--c-ink);
}
.cat__desc {
  margin-top: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.55;
}
.cat__arrow {
  margin-top: auto;
  padding-top: var(--s-6);
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  background: var(--c-bg-cream);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--t-base) var(--ease-out), color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-snappy);
}
.cat__arrow svg { width: 14px; height: 14px; }
.cat:hover .cat__arrow {
  background: var(--c-brand); color: #fff;
  transform: translateX(4px);
}

/* ----- LINK ARROW ------------------------------------------------------- */
.link-arrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-brand);
  padding: 8px 0;
  position: relative;
  transition: gap var(--t-base) var(--ease-snappy);
}
.link-arrow svg { width: 14px; height: 14px; }
.link-arrow:hover { gap: var(--s-3); }

/* ----- FILTER PILLS ----------------------------------------------------- */
.filter-pills {
  display: inline-flex;
  gap: 4px;
  background: var(--c-bg-cream);
  border-radius: var(--r-full);
  padding: 4px;
}
.pill {
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  padding: 8px 16px;
  border-radius: var(--r-full);
  color: var(--c-text-muted);
  letter-spacing: -0.005em;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.pill:hover { color: var(--c-brand); }
.pill.is-active { background: #fff; color: var(--c-brand); box-shadow: var(--sh-1); }

/* ----- PRODUCTS --------------------------------------------------------- */
.products {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
}
@media (max-width: 1020px) { .products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .products { grid-template-columns: 1fr; gap: var(--s-5); } }

.product {
  position: relative;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  transition: transform var(--t-base) var(--ease-smooth),
              border-color var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-smooth);
  display: flex; flex-direction: column;
}
.product__link {
  position: absolute; inset: 0;
  z-index: 1;
  text-indent: -9999px;
  overflow: hidden;
  border-radius: inherit;
}
.product__link:focus-visible {
  outline: 2px solid var(--c-accent);
  outline-offset: -4px;
  border-radius: var(--r-xl);
}
.product:hover {
  transform: translateY(-4px);
  border-color: transparent;
  box-shadow: var(--sh-card-hover);
}

.product__media {
  position: relative;
  background: linear-gradient(180deg, var(--c-bg-soft) 0%, #fff 100%);
  padding: var(--s-9) var(--s-7) var(--s-7);
  height: 320px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.product__media::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 80%, rgba(232,234,216,0.4) 0%, transparent 60%);
  pointer-events: none;
}
.product__media .bottle {
  transition: transform 600ms var(--ease-smooth);
}
.product:hover .product__media .bottle {
  transform: translateY(-8px) scale(1.03);
}

.product__badges {
  position: absolute; top: var(--s-5); left: var(--s-5);
  display: flex; gap: var(--s-2);
  z-index: 2;
}
.product__wish {
  position: absolute; top: var(--s-5); right: var(--s-5);
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.85);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  color: var(--c-text-muted);
  display: inline-flex; align-items: center; justify-content: center;
  z-index: 2;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.product__wish svg { width: 18px; height: 18px; }
.product__wish:hover { background: #fff; color: var(--c-sale); transform: scale(1.06); }
.product__wish.is-active { color: var(--c-sale); }

.product__body {
  padding: var(--s-6) var(--s-6) var(--s-6);
  flex: 1;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--c-border);
}
.product__cat {
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-accent);
  font-weight: 500;
}
.product__title {
  margin-top: var(--s-2);
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--c-ink);
  line-height: 1.25;
}
.product__desc {
  margin-top: 6px;
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.5;
  min-height: 42px;
}
.product__rating {
  margin-top: var(--s-4);
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
}
.stars {
  color: #d8a23a;
  letter-spacing: 1px;
  font-size: 12px;
}
.product__foot {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-3);
}

/* Price */
.price {
  display: inline-flex; align-items: baseline; gap: var(--s-2);
}
.price__now {
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.015em;
}
.price__was {
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  text-decoration: line-through;
}

.add-cart {
  height: 40px;
  padding: 0 18px 0 14px;
  border-radius: var(--r-full);
  background: var(--c-brand);
  color: #fff;
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.005em;
  white-space: nowrap;
  box-shadow: 0 1px 2px rgba(29,43,30,0.08), 0 4px 10px rgba(29,43,30,0.10);
  transition: background var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}
.product:hover .product__title { color: var(--c-brand); }
.add-cart svg { width: 16px; height: 16px; transition: transform var(--t-fast) var(--ease-out); }
.add-cart__label { line-height: 1; }
.add-cart:hover {
  background: var(--c-brand-2);
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(29,43,30,0.12), 0 8px 18px rgba(29,43,30,0.18);
}
.add-cart:hover svg { transform: rotate(90deg); }
.add-cart:active { transform: scale(0.97); }
@media (max-width: 380px) {
  .add-cart { padding: 0 14px 0 12px; font-size: 12px; }
}

/* ----- FEATURED (PRODUCT DETAIL) ---------------------------------------- */
.featured {
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
}
.featured__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-12);
  align-items: center;
}
@media (max-width: 980px) { .featured__inner { grid-template-columns: 1fr; gap: var(--s-9); } }

.featured__visual {
  position: relative;
  background: var(--c-bg-cream);
  border-radius: var(--r-2xl);
  padding: var(--s-12) var(--s-9) var(--s-9);
  min-height: 560px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  overflow: hidden;
}
.featured__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 30% 30%, rgba(101,109,65,0.15) 0%, transparent 55%),
    radial-gradient(circle at 70% 80%, rgba(255,255,255,0.6) 0%, transparent 55%);
  pointer-events: none;
}
.featured__visual .bottle {
  position: relative; z-index: 1;
  transition: transform 800ms var(--ease-smooth);
}
.featured__inner:hover .featured__visual .bottle { transform: translateY(-6px); }

.featured__thumbs {
  position: absolute;
  bottom: var(--s-7); left: 50%;
  transform: translateX(-50%);
  display: flex; gap: var(--s-3);
  z-index: 2;
}
.thumb {
  width: 56px; height: 56px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.7);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid transparent;
  transition: border-color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
  position: relative;
}
.thumb::before {
  content: '';
  position: absolute; inset: 8px;
  border-radius: 6px;
  background: linear-gradient(180deg, #fff 30%, #efece1 100%);
  border: 1px solid rgba(29,43,30,0.06);
}
.thumb.is-active { border-color: var(--c-brand); }
.thumb:hover { transform: translateY(-2px); }

.featured__info { padding-left: var(--s-2); }
.featured__title {
  font-family: var(--ff-display);
  font-size: clamp(36px, 4.4vw, 56px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--c-ink);
  margin-top: var(--s-2);
}
.featured__rating {
  margin-top: var(--s-5);
  display: inline-flex; align-items: center; gap: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.featured__rating .stars { font-size: 16px; }
.featured__rating strong { color: var(--c-ink); font-weight: 600; }

.featured__lead {
  margin-top: var(--s-6);
  font-size: var(--fs-lg);
  line-height: 1.6;
  color: var(--c-text);
}

.features {
  margin-top: var(--s-7);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.features li {
  display: flex; align-items: center; gap: var(--s-3);
  font-size: var(--fs-md);
  color: var(--c-text);
}
.features li svg {
  width: 18px; height: 18px; padding: 4px;
  background: var(--c-accent-soft);
  color: var(--c-brand);
  border-radius: 50%;
  flex-shrink: 0; box-sizing: content-box;
}
.features li strong { color: var(--c-ink); font-weight: 600; }

/* Variants */
.featured__variants {
  margin-top: var(--s-9);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
}
@media (max-width: 480px) { .featured__variants { grid-template-columns: 1fr; } }

.variant {
  position: relative;
  text-align: left;
  padding: var(--s-5) var(--s-5);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  background: #fff;
  transition: border-color var(--t-base) var(--ease-out), background var(--t-base) var(--ease-out);
  display: flex; flex-direction: column; gap: 4px;
}
.variant:hover { border-color: var(--c-accent); }
.variant.is-active {
  border-color: var(--c-brand);
  background: var(--c-bg-cream);
}
.variant.is-active::after {
  content: '';
  position: absolute; top: var(--s-3); right: var(--s-3);
  width: 18px; height: 18px;
  background: var(--c-brand);
  border-radius: 50%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='m3 8 3.5 3.5L13 5'/></svg>");
  background-size: 12px;
  background-position: center;
  background-repeat: no-repeat;
}
.variant__name {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: var(--fs-sm);
  color: var(--c-ink);
}
.variant__price {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-brand);
}
.variant__tag {
  font-size: var(--fs-mini);
  color: var(--c-accent);
  font-weight: 500;
  margin-top: 4px;
  letter-spacing: 0.02em;
}

/* Buy block */
.featured__buy {
  margin-top: var(--s-8);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-4);
  align-items: center;
}
@media (max-width: 540px) {
  .featured__buy { grid-template-columns: 1fr 1fr; }
  .featured__buy .btn--block { grid-column: 1 / -1; }
}

.qty {
  display: inline-flex; align-items: center;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-full);
  padding: 4px;
  height: 48px;
}
.qty button {
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  font-size: 18px;
  color: var(--c-brand);
  transition: background var(--t-fast) var(--ease-out);
}
.qty button:hover { background: var(--c-bg-cream); }
.qty input {
  width: 36px;
  text-align: center;
  border: 0; background: transparent;
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: var(--fs-md);
  color: var(--c-ink);
  outline: none;
}

.featured__price {
  display: flex; flex-direction: column;
}
.featured__price .price__now { font-size: clamp(24px, 2.5vw, 30px); }
.featured__price .price__was { font-size: var(--fs-sm); }

.featured__perks {
  margin-top: var(--s-7);
  padding-top: var(--s-7);
  border-top: 1px solid var(--c-border);
  display: flex; gap: var(--s-7); flex-wrap: wrap;
}
.featured__perks li {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.featured__perks li svg {
  width: 18px; height: 18px;
  color: var(--c-accent);
}
.featured__perks li strong { color: var(--c-ink); font-weight: 600; }

/* ----- WHY ------------------------------------------------------------- */
.why {
  background: var(--c-brand);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.why::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, var(--c-accent) 0%, transparent 60%);
  opacity: 0.3;
  filter: blur(60px);
}
.why::after {
  content: '';
  position: absolute;
  bottom: -200px; left: -200px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, var(--c-accent-2) 0%, transparent 60%);
  opacity: 0.2;
  filter: blur(60px);
}
.why .container { position: relative; z-index: 1; }
.why .section__title { color: #fff; }
.why .section__lead { color: rgba(255,255,255,0.7); }

.why__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-2);
  border-top: 1px solid rgba(255,255,255,0.12);
}
@media (max-width: 980px) { .why__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .why__grid { grid-template-columns: 1fr; } }

.why__item {
  padding: var(--s-9) var(--s-6) var(--s-7) 0;
  border-right: 1px solid rgba(255,255,255,0.12);
}
.why__item:last-child { border-right: 0; }
@media (max-width: 980px) {
  .why__item:nth-child(2) { border-right: 0; }
  .why__item:nth-child(1), .why__item:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,0.12); }
}
@media (max-width: 540px) {
  .why__item { border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.12); }
  .why__item:last-child { border-bottom: 0; }
}

.why__num {
  display: inline-block;
  font-family: var(--ff-serif);
  font-style: italic;
  font-size: 36px;
  font-weight: 400;
  color: var(--c-accent-2);
  letter-spacing: -0.02em;
}
.why__item h3 {
  margin-top: var(--s-5);
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: #fff;
}
.why__item p {
  margin-top: var(--s-3);
  font-size: var(--fs-sm);
  color: rgba(255,255,255,0.7);
  line-height: 1.6;
}

/* ----- NEWSLETTER ------------------------------------------------------- */
.newsletter {
  padding: var(--s-12) 0;
  background: var(--c-bg-cream);
  position: relative;
  overflow: hidden;
}
.newsletter::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 800px; height: 800px;
  background: radial-gradient(circle, rgba(232,234,216,0.6) 0%, transparent 60%);
  transform: translate(-50%, -50%);
  filter: blur(60px);
}
.newsletter__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-9);
  align-items: center;
}
@media (max-width: 880px) { .newsletter__inner { grid-template-columns: 1fr; gap: var(--s-7); } }

.newsletter__title {
  margin-top: var(--s-3);
  font-family: var(--ff-display);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--c-ink);
}
.newsletter__text p {
  margin-top: var(--s-4);
  font-size: var(--fs-md);
  color: var(--c-text-muted);
  line-height: 1.6;
}

.newsletter__form {
  display: flex;
  gap: var(--s-3);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  padding: 6px;
  box-shadow: var(--sh-2);
}
.newsletter__form input {
  flex: 1;
  border: 0;
  background: transparent;
  padding: 12px var(--s-5);
  font-size: var(--fs-md);
  color: var(--c-ink);
  outline: none;
  min-width: 0;
}
.newsletter__form input::placeholder { color: var(--c-text-soft); }
.newsletter__form .btn { flex-shrink: 0; }

/* ----- FOOTER ----------------------------------------------------------- */
.footer {
  background: var(--c-brand-3);
  color: rgba(255,255,255,0.7);
  padding: var(--s-12) 0 var(--s-7);
  font-size: var(--fs-sm);
}
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--s-9);
}
@media (max-width: 980px) { .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--s-7); } }
@media (max-width: 540px) { .footer__grid { grid-template-columns: 1fr; } }

.footer__brand .logo { margin-bottom: var(--s-5); }
.footer__brand p { line-height: 1.6; max-width: 360px; }
.socials {
  margin-top: var(--s-6);
  display: flex; gap: var(--s-3);
}
.socials a {
  width: 40px; height: 40px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.8);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.socials a svg { width: 18px; height: 18px; }
.socials a:hover { background: var(--c-accent); color: #fff; transform: translateY(-2px); }

.footer__col h4 {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.02em;
  margin-bottom: var(--s-5);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: var(--fs-xs);
}
.footer__col ul { display: flex; flex-direction: column; gap: var(--s-3); }
.footer__col a {
  color: rgba(255,255,255,0.65);
  transition: color var(--t-fast) var(--ease-out);
}
.footer__col a:hover { color: #fff; }

.footer__bottom {
  margin-top: var(--s-10);
  padding-top: var(--s-6);
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5);
  font-size: var(--fs-xs);
  flex-wrap: wrap;
  color: rgba(255,255,255,0.5);
}
.footer__legal {
  display: flex; gap: var(--s-5);
}
.footer__legal a { color: rgba(255,255,255,0.5); transition: color var(--t-fast); }
.footer__legal a:hover { color: rgba(255,255,255,0.9); }
.payments {
  display: flex; gap: var(--s-2);
}
.pay {
  font-family: var(--ff-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 5px 8px;
  background: rgba(255,255,255,0.06);
  border-radius: 4px;
  color: rgba(255,255,255,0.6);
}

/* ----- REVEAL ANIMATIONS ------------------------------------------------ */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 800ms var(--ease-smooth), transform 800ms var(--ease-smooth);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  [data-reveal] { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}

/* ==========================================================================
   MEGA MENU
   ========================================================================== */
.nav__chevron {
  width: 11px; height: 11px;
  margin-left: 0;
  margin-top: 1px;
  stroke-width: 2.2;
  transition: transform var(--t-fast) var(--ease-out), opacity var(--t-fast) var(--ease-out);
  opacity: 0.7;
}
.nav__item.has-mega:hover .nav__chevron { opacity: 1; }
.nav__item.has-mega.is-active .nav__chevron {
  transform: rotate(180deg);
  opacity: 1;
}
.nav__item.has-mega.is-active .nav__link {
  color: var(--c-brand);
}
.nav__item.has-mega.is-active .nav__link::after {
  transform: scaleX(1); transform-origin: left;
}

.megas {
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  z-index: 40;
  pointer-events: none;
}

.mega {
  position: absolute;
  top: 0; left: 0; right: 0;
  background: rgba(255, 255, 255, 0.985);
  -webkit-backdrop-filter: saturate(200%) blur(40px);
  backdrop-filter: saturate(200%) blur(40px);
  border-bottom: 1px solid var(--c-border);
  box-shadow:
    0 1px 0 rgba(15, 17, 16, 0.04),
    0 24px 48px rgba(15, 17, 16, 0.12),
    0 48px 96px rgba(15, 17, 16, 0.08);
  padding: var(--s-9) 0 var(--s-10);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-12px);
  transition:
    opacity 280ms var(--ease-smooth),
    transform 360ms var(--ease-smooth),
    visibility 360ms;
  pointer-events: none;
}

/* Backdrop dim behind mega — focuses attention, masks page below */
.mega-backdrop {
  position: fixed;
  top: calc(var(--topbar-h) + var(--header-h));
  left: 0; right: 0; bottom: 0;
  background: rgba(15, 17, 16, 0.35);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 280ms var(--ease-smooth), visibility 360ms;
  z-index: 39;
  pointer-events: none;
}
.mega-backdrop.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
@media (max-width: 1080px) {
  .mega-backdrop { display: none; }
}
.mega.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.mega__inner {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 320px;
  gap: var(--s-10);
  align-items: start;
}
@media (max-width: 1180px) {
  .mega__inner {
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--s-9);
  }
  .mega__feature { display: none; }
}

.mega__heading {
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: var(--s-5);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--c-border);
}

.mega__list {
  display: flex; flex-direction: column;
}
.mega__list a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 0;
  font-family: var(--ff-display);
  font-size: 15px;
  color: var(--c-text);
  font-weight: 500;
  letter-spacing: -0.005em;
  transition:
    color var(--t-fast) var(--ease-out),
    padding-left 240ms var(--ease-snappy);
  position: relative;
}
.mega__list a::before {
  content: '';
  position: absolute;
  left: -2px; top: 50%;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--c-accent);
  transform: translateY(-50%) scale(0);
  transition: transform 240ms var(--ease-snappy);
}
.mega__list a:hover {
  color: var(--c-brand);
  padding-left: 14px;
}
.mega__list a:hover::before { transform: translateY(-50%) scale(1); }
.mega__list a small {
  font-family: var(--ff-display);
  font-size: 11px;
  color: var(--c-text-soft);
  font-weight: 500;
  background: var(--c-bg-cream);
  padding: 2px 8px;
  border-radius: var(--r-full);
  letter-spacing: 0;
}

.mega__more {
  display: inline-flex; align-items: center; gap: var(--s-2);
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--c-border);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-brand);
  transition: gap var(--t-fast) var(--ease-snappy);
  width: 100%;
}
.mega__more:hover { gap: var(--s-3); }
.mega__more svg { width: 14px; height: 14px; }

.mega__feature {
  background: linear-gradient(180deg, var(--c-bg-cream) 0%, #f8f6ee 100%);
  border-radius: var(--r-xl);
  padding: var(--s-7) var(--s-6);
  position: relative;
  display: flex; flex-direction: column;
  align-items: center;
  text-align: center;
  overflow: hidden;
}
.mega__feature::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at top, rgba(232,234,216,0.5) 0%, transparent 60%);
  pointer-events: none;
}
.mega__feature .badge {
  position: absolute;
  top: var(--s-5); left: var(--s-5);
  z-index: 2;
}
.mega__bottle {
  position: relative;
  z-index: 1;
  padding: var(--s-3) 0;
}
.bottle--mega { width: 130px; height: 200px; }
.bottle--mega .bottle__label-brand { font-size: 14px; }
.bottle--mega .bottle__label-product { font-size: 9px; letter-spacing: 0.14em; }
.bottle--mega .bottle__label-meta { font-size: 7px; }
.bottle--mega .bottle__label-divider { width: 22px; margin: 5px 0; }
.bottle--mega.bottle--jar .bottle__cap { height: 12%; }

.mega__feature-info {
  position: relative;
  z-index: 1;
  width: 100%;
  margin-top: var(--s-3);
}
.mega__feature-info h5 {
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.015em;
}
.mega__feature-row {
  margin-top: var(--s-3);
  display: flex; align-items: center; justify-content: center;
  gap: var(--s-3); flex-wrap: wrap;
}
.mega__feature-row .rating-pill {
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--c-border);
}
.mega__feature-row .price__now { font-size: 18px; }
.mega__feature-row .price__was { font-size: var(--fs-xs); }
.mega__feature-info .btn {
  margin-top: var(--s-5);
  width: 100%;
}

.btn--sm {
  padding: 11px 18px;
  font-size: var(--fs-xs);
}
.btn--sm svg { width: 14px; height: 14px; }

@media (max-width: 1080px) {
  .megas { display: none; }
  .nav__chevron { display: none; }
}

/* ==========================================================================
   CATEGORIES — RICH TILES
   ========================================================================== */
.cat {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-2xl);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform var(--t-base) var(--ease-smooth),
              border-color var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-smooth);
  text-decoration: none;
  min-height: 0;
  padding: 0;
}
.cat::before { display: none; }
.cat:hover {
  transform: translateY(-6px);
  border-color: transparent;
  box-shadow: var(--sh-card-hover);
}

.cat__media {
  position: relative;
  height: 150px;
  overflow: hidden;
  background: var(--c-brand);
}
.cat__pattern {
  position: absolute; inset: 0;
  transition: transform 1000ms var(--ease-smooth);
  pointer-events: none;
}
.cat__pattern::before,
.cat__pattern::after {
  content: '';
  position: absolute;
  border-radius: 50%;
}
.cat__pattern::before {
  width: 320px; height: 320px;
  top: -120px; right: -120px;
  background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 60%);
  filter: blur(20px);
}
.cat__pattern::after {
  width: 240px; height: 240px;
  bottom: -100px; left: -80px;
  background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 60%);
  filter: blur(20px);
}
.cat:hover .cat__pattern { transform: scale(1.08); }

.cat[data-cat="apteczka"] .cat__media {
  background:
    linear-gradient(180deg, rgba(29,43,30,0.45) 0%, rgba(29,43,30,0.25) 55%, rgba(29,43,30,0.6) 100%),
    url('/image/catalog/vit4u/asset/top1.webp') center/cover no-repeat,
    linear-gradient(135deg, #2a3d2b 0%, #1d2b1e 100%);
}
.cat[data-cat="medycyna"] .cat__media {
  background:
    linear-gradient(180deg, rgba(29,43,30,0.45) 0%, rgba(29,43,30,0.25) 55%, rgba(29,43,30,0.6) 100%),
    url('/image/catalog/vit4u/asset/top2.webp') center/cover no-repeat,
    linear-gradient(135deg, #3a4b2e 0%, #1d2b1e 100%);
}
.cat[data-cat="bieganie"] .cat__media {
  background:
    linear-gradient(180deg, rgba(15,26,16,0.5) 0%, rgba(15,26,16,0.3) 55%, rgba(15,26,16,0.65) 100%),
    url('/image/catalog/vit4u/asset/top3.webp') center/cover no-repeat,
    linear-gradient(135deg, #2a3d2b 0%, #0f1a10 100%);
}
.cat[data-cat="silownia"] .cat__media {
  background:
    linear-gradient(180deg, rgba(10,20,8,0.5) 0%, rgba(10,20,8,0.3) 55%, rgba(10,20,8,0.65) 100%),
    url('/image/catalog/vit4u/asset/top4.webp') center/cover no-repeat,
    linear-gradient(135deg, #1d2b1e 0%, #0a1408 100%);
}

.cat__icon-float {
  position: absolute;
  bottom: var(--s-4);
  left: var(--s-4);
  width: 44px; height: 44px;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.95);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-brand);
  z-index: 2;
  transition: transform var(--t-base) var(--ease-snappy);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}
.cat__icon-float svg { width: 22px; height: 22px; }
.cat:hover .cat__icon-float { transform: scale(1.08) rotate(-3deg); }

.cat__count-pill {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #fff;
  background: rgba(255,255,255,0.16);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.22);
  padding: 6px 12px;
  border-radius: var(--r-full);
  z-index: 2;
}

.cat__body {
  padding: var(--s-7);
  flex: 1;
  display: flex; flex-direction: column;
}
.cat__title {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--c-ink);
  margin: 0;
}
.cat__desc {
  margin-top: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.55;
}
.cat__cta {
  margin-top: auto;
  padding-top: var(--s-5);
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-brand);
  transition: gap var(--t-fast) var(--ease-snappy);
}
.cat:hover .cat__cta { gap: var(--s-3); }
.cat__cta svg { width: 14px; height: 14px; }

/* ==========================================================================
   LIFESTYLE — EDITORIAL SECTION
   ========================================================================== */
.lifestyle {
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
}
.lifestyle__inner {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: var(--s-12);
  align-items: center;
}
@media (max-width: 980px) {
  .lifestyle__inner { grid-template-columns: 1fr; gap: var(--s-9); }
}

.lifestyle__visual {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--s-4);
  height: 600px;
}
@media (max-width: 540px) {
  .lifestyle__visual { height: 480px; }
}

.lifestyle__photo {
  border-radius: var(--r-xl);
  overflow: hidden;
  position: relative;
  background-size: cover;
  background-position: center;
}
.lifestyle__photo--main {
  grid-row: 1 / -1;
  background-image: url('/image/catalog/vit4u/asset/anime1.webp');
  background-size: cover;
  background-position: center;
}
.lifestyle__photo--main::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(15,17,16,0.55) 100%);
  pointer-events: none;
}
.lifestyle__photo--sub {
  background-image: url('/image/catalog/vit4u/asset/anime2.webp');
  background-size: cover;
  background-position: center;
  position: relative;
}
.lifestyle__photo--detail {
  background-image: url('/image/catalog/vit4u/asset/anime3.webp');
  background-size: cover;
  background-position: center;
  position: relative;
}

.lifestyle__stat {
  position: absolute;
  bottom: var(--s-7);
  left: var(--s-7);
  right: var(--s-7);
  background: rgba(255,255,255,0.95);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex; align-items: center; gap: var(--s-5);
  box-shadow: var(--sh-3);
  z-index: 3;
  max-width: 280px;
}
.lifestyle__stat-num {
  font-family: var(--ff-display);
  font-size: 44px;
  font-weight: 700;
  color: var(--c-brand);
  line-height: 1;
  letter-spacing: -0.02em;
}
.lifestyle__stat-label {
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  line-height: 1.4;
}

.lifestyle__content { padding-left: var(--s-3); }
.lifestyle__content .section__title em {
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 500;
  color: var(--c-accent);
}
.lifestyle__lead {
  margin-top: var(--s-6);
  font-size: var(--fs-lg);
  color: var(--c-text-muted);
  line-height: 1.6;
}
.lifestyle__points {
  margin-top: var(--s-8);
  display: flex; flex-direction: column;
  gap: var(--s-5);
  padding: 0;
  list-style: none;
}
.lifestyle__points li {
  display: flex; gap: var(--s-4);
  font-size: var(--fs-md);
  color: var(--c-text);
  line-height: 1.5;
  padding-bottom: var(--s-5);
  border-bottom: 1px solid var(--c-border);
}
.lifestyle__points li:last-child { border-bottom: 0; padding-bottom: 0; }
.lifestyle__points strong { color: var(--c-ink); font-weight: 600; }
.lifestyle__bullet {
  width: 8px; height: 12px;
  background: var(--c-accent);
  border-radius: 4px 4px 4px 8px;
  flex-shrink: 0;
  margin-top: 6px;
  transform: rotate(15deg);
}

.lifestyle__content .btn {
  margin-top: var(--s-7);
}

/* ==========================================================================
   REVIEWS — VERIFIED TESTIMONIALS
   ========================================================================== */
.reviews {
  background: var(--c-bg-soft);
}
.reviews__rating {
  margin-top: var(--s-5);
  display: inline-flex; align-items: center; gap: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.reviews__rating .stars { font-size: 16px; }
.reviews__rating strong { color: var(--c-ink); font-weight: 600; }

.reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 980px) { .reviews__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .reviews__grid { grid-template-columns: 1fr; } }

.review {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-7);
  display: flex; flex-direction: column;
  transition: transform var(--t-base) var(--ease-smooth), box-shadow var(--t-base) var(--ease-smooth), border-color var(--t-base);
}
.review:hover {
  transform: translateY(-4px);
  border-color: transparent;
  box-shadow: var(--sh-card-hover);
}

.review__head {
  display: flex; align-items: center; gap: var(--s-4);
  margin-bottom: var(--s-5);
}
.avatar {
  width: 48px; height: 48px;
  border-radius: var(--r-full);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.avatar--a { background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-2) 100%); }
.avatar--b { background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-2) 100%); }
.avatar--c { background: linear-gradient(135deg, #5c6e44 0%, var(--c-brand) 100%); }
.avatar--d { background: linear-gradient(135deg, #d8a23a 0%, #b8842b 100%); }
.avatar--e { background: linear-gradient(135deg, #a8576a 0%, #6b3645 100%); }
.avatar--f { background: linear-gradient(135deg, var(--c-accent-2) 0%, var(--c-brand-2) 100%); }

.review__head h4 {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
  margin: 0;
}
.review__verified {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--fs-mini);
  color: var(--c-success);
  font-weight: 500;
  margin-top: 2px;
}
.review__verified svg { width: 12px; height: 12px; flex-shrink: 0; }

.review__rating { margin-bottom: var(--s-4); }
.review__text {
  font-size: var(--fs-md);
  color: var(--c-text);
  line-height: 1.6;
  flex: 1;
}
.review__foot {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-3);
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
}
.review__product {
  color: var(--c-accent);
  font-weight: 500;
  text-decoration: none;
  transition: color var(--t-fast) var(--ease-out);
}
.review__product:hover { color: var(--c-brand); }

/* ==========================================================================
   BLOG — STREFA WIEDZY
   ========================================================================== */
.blog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
}
@media (max-width: 880px) { .blog__grid { grid-template-columns: 1fr; } }

.post {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  transition: transform var(--t-base) var(--ease-smooth),
              border-color var(--t-base),
              box-shadow var(--t-base) var(--ease-smooth);
}
.post:hover {
  transform: translateY(-4px);
  border-color: transparent;
  box-shadow: var(--sh-card-hover);
}
.post__link {
  display: flex; flex-direction: column;
  text-decoration: none;
  height: 100%;
}

.post__media {
  position: relative;
  height: 220px;
  overflow: hidden;
  background: var(--c-brand);
}
.post__media--1 { background: url('/image/catalog/vit4u/asset/blog1.webp') center / cover no-repeat; }
.post__media--2 { background: url('/image/catalog/vit4u/asset/blog2.webp') center / cover no-repeat; }
.post__media--3 { background: url('/image/catalog/vit4u/asset/blog3.webp') center / cover no-repeat; }
.post__media { transition: background-size 700ms var(--ease-smooth); }
.post:hover .post__media[class*="post__media--"] { background-size: 110%; }
.post__media::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 70%, rgba(0,0,0,0.15) 0%, transparent 60%);
  pointer-events: none;
}

.post__cat {
  position: absolute;
  top: var(--s-5); left: var(--s-5);
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(255,255,255,0.18);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.24);
  padding: 6px 12px;
  border-radius: var(--r-full);
  z-index: 2;
}

.post__body {
  padding: var(--s-7);
  flex: 1;
  display: flex; flex-direction: column;
}
.post__meta {
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-text-soft);
  font-weight: 500;
}
.post__title {
  margin-top: var(--s-3);
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.018em;
  color: var(--c-ink);
  line-height: 1.25;
}
.post__excerpt {
  margin-top: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.55;
  flex: 1;
}
.post__more {
  margin-top: var(--s-5);
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-brand);
  transition: gap var(--t-fast) var(--ease-snappy);
}
.post__more svg { width: 14px; height: 14px; flex-shrink: 0; }
.post:hover .post__more { gap: var(--s-3); }

/* ==========================================================================
   CATEGORY PAGE
   ========================================================================== */

/* Breadcrumb */
.breadcrumb {
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-6) 0 var(--s-5);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  flex-wrap: wrap;
}
.breadcrumb a {
  color: var(--c-text-muted);
  transition: color var(--t-fast) var(--ease-out);
}
.breadcrumb a:hover { color: var(--c-brand); }
.breadcrumb svg { width: 12px; height: 12px; opacity: 0.5; }
.breadcrumb [aria-current] { color: var(--c-ink); font-weight: 500; }
.breadcrumb ol {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: var(--s-2);
}
.breadcrumb ol li {
  display: inline-flex; align-items: center;
  color: var(--c-text-soft);
}
.breadcrumb ol li[aria-current] { color: var(--c-ink); font-weight: 500; }

/* Category compact header (breadcrumb + title + lead only) */
.cat-header {
  background: #fff;
  padding-bottom: var(--s-7);
}
.cat-header__inner {
  max-width: 820px;
  padding-top: var(--s-3);
}
.cat-header__title {
  font-family: var(--ff-display);
  font-size: clamp(36px, 4.6vw, 60px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--c-ink);
  margin-top: var(--s-2);
}
.cat-header__lead {
  margin-top: var(--s-4);
  font-size: var(--fs-lg);
  color: var(--c-text-muted);
  line-height: 1.55;
  max-width: 720px;
}

/* Category hero (legacy — kept for back-compat, not rendered) */
.cat-hero {
  padding-bottom: var(--s-9);
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
}
.cat-hero__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--s-10);
  align-items: center;
  padding-top: var(--s-5);
}
@media (max-width: 980px) {
  .cat-hero__inner { grid-template-columns: 1fr; gap: var(--s-8); }
}

.cat-hero__title {
  font-family: var(--ff-display);
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--c-ink);
  margin-top: var(--s-2);
}
.cat-hero__lead {
  margin-top: var(--s-5);
  font-size: var(--fs-lg);
  color: var(--c-text-muted);
  line-height: 1.55;
  max-width: 480px;
}
.cat-hero__stats {
  margin-top: var(--s-8);
  display: flex; gap: var(--s-9);
  padding-top: var(--s-6);
  border-top: 1px solid var(--c-border);
}
.cat-hero__stats > div { display: flex; flex-direction: column; }
.cat-hero__stats dt {
  font-family: var(--ff-display);
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 600;
  color: var(--c-brand);
  line-height: 1;
  letter-spacing: -0.02em;
}
.cat-hero__stats dt span { color: var(--c-text-soft); font-weight: 400; }
.cat-hero__stats dd {
  margin-top: var(--s-2);
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}
@media (max-width: 540px) {
  .cat-hero__stats { gap: var(--s-6); flex-wrap: wrap; }
}

.cat-hero__visual {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  min-height: 460px;
}
.cat-hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 30% 30%, var(--c-accent-soft) 0%, transparent 60%),
    radial-gradient(circle at 70% 70%, #ece9dc 0%, transparent 60%);
  border-radius: var(--r-2xl);
  pointer-events: none;
}
.cat-hero__featured {
  position: relative;
  background: #fff;
  border-radius: var(--r-2xl);
  padding: var(--s-8) var(--s-7) var(--s-6);
  box-shadow: var(--sh-3);
  display: flex; flex-direction: column; align-items: center;
  width: 100%; max-width: 380px;
}
.cat-hero__featured .badge {
  position: absolute;
  top: var(--s-5); right: var(--s-5);
}
.cat-hero__featured-info {
  margin-top: var(--s-5);
  padding-top: var(--s-5);
  border-top: 1px solid var(--c-border);
  text-align: center;
  width: 100%;
}
.cat-hero__featured-info h3 {
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.cat-hero__featured-info p {
  margin-top: 4px;
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}

/* Subcategory pills bar */
.subcats {
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  padding: var(--s-5) 0;
  background: #fff;
  position: sticky;
  top: calc(var(--topbar-h) + var(--header-h));
  z-index: 30;
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  background: rgba(255,255,255,0.92);
}
.subcats__scroll {
  display: flex; gap: var(--s-2);
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 2px;
}
.subcats__scroll::-webkit-scrollbar { display: none; }

.chip {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-muted);
  background: var(--c-bg-cream);
  padding: 9px 16px;
  border-radius: var(--r-full);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
  letter-spacing: -0.005em;
}
.chip small {
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-text-soft);
  background: rgba(255,255,255,0.7);
  padding: 1px 7px;
  border-radius: var(--r-full);
  letter-spacing: 0;
}
.chip:hover { color: var(--c-brand); }
.chip.is-active {
  background: var(--c-brand);
  color: #fff;
}
.chip.is-active small {
  background: rgba(255,255,255,0.18);
  color: #fff;
}

/* Toolbar */
.toolbar {
  padding: var(--s-6) 0;
  background: var(--c-bg-soft);
  border-bottom: 1px solid var(--c-border);
}
.toolbar__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5); flex-wrap: wrap;
}
.toolbar__left, .toolbar__right {
  display: flex; align-items: center; gap: var(--s-4);
}
.toolbar__count {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.toolbar__count strong { color: var(--c-ink); font-weight: 600; }

.toolbar__filters-btn {
  display: none;
  align-items: center; gap: var(--s-2);
  padding: 10px 16px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-ink);
  background: #fff;
}
.toolbar__filters-btn svg { width: 16px; height: 16px; }
.toolbar__filters-count {
  background: var(--c-brand);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  width: 18px; height: 18px;
  border-radius: var(--r-full);
  display: inline-flex; align-items: center; justify-content: center;
}
@media (max-width: 980px) {
  .toolbar__filters-btn { display: inline-flex; }
}

/* Custom select */
.select-wrap { position: relative; }
.select {
  appearance: none;
  -webkit-appearance: none;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-ink);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  padding: 10px 36px 10px 16px;
  cursor: pointer;
  letter-spacing: -0.005em;
}
.select:focus { outline: none; border-color: var(--c-brand); }
.select-chevron {
  position: absolute; right: 14px; top: 50%;
  transform: translateY(-50%);
  width: 11px; height: 11px;
  pointer-events: none;
  opacity: 0.6;
}

/* View toggle */
.view-toggle {
  display: inline-flex;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  padding: 3px;
}
.view-btn {
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-text-soft);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.view-btn svg { width: 14px; height: 14px; }
.view-btn:hover { color: var(--c-brand); }
.view-btn.is-active { background: var(--c-bg-cream); color: var(--c-brand); }

/* Listing layout */
.listing {
  padding: var(--s-9) 0 var(--s-10);
}
.listing__inner {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s-9);
  align-items: start;
}
@media (max-width: 980px) {
  .listing__inner { grid-template-columns: 1fr; }
}

/* Filters sidebar */
.filters {
  position: sticky;
  top: calc(var(--topbar-h) + var(--header-h) + 64px + var(--s-7));
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-5);
  max-height: calc(100vh - var(--topbar-h) - var(--header-h) - 64px - var(--s-7) - 32px);
  overflow-y: auto;
  scrollbar-width: thin;
}
.filters::-webkit-scrollbar { width: 6px; }
.filters::-webkit-scrollbar-thumb { background: var(--c-border-2); border-radius: 4px; }

.filters__head {
  display: none;
  align-items: center; justify-content: space-between;
  padding-bottom: var(--s-4);
  margin-bottom: var(--s-4);
  border-bottom: 1px solid var(--c-border);
}
.filters__head h2 {
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--c-ink);
}
.filters__close {
  width: 32px; height: 32px;
  border-radius: var(--r-full);
  color: var(--c-text-muted);
}
.filters__close svg { width: 18px; height: 18px; }
.filters__close:hover { background: var(--c-bg-cream); color: var(--c-brand); }

@media (max-width: 980px) {
  .filters {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: 320px; max-width: 90vw;
    height: 100vh; max-height: none;
    border-radius: 0;
    border: 0;
    box-shadow: 24px 0 48px rgba(0,0,0,0.15);
    z-index: 60;
    transform: translateX(-100%);
    transition: transform var(--t-base) var(--ease-smooth);
  }
  .filters.is-open { transform: translateX(0); }
  .filters__head { display: flex; }
}

/* Filter group (accordion) */
.fgroup {
  border-bottom: 1px solid var(--c-border);
  padding: var(--s-3) 0;
}
.fgroup:last-of-type { border-bottom: 0; }
.fgroup summary {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-3) 0;
  cursor: pointer;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.005em;
  list-style: none;
  user-select: none;
}
.fgroup summary::-webkit-details-marker { display: none; }
.fgroup__chev {
  width: 12px; height: 12px;
  transition: transform var(--t-fast) var(--ease-out);
  color: var(--c-text-muted);
}
.fgroup[open] .fgroup__chev { transform: rotate(180deg); }

.fgroup__search {
  position: relative;
  margin: var(--s-3) 0;
}
.fgroup__search svg {
  position: absolute;
  left: 12px; top: 50%; transform: translateY(-50%);
  width: 14px; height: 14px;
  color: var(--c-text-soft);
  pointer-events: none;
}
.fgroup__search input {
  width: 100%;
  padding: 8px 12px 8px 34px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  outline: none;
  background: var(--c-bg-soft);
  transition: border-color var(--t-fast) var(--ease-out);
}
.fgroup__search input:focus { border-color: var(--c-brand); background: #fff; }

.fgroup__list {
  display: flex; flex-direction: column;
  gap: 2px;
  padding: var(--s-2) 0 var(--s-3);
}

/* Custom checkbox option */
.fopt {
  display: flex; align-items: center; gap: var(--s-3);
  padding: 7px 0;
  cursor: pointer;
  font-size: var(--fs-sm);
  color: var(--c-text);
  transition: color var(--t-fast) var(--ease-out);
}
.fopt:hover { color: var(--c-brand); }
.fopt input { position: absolute; opacity: 0; pointer-events: none; }
.fopt__box {
  width: 18px; height: 18px;
  border: 1.5px solid var(--c-border-2);
  border-radius: 5px;
  flex-shrink: 0;
  position: relative;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.fopt__box::after {
  content: '';
  position: absolute;
  inset: 4px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23fff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'><path d='m3 8 3.5 3.5L13 5'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0;
  transform: scale(0.6);
  transition: opacity var(--t-fast) var(--ease-out), transform var(--t-fast) var(--ease-snappy);
}
.fopt input:checked ~ .fopt__box {
  background: var(--c-brand);
  border-color: var(--c-brand);
}
.fopt input:checked ~ .fopt__box::after {
  opacity: 1;
  transform: scale(1);
}
.fopt input:focus-visible ~ .fopt__box {
  outline: 2px solid var(--c-accent);
  outline-offset: 2px;
}
.fopt__name { flex: 1; }
.fopt__count {
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
  font-weight: 400;
}
.fopt input:checked ~ .fopt__name { color: var(--c-brand); font-weight: 500; }

/* Pill option (radio) */
.fgroup__list--pills {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: var(--s-3) 0;
}
.fpill {
  cursor: pointer;
  position: relative;
}
.fpill input { position: absolute; opacity: 0; pointer-events: none; }
.fpill span {
  display: inline-block;
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  padding: 6px 12px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  color: var(--c-text-muted);
  transition: all var(--t-fast) var(--ease-out);
  letter-spacing: -0.005em;
}
.fpill:hover span { border-color: var(--c-brand); color: var(--c-brand); }
.fpill input:checked ~ span {
  background: var(--c-brand);
  color: #fff;
  border-color: var(--c-brand);
}

/* Price range */
.price-range {
  padding: var(--s-3) 0 var(--s-4);
}
.price-range__inputs {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--s-3);
  align-items: end;
  margin-bottom: var(--s-5);
}
.price-range__input label {
  display: block;
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
  margin-bottom: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.price-range__value {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: 7px 10px;
  background: #fff;
  display: block;
}
.price-range__sep {
  color: var(--c-text-soft);
  padding-bottom: 9px;
}

.price-range__slider {
  position: relative;
  height: 24px;
  margin: var(--s-4) 0;
}
.price-range__track {
  position: absolute;
  top: 50%; left: 0; right: 0;
  height: 4px;
  background: var(--c-bg-cream);
  border-radius: var(--r-full);
  transform: translateY(-50%);
}
.price-range__fill {
  position: absolute;
  top: 0; bottom: 0;
  background: var(--c-brand);
  border-radius: var(--r-full);
}
.price-range__handle {
  position: absolute;
  top: 50%;
  width: 18px; height: 18px;
  background: #fff;
  border: 2.5px solid var(--c-brand);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(29,43,30,0.15);
}
.price-range__presets {
  display: flex; flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--s-4);
}
.price-range__presets button {
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  padding: 5px 11px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  color: var(--c-text-muted);
  background: #fff;
  transition: all var(--t-fast) var(--ease-out);
}
.price-range__presets button:hover { border-color: var(--c-brand); color: var(--c-brand); }
.price-range__presets button.is-active {
  background: var(--c-brand); color: #fff; border-color: var(--c-brand);
}

.filters__actions {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--c-border);
}
.btn--block { width: 100%; }

/* Active filters */
.active-filters {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: var(--s-2);
  margin-bottom: var(--s-6);
}
.active-filters__label {
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-text-soft);
  margin-right: var(--s-2);
}
.filter-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-brand);
  background: var(--c-accent-soft);
  padding: 6px 10px 6px 12px;
  border-radius: var(--r-full);
  transition: background var(--t-fast) var(--ease-out);
}
.filter-chip svg { width: 11px; height: 11px; opacity: 0.6; }
.filter-chip:hover { background: var(--c-brand); color: #fff; }
.active-filters__clear {
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  margin-left: var(--s-2);
}
.active-filters__clear:hover { color: var(--c-brand); }

/* Listing products grid */
.products--listing {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 1180px) { .products--listing { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .products--listing { grid-template-columns: 1fr; } }

/* Load more */
.load-more {
  margin-top: var(--s-9);
  display: flex; flex-direction: column; align-items: center;
  gap: var(--s-4);
}
.load-more__progress {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.load-more__progress strong { color: var(--c-ink); font-weight: 600; }
.load-more__bar {
  width: 200px;
  height: 3px;
  background: var(--c-bg-cream);
  border-radius: var(--r-full);
  overflow: hidden;
}
.load-more__fill {
  height: 100%;
  background: var(--c-brand);
  border-radius: var(--r-full);
  transition: width 600ms var(--ease-smooth);
}
.btn--lg {
  padding: 18px 32px;
  font-size: var(--fs-md);
  margin-top: var(--s-2);
}
.btn--lg svg { width: 18px; height: 18px; }

/* SEO content */
.cat-info {
  background: var(--c-bg-soft);
  padding: var(--s-10) 0;
  border-top: 1px solid var(--c-border);
}
.cat-info__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--s-9);
}
@media (max-width: 880px) { .cat-info__grid { grid-template-columns: 1fr; gap: var(--s-7); } }
.cat-info h2 {
  font-family: var(--ff-display);
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--c-ink);
}
.cat-info p {
  margin-top: var(--s-4);
  font-size: var(--fs-md);
  color: var(--c-text);
  line-height: 1.7;
}
.cat-info p strong { color: var(--c-brand); font-weight: 600; }
.cat-info h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.015em;
  margin-bottom: var(--s-4);
}
.cat-info__links { display: flex; flex-direction: column; gap: var(--s-3); }
.cat-info__links a {
  display: inline-flex; align-items: center;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  color: var(--c-brand);
  font-weight: 500;
  padding: 8px 0;
  border-bottom: 1px solid var(--c-border);
  transition: padding-left var(--t-fast) var(--ease-snappy), color var(--t-fast) var(--ease-out);
}
.cat-info__links a:hover { padding-left: 8px; color: var(--c-accent); }

/* FAQ */
.faq__list {
  max-width: 820px;
  margin: 0 auto;
  display: flex; flex-direction: column;
  gap: var(--s-3);
}
.faq__item {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--t-fast) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.faq__item:hover { border-color: var(--c-border-2); }
.faq__item[open] {
  border-color: var(--c-brand);
  box-shadow: var(--sh-2);
}
.faq__item summary {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-6) var(--s-7);
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--c-ink);
  cursor: pointer;
  list-style: none;
  letter-spacing: -0.015em;
  gap: var(--s-4);
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary svg {
  width: 18px; height: 18px;
  color: var(--c-accent);
  transition: transform var(--t-base) var(--ease-smooth);
  flex-shrink: 0;
}
.faq__item[open] summary svg { transform: rotate(180deg); }
.faq__answer {
  padding: 0 var(--s-7) var(--s-6);
  color: var(--c-text-muted);
  font-size: var(--fs-md);
  line-height: 1.7;
}
.faq__answer p { margin-bottom: var(--s-3); }
.faq__answer p:last-child { margin-bottom: 0; }
.faq__answer a { color: var(--c-brand); text-decoration: underline; text-underline-offset: 3px; }
.faq__answer strong { color: var(--c-ink); font-weight: 600; }

/* ==========================================================================
   CATEGORY LONG DESCRIPTION (collapsible)
   ========================================================================== */
.cat-description {
  background: var(--c-bg-soft);
  padding: var(--s-10) 0;
  border-top: 1px solid var(--c-border);
}
.cat-description__inner {
  max-width: 860px;
  margin: 0 auto;
}
.cat-description__head {
  margin-bottom: var(--s-7);
}
.cat-description__head h2 {
  margin-top: var(--s-2);
  font-family: var(--ff-display);
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--c-ink);
}
.cat-description__content {
  position: relative;
  max-height: 280px;
  overflow: hidden;
  transition: max-height 700ms var(--ease-smooth);
}
.cat-description__content.is-expanded {
  max-height: 4000px;
}
.cat-description__content::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 140px;
  background: linear-gradient(180deg, rgba(250,249,245,0) 0%, var(--c-bg-soft) 85%);
  pointer-events: none;
  transition: opacity 320ms var(--ease-out);
}
.cat-description__content.is-expanded::after { opacity: 0; }
.cat-description__content p {
  margin-bottom: var(--s-4);
  font-size: var(--fs-md);
  color: var(--c-text);
  line-height: 1.75;
}
.cat-description__content p:last-child { margin-bottom: 0; }
.cat-description__content strong { color: var(--c-ink); font-weight: 600; }

.cat-description__toggle {
  margin-top: var(--s-5);
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-brand);
  padding: 11px 22px;
  border: 1.5px solid var(--c-border-2);
  border-radius: var(--r-full);
  background: #fff;
  cursor: pointer;
  transition: gap var(--t-fast) var(--ease-snappy),
              border-color var(--t-fast) var(--ease-out),
              background var(--t-fast) var(--ease-out);
}
.cat-description__toggle:hover {
  gap: var(--s-3);
  border-color: var(--c-brand);
  background: var(--c-bg-cream);
}
.cat-description__toggle svg {
  width: 14px; height: 14px;
  transition: transform var(--t-base) var(--ease-out);
  flex-shrink: 0;
}
.cat-description__toggle.is-active svg { transform: rotate(180deg); }

/* ==========================================================================
   PRODUCT DETAIL PAGE (PDP)
   ========================================================================== */

.page-product { background: var(--c-bg); }

.page-product .breadcrumb {
  margin-top: var(--s-6);
  margin-bottom: var(--s-5);
}

/* ----- PDP HERO -------------------------------------------------------- */
.pdp { padding: var(--s-4) 0 var(--s-9); }
.pdp__inner {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--s-9);
  align-items: flex-start;
}
@media (max-width: 1080px) {
  .pdp__inner { grid-template-columns: 1fr; gap: var(--s-7); }
}

.pdp__gallery { position: sticky; top: calc(var(--header-h) + 16px); }
@media (max-width: 1080px) { .pdp__gallery { position: static; } }

/* ----- GALLERY --------------------------------------------------------- */
.gallery {
  background: linear-gradient(160deg, var(--c-bg-cream) 0%, var(--c-bg-warm) 100%);
  border-radius: var(--r-2xl);
  padding: var(--s-7);
  position: relative;
  overflow: hidden;
}
.gallery::before {
  content: '';
  position: absolute;
  top: -40%; right: -20%;
  width: 70%; aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(101,109,65,0.18), transparent 70%);
  filter: blur(40px);
  pointer-events: none;
}
.gallery::after {
  content: '';
  position: absolute;
  bottom: -30%; left: -10%;
  width: 50%; aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(29,43,30,0.10), transparent 70%);
  filter: blur(40px);
  pointer-events: none;
}

.gallery__stage {
  position: relative;
  aspect-ratio: 1 / 1;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--s-6);
}
.gallery__view { position: relative; display: flex; align-items: center; justify-content: center; }
.gallery__view[hidden] { display: none; }

.gallery__badges {
  position: absolute; top: 0; left: 0;
  display: flex; flex-direction: column; gap: var(--s-2);
  z-index: 3;
}
.gallery__zoom {
  position: absolute; top: 0; right: 0;
  width: 44px; height: 44px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  z-index: 3;
  transition: transform var(--t-fast) var(--ease-snappy), background var(--t-fast) var(--ease-out);
}
.gallery__zoom:hover { background: #fff; transform: scale(1.06); }
.gallery__zoom svg { width: 18px; height: 18px; }

.gallery__nav {
  position: absolute; top: 50%; left: 0; right: 0;
  transform: translateY(-50%);
  display: flex; justify-content: space-between;
  pointer-events: none;
  z-index: 2;
}
.gallery__arrow {
  width: 44px; height: 44px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  pointer-events: auto;
  opacity: 0;
  transition: opacity var(--t-base) var(--ease-out), transform var(--t-fast) var(--ease-snappy), background var(--t-fast) var(--ease-out);
}
.gallery:hover .gallery__arrow { opacity: 1; }
.gallery__arrow:hover { background: #fff; transform: scale(1.06); }
.gallery__arrow svg { width: 16px; height: 16px; }

.bottle--back .bottle__body { background: linear-gradient(180deg, #f7f5ed, #e9e6d6); }
.bottle__label--back {
  display: flex; flex-direction: column;
  text-align: left;
  font-family: var(--ff-display);
  color: var(--c-ink);
  padding: 10px 14px;
}
.bottle__label--back small {
  font-size: 8px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--c-text-muted); margin-bottom: 6px;
}
.bottle__label--back strong { font-size: 11px; font-weight: 700; margin-top: 8px; }
.bottle__label--back strong:first-of-type { margin-top: 0; }
.bottle__label--back span:not(.bottle__label-divider) { font-size: 9px; color: var(--c-text); margin-top: 2px; }

.gallery__view--macro { width: 100%; height: 100%; }
.macro {
  position: relative;
  width: 360px; max-width: 80%; aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
}
.macro__core {
  position: absolute;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--c-accent-2), var(--c-brand) 70%);
  box-shadow: 0 12px 32px rgba(29,43,30,0.30), inset -6px -6px 14px rgba(0,0,0,0.18);
}
.macro__ring {
  position: absolute;
  border: 1.5px dashed rgba(29,43,30,0.30);
  border-radius: 50%;
  animation: macroSpin 22s linear infinite;
}
.macro__ring--1 { width: 60%; aspect-ratio: 1; animation-duration: 16s; }
.macro__ring--2 { width: 80%; aspect-ratio: 1; animation-duration: 22s; animation-direction: reverse; }
.macro__ring--3 { width: 100%; aspect-ratio: 1; animation-duration: 30s; opacity: 0.6; }
@keyframes macroSpin { to { transform: rotate(360deg); } }
.macro__label {
  position: absolute;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 28px;
  color: #fff;
  z-index: 2;
}

.gallery__view--lifestyle { width: 100%; }
.lifestyle-card {
  position: relative;
  width: 86%;
  aspect-ratio: 1 / 1;
  border-radius: var(--r-xl);
  background:
    linear-gradient(135deg, rgba(29,43,30,0.4), rgba(15,26,16,0.6)),
    radial-gradient(circle at 30% 30%, #d4d2bd, #6f7556);
  display: flex; align-items: flex-end; padding: var(--s-7);
  overflow: hidden;
}
.lifestyle-card__sun {
  position: absolute; top: 18%; right: 18%;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: radial-gradient(circle, #f4ecd3 0%, rgba(244,236,211,0.0) 70%);
}
.lifestyle-card__leaf {
  position: absolute; bottom: -10%; left: -10%;
  width: 60%; aspect-ratio: 1;
  background: radial-gradient(ellipse 60% 80% at 30% 30%, rgba(101,109,65,0.6), transparent 70%);
}
.lifestyle-card__caption {
  position: relative; z-index: 1;
  font-family: var(--ff-serif);
  font-style: italic;
  font-size: 22px;
  color: #fff;
  line-height: 1.3;
}

.gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
}
.thumb {
  display: flex; flex-direction: column; gap: 6px;
  align-items: center;
  cursor: pointer;
  padding: var(--s-2);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.55);
  border: 1.5px solid transparent;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.thumb:hover { background: #fff; }
.thumb.is-active { border-color: var(--c-brand); background: #fff; }
.thumb__inner {
  width: 100%; aspect-ratio: 1;
  border-radius: var(--r-sm);
  background: var(--c-bg-cream);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.thumb__inner--text {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 22px;
  color: var(--c-brand);
  letter-spacing: -0.04em;
}
.thumb__atom {
  width: 60%; aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--c-accent-2), var(--c-brand) 70%);
  position: relative;
}
.thumb__atom::before, .thumb__atom::after {
  content: ''; position: absolute; inset: -20%;
  border: 1px dashed rgba(29,43,30,0.4);
  border-radius: 50%;
}
.thumb__atom::after { inset: -40%; transform: rotate(60deg); }
.thumb__inner--lifestyle {
  background: linear-gradient(135deg, #6f7556 0%, #1d2b1e 100%);
  position: relative;
}
.thumb__inner--lifestyle::after {
  content: ''; position: absolute; top: 20%; right: 20%;
  width: 30%; aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244,236,211,0.7), transparent 70%);
}
.thumb small {
  font-size: var(--fs-mini);
  color: var(--c-text-muted);
  font-family: var(--ff-display);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
}

.bottle--thumb { width: 36px; height: 56px; position: relative; }
.bottle--thumb .bottle__cap {
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 18%;
  background: var(--c-brand);
  border-radius: 4px 4px 2px 2px;
}
.bottle--thumb .bottle__body {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 100%; height: 78%;
  background: linear-gradient(180deg, #f7f5ed, #e9e6d6);
  border-radius: 6px;
  border: 1px solid var(--c-border);
}

.bottle--mini {
  width: 28px; height: 44px;
  position: relative;
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
}
.bottle--mini .bottle__cap {
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 16%;
  background: var(--bottle-cap, var(--c-brand));
  border-radius: 3px 3px 1px 1px;
}
.bottle--mini .bottle__body {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 100%; height: 80%;
  background: linear-gradient(180deg, #f7f5ed, #e9e6d6);
  border-radius: 4px;
  border: 1px solid var(--c-border);
}

.pdp-usp {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  margin-top: var(--s-5);
}
.pdp-usp__item {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4);
  background: var(--c-bg-soft);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
}
.pdp-usp__item svg { width: 24px; height: 24px; color: var(--c-brand); flex-shrink: 0; }
.pdp-usp__item span { display: flex; flex-direction: column; line-height: 1.2; }
.pdp-usp__item strong { font-family: var(--ff-display); font-size: var(--fs-sm); font-weight: 600; color: var(--c-ink); }
.pdp-usp__item small { font-size: var(--fs-mini); color: var(--c-text-muted); margin-top: 2px; }
@media (max-width: 640px) { .pdp-usp { grid-template-columns: 1fr; } }

/* ----- PDP INFO PANEL -------------------------------------------------- */
.pdp-info { padding-top: var(--s-2); }
.pdp-info__title {
  font-family: var(--ff-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin-top: var(--s-3);
}
.pdp-info__subtitle {
  font-size: var(--fs-lg);
  color: var(--c-text-muted);
  line-height: 1.5;
  margin-top: var(--s-3);
}
.pdp-info__rating {
  display: flex; align-items: center; gap: var(--s-2);
  margin-top: var(--s-5);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.pdp-info__rating .stars { font-size: 16px; color: var(--c-accent); letter-spacing: 1px; }
.pdp-info__rating strong { color: var(--c-ink); font-weight: 600; }
.pdp-info__rating-link { color: var(--c-brand); text-decoration: underline; text-underline-offset: 3px; }
.pdp-info__rating-link:hover { color: var(--c-accent); }
.pdp-info__sep { color: var(--c-border-2); }
.pdp-info__sold { color: var(--c-text-muted); }

.pdp-info__chips {
  display: flex; flex-wrap: wrap; gap: var(--s-2);
  margin-top: var(--s-5);
}
.pdp-info__chips li {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px;
  border-radius: var(--r-full);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
}
.pdp-info__chips svg { width: 14px; height: 14px; color: var(--c-accent); }

.pdp-claims {
  margin-top: var(--s-6);
  padding: var(--s-5);
  background: var(--c-bg-cream);
  border-radius: var(--r-md);
}
.pdp-claims__head {
  display: block;
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-text-muted);
  margin-bottom: var(--s-3);
}
.pdp-claims__pills { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.claim-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 12px;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-brand);
}
.claim-pill svg { width: 14px; height: 14px; color: var(--c-accent); }
.pdp-claims__foot {
  display: block;
  font-size: var(--fs-mini);
  color: var(--c-text-muted);
  margin-top: var(--s-3);
}
.pdp-claims__foot a { color: var(--c-brand); text-decoration: underline; text-underline-offset: 2px; }

/* Variant picker */
.variant-pick { border: 0; padding: 0; margin-top: var(--s-7); }
.variant-pick legend {
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-text-muted);
  margin-bottom: var(--s-3);
  font-weight: 500;
}
.variant-pick__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
}
.variant {
  position: relative;
  cursor: pointer;
  display: block;
}
.variant input { position: absolute; opacity: 0; pointer-events: none; }
.variant__inner {
  display: flex; flex-direction: column; gap: 4px;
  padding: var(--s-4);
  background: #fff;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.variant:hover .variant__inner { border-color: var(--c-border-2); }
.variant.is-checked .variant__inner {
  border-color: var(--c-brand);
  background: var(--c-bg-soft);
  box-shadow: 0 0 0 4px rgba(29,43,30,0.06);
}
.variant__name {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
}
.variant__meta { font-size: var(--fs-mini); color: var(--c-text-muted); }
.variant__price {
  margin-top: 4px;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-brand);
}
.variant__price s { color: var(--c-text-soft); font-weight: 400; margin-left: 4px; font-size: var(--fs-xs); }
.variant__flag {
  position: absolute; top: -8px; left: 12px;
  background: var(--c-brand); color: #fff;
  padding: 2px 8px;
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
}
.variant__flag--save { background: var(--c-sale); }
@media (max-width: 540px) { .variant-pick__grid { grid-template-columns: 1fr; } }

.sub-pick {
  margin-top: var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-2);
}
.sub-pick__row {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-4) var(--s-5);
  background: #fff;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.sub-pick__row:hover { border-color: var(--c-border-2); }
.sub-pick__row input { position: absolute; opacity: 0; pointer-events: none; }
.sub-pick__bullet {
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 2px solid var(--c-border-2);
  position: relative;
  flex-shrink: 0;
}
.sub-pick__row.is-checked { border-color: var(--c-brand); background: var(--c-bg-soft); }
.sub-pick__row.is-checked .sub-pick__bullet { border-color: var(--c-brand); }
.sub-pick__row.is-checked .sub-pick__bullet::after {
  content: ''; position: absolute; inset: 3px;
  border-radius: 50%;
  background: var(--c-brand);
}
.sub-pick__body strong {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
}
.sub-pick__body small {
  display: block;
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  margin-top: 2px;
}
.sub-tag {
  background: var(--c-accent);
  color: #fff;
  padding: 2px 8px;
  border-radius: var(--r-full);
  font-size: var(--fs-mini);
  font-weight: 700;
  letter-spacing: 0.04em;
}
.sub-pick__select {
  display: inline-flex; align-items: center; gap: 4px;
  position: relative;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: 2px 6px 2px 8px;
  margin: 0 4px;
}
.sub-pick__select select {
  border: 0; background: transparent; outline: none;
  appearance: none; -webkit-appearance: none;
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--c-brand);
  padding-right: 14px;
}
.sub-pick__select svg { width: 10px; height: 10px; color: var(--c-brand); position: absolute; right: 6px; pointer-events: none; }
.sub-pick__price {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-brand);
}

.pdp-buy {
  margin-top: var(--s-6);
  padding: var(--s-6);
  background: linear-gradient(180deg, var(--c-bg-soft) 0%, var(--c-bg-cream) 100%);
  border-radius: var(--r-lg);
  border: 1px solid var(--c-border);
}
.pdp-buy__price {
  display: flex; align-items: baseline; gap: var(--s-3);
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
}
.pdp-buy__price .price__now {
  font-size: clamp(28px, 3.6vw, 40px);
  font-family: var(--ff-display);
  font-weight: 600;
  color: var(--c-brand);
  letter-spacing: -0.02em;
}
.pdp-buy__price .price__was { font-size: var(--fs-md); }
.pdp-buy__per {
  margin-left: auto;
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  font-family: var(--ff-display);
}

.pdp-buy__row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-3);
  align-items: stretch;
}
.pdp-buy__cta { height: 56px; font-size: var(--fs-md); }
.icon-btn--lg {
  width: 56px; height: 56px;
  border-radius: var(--r-full);
  background: #fff;
  border: 1.5px solid var(--c-border);
  color: var(--c-brand);
}
.icon-btn--lg:hover { border-color: var(--c-sale); color: var(--c-sale); background: #fff; }
@media (max-width: 540px) {
  .pdp-buy__row { grid-template-columns: auto 1fr; }
  .pdp-buy__row .icon-btn--lg { grid-column: 1 / -1; width: 100%; }
}

.pdp-buy__pay {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-3);
  margin-top: var(--s-4);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  flex-wrap: wrap;
}
.pdp-buy__pay strong { color: var(--c-ink); font-weight: 600; }
.pay-icons { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.pay-icons .pay {
  display: inline-flex; align-items: center;
  background: #fff;
  border: 1px solid var(--c-border);
  padding: 4px 8px;
  border-radius: var(--r-xs);
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  font-weight: 600;
  color: var(--c-text);
  letter-spacing: 0.04em;
}

.pdp-buy__stock {
  display: flex; align-items: center; gap: var(--s-2);
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--c-border);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  flex-wrap: wrap;
}
.pdp-buy__stock strong { color: var(--c-success); font-weight: 600; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c-text-soft); display: inline-block; }
.dot--ok { background: var(--c-success); box-shadow: 0 0 0 4px rgba(79,122,57,0.18); animation: pulseDot 2s ease-in-out infinite; }
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 4px rgba(79,122,57,0.18); }
  50% { box-shadow: 0 0 0 8px rgba(79,122,57,0.05); }
}

.pdp-quick { margin-top: var(--s-5); display: flex; flex-direction: column; gap: var(--s-2); }
.pdp-quick__item {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.pdp-quick__item summary {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
  cursor: pointer;
  list-style: none;
}
.pdp-quick__item summary::-webkit-details-marker { display: none; }
.pdp-quick__item summary > svg:first-child { width: 18px; height: 18px; color: var(--c-accent); flex-shrink: 0; }
.pdp-quick__item summary .chev {
  width: 12px; height: 12px;
  margin-left: auto;
  color: var(--c-text-muted);
  transition: transform var(--t-base) var(--ease-out);
}
.pdp-quick__item[open] summary .chev { transform: rotate(180deg); }
.pdp-quick__body {
  padding: 0 var(--s-5) var(--s-5);
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.6;
}
.pdp-quick__body p + p { margin-top: var(--s-3); }
.pdp-quick__body strong { color: var(--c-ink); }

.dot-list { display: flex; flex-direction: column; gap: var(--s-2); }
.dot-list li {
  position: relative;
  padding-left: 18px;
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.55;
}
.dot-list li::before {
  content: ''; position: absolute;
  top: 9px; left: 0;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--c-accent);
}
.dot-list li strong { color: var(--c-ink); font-weight: 600; }

/* ----- CERT RIBBON ----------------------------------------------------- */
.cert-ribbon {
  background: var(--c-bg-dark);
  color: #fff;
  padding: var(--s-6) 0;
}
.cert-ribbon__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5);
  flex-wrap: wrap;
}
.cert {
  display: flex; align-items: center; gap: var(--s-3);
  flex: 1 1 200px;
}
.cert__seal {
  flex-shrink: 0;
  width: 56px; height: 56px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-align: center;
  line-height: 1;
  border: 2px solid var(--c-accent-2);
  color: var(--c-accent-2);
}
.cert__seal--gmp { background: rgba(101,109,65,0.15); }
.cert__seal--iso { font-size: 10px; }
.cert__seal--vegan { font-size: 22px; font-style: italic; }
.cert__seal--lab { background: rgba(101,109,65,0.15); }
.cert__seal--gis { background: rgba(101,109,65,0.15); font-size: 12px; }
.cert > span:last-child { display: flex; flex-direction: column; line-height: 1.25; }
.cert strong { font-family: var(--ff-display); font-size: var(--fs-sm); font-weight: 600; color: #fff; }
.cert small { font-size: var(--fs-mini); color: var(--c-accent-2); margin-top: 2px; }
@media (max-width: 880px) {
  .cert-ribbon__inner { gap: var(--s-4); }
  .cert { flex: 1 1 240px; }
}

/* ----- STICKY TABS ----------------------------------------------------- */
.pdp-tabs {
  position: sticky;
  top: 0;
  z-index: 55;
  background: rgba(255,255,255,0.94);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--c-border);
  box-shadow: 0 1px 0 rgba(15,17,16,0.02), 0 8px 24px rgba(15,17,16,0.04);
}
.pdp-tabs__inner {
  display: flex;
  gap: var(--s-4);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.pdp-tabs__inner::-webkit-scrollbar { display: none; }
.pdp-tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: var(--s-4) 0;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-muted);
  position: relative;
  white-space: nowrap;
  flex-shrink: 0;
  transition: color var(--t-fast) var(--ease-out);
}
.pdp-tab:not(:last-child) { margin-right: var(--s-4); }
.pdp-tab:hover { color: var(--c-ink); }
.pdp-tab.is-active {
  color: var(--c-brand);
  font-weight: 600;
}
.pdp-tab.is-active::after {
  content: ''; position: absolute;
  bottom: -1px; left: 0; right: 0;
  height: 2px;
  background: var(--c-brand);
  border-radius: 2px 2px 0 0;
}
.pdp-tab__count {
  font-size: 10px;
  background: var(--c-accent-soft);
  color: var(--c-brand);
  padding: 1px 6px;
  border-radius: var(--r-full);
  font-weight: 600;
}

/* ----- PDP SECTION ----------------------------------------------------- */
.pdp-section { scroll-margin-top: 70px; }
.pdp-note {
  margin-top: var(--s-7);
  padding: var(--s-5);
  background: var(--c-bg-soft);
  border-left: 3px solid var(--c-accent);
  border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.6;
}
.pdp-note strong { color: var(--c-ink); }

/* ----- CLAIMS GRID ----------------------------------------------------- */
.claims-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 880px) { .claims-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .claims-grid { grid-template-columns: 1fr; } }
.claim {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  transition: border-color var(--t-fast) var(--ease-out), box-shadow var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-snappy);
}
.claim:hover {
  border-color: var(--c-border-2);
  box-shadow: var(--sh-card);
  transform: translateY(-2px);
}
.claim__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  margin-bottom: var(--s-4);
}
.claim__icon svg { width: 28px; height: 28px; }
.claim h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.015em;
  line-height: 1.3;
}
.claim p {
  margin-top: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.6;
}
.claim__src {
  display: block;
  margin-top: var(--s-4);
  padding-top: var(--s-3);
  border-top: 1px dashed var(--c-border);
  font-size: var(--fs-mini);
  color: var(--c-text-soft);
  font-family: var(--ff-display);
  letter-spacing: 0.04em;
}

/* ----- INGREDIENTS ----------------------------------------------------- */
.ingredients {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6);
}
.ingredient--hero { grid-column: 1 / -1; }
@media (max-width: 880px) { .ingredients { grid-template-columns: 1fr; } }
.ingredient {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--s-7);
  padding: var(--s-7);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  align-items: center;
}
.ingredient--hero {
  background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-2) 100%);
  color: #fff;
  border-color: transparent;
}
.ingredient--hero h3 { color: #fff; }
.ingredient--hero p { color: rgba(255,255,255,0.85); }
@media (max-width: 720px) {
  .ingredient { grid-template-columns: 1fr; gap: var(--s-5); padding: var(--s-5); }
}
.ingredient__media {
  position: relative;
  width: 100%; aspect-ratio: 1;
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.08);
  display: flex; align-items: center; justify-content: center;
}
.ingredient:not(.ingredient--hero) .ingredient__media { background: var(--c-accent-soft); }
.ingredient__media--small { aspect-ratio: 1; max-width: 140px; }
.ingredient__atom {
  position: relative;
  width: 70%; aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
}
.atom__core {
  position: absolute;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--c-accent-2), var(--c-accent) 80%);
  box-shadow: 0 8px 24px rgba(0,0,0,0.25), inset -4px -4px 10px rgba(0,0,0,0.2);
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 22px;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.atom__orbit {
  position: absolute;
  border: 1.5px dashed rgba(255,255,255,0.4);
  border-radius: 50%;
  animation: macroSpin 16s linear infinite;
}
.atom__orbit--1 { width: 60%; aspect-ratio: 1; }
.atom__orbit--2 { width: 80%; aspect-ratio: 1; animation-duration: 22s; animation-direction: reverse; }
.atom__orbit--3 { width: 100%; aspect-ratio: 1; animation-duration: 30s; }
.atom__electron {
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 8px rgba(255,255,255,0.8);
}
.atom__electron--1 { animation: electronOrbit 4s linear infinite; }
.atom__electron--2 { animation: electronOrbit 7s linear infinite reverse; }
@keyframes electronOrbit {
  0% { transform: rotate(0deg) translateX(70px) rotate(0deg); }
  100% { transform: rotate(360deg) translateX(70px) rotate(-360deg); }
}
.ingredient__bubble {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-accent), var(--c-brand));
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 28px;
  box-shadow: 0 8px 20px rgba(29,43,30,0.25);
}
.ingredient__pct {
  position: absolute;
  bottom: 12px; right: 12px;
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.2);
  padding: 8px 12px;
  border-radius: var(--r-sm);
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 22px;
  color: #fff;
  display: flex; flex-direction: column; align-items: center;
  line-height: 1;
}
.ingredient:not(.ingredient--hero) .ingredient__pct {
  background: #fff;
  border-color: var(--c-border);
  color: var(--c-brand);
}
.ingredient__pct small {
  font-size: 9px;
  font-weight: 500;
  margin-top: 4px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.85;
}
.ingredient__pct--small { bottom: -8px; right: -8px; font-size: 16px; padding: 6px 10px; }

.ingredient__tag {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--r-full);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}
.ingredient--hero .ingredient__tag { background: rgba(255,255,255,0.15); color: #fff; }
.ingredient h3 {
  font-family: var(--ff-display);
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.2;
}
.ingredient__lead { margin-top: var(--s-3); font-size: var(--fs-md); line-height: 1.55; }
.ingredient__facts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-3);
  margin-top: var(--s-5);
}
.ingredient__facts li {
  padding: var(--s-3) var(--s-4);
  background: rgba(255,255,255,0.08);
  border-radius: var(--r-sm);
  display: flex; flex-direction: column;
}
.ingredient__facts strong { font-family: var(--ff-display); font-size: var(--fs-md); font-weight: 600; color: #fff; }
.ingredient__facts span { font-size: var(--fs-xs); color: rgba(255,255,255,0.75); margin-top: 2px; }
@media (max-width: 540px) { .ingredient__facts { grid-template-columns: 1fr; } }

.ingredient__rws {
  display: inline-block;
  margin-top: var(--s-3);
  background: var(--c-success);
  color: #fff;
  padding: 4px 10px;
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.ingredient-anti {
  grid-column: 1 / -1;
  padding: var(--s-6);
  background: var(--c-bg-soft);
  border-radius: var(--r-lg);
  border: 1px dashed var(--c-border-2);
}
.ingredient-anti h4 {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--c-ink);
  margin-bottom: var(--s-4);
}
.ingredient-anti__list { display: flex; flex-wrap: wrap; gap: var(--s-3); }
.ingredient-anti__list li {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-text);
  text-decoration: line-through;
  text-decoration-color: var(--c-sale);
  text-decoration-thickness: 1.5px;
}
.ingredient-anti__list svg { width: 14px; height: 14px; color: var(--c-sale); flex-shrink: 0; }

/* ----- NUTRITION TABLE ------------------------------------------------- */
.nutrition {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-7);
  align-items: flex-start;
}
@media (max-width: 880px) { .nutrition { grid-template-columns: 1fr; } }

.nutrition-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.nutrition-table thead th {
  text-align: left;
  padding: var(--s-4) var(--s-5);
  background: var(--c-bg-cream);
  font-family: var(--ff-display);
  font-size: var(--fs-mini);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-brand);
  font-weight: 600;
  border-bottom: 1px solid var(--c-border);
}
.nutrition-table thead th small { display: block; font-weight: 400; letter-spacing: 0; text-transform: none; color: var(--c-text-muted); margin-top: 2px; }
.nutrition-table tbody th {
  text-align: left;
  padding: var(--s-5);
  font-family: var(--ff-display);
  font-weight: 600;
  color: var(--c-ink);
  vertical-align: top;
  border-bottom: 1px solid var(--c-border);
  font-size: var(--fs-md);
}
.nutrition-table tbody th small {
  display: block;
  font-weight: 400;
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  margin-top: 2px;
}
.nutrition-table tbody td {
  padding: var(--s-5);
  vertical-align: middle;
  border-bottom: 1px solid var(--c-border);
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  color: var(--c-text);
}
.nutrition-table tbody td strong { color: var(--c-ink); font-weight: 600; }
.nutrition-table tbody tr:last-child td,
.nutrition-table tbody tr:last-child th { border-bottom: 0; }
.nutrition-table tfoot td {
  padding: var(--s-4) var(--s-5);
  background: var(--c-bg-soft);
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  border-top: 1px solid var(--c-border);
}

.rws-bar {
  display: inline-block;
  width: 100px;
  height: 6px;
  background: var(--c-bg-cream);
  border-radius: var(--r-full);
  overflow: hidden;
  vertical-align: middle;
  margin-right: var(--s-2);
}
.rws-bar__fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--c-accent), var(--c-brand));
  border-radius: var(--r-full);
}
.rws-bar__val { font-weight: 600; color: var(--c-brand); }

.nutrition-aside {
  display: flex; flex-direction: column;
  gap: var(--s-5);
}
.ingr-list {
  padding: var(--s-5);
  background: var(--c-bg-cream);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
}
.ingr-list h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
  margin-bottom: var(--s-3);
}
.ingr-list__main {
  font-size: var(--fs-sm);
  line-height: 1.7;
  color: var(--c-text);
}
.allergens, .storage {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--s-4);
  padding: var(--s-5);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  align-items: flex-start;
}
.allergens__icon, .storage__icon {
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--c-accent-soft);
  color: var(--c-brand);
}
.allergens__icon svg, .storage__icon svg { width: 24px; height: 24px; }
.allergens h4, .storage h4 {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
}
.allergens p, .storage p {
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.55;
  margin-top: 4px;
}
.allergens__note { font-size: var(--fs-xs) !important; color: var(--c-text-muted) !important; font-style: italic; }
.allergens p strong, .storage p strong { color: var(--c-ink); font-weight: 600; }

/* ----- HOW-TO ---------------------------------------------------------- */
.how-to { display: grid; gap: var(--s-7); }
.how-to__protocol {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 880px) { .how-to__protocol { grid-template-columns: 1fr; } }
.how-step {
  position: relative;
  padding: var(--s-7) var(--s-6) var(--s-6);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.how-step::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-accent), var(--c-brand));
}
.how-step__num {
  position: absolute;
  top: var(--s-5); right: var(--s-5);
  font-family: var(--ff-serif);
  font-style: italic;
  font-size: 56px;
  color: var(--c-bg-cream);
  font-weight: 500;
  line-height: 1;
  pointer-events: none;
}
.how-step__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  margin-bottom: var(--s-4);
}
.how-step__icon svg { width: 26px; height: 26px; }
.how-step h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.015em;
}
.how-step h3 small {
  display: block;
  font-weight: 400;
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  margin-top: 2px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.how-step p { margin-top: var(--s-3); font-size: var(--fs-sm); color: var(--c-text); line-height: 1.6; }
.how-step p strong { color: var(--c-ink); font-weight: 600; }
.how-step--final::before { background: var(--c-brand); }

.how-to__rules {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
}
@media (max-width: 720px) { .how-to__rules { grid-template-columns: 1fr; } }
.rule {
  padding: var(--s-6);
  border-radius: var(--r-lg);
  border: 1px solid var(--c-border);
}
.rule--good { background: rgba(79,122,57,0.06); border-color: rgba(79,122,57,0.25); }
.rule--bad { background: rgba(184,52,28,0.05); border-color: rgba(184,52,28,0.25); }
.rule__head {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--s-4);
}
.rule__head svg {
  width: 22px; height: 22px;
  padding: 4px;
  border-radius: 50%;
}
.rule--good .rule__head { color: var(--c-success); }
.rule--good .rule__head svg { background: var(--c-success); color: #fff; }
.rule--bad .rule__head { color: var(--c-sale); }
.rule--bad .rule__head svg { background: var(--c-sale); color: #fff; }
.rule ul { display: flex; flex-direction: column; gap: var(--s-2); }
.rule li {
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.55;
  padding-left: 18px;
  position: relative;
}
.rule li::before {
  content: ''; position: absolute;
  top: 9px; left: 0;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.5;
}

.serving-card {
  display: flex; align-items: center; justify-content: center;
  gap: var(--s-7);
  padding: var(--s-7);
  background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-2) 100%);
  color: #fff;
  border-radius: var(--r-lg);
  flex-wrap: wrap;
}
.serving-card__big { display: flex; flex-direction: column; align-items: center; }
.serving-card__big strong {
  font-family: var(--ff-display);
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1;
}
.serving-card__big small {
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-top: var(--s-2);
}
.serving-card__divider { width: 1px; height: 56px; background: rgba(255,255,255,0.2); }
@media (max-width: 720px) { .serving-card__divider { display: none; } }

/* ----- FOR GRID -------------------------------------------------------- */
.for-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 880px) { .for-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .for-grid { grid-template-columns: 1fr; } }
.for-card {
  padding: var(--s-6);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  transition: transform var(--t-base) var(--ease-snappy), border-color var(--t-fast) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.for-card:hover {
  transform: translateY(-2px);
  border-color: var(--c-border-2);
  box-shadow: var(--sh-card);
}
.for-card__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  margin-bottom: var(--s-4);
}
.for-card__icon svg { width: 26px; height: 26px; }
.for-card h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--c-ink);
  line-height: 1.3;
}
.for-card p { margin-top: var(--s-3); font-size: var(--fs-sm); color: var(--c-text); line-height: 1.55; }

.caution {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--s-5);
  margin-top: var(--s-7);
  padding: var(--s-6);
  background: rgba(184,52,28,0.04);
  border: 1px solid rgba(184,52,28,0.20);
  border-radius: var(--r-lg);
  align-items: flex-start;
}
.caution__icon {
  width: 64px; height: 64px;
  border-radius: var(--r-md);
  background: rgba(184,52,28,0.10);
  color: var(--c-sale);
  display: inline-flex; align-items: center; justify-content: center;
}
.caution__icon svg { width: 32px; height: 32px; }
.caution h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-sale);
  margin-bottom: var(--s-3);
}

/* ----- LAB ------------------------------------------------------------- */
.lab {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-7);
  align-items: center;
}
@media (max-width: 880px) { .lab { grid-template-columns: 1fr; } }
.lab-card {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh-3);
  transform: rotate(-1deg);
  transition: transform var(--t-slow) var(--ease-snappy);
}
.lab-card:hover { transform: rotate(0); }
.lab-card__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-5);
  background: var(--c-bg-dark);
  color: #fff;
  font-family: var(--ff-display);
  flex-wrap: wrap; gap: var(--s-3);
}
.lab-card__title { font-weight: 600; font-size: var(--fs-md); letter-spacing: 0.02em; }
.lab-card__lot {
  font-family: 'Courier New', monospace;
  font-size: var(--fs-xs);
  color: var(--c-accent-2);
  background: rgba(255,255,255,0.08);
  padding: 4px 10px;
  border-radius: var(--r-xs);
  letter-spacing: 0.04em;
}
.lab-card__rows { padding: var(--s-3) var(--s-5); }
.lab-row {
  display: grid;
  grid-template-columns: 1.6fr 1fr auto;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  border-bottom: 1px dashed var(--c-border);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  align-items: center;
}
.lab-row:last-child { border-bottom: 0; }
.lab-row span:nth-child(2) { color: var(--c-ink); font-weight: 600; font-family: 'Courier New', monospace; }
.lab-row__ok {
  display: inline-flex;
  background: var(--c-success);
  color: #fff;
  padding: 3px 10px;
  border-radius: var(--r-full);
  font-size: var(--fs-mini);
  font-weight: 700;
  letter-spacing: 0.06em;
}
.lab-card__foot {
  display: flex; justify-content: space-between;
  padding: var(--s-4) var(--s-5);
  background: var(--c-bg-soft);
  font-size: var(--fs-mini);
  color: var(--c-text-muted);
  border-top: 1px solid var(--c-border);
  flex-wrap: wrap; gap: var(--s-2);
}
.lab__copy h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h3);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin-bottom: var(--s-5);
}
.check-list {
  display: flex; flex-direction: column;
  gap: var(--s-3);
  margin-bottom: var(--s-5);
}
.check-list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.55;
  align-items: flex-start;
}
.check-list svg {
  width: 20px; height: 20px;
  padding: 3px;
  border-radius: 50%;
  background: var(--c-success);
  color: #fff;
  flex-shrink: 0;
  margin-top: 2px;
}
.check-list strong { color: var(--c-ink); font-weight: 600; }

/* ----- FAQ (PDP) ------------------------------------------------------- */
.faq__container { max-width: 920px; }
.faq {
  display: flex; flex-direction: column;
  gap: var(--s-3);
}
.faq .faq__item summary { font-size: var(--fs-md); padding: var(--s-5) var(--s-6); }
.faq .faq__item .chev {
  width: 14px; height: 14px;
  flex-shrink: 0;
  margin-left: var(--s-3);
  color: var(--c-text-muted);
  transition: transform var(--t-base) var(--ease-out);
}
.faq .faq__item[open] .chev { transform: rotate(180deg); color: var(--c-brand); }
.faq__body {
  padding: 0 var(--s-6) var(--s-6);
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.7;
  border-top: 1px solid var(--c-border);
  padding-top: var(--s-4);
}
.link-arrow--inline { display: inline-flex; }

/* ----- REVIEWS --------------------------------------------------------- */
.reviews-summary {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s-7);
  padding: var(--s-7);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  margin-bottom: var(--s-7);
  align-items: center;
}
@media (max-width: 880px) { .reviews-summary { grid-template-columns: 1fr; } }
.reviews-summary__big {
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding-right: var(--s-7);
  border-right: 1px solid var(--c-border);
}
@media (max-width: 880px) {
  .reviews-summary__big {
    padding-right: 0; border-right: 0;
    padding-bottom: var(--s-5);
    border-bottom: 1px solid var(--c-border);
  }
}
.reviews-summary__score {
  font-family: var(--ff-display);
  font-size: 64px;
  font-weight: 600;
  color: var(--c-brand);
  line-height: 1;
  letter-spacing: -0.02em;
}
.reviews-summary__score small { font-size: 22px; color: var(--c-text-muted); font-weight: 400; margin-left: 4px; }
.stars--lg { font-size: 22px; letter-spacing: 3px; color: var(--c-accent); margin: var(--s-3) 0; }
.reviews-summary__count {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  font-family: var(--ff-display);
}
.reviews-summary__bars {
  display: flex; flex-direction: column;
  gap: 6px;
}
.rbar {
  display: grid;
  grid-template-columns: 28px 1fr 50px;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
}
.rbar__track {
  height: 8px;
  background: var(--c-bg-cream);
  border-radius: var(--r-full);
  overflow: hidden;
}
.rbar__fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--c-accent), var(--c-brand));
  border-radius: var(--r-full);
  transition: width var(--t-slow) var(--ease-snappy);
}
.rbar__pct { text-align: right; font-weight: 600; color: var(--c-ink); }

.reviews-summary__tags {
  grid-column: 1 / -1;
  display: flex; flex-wrap: wrap; gap: var(--s-2);
  padding-top: var(--s-5);
  border-top: 1px solid var(--c-border);
}
.rtag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  background: var(--c-accent-soft);
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-brand);
}
.rtag small { color: var(--c-text-muted); font-weight: 400; }

.reviews-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 1080px) { .reviews-list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) { .reviews-list { grid-template-columns: 1fr; } }
.review-card {
  padding: var(--s-6);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column;
  gap: var(--s-3);
}
.review-card header {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: var(--s-3);
  align-items: center;
}
.review-card header > div:nth-child(2) { display: flex; flex-direction: column; gap: 2px; }
.review-card h4 {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
}
.review-card__meta {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--fs-mini);
  color: var(--c-success);
}
.review-card__meta svg { width: 12px; height: 12px; }
.review-card .stars { font-size: 13px; letter-spacing: 1px; color: var(--c-accent); }
.review-card h5 {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.review-card p { font-size: var(--fs-sm); color: var(--c-text); line-height: 1.6; }
.review-card footer {
  display: flex; flex-direction: column;
  gap: var(--s-2);
  margin-top: auto;
  padding-top: var(--s-3);
  border-top: 1px solid var(--c-border);
}
.review-card__product {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  color: var(--c-brand);
  font-weight: 500;
}
.review-card__product:hover { color: var(--c-accent); }
.helpful {
  font-size: var(--fs-mini);
  color: var(--c-text-muted);
  display: inline-flex; gap: 6px; align-items: center; flex-wrap: wrap;
}
.helpful button {
  padding: 3px 10px;
  border-radius: var(--r-full);
  border: 1px solid var(--c-border);
  font-size: var(--fs-mini);
  color: var(--c-text);
  font-family: var(--ff-display);
  transition: border-color var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.helpful button:hover { border-color: var(--c-brand); color: var(--c-brand); }

.reviews-more {
  margin-top: var(--s-7);
  display: flex; justify-content: center;
}

/* ----- BUNDLE ---------------------------------------------------------- */
.bundle {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--s-7);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-7);
}
@media (max-width: 880px) { .bundle { grid-template-columns: 1fr; padding: var(--s-5); } }
.bundle__items {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: var(--s-3);
  align-items: stretch;
}
@media (max-width: 720px) {
  .bundle__items { grid-template-columns: 1fr; }
  .bundle__op { display: none; }
}
.bundle-item {
  position: relative;
  padding: var(--s-5);
  background: var(--c-bg-soft);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  gap: var(--s-2);
}
.bundle-item.is-current { border-color: var(--c-brand); background: #fff; }
.bundle-item__check {
  position: absolute;
  top: 12px; right: 12px;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--c-brand);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}
.bundle-item__check svg { width: 12px; height: 12px; }
.bundle-item__media {
  display: flex; align-items: center; justify-content: center;
  height: 180px;
  margin-bottom: var(--s-3);
}
.bundle-item h4 {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
}
.bundle-item__tag {
  font-size: var(--fs-mini);
  color: var(--c-text-muted);
  letter-spacing: 0.04em;
}
.bundle-item .price__now { font-size: var(--fs-md); }
.bundle__op {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-size: 28px;
  font-weight: 300;
  color: var(--c-text-soft);
}

.bundle__sum {
  display: flex; flex-direction: column;
  justify-content: center;
  gap: var(--s-3);
  padding: var(--s-6);
  background: linear-gradient(135deg, var(--c-bg-cream) 0%, var(--c-bg-warm) 100%);
  border-radius: var(--r-md);
}
.bundle__sum-row {
  display: flex; align-items: baseline; justify-content: space-between;
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  color: var(--c-ink);
  font-weight: 600;
}
.bundle__sum-row .price__now { font-size: clamp(24px, 2.4vw, 32px); color: var(--c-brand); }
.bundle__sum-row .price__was { font-size: var(--fs-md); }
.bundle__save {
  display: inline-flex; align-items: center;
  background: var(--c-sale);
  color: #fff;
  padding: 4px 10px;
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: 600;
  align-self: flex-start;
}

/* ----- LEGAL GRID ------------------------------------------------------ */
.legal-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
}
@media (max-width: 720px) { .legal-grid { grid-template-columns: 1fr; } }
.legal-card {
  position: relative;
  padding: var(--s-7);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
}
.legal-card--wide { grid-column: 1 / -1; }
.legal-card__num {
  position: absolute;
  top: var(--s-5); right: var(--s-6);
  font-family: var(--ff-serif);
  font-style: italic;
  font-size: 48px;
  color: var(--c-bg-cream);
  font-weight: 500;
  line-height: 1;
}
.legal-card h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.015em;
  margin-bottom: var(--s-4);
}
.legal-card p {
  font-size: var(--fs-sm);
  color: var(--c-text);
  line-height: 1.6;
  margin-top: var(--s-2);
}
.legal-card__big {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 700;
  color: var(--c-brand);
  margin-top: var(--s-3) !important;
  letter-spacing: 0.02em;
  background: var(--c-accent-soft);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-sm);
  display: inline-block;
}
.legal-card__small {
  font-size: var(--fs-xs) !important;
  color: var(--c-text-muted) !important;
  margin-top: var(--s-3) !important;
}
.legal-list {
  display: flex; flex-direction: column;
  gap: var(--s-2);
}
.legal-list li {
  display: flex; justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-2) 0;
  border-bottom: 1px dashed var(--c-border);
  font-size: var(--fs-sm);
}
.legal-list li:last-child { border-bottom: 0; }
.legal-list span { color: var(--c-text-muted); font-family: var(--ff-display); }
.legal-list strong { color: var(--c-ink); font-family: var(--ff-display); font-weight: 600; }
.legal-ingredients {
  background: var(--c-bg-soft);
  padding: var(--s-5);
  border-radius: var(--r-sm);
  border-left: 3px solid var(--c-brand);
  font-size: var(--fs-sm) !important;
  line-height: 1.7 !important;
}
.legal-ingredients strong { color: var(--c-brand); font-weight: 600; }

/* ----- CROSS-SELL RELATED --------------------------------------------- */
.products--related {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
}
@media (max-width: 1080px) { .products--related { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .products--related { grid-template-columns: 1fr; } }

/* ----- STICKY MOBILE BAR ---------------------------------------------- */
.pdp-sticky {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--c-border);
  z-index: 60;
  padding: var(--s-3) 0;
  transform: translateY(100%);
  transition: transform var(--t-base) var(--ease-snappy);
  box-shadow: 0 -4px 16px rgba(15,17,16,0.08);
}
.pdp-sticky.is-visible { transform: translateY(0); }
.pdp-sticky__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-4);
  align-items: center;
}
.pdp-sticky__info {
  display: flex; align-items: center; gap: var(--s-3);
  min-width: 0;
}
.pdp-sticky__info > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.pdp-sticky__info strong {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pdp-sticky__info .price__now { font-size: var(--fs-sm); }
.pdp-sticky__info .price__was { font-size: var(--fs-xs); }
.pdp-sticky__cta { padding: 12px 22px; }

@media (max-width: 540px) {
  .pdp-buy { padding: var(--s-5); }
  .reviews-summary { padding: var(--s-5); }
  .gallery { padding: var(--s-5); }
  .pdp-tab { padding: var(--s-3) 0; font-size: var(--fs-xs); }
}

/* ==========================================================================
   CHECKOUT — secure & fast one-page
   ========================================================================== */
.page-checkout { background: var(--c-bg-soft); }

/* Topbar variant */
.topbar--checkout {
  background: linear-gradient(90deg, var(--c-brand) 0%, var(--c-brand-2) 100%);
  height: 34px;
}
.topbar--checkout .topbar__item {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11.5px;
  letter-spacing: 0.05em;
}
.topbar--checkout .topbar__item svg { width: 13px; height: 13px; opacity: 0.85; }
.topbar--checkout .topbar__item strong { color: var(--c-accent-2); font-weight: 600; }

/* Header variant — compact + progress */
.header--checkout {
  background: rgba(255,255,255,0.92);
  border-bottom: 1px solid var(--c-border);
}
.header--checkout .header__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-7);
  align-items: center;
}
@media (max-width: 880px) {
  .header--checkout .header__inner { grid-template-columns: auto auto; gap: var(--s-4); }
}

/* Progress steps */
.co-progress {
  justify-self: center;
  max-width: 540px;
  width: 100%;
}
.co-progress ol {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.co-progress ol::before {
  content: '';
  position: absolute;
  top: 14px; left: 12.5%; right: 12.5%;
  height: 1.5px;
  background: var(--c-border-2);
  z-index: 0;
}
.co-progress__step {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  position: relative;
  z-index: 1;
}
.co-progress__dot {
  width: 28px; height: 28px;
  border-radius: var(--r-full);
  background: #fff;
  border: 1.5px solid var(--c-border-2);
  color: var(--c-text-muted);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 600;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out);
}
.co-progress__dot svg { width: 13px; height: 13px; }
.co-progress__label {
  font-family: var(--ff-display);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--c-text-muted);
  white-space: nowrap;
}
.co-progress__step.is-done .co-progress__dot {
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: #fff;
}
.co-progress__step.is-done .co-progress__label { color: var(--c-accent); }
.co-progress__step.is-current .co-progress__dot {
  background: var(--c-brand);
  border-color: var(--c-brand);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(29,43,30,0.10);
}
.co-progress__step.is-current .co-progress__label {
  color: var(--c-brand);
  font-weight: 600;
}
@media (max-width: 880px) {
  .co-progress {
    grid-column: 1 / -1;
    grid-row: 2;
    order: 3;
    padding-top: var(--s-3);
    border-top: 1px solid var(--c-border);
  }
  .co-progress__label { font-size: 10px; }
}

/* Back to shop */
.co-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-muted);
  padding: 8px 12px;
  border-radius: var(--r-full);
  transition: color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.co-back svg { width: 14px; height: 14px; transition: transform var(--t-fast) var(--ease-out); }
.co-back:hover { color: var(--c-brand); background: var(--c-bg-cream); }
.co-back:hover svg { transform: translateX(-2px); }
@media (max-width: 540px) { .co-back span { display: none; } }

.icon-btn--cart.is-active { background: var(--c-brand); color: #fff; }
.icon-btn--cart.is-active:hover { background: var(--c-brand-2); }

/* Intro banner */
.co-intro {
  padding: var(--s-9) 0 var(--s-8);
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
}
.co-intro__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-9);
  align-items: center;
}
@media (max-width: 980px) {
  .co-intro { padding: var(--s-8) 0 var(--s-7); }
  .co-intro__inner { grid-template-columns: 1fr; gap: var(--s-7); }
}
.co-intro__title {
  font-family: var(--ff-display);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--c-ink);
}
.co-intro__title em {
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--c-accent);
}
.co-intro__lead {
  margin-top: var(--s-5);
  font-size: var(--fs-lg);
  color: var(--c-text-muted);
  line-height: 1.55;
  max-width: 520px;
}

/* Trust grid */
.co-trust {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-3);
}
.co-trust li {
  display: flex; align-items: center; gap: var(--s-3);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--s-4) var(--s-4);
  box-shadow: var(--sh-1);
}
.co-trust__icon {
  width: 38px; height: 38px;
  border-radius: var(--r-full);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.co-trust__icon svg { width: 18px; height: 18px; }
.co-trust li > span:last-child {
  display: flex; flex-direction: column; line-height: 1.2;
}
.co-trust li strong {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
}
.co-trust li small {
  font-size: 11.5px;
  color: var(--c-text-soft);
  margin-top: 2px;
}
@media (max-width: 480px) {
  .co-trust { grid-template-columns: 1fr; }
}

/* Two-column main */
.checkout {
  padding: var(--s-9) 0 var(--s-12);
}
.checkout__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 400px;
  gap: var(--s-8);
  align-items: start;
}
@media (max-width: 1080px) {
  .checkout__inner { grid-template-columns: 1fr; }
}

.checkout__main {
  display: flex; flex-direction: column;
  gap: var(--s-6);
}

/* Express checkout */
.co-express {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-6) var(--s-6) var(--s-7);
  box-shadow: var(--sh-card);
}
.co-express__head { margin-bottom: var(--s-4); }
.co-express__head h2 {
  font-family: var(--ff-display);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--c-ink);
  display: flex; align-items: center; gap: var(--s-3); flex-wrap: wrap;
}
.co-express__time {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--c-accent);
  background: var(--c-accent-soft);
  padding: 3px 9px;
  border-radius: var(--r-full);
}
.co-express__head p {
  margin-top: 6px;
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.co-express__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
}
@media (max-width: 720px) { .co-express__row { grid-template-columns: repeat(2, 1fr); } }
.co-express__btn {
  height: 50px;
  border-radius: var(--r-md);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.co-express__btn:hover { transform: translateY(-1px); box-shadow: var(--sh-2); }
.co-express__btn svg { width: 22px; height: 22px; }
.co-express__btn--apple { background: #000; color: #fff; }
.co-express__btn--google { background: #fff; color: #1a1c1b; border-color: var(--c-border-2); }
.co-express__btn--blik {
  background: linear-gradient(135deg, #ff80c0 0%, #d04098 100%);
  color: #fff;
  font-size: 12px;
  flex-direction: column;
  gap: 2px;
  padding: 8px 0;
}
.co-express__blik { font-size: 14px; font-weight: 700; letter-spacing: 0.04em; }
.co-express__btn--paypal { background: #ffc439; color: #003087; }
.co-express__or {
  margin-top: var(--s-6);
  position: relative;
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
}
.co-express__or::before, .co-express__or::after {
  content: '';
  position: absolute; top: 50%;
  width: calc(50% - 90px);
  height: 1px;
  background: var(--c-border);
}
.co-express__or::before { left: 0; }
.co-express__or::after { right: 0; }

/* Step card */
.co-step {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-card);
}
.co-step__head {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-5) var(--s-6);
  border-bottom: 1px solid var(--c-border);
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
  flex-wrap: wrap;
}
.co-step__num {
  width: 30px; height: 30px;
  border-radius: var(--r-full);
  background: var(--c-brand);
  color: #fff;
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.co-step__head h2 {
  font-family: var(--ff-display);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--c-ink);
  flex: 1;
}
.co-step__link {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.co-step__link:hover { color: var(--c-brand); }
.co-step__badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--c-accent);
  background: var(--c-accent-soft);
  padding: 5px 10px;
  border-radius: var(--r-full);
}
.co-step__badge svg { width: 12px; height: 12px; }
.co-step__badge--lock {
  color: var(--c-success);
  background: #e6efdf;
}
.co-step__body {
  padding: var(--s-6);
  display: flex; flex-direction: column; gap: var(--s-5);
}
.co-step__sub {
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--c-ink);
  margin-bottom: -4px;
}

/* Form grid */
.co-grid {
  display: grid;
  gap: var(--s-3);
}
.co-grid--1 { grid-template-columns: 1fr 1fr; }
.co-grid--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) {
  .co-grid--1, .co-grid--2 { grid-template-columns: 1fr; }
}
.co-field { display: flex; flex-direction: column; gap: 6px; }
.co-field--span { grid-column: 1 / -1; }
.co-field__label {
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 500;
  color: var(--c-text-muted);
  letter-spacing: 0.01em;
}
.co-field__label small {
  color: var(--c-text-soft);
  font-weight: 400;
  margin-left: 2px;
}
.co-field__wrap {
  position: relative;
  display: flex; align-items: center;
  background: var(--c-bg-soft);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.co-field__wrap:focus-within {
  border-color: var(--c-brand);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(29,43,30,0.08);
}
.co-field__wrap input,
.co-field__wrap select {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  padding: 13px 14px;
  font-family: var(--ff-body);
  font-size: var(--fs-md);
  color: var(--c-ink);
  width: 100%;
  min-width: 0;
}
.co-field__wrap input::placeholder { color: var(--c-text-soft); }
.co-field__check {
  position: absolute; right: 12px; top: 50%;
  transform: translateY(-50%);
  width: 20px; height: 20px;
  border-radius: var(--r-full);
  background: var(--c-success);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  opacity: 0.95;
}
.co-field__check svg { width: 12px; height: 12px; }
.co-field__hint {
  font-size: 11.5px;
  color: var(--c-text-soft);
  line-height: 1.4;
}
.co-field__wrap--phone { display: flex; align-items: stretch; }
.co-field__prefix {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 0 12px 0 14px;
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 500;
  color: var(--c-ink);
  border-right: 1px solid var(--c-border);
}
.co-field__wrap--select { position: relative; }
.co-field__wrap--select select { appearance: none; padding-right: 38px; cursor: pointer; }
.co-field__chev {
  position: absolute; right: 14px; top: 50%;
  transform: translateY(-50%);
  width: 12px; height: 12px;
  pointer-events: none;
  color: var(--c-text-muted);
}

/* Checkbox */
.co-checkbox {
  display: flex; align-items: flex-start; gap: var(--s-3);
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--c-text);
  cursor: pointer;
  position: relative;
}
.co-checkbox input { position: absolute; opacity: 0; pointer-events: none; }
.co-checkbox__box {
  width: 20px; height: 20px;
  flex-shrink: 0;
  border-radius: 6px;
  background: #fff;
  border: 1.5px solid var(--c-border-2);
  display: inline-flex; align-items: center; justify-content: center;
  color: transparent;
  transition: background var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
  margin-top: 1px;
}
.co-checkbox__box svg { width: 12px; height: 12px; }
.co-checkbox input:checked + .co-checkbox__box {
  background: var(--c-brand);
  border-color: var(--c-brand);
  color: #fff;
}
.co-checkbox a { color: var(--c-brand); text-decoration: underline; text-underline-offset: 2px; }
.co-checkbox a:hover { color: var(--c-accent); }
.co-checkbox small { color: var(--c-text-soft); font-size: inherit; }

/* Shipping options */
.co-ship {
  display: flex; flex-direction: column;
  gap: var(--s-3);
}
.co-ship__opt {
  display: grid;
  grid-template-columns: 22px 56px 1fr auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-4);
  background: var(--c-bg-soft);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
  position: relative;
}
.co-ship__opt input { position: absolute; opacity: 0; pointer-events: none; }
.co-ship__opt:hover { border-color: var(--c-border-2); background: #fff; }
.co-ship__opt.is-selected {
  border-color: var(--c-brand);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(29,43,30,0.06), var(--sh-card);
}
.co-ship__bullet {
  width: 18px; height: 18px;
  border-radius: var(--r-full);
  border: 1.5px solid var(--c-border-2);
  background: #fff;
  position: relative;
  flex-shrink: 0;
  transition: border-color var(--t-fast) var(--ease-out);
}
.co-ship__bullet::after {
  content: '';
  position: absolute; inset: 4px;
  border-radius: var(--r-full);
  background: var(--c-brand);
  transform: scale(0);
  transition: transform var(--t-fast) var(--ease-snappy);
}
.co-ship__opt.is-selected .co-ship__bullet { border-color: var(--c-brand); }
.co-ship__opt.is-selected .co-ship__bullet::after { transform: scale(1); }
.co-ship__media {
  width: 56px; height: 40px;
  border-radius: var(--r-sm);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #fff;
  flex-shrink: 0;
}
.co-ship__media--inpost { background: #ffd200; color: #1a1c1b; }
.co-ship__media--dpd { background: #dc0032; }
.co-ship__media--orlen { background: #ed1c24; }
.co-ship__media--express { background: var(--c-brand); }
.co-ship__media--express svg { width: 18px; height: 18px; }
.co-ship__brand { line-height: 1; }
.co-ship__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.co-ship__body strong {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
}
.co-ship__body small {
  font-size: 12px;
  color: var(--c-text-muted);
  line-height: 1.3;
}
.co-ship__eta {
  margin-top: 4px;
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 600;
  color: var(--c-text-muted);
}
.co-ship__eta svg { width: 11px; height: 11px; }
.co-ship__eta--accent { color: var(--c-accent); }
.co-ship__price {
  text-align: right;
  display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
}
.co-ship__price strong {
  font-family: var(--ff-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-ink);
}
.co-ship__price small s {
  font-size: 11px;
  color: var(--c-text-soft);
  text-decoration: line-through;
}
.co-ship__opt.is-selected .co-ship__price strong { color: var(--c-accent); }
@media (max-width: 540px) {
  .co-ship__opt { grid-template-columns: 18px 44px 1fr; row-gap: var(--s-2); }
  .co-ship__media { width: 44px; height: 32px; font-size: 10px; }
  .co-ship__price {
    grid-column: 2 / -1;
    flex-direction: row; align-items: baseline; gap: 6px;
    text-align: left;
  }
}

/* Paczkomat picker */
.co-paczkomat {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--s-5);
  padding: var(--s-4);
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
}
@media (max-width: 600px) { .co-paczkomat { grid-template-columns: 1fr; } }
.co-paczkomat__map {
  position: relative;
  height: 160px;
  border-radius: var(--r-sm);
  background:
    radial-gradient(circle at 30% 40%, rgba(101,109,65,0.12), transparent 50%),
    radial-gradient(circle at 70% 60%, rgba(29,43,30,0.06), transparent 50%),
    linear-gradient(135deg, #e8ead8 0%, #dadcc7 100%);
  overflow: hidden;
}
.co-paczkomat__streets {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, transparent 49.5%, rgba(255,255,255,0.4) 49.5%, rgba(255,255,255,0.4) 50.5%, transparent 50.5%),
    linear-gradient(180deg, transparent 33%, rgba(255,255,255,0.3) 33%, rgba(255,255,255,0.3) 34%, transparent 34%),
    linear-gradient(180deg, transparent 66%, rgba(255,255,255,0.3) 66%, rgba(255,255,255,0.3) 67%, transparent 67%);
}
.co-paczkomat__pin {
  position: absolute;
  width: 12px; height: 12px;
  background: #ffd200;
  border-radius: var(--r-full);
  border: 2px solid #1a1c1b;
}
.co-paczkomat__pin--1 { top: 25%; left: 20%; }
.co-paczkomat__pin--2 { top: 60%; left: 30%; }
.co-paczkomat__pin--3 { top: 45%; left: 55%; width: 18px; height: 18px; background: var(--c-brand); border-color: var(--c-accent); box-shadow: 0 0 0 6px rgba(29,43,30,0.20); }
.co-paczkomat__pin--3.is-active::after {
  content: '';
  position: absolute; inset: -8px;
  border-radius: var(--r-full);
  border: 1.5px solid var(--c-brand);
  animation: pinPulse 1.6s var(--ease-out) infinite;
}
@keyframes pinPulse {
  0% { transform: scale(0.8); opacity: 1; }
  100% { transform: scale(1.6); opacity: 0; }
}
.co-paczkomat__pin--4 { top: 80%; left: 70%; }
.co-paczkomat__pin--5 { top: 30%; left: 80%; }
.co-paczkomat__info { display: flex; flex-direction: column; gap: 6px; }
.co-paczkomat__tag {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--c-accent);
}
.co-paczkomat__info h4 {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.co-paczkomat__info p {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.co-paczkomat__hours {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12px;
  color: var(--c-success);
  font-weight: 500;
}
.co-paczkomat__hours svg { width: 13px; height: 13px; }
.co-paczkomat__info .btn { margin-top: var(--s-2); align-self: flex-start; }

/* Toggle (faktura) */
.co-toggle {
  background: var(--c-bg-soft);
  border: 1px dashed var(--c-border-2);
  border-radius: var(--r-md);
  padding: var(--s-4);
}
.co-toggle summary {
  list-style: none;
  cursor: pointer;
  display: flex; align-items: center; gap: var(--s-3);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-ink);
}
.co-toggle summary::-webkit-details-marker { display: none; }
.co-toggle__icon {
  width: 32px; height: 32px;
  border-radius: var(--r-full);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.co-toggle__icon svg { width: 16px; height: 16px; }
.co-toggle summary > span { flex: 1; }
.co-toggle__chev {
  width: 12px; height: 12px;
  color: var(--c-text-muted);
  transition: transform var(--t-fast) var(--ease-out);
}
.co-toggle[open] .co-toggle__chev { transform: rotate(180deg); }
.co-toggle__body { padding-top: var(--s-4); }

/* Payment options */
.co-pay { display: flex; flex-direction: column; gap: var(--s-3); }
.co-pay__opt {
  display: grid;
  grid-template-columns: 22px 56px 1fr auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-4);
  background: var(--c-bg-soft);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
  position: relative;
}
.co-pay__opt input { position: absolute; opacity: 0; pointer-events: none; }
.co-pay__opt:hover { border-color: var(--c-border-2); background: #fff; }
.co-pay__opt.is-selected {
  border-color: var(--c-brand);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(29,43,30,0.06), var(--sh-card);
}
.co-pay__bullet {
  width: 18px; height: 18px;
  border-radius: var(--r-full);
  border: 1.5px solid var(--c-border-2);
  background: #fff;
  position: relative;
  flex-shrink: 0;
}
.co-pay__bullet::after {
  content: '';
  position: absolute; inset: 4px;
  border-radius: var(--r-full);
  background: var(--c-brand);
  transform: scale(0);
  transition: transform var(--t-fast) var(--ease-snappy);
}
.co-pay__opt.is-selected .co-pay__bullet { border-color: var(--c-brand); }
.co-pay__opt.is-selected .co-pay__bullet::after { transform: scale(1); }
.co-pay__media {
  width: 56px; height: 36px;
  border-radius: var(--r-sm);
  display: inline-flex; align-items: center; justify-content: center; gap: 3px;
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #fff;
  flex-shrink: 0;
}
.co-pay__media .pay {
  font-size: 9px; padding: 2px 4px; border-radius: 3px;
  background: rgba(255,255,255,0.2); color: inherit;
  border: 0;
}
.co-pay__media--blik { background: linear-gradient(135deg, #ff80c0 0%, #d04098 100%); }
.co-pay__media--card { background: linear-gradient(135deg, #2a3d2b 0%, #0f1a10 100%); padding: 0 6px; }
.co-pay__media--p24 { background: #ee3f43; }
.co-pay__media--apple { background: #000; }
.co-pay__media--apple svg { width: 24px; height: 24px; }
.co-pay__media--klarna { background: #ffa8cd; color: #17120c; font-size: 10px; }
.co-pay__media--cod { background: var(--c-bg-cream); color: var(--c-brand); }
.co-pay__media--cod svg { width: 22px; height: 22px; }
.co-pay__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.co-pay__body strong {
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
}
.co-pay__body small {
  font-size: 12px;
  color: var(--c-text-muted);
  line-height: 1.3;
}
.co-pay__time {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 500;
  color: var(--c-accent);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
@media (max-width: 540px) {
  .co-pay__opt { grid-template-columns: 18px 44px 1fr; row-gap: var(--s-2); }
  .co-pay__media { width: 44px; height: 28px; font-size: 9px; }
  .co-pay__media--apple svg { width: 18px; height: 18px; }
  .co-pay__time { grid-column: 2 / -1; }
}

/* BLIK input */
.co-blik {
  margin-top: -4px;
  padding: var(--s-5);
  background: linear-gradient(135deg, #fff5f9 0%, #ffe7f1 100%);
  border: 1px solid #fbcfdf;
  border-radius: var(--r-md);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.co-blik__label {
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: #d04098;
}
.co-blik__inputs {
  display: inline-flex; align-items: center; gap: 6px;
}
.co-blik__inputs input {
  width: 42px; height: 52px;
  text-align: center;
  border: 1.5px solid #f5b3cd;
  background: #fff;
  border-radius: var(--r-sm);
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 600;
  color: #1a1c1b;
  outline: 0;
  transition: border-color var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.co-blik__inputs input:focus { border-color: #d04098; box-shadow: 0 0 0 4px rgba(208,64,152,0.15); }
.co-blik__sep {
  width: 16px; text-align: center;
  font-size: 22px; color: #d04098; opacity: 0.4; user-select: none;
}
.co-blik__hint {
  font-size: 12px;
  color: var(--c-text-muted);
}
@media (max-width: 480px) {
  .co-blik__inputs input { width: 36px; height: 44px; font-size: 18px; }
}

/* Secure note inline */
.co-secure {
  display: flex; align-items: flex-start; gap: var(--s-3);
  padding: var(--s-4);
  background: #f0f4ec;
  border: 1px solid #d8e2ce;
  border-radius: var(--r-md);
  font-size: 12.5px;
  color: var(--c-text);
  line-height: 1.5;
}
.co-secure__lock {
  width: 28px; height: 28px;
  border-radius: var(--r-full);
  background: var(--c-success);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.co-secure__lock svg { width: 14px; height: 14px; }

/* Final block */
.co-final {
  display: flex; flex-direction: column;
  gap: var(--s-5);
  padding: var(--s-6);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-card);
}
.co-promo {
  background: var(--c-bg-soft);
  border: 1px dashed var(--c-border-2);
  border-radius: var(--r-md);
  padding: var(--s-4);
}
.co-promo summary {
  list-style: none;
  cursor: pointer;
  display: flex; align-items: center; gap: var(--s-3);
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-ink);
}
.co-promo summary::-webkit-details-marker { display: none; }
.co-promo__icon {
  width: 32px; height: 32px;
  border-radius: var(--r-full);
  background: #fffaee;
  color: #c89329;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.co-promo__icon svg { width: 15px; height: 15px; }
.co-promo summary > span { flex: 1; }
.co-promo__chev {
  width: 12px; height: 12px;
  color: var(--c-text-muted);
  transition: transform var(--t-fast) var(--ease-out);
}
.co-promo[open] .co-promo__chev { transform: rotate(180deg); }
.co-promo__row {
  margin-top: var(--s-4);
  display: flex; gap: var(--s-3);
}
.co-promo__row input {
  flex: 1;
  background: #fff;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 12px 14px;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--c-ink);
  outline: 0;
}
.co-promo__row input:focus { border-color: var(--c-brand); }
.co-promo__applied {
  margin-top: var(--s-3);
  display: flex; align-items: center; gap: 6px;
  font-size: 12.5px;
  color: var(--c-success);
  font-weight: 500;
}
.co-promo__applied svg { width: 16px; height: 16px; flex-shrink: 0; }

.co-terms {
  display: flex; flex-direction: column; gap: var(--s-3);
  padding: var(--s-5);
  background: var(--c-bg-soft);
  border-radius: var(--r-md);
}

.co-cta {
  height: 64px;
  font-size: 15px;
  font-weight: 600;
  background: linear-gradient(180deg, var(--c-brand) 0%, var(--c-brand-3) 100%);
  position: relative;
}
.co-cta:hover {
  background: linear-gradient(180deg, var(--c-brand-2) 0%, var(--c-brand) 100%);
  box-shadow: 0 4px 8px rgba(29,43,30,0.16), 0 16px 32px rgba(29,43,30,0.24);
}
.co-cta strong { font-weight: 700; }
.co-cta__lock {
  width: 22px; height: 22px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.18);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.co-cta__lock svg { width: 12px; height: 12px; }
.co-secure-note {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 11.5px;
  color: var(--c-text-soft);
  line-height: 1.5;
  text-align: left;
}
.co-secure-note svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 2px; color: var(--c-success); }
.co-secure-note strong { color: var(--c-ink); font-weight: 500; }

/* SUMMARY (right column) */
.checkout__aside {
  position: sticky;
  top: calc(var(--header-h) + var(--topbar-h) + var(--s-5));
}
@media (max-width: 1080px) { .checkout__aside { position: static; } }

.co-summary {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-card);
  display: flex; flex-direction: column;
}
.co-summary__head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: var(--s-5) var(--s-6);
  border-bottom: 1px solid var(--c-border);
  background: linear-gradient(180deg, #fff 0%, var(--c-bg-soft) 100%);
}
.co-summary__head h2 {
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.co-summary__count {
  font-size: 12px;
  color: var(--c-text-muted);
  font-weight: 500;
}

.co-lines {
  padding: var(--s-3) var(--s-6);
  display: flex; flex-direction: column;
}
.co-line {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: var(--s-3);
  align-items: flex-start;
  padding: var(--s-4) 0;
  border-bottom: 1px dashed var(--c-border);
}
.co-line:last-child { border-bottom: 0; }
.co-line__media {
  position: relative;
  width: 64px; height: 64px;
  border-radius: var(--r-sm);
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  display: inline-flex; align-items: center; justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}
.co-line__media img { max-width: 80%; max-height: 80%; }
.co-line__qty-badge {
  position: absolute; top: -6px; right: -6px;
  min-width: 18px; height: 18px;
  border-radius: var(--r-full);
  background: var(--c-brand);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 5px;
}
.co-line__body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.co-line__body h4 {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.co-line__variant {
  font-size: 11.5px;
  color: var(--c-text-muted);
  line-height: 1.3;
}
.co-line__qty {
  margin-top: 4px;
  display: inline-flex; align-items: center;
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  padding: 2px;
  width: max-content;
}
.co-line__qty button {
  width: 22px; height: 22px;
  border-radius: var(--r-full);
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 500;
  color: var(--c-text-muted);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.co-line__qty button:hover { background: var(--c-brand); color: #fff; }
.co-line__qty input {
  width: 28px;
  text-align: center;
  background: transparent;
  border: 0;
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 600;
  color: var(--c-ink);
  outline: 0;
}
.co-line__price {
  text-align: right;
  display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
  position: relative;
}
.co-line__price strong {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.co-line__price s {
  font-size: 11px;
  color: var(--c-text-soft);
}
.co-line__remove {
  margin-top: 4px;
  width: 22px; height: 22px;
  border-radius: var(--r-full);
  color: var(--c-text-soft);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.co-line__remove:hover { background: #fdebe7; color: var(--c-sale); }
.co-line__remove svg { width: 12px; height: 12px; }

.co-totals {
  padding: var(--s-5) var(--s-6);
  background: var(--c-bg-soft);
  border-top: 1px solid var(--c-border);
  display: flex; flex-direction: column; gap: 8px;
}
.co-totals__row {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--ff-display);
  font-size: 13px;
  color: var(--c-text);
  gap: var(--s-3);
}
.co-totals__row > span:first-child {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--c-text-muted);
}
.co-totals__row > span:first-child svg { width: 13px; height: 13px; flex-shrink: 0; }
.co-totals__row--save > span { color: var(--c-success); font-weight: 500; }
.co-totals__free { color: var(--c-success); font-weight: 600; }
.co-totals__row--total {
  margin-top: 6px;
  padding-top: var(--s-3);
  border-top: 1px solid var(--c-border);
  font-size: var(--fs-md);
  color: var(--c-ink);
  font-weight: 600;
}
.co-totals__row--total > span:first-child { color: var(--c-ink); }
.co-totals__amount {
  font-size: 22px;
  font-weight: 700;
  color: var(--c-brand);
  letter-spacing: -0.02em;
}
.co-totals__vat {
  font-size: 11px;
  color: var(--c-text-soft);
  text-align: right;
  margin-top: 2px;
}

.co-summary__cta {
  margin: var(--s-5) var(--s-6) var(--s-3);
  height: 56px;
  font-size: 14px;
  font-weight: 600;
}
.co-summary__cta svg { width: 16px; height: 16px; }
@media (min-width: 1081px) {
  .co-summary__cta { display: none; }
}

.co-summary__perks {
  display: flex; flex-direction: column; gap: 8px;
  padding: var(--s-3) var(--s-6) var(--s-5);
}
.co-summary__perks li {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px;
  color: var(--c-text-muted);
}
.co-summary__perks svg { width: 14px; height: 14px; color: var(--c-success); flex-shrink: 0; }
.co-summary__perks strong { color: var(--c-ink); font-weight: 500; }

.co-summary__secure {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4) var(--s-6);
  background: linear-gradient(180deg, var(--c-brand) 0%, var(--c-brand-3) 100%);
  color: #fff;
}
.co-summary__lock {
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.12);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--c-accent-2);
}
.co-summary__lock svg { width: 20px; height: 20px; }
.co-summary__secure > div { display: flex; flex-direction: column; gap: 2px; }
.co-summary__secure strong {
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: #fff;
}
.co-summary__secure small {
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: var(--c-accent-2);
  opacity: 0.9;
}
.co-summary__pay {
  display: flex; flex-wrap: wrap; gap: 5px;
  padding: var(--s-3) var(--s-6) var(--s-4);
  background: var(--c-bg-soft);
}
.co-summary__pay .pay {
  font-size: 9px;
  padding: 3px 6px;
  background: #fff;
  color: var(--c-ink);
  border: 1px solid var(--c-border);
  border-radius: 4px;
  font-family: var(--ff-display);
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* Bottom assurance */
.co-assure {
  padding: var(--s-9) 0 var(--s-10);
  background: #fff;
  border-top: 1px solid var(--c-border);
}
.co-assure__inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
}
@media (max-width: 980px) { .co-assure__inner { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .co-assure__inner { grid-template-columns: 1fr; } }
.co-assure__item {
  text-align: left;
}
.co-assure__icon {
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--s-4);
}
.co-assure__icon svg { width: 24px; height: 24px; }
.co-assure__item h3 {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--c-ink);
  margin-bottom: 6px;
}
.co-assure__item p {
  font-size: 13px;
  color: var(--c-text-muted);
  line-height: 1.5;
}
.co-assure__item strong { color: var(--c-ink); }

/* Providers strip */
.co-providers {
  padding: var(--s-7) 0 var(--s-9);
  background: var(--c-bg-soft);
  text-align: center;
}
.co-providers__head {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-text-soft);
  margin-bottom: var(--s-5);
}
.co-providers__row {
  display: flex; flex-wrap: wrap; justify-content: center; gap: var(--s-7) var(--s-9);
}
.co-provider {
  display: inline-flex; flex-direction: column; align-items: center; gap: 2px;
  opacity: 0.55;
  transition: opacity var(--t-fast) var(--ease-out);
}
.co-provider:hover { opacity: 1; }
.co-provider strong {
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--c-ink);
  letter-spacing: -0.02em;
}
.co-provider small {
  font-size: 10px;
  color: var(--c-text-soft);
  letter-spacing: 0.05em;
}

/* Mobile sticky bar */
.co-mobile {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  background: #fff;
  border-top: 1px solid var(--c-border);
  z-index: 60;
  padding: var(--s-3) 0;
  box-shadow: 0 -4px 16px rgba(15,17,16,0.08);
}
@media (max-width: 1080px) { .co-mobile { display: block; } }
.co-mobile__inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-3);
  align-items: center;
}
.co-mobile__sum {
  display: flex; flex-direction: column;
  line-height: 1.1;
}
.co-mobile__sum span {
  font-size: 11px;
  color: var(--c-text-soft);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.co-mobile__sum strong {
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--c-brand);
  letter-spacing: -0.02em;
}
.co-mobile__cta { padding: 14px 22px; }
.co-mobile__cta svg { width: 16px; height: 16px; }

@media (max-width: 1080px) {
  body.page-checkout { padding-bottom: 80px; }
}

/* Footer variant */
.footer--checkout {
  background: var(--c-brand);
  color: #fff;
  padding: var(--s-5) 0;
}
.footer--checkout .footer__bottom {
  border-top: 0;
  padding: 0;
  display: flex; flex-wrap: wrap; gap: var(--s-5);
  align-items: center; justify-content: space-between;
  font-size: 11.5px;
}
.footer--checkout p { color: rgba(255,255,255,0.6); }
.footer--checkout .footer__legal { display: flex; flex-wrap: wrap; gap: var(--s-4); }
.footer--checkout .footer__legal a {
  color: rgba(255,255,255,0.7);
  font-size: 11.5px;
  text-decoration: none;
}
.footer--checkout .footer__legal a:hover { color: #fff; }
.footer--checkout .payments { display: flex; gap: 5px; flex-wrap: wrap; }
.footer--checkout .pay {
  font-size: 9px; padding: 3px 6px;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.85);
  border: 0;
  border-radius: 4px;
  font-family: var(--ff-display);
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* btn--sm variant for checkout */
.btn--sm { padding: 8px 14px; font-size: 12px; }
.btn--sm svg { width: 13px; height: 13px; }

/* ==========================================================================
   CONTACT PAGE
   ========================================================================== */

/* Quick contact methods */
.contact-methods { padding: var(--s-2) 0 var(--s-9); }
.contact-methods__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}
@media (max-width: 1080px) { .contact-methods__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .contact-methods__grid { grid-template-columns: 1fr; } }

.cm-card {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-5);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-1);
  text-align: left;
  font: inherit;
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              border-color var(--t-fast) var(--ease-out);
}
.cm-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-card-hover);
  border-color: var(--c-accent-soft);
}
.cm-card__icon {
  width: 44px; height: 44px;
  flex-shrink: 0;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
}
.cm-card__icon svg { width: 22px; height: 22px; }
.cm-card__body {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 0;
  flex: 1;
}
.cm-card__label {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-accent);
}
.cm-card__value {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--c-ink);
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.cm-card__hint {
  font-size: 12.5px;
  color: var(--c-text-muted);
  display: inline-flex; align-items: center; gap: var(--s-2);
  line-height: 1.4;
}
.cm-card--feature {
  background: var(--c-brand);
  border-color: var(--c-brand);
  color: #fff;
}
.cm-card--feature .cm-card__icon { background: rgba(255,255,255,0.12); color: #fff; }
.cm-card--feature .cm-card__label { color: var(--c-accent-2); }
.cm-card--feature .cm-card__value { color: #fff; }
.cm-card--feature .cm-card__hint { color: rgba(255,255,255,0.72); }
.cm-card--feature:hover { border-color: var(--c-brand); }
.cm-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--c-success);
  box-shadow: 0 0 0 3px rgba(79,122,57,0.18);
}

/* Main two-column: form + aside */
.contact-main { padding: 0 0 var(--s-10); }
.contact-main__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr);
  gap: var(--s-8);
  align-items: flex-start;
}
@media (max-width: 980px) { .contact-main__grid { grid-template-columns: 1fr; } }

/* Form */
.contact-form {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-7) var(--s-7) var(--s-7);
  box-shadow: var(--sh-card);
}
@media (max-width: 540px) { .contact-form { padding: var(--s-5); } }
.contact-form__head { margin-bottom: var(--s-6); }
.contact-form__head h2 {
  font-family: var(--ff-display);
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin-top: var(--s-2);
}
.contact-form__head p {
  margin-top: var(--s-3);
  color: var(--c-text-muted);
  font-size: var(--fs-sm);
  line-height: 1.55;
}
.contact-form__head [aria-hidden],
.contact-form__topic [aria-hidden],
.co-field__label [aria-hidden] { color: var(--c-sale); margin-left: 2px; }
.contact-form__body {
  display: flex; flex-direction: column;
  gap: var(--s-5);
}

/* Topic pills */
.contact-form__topic { border: 0; padding: 0; }
.contact-form__topic legend {
  margin-bottom: var(--s-3);
  display: block;
}
.contact-topic {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-2);
}
@media (max-width: 720px) { .contact-topic { grid-template-columns: repeat(2, 1fr); } }
.ct-pill {
  position: relative;
  display: flex; align-items: center; gap: var(--s-2);
  padding: 10px 12px;
  background: var(--c-bg-soft);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 500;
  color: var(--c-text);
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease-out),
              background var(--t-fast) var(--ease-out),
              color var(--t-fast) var(--ease-out);
}
.ct-pill input { position: absolute; opacity: 0; pointer-events: none; }
.ct-pill__icon {
  width: 26px; height: 26px;
  flex-shrink: 0;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--c-border);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-accent);
  transition: background var(--t-fast) var(--ease-out),
              color var(--t-fast) var(--ease-out),
              border-color var(--t-fast) var(--ease-out);
}
.ct-pill__icon svg { width: 14px; height: 14px; }
.ct-pill:hover { border-color: var(--c-border-2); background: #fff; }
.ct-pill.is-selected {
  background: var(--c-brand);
  border-color: var(--c-brand);
  color: #fff;
}
.ct-pill.is-selected .ct-pill__icon {
  background: rgba(255,255,255,0.14);
  border-color: transparent;
  color: #fff;
}

/* Textarea wrap */
.co-field__wrap--area { align-items: stretch; padding: 0; }
.co-field__wrap--area textarea {
  flex: 1;
  width: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  padding: 12px 14px;
  resize: vertical;
  min-height: 130px;
  font-family: var(--ff-body);
  font-size: var(--fs-md);
  color: var(--c-ink);
  line-height: 1.5;
}
.co-field__wrap--area textarea::placeholder { color: var(--c-text-soft); }

/* Attach */
.contact-attach { position: relative; cursor: pointer; }
.contact-attach input[type="file"] {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  opacity: 0;
  cursor: pointer;
}
.contact-attach__inner {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4);
  background: var(--c-bg-soft);
  border: 1.5px dashed var(--c-border-2);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast) var(--ease-out),
              background var(--t-fast) var(--ease-out);
}
.contact-attach:hover .contact-attach__inner {
  border-color: var(--c-brand);
  background: #fff;
}
.contact-attach__icon {
  width: 36px; height: 36px;
  flex-shrink: 0;
  border-radius: var(--r-sm);
  background: #fff;
  border: 1px solid var(--c-border);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-accent);
}
.contact-attach__icon svg { width: 16px; height: 16px; }
.contact-attach__text {
  display: flex; flex-direction: column;
  font-family: var(--ff-display);
  font-size: 13.5px;
  color: var(--c-ink);
}
.contact-attach__text strong { font-weight: 600; }
.contact-attach__text small {
  font-size: 11.5px;
  font-weight: 400;
  color: var(--c-text-soft);
}

/* Form actions */
.contact-form__actions {
  display: flex; align-items: center; gap: var(--s-5);
  flex-wrap: wrap;
  margin-top: var(--s-3);
  padding-top: var(--s-5);
  border-top: 1px solid var(--c-border);
}
.contact-form__note {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: 12px;
  color: var(--c-text-soft);
}
.contact-form__note svg { width: 14px; height: 14px; color: var(--c-accent); }

/* Aside */
.contact-aside {
  display: flex; flex-direction: column;
  gap: var(--s-4);
  position: sticky;
  top: calc(var(--header-h) + var(--s-4));
}
@media (max-width: 980px) { .contact-aside { position: static; } }

.ca-card {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-5);
}
.ca-card__eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: var(--s-3);
}
.ca-card__eyebrow svg { width: 14px; height: 14px; }

.ca-hours {
  display: flex; flex-direction: column;
  gap: 8px;
  font-size: 13.5px;
}
.ca-hours li {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--s-3);
  padding: 6px 0;
  border-bottom: 1px dashed var(--c-border);
}
.ca-hours li:last-child { border-bottom: 0; }
.ca-hours span { color: var(--c-text-muted); }
.ca-hours strong {
  font-family: var(--ff-display);
  font-weight: 600;
  color: var(--c-ink);
}
.ca-hours strong.is-closed { color: var(--c-text-soft); font-weight: 500; }
.ca-status {
  display: inline-flex; align-items: center; gap: var(--s-2);
  margin-top: var(--s-3);
  padding: 8px 12px;
  background: rgba(79,122,57,0.08);
  border-radius: var(--r-full);
  font-size: 12.5px;
  color: var(--c-success);
  width: fit-content;
}
.ca-status__dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--c-success);
  box-shadow: 0 0 0 3px rgba(79,122,57,0.20);
  flex-shrink: 0;
}
.ca-status strong { color: var(--c-success); font-weight: 600; }

.ca-address {
  font-style: normal;
  font-size: 14px;
  color: var(--c-text);
  line-height: 1.55;
}
.ca-address strong {
  display: block;
  font-family: var(--ff-display);
  font-weight: 600;
  color: var(--c-ink);
  margin-bottom: 4px;
}
.ca-note {
  margin-top: var(--s-2);
  font-size: 12.5px;
  color: var(--c-text-muted);
}
.ca-link {
  display: inline-flex; align-items: center; gap: var(--s-2);
  margin-top: var(--s-4);
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 500;
  color: var(--c-brand);
  transition: gap var(--t-fast) var(--ease-snappy);
}
.ca-link svg { width: 14px; height: 14px; }
.ca-link:hover { gap: var(--s-3); color: var(--c-accent); }

.ca-data {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-3) var(--s-4);
  font-size: 13px;
}
.ca-data > div { display: flex; flex-direction: column; gap: 2px; }
.ca-data dt {
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}
.ca-data dd {
  font-family: var(--ff-display);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.005em;
}

.ca-card--social { padding-bottom: var(--s-4); }
.ca-socials {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-2);
}
.ca-socials a {
  display: flex; align-items: center; gap: var(--s-2);
  padding: 10px 12px;
  background: var(--c-bg-soft);
  border-radius: var(--r-md);
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 500;
  color: var(--c-ink);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.ca-socials a svg { width: 16px; height: 16px; color: var(--c-accent); }
.ca-socials a:hover { background: var(--c-brand); color: #fff; }
.ca-socials a:hover svg { color: var(--c-accent-2); }

/* Departments */
.contact-depts { padding: var(--s-9) 0; background: var(--c-bg-soft); }
.contact-depts__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}
@media (max-width: 1080px) { .contact-depts__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .contact-depts__grid { grid-template-columns: 1fr; } }

.dept-card {
  display: flex; flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-5);
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  transition: transform var(--t-fast) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              border-color var(--t-fast) var(--ease-out);
}
.dept-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-card-hover);
  border-color: var(--c-accent-soft);
}
.dept-card__icon {
  width: 40px; height: 40px;
  flex-shrink: 0;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--s-2);
}
.dept-card__icon svg { width: 20px; height: 20px; }
.dept-card h3 {
  font-family: var(--ff-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.dept-card p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--c-text-muted);
  flex: 1;
}
.dept-card__link {
  display: inline-flex; align-items: center;
  margin-top: var(--s-2);
  font-family: var(--ff-display);
  font-size: 13.5px;
  font-weight: 600;
  color: var(--c-brand);
  letter-spacing: -0.005em;
  transition: color var(--t-fast) var(--ease-out);
}
.dept-card__link:hover { color: var(--c-accent); }
.dept-card__phone {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: var(--s-1);
  font-size: 12px;
  color: var(--c-text-soft);
}
.dept-card__phone svg { width: 12px; height: 12px; }

/* Map / showroom */
.contact-map { padding: var(--s-10) 0 var(--s-9); }
.contact-map__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: var(--s-8);
  align-items: center;
}
@media (max-width: 980px) {
  .contact-map__inner { grid-template-columns: 1fr; gap: var(--s-7); }
}
.contact-map__info h2 {
  font-family: var(--ff-display);
  font-size: clamp(28px, 3.4vw, 42px);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin-top: var(--s-2);
}
.contact-map__info p {
  margin-top: var(--s-4);
  font-size: var(--fs-md);
  line-height: 1.6;
  color: var(--c-text-muted);
  max-width: 480px;
}
.contact-map__features {
  display: flex; flex-direction: column;
  gap: var(--s-2);
  margin-top: var(--s-5);
}
.contact-map__features li {
  display: flex; align-items: flex-start; gap: var(--s-3);
  font-size: 14px;
  line-height: 1.5;
  color: var(--c-text);
}
.contact-map__features li > span {
  width: 22px; height: 22px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: 1px;
}
.contact-map__features li > span svg { width: 12px; height: 12px; }
.contact-map__actions {
  display: flex; gap: var(--s-3);
  flex-wrap: wrap;
  margin-top: var(--s-6);
}

.contact-map__map {
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-card);
  border: 1px solid var(--c-border);
}
.contact-map__placeholder {
  position: relative;
  aspect-ratio: 4 / 3;
  background:
    radial-gradient(circle at 60% 50%, rgba(101,109,65,0.10), transparent 60%),
    linear-gradient(180deg, var(--c-bg-cream) 0%, var(--c-bg-warm) 100%);
  overflow: hidden;
}
.contact-map__grid {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
}
.contact-map__pin {
  position: absolute;
  left: 60%; top: 56%;
  transform: translate(-50%, -100%);
  pointer-events: none;
}
.contact-map__pulse {
  position: absolute;
  left: 50%; bottom: -8px;
  transform: translateX(-50%);
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--c-brand);
  opacity: 0.18;
  animation: cmPulse 2.4s var(--ease-out) infinite;
}
@keyframes cmPulse {
  0%   { transform: translateX(-50%) scale(0.6); opacity: 0.45; }
  70%  { transform: translateX(-50%) scale(1.6); opacity: 0; }
  100% { transform: translateX(-50%) scale(1.6); opacity: 0; }
}
.contact-map__marker {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  color: var(--c-brand);
  filter: drop-shadow(0 6px 14px rgba(15,17,16,0.20));
}
.contact-map__marker svg { width: 100%; height: 100%; }
.contact-map__bubble {
  position: absolute;
  left: var(--s-5); bottom: var(--s-5);
  display: flex; flex-direction: column; gap: 2px;
  padding: var(--s-4) var(--s-5);
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(8px);
  border-radius: var(--r-md);
  box-shadow: var(--sh-3);
  font-size: 12.5px;
  color: var(--c-text-muted);
  max-width: 220px;
}
.contact-map__bubble strong {
  font-family: var(--ff-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--c-ink);
  margin-bottom: 2px;
}

/* ==========================================================================
   BLOG — POJEDYNCZY ARTYKUŁ
   ========================================================================== */
.page-article main { padding-bottom: var(--s-10); }

.article { padding-top: var(--s-7); }

/* Hero */
.article__head { padding-bottom: var(--s-9); }
.article__head-inner {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}
.article__title {
  margin-top: var(--s-3);
  font-family: var(--ff-serif);
  font-size: clamp(34px, 4.4vw, 56px);
  font-weight: 500;
  letter-spacing: -0.022em;
  line-height: 1.08;
  color: var(--c-ink);
}
.article__lead {
  margin-top: var(--s-5);
  font-family: var(--ff-display);
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  color: var(--c-text-muted);
  letter-spacing: -0.005em;
}
.article__meta {
  margin-top: var(--s-7);
  padding-top: var(--s-5);
  border-top: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--s-5);
  text-align: left;
}
.article__author {
  display: inline-flex; align-items: center; gap: var(--s-3);
}
.article__avatar {
  width: 44px; height: 44px;
  border-radius: var(--r-full);
  background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-2) 100%);
  color: #fff;
  font-family: var(--ff-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.article__author strong {
  display: block;
  font-family: var(--ff-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ink);
}
.article__author span {
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
}
.article__info {
  display: inline-flex; align-items: center; gap: var(--s-5);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.article__share { display: inline-flex; gap: var(--s-2); }
.share-btn {
  width: 36px; height: 36px;
  border-radius: var(--r-full);
  border: 1px solid var(--c-border);
  background: #fff;
  color: var(--c-text-muted);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--t-fast) var(--ease-out),
              color var(--t-fast) var(--ease-out),
              border-color var(--t-fast) var(--ease-out),
              transform var(--t-fast) var(--ease-out);
}
.share-btn svg { width: 15px; height: 15px; }
.share-btn:hover {
  background: var(--c-brand);
  color: #fff;
  border-color: var(--c-brand);
  transform: translateY(-1px);
}

.article__cover {
  margin-top: var(--s-9);
  width: 100%;
  max-width: var(--container);
  margin-left: auto; margin-right: auto;
  padding: 0 var(--container-pad);
}
.article__cover-img {
  width: 100%;
  aspect-ratio: 16 / 8;
  background-size: cover;
  background-position: center;
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-3);
}

/* Body — pełna szerokość containera (jak baner i reszta strony) */
.article__body {
  padding-top: var(--s-9);
  font-family: var(--ff-body);
  font-size: 17px;
  line-height: 1.75;
  color: var(--c-text);
}
.article__body > * + * { margin-top: var(--s-5); }
.article__body h2 + p { margin-top: var(--s-4); }

.article__h2 {
  margin-top: var(--s-9) !important;
  font-family: var(--ff-serif);
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 500;
  letter-spacing: -0.018em;
  line-height: 1.2;
  color: var(--c-ink);
}
.article__body p strong { color: var(--c-ink); font-weight: 600; }
.article__body a { color: var(--c-brand); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; transition: color var(--t-fast); }
.article__body a:hover { color: var(--c-accent); }

.article__dropcap::first-letter {
  float: left;
  font-family: var(--ff-serif);
  font-size: 76px;
  line-height: 0.85;
  font-weight: 500;
  color: var(--c-brand);
  padding: 6px 12px 0 0;
  letter-spacing: -0.02em;
}

.article__list {
  padding-left: 0;
  list-style: none;
  display: flex; flex-direction: column; gap: var(--s-3);
}
.article__list li {
  position: relative;
  padding-left: var(--s-7);
}
.article__list li::before {
  content: '';
  position: absolute;
  left: 8px; top: 12px;
  width: 6px; height: 6px;
  border-radius: var(--r-full);
  background: var(--c-accent);
}
.article__list--ordered { counter-reset: alist; }
.article__list--ordered li {
  counter-increment: alist;
  padding-left: var(--s-9);
}
.article__list--ordered li::before {
  content: counter(alist);
  width: 26px; height: 26px;
  left: 0; top: 5px;
  background: var(--c-accent-soft);
  color: var(--c-brand);
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

.article__quote {
  margin: var(--s-8) 0 !important;
  padding: var(--s-7) var(--s-8);
  background: var(--c-bg-soft);
  border-left: 3px solid var(--c-accent);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  font-family: var(--ff-serif);
  font-size: 21px;
  font-style: italic;
  line-height: 1.5;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.article__quote cite {
  display: block;
  margin-top: var(--s-4);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}

.article__footer {
  margin-top: var(--s-10) !important;
  padding-top: var(--s-7);
  border-top: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--s-5);
}
.article__tags { display: inline-flex; flex-wrap: wrap; gap: var(--s-2); }
.tag {
  display: inline-block;
  padding: 6px 12px;
  border-radius: var(--r-full);
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-text-muted);
  text-decoration: none !important;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.tag:hover { background: var(--c-brand); color: #fff !important; border-color: var(--c-brand); }
.article__share-foot {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--ff-display);
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}

/* ==========================================================================
   PRODUCT RAIL — karuzela produktów w artykule
   ========================================================================== */
.product-rail {
  margin: var(--s-11) 0;
  padding: var(--s-9) 0;
  background: linear-gradient(180deg, var(--c-bg-soft) 0%, var(--c-bg-cream) 100%);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  position: relative;
}

.product-rail__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: var(--s-5);
  margin-bottom: var(--s-7);
}
.product-rail__title {
  margin-top: var(--s-2);
  font-family: var(--ff-serif);
  font-size: clamp(24px, 2.6vw, 34px);
  font-weight: 500;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--c-ink);
  max-width: 560px;
}

.product-rail__nav {
  display: inline-flex;
  gap: var(--s-2);
}
.product-rail__btn {
  width: 48px; height: 48px;
  border-radius: var(--r-full);
  border: 1px solid var(--c-border-2);
  background: #fff;
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: var(--sh-1);
  transition: background var(--t-fast) var(--ease-out),
              color var(--t-fast) var(--ease-out),
              border-color var(--t-fast) var(--ease-out),
              transform var(--t-fast) var(--ease-out),
              opacity var(--t-fast) var(--ease-out);
}
.product-rail__btn svg { width: 18px; height: 18px; }
.product-rail__btn:hover {
  background: var(--c-brand);
  color: #fff;
  border-color: var(--c-brand);
  transform: translateY(-1px);
  box-shadow: var(--sh-2);
}
.product-rail__btn[aria-disabled="true"],
.product-rail__btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
  transform: none;
}

.product-rail__viewport {
  position: relative;
  margin-left: calc(var(--container-pad) * -1);
  margin-right: calc(var(--container-pad) * -1);
}
.product-rail__viewport::before,
.product-rail__viewport::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: var(--container-pad);
  pointer-events: none;
  z-index: 2;
}
.product-rail__viewport::before {
  left: 0;
  background: linear-gradient(90deg, var(--c-bg-cream) 0%, transparent 100%);
}
.product-rail__viewport::after {
  right: 0;
  background: linear-gradient(270deg, var(--c-bg-cream) 0%, transparent 100%);
}

.product-rail__track {
  display: flex;
  gap: var(--s-5);
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: var(--s-2) var(--container-pad) var(--s-5);
}
.product-rail__track::-webkit-scrollbar { display: none; }

.product--rail {
  flex: 0 0 calc((100% - var(--container-pad) * 2 - var(--s-5) * 2) / 3);
  min-width: 0;
}
.product--rail .product__media { height: 260px; padding: var(--s-7) var(--s-6) var(--s-5); }
.product--rail .product-photo--md { max-height: 200px; }
.product--rail .product__body { padding: var(--s-5); }
.product--rail .product__desc { min-height: 0; }

@media (max-width: 1020px) {
  .product--rail { flex-basis: calc((100% - var(--container-pad) * 2 - var(--s-5)) / 2); }
}
@media (max-width: 720px) {
  .product-rail { margin: var(--s-9) 0; padding: var(--s-8) 0; }
  .product-rail__head { margin-bottom: var(--s-5); }
  .product--rail { flex-basis: 78%; }
  .product--rail .product__media { height: 220px; }
  .article__body { font-size: 16px; padding-top: var(--s-7); }
  .article__quote { padding: var(--s-5) var(--s-6); font-size: 18px; }
  .article__cover { margin-top: var(--s-7); padding: 0 var(--container-pad); }
  .article__meta { flex-direction: column; align-items: flex-start; }
  .article__footer { flex-direction: column; align-items: flex-start; }
}

/* ==========================================================================
   O NAS — about page sections
   ========================================================================== */

/* Stats band — pełna szerokość, ciemne tło brand */
.about-stats {
  background: var(--c-brand);
  color: #fff;
  padding: var(--s-10) 0;
}
.about-stats__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-7);
}
.about-stat {
  display: flex; flex-direction: column; gap: var(--s-2);
  padding: 0 var(--s-2);
  border-left: 1px solid rgba(255,255,255,0.14);
  padding-left: var(--s-5);
}
.about-stat:first-child { border-left: 0; padding-left: 0; }
.about-stat__num {
  font-family: var(--ff-display);
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.025em;
  color: #fff;
}
.about-stat__num small {
  font-size: 0.5em;
  font-weight: 500;
  color: var(--c-accent-2);
  margin-left: 4px;
  letter-spacing: 0;
}
.about-stat__label {
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.66);
  line-height: 1.4;
}
@media (max-width: 1100px) {
  .about-stats__grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-7) var(--s-5); }
  .about-stat:nth-child(4) { border-left: 0; padding-left: 0; }
}
@media (max-width: 640px) {
  .about-stats { padding: var(--s-9) 0; }
  .about-stats__grid { grid-template-columns: repeat(2, 1fr); gap: var(--s-6) var(--s-4); }
  .about-stat { padding-left: var(--s-4); }
  .about-stat:nth-child(odd) { border-left: 0; padding-left: 0; }
}

/* Proces — numerowana lista 4 etapów */
.about-process { background: var(--c-bg-soft); }
.proc__list {
  margin-top: var(--s-9);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
  counter-reset: proc;
  list-style: none;
}
.proc__step {
  position: relative;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-7) var(--s-6) var(--s-6);
  display: flex; flex-direction: column; gap: var(--s-4);
  transition: transform var(--t-base) var(--ease-snappy), box-shadow var(--t-base) var(--ease-snappy), border-color var(--t-base) var(--ease-snappy);
}
.proc__step:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-card-hover);
  border-color: var(--c-accent-2);
}
.proc__num {
  font-family: var(--ff-display);
  font-size: 32px;
  font-weight: 700;
  color: var(--c-accent);
  line-height: 1;
  letter-spacing: -0.02em;
  display: inline-flex; align-items: center; gap: var(--s-3);
}
.proc__num::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--c-border);
}
.proc__body h3 {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.proc__body p {
  margin-top: var(--s-3);
  color: var(--c-text-muted);
  font-size: var(--fs-sm);
  line-height: 1.6;
}
@media (max-width: 1020px) {
  .proc__list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .proc__list { grid-template-columns: 1fr; gap: var(--s-4); margin-top: var(--s-7); }
  .proc__step { padding: var(--s-6) var(--s-5); }
}

/* Team — karty członków zespołu */
.about-team { background: #fff; }
.team__grid {
  margin-top: var(--s-9);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
}
.team-card {
  background: var(--c-bg-soft);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  display: flex; flex-direction: column;
  transition: transform var(--t-base) var(--ease-snappy), box-shadow var(--t-base) var(--ease-snappy);
}
.team-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-card-hover);
}
.team-card__photo {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  position: relative;
  overflow: hidden;
}
.team-card__photo--a { background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-2) 100%); }
.team-card__photo--b { background: linear-gradient(135deg, var(--c-accent) 0%, var(--c-accent-2) 100%); }
.team-card__photo--c { background: linear-gradient(135deg, #5c6e44 0%, var(--c-brand) 100%); }
.team-card__photo--d { background: linear-gradient(135deg, var(--c-accent-2) 0%, var(--c-brand-2) 100%); }
.team-card__initials {
  font-family: var(--ff-display);
  font-size: clamp(48px, 4vw, 64px);
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  letter-spacing: -0.02em;
}
.team-card__body {
  margin-top: var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-2);
}
.team-card__name {
  font-family: var(--ff-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}
.team-card__role {
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-accent);
  font-weight: 500;
}
.team-card__bio {
  margin-top: var(--s-2);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.55;
}
@media (max-width: 1020px) {
  .team__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .team__grid { grid-template-columns: 1fr; gap: var(--s-4); margin-top: var(--s-7); }
}

/* Certyfikaty */
.about-certs { background: var(--c-bg-soft); }
.certs__grid {
  margin-top: var(--s-9);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
.cert-card {
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex; align-items: flex-start; gap: var(--s-5);
  transition: border-color var(--t-base) var(--ease-snappy), transform var(--t-base) var(--ease-snappy);
}
.cert-card:hover {
  border-color: var(--c-accent-2);
  transform: translateY(-2px);
}
.cert-card__icon {
  flex-shrink: 0;
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  background: var(--c-accent-soft);
  color: var(--c-brand);
  display: inline-flex; align-items: center; justify-content: center;
}
.cert-card__icon svg { width: 24px; height: 24px; }
.cert-card strong {
  display: block;
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--c-ink);
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.cert-card span:not(.cert-card__icon) {
  display: block;
  margin-top: var(--s-2);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: 1.5;
}
@media (max-width: 880px) {
  .certs__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .certs__grid { grid-template-columns: 1fr; gap: var(--s-3); margin-top: var(--s-7); }
  .cert-card { padding: var(--s-5); gap: var(--s-4); }
}

/* ============================================================
   OC compat shim — klasy OpenCart NIEobecne w makiecie vit4u
   (formularze konta/rejestracji/informacji). Tokeny z :root powyżej.
   ============================================================ */
#content,#account-account,#information-information,#information-contact{padding:2.25rem 0 3.5rem;}
#content .container>h1,#content h1,#account-account h1,#information-contact h1,#information-information h1{font-family:var(--ff-display);color:var(--c-brand);}
.form-group{margin-bottom:1rem;}
label.control-label,.form-group>label,.control-label{display:inline-block;font-size:.84rem;font-weight:600;color:var(--c-text-muted);margin-bottom:.35rem;}
.form-control{width:100%;padding:.7rem .9rem;border:1px solid var(--c-border-2);border-radius:10px;font:inherit;background:var(--c-bg-soft);color:var(--c-text);line-height:1.4;}
.form-control:focus{outline:none;border-color:var(--c-accent);background:#fff;}
textarea.form-control{min-height:120px;}
.btn-primary{background:var(--c-brand);color:#fff;border:0;}
.btn-primary:hover,.btn-primary:focus{background:var(--c-brand-2);color:#fff;}
.btn-default,.btn-light{background:var(--c-bg-warm);color:var(--c-ink);border:1px solid var(--c-border-2);}
.btn-default:hover{background:var(--c-bg-cream);color:var(--c-ink);}
.panel{background:var(--c-bg);border:1px solid var(--c-border);border-radius:16px;margin-bottom:1.25rem;overflow:hidden;}
.panel-heading{padding:.9rem 1.2rem;border-bottom:1px solid var(--c-border);font-weight:700;font-family:var(--ff-display);}
.panel-title{margin:0;font-size:1.05rem;color:var(--c-brand);}
.panel-body{padding:1.2rem;}
.well{background:var(--c-bg-soft);border:1px solid var(--c-border);border-radius:14px;padding:1.3rem;}
.alert-danger{background:#fbe9e7;color:var(--c-sale);border:1px solid #f3c3bb;padding:.7rem 1rem;border-radius:10px;margin-bottom:1rem;}
.alert-success{background:#eaf3e3;color:var(--c-success);border:1px solid #cfe3bf;padding:.7rem 1rem;border-radius:10px;margin-bottom:1rem;}
.text-danger{color:var(--c-sale);font-size:.8rem;}
.required .control-label:before,.required.control-label:before{content:'* ';color:var(--c-sale);}
.list-group{list-style:none;padding:0;margin:0;}
.list-group-item{display:block;padding:.6rem .2rem;border-bottom:1px solid var(--c-border);color:var(--c-text);}
.list-group-item:hover{color:var(--c-accent);}
.table{width:100%;border-collapse:collapse;margin:1rem 0;}
.table th,.table td{padding:.65rem .75rem;border-bottom:1px solid var(--c-border);text-align:left;}
.input-group{display:flex;gap:.5rem;}
.input-group .form-control{flex:1;}

/* ============================================================
   Konto / logowanie / rejestracja (klasy figurydeco -> styl vit4u)
   ============================================================ */
.cat-lead,.reg-lead{padding:2.5rem 0 1.25rem;background:var(--c-bg-soft);border-bottom:1px solid var(--c-border);}
.cat-lead .container,.reg .container{position:relative;}
.cat-lead__inner{max-width:640px;}
.cat-lead__title{font-family:var(--ff-serif);font-size:clamp(2rem,4vw,3rem);color:var(--c-brand);margin:.3rem 0;line-height:1.05;}
.cat-lead__title em{font-style:italic;color:var(--c-accent);}
.cat-lead__intro{color:var(--c-text-muted);}
.cat-lead__intro a,.reg-lead__login{color:var(--c-accent);font-weight:600;}
.reg{padding:2rem 0 4rem;}
.reg__grid{display:grid;grid-template-columns:1.4fr .8fr;gap:1.75rem;align-items:start;}
.kform{background:var(--c-bg);border:1px solid var(--c-border);border-radius:18px;padding:1.6rem 1.7rem;}
.kform__legend{font-family:var(--ff-display);font-size:1.25rem;color:var(--c-brand);margin:0 0 .25rem;}
.kform__sub{color:var(--c-text-muted);font-size:.9rem;margin:0 0 1.25rem;}
.kf{display:block;margin-bottom:1rem;}
.kf>span:first-child{display:block;font-size:.82rem;font-weight:600;color:var(--c-text-muted);margin-bottom:.35rem;}
.kf input,.kf select,.kf textarea{width:100%;padding:.72rem .9rem;border:1px solid var(--c-border-2);border-radius:10px;font:inherit;background:var(--c-bg-soft);color:var(--c-text);}
.kf input:focus,.kf select:focus,.kf textarea:focus{outline:none;border-color:var(--c-accent);background:#fff;}
.kf__aside{display:block;margin-top:.4rem;font-size:.8rem;}
.kf__aside a{color:var(--c-accent);}
.reg-form__submit{margin-top:.5rem;}
.reg-form__alt{margin-top:1rem;color:var(--c-text-muted);font-size:.9rem;}
.reg-form__alt a{color:var(--c-accent);font-weight:600;}
.reg__aside{display:grid;gap:1.1rem;}
.reg-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:18px;padding:1.4rem;}
.reg-card--accent{background:var(--c-brand);color:#fff;border:0;}
.reg-card--accent .reg-card__title,.reg-card--accent strong{color:#fff;}
.reg-card__title{font-family:var(--ff-display);font-size:1.1rem;color:var(--c-brand);margin:0 0 .75rem;}
.reg-benefits{list-style:none;padding:0;margin:0 0 1.1rem;display:grid;gap:.55rem;}
.reg-benefits li{position:relative;padding-left:1.5rem;font-size:.9rem;line-height:1.4;}
.reg-benefits li:before{content:'✓';position:absolute;left:0;color:var(--c-accent-2);font-weight:700;}
.reg-card--accent .reg-benefits li:before{color:#cdd3a8;}
.reg-card--accent .btn--primary{background:#fff;color:var(--c-brand);}
.kinfo__label{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--c-text-soft);margin-bottom:.25rem;}
.kinfo__cta{display:inline-block;margin-top:.5rem;color:var(--c-accent);font-weight:600;}
.reg-help p{font-size:.88rem;color:var(--c-text-muted);}
.reg-secure{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--c-text-soft);margin-top:.5rem;}
.kf-check{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;color:var(--c-text-muted);margin:.5rem 0;}
@media(max-width:880px){.reg__grid{grid-template-columns:1fr;}}
/* Konto - dashboard (vanilla OC) */
.list-unstyled{list-style:none;padding-left:0;margin:0 0 1.25rem;}
#account-account h2,#content h2{font-family:var(--ff-display);font-size:1.15rem;color:var(--c-brand);margin:1.5rem 0 .6rem;}
#account-account .list-unstyled li{padding:.45rem 0;border-bottom:1px solid var(--c-border);}
#account-account a,#content a{color:var(--c-text);}
#account-account a:hover,#content a:hover{color:var(--c-accent);}
/* Strony informacyjne */
.info{padding:2.5rem 0 4rem;}
.info .container{max-width:820px;}
.info h2,.info h3{font-family:var(--ff-display);color:var(--c-brand);margin:1.5rem 0 .6rem;}
.info p{margin:0 0 1rem;line-height:1.7;color:var(--c-text);}
.info ul,.info ol{margin:0 0 1rem 1.25rem;line-height:1.7;}
.info a{color:var(--c-accent);}

/* ============================================================
   Mobile: "Nasze bestsellery" jako pozioma ROLKA (swipe lewo-prawo),
   zamiast produktow jeden pod drugim. Tylko #bestsellery.
   ============================================================ */
@media (max-width: 768px) {
  #bestsellery .products {
    display: flex !important;
    grid-template-columns: none !important;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 12px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
  }
  #bestsellery .products > .product {
    flex: 0 0 78%;
    max-width: 78%;
    scroll-snap-align: start;
  }
  #bestsellery .products::-webkit-scrollbar { height: 6px; }
  #bestsellery .products::-webkit-scrollbar-thumb { background: var(--c-border-2); border-radius: 999px; }
  #bestsellery .products::-webkit-scrollbar-track { background: transparent; }
}
@media (max-width: 768px) {
  /* rolka bestsellerow: wymus widocznosc kart (neutralizuj data-reveal poza ekranem) */
  #bestsellery .products > .product { opacity: 1 !important; transform: none !important; }
}

/* ============================================================
   Mobile: OPINIE i BLOG jako poziome ROLKI (swipe lewo-prawo),
   zamiast kart jedna pod druga.
   ============================================================ */
@media (max-width: 768px) {
  /* --- OPINIE --- */
  .reviews__grid {
    display: flex !important;
    grid-template-columns: none !important;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 12px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
  }
  .reviews__grid > .review {
    flex: 0 0 84%;
    max-width: 84%;
    scroll-snap-align: start;
    opacity: 1 !important;
    transform: none !important;
  }
  .reviews__grid::-webkit-scrollbar { height: 6px; }
  .reviews__grid::-webkit-scrollbar-thumb { background: var(--c-border-2); border-radius: 999px; }
  .reviews__grid::-webkit-scrollbar-track { background: transparent; }

  /* --- BLOG --- */
  #blog .blog__grid {
    display: flex !important;
    grid-template-columns: none !important;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 12px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
  }
  #blog .blog__grid > .post {
    flex: 0 0 82%;
    max-width: 82%;
    scroll-snap-align: start;
    opacity: 1 !important;
    transform: none !important;
  }
  #blog .blog__grid::-webkit-scrollbar { height: 6px; }
  #blog .blog__grid::-webkit-scrollbar-thumb { background: var(--c-border-2); border-radius: 999px; }
  #blog .blog__grid::-webkit-scrollbar-track { background: transparent; }
}
/* Rejestracja B2B (konto firmowe) */
.kform__section{margin-bottom:1.5rem;}
.kform__row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;}
.kform__hint{font-size:.78rem;color:var(--c-text-soft);margin:.35rem 0 0;}
.kf-check--toggle{padding:.85rem 1rem;background:var(--c-bg-soft);border:1px solid var(--c-border);border-radius:12px;font-size:.95rem;cursor:pointer;}
.company-section{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--c-border-2);}
.company-section[hidden]{display:none;}
.kform__nip{display:flex;gap:.5rem;align-items:stretch;}
.kform__nip input{flex:1;}
.kform__nip .btn{white-space:nowrap;}
#gus-result-register{margin-top:.5rem;}
#gus-result-register .alert{padding:.6rem .85rem;border-radius:10px;font-size:.85rem;}
@media(max-width:600px){.kform__row{grid-template-columns:1fr;}.kform__nip{flex-direction:column;}}
/* B2B: etykieta netto + linia brutto */
.price__unit{font-size:.5em;font-weight:600;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.03em;}
.pdp-buy__price .pdp-buy__per{display:block;font-size:.9rem;color:var(--c-text-muted);margin-top:.2rem;}
/* Blog (lista + artykul) — makieta */
.blog-page .section{padding-top:2rem;}
.blog__grid--page{margin-top:1.5rem;}
.blog-page .post__media{height:200px;background-size:cover;background-position:center;background-color:var(--c-bg-warm);}
.post__more{display:inline-flex;align-items:center;gap:.35rem;color:var(--c-accent);font-weight:600;font-size:.85rem;margin-top:.6rem;}
.post__more svg{width:14px;height:14px;}
.article-meta{color:var(--c-text-muted);font-size:.9rem;}
.article-cover{margin:1.5rem auto;max-width:1000px;}
.article-cover img{width:100%;max-height:460px;object-fit:cover;border-radius:18px;display:block;}
.article-body{padding:1.5rem 0 4rem;}
.article-prose{max-width:760px;margin:0 auto;}
.article-prose h1,.article-prose h2,.article-prose h3{font-family:var(--ff-display);color:var(--c-brand);margin:1.75rem 0 .6rem;line-height:1.2;}
.article-prose p{margin:0 0 1.1rem;line-height:1.75;color:var(--c-text);}
.article-prose img{max-width:100%;height:auto;border-radius:12px;margin:1rem 0;}
.article-prose ul,.article-prose ol{margin:0 0 1.1rem 1.4rem;line-height:1.7;}
.article-prose a{color:var(--c-accent);}
.article-prose table{width:100%;border-collapse:collapse;margin:1rem 0;}
.article-prose th,.article-prose td{border:1px solid var(--c-border);padding:.5rem .7rem;text-align:left;}
.article-prose h2{font-size:1.5rem;margin-top:2.2rem;}
.article-prose .lead{font-size:1.18rem;line-height:1.7;color:var(--c-brand);font-weight:500;margin-bottom:1.5rem;}
.article-prose ul li,.article-prose ol li{margin-bottom:.45rem;}
.article-prose blockquote{margin:1.8rem 0;padding:1.1rem 1.5rem;border-left:4px solid var(--c-accent);background:rgba(101,109,65,.06);font-family:var(--ff-display);font-size:1.14rem;line-height:1.6;color:var(--c-brand);border-radius:0 14px 14px 0;}
.article-prose blockquote cite{display:block;margin-top:.7rem;font-size:.9rem;font-style:normal;font-family:var(--ff-base);color:var(--c-text);opacity:.7;}

/* ==========================================================================
   APLIKACJA STAŁEGO KLIENTA — pływający launcher + panel promocyjny apki
   Widget wstrzykiwany przez vit4u.js, obecny na każdej podstronie.
   ========================================================================== */

.lcapp { font-family: var(--ff-body); }

/* ----- LAUNCHER (pływająca ikonka, prawy dolny róg) --------------------- */
.lcapp__fab {
  position: fixed;
  right: clamp(16px, 3vw, 28px);
  bottom: calc(clamp(16px, 3vw, 28px) + env(safe-area-inset-bottom, 0px));
  z-index: 90;
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: 10px 20px 10px 12px;
  border-radius: var(--r-full);
  background: var(--c-brand);
  color: #fff;
  box-shadow: var(--sh-4), 0 0 0 6px rgba(29,43,30,0.05);
  /* wejście — „wyskakuje" po krótkiej zwłoce */
  opacity: 0;
  transform: translateY(26px) scale(0.9);
  transition: transform var(--t-base) var(--ease-snappy),
              opacity var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out);
}
.lcapp.is-revealed .lcapp__fab { opacity: 1; transform: none; }
.lcapp__fab:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(29,43,30,0.22), 0 24px 48px rgba(29,43,30,0.26), 0 0 0 6px rgba(29,43,30,0.08);
}
.lcapp__fab:active { transform: translateY(0) scale(0.98); }
.lcapp.is-open .lcapp__fab { z-index: 111; }

.lcapp__fab-icon {
  position: relative;
  display: grid; place-items: center;
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  background: linear-gradient(150deg, var(--c-accent-2), var(--c-accent));
  color: #fff;
}
.lcapp__fab-icon svg { width: 21px; height: 21px; }

.lcapp__fab-dot {
  position: absolute; top: -2px; right: -2px;
  width: 12px; height: 12px; border-radius: var(--r-full);
  background: var(--c-sale);
  border: 2px solid var(--c-brand);
}

.lcapp__fab-text {
  display: flex; flex-direction: column; align-items: flex-start;
  line-height: 1.08; text-align: left;
}
.lcapp__fab-kicker {
  font-family: var(--ff-display);
  font-size: 10px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--c-accent-2);
}
.lcapp__fab-title {
  font-family: var(--ff-display);
  font-size: var(--fs-sm); font-weight: 600; letter-spacing: -0.01em;
}

/* pierścień przyciągający uwagę (gaśnie po pierwszym otwarciu) */
.lcapp__fab-pulse {
  position: absolute; inset: 0;
  border-radius: inherit;
  pointer-events: none;
  animation: lcapp-pulse 2.8s var(--ease-out) infinite;
}
.lcapp.is-seen .lcapp__fab-pulse,
.lcapp.is-open .lcapp__fab-pulse { animation: none; opacity: 0; }
@keyframes lcapp-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(101,109,65,0.45); }
  70%  { box-shadow: 0 0 0 18px rgba(101,109,65,0); }
  100% { box-shadow: 0 0 0 0 rgba(101,109,65,0); }
}

/* ----- BACKDROP --------------------------------------------------------- */
.lcapp__backdrop {
  position: fixed; inset: 0;
  z-index: 100;
  background: rgba(15,17,16,0.42);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  opacity: 0; visibility: hidden;
  transition: opacity var(--t-base) var(--ease-out), visibility var(--t-base);
}
.lcapp.is-open .lcapp__backdrop { opacity: 1; visibility: visible; }

/* ----- PANEL (zakładka z opisem apki) ----------------------------------- */
.lcapp__panel {
  position: fixed;
  right: clamp(16px, 3vw, 28px);
  bottom: calc(clamp(16px, 3vw, 28px) + 70px + env(safe-area-inset-bottom, 0px));
  z-index: 110;
  width: min(388px, calc(100vw - 32px));
  max-height: min(78vh, 760px);
  overflow-y: auto;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-4);
  padding: var(--s-6);
  transform-origin: bottom right;
  opacity: 0; visibility: hidden;
  transform: translateY(16px) scale(0.96);
  transition: opacity var(--t-base) var(--ease-out),
              transform var(--t-base) var(--ease-snappy),
              visibility var(--t-base);
}
.lcapp.is-open .lcapp__panel { opacity: 1; visibility: visible; transform: none; }

.lcapp__grabber { display: none; }

.lcapp__close {
  position: absolute; top: var(--s-4); right: var(--s-4);
  width: 34px; height: 34px;
  display: grid; place-items: center;
  border-radius: var(--r-full);
  background: var(--c-bg-cream); color: var(--c-text-muted);
  transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.lcapp__close:hover { background: var(--c-bg-warm); color: var(--c-ink); }
.lcapp__close svg { width: 16px; height: 16px; }

/* hero */
.lcapp__badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-display); font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--c-accent);
  background: var(--c-accent-soft);
  padding: 5px 10px; border-radius: var(--r-full);
}
.lcapp__hero-row { display: flex; gap: var(--s-4); align-items: center; margin-top: var(--s-4); padding-right: var(--s-7); }
.lcapp__appicon {
  flex-shrink: 0;
  width: 56px; height: 56px; border-radius: var(--r-md);
  background: linear-gradient(155deg, var(--c-brand-2), var(--c-brand-3));
  display: grid; place-items: center;
  box-shadow: var(--sh-2);
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 19px;
  letter-spacing: -0.01em;
  color: #fff;
  font-feature-settings: 'ss01', 'ss02';
}
.lcapp__title {
  font-family: var(--ff-serif);
  font-size: 23px; font-weight: 600; line-height: 1.12; color: var(--c-ink);
  letter-spacing: -0.015em;
}
.lcapp__sub { font-size: var(--fs-sm); color: var(--c-text-muted); margin-top: 4px; line-height: 1.5; }

.lcapp__rating {
  display: inline-flex; align-items: center; gap: 7px;
  margin-top: var(--s-4);
  font-size: var(--fs-xs); color: var(--c-text-muted);
}
.lcapp__rating b { color: var(--c-ink); font-weight: 600; }
.lcapp__stars { color: #d9a300; letter-spacing: 1.5px; }

/* korzyści */
.lcapp__features {
  margin: var(--s-5) 0;
  padding: var(--s-5) 0;
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  display: flex; flex-direction: column; gap: var(--s-4);
}
.lcapp__feat { display: flex; gap: var(--s-3); align-items: flex-start; }
.lcapp__feat-icon {
  flex-shrink: 0;
  width: 40px; height: 40px; border-radius: var(--r-sm);
  display: grid; place-items: center;
  background: var(--c-bg-cream); color: var(--c-accent);
}
.lcapp__feat-icon svg { width: 20px; height: 20px; }
.lcapp__feat-txt strong {
  display: block; font-family: var(--ff-display);
  font-size: var(--fs-sm); font-weight: 600; color: var(--c-ink); letter-spacing: -0.01em;
}
.lcapp__feat-txt span { display: block; font-size: var(--fs-xs); color: var(--c-text-muted); line-height: 1.5; margin-top: 2px; }

/* przyciski sklepów */
.lcapp__stores { display: flex; gap: var(--s-3); }
.lcapp__store {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: 10px 12px; border-radius: var(--r-md);
  background: var(--c-brand); color: #fff;
  transition: background var(--t-base) var(--ease-out), transform var(--t-fast) var(--ease-out);
}
.lcapp__store:hover { background: var(--c-brand-3); transform: translateY(-1px); }
.lcapp__store:active { transform: scale(0.98); }
.lcapp__store svg { width: 22px; height: 22px; }
.lcapp__store-txt { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.05; }
.lcapp__store-txt small { font-family: var(--ff-display); font-size: 9px; letter-spacing: 0.05em; opacity: 0.82; text-transform: uppercase; }
.lcapp__store-txt b { font-family: var(--ff-display); font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }

.lcapp__foot { margin-top: var(--s-4); text-align: center; font-size: var(--fs-mini); color: var(--c-text-soft); }

/* ----- MOBILE: dolny sheet ---------------------------------------------- */
@media (max-width: 600px) {
  .lcapp__fab { padding: 0; width: 58px; height: 58px; justify-content: center; gap: 0; }
  .lcapp__fab-text { display: none; }
  .lcapp__fab-icon { width: 100%; height: 100%; border-radius: var(--r-full); background: transparent; }
  .lcapp__fab-icon svg { width: 25px; height: 25px; }

  .lcapp__panel {
    right: 0; left: 0; bottom: 0;
    width: 100%;
    max-height: 90vh;
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    transform: translateY(100%);
    padding: var(--s-5) var(--s-5) calc(var(--s-6) + env(safe-area-inset-bottom, 0px));
  }
  .lcapp.is-open .lcapp__panel { transform: none; }
  .lcapp__grabber {
    display: block;
    width: 40px; height: 4px; border-radius: var(--r-full);
    background: var(--c-border-2);
    margin: 0 auto var(--s-4);
  }
  .lcapp__close { top: var(--s-3); right: var(--s-3); }
}

/* ----- REDUCED MOTION --------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .lcapp__fab, .lcapp__panel, .lcapp__backdrop { transition: opacity 1ms linear; }
  .lcapp__fab-pulse { animation: none; }
  .lcapp.is-revealed .lcapp__fab { opacity: 1; transform: none; }
  .lcapp.is-open .lcapp__panel { transform: none; }
}
