/* ============================================================================
   BIOHEAL SUMMER26 v3 — Nyári Rutin 2026 · Group-Grade Premium Commerce pilot
   Scope: .bh-home--summer26 (a bioheal-home.css UTÁN tölt, arra épít).
   v3 gate-fixek: display-lépték clamp(3rem,7.5vw,6.4rem) · countdown NINCS ·
   LCP-kép opacity-animáció NÉLKÜL · proof szélesség-foglalás (CLS=0) ·
   Fraunces size-adjust fallback · sticky mobil CTA · csomag-összár sor ·
   claims teljes mondat egy látótérben · fotografikus záró-pillanat.
   0 GLB / 0 videó / transform+opacity-only. Tokenek: --bh-* + lokális --bh-su-*.
   ============================================================================ */

/* Fraunces-kiesés elleni CLS-fallback (méret-illesztett Georgia) */
@font-face {
  font-family: 'Inter';
  src: local('Georgia');
  size-adjust: 96%;
  ascent-override: 92%;
  descent-override: 24%;
}

.bh-home--summer26 {
  --bh-su-sun: #F7E8C9;
  --bh-su-sky: #EAF3EE;
  --bh-su-sunline: rgba(201, 169, 97, .30);
  --bh-su-warm: #FBF7EE;
  --bh-su-display: 'Inter', 'Inter', Georgia, serif;
}

/* ============================== 1) FULL-BLEED CINEMATIC HERO (v2 korrekció) =
   Teljes képernyős hangulati nyitány: NINCS keret/kártya/konténer; a videó a
   teljes viewport-szélességre fut ki; kevés szöveg jobb alul, meleg-fehér
   tipográfiával, lokális puha sötét-zöld scrim felett. CLS=0: fix magasság. */
/* a Hyvä tartalom-konténer kinyitása ezen az oldalon (full-bleed szekciók) */
main:has(.bh-home--summer26), .page-main:has(.bh-home--summer26) { max-width: 100% !important; padding: 0 !important; margin: 0 !important; }
main:has(.bh-home--summer26) .columns, .page-main:has(.bh-home--summer26) .columns { max-width: 100% !important; padding: 0 !important; margin: 0 !important; }

.bh-su-hero { position: relative; background: var(--bh-paper); overflow: hidden; height: clamp(560px, 88vh, 940px); display: flex; align-items: flex-end; border: 0; border-radius: 0; }
@supports (height: 1svh) { .bh-su-hero { height: clamp(560px, 88svh, 940px); } }
@media (min-width: 768px) { .bh-su-hero { height: clamp(660px, 94vh, 1100px); } }

.bh-su-cine { position: absolute; inset: 0; z-index: 0; pointer-events: none; background: var(--bh-paper); }
.bh-su-cine__poster img, .bh-su-cine__vid { position: absolute; inset: 0; width: 100%; height: 100%; max-width: none; margin: 0; display: block; object-fit: cover; object-position: 50% 50%; }
.bh-su-cine__vid { opacity: 0; transition: opacity .8s ease; z-index: 2; }
.bh-su-cine.is-vid .bh-su-cine__vid { opacity: 1; }
@media (min-width: 768px) { .bh-su-cine__poster img, .bh-su-cine__vid { object-position: 45% 52%; } }

/* lokális, puha, természetes scrim — NEM reklámfilmes sötétítés.
   TEGAKI KOMPOZÍCIÓ-KAPCSOLÓ: ÁLLÓ nézet (telefon + álló tablet) = közép-
   szlogenes kompozíció; FEKVŐ tablet + desktop = egysoros, jobb alsó kompozíció.
   Desktop-comp query mindenhol: (≥768px ÉS fekvő) VAGY ≥1280px. */
/* Attila 06-12 v3: a szöveg-vezérelt sötétítés (radiál-haló + erősített felső
   sáv) KIVEZETVE — a scrim csak halk, természetes atmoszféra; a szlogen
   olvashatóságát a betűk alatti rövid vetett árnyék adja. */
.bh-su-cine__scrim { position: absolute; inset: 0; z-index: 3;
  background: linear-gradient(180deg, rgba(23, 35, 30, .18) 0%, rgba(23, 35, 30, .06) 20%, transparent 40%, rgba(23, 35, 30, .24) 66%, rgba(23, 35, 30, .60) 100%); }
@media (min-width: 768px) and (orientation: landscape), (min-width: 1280px) {
  .bh-su-cine__scrim { background:
    radial-gradient(110% 115% at 100% 102%, rgba(20, 32, 26, .58) 0%, rgba(20, 32, 26, .34) 36%, rgba(20, 32, 26, .10) 58%, transparent 74%),
    linear-gradient(180deg, rgba(23, 35, 30, .08) 0%, transparent 22%); }
}

/* copy: kicsi, elegáns blokk — álló: alul, a közép-szlogen tengelyén KÖZÉPRE
   zárva (a CTA a szlogen alatt, lejjebb — nem zsúfolja a közepet);
   fekvő tablet + desktop: jobb alul, balra zárt */
.bh-su-hero__inner { position: relative; z-index: 4; width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 20px clamp(30px, 6svh, 56px); display: flex; justify-content: center; }
.bh-su-hero__copy { position: relative; max-width: 470px; text-align: center; }
.bh-su-hero__copy .bh-cta-row { justify-content: center; }
@media (min-width: 768px) and (orientation: landscape), (min-width: 1280px) {
  .bh-su-hero__inner { justify-content: flex-end; padding-bottom: clamp(44px, 7vh, 84px); }
  .bh-su-hero__copy { text-align: left; }
  .bh-su-hero__copy .bh-cta-row { justify-content: flex-start; }
}
.bh-home--summer26 .bh-su-hero h1 {
  font-family: var(--bh-su-display); font-weight: 600; color: var(--bh-su-cream, #FBF6EA);
  font-size: clamp(1.55rem, 4.2vw, 2.5rem); line-height: 1.14; letter-spacing: -.015em;
  margin: 0 0 10px; text-wrap: balance; text-shadow: 0 1px 18px rgba(15, 25, 20, .35);
}
/* H1: a wordmark helyén a HIVATALOS fehér Bioheal-logó (hiteles asset, nem újrarajzolt) */
.bh-su-hero__logo { display: block; width: auto; height: clamp(30px, 4.4vw, 44px); margin: 0 auto 12px; filter: drop-shadow(0 1px 12px rgba(15, 25, 20, .38)); }
@media (min-width: 768px) and (orientation: landscape), (min-width: 1280px) { .bh-su-hero__logo { margin: 0 0 12px; } }
.bh-su-hero__h1t { display: block; }
.bh-su-hero__h1x { display: none; }

/* ---- TEGAKI SZLOGEN — a hero FŐ vizuális eleme (06-12 v3, Attila) --------
   Álló (telefon + álló tablet): KÉT SOR nagyban, a felső harmad ALSÓ felén
   (top 27% — Attila: „tolhatjuk lentebb"); fekvő tablet + desktop: EGY SOR a
   felső harmad közepén (top 16.7%). NINCS háttér-derengés/haló — csak rövid,
   direkt vetett árnyék a betűk alatt. PURE-CSS clip-path kiírás;
   reduced-motion: azonnal, ugyanitt, ugyanekkora. */
/* SZLOGEN 4.0 (Attila 06-12 este): KÉZÍRÁS (Dancing Script 400 = vékony),
   tegaki kiírás-animációval, DE EGYENESEN (nincs döntés), MINDIG két sor,
   HÓFEHÉR + nagyon pici, rövid BARNÁS árnyék. Abszolút réteg (0 CLS). */
.bh-su-slogan { position: absolute; z-index: 4; left: 50%; top: 27%; transform: translate(-50%, -50%); width: min(92vw, 560px); text-align: center; pointer-events: none; }
.bh-su-slogan .bh-handwrite {
  display: block; position: relative; width: fit-content; margin-inline: auto;
  font-family: 'Newsreader', 'Segoe Script', cursive;
  font-weight: 400;
  font-size: clamp(38px, 12vw, 62px); line-height: 1.12;
  color: #fff;
  /* EGYENESEN: a .bh-handwrite alap -3.5deg döntését kioltjuk */
  transform: none;
  text-shadow: 0 1px 2px rgba(94, 66, 41, .45);
  clip-path: inset(-12% 103% -16% -3%);
  animation: bhSuWrite 2.4s cubic-bezier(.42, .06, .4, .98) .5s forwards;
}
.bh-su-slogan .bh-handwrite:nth-child(2) { animation-delay: 2.1s; }
.bh-su-slogan .bh-handwrite::after { display: none !important; }
@keyframes bhSuWrite { to { clip-path: inset(-12% -3% -16% -3%); } }
@media (prefers-reduced-motion: reduce) {
  .bh-su-slogan .bh-handwrite { clip-path: none; animation: none; }
}
/* desktop: UGYANÚGY két sor, nagyobb prémium méretben, közép-felül */
@media (min-width: 768px) and (orientation: landscape), (min-width: 1280px) {
  .bh-su-slogan { top: 22%; width: min(80vw, 900px); }
  .bh-su-slogan .bh-handwrite { font-size: clamp(3.2rem, 4.8vw, 5rem); }
}
@media (min-width: 768px) and (orientation: landscape), (min-width: 1280px) { .bh-su-hero__h1x { display: inline; } }
.bh-su-hero__lead { font-size: .98rem; line-height: 1.55; color: rgba(251, 246, 234, .88); max-width: 44ch; margin: 0 auto 18px; text-shadow: 0 1px 12px rgba(15, 25, 20, .30); }
.bh-su-hero__lead--d { display: none; }
@media (min-width: 768px) and (orientation: landscape), (min-width: 1280px) { .bh-su-hero__lead--d { display: block; } .bh-su-hero__lead--m { display: none; } .bh-su-hero__lead { margin: 0 0 18px; } }
.bh-su-hero .bh-btn--primary { box-shadow: 0 10px 28px rgba(3, 76, 60, .35); }

/* ---- 1b) AJÁNLAT-SÁV (a hero alatti csendes commerce-sor) ---- */
.bh-su-offerbar { background: var(--bh-paper); border-bottom: 1px solid var(--bh-line); }
.bh-su-offerbar__inner { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; padding-top: 18px; padding-bottom: 18px; }
.bh-su-offerbar__note { margin: 0; font-size: .9rem; color: var(--bh-mute); line-height: 1.5; }
.bh-su-offerbar__note strong { color: var(--bh-forest); }
.bh-su-offerbar .bh-su-chips { margin: 0; }
@media (min-width: 960px) { .bh-su-offerbar__inner { flex-direction: row; align-items: center; justify-content: space-between; } }

/* hero termék-chipek (funkcióval: színpad-horgonyok) */
.bh-su-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0 0; padding: 0; }
.bh-su-chips a {
  display: inline-flex; align-items: center; gap: 6px; text-decoration: none;
  font-family: 'Inter', sans-serif; font-weight: 600; font-size: .8rem; letter-spacing: .02em;
  color: var(--bh-forest); background: #fff; border: 1px solid var(--bh-sage-100);
  border-radius: 999px; padding: 7px 13px; transition: border-color .2s, background-color .2s;
}
.bh-su-chips a::after { content: "\2192"; font-weight: 400; color: var(--bh-sage-500); }
.bh-su-chips a:hover { border-color: var(--bh-sage); background: var(--bh-sage-50); }

/* ============================== 1c) BIOHEAL TÉMÁK — STICKY CARD STACK ======
   Hero utáni márkaélmény: a kártyák görgetésre egymásra torlódnak (sticky,
   lépcsőzött top — a korábbi kártya „mögötte marad"), az érkező kártya finom
   3D-billenéssel úszik be (scroll-driven view() animáció, ahol támogatott;
   máshol sima elegáns sticky stack). Mobil + reduced-motion: statikus
   kártyalista. 0 JS, 0 könyvtár, lazy képek, CLS=0 (in-flow sticky). */
.bh-su-stack { background: var(--bh-mist); border-top: 1px solid var(--bh-line); }
.bh-su-stack .bh-section__head { padding-top: clamp(48px, 7vw, 84px); margin-bottom: 0; }
.bh-su-stack__cards { display: grid; gap: clamp(22px, 4vh, 36px); padding: clamp(28px, 4vw, 48px) 0 clamp(48px, 7vw, 84px); }
.bh-su-card { display: grid; grid-template-columns: 1fr; gap: 20px; background: #fff; border: 1px solid var(--bh-line); border-radius: 20px; padding: clamp(22px, 3.5vw, 44px); box-shadow: 0 16px 38px -26px rgba(23, 35, 30, .28); }
.bh-su-card__title { font-family: var(--bh-su-display); font-weight: 600; font-size: clamp(1.45rem, 2.6vw, 2.05rem); line-height: 1.16; letter-spacing: -.015em; color: var(--bh-ink); margin: 6px 0 10px; }
.bh-su-card__desc { font-size: .98rem; line-height: 1.6; color: var(--bh-ink-soft); max-width: 52ch; margin: 0 0 18px; }
/* FLIP EXT: claim-chipek a kártyán (mini flipek) — a kártya-grid közvetlen
   gyereke, teljes szélességű alsó sávként (desktop + mobil egyaránt) */
.bh-su-card__chips { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 8px; margin: 4px 0 0; }
.bh-su-card__chips .bh-symbol-flip--mini { flex: 1 1 104px; max-width: 150px; }
.bh-su-card__media { display: flex; align-items: center; justify-content: center; }
.bh-su-card__media img { max-height: 230px; width: auto; max-width: 100%; filter: drop-shadow(0 14px 22px rgba(42, 53, 40, .16)); }
.bh-su-card__media .bh-symbol__circle { width: clamp(96px, 10vw, 128px); height: clamp(96px, 10vw, 128px); }
.bh-su-card__media .bh-symbol__icon { width: clamp(58px, 6vw, 76px); height: clamp(58px, 6vw, 76px); }
/* MOBIL (POLISH 2026-06-12): kompakt, olvasható kártyasor — kép JOBBRA,
   kis méretben; chips teljes szélességben; finom reveal-belépő (view(),
   csak no-RM); SEMMI sticky → nincs scroll-csapda */
@media (max-width: 767px) {
  .bh-su-card { grid-template-columns: minmax(0, 1fr) 92px; gap: 12px 14px; padding: 18px 16px; align-items: start; }
  .bh-su-card__media { grid-column: 2; grid-row: 1; }
  .bh-su-card__body { grid-column: 1; grid-row: 1; min-width: 0; }
  .bh-su-card__chips { grid-column: 1 / -1; grid-row: 2; margin: 4px 0 0; }
  .bh-su-card__title { font-size: 1.22rem; }
  .bh-su-card__desc { font-size: .9rem; margin-bottom: 12px; }
  .bh-su-card__media img { max-height: 104px; }
  .bh-su-card__media .bh-symbol__circle { width: 72px; height: 72px; }
  .bh-su-card__media .bh-symbol__icon { width: 44px; height: 44px; }
  /* chips: mindig EGY sorban (3-up) — a 2 sorba törés nyújtotta a kártyát */
  .bh-su-card__chips { gap: 6px; }
  .bh-su-card__chips .bh-symbol-flip--mini { flex: 1 1 0; min-width: 0; max-width: none; }
  .bh-su-card__chips .bh-symbol-flip__title { font-size: .74rem; }
  .bh-su-card__chips .bh-symbol-flip__text { font-size: .68rem; line-height: 1.35; }
  .bh-su-card__chips .bh-symbol-flip__front, .bh-su-card__chips .bh-symbol-flip__back { min-height: 118px; padding: 10px 8px; }
}
/* MOBIL PILE (Attila 06-12): a kártya-torlódás mobilon IS él — kompakt
   kártyákkal, kisebb lépcsővel (RM: statikus lista marad).
   A nagyobb gap = „tekerésnyi" fix nézet kártyánként (csak pile-módban —
   RM-statikus listában a kis alap-gap marad!) */
/* MOBIL PILE VISSZAÁLLÍTVA (Attila 06-12 este: „elromlott az egymásra csúszó
   kártya effekt") — a kártya-torlódás mobilon IS él, kompakt kártyákkal,
   kisebb lépcsővel (RM: statikus lista marad). */
@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards { gap: clamp(120px, 26vh, 240px); }
  .bh-su-card { position: sticky; top: calc(76px + var(--i, 0) * 6px); }
  /* :has(:focus-visible) — NEM :focus-within! A pointer-kattintás fókusza
     felülre ragasztaná a kártyát; a :focus-visible csak billentyűzet-fókusznál
     emel (WCAG 2.4.11 megmarad) */
  .bh-su-card:has(:focus-visible) { z-index: 1; }
}
@media (min-width: 768px) {
  .bh-su-stack .bh-wrap { max-width: 1080px; }
  .bh-su-card { grid-template-columns: 1.3fr .7fr; align-items: center; min-height: 300px; }
  /* review-fix: a teljes-soros chips-elem nélkül EXPLICIT elhelyezés kell,
     különben az auto-placement a médiát a 3. sorba (bal oszlop) löki */
  .bh-su-card__body { grid-column: 1; grid-row: 1; }
  .bh-su-card__media { grid-column: 2; grid-row: 1; }
  .bh-su-card__chips { grid-row: 2; }
}
/* sticky stack: csak ≥768 ÉS no-reduced-motion (mobil/RM = statikus lista).
   STACK 3.0 (Attila spec 06-12 du.): a diszkrét lépcsőzés helyett FOLYAMATOS
   scroll-progress vezérlés — a pinned kártya a következő közeledtével
   ARÁNYOSAN süllyed/zsugorodik/halványul (--bh-stack-p 0→1, rAF-ból írva,
   transform+opacity-only → Android-safe, 0 layout). Hosszú scroll-range
   (nagy gap) megmarad, a mozgás kicsi és természetes. */
@media (min-width: 768px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards { gap: clamp(260px, 58vh, 640px); }
  .bh-su-card {
    position: sticky; top: calc(18px + var(--i, 0) * 8px);
    transform: translateY(calc(var(--bh-stack-p, 0) * -8px)) scale(calc(1 - var(--bh-stack-p, 0) * 0.035));
    transform-origin: 50% 0;
  }
  /* :has(:focus-visible) — NEM :focus-within! A flip-chipre kattintás fókusza
     felülre ragasztaná a kártyát, és a továbbiak láthatatlanul mögötte
     lapoznának (Attila-bug). Billentyűzet-fókusznál továbbra is emel (WCAG). */
  .bh-su-card:has(:focus-visible) { z-index: 1; }
}
/* BELÉPŐ-MOTION: IO-alapú reveal (view() helyett — Samsung Internet/Firefox is).
   STACK 3.0: desktopon a belépő CSAK fade (a transformot a progress-réteg
   birtokolja → nincs ütközés); mobilon lágy fel-úszás + fade. JS/IO nélkül:
   sosem armol → minden látható. */
@media (prefers-reduced-motion: no-preference) {
  .bh-reveal-armed .bh-su-card { opacity: 0; transition: opacity .8s ease-out, transform .85s cubic-bezier(.22, .61, .36, 1); }
  .bh-reveal-armed .bh-su-card.is-inview { opacity: 1; }
}
@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
  .bh-reveal-armed .bh-su-card { transform: translateY(18px); }
  .bh-reveal-armed .bh-su-card.is-inview { transform: none; }
}

@keyframes bhSuInUp { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }
@keyframes bhSuFloatA { from { transform: translateY(0) rotate(0); } to { transform: translateY(-9px) rotate(-1.1deg); } }
@keyframes bhSuFloatB { from { transform: translateY(0) rotate(0); } to { transform: translateY(-12px) rotate(.8deg); } }
@keyframes bhSuFloatC { from { transform: translateY(0) rotate(0); } to { transform: translateY(-10px) rotate(1.3deg); } }
@keyframes bhSuFloatS { from { transform: translateY(0); } to { transform: translateY(-6px); } }
@keyframes bhSuShadow { from { opacity: .85; transform: scaleX(1); } to { opacity: .5; transform: scaleX(.93); } }
@keyframes bhSuBeam { from { opacity: .45; transform: translateX(-3%); } to { opacity: .9; transform: translateX(3%); } }

.bh-su-hero .bh-finetext { max-width: 52ch; }
@media (min-width: 980px) { .bh-su-hero__lead { font-size: 1.16rem; } }
/* reduced-motion / no-JS: a poszter él, a videó sosem indul (JS-gate) */
@media (prefers-reduced-motion: reduce) { .bh-su-cine__vid { display: none !important; } }

/* ============================== 2) MISSZIÓ + CÉGCSOPORT (kompakt) ========= */
.bh-su-mission { background: var(--bh-paper-2); border-bottom: 1px solid var(--bh-line); text-align: center; }
.bh-su-mission .bh-wrap { max-width: 1020px; padding-top: clamp(48px, 7vw, 84px); padding-bottom: clamp(48px, 7vw, 84px); }
.bh-su-mission__statement {
  font-family: var(--bh-su-display); font-weight: 600; color: var(--bh-ink);
  font-size: clamp(1.8rem, 4.2vw, 3.05rem); line-height: 1.16; letter-spacing: -.022em;
  max-width: 24ch; margin: 0 auto 22px;
}
.bh-su-mission__group { font-size: 1rem; line-height: 1.65; color: var(--bh-ink-soft); max-width: 58ch; margin: 0 auto 26px; }
.bh-su-mission__group strong { color: var(--bh-forest); font-weight: 600; }

/* ============================== 3) RUTIN-VÁLASZTÓ (5 pillér) ============== */
.bh-su-pick { background: var(--bh-paper); }
.bh-su-pick__grid { display: grid; grid-template-columns: 1fr; gap: 14px; }
.bh-su-pick__card {
  position: relative; min-width: 0; min-height: 235px; display: flex; flex-direction: column; gap: 6px;
  background: #fff; border: 1px solid var(--bh-line); border-radius: 16px; padding: 22px 20px 18px;
  padding-right: clamp(120px, 30%, 190px); text-decoration: none; color: var(--bh-ink); overflow: hidden;
  transition: border-color .2s, transform .28s var(--bh-ease-soft), box-shadow .28s;
}
.bh-su-pick__card::before {
  content: ""; position: absolute; right: -12%; bottom: -22%; width: 64%; height: 86%; pointer-events: none;
  background: radial-gradient(closest-side, var(--bh-su-warm) 0%, rgba(251, 247, 238, .65) 55%, transparent 80%);
}
.bh-su-pick__card:hover { border-color: var(--bh-sage); transform: translateY(-3px); box-shadow: var(--bh-shadow-soft); }
/* PICK-KÁRTYA POLISH (Attila spec 06-12 du., audit SUPICK-01/02/03/04):
   szimbólum a JOBB FELSŐ sarokba (kicsit nagyobb), a szövegblokk feljebb
   csúszik (a szimbólum kikerült a flow-ból), a termékképek elválnak a
   sarok-élektől (breathing space, a lekerekítés nem vág a palackba), és a
   kép-magasság plafonja védi a felső szimbólum-sávot az ütközéstől. */
.bh-su-pick__card .bh-symbol { position: absolute; top: 14px; right: 14px; width: fit-content; }
.bh-su-pick__card .bh-symbol__circle { width: 60px; height: 60px; }
.bh-su-pick__card .bh-symbol__icon { width: 38px; height: 38px; }
.bh-su-pick__name { font-family: var(--bh-su-display); font-weight: 600; font-size: 1.18rem; line-height: 1.2; margin-top: 2px; padding-right: 4px; }
.bh-su-pick__desc { font-size: .88rem; color: var(--bh-mute); line-height: 1.5; flex: 1; max-width: 34ch; }
.bh-su-pick__more { font-size: .84rem; color: var(--bh-green); font-weight: 600; margin-top: 8px; }
.bh-su-pick__imgs { position: absolute; right: 14px; bottom: 12px; width: clamp(104px, 26%, 165px); height: calc(100% - 100px); display: flex; align-items: flex-end; justify-content: flex-end; pointer-events: none; }
.bh-su-pick__imgs img { width: 62%; height: auto; max-width: none; max-height: 100%; object-fit: contain; object-position: bottom; margin: 0; filter: drop-shadow(0 10px 16px rgba(42, 53, 40, .16)); transition: transform .28s var(--bh-ease-soft); }
.bh-su-pick__imgs img + img { width: 48%; margin-left: -16%; }
.bh-su-pick__card:hover .bh-su-pick__imgs img { transform: translateY(-4px); }
@media (min-width: 700px) { .bh-su-pick__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1080px) {
  .bh-su-pick__grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
  .bh-su-pick__card:nth-child(-n+3) { grid-column: span 2; }
  .bh-su-pick__card:nth-child(n+4) { grid-column: span 3; }
}

/* ============================== 4–7) TERMÉKSZÍNPADOK ====================== */
.bh-su-stage { border-top: 1px solid var(--bh-line); }
.bh-su-stage--mist { background: var(--bh-mist); }
.bh-su-stage--sage { background: var(--bh-sage-50); }
.bh-su-stage--paper { background: var(--bh-paper); }
.bh-su-stage--white { background: #fff; }
.bh-su-stage__inner { display: grid; grid-template-columns: 1fr; gap: 30px; align-items: center; }
.bh-su-stagebox { position: relative; width: 100%; max-width: 440px; margin: 0 auto; aspect-ratio: 4 / 5; }
.bh-su-stagebox::before {
  content: ""; position: absolute; inset: 0; border-radius: var(--bh-radius-xl);
  background: radial-gradient(92% 84% at 50% 22%, #ffffff 0%, #ffffff 42%, var(--bh-su-warm) 100%);
  border: 1px solid var(--bh-su-sunline);
}
.bh-su-stagebox::after {
  content: ""; position: absolute; left: 18%; right: 18%; bottom: 7%; height: 4.5%; border-radius: 50%;
  background: radial-gradient(closest-side, rgba(3, 76, 60, .15), transparent 80%); filter: blur(3px);
}
.bh-su-stagebox img {
  position: absolute; inset: 0; margin: auto; z-index: 2;
  max-height: 82%; max-width: 72%; width: auto; height: auto; object-fit: contain;
  filter: drop-shadow(0 18px 28px rgba(42, 53, 40, .18));
  animation: bhSuFloatB 9s ease-in-out infinite alternate;
}
.bh-su-stagebox__sweep { position: absolute; inset: 0; border-radius: var(--bh-radius-xl); overflow: hidden; z-index: 3; pointer-events: none; }
.bh-su-stagebox__sweep::before {
  content: ""; position: absolute; inset: -10% -30%; mix-blend-mode: screen;
  background: linear-gradient(105deg, transparent 42%, rgba(255, 247, 224, .55) 50%, transparent 58%);
  transform: translateX(-65%); transition: transform 1.1s var(--bh-ease-soft);
}
.bh-su-stage__inner:hover .bh-su-stagebox__sweep::before { transform: translateX(65%); }
.bh-su-stage h2 { font-size: clamp(1.7rem, 4.8vw, 2.5rem); margin: 0 0 12px; letter-spacing: -.018em; }
.bh-su-stage__lead { font-size: 1rem; line-height: 1.62; color: var(--bh-ink-soft); max-width: 56ch; margin: 0 0 6px; }

/* claims: szimbólum-hármas + a TELJES engedélyezett mondatok egy látótérben */
.bh-su-claims { list-style: none; display: grid; grid-template-columns: 1fr; gap: 10px; margin: 18px 0 10px; padding: 0; }
.bh-su-claims li { display: flex; align-items: center; gap: 12px; min-width: 0; }
.bh-su-claims .bh-symbol { flex: none; }
.bh-su-claims .bh-symbol__circle { width: 50px; height: 50px; }
.bh-su-claims .bh-symbol__icon { width: 32px; height: 32px; }
.bh-su-claims strong { display: block; font-size: .92rem; color: var(--bh-ink); font-weight: 600; line-height: 1.25; }
.bh-su-claims i { display: block; font-style: normal; font-size: .78rem; color: var(--bh-mute); margin-top: 2px; }
.bh-su-claimsfull { font-size: .8rem; color: var(--bh-mute); line-height: 1.55; max-width: 60ch; margin: 0 0 20px; }
.bh-su-stage__related { margin-top: 30px; }
.bh-su-stage__relatedlabel { font-family: 'Inter', sans-serif; font-weight: 600; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--bh-sage); margin: 0 0 14px; }

/* összetevő-jelölő (NEM claim-badge — vizuálisan elkülönítve, kör nélkül) */
.bh-su-ing { display: inline-block; font-family: 'Inter', sans-serif; font-size: .76rem; font-weight: 600; letter-spacing: .04em; color: var(--bh-ink-soft); background: var(--bh-paper-2); border: 1px dashed var(--bh-hair-strong); border-radius: 8px; padding: 5px 10px; margin: 0 6px 6px 0; }

@media (min-width: 640px) { .bh-su-claims { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; } .bh-su-claims li { flex-direction: column; text-align: center; align-items: center; gap: 8px; } }
@media (min-width: 960px) {
  .bh-su-stage__inner { grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 56px; }
  .bh-su-stage--flip .bh-su-stage__media { order: 2; }
  .bh-su-stage--flip .bh-su-stage__body { order: 1; }
}

/* ============================== 8) CSOMAGOK (details-accordion) =========== */
.bh-su-packs { background: var(--bh-paper-2); border-top: 1px solid var(--bh-line); }
.bh-su-pack { background: #fff; border: 1px solid var(--bh-line); border-radius: 16px; margin: 0 0 12px; overflow: hidden; }
.bh-su-pack summary { display: flex; align-items: center; gap: 16px; padding: 16px 18px; cursor: pointer; list-style: none; }
.bh-su-pack summary::-webkit-details-marker { display: none; }
.bh-su-pack summary:hover { background: var(--bh-paper); }
.bh-su-pack__figs { display: flex; align-items: flex-end; width: 96px; flex: none; min-height: 64px; }
.bh-su-pack__figs img { width: 46px; height: auto; max-width: none; margin: 0 -14px 0 0; filter: drop-shadow(0 8px 12px rgba(42, 53, 40, .16)); }
.bh-su-pack__figs img:nth-child(2) { width: 40px; }
.bh-su-pack__figs img:nth-child(3) { width: 34px; }
.bh-su-pack__t { flex: 1; min-width: 0; }
.bh-su-pack__name { font-family: var(--bh-su-display); font-weight: 600; font-size: 1.12rem; color: var(--bh-ink); display: block; }
.bh-su-pack__desc { font-size: .85rem; color: var(--bh-mute); line-height: 1.45; display: block; margin-top: 3px; }
.bh-su-pack__chev { flex: none; width: 22px; height: 22px; position: relative; transition: transform .25s var(--bh-ease-soft); }
.bh-su-pack__chev::before { content: ""; position: absolute; left: 5px; top: 7px; width: 10px; height: 10px; border-right: 2px solid var(--bh-sage-500); border-bottom: 2px solid var(--bh-sage-500); transform: rotate(45deg); }
.bh-su-pack[open] .bh-su-pack__chev { transform: rotate(180deg); }
.bh-su-pack__body { padding: 6px 18px 22px; border-top: 1px dashed var(--bh-hair); }
.bh-su-pack__cta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-top: 18px; }
.bh-su-pack__note { font-size: .8rem; color: var(--bh-mute); margin: 0; max-width: 44ch; }
.bh-su-pack__total { display: none; font-family: 'Inter', sans-serif; font-size: .92rem; color: var(--bh-ink); background: var(--bh-sage-50); border: 1px solid var(--bh-sage-100); border-radius: 10px; padding: 9px 14px; margin: 16px 0 0; }
.bh-su-pack__total.is-ready { display: inline-block; }
.bh-su-pack__total b { font-family: var(--bh-su-display); font-weight: 600; color: var(--bh-forest); font-variant-numeric: tabular-nums; }

/* ============================== 9) PROOF STRIP ============================ */
.bh-su-proof { background: #fff; border-top: 1px solid var(--bh-line); border-bottom: 1px solid var(--bh-line); }
.bh-su-proof__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 26px 12px; padding-top: 36px; padding-bottom: 36px; }
.bh-su-proof__item { text-align: center; min-width: 0; position: relative; }
.bh-su-num { display: inline-grid; font-family: var(--bh-su-display); font-weight: 600; line-height: 1; font-size: clamp(2rem, 4.6vw, 3.05rem); color: var(--bh-green); letter-spacing: -.012em; }
.bh-su-num__ghost { grid-area: 1 / 1; visibility: hidden; }
.bh-su-num__live { grid-area: 1 / 1; }
.bh-su-proof__item > span { display: block; font-size: .85rem; color: var(--bh-mute); margin-top: 7px; line-height: 1.4; }
@media (min-width: 760px) {
  .bh-su-proof__grid { grid-template-columns: repeat(4, 1fr); padding-top: 44px; padding-bottom: 44px; }
  .bh-su-proof__item + .bh-su-proof__item::before { content: ""; position: absolute; left: -6px; top: 50%; transform: translateY(-50%); width: 4px; height: 4px; border-radius: 50%; background: var(--bh-gold); }
}

/* ============================== 10) MINŐSÉG-PILLÉREK + CÉGCSOPORT-SÁV ===== */
.bh-su-group { background: var(--bh-forest); color: #fff; }
.bh-su-group__band { display: grid; grid-template-columns: 1fr; gap: 24px; align-items: center; padding-top: clamp(44px, 7vw, 72px); padding-bottom: clamp(44px, 7vw, 72px); }
.bh-su-group__band h2 { color: #fff; font-size: clamp(1.5rem, 4.4vw, 2.1rem); margin: 0 0 12px; letter-spacing: -.015em; }
.bh-su-group__band p { color: rgba(255, 255, 255, .88); font-size: 1rem; line-height: 1.65; margin: 0; max-width: 62ch; }
.bh-su-group__band p strong { color: var(--bh-gold-soft); font-weight: 600; }
@media (min-width: 900px) { .bh-su-group__band { grid-template-columns: 1.5fr auto; gap: 40px; } }

.bh-su-pillars { background: var(--bh-paper); border-bottom: 1px solid var(--bh-line); }
.bh-su-pillars__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 26px 14px; }
/* pillér-elemek: SYM-FLIP kártyákká alakítva (2026-06-12) — a kör-méretek a
   flip-kártyán belül élnek; a 6-oszlopos desktop-grid 3-oszlopra vált
   (a hátlap magyarázat-szövegének hely kell) */
.bh-su-pillars__grid .bh-symbol { display: block; width: fit-content; margin: 0 auto; }
.bh-su-pillars__grid .bh-symbol__circle { width: clamp(56px, 6vw, 72px); height: clamp(56px, 6vw, 72px); }
.bh-su-pillars__grid .bh-symbol__icon { width: clamp(32px, 3.5vw, 40px); height: clamp(32px, 3.5vw, 40px); }
.bh-su-pillars__guard { font-size: .78rem; color: var(--bh-mute); text-align: center; max-width: 72ch; margin: 26px auto 0; line-height: 1.55; }
.bh-su-pillars__guard a { color: var(--bh-green); }
@media (max-width: 379px) { .bh-su-pillars__grid { grid-template-columns: 1fr; } }
@media (min-width: 760px) { .bh-su-pillars__grid { grid-template-columns: repeat(3, 1fr); } }

/* ============================== 12) ZÁRÓ — fotografikus pillanat ========== */
.bh-su-final { position: relative; border-bottom: 1px solid var(--bh-line); text-align: center; padding: clamp(56px, 9vw, 96px) 0 44px; overflow: hidden; }
.bh-su-final::before {
  content: ""; position: absolute; inset: 0;
  background-image: url('/media/wysiwyg/home/nyari/scene_reggel.jpg');
  background-size: cover; background-position: center 38%;
}
.bh-su-final::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(250, 248, 242, .94) 0%, rgba(250, 248, 242, .88) 55%, rgba(250, 248, 242, .96) 100%);
}
.bh-su-final > .bh-wrap { position: relative; z-index: 2; }
.bh-su-final h2 { font-family: var(--bh-su-display); font-size: clamp(1.8rem, 5vw, 2.7rem); letter-spacing: -.02em; margin: 0 0 12px; }
.bh-su-final__lead { font-size: 1rem; color: var(--bh-ink-soft); line-height: 1.6; max-width: 56ch; margin: 0 auto 24px; }
.bh-su-final__slogan { margin-top: 44px; padding-top: 36px; border-top: 1px solid var(--bh-line); }
.bh-su-final__logo { display: block; height: 42px; width: auto; margin: 0 auto 26px; }
.bh-su-final .bh-handwrite { font-weight: 600; white-space: normal; line-height: 1.12; font-size: clamp(1.5rem, 3.6vw, 2.1rem); }

/* ============================== STICKY MOBIL CTA ========================== */
.bh-su-sticky {
  /* audit-fix 06-12 (M6): z 60→55 — a menü-scrim (z:60) és a sheet (z:61) FÖLÉ ne lógjon */
  position: fixed; left: 50%; bottom: 14px; transform: translate(-50%, 90px); z-index: 55;
  display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
  background: var(--bh-green); color: #fff; text-decoration: none;
  font-family: 'Inter', sans-serif; font-weight: 600; font-size: .92rem;
  border-radius: 999px; padding: 13px 22px; min-height: 48px;
  box-shadow: 0 10px 28px rgba(3, 76, 60, .30); opacity: 0;
  transition: transform .35s var(--bh-ease-soft), opacity .35s;
}
.bh-su-sticky.is-on { transform: translate(-50%, 0); opacity: 1; }
.bh-su-sticky:hover { background: var(--bh-greendeep); color: #fff; }
@media (min-width: 980px) { .bh-su-sticky { display: none; } }

/* ============================== APRÓSÁGOK / REDUCED MOTION ================ */
.bh-su-stage .bh-giftline { margin-top: 4px; }
@media (prefers-reduced-motion: reduce) {
  .bh-su-stagebox img { animation: none !important; }
  .bh-su-stagebox__sweep::before { transition: none; transform: none; opacity: 0; }
  .bh-su-pick__card, .bh-su-pick__imgs img { transition: none; }
  .bh-su-sticky { transition: opacity .2s; }
}

/* ================== TERMÉKSZÍNPAD ÉLŐ HÁTTÉR (bh-su-scene) ================
   A hero cine-minta általánosítása: poszter+videó+scrim hármas a 4 színpad
   mögött. CSAK ≥960px (mobil = marad a csendes flat tónus, 0 extra bájt);
   az injektálást a bhSceneLoader végzi (IO, ±1 képernyő, pause kilépéskor).
   CLS-semleges: abszolút réteg, a tartalom-rácsot nem érinti. */
/* MOBIL-BŐVÍTÉS (Attila 06-12 este): a scene-réteg MINDEN szélességen él —
   <960px-en saját 9:16 mobil-asset párral (loader választ) + FÜGGŐLEGES
   scrimmel (fent stagebox = él a jelenet, lent szöveg = közel fedett). */
.bh-su-stage { position: relative; overflow: hidden; }
.bh-su-stage .bh-wrap { position: relative; z-index: 1; }
.bh-su-scene { display: block; position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.bh-su-scene__poster, .bh-su-scene__vid {
  position: absolute; inset: 0; width: 100%; height: 100%; max-width: none; margin: 0;
  display: block; object-fit: cover; object-position: 50% 50%; opacity: 0;
}
.bh-su-scene__poster { transition: opacity .6s ease; z-index: 1; }
.bh-su-scene__vid { transition: opacity .9s ease; z-index: 2; }
.bh-su-scene.is-img .bh-su-scene__poster { opacity: 1; }
.bh-su-scene.is-vid .bh-su-scene__vid { opacity: 1; }
.bh-su-scene__scrim { position: absolute; inset: 0; z-index: 3; }
/* mobil/tablet (<960): függőleges tónus-helyes scrim */
@media (max-width: 959px) {
  .bh-su-stage--mist .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(245, 248, 245, .42) 0%, rgba(245, 248, 245, .55) 32%, rgba(245, 248, 245, .9) 52%, rgba(245, 248, 245, .95) 100%); }
  .bh-su-stage--sage .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(238, 245, 239, .42) 0%, rgba(238, 245, 239, .55) 32%, rgba(238, 245, 239, .9) 52%, rgba(238, 245, 239, .95) 100%); }
  .bh-su-stage--white .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(255, 255, 255, .42) 0%, rgba(255, 255, 255, .55) 32%, rgba(255, 255, 255, .9) 52%, rgba(255, 255, 255, .95) 100%); }
  .bh-su-stage--paper .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(250, 248, 242, .42) 0%, rgba(250, 248, 242, .55) 32%, rgba(250, 248, 242, .9) 52%, rgba(250, 248, 242, .95) 100%); }
}
@media (min-width: 960px) {
  /* tónus- és irány-helyes scrim: a szöveg-oszlop oldala közel fedett, az alsó
     (kapcsolódó termékek) sáv nyugodt; a stagebox körül él a jelenet */
  .bh-su-stage--mist .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(245, 248, 245, 0) 46%, rgba(245, 248, 245, .88) 74%, rgba(245, 248, 245, .94) 100%),
    linear-gradient(to right, rgba(245, 248, 245, .36) 0%, rgba(245, 248, 245, .5) 40%, rgba(245, 248, 245, .93) 60%, rgba(245, 248, 245, .97) 100%); }
  .bh-su-stage--sage .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(238, 245, 239, 0) 46%, rgba(238, 245, 239, .88) 74%, rgba(238, 245, 239, .94) 100%),
    linear-gradient(to right, rgba(238, 245, 239, .36) 0%, rgba(238, 245, 239, .5) 40%, rgba(238, 245, 239, .93) 60%, rgba(238, 245, 239, .97) 100%); }
  .bh-su-stage--white .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(255, 255, 255, 0) 46%, rgba(255, 255, 255, .88) 74%, rgba(255, 255, 255, .94) 100%),
    linear-gradient(to left, rgba(255, 255, 255, .36) 0%, rgba(255, 255, 255, .5) 40%, rgba(255, 255, 255, .93) 60%, rgba(255, 255, 255, .97) 100%); }
  .bh-su-stage--paper .bh-su-scene__scrim { background:
    linear-gradient(to bottom, rgba(250, 248, 242, 0) 46%, rgba(250, 248, 242, .88) 74%, rgba(250, 248, 242, .94) 100%),
    linear-gradient(to left, rgba(250, 248, 242, .36) 0%, rgba(250, 248, 242, .5) 40%, rgba(250, 248, 242, .93) 60%, rgba(250, 248, 242, .97) 100%); }
}
@media (prefers-reduced-motion: reduce) { .bh-su-scene__vid { display: none !important; } }

/* ================== S3: „MEGNÉZEM" MINI-CTA EGYSÉGESÍTÉS (06-12 du.) ========
   A kártya-belső mikrolinkek (pick 5× + needs 8×) egységes finom pill-t kapnak:
   halvány zöld háttér + kontúr + nyíl-irányjelzés. A pill maga nem interaktív
   (a teljes kártya a link) → a tap-target a kártya. A ghost-gombflotta marad. */
.bh-su-pick__more, .bh-need__more {
  display: inline-flex; align-items: center; gap: 7px; width: fit-content;
  font-family: 'Inter', sans-serif; font-size: .82rem; font-weight: 600;
  color: var(--bh-green); background: var(--bh-sage-50);
  border: 1px solid var(--bh-sage-100); border-radius: 999px;
  padding: 7px 14px; margin-top: 10px;
}
.bh-su-pick__more::after, .bh-need__more::after {
  content: "\2192"; font-weight: 400; line-height: 1;
  transition: transform .22s var(--bh-ease-soft);
}
.bh-su-pick__card:hover .bh-su-pick__more, .bh-need:hover .bh-need__more {
  background: var(--bh-sage-100); border-color: var(--bh-sage-300);
}
.bh-su-pick__card:hover .bh-su-pick__more::after, .bh-need:hover .bh-need__more::after { transform: translateX(3px); }
/* ajánlatsáv-chipek: tap-friendly magasság mobilon (audit MEGNEZEM-02) */
@media (max-width: 767px) {
  .bh-su-chips a { min-height: 44px; display: inline-flex; align-items: center; }
}
/* globális fókusz-réteg a home interaktív elemein (S10) */
.bh-home a:focus-visible, .bh-home button:focus-visible {
  outline: 2px solid var(--bh-green); outline-offset: 2px; border-radius: 8px;
}
@media (prefers-reduced-motion: reduce) {
  .bh-su-pick__more::after, .bh-need__more::after { transition: none; }
}

/* ================== S6: STAGE CLAIM-SZIMBÓLUM FLIP-KÁRTYÁK (06-12 du.) =====
   A 11 claim a bh-temak mini-flip mintára fordul: front = szimbólum + címke,
   back = a SAJÁT claimsfull EFSA-mondata. ≥44px tap target, a kártya-magasság
   érdemben nem nő (min-height a korábbi sor-magasság körül). */
.bh-su-claims li { display: block; }
.bh-symbol-flip--claim .bh-symbol-flip__front,
.bh-symbol-flip--claim .bh-symbol-flip__back { min-height: 78px; border-radius: 14px; }
.bh-symbol-flip--claim .bh-symbol-flip__front {
  flex-direction: row; justify-content: flex-start; align-items: center;
  gap: 12px; text-align: left; padding: 10px 38px 10px 12px;
}
.bh-symbol-flip--claim .bh-symbol-flip__back { justify-content: center; padding: 12px 38px 12px 14px; }
.bh-symbol-flip--claim .bh-symbol-flip__text { font-size: .78rem; line-height: 1.45; max-width: none; }
@media (min-width: 640px) {
  .bh-symbol-flip--claim .bh-symbol-flip__front {
    flex-direction: column; justify-content: center; text-align: center;
    gap: 8px; padding: 14px 12px; min-height: 138px;
  }
  .bh-symbol-flip--claim .bh-symbol-flip__back { min-height: 138px; padding: 12px 14px; }
}

/* ================== S8: SEJT-LOGÓ VÍZJEL-RENDSZER (06-12 du.) ==============
   A hiteles Bioheal sejt-logó (fehér-on-átlátszó) CSS mask-kal — így bármire
   színezhető (background-color = a vízjel színe). Dekoratív réteg:
   pointer-events none + a markup-horgok aria-hidden. 0 CLS (abszolút réteg).
   Használat: .bh-cellwm--<variáns> osztály a section-ön/kártyán. */
.bh-cellwm { position: relative; }
.bh-cellwm::before {
  content: ""; position: absolute; z-index: 0; pointer-events: none;
  -webkit-mask-image: url('/media/bioheal/brand/bioheal-cell-logo-transparent-inverse-1600.png');
  mask-image: url('/media/bioheal/brand/bioheal-cell-logo-transparent-inverse-1600.png');
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-size: contain; mask-size: contain;
}
/* a vízjel fölé kerülő tartalom-wrappek (a section-ök .bh-wrap-jei már
   pozicionáltak a scene-rétegtől — itt csak biztosítjuk) */
.bh-cellwm > * { position: relative; z-index: 1; }
/* misszió-szekció: nagy, halvány sage sejt — jobb szélen, felezve kilógatva */
.bh-su-mission.bh-cellwm { overflow: hidden; }
.bh-su-mission.bh-cellwm::before {
  width: 520px; height: 520px; right: -200px; top: 50%; transform: translateY(-50%);
  background: var(--bh-sage-50, #EEF5EF);
}
/* záró/hírlevél-szekció: negyed-sejt a bal alsó sarokban, törtfehér-sage */
.bh-su-final.bh-cellwm { overflow: hidden; }
.bh-su-final.bh-cellwm::before {
  width: 640px; height: 640px; left: -260px; bottom: -260px;
  background: rgba(238, 245, 239, .8);
}
/* flip-hátlapok: finom sejt-részlet a sage hátteren (minden flip-back) */
.bh-symbol-flip__back { position: relative; overflow: hidden; }
.bh-symbol-flip__back::before {
  content: ""; position: absolute; pointer-events: none;
  width: 150%; aspect-ratio: 1; right: -55%; bottom: -55%;
  background: rgba(45, 90, 61, .05);
  -webkit-mask-image: url('/media/bioheal/brand/bioheal-cell-logo-transparent-inverse-640.png');
  mask-image: url('/media/bioheal/brand/bioheal-cell-logo-transparent-inverse-640.png');
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-size: contain; mask-size: contain;
}
.bh-symbol-flip__back > * { position: relative; }

/* ===========================================================================
   §CARDSTACK — editorial product-story design for ALL stack cards + 3 features
   (glass shine on land, protruding lined-up clickable bookmark tabs, tab-nav).
   2026-06-14. Replaces the earlier §IMMUNRUTIN (card-0-only) blocks.
   Flip core (.55s) stays in bioheal-brand.css. Rollback = strip from the
   "§CARDSTACK" marker to EOF and restore the previous css backup.
   =========================================================================== */
html { scroll-behavior: smooth; }

.bh-su-stack__cards .bh-su-card {
  position: relative;
  scroll-margin-top: 96px;
  background: var(--bh-paper);
  border: 1px solid rgba(23, 35, 30, .06);
  border-radius: var(--bh-radius-lg, 24px);
  background-image:
    radial-gradient(circle at 0 0, rgba(255, 255, 255, .55), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(255, 255, 255, .35), transparent 55%);
  box-shadow: 0 18px 40px -30px rgba(23, 35, 30, .26);
}
.bh-su-stack__cards .bh-eyebrow { color: var(--bh-muted); letter-spacing: .08em; }
.bh-su-stack__cards .bh-eyebrow::before {
  content: ""; display: inline-block; width: 18px; height: 2px; margin-right: 8px;
  vertical-align: middle; border-radius: 2px; background: var(--bh-copper);
}
.bh-su-stack__cards .bh-su-card__title { letter-spacing: 0; }
.bh-su-stack__cards .bh-su-card__desc { max-width: 46ch; }
.bh-su-stack__cards .bh-su-card__cta {
  display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  background: var(--bh-green); color: var(--bh-white); border: 0;
  padding: 11px 22px; border-radius: 999px; font-weight: 600; letter-spacing: .02em;
  text-decoration: none; box-shadow: 0 10px 22px -12px rgba(3, 76, 60, .5);
  transition: background .16s var(--bh-ease-soft), transform .16s var(--bh-ease-soft), box-shadow .16s var(--bh-ease-soft);
}
.bh-su-stack__cards .bh-su-card__cta:hover { background: var(--bh-greendeep); transform: translateY(-1px); }

/* ingredient / property bar */
.bh-su-card__ingredients {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px 16px;
  margin: 4px 0 0; padding: 12px 16px; border-radius: var(--bh-radius, 16px);
  background: var(--bh-mist); border: 1px solid rgba(23, 35, 30, .05);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7);
}
.bh-su-card__ing { min-width: 0; }
.bh-su-card__ingredients-label { display: block; margin: 0; font-size: clamp(.72rem, .7rem + .15vw, .8125rem); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--bh-muted); }
.bh-su-card__ingredients-value { margin: 2px 0 0; font-size: clamp(.84rem, .82rem + .15vw, .9375rem); font-weight: 500; line-height: 1.4; color: var(--bh-forest-3); }

/* product world (right column) */
.bh-su-card__media--editorial { position: relative; min-height: 280px; padding: 16px; }
.bh-su-card__world-bg {
  position: absolute; inset: 6px; border-radius: var(--bh-radius-lg, 24px); overflow: hidden;
  background:
    linear-gradient(180deg, rgba(244, 241, 232, .28) 0%, rgba(238, 245, 239, .40) 55%, rgba(244, 241, 232, .58) 100%),
    var(--world-img, none) center / cover no-repeat,
    var(--bh-sage-50);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .55), inset 0 0 0 1px rgba(23, 35, 30, .05);
}
.bh-su-card__packshot { position: relative; z-index: 2; display: flex; align-items: center; justify-content: center; }
.bh-su-card__packshot img { max-height: 300px; width: auto; max-width: 100%; filter: drop-shadow(0 20px 26px rgba(23, 35, 30, .22)); }
/* Tudástár: no product -> centered illustration */
.bh-su-card__illus { position: relative; z-index: 2; display: flex; align-items: center; justify-content: center; }
.bh-su-card__illus .bh-symbol__circle { width: clamp(120px, 16vw, 168px); height: clamp(120px, 16vw, 168px); background: radial-gradient(circle at 30% 22%, #fff, var(--bh-sage-50)); box-shadow: 0 10px 26px -10px rgba(23, 35, 30, .2); }
.bh-su-card__illus .bh-symbol__icon { width: clamp(64px, 9vw, 92px); height: clamp(64px, 9vw, 92px); }
.bh-su-card__benefit { position: absolute; z-index: 3; top: 14px; right: 14px; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.bh-su-card__benefit .bh-symbol__circle {
  width: 72px; height: 72px; background: radial-gradient(circle at 30% 22%, var(--bh-gold-soft), var(--bh-paper));
  border: 1px solid rgba(201, 169, 97, .5); box-shadow: 0 6px 14px rgba(23, 35, 30, .12), 0 0 0 3px rgba(184, 117, 74, .10);
}
.bh-su-card__benefit .bh-symbol__icon { width: 34px; height: 34px; }
.bh-su-card__benefit-label { font-size: clamp(.66rem, .64rem + .1vw, .72rem); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--bh-forest-3); }
.bh-su-card__micro { position: absolute; z-index: 3; left: 16px; bottom: 16px; padding: 4px 10px; border-radius: 999px; font-size: clamp(.72rem, .7rem + .1vw, .8125rem); font-weight: 500; color: var(--bh-forest); background: rgba(255, 255, 255, .72); box-shadow: inset 0 0 0 1px rgba(23, 35, 30, .05); }

/* claim cards (flip chips restyled) */
.bh-su-stack__cards .bh-su-card__chips { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin: 4px 0 0; }
.bh-su-stack__cards .bh-su-card__chips .bh-symbol-flip--mini { flex: none; max-width: none; }
.bh-su-stack__cards .bh-symbol-flip { border: 1px solid rgba(23, 35, 30, .08); border-radius: var(--bh-radius, 16px); box-shadow: 0 8px 18px -10px rgba(23, 35, 30, .18); transition: transform .18s var(--bh-ease-soft), box-shadow .18s var(--bh-ease-soft); }
.bh-su-stack__cards .bh-symbol-flip:hover { transform: translateY(-2px); box-shadow: 0 12px 22px -10px rgba(23, 35, 30, .22); }
/* uniform fixed-height tiles; symbol-only front; name + explanation on the back */
.bh-su-stack__cards .bh-symbol-flip__front, .bh-su-stack__cards .bh-symbol-flip__back { height: 116px; min-height: 0; padding: 12px; border-radius: var(--bh-radius, 16px); }
.bh-su-stack__cards .bh-symbol-flip__front { display: flex; align-items: center; justify-content: center; background-image: linear-gradient(145deg, rgba(255, 255, 255, .82), var(--bh-sage-50)); }
.bh-su-stack__cards .bh-symbol-flip__front .bh-symbol__circle { width: 54px; height: 54px; }
.bh-su-stack__cards .bh-symbol-flip__front .bh-symbol__icon { width: 32px; height: 32px; }
.bh-su-stack__cards .bh-symbol-flip__back { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; gap: 4px; text-align: left; background: var(--bh-paper-2); overflow: hidden; }
.bh-su-stack__cards .bh-symbol-flip__title { color: var(--bh-forest-2); font-size: .9rem; line-height: 1.2; }
.bh-su-stack__cards .bh-symbol-flip__text { color: var(--bh-ink-soft); text-align: left; font-size: .74rem; line-height: 1.35; max-width: none; }
/* subtle flip affordance (no permanent label) */
.bh-su-stack__cards .bh-symbol-flip__front::after { content: "\21BB"; position: absolute; top: 8px; right: 10px; font-size: 13px; line-height: 1; color: var(--bh-sage-500); opacity: .55; }
/* desktop: reveal on hover/focus (no click needed); touch: tap toggles .is-flipped */
@media (hover: hover) and (pointer: fine) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards .bh-symbol-flip:hover:not(.is-flipped) .bh-symbol-flip__inner,
  .bh-su-stack__cards .bh-symbol-flip:focus-within:not(.is-flipped) .bh-symbol-flip__inner { transform: rotateY(180deg); }
}
/* benefit coin: symbol only, name shown via title/hover (no permanent label) */
.bh-su-card__benefit-label { display: none; }

/* glass shine sweep when a card lands on the stack */
.bh-su-card__shine { position: absolute; inset: 0; border-radius: inherit; overflow: hidden; pointer-events: none; z-index: 4; }
.bh-su-card__shine::before {
  content: ""; position: absolute; top: -60%; left: 0; width: 45%; height: 220%;
  transform: rotate(18deg) translateX(-260%); opacity: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, .55) 50%, transparent 100%);
}
.bh-su-card.is-stuck .bh-su-card__shine::before { animation: bh-card-shine .95s cubic-bezier(.25, .6, .3, 1) 1; }
@keyframes bh-card-shine { 0% { opacity: 0; transform: rotate(18deg) translateX(-260%); } 12% { opacity: 1; } 100% { opacity: 0; transform: rotate(18deg) translateX(340%); } }

/* protruding bookmark tabs (lined up across the pinned pile, clickable) */
.bh-su-card__tab {
  position: absolute; top: -30px; z-index: 6; height: 34px;
  left: calc(8px + var(--tabi, 0) * (100% - 16px) / 6);
  width: calc((100% - 16px) / 6 - 6px);
  display: flex; align-items: center; justify-content: center; gap: 6px;
  background: var(--bh-paper); border: 1px solid rgba(23, 35, 30, .10); border-bottom: 0;
  border-radius: 12px 12px 0 0; box-shadow: 0 -6px 14px -8px rgba(23, 35, 30, .22);
  text-decoration: none; color: var(--bh-forest-2); cursor: pointer;
  transition: transform .16s var(--bh-ease-soft), background .16s var(--bh-ease-soft);
}
.bh-su-card__tab:hover, .bh-su-card__tab:focus-visible { transform: translateY(-3px); background: var(--bh-sage-50); }
.bh-su-card__tab .bh-symbol__circle { width: 22px; height: 22px; }
.bh-su-card__tab .bh-symbol__icon { width: 16px; height: 16px; }
.bh-su-card__tab-label { font-size: .72rem; font-weight: 600; letter-spacing: .02em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* desktop two-column editorial grid + raised sticky for tab room */
@media (min-width: 768px) {
  .bh-su-stack__cards .bh-su-card {
    grid-template-columns: 1.4fr .9fr;
    grid-template-areas: "body media" "chips media" "ingredients media";
    column-gap: 32px; row-gap: 18px; align-items: start; min-height: 360px;
  }
  .bh-su-stack__cards .bh-su-card__body { grid-area: body; min-width: 0; max-width: 520px; }
  .bh-su-stack__cards .bh-su-card__chips { grid-area: chips; margin-top: 16px; }
  .bh-su-stack__cards .bh-su-card__ingredients { grid-area: ingredients; margin-top: 20px; }
  .bh-su-stack__cards .bh-su-card__media { grid-area: media; align-self: stretch; min-height: 320px; }
  .bh-su-stack__cards .bh-su-card__desc { margin-bottom: 16px; }
}
@media (min-width: 768px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards .bh-su-card { position: sticky; top: calc(72px + var(--i, 0) * 8px); }
}
@media (min-width: 768px) {
  .bh-su-stack__cards { padding-top: 44px; }
}

/* mobile: title -> media -> CTA -> claim cards -> ingredient bar */
@media (max-width: 767px) {
  .bh-su-stack__cards .bh-su-card { display: flex; flex-direction: column; gap: 16px; grid-template-columns: none; }
  .bh-su-stack__cards .bh-su-card__tab { left: calc(6px + var(--tabi, 0) * (100% - 12px) / 6); width: calc((100% - 12px) / 6 - 4px); }
  .bh-su-stack__cards .bh-su-card__tab-label { display: none; }
  .bh-su-stack__cards .bh-su-card__body { display: contents; }
  .bh-su-stack__cards .bh-eyebrow { order: 1; }
  .bh-su-stack__cards .bh-su-card__title { order: 2; }
  .bh-su-stack__cards .bh-su-card__desc { order: 3; }
  .bh-su-stack__cards .bh-su-card__media { order: 4; }
  .bh-su-stack__cards .bh-su-card__cta { order: 5; align-self: flex-start; }
  .bh-su-stack__cards .bh-su-card__chips { order: 6; grid-template-columns: 1fr; }
  .bh-su-stack__cards .bh-su-card__ingredients { order: 7; grid-template-columns: 1fr 1fr; }
  .bh-su-card__media--editorial { min-height: 240px; }
  .bh-su-card__packshot img { max-height: 220px; }
  .bh-su-stack__cards { padding-top: 40px; }
}
@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards .bh-su-card { position: sticky; top: calc(84px + var(--i, 0) * 6px); }
}

@media (prefers-reduced-motion: reduce) {
  .bh-su-stack__cards .bh-symbol-flip:hover, .bh-su-stack__cards .bh-su-card__cta:hover, .bh-su-card__tab:hover { transform: none; }
  .bh-su-card.is-stuck .bh-su-card__shine::before { animation: none; }
}
/* ============================================================
/* ============================================================
/* ============================================================
/* ============================================================
   §HEROLEAP - "From Leaf to Molecule" hero (Experience Leap 2026-06-14, rev3)
   ADDITIVE, scoped to .bh-su-hero--leap. Never overwrites base rules.
   ============================================================ */

/* scrim: keep white logo + cream copy AA on the bright clip */
.bh-su-hero--leap .bh-su-cine__scrim{
  background:
    linear-gradient(180deg, rgba(16,32,24,0) 30%, rgba(16,32,24,.30) 66%, rgba(13,28,20,.62) 100%),
    linear-gradient(90deg, rgba(13,28,20,.36) 0%, rgba(13,28,20,.12) 44%, rgba(13,28,20,0) 68%);
}
.bh-su-hero--leap .bh-su-hero__lead{ color: rgba(251,250,247,.95); }
.bh-su-hero--leap .bh-su-hero__logo{ filter: drop-shadow(0 2px 16px rgba(8,20,14,.5)); }

/* media: belt-and-suspenders 1px overscan (source edges already cropped) */
.bh-su-hero--leap .bh-su-cine__poster img,
.bh-su-hero--leap .bh-su-cine__vid{ inset:-1px; width:calc(100% + 2px); height:calc(100% + 2px); background:transparent; }

/* SLOGAN "Az egészség mindenkié!" - thin handwriting + write-on (inherited from base) */
.bh-su-hero--leap .bh-su-slogan .bh-handwrite{ font-weight:300; }
.bh-su-hero--leap .bh-su-slogan{ top:33%; transform:translate(-50%,-100%); }
@media (max-width:767px){
  /* MOBILE: green slogan at the bottom line of the top third */
  .bh-su-hero--leap .bh-su-slogan .bh-handwrite{ color:#1B5E20; text-shadow:0 1px 10px rgba(251,250,247,.65); }
}
@media (min-width:768px){
  /* DESKTOP: slogan top-centered */
  .bh-su-hero--leap .bh-su-slogan{ top:13%; transform:translate(-50%,0); width:min(80vw,900px); }
}

/* INNER: mobile = centered column (copy then footer); desktop = full height */
.bh-su-hero--leap .bh-su-hero__inner{ flex-direction:column; align-items:center; }
.bh-su-hero--leap .bh-su-hero__footer{ display:flex; justify-content:center; align-items:center; gap:18px; margin-top:16px; }
.bh-su-hero--leap .bh-su-hero__founded{
  font-family:'Inter',system-ui,sans-serif; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(251,250,247,.9); margin:0; white-space:nowrap; text-shadow:0 1px 10px rgba(8,20,14,.55); display:none;
}
@media (min-width:768px){
  /* hero TEXT left + vertically centered; CTA bottom-left, "Alapítva: 2013." bottom-right */
  .bh-su-hero--leap .bh-su-hero__inner{ align-self:stretch; position:relative; justify-content:center; align-items:flex-start; }
  .bh-su-hero--leap .bh-su-hero__copy{ text-align:left; max-width:560px; margin:0; }
  .bh-su-hero--leap .bh-su-hero__footer{
    position:absolute; left:20px; right:20px; bottom:clamp(28px,5vh,60px);
    justify-content:space-between; align-items:flex-end; margin:0;
  }
  .bh-su-hero--leap .bh-su-hero__founded{ display:block; }
}

/* DECORATIVE CTA (brand green inherited from .bh-btn--primary; layer decoration) */
.bh-su-hero--leap .bh-su-hero__cta{
  position:relative; overflow:hidden; isolation:isolate; border:0; cursor:pointer;
  display:inline-flex; align-items:center; gap:.55em;
  padding:15px 30px; border-radius:999px; font-weight:600; letter-spacing:.01em;
  box-shadow:0 12px 30px -8px rgba(3,76,60,.55), inset 0 0 0 1.5px rgba(201,162,39,.55);
  transition:transform .28s cubic-bezier(.2,.6,.2,1), box-shadow .28s cubic-bezier(.2,.6,.2,1);
}
.bh-su-hero--leap .bh-su-hero__cta > span{ position:relative; z-index:1; }
.bh-su-hero--leap .bh-su-hero__cta::after{ content:"\2192"; font-size:1.12em; line-height:1; transform:translateZ(0); transition:transform .3s cubic-bezier(.2,.6,.2,1); }
.bh-su-hero--leap .bh-su-hero__cta::before{ content:""; position:absolute; inset:0; z-index:0; background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.30) 50%,transparent 68%); transform:translateX(-130%); transition:transform .7s cubic-bezier(.2,.6,.2,1); }
.bh-su-hero--leap .bh-su-hero__cta:hover{ transform:translateY(-2px); box-shadow:0 18px 44px -8px rgba(3,76,60,.62), inset 0 0 0 1.5px rgba(201,162,39,.9); }
.bh-su-hero--leap .bh-su-hero__cta:hover::after{ transform:translateX(5px); }
.bh-su-hero--leap .bh-su-hero__cta:hover::before{ transform:translateX(130%); }
@media (prefers-reduced-motion:reduce){
  .bh-su-hero--leap .bh-su-hero__cta,
  .bh-su-hero--leap .bh-su-hero__cta::after,
  .bh-su-hero--leap .bh-su-hero__cta::before{ transition:none; }
}

/* ===========================================================================
   §STAGEUNIFY — unified product "stage" for ALL home stack cards (Phase 3 · 1b)
   Drops the per-card botanical --world-img in favour of ONE consistent stage:
   white -> cream radial base + soft green glow + a faint dashed "molecular ring"
   with gold/green nodes (visual-rhyme with the site-wide §BGLEAP lattice).
   2026-06-15. Re-runnable: pure override, appended LAST so it wins by cascade
   + extra specificity. Rollback = strip from the "§STAGEUNIFY" marker to EOF and
   restore the previous css backup. The botanical card-bg-*.webp files are left
   in place on the server (unused, harmless) for an instant revert.
   =========================================================================== */
.bh-su-card__media--editorial .bh-su-card__world-bg {
  background:
    /* molecular ring: dashed circle + gold/green nodes (echoes the site watermark) */
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><circle cx='100' cy='100' r='84' fill='none' stroke='%232E7D32' stroke-opacity='0.16' stroke-width='1.3' stroke-dasharray='4 7'/><circle cx='100' cy='16' r='3' fill='%23C9A227' fill-opacity='0.55'/><circle cx='184' cy='100' r='2.4' fill='%232E7D32' fill-opacity='0.42'/><circle cx='100' cy='184' r='2.4' fill='%232E7D32' fill-opacity='0.42'/><circle cx='16' cy='100' r='2.4' fill='%232E7D32' fill-opacity='0.42'/></svg>") 50% 46% / auto 64% no-repeat,
    /* soft green glow halo behind the packshot */
    radial-gradient(44% 44% at 50% 46%, rgba(46, 125, 50, .06), transparent 70%) 0 0 / cover no-repeat,
    /* base stage: white centre easing to cream/mist (identical for every product) */
    radial-gradient(60% 60% at 50% 40%, #ffffff 0%, #FBFAF7 56%, var(--bh-mist, #F5F8F5) 100%) 0 0 / cover no-repeat;
}

/* ===========================================================================
   §STACKFIT — home card-stack refinement (Phase 3 · 1b follow-up, 2026-06-15)
   Fixes from Attila's live review:
     (1) desktop cards too tall -> bottom cut off in 16:9  -> shorter cards
     (2) product packshot too big -> the new stage doesn't show -> smaller product
     (3) mobile sticky-collapse looks like a bug -> simplify: NO sticky, NO tabs,
         clean separate cards in normal flow.
   Re-runnable: pure override appended LAST. Higher-specificity (chips-scoped)
   selectors used where a base min-height would otherwise win.
   Rollback = strip from the "§STACKFIT" marker to EOF + restore the css backup.
   =========================================================================== */

/* product smaller so the stage (glow + molecular ring) breathes; ring a touch larger */
.bh-su-card__media--editorial .bh-su-card__world-bg {
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><circle cx='100' cy='100' r='86' fill='none' stroke='%232E7D32' stroke-opacity='0.18' stroke-width='1.3' stroke-dasharray='4 7'/><circle cx='100' cy='14' r='3' fill='%23C9A227' fill-opacity='0.6'/><circle cx='186' cy='100' r='2.4' fill='%232E7D32' fill-opacity='0.45'/><circle cx='100' cy='186' r='2.4' fill='%232E7D32' fill-opacity='0.45'/><circle cx='14' cy='100' r='2.4' fill='%232E7D32' fill-opacity='0.45'/></svg>") 50% 47% / auto 72% no-repeat,
    radial-gradient(48% 48% at 50% 47%, rgba(46, 125, 50, .07), transparent 70%) 0 0 / cover no-repeat,
    radial-gradient(62% 62% at 50% 42%, #ffffff 0%, #FBFAF7 56%, var(--bh-mist, #F5F8F5) 100%) 0 0 / cover no-repeat;
}

/* ---------- DESKTOP: compact so the whole card fits a 16:9 viewport ---------- */
@media (min-width: 768px) {
  .bh-su-stack__cards .bh-su-card {
    min-height: 0;
    row-gap: 10px;
    padding: 22px 28px;           /* was clamp() up to 44px -> big height saving */
  }
  .bh-su-stack__cards .bh-su-card__desc { margin-bottom: 8px; }
  .bh-su-stack__cards .bh-su-card__cta { padding: 9px 20px; }
  .bh-su-stack__cards .bh-su-card__chips { margin-top: 8px; }
  .bh-su-stack__cards .bh-su-card__ingredients { margin-top: 10px; padding: 9px 14px; }
  /* shorter claim tiles — chips-scoped to beat base min-height rules */
  .bh-su-stack__cards .bh-su-card__chips .bh-symbol-flip__front,
  .bh-su-stack__cards .bh-su-card__chips .bh-symbol-flip__back { height: 88px; min-height: 0; }
  /* media + product noticeably smaller -> stage shows */
  .bh-su-stack__cards .bh-su-card__media { min-height: 236px; }
  .bh-su-card__media--editorial { min-height: 236px; padding: 12px; }
  .bh-su-card__packshot img { max-height: 200px; }
  .bh-su-card__illus .bh-symbol__circle { width: clamp(104px, 12vw, 132px); height: clamp(104px, 12vw, 132px); }
}
/* lower the sticky anchor so a pinned card has more vertical room */
@media (min-width: 768px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards .bh-su-card { top: calc(52px + var(--i, 0) * 6px); }
}

/* ---------- MOBILE: simplify — no sticky pile, no tabs, clean cards ---------- */
@media (max-width: 767px) {
  /* kill the sticky collapse that looked like a bug -> normal vertical flow */
  .bh-su-stack__cards .bh-su-card {
    position: static;
    margin-bottom: 18px;
    padding: 18px 16px;
    scroll-margin-top: 80px;
  }
  /* remove the protruding bookmark tabs (only made sense for the desktop pile) */
  .bh-su-stack__cards .bh-su-card__tab { display: none; }
  /* no tab-room needed at the top of the stack */
  .bh-su-stack__cards { padding-top: 4px; }
  /* compact media + product on small screens */
  .bh-su-card__media--editorial { min-height: 190px; padding: 10px; }
  .bh-su-card__packshot img { max-height: 168px; }
  /* claim tiles: compact 3-across badge row (tidier + shorter than 1-col) */
  .bh-su-stack__cards .bh-su-card__chips { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .bh-su-stack__cards .bh-su-card__chips .bh-symbol-flip__front,
  .bh-su-stack__cards .bh-su-card__chips .bh-symbol-flip__back { height: 80px; min-height: 0; padding: 8px; }
}
/* neutralise the sticky for no-preference users on mobile too (belt + braces) */
@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards .bh-su-card { position: static; }
}

/* ===========================================================================
   §STACKMOBILE — rethought MOBILE concept for the home product stack
   (Phase 3 · 1b, 2026-06-15). Attila: the vertical sticky stack felt buggy and
   paging didn't work; he wants LANDSCAPE, SWIPEABLE product cards; the benefit
   symbol covered the product; the flip-tiles' text was too long for mobile.
   -> mobile becomes a horizontal scroll-snap CAROUSEL of compact landscape cards
      (product-on-stage left + name/short-desc/CTA right), next card peeks as the
      swipe affordance. Flip claim-tiles + ingredient bar + covering symbol hidden.
   Desktop is untouched (only @media max-width:767px here). Appended LAST so it
   overrides the §STACKFIT/§CARDSTACK mobile rules. Rollback = strip from the
   "§STACKMOBILE" marker to EOF + restore the css backup.
   =========================================================================== */
/* dots are mobile-only (declared BEFORE the media query so the mobile flex wins) */
.bh-su-stack__dots { display: none; }
@media (max-width: 767px) {
  /* ---- carousel track: horizontal swipe with snap ---- */
  .bh-su-stack__cards {
    display: flex;
    flex-wrap: nowrap;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 16px;
    padding: 6px 16px 16px;
    margin-inline: -16px;                 /* bleed to the screen edges */
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .bh-su-stack__cards::-webkit-scrollbar { display: none; }

  /* ---- each card: a compact LANDSCAPE panel; the next one peeks ---- */
  .bh-su-stack__cards .bh-su-card {
    position: static;
    flex: 0 0 86%;
    scroll-snap-align: center;
    margin: 0;
    display: grid;
    grid-template-columns: 43% 1fr;
    grid-template-areas: "media body";
    align-items: center;
    column-gap: 14px;
    padding: 14px;
    min-height: 0;
  }

  /* product on its stage, left */
  .bh-su-stack__cards .bh-su-card__media { grid-area: media; order: 0; min-height: 0; }
  .bh-su-card__media--editorial { min-height: 152px; padding: 8px; }
  .bh-su-card__packshot img { max-height: 138px; }
  /* the symbol that covered the product + the floating micro label: off on mobile */
  .bh-su-card__benefit { display: none; }
  .bh-su-card__micro { display: none; }

  /* name + short description + CTA, right (un-set the desktop display:contents) */
  .bh-su-stack__cards .bh-su-card__body {
    grid-area: body; display: flex; flex-direction: column; gap: 0; min-width: 0;
  }
  .bh-su-stack__cards .bh-eyebrow { order: 0; font-size: .66rem; margin: 0 0 2px; }
  .bh-su-stack__cards .bh-su-card__title { order: 1; font-size: 1.1rem; line-height: 1.16; margin: 0; }
  /* keep the title's intended <br> (the source break has no surrounding space) */
  .bh-su-stack__cards .bh-su-card__desc {
    order: 2; font-size: .8rem; line-height: 1.38; margin: 6px 0 10px; max-width: none;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
  }
  .bh-su-stack__cards .bh-su-card__cta { order: 3; align-self: flex-start; padding: 8px 16px; font-size: .85rem; }

  /* drop what doesn't work on a compact swipe card */
  .bh-su-stack__cards .bh-su-card__chips { display: none; }       /* long flip-tile text */
  .bh-su-stack__cards .bh-su-card__ingredients { display: none; } /* detail lives on the PDP */
  .bh-su-stack__cards .bh-su-card__tab { display: none; }

  /* keep the section header tidy above the carousel */
  .bh-su-stack { overflow: hidden; }

  /* paging dots (active = pill) */
  .bh-su-stack__dots { display: flex; justify-content: center; align-items: center; gap: 8px; margin-top: 14px; }
  .bh-su-dot {
    width: 8px; height: 8px; padding: 0; border: 0; border-radius: 999px; cursor: pointer;
    background: rgba(3, 76, 60, .22); transition: width .2s var(--bh-ease-soft), background .2s var(--bh-ease-soft);
  }
  .bh-su-dot.is-active { width: 22px; background: var(--bh-green, #2d5a3d); }
}
@media (max-width: 767px) and (prefers-reduced-motion: no-preference) {
  .bh-su-stack__cards .bh-su-card { position: static; }
}

/* ===========================================================================
   §BVTEASER — homepage teaser for the /bioheal-vilag legacy-media showcase
   (2026-06-15). Auto-scroll lifestyle mosaic + stats + CTA. Home-only (this
   file loads on the home page). Rollback = strip from "§BVTEASER" marker to EOF.
   =========================================================================== */
.bh-bvteaser { padding: 64px 0 70px; overflow: hidden; }
.bh-bvteaser__head { max-width: 1180px; margin: 0 auto 26px; padding: 0 24px; text-align: center; }
.bh-bvteaser__k { display: inline-block; font-size: .74rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--bh-copper, #B8754A); margin-bottom: 12px; }
.bh-bvteaser__t { font-family: 'Inter', Georgia, serif; font-weight: 600; color: var(--bh-ink, #17231E); font-size: clamp(1.7rem, 3.6vw, 2.6rem); line-height: 1.08; margin: 0 0 12px; }
.bh-bvteaser__d { color: var(--bh-muted, #6B7A70); max-width: 60ch; margin: 0 auto; font-size: 1.04rem; line-height: 1.6; }
.bh-bvteaser__stats { display: flex; gap: 30px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }
.bh-bvteaser__stats span { font-size: .8rem; color: var(--bh-muted, #6B7A70); letter-spacing: .03em; }
.bh-bvteaser__stats b { display: block; font-family: 'Inter', Georgia, serif; font-size: 1.6rem; color: var(--bh-forest, #034C3C); line-height: 1; }
.bh-bvteaser__mosaic { display: flex; flex-direction: column; gap: 14px; margin: 30px 0 8px; }
.bh-bvteaser__row { display: flex; gap: 14px; width: max-content; animation: bh-bvscroll 64s linear infinite; }
.bh-bvteaser__row--rev { animation-direction: reverse; animation-duration: 78s; }
.bh-bvteaser__mosaic:hover .bh-bvteaser__row { animation-play-state: paused; }
.bh-bvteaser__row img { height: 168px; width: auto; border-radius: 14px; object-fit: cover; box-shadow: 0 12px 28px -18px rgba(23,35,30,.45); background: #fff; }
@keyframes bh-bvscroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.bh-bvteaser__cta-wrap { text-align: center; margin-top: 26px; }
.bh-bvteaser__cta { display: inline-flex; align-items: center; gap: 8px; background: var(--bh-green, #2d5a3d); color: #fff; text-decoration: none; padding: 13px 28px; border-radius: 999px; font-weight: 600; box-shadow: 0 12px 24px -12px rgba(3,76,60,.5); transition: background .16s, transform .16s; }
.bh-bvteaser__cta:hover { background: var(--bh-greendeep, #234a31); transform: translateY(-1px); }
@media (max-width: 767px) { .bh-bvteaser__row img { height: 124px; } .bh-bvteaser { padding: 48px 0 54px; } }
@media (prefers-reduced-motion: reduce) { .bh-bvteaser__row { animation: none; } .bh-bvteaser__mosaic { overflow-x: auto; } }

/* ============================================================================
   §JULY-BUNDLES (2026-06-17, v2) — Nyári júliusi akció + virtuális csomagok.
   v2: NO bridge band (the hero already fades to cream); cards are LANDSCAPE on
   desktop (1 per row, 3 zones: intro | products | buy) and PORTRAIT (stacked) on
   mobile. "Hajnali fény a patikai fehér színpadon." Namespaced .bh-july.
   Rollback = strip from this §JULY-BUNDLES marker to EOF.
   ============================================================================ */
.bh-july{
  --jl-ink:var(--bh-ink,#2B322E); --jl-paper:var(--bh-paper,#FAFBF8); --jl-mist:var(--bh-mist,#F5F8F5);
  --jl-s50:var(--bh-sage-50,#EEF5EF); --jl-s100:var(--bh-sage-100,#DFEDE2); --jl-s300:var(--bh-sage-300,#9FC4A8);
  --jl-s500:var(--bh-sage-500,#5F9270); --jl-s600:#3f6a50; --jl-brand:var(--bh-green,#2D5A3D); --jl-forest:var(--bh-forest,#034C3C);
  --jl-deep:var(--bh-forest-3,#0D2F26); --jl-gold:var(--bh-gold,#C9A961); --jl-goldsoft:var(--bh-gold-soft,#E8D9B5);
  position:relative; isolation:isolate; color:var(--jl-ink);
  background:
    radial-gradient(circle at 8% 12%, rgba(238,245,239,.7), transparent 26%),
    radial-gradient(circle at 92% 4%, rgba(232,217,181,.22), transparent 24%),
    var(--jl-paper);
  padding:clamp(28px,4vw,56px) 0 clamp(48px,7vw,96px);
}
.bh-july__wrap{ width:min(100% - 32px, 1240px); margin-inline:auto; }
.bh-july-eyebrow{ margin:0 0 6px; font-family:'Inter',sans-serif; font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--jl-s600); }

/* ---- SALE BAND ---- */
.bh-july-band{
  position:relative; display:grid; grid-template-columns:minmax(0,1.45fr) minmax(290px,.8fr);
  gap:clamp(20px,3vw,40px); align-items:center; padding:clamp(22px,3vw,36px); border-radius:30px;
  background:
   linear-gradient(135deg, rgba(255,255,255,.86), rgba(250,251,248,.96)),
   radial-gradient(circle at 92% 0%, rgba(232,217,181,.34), transparent 34%),
   linear-gradient(180deg, var(--jl-mist), var(--jl-paper));
  border:1px solid rgba(201,169,97,.3);
  box-shadow:0 22px 60px rgba(13,47,38,.09), 0 1px 0 rgba(255,255,255,.72) inset;
}
.bh-july-band::before{ content:""; position:absolute; inset:11px; border-radius:22px; border:1px solid rgba(223,237,226,.7); pointer-events:none; }
.bh-july-band__main{ display:grid; grid-template-columns:auto minmax(0,1fr); gap:clamp(16px,2vw,26px); align-items:center; }
.bh-july-badge{
  width:clamp(78px,8vw,100px); aspect-ratio:1; border-radius:999px; display:grid; place-items:center; align-content:center; text-align:center; color:#fff;
  background:linear-gradient(150deg, var(--jl-brand), var(--jl-forest));
  border:1px solid rgba(232,217,181,.7); box-shadow:0 14px 30px rgba(3,76,60,.24), 0 0 0 5px rgba(232,217,181,.24);
}
.bh-july-badge span{ display:block; font-family:'Inter',sans-serif; font-size:clamp(23px,3vw,31px); font-weight:800; line-height:1; letter-spacing:-.04em; }
.bh-july-badge small{ margin-top:4px; font-size:10px; font-weight:700; line-height:1; text-transform:uppercase; letter-spacing:.14em; color:var(--jl-goldsoft); }
.bh-july-band h2{ margin:0; font-family:'Newsreader',Georgia,serif; font-size:clamp(30px,4vw,50px); font-weight:500; line-height:1; letter-spacing:-.035em; color:var(--jl-deep); }
.bh-july-band__copy{ max-width:540px; margin:12px 0 0; font-family:'Inter',sans-serif; font-size:15px; line-height:1.6; color:rgba(43,50,46,.78); }
.bh-july-band__facts{ display:grid; gap:10px; }
.bh-july-fact{ display:flex; justify-content:space-between; gap:16px; align-items:center; min-height:54px; padding:12px 16px; border-radius:16px; background:rgba(255,255,255,.7); border:1px solid rgba(223,237,226,.95); }
.bh-july-fact__l{ font-family:'Inter',sans-serif; font-size:12px; font-weight:600; letter-spacing:.03em; color:rgba(43,50,46,.74); }
.bh-july-fact strong{ white-space:nowrap; font-family:'Inter',sans-serif; font-size:14px; font-weight:800; color:var(--jl-forest); }

/* ---- BUNDLES HEAD ---- */
.bh-july-bundles__head{ max-width:760px; margin:clamp(40px,6vw,72px) 0 clamp(20px,3vw,30px); }
.bh-july-bundles__head h2{ margin:0; font-family:'Newsreader',Georgia,serif; font-size:clamp(30px,4vw,48px); font-weight:500; line-height:1.04; letter-spacing:-.04em; color:var(--jl-deep); }
.bh-july-bundles__head p:not(.bh-july-eyebrow){ margin:13px 0 0; max-width:660px; font-family:'Inter',sans-serif; font-size:15px; line-height:1.6; color:rgba(43,50,46,.74); }

/* ---- CARD STACK (landscape on desktop, portrait on mobile) ---- */
.bh-july-grid{ display:grid; grid-template-columns:1fr; gap:16px; }

.bh-july-card{
  position:relative; display:grid; grid-template-columns:1fr; gap:18px;
  padding:clamp(18px,2vw,24px) clamp(18px,2.4vw,30px); border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,251,248,1)), var(--jl-paper);
  border:1px solid rgba(223,237,226,.96);
  box-shadow:0 14px 40px rgba(13,47,38,.07), 0 1px 0 rgba(255,255,255,.86) inset;
  transition:transform .22s var(--bh-ease-out,ease), box-shadow .22s ease, border-color .22s ease;
}
@media (hover:hover){ .bh-july-card:hover{ transform:translateY(-2px); border-color:rgba(201,169,97,.42); box-shadow:0 22px 58px rgba(13,47,38,.11), 0 1px 0 rgba(255,255,255,.9) inset; } }

/* DESKTOP = landscape 3-zone */
@media (min-width:900px){
  .bh-july-card{
    grid-template-columns:minmax(210px,.92fr) minmax(330px,1.55fr) minmax(228px,.82fr);
    gap:clamp(22px,2.4vw,38px); align-items:center;
  }
  .bh-july-card__buy{ border-left:1px solid rgba(223,237,226,.92); padding-left:clamp(20px,2vw,30px); }
}

/* INTRO zone */
.bh-july-card__intro{ }
.bh-july-sym{ width:42px; aspect-ratio:1; border-radius:999px; display:grid; place-items:center; color:var(--jl-forest); margin-bottom:10px;
  background:radial-gradient(circle at 34% 24%, rgba(255,255,255,.9), transparent 36%), linear-gradient(145deg, var(--jl-s50), rgba(232,217,181,.36));
  border:1px solid rgba(201,169,97,.42); }
.bh-july-sym svg{ width:23px; height:23px; fill:none; stroke:currentColor; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.bh-july-kicker{ margin:0 0 3px; font-family:'Inter',sans-serif; font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--jl-s600); }
.bh-july-card__title{ margin:0; font-family:'Newsreader',Georgia,serif; font-size:clamp(23px,1.9vw,28px); font-weight:500; line-height:1.05; letter-spacing:-.03em; color:var(--jl-deep); }
.bh-july-hook{ margin:9px 0 0; font-family:'Inter',sans-serif; font-size:13.5px; line-height:1.5; color:rgba(43,50,46,.76); max-width:34ch; }
.bh-july-gift{ margin:11px 0 0; padding:7px 12px; border-radius:999px; width:fit-content; font-family:'Inter',sans-serif; font-size:12px; font-weight:700;
  color:var(--jl-forest); background:rgba(232,217,181,.5); border:1px solid rgba(201,169,97,.42); }

/* PRODUCTS zone — 3 minis */
.bh-july-card__products{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(10px,1.4vw,16px); }
.bh-july-prod{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:8px; }
.bh-july-prod figure{ margin:0; width:100%; aspect-ratio:1; border-radius:16px; overflow:hidden; display:grid; place-items:center; background:#fff;
  border:1px solid rgba(223,237,226,.96); box-shadow:0 10px 24px rgba(13,47,38,.07), 0 1px 0 rgba(255,255,255,.92) inset; transition:transform .22s ease; }
.bh-july-prod img{ display:block; width:100%; height:100%; object-fit:contain; padding:6px; }
@media (hover:hover){ .bh-july-card:hover .bh-july-prod figure{ transform:translateY(-2px); } }
.bh-july-prod__name{ font-family:'Inter',sans-serif; font-size:11.5px; line-height:1.28; color:rgba(43,50,46,.84); overflow-wrap:anywhere; min-height:2.6em; display:flex; align-items:center; }
.bh-july-prod .bh-addform{ margin:0; }
.bh-july-iadd{ display:inline-flex; align-items:center; gap:5px; padding:6px 13px 6px 10px; border-radius:999px; font-family:'Inter',sans-serif; font-size:11.5px; font-weight:600; line-height:1; color:var(--jl-forest);
  background:#fff; border:1px solid rgba(159,196,168,.7); cursor:pointer; transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease; }
.bh-july-iadd__g{ font-size:15px; font-weight:700; }
@media (hover:hover){ .bh-july-iadd:hover{ color:#fff; background:var(--jl-forest); border-color:var(--jl-forest); } }

/* BUY zone */
.bh-july-card__buy{ display:flex; flex-direction:column; gap:11px; }
.bh-july-lbl{ display:block; font-family:'Inter',sans-serif; font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:rgba(43,50,46,.70); }
.bh-july-price__row{ display:flex; align-items:baseline; flex-wrap:wrap; gap:9px; margin-top:4px; }
.bh-july-price__row s{ font-family:'Inter',sans-serif; font-size:14px; font-weight:700; color:rgba(43,50,46,.55); }
.bh-july-price__row strong{ font-family:'Newsreader',Georgia,serif; font-size:30px; font-weight:600; line-height:.95; letter-spacing:-.04em; color:var(--jl-deep); }
.bh-july-pill{ align-self:center; padding:5px 10px; border-radius:999px; font-family:'Inter',sans-serif; font-size:12px; font-weight:800; letter-spacing:.01em;
  color:var(--jl-forest); background:rgba(232,217,181,.56); border:1px solid rgba(201,169,97,.46); white-space:nowrap; }
.bh-july-cta{ width:100%; min-height:48px; border-radius:999px; cursor:pointer; font-family:'Inter',sans-serif; font-size:14px; font-weight:800; letter-spacing:.01em; color:#fff;
  background:linear-gradient(145deg, var(--jl-brand), var(--jl-forest)); border:1px solid rgba(232,217,181,.5);
  box-shadow:0 12px 26px rgba(3,76,60,.18), 0 1px 0 rgba(255,255,255,.16) inset; transition:transform .18s ease, box-shadow .18s ease; }
@media (hover:hover){ .bh-july-cta:hover{ transform:translateY(-1px); box-shadow:0 16px 32px rgba(3,76,60,.24), 0 1px 0 rgba(255,255,255,.18) inset; } }
.bh-july-cta:disabled{ opacity:.7; cursor:default; transform:none; }
.bh-july-iadd:focus-visible, .bh-july-cta:focus-visible{ outline:2px solid var(--jl-forest); outline-offset:2px; }
.bh-july-note{ margin:0; font-family:'Inter',sans-serif; font-size:11.5px; line-height:1.4; color:rgba(43,50,46,.66); }

/* MOBILE = portrait stack */
@media (max-width:767px){
  .bh-july-band{ grid-template-columns:1fr; padding:20px; border-radius:24px; }
  .bh-july-band::before{ inset:9px; border-radius:18px; }
  .bh-july-band__main{ grid-template-columns:1fr; gap:14px; }
  .bh-july-fact{ flex-direction:column; align-items:flex-start; gap:4px; }
  .bh-july-card{ padding:18px; }
  .bh-july-card__products{ gap:10px; }
  .bh-july-prod__name{ min-height:0; }
}
@media (prefers-reduced-motion:reduce){
  .bh-july-card,.bh-july-prod figure,.bh-july-iadd,.bh-july-cta{ transition:none; }
  .bh-july-card:hover,.bh-july-card:hover .bh-july-prod figure,.bh-july-iadd:hover,.bh-july-cta:hover{ transform:none; }
}
[x-cloak]{ display:none !important; }
/* ===== end §JULY-BUNDLES ===== */
