
:root{
  --bg:#0b0b0b; --bg-2:#121212; --text:#eee; --muted:#b0b0b0;
  --gold:#d4af37; --gold-2:#c79a14; --white:#fff; --shadow:rgba(0,0,0,.25);
  --radius:16px; --container:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,"Helvetica Neue",Arial,"Apple Color Emoji","Segoe UI Emoji";line-height:1.6}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.container{width:min(92%, var(--container));margin:0 auto}
.muted{color:var(--muted)}
h1,h2,h3,h4{font-family:"Playfair Display",Georgia,Times,"Times New Roman",serif;margin:0 0 .6rem 0;line-height:1.2}
p{margin:.6rem 0 1rem}

.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.1rem;border-radius:999px;border:1px solid transparent;background:#1d1d1d;transition:.25s ease;font-weight:600}
.btn:hover{transform:translateY(-1px)}
.btn-gold{background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#111}
.btn-outline{background:transparent;border-color:var(--gold);color:var(--gold)}

.site-header{position:sticky;top:0;z-index:50;background:rgba(11,11,11,.7);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid #1e1e1e}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0}
.logo{display:flex;align-items:center;gap:.6rem;font-weight:700}
.logo-mark{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#111;font-weight:900}
.logo-text{font-family:"Playfair Display",serif;letter-spacing:.5px}
.nav-list{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.nav-link{padding:.4rem .75rem;border-radius:8px;color:#ddd}
.nav-link.active, .nav-link:hover{background:#1a1a1a;color:var(--white)}
.hamburger{display:none;flex-direction:column;gap:4px;background:transparent;border:0}
.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px;display:block}

.hero{position:relative;min-height:88vh;display:grid;place-items:center;overflow:hidden;isolation:isolate}
.hero::before{content:"";position:absolute;inset:-10%;background:url('https://images.unsplash.com/photo-1503951914875-452162b0f3f1?q=80&w=2000&auto=format&fit=crop') center/cover no-repeat;transform:scale(1.1);animation:kenburns 22s ease-in-out infinite alternate;z-index:-2;filter:contrast(1.05) saturate(1.05) brightness(.6)}
@media (prefers-reduced-motion: reduce){.hero::before{animation:none;transform:none}}
@keyframes kenburns{from{transform:scale(1.1)} to{transform:scale(1.22)}}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 65% 35%, rgba(0,0,0,.25), transparent 48%), linear-gradient(to top, rgba(0,0,0,.65), transparent 50%)}
.hero-inner{text-align:center;padding:8vh 0}
.hero h1{font-size:clamp(2rem,5vw,3.6rem);margin-bottom:.6rem}
.hero p{max-width:720px;margin:0 auto 1rem;color:#ddd}
.hero-ctas{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}

.section{padding:72px 0;border-top:1px solid #141414;border-bottom:1px solid #141414;background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:1.1fr .9fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:#0f0f0f;border:1px solid #1e1e1e;border-radius:var(--radius);padding:20px;box-shadow:0 10px 30px var(--shadow)}
.kafelek{text-align:center;padding:24px;border-radius:var(--radius);background:#0f0f0f;border:1px solid #1f1f1f}
.kafelek .icon{font-size:28px}
.kafelek h3{margin-top:.4rem}

.scroller{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
.scroller > figure{min-width:62%;scroll-snap-align:center;border-radius:18px;overflow:hidden;position:relative;border:1px solid #1f1f1f}
.scroller figcaption{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.45);padding:.3rem .5rem;border-radius:999px;font-size:.8rem}

.reviews{position:relative}
.review-slider{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x proximity;padding:6px}
.review{min-width:300px;max-width:360px;scroll-snap-align:start;background:#0f0f0f;border:1px solid #1f1f1f;border-radius:16px;padding:16px}
.stars{color:var(--gold)}
.review .who{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.avatar{width:36px;height:36px;border-radius:999px;background:#222;overflow:hidden}

.cta{position:relative;overflow:hidden;border-radius:22px;padding:44px;background:#0f0f0f;border:1px solid #242424}
.cta::before{content:"";position:absolute;inset:-10%;background:url('https://images.unsplash.com/photo-1556229176-30d6677b4d8f?q=80&w=2000&auto=format&fit=crop') center/cover no-repeat;opacity:.25;z-index:-1;filter:blur(2px)}

.gallery{column-count:1;column-gap:16px}
.gallery .item{break-inside:avoid;border-radius:16px;overflow:hidden;margin:0 0 16px 0;border:1px solid #1f1f1f;position:relative}
.gallery .item a::after{content:"Zobacz więcej";position:absolute;inset:auto 8px 8px 8px;background:rgba(0,0,0,.45);padding:.25rem .5rem;border-radius:8px;opacity:0;transition:.25s}
.gallery .item:hover a::after{opacity:1}

.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;padding:20px;z-index:100}
.lightbox.open{display:flex}
.lightbox img{max-width:96vw;max-height:90vh;border-radius:12px}

.pricing{width:100%;border-collapse:collapse}
.pricing th,.pricing td{border-bottom:1px solid #1f1f1f;padding:14px;text-align:left}
.pricing tr:hover{background:#111}
.pricing .price{color:var(--gold);font-weight:700}

.form{display:grid;gap:12px}
.form input,.form select,.form textarea{width:100%;padding:.8rem;border-radius:10px;border:1px solid #2a2a2a;background:#0f0f0f;color:var(--text)}
.form .row{display:grid;gap:12px;grid-template-columns:1fr 1fr}
.form .success{color:#30c37c;font-weight:600}

.map-embed{width:100%;aspect-ratio:16/10;border:0;border-radius:16px;filter:grayscale(.1) contrast(1.1)}

.site-footer{background:#0a0a0a;border-top:1px solid #1f1f1f;margin-top:48px}
.footer-grid{display:grid;gap:24px;grid-template-columns:repeat(4,1fr);padding:36px 0}
.site-footer .icon{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:999px;background:#111;border:1px solid #1f1f1f;margin-right:6px}
.site-footer h4{margin-bottom:.6rem}
.list{list-style:none;margin:0;padding:0;display:grid;gap:.3rem}
.newsletter{display:grid;gap:10px}
.form-success{font-size:.9rem;color:#30c37c}

.copyright{border-top:1px solid #1a1a1a;padding:12px 0;text-align:center;color:#9a9a9a;font-size:.9rem}

.rez-card{background:#0f0f0f;border:1px solid #1f1f1f;border-radius:16px;padding:20px}
.badge{display:inline-block;background:#151515;color:#ccc;border:1px solid #1f1f1f;padding:.25rem .5rem;border-radius:999px;font-size:.8rem}

@media (max-width: 980px){
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .nav-list{position:fixed;inset:64px 12px auto 12px;background:#0f0f0f;border:1px solid #1f1f1f;border-radius:16px;padding:10px;display:none;flex-direction:column}
  .nav.open .nav-list{display:flex}
  .hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr}
  .scroller>figure{min-width:82%}
}
@media (max-width: 620px){
  .grid-3{grid-template-columns:1fr}
  .gallery{column-count:1}
}
.reveal{opacity:0;transform:translateY(10px);transition:.6s ease}
.reveal.show{opacity:1;transform:none}


/* --- Steam overlay (fade-out on entry) --- */
.steam-overlay{
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: .85;
  transition: opacity 2s ease;
  mix-blend-mode: lighten;
}
.steam-overlay.fade{ opacity: 0; }
.steam-overlay .puff{
  position: absolute;
  width: 70vmin;
  height: 70vmin;
  background: radial-gradient(closest-side at 50% 50%, rgba(255,255,255,.18), rgba(255,255,255,0) 60%);
  filter: blur(14px);
  animation: drift 8s ease-in-out infinite alternate;
  will-change: transform, opacity;
  opacity: .8;
}
@keyframes drift{
  from{ transform: translate3d(0,0,0) scale(1); }
  to  { transform: translate3d(10px,-14px,0) scale(1.06); }
}


/* --- Steam overlay (full-screen, first-visit, 2s fade) --- */
.steam-overlay{
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0.98; /* start nearly opaque to fully cover */
  transition: opacity 2s ease; /* exactly 2s fade */
  background:
    radial-gradient(120vmax 120vmax at 30% 40%, rgba(255,255,255,.25), rgba(255,255,255,.10) 60%, rgba(255,255,255,0) 75%),
    radial-gradient(120vmax 120vmax at 70% 60%, rgba(255,255,255,.24), rgba(255,255,255,.08) 55%, rgba(255,255,255,0) 75%),
    linear-gradient(rgba(255,255,255,.12), rgba(255,255,255,.12));
}
.steam-overlay.fade{ opacity: 0; }
.steam-overlay .puff{
  position: absolute;
  width: 80vmin;
  height: 80vmin;
  background: radial-gradient(closest-side at 50% 50%, rgba(255,255,255,.22), rgba(255,255,255,0) 60%);
  filter: blur(18px);
  animation: drift 8s ease-in-out infinite alternate;
  will-change: transform, opacity;
  opacity: .9;
}
.steam-overlay .puff.small{
  width: 52vmin;
  height: 52vmin;
  opacity: .85;
  filter: blur(14px);
}
@keyframes drift{
  from{ transform: translate3d(-12px, 6px, 0) scale(1); }
  to  { transform: translate3d(14px,-10px, 0) scale(1.06); }
}


/* --- Glassmorphism for "Oferta skrócona" cards --- */
.kafelek.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(212,175,55,.6); /* golden outline */
  box-shadow: 0 10px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
}
.kafelek.glass:hover{ transform: translateY(-2px); background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06)); }


/* Offer section with parallax background (fix stacking + iOS fallback) */
.section-offer{ position:relative; background:transparent!important; border-top:1px solid #141414; border-bottom:1px solid #141414; overflow:hidden; }
.section-offer .container{ position: relative; z-index: 2; }
.section-offer::before{content:""; position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1556229176-30d6677b4d8f?q=80&w=2400&auto=format&fit=crop') center/cover no-repeat; z-index:0; transform:translate3d(0,var(--parallaxY,0px),0) scale(1.12); will-change:transform; filter:brightness(.6) contrast(1.06) saturate(1.06);}
.section-offer::after{content:""; position:absolute; inset:0; background: radial-gradient(120% 80% at 50% 20%, rgba(0,0,0,.15), transparent 48%), linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.18)); z-index:1;}

/* Robust parallax background for Oferta (uses child element, not pseudo) */
.section-offer{ position:relative; overflow:hidden; background:transparent!important; }
.section-offer .offer-bg{
  position:absolute; inset:0; z-index:0;
  background-image: url('https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?q=80&w=2400&auto=format&fit=crop'), url('https://images.unsplash.com/photo-1556229176-30d6677b4d8f?q=80&w=2400&auto=format&fit=crop');
  background-size: cover; background-position: center;
  transform: translate3d(0, var(--offerPY, 0px), 0) scale(1.12);
  will-change: transform;
  filter: brightness(.62) contrast(1.06) saturate(1.06);
}
.section-offer::after{
  content:""; position:absolute; inset:0; z-index:1;
  background: radial-gradient(120% 80% at 50% 20%, rgba(0,0,0,.15), transparent 48%), linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.18));
}
.section-offer .container{ position:relative; z-index:2; }


/* === Scrollytelling (global, non-home pages) === */
.scrollytelling{position:relative; isolation:isolate;}
.scrollytelling .scrolly-bg{position:sticky; top:0; inset:auto; height:100svh; background-size:cover; background-position:center; z-index:0; transform:translateZ(0);}
.scrollytelling .scrolly-overlay{position:sticky; top:0; height:100svh; z-index:0; pointer-events:none;
  background: linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.30) 35%, rgba(0,0,0,.38) 75%, rgba(0,0,0,.40));}
.scrollytelling .scrolly-slides{position:relative; z-index:1;}

.scrollytelling .slide{min-height:100svh; display:grid; place-items:center; padding:clamp(16px,3vw,48px); scroll-snap-align:start;}
.scrollytelling .slides-hint{position:sticky; top:calc(100svh - 56px); text-align:center; opacity:.8; font-size:.9rem; letter-spacing:.02em;}

.scrollytelling .panel{width:min(1100px, 92vw); margin-inline:auto; border-radius:22px; border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.20); box-shadow:0 20px 60px rgba(0,0,0,.25); padding:clamp(18px, 3.2vw, 44px); color: var(--text);}
@supports (backdrop-filter: blur(8px)){
  .scrollytelling .panel{backdrop-filter: blur(10px); background: rgba(0,0,0,.28);}
}

/* Keep tables and grids readable inside slides */
.scrollytelling .panel .pricing{background:transparent;}
.scrollytelling .panel .grid{gap:clamp(12px,2vw,24px);}
.scrollytelling .panel .gallery{background:transparent;}

/* Smooth snap only within slides container; page scroll remains normal */
.scrollytelling .scrolly-slides{scroll-snap-type:y proximity;}
.scrollytelling .slide > .container{margin:0 auto;}

/* Ensure header remains on top */
.site-header{z-index:50}

/* Respect existing reveal animations */
.scrollytelling .panel .reveal{opacity:1; transform:none}


/* === Scrollytelling tune-up === */
.scrollytelling{position:relative; isolation:isolate;}
.scrollytelling .scrolly-bg{position:sticky; top:0; height:100svh; background-size:cover; background-position:center; z-index:0;}
.scrollytelling .scrolly-overlay{position:sticky; top:0; height:100svh; z-index:0; pointer-events:none;
  background: linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.30) 35%, rgba(0,0,0,.38) 75%, rgba(0,0,0,.40));}
.scrollytelling .scrolly-slides{position:relative; z-index:1; scroll-snap-type: y mandatory;}
.scrollytelling .slide{min-height:100svh; display:grid; place-items:center; padding:clamp(16px,3vw,48px); scroll-snap-align:start;}
.scrollytelling .panel{background: rgba(0,0,0,.20); box-shadow:0 20px 60px rgba(0,0,0,.25);}


/* === Scrollytelling tune-up v3: static bg, top-snapping panels === */
body[data-scrollytelling="1"]{
  scroll-snap-type: y mandatory;
  /* ensure snapped panels stop below sticky header */
  scroll-padding-top: var(--headerH, 72px);
}

.scrollytelling{position:relative; isolation:isolate;}
.scrollytelling .scrolly-bg{position:fixed; inset:0; height:100svh; background-size:cover; background-position:center; z-index:-2; transform:translateZ(0);}
.scrollytelling .scrolly-overlay{position:fixed; inset:0; height:100svh; z-index:-1; pointer-events:none;
  background: linear-gradient(to bottom, rgba(0,0,0,.18), rgba(0,0,0,.22) 35%, rgba(0,0,0,.28) 75%, rgba(0,0,0,.32));}

.scrollytelling .scrolly-slides{position:relative; z-index:1;}
.scrollytelling .slide{
  min-height:100svh;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:clamp(16px,3vw,40px);
  scroll-snap-align:start;
}
.scrollytelling .panel{
  width:min(1100px, 92vw);
  margin-inline:auto;
  margin-top: clamp(8px, 2vh, 20px);
  border-radius:22px;
  border:1px solid rgba(255,255,255,.1);
  background: rgba(0,0,0,.16);
  box-shadow: 0 16px 44px rgba(0,0,0,.20);
  color: var(--text);
}
@supports(backdrop-filter: blur(8px)){
  .scrollytelling .panel{backdrop-filter: blur(10px); background: rgba(0,0,0,.12);}
}

/* optional nicer entering feel */
@media (prefers-reduced-motion: no-preference){
  .scrollytelling .panel{opacity:.999; transform: translateY(0); transition: transform .45s ease, box-shadow .45s ease;}
}


/* === Title slide (non-Home) === */
.scrollytelling .title-slide{min-height:100svh; display:grid; place-items:center; scroll-snap-align:start; padding:0;}
.scrollytelling .title-hero{
  width:100%; height:100%;
  display:grid; place-items:center;
  padding-top: var(--headerH, 72px);
}
.scrollytelling .page-title{
  text-align:center;
  font-family: "Playfair Display", serif;
  font-size: clamp(36px, 7vw, 86px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: .01em;
  color: var(--text);
  opacity: 0;
  transform: translateY(14px) scale(.98);
  filter: blur(8px);
  animation: titleReveal .9s cubic-bezier(.19,.8,.22,1) .15s forwards;
  will-change: transform, opacity, filter;
}
.scrollytelling .page-title .accent{
  display:block;
  margin: clamp(10px,1.8vh,16px) auto 0 auto;
  width: min(240px, 40vw);
  height: 3px;
  border-radius: 3px;
  background: linear-gradient(90deg, rgba(255,215,120,.0), var(--gold), rgba(255,215,120,.0));
  opacity:.0;
  transform: scaleX(.9);
  animation: titleAccent .8s ease .45s forwards;
}

@keyframes titleReveal{
  to{opacity:1; transform: translateY(0) scale(1); filter: blur(0);}
}
@keyframes titleAccent{
  to{opacity:1; transform: scaleX(1);}
}

/* Hide default hero inner content when scrollytelling is enabled */
body[data-scrollytelling="1"] .hero .hero-inner { display:none; }


/* === Spacing tweak v5: tighter slides/panels === */
.scrollytelling .slide{ padding: clamp(10px, 2vw, 24px); }
.scrollytelling .panel{ padding: clamp(14px, 2.2vw, 28px); }
.scrollytelling .panel .grid{ gap: clamp(8px, 1.4vw, 16px); }
.scrollytelling .panel .pricing th, 
.scrollytelling .panel .pricing td{ padding: .45rem .6rem; }


/* === Spacing tweak v6: tighter everywhere on scrollytelling pages === */
body[data-scrollytelling="1"] .slide{ padding: clamp(6px, 1.4vw, 18px); }
body[data-scrollytelling="1"] .panel{ padding: clamp(10px, 1.6vw, 20px); }
body[data-scrollytelling="1"] .panel h1, 
body[data-scrollytelling="1"] .panel h2, 
body[data-scrollytelling="1"] .panel h3{ margin-block: .45em .35em; }
body[data-scrollytelling="1"] .panel p{ margin-block: .45em; }
body[data-scrollytelling="1"] .panel .grid{ gap: clamp(6px, 1vw, 12px); }
body[data-scrollytelling="1"] .panel .pricing th, 
body[data-scrollytelling="1"] .panel .pricing td{ padding: .32rem .5rem; }

/* Footer slide look */
.footer-slide .panel{ 
  background: rgba(0,0,0,.14);
  box-shadow: 0 12px 36px rgba(0,0,0,.18);
}
.footer-slide footer{ width: 100%; }


/* === Footer bottom-gap normalization v7 === */
:root{ --footerGap: 24px; } /* adjust here to mirror Home exactly */

body[data-scrollytelling="1"] .footer-slide{
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-top: clamp(6px, 1.2vw, 16px);
  padding-bottom: 0; /* control gap via panel margin-bottom */
}
body[data-scrollytelling="1"] .footer-slide .panel{
  margin-bottom: var(--footerGap);
}

/* Remove hint on scrollytelling pages to keep bottom spacing consistent */
body[data-scrollytelling="1"] .slides-hint{ display:none !important; }


/* === Scrollytelling spacing v8: only title visible on entry, sections + footer closer === */
/* Title slide stays full viewport; no bottom hint */
body[data-scrollytelling="1"] .title-slide{ min-height:100svh; padding:0; }
body[data-scrollytelling="1"] .title-slide .title-hero{ padding-bottom: 0; }
body[data-scrollytelling="1"] .slides-hint{ display:none !important; }

/* Snap panels to the very top (under header) with minimal offset */
body[data-scrollytelling="1"]{ scroll-padding-top: var(--headerH, 64px); }
body[data-scrollytelling="1"] .slide{
  min-height:100svh;
  padding: clamp(0px, 0.8vw, 10px); /* minimal internal slide padding */
  display:flex; align-items:flex-start; justify-content:center;
}

/* Panel compact look */
body[data-scrollytelling="1"] .panel{
  margin-top: clamp(2px, 0.6vh, 8px);
  margin-bottom: 0;
  padding: clamp(10px, 1.2vw, 18px);
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(0,0,0,.18);
  background: rgba(0,0,0,.12);
}
@supports(backdrop-filter: blur(8px)){
  body[data-scrollytelling="1"] .panel{ backdrop-filter: blur(10px); background: rgba(0,0,0,.10); }
}

/* Tighten inner typography spacing */
body[data-scrollytelling="1"] .panel h1,
body[data-scrollytelling="1"] .panel h2,
body[data-scrollytelling="1"] .panel h3{ margin-block: .35em .25em; }
body[data-scrollytelling="1"] .panel p{ margin-block: .35em; }
body[data-scrollytelling="1"] .panel .grid{ gap: clamp(4px, .8vw, 10px); }
body[data-scrollytelling="1"] .panel .pricing th,
body[data-scrollytelling="1"] .panel .pricing td{ padding: .28rem .45rem; }

/* Footer slide closer to bottom */
:root{ --footerGap: 16px; } /* was 24px */
body[data-scrollytelling="1"] .footer-slide{
  min-height:100svh; display:flex; align-items:flex-end; justify-content:center;
  padding-top: clamp(4px, .8vw, 12px); padding-bottom: 0;
}
body[data-scrollytelling="1"] .footer-slide .panel{ margin-bottom: var(--footerGap); }


/* === Scrollytelling spacing v9: title centered; sections + footer MUCH closer === */
/* Keep title centered on full viewport */
body[data-scrollytelling="1"] .title-slide{
  min-height:100svh;
  display:grid; place-items:center;
  padding:0;
}

/* Slides after the title: snap to very top with minimal offset */
body[data-scrollytelling="1"]{
  scroll-padding-top: var(--headerH, 64px);
}

/* Zero out slide padding to eliminate extra vertical space */
body[data-scrollytelling="1"] .slide{ padding: 0; }
body[data-scrollytelling="1"] .slide:not(.title-slide):not(.footer-slide){
  min-height:100svh;
  display:flex; align-items:flex-start; justify-content:center;
}

/* Panels: extremely tight top margin; remove bottom margin completely */
body[data-scrollytelling="1"] .panel{
  margin-top: clamp(0px, 0.2vh, 4px);
  margin-bottom: 0;
  padding: clamp(8px, 1vw, 16px);
  border-radius: 16px;
  box-shadow: 0 8px 22px rgba(0,0,0,.16);
  background: rgba(0,0,0,.10);
}
@supports(backdrop-filter: blur(8px)){
  body[data-scrollytelling="1"] .panel{ backdrop-filter: blur(10px); background: rgba(0,0,0,.08); }
}

/* Trim inner typography spacing even further */
body[data-scrollytelling="1"] .panel h1,
body[data-scrollytelling="1"] .panel h2,
body[data-scrollytelling="1"] .panel h3{ margin-block: .28em .22em; }
body[data.scrollytelling="1"] .panel p{ margin-block: .28em; } /* fallback typo guard */
body[data-scrollytelling="1"] .panel p{ margin-block: .28em; }
body[data-scrollytelling="1"] .panel .grid{ gap: clamp(3px, .6vw, 8px); }
body[data-scrollytelling="1"] .panel .pricing th,
body[data-scrollytelling="1"] .panel .pricing td{ padding: .24rem .4rem; }
body[data-scrollytelling="1"] .panel > :last-child{ margin-bottom: 0 !important; }

/* Footer: minimal consistent gap to viewport bottom */
:root{ --footerGap: 8px; } /* drastically smaller */
body[data-scrollytelling="1"] .footer-slide{
  min-height:100svh; display:flex; align-items:flex-end; justify-content:center;
  padding: 0;
}
body[data-scrollytelling="1"] .footer-slide .panel{ margin-bottom: var(--footerGap); }


/* ==== BEGIN Non-home spacing override (generated) ==== */
/* === Tighten vertical spacing on all non-home tabs (body[data-scrollytelling="1"]) ===
   Goal: sections much closer together without changing backgrounds or JS behavior.
   Scope: Only pages with body[data-scrollytelling="1"] (O nas, Oferta, Galeria, Rezerwacja, Opinie, Kontakt)
   Date: 2025-09-05
*/

/* 1) Generic sections on non-home pages */
body[data-scrollytelling="1"] .section{
  /* Previously ~72px top/bottom; compress notably */
  padding-block: clamp(10px, 2.6vw, 24px);
}

/* Headings & paragraphs inside compressed sections */
body[data-scrollytelling="1"] .section h1,
body[data-scrollytelling="1"] .section h2,
body[data-scrollytelling="1"] .section h3{ 
  margin-block: .35em .28em;
}
body[data-scrollytelling="1"] .section p{ 
  margin-block: .35em;
}

/* Tighten grids/rows where used */
body[data-scrollytelling="1"] .section .grid{ gap: clamp(6px, 1.2vw, 12px); }
body[data-scrollytelling="1"] .section .row{ gap: clamp(6px, 1.2vw, 12px); }

/* 2) If a page uses scrollytelling slides, shrink slide height/padding (safe no-op otherwise) */
body[data-scrollytelling="1"] .slide{ padding: 0; }
body[data-scrollytelling="1"] .slide:not(.title-slide):not(.footer-slide){
  /* Remove forced viewport height so slides stack closer */
  min-height: auto;
  padding-block: clamp(8px, 1.8vw, 16px);
  display: block;
}

/* Panels inside slides: smaller internal padding and almost no outer margins */
body[data-scrollytelling="1"] .panel{
  margin-block: clamp(6px, 1vh, 10px);
  padding: clamp(8px, 1.4vw, 14px);
  border-radius: 16px;
}
body[data-scrollytelling="1"] .panel > :last-child{ margin-bottom: 0 !important; }

/* Footer: reduce top spacing only on non-home pages */
body[data-scrollytelling="1"] footer{ margin-top: clamp(10px, 1.6vw, 18px); }
/* ==== END Non-home spacing override (generated) ==== */


/* ==== BEGIN Footer fine-tune override (generated v2) ==== */
/* === Footer spacing fine-tune (2025-09-05) ===
   Reduce overall whitespace before footer, but keep a *slightly larger*,
   still noticeable gap vs. spacing between sekcje.
*/
body[data-scrollytelling="1"] .section:last-of-type{
  /* Bottom padding minimal, so stopka podejdzie bliżej treści */
  padding-bottom: clamp(6px, 1vw, 10px);
}
body[data-scrollytelling="1"] footer{
  /* Lekko większy odstęp niż między sekcjami, ale wciąż mały */
  margin-top: clamp(12px, 1.2vw, 16px);
}
/* ==== END Footer fine-tune override (generated v2) ==== */


/* ==== BEGIN Footer vs Sections proportional spacing (v3, 2025-09-05) ====
   Make the gap before the footer only *slightly* larger than the gap between sections.
   Works only on non-home pages (body[data-scrollytelling="1"]). 
*/
body[data-scrollytelling="1"]{
  /* Base vertical padding for sections */
  --sectionPY: clamp(10px, 2.4vw, 22px);
}

/* Sections use the variable above */
body[data-scrollytelling="1"] .section{ padding-block: var(--sectionPY); }

/* Last section: reduce its bottom padding so total footer gap is controlled */
body[data-scrollytelling="1"] .section:last-of-type{
  padding-bottom: calc(var(--sectionPY) * 0.6);
}

/* Ensure the very last panel inside the last section doesn't add extra gap */
body[data-scrollytelling="1"] .section:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* Footer top margin: a bit larger than per-side section padding.
   Inter-section visual gap ≈ 2 * var(--sectionPY).
   We set footer gap ≈ 2.1 * var(--sectionPY) (slightly larger than between sections). */
body[data-scrollytelling="1"] footer{
  margin-top: calc(var(--sectionPY) * 2.1);
}
/* ==== END Footer vs Sections proportional spacing (v3) ==== */



/* ==== BEGIN Footer gap ~slightly larger than inter-section (v4, 2025-09-05) ====
   Target: all non-home pages (body[data-scrollytelling="1"])
   Make gap before footer just a touch larger than gap between sections.
   Inter-section ≈ 2 * var(--sectionPY).
   Footer gap target ≈ 2.10–2.15 * var(--sectionPY).
*/
body[data-scrollytelling="1"]{
  --sectionPY: clamp(10px, 2.2vw, 22px);
}

/* Base section spacing */
body[data-scrollytelling="1"] .section{ padding-block: var(--sectionPY); }

/* Last section: keep a bit of bottom padding */
body[data-scrollytelling="1"] .section:last-of-type{
  padding-bottom: calc(var(--sectionPY) * 0.9);
}

/* Fallback for pages using slides instead of .section wrappers */
body[data-scrollytelling="1"] .slide:last-of-type{ padding-bottom: calc(var(--sectionPY) * 0.9); }
body[data-scrollytelling="1"] .slide:last-of-type .panel:last-child{ margin-bottom: 0 !important; }

/* Footer: only slightly more than inter-section */
body[data-scrollytelling="1"] footer{
  margin-top: calc(var(--sectionPY) * 1.24);
}
/* Total before-footer visual space ≈ 0.9 + 1.24 = 2.14 * var(--sectionPY) */
/* ==== END Footer gap v4 ==== */



/* ==== BEGIN Footer gap ultra-tight (v5, 2025-09-05) ====
   Goal: gap before footer is *noticeably smaller than v4*,
   but still a hair larger than the gap between sections.
   Inter-section ≈ 2.00 × var(--sectionPY).
   Here we set total ≈ 0.85 + 1.16 = 2.01 × var(--sectionPY).
*/
body[data-scrollytelling="1"]{
  --sectionPY: clamp(10px, 2.1vw, 22px);
}

/* Keep sections aligned with the base variable */
body[data-scrollytelling="1"] .section{ padding-block: var(--sectionPY); }

/* Last section: very small bottom padding */
body[data-scrollytelling="1"] .section:last-of-type{
  padding-bottom: calc(var(--sectionPY) * 0.85);
}

/* Slides fallback (if a page uses .slide as last block) */
body[data-scrollytelling="1"] .slide:last-of-type{ 
  padding-bottom: calc(var(--sectionPY) * 0.85);
}
body[data-scrollytelling="1"] .slide:last-of-type .panel:last-child{ margin-bottom: 0 !important; }

/* Footer: hairline more than inter-section */
body[data-scrollytelling="1"] footer{
  margin-top: calc(var(--sectionPY) * 1.16);
}
/* ==== END Footer gap v5 ==== */



/* ==== BEGIN Footer gap ~like-between-sections-but-a-bit-more (v6, 2025-09-05) ====
   Applies to all non-home pages: body[data-scrollytelling="1"]
   Target total gap before footer ≈ 2.06 × --sectionPY (inter-section ≈ 2.00 ×).
*/
body[data-scrollytelling="1"]{
  --sectionPY: clamp(10px, 2vw, 20px);
}
body[data-scrollytelling="1"] .section{ padding-block: var(--sectionPY); }

/* Tight last section */
body[data-scrollytelling="1"] .section:last-of-type{ padding-bottom: calc(var(--sectionPY) * 0.90); }
body[data-scrollytelling="1"] .section:last-of-type .panel:last-child{ margin-bottom: 0 !important; }

/* Slides fallback (if used) */
body[data-scrollytelling="1"] .slide:last-of-type{ padding-bottom: calc(var(--sectionPY) * 0.90); }
body[data-scrollytelling="1"] .slide:last-of-type .panel:last-child{ margin-bottom: 0 !important; }

/* Footer: a hair more than inter-section */
body[data-scrollytelling="1"] footer{ margin-top: calc(var(--sectionPY) * 1.16); }
/* Sum ≈ 0.90 + 1.16 = 2.06 × --sectionPY */
/* ==== END v6 ==== */



/* ==== BEGIN Footer gap 'almost touching' (v7, 2025-09-05) ====
   Applies only to non-home pages (body[data-scrollytelling="1"]).
   Make the space before the footer very small, still non-zero.
*/
body[data-scrollytelling="1"]{
  /* keep base for sections; not changing earlier values to avoid ripple */
  --sectionPY: clamp(10px, 2vw, 20px);
}

/* Ensure last section doesn't add big bottom padding */
body[data-scrollytelling="1"] .section:last-of-type{
  padding-bottom: clamp(4px, 0.6vw, 8px);
}
/* Remove trailing margins that could inflate the gap */
body[data-scrollytelling="1"] .section:last-of-type > *:last-child,
body[data-scrollytelling="1"] .section:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* Slides fallback: if a page uses .slide instead of .section */
body[data-scrollytelling="1"] .slide:last-of-type{
  padding-bottom: clamp(4px, 0.6vw, 8px);
}
body[data-scrollytelling="1"] .slide:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* Footer: keep a tiny buffer so it doesn't touch */
body[data-scrollytelling="1"] footer{
  margin-top: clamp(8px, 0.8vw, 12px);
}
/* ==== END v7 ==== */



/* ==== BEGIN Footer zero-gap (v8, 2025-09-05) ====
   Non-home pages only: body[data-scrollytelling="1"]
   Make footer sit directly next to the last section (no visible whitespace).
*/
body[data-scrollytelling="1"] .section:last-of-type{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}
/* Remove trailing margins inside final section */
body[data-scrollytelling="1"] .section:last-of-type > *:last-child,
body[data-scrollytelling="1"] .section:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* Slides fallback */
body[data-scrollytelling="1"] .slide:last-of-type{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}
body[data-scrollytelling="1"] .slide:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* Footer directly adjacent to last section */
body[data-scrollytelling="1"] footer{
  margin-top: 0 !important;
}
/* ==== END Footer zero-gap v8 ==== */



/* ==== BEGIN Zero-gap harden (v9, 2025-09-05) ====
   Force footer to touch the last section on all non-home pages.
   - Neutralize margin-collapsing
   - Target both <footer> and .site-footer
   - Handle scrollytelling containers & slides
*/
body[data-scrollytelling="1"] .section:last-of-type{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  display: flow-root;        /* prevent bottom-margin collapse */
  overflow: hidden;          /* extra safeguard */
}
/* kill trailing margins inside the last section */
body[data-scrollytelling="1"] .section:last-of-type > *:last-child{
  margin-bottom: 0 !important;
}
body[data-scrollytelling="1"] .section:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* If a page uses scrollytelling with slides */
body[data-scrollytelling="1"] .slide:last-of-type{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  min-height: auto !important; /* no forced viewport gap */
  display: flow-root;
  overflow: hidden;
}
body[data-scrollytelling="1"] .slide:last-of-type .panel:last-child{
  margin-bottom: 0 !important;
}

/* Footer must not introduce any gap */
body[data-scrollytelling="1"] footer,
body[data-scrollytelling="1"] .site-footer{
  margin-top: 0 !important;
  padding-top: 0; /* visual 'touch' — remove internal buffer if any */
}

/* If the scrollytelling wrapper sits before footer */
body[data-scrollytelling="1"] .scrollytelling{
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
body[data-scrollytelling="1"] .scrollytelling + footer,
body[data-scrollytelling="1"] .scrollytelling + .site-footer{
  margin-top: 0 !important;
}

/* Explicit adjacent sibling rule: last .section right before footer */
body[data-scrollytelling="1"] .section:last-of-type + footer,
body[data-scrollytelling="1"] .section:last-of-type + .site-footer{
  margin-top: 0 !important;
}
/* ==== END Zero-gap harden v9 ==== */

