/* Liftaya bundle PDP — components specific to the zestaw page.
   Loaded AFTER pdp.css; reuses its variables + shared sections
   (breadcrumb, .pdp grid, buy box, .section, reviews-boomba, pdp-ugc,
   .why base, reviews-wall, add-review, trust-strip, badges-row, acc-wrap).
   Everything here is scoped under .liftaya-bundle to avoid collisions. */

.liftaya-bundle { --ink: #3a2f33; }
/* stars inherit pdp.css `.stars { color: var(--primary) }` (pink) for parity with PDP */

/* ── hero visual: banner + gallery thumbs ───────────────────────── */
.liftaya-bundle .bvis { position: relative; background: radial-gradient(120% 120% at 50% 30%, var(--whisper), var(--kiss)); border-radius: var(--r-md); padding: clamp(1.25rem, 3vw, 2rem); box-shadow: var(--shadow); }
.liftaya-bundle .bgal__stage { position: relative; }
/* banner stays in flow and defines the stage height; collages overlay it */
.liftaya-bundle .bgal__slide.bbnr { display: flex; flex-direction: column; position: relative; z-index: 1; aspect-ratio: 1000/850; }
.liftaya-bundle img.bgal__slide { display: none; position: absolute; inset: 0; z-index: 2; width: 100%; height: 100%; object-fit: contain; border-radius: var(--r-md); background: #fff; border: 1px solid var(--line); }
.liftaya-bundle img.bgal__slide.is-active { display: block; }
.liftaya-bundle .bgal__thumbs { display: flex; flex-wrap: nowrap; gap: .6rem; margin-top: 1rem; padding-bottom: .25rem; }
.liftaya-bundle .bgal__thumb { flex: 1 1 0; min-width: 0; aspect-ratio: 1; border-radius: 16px; border: 2px solid transparent; background: #fff; padding: 0; overflow: hidden; cursor: pointer; box-shadow: 0 4px 10px rgba(27,18,20,.06); transition: border-color .15s; }
.liftaya-bundle .bgal__thumb:hover { border-color: var(--accent); }
.liftaya-bundle .bgal__thumb.is-active { border-color: var(--primary); }
.liftaya-bundle .bgal__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.liftaya-bundle .bgal__thumb--grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; padding: 3px; background: var(--kiss); }
.liftaya-bundle .bgal__thumb--grid img { border-radius: 3px; background: #fff; }

/* banner (slide 0) */
.liftaya-bundle .bbnr { position: relative; background: linear-gradient(160deg, #fff, var(--whisper)); border: 1px solid var(--line); border-radius: var(--r-md); padding: clamp(.7rem, 2.4vw, 1.3rem); gap: .55rem; }
.liftaya-bundle .bbnr__top { position: static; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; flex: none; padding: .1rem 3.4rem .2rem; }
.liftaya-bundle .bbnr__kick { font-size: .56rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--primary); }
.liftaya-bundle .bbnr__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.05rem, 2.8vw, 1.65rem); line-height: 1.04; color: var(--midnight); margin-top: .1rem; }
.liftaya-bundle .bbnr__title b { color: var(--primary); font-weight: 700; }
.liftaya-bundle .bbnr__badge { position: absolute; right: .55rem; top: .7rem; transform: rotate(-8deg); width: clamp(3.1rem, 9vw, 4.3rem); height: clamp(3.1rem, 9vw, 4.3rem); border-radius: 50%; background: radial-gradient(circle at 50% 38%, var(--kiss), var(--whisper)); border: 1.5px solid var(--line); display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--primary); box-shadow: 0 10px 20px rgba(255,45,120,.18); }
.liftaya-bundle .bbnr__badge b { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.05rem, 2.9vw, 1.5rem); line-height: .95; }
.liftaya-bundle .bbnr__badge small { font-size: .5rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; line-height: 1.1; }
.liftaya-bundle .bbnr__row { flex: 1; min-height: 0; display: grid; gap: .5rem; }
.liftaya-bundle .bbnr__row.is-2 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr; }
.liftaya-bundle .bbnr__row.is-3 { grid-template-columns: repeat(3, 1fr); grid-template-rows: 1fr; }
.liftaya-bundle .bbnr__row.is-4 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.liftaya-bundle .bbnr__prod { display: flex; flex-direction: column; min-height: 0; background: #feeef3; border: 1px solid var(--line); border-radius: 14px; padding: .45rem .5rem; text-align: center; }
.liftaya-bundle .bbnr__prod-ph { flex: 1 1 0; min-height: 0; overflow: hidden; border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.liftaya-bundle .bbnr__prod-ph img { width: 100%; height: 100%; object-fit: contain; transform: scale(1.32); transform-origin: center 52%; }
.liftaya-bundle .bbnr__prod small { margin-top: .25rem; font-size: .66rem; font-weight: 700; color: var(--midnight); flex: none; }

/* ── "Co w zestawie" accordion ──────────────────────────────────── */
.liftaya-bundle .incl { border: 1px solid var(--line); border-radius: var(--r-md); padding: 1rem 1.1rem; margin: 0 0 1.2rem; background: var(--whisper); }
.liftaya-bundle .incl__h { font-size: .66rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--primary); margin-bottom: .6rem; }
.liftaya-bundle .incl__item { border-bottom: 1px dashed var(--line); }
.liftaya-bundle .incl__item:last-of-type { border-bottom: 0; }
.liftaya-bundle .incl__row { display: flex; align-items: center; gap: .7rem; padding: .5rem 0; }
.liftaya-bundle .incl__row img { width: 42px; height: 42px; border-radius: 10px; object-fit: cover; background: var(--kiss); flex: none; }
.liftaya-bundle .incl__row b { font-size: .92rem; }
.liftaya-bundle .incl__row span { font-size: .78rem; color: var(--muted); }
.liftaya-bundle .incl__toggle { margin-left: auto; flex: none; display: inline-flex; align-items: center; gap: .3rem; font-family: inherit; font-size: .76rem; font-weight: 700; color: var(--primary); background: none; border: 0; cursor: pointer; padding: .25rem .15rem; }
.liftaya-bundle .incl__toggle svg { width: .85rem; height: .85rem; transition: transform .2s; }
.liftaya-bundle .incl__toggle[aria-expanded="true"] svg { transform: rotate(180deg); }
.liftaya-bundle .incl__detail { overflow: hidden; max-height: 0; transition: max-height .28s ease; }
.liftaya-bundle .incl__detail.is-open { max-height: 200px; }
.liftaya-bundle .incl__detail p { margin: 0; padding: 0 .2rem .7rem calc(42px + .7rem); font-size: .8rem; line-height: 1.45; color: var(--ink); }
.liftaya-bundle .incl__gratis { margin-top: .7rem; font-size: .82rem; color: var(--success); font-weight: 700; display: flex; align-items: center; gap: .4rem; }
.liftaya-bundle .incl__gratis svg { width: 1.05rem; height: 1.05rem; flex: none; }

/* ── size selector ──────────────────────────────────────────────── */
.liftaya-bundle .size { margin: 0 0 1.1rem; border: 1px solid var(--line); border-radius: var(--r-md); padding: .9rem 1rem; background: #fff; }
.liftaya-bundle .size__top { display: flex; align-items: center; justify-content: space-between; gap: .6rem; margin-bottom: .65rem; }
.liftaya-bundle .size__label { font-size: .7rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--primary); }
.liftaya-bundle .size__calc { font-family: inherit; font-size: .74rem; font-weight: 700; color: var(--primary); background: var(--whisper); border: 1px solid var(--line); border-radius: var(--r-pill); padding: .32rem .7rem; cursor: pointer; display: inline-flex; align-items: center; gap: .35rem; }
.liftaya-bundle .size__calc svg { width: .9rem; height: .9rem; }
.liftaya-bundle .size__opts { display: flex; gap: .45rem; }
.liftaya-bundle .size__opt { flex: 1; text-align: center; padding: .6rem 0; border: 1.5px solid var(--line); border-radius: 12px; background: #fff; font-family: inherit; font-weight: 700; font-size: .95rem; color: var(--ink); cursor: pointer; transition: border-color .15s, background .15s, color .15s; }
.liftaya-bundle .size__opt:hover { border-color: var(--accent); }
.liftaya-bundle .size__opt.is-sel { border-color: var(--primary); background: var(--whisper); color: var(--primary); }
.liftaya-bundle .size__toggle { margin-top: .75rem; font-family: inherit; font-size: .76rem; font-weight: 600; color: var(--muted); background: none; border: 0; cursor: pointer; text-decoration: underline; padding: 0; }
.liftaya-bundle .size__per { display: none; flex-direction: column; gap: .55rem; }
.liftaya-bundle .size.is-per .size__shared { display: none; }
.liftaya-bundle .size.is-per .size__per { display: flex; }
.liftaya-bundle .size__perrow { display: flex; align-items: center; gap: .6rem; }
.liftaya-bundle .size__perrow b { font-size: .82rem; min-width: 6.5rem; color: var(--midnight); }
.liftaya-bundle .size__perrow select { flex: 1; padding: .5rem .6rem; border: 1.5px solid var(--line); border-radius: 10px; font-family: inherit; font-size: .85rem; background: #fff; color: var(--ink); }

/* ── "Dlaczego komplet?" value grid ─────────────────────────────── */
.liftaya-bundle .valuegrid { display: grid; gap: 1rem; grid-template-columns: 1fr; margin-top: 1.75rem; }
@media (min-width: 760px) { .liftaya-bundle .valuegrid { grid-template-columns: repeat(3, 1fr); } }
.liftaya-bundle .valuecard { background: #fff; border: 1.5px solid var(--line); border-radius: var(--r-md); padding: 1.4rem; text-align: center; }
.liftaya-bundle .valuecard .ico { width: 3rem; height: 3rem; margin: 0 auto; border-radius: 50%; background: var(--whisper); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--primary); }
.liftaya-bundle .valuecard .ico svg { width: 1.4rem; height: 1.4rem; }
.liftaya-bundle .valuecard h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.12rem; margin: .6rem 0 .3rem; }
.liftaya-bundle .valuecard p { margin: 0; font-size: .86rem; color: var(--muted); }

/* ── before/after (copy + collage) ──────────────────────────────── */
.liftaya-bundle .ba__grid { display: grid; gap: clamp(1.2rem, 3vw, 2.4rem); grid-template-columns: 1fr; align-items: center; text-align: left; }
@media (min-width: 860px) { .liftaya-bundle .ba__grid { grid-template-columns: 1.02fr .98fr; } }
.liftaya-bundle .ba__media img { width: 100%; border-radius: var(--r-md); border: 1px solid var(--line); }
.liftaya-bundle .ba__feats { list-style: none; margin: 1.2rem 0 0; padding: 0; display: grid; gap: .85rem; }
.liftaya-bundle .ba__feat { display: flex; gap: .7rem; align-items: flex-start; }
.liftaya-bundle .ba__feat svg { width: 1.3rem; height: 1.3rem; color: var(--primary); flex: none; margin-top: .15rem; }
.liftaya-bundle .ba__feat b { display: block; color: var(--midnight); font-size: .95rem; }
.liftaya-bundle .ba__feat span { font-size: .85rem; color: var(--muted); }

/* ── "Dlaczego Liftaya?" — white frame + 4-product set ──────────── */
.liftaya-bundle .why__visual { background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-lg); }
.liftaya-bundle .why__cue__ico { background: var(--whisper); }
.liftaya-bundle .why__set { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: .55rem; width: clamp(14rem, 38vw, 21rem); }
.liftaya-bundle .why__set-cell { background: #feeef3; border: 1px solid var(--kiss); border-radius: 14px; padding: .45rem .5rem; text-align: center; }
.liftaya-bundle .why__set-ph { overflow: hidden; border-radius: 10px; display: flex; align-items: center; justify-content: center; aspect-ratio: 1/0.8; }
.liftaya-bundle .why__set-ph img { width: 100%; height: 100%; object-fit: contain; transform: scale(1.28); transform-origin: center 52%; }
.liftaya-bundle .why__set-cell small { display: block; margin-top: .2rem; font-size: .62rem; font-weight: 700; color: var(--midnight); }
@media (max-width: 640px) { .liftaya-bundle .why__set { width: min(100%, 18rem); } }

/* ── cross-sell: bundle cards (format from /zestawy) ────────────── */
.liftaya-bundle .vbundles { display: grid; gap: 1.1rem; grid-template-columns: 1fr; margin-top: 1.75rem; text-align: center; }
@media (min-width: 560px) { .liftaya-bundle .vbundles { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .liftaya-bundle .vbundles { grid-template-columns: repeat(5, 1fr); } }
.liftaya-bundle .vbundle { position: relative; display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); padding: 1.6rem 1rem 1.1rem; box-shadow: var(--shadow); }
.liftaya-bundle .vbundle__off { position: absolute; top: -.8rem; left: .9rem; width: 54px; height: 54px; border-radius: 50%; background: linear-gradient(145deg, var(--primary), var(--primary-dark)); color: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: .48rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; line-height: 1.1; box-shadow: 0 10px 22px rgba(255,45,120,.3); text-align: center; }
.liftaya-bundle .vbundle__off strong { font-family: var(--font-display); font-size: 1rem; }
.liftaya-bundle .vbundle__title { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; line-height: 1.05; margin: .2rem 0 .15rem; color: var(--midnight); }
.liftaya-bundle .vbundle__pill { display: block; font-size: .58rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--primary); margin-bottom: .7rem; }
.liftaya-bundle .vbundle__items { display: grid; gap: .45rem; margin: 0 auto .1rem; width: 100%; }
.liftaya-bundle .vbundle__items.is-2 { grid-template-columns: 1fr 1fr; max-width: 80%; }
.liftaya-bundle .vbundle__items.is-3 { grid-template-columns: repeat(3, 1fr); }
.liftaya-bundle .vbundle__item { text-align: center; }
.liftaya-bundle .vbundle__item img { width: 100%; aspect-ratio: 1/1; object-fit: contain; border-radius: 12px; background: var(--kiss); padding: .15rem; margin-bottom: .25rem; display: block; }
.liftaya-bundle .vbundle__item small { font-size: .55rem; color: var(--muted); line-height: 1.15; display: block; }
.liftaya-bundle .vbundle__extra { margin-top: .7rem; padding-top: .65rem; border-top: 1px dashed var(--line); font-size: .64rem; color: var(--muted); }
.liftaya-bundle .vbundle__pr { font-weight: 800; margin: .7rem 0 .85rem; font-size: 1rem; }
.liftaya-bundle .vbundle__pr s { color: var(--muted); font-weight: 500; margin-right: .35rem; font-size: .82em; }
.liftaya-bundle .vbundle__pr .sale { color: var(--primary); }
.liftaya-bundle .vbundle__btn { margin-top: auto; width: 100%; padding: .7rem 1rem; font-size: .8rem; }
