
: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); }


/* === Scrollytelling v10: per-page compact slides === */
body[data-scrollytelling="1"] .slide.compact{
  min-height: auto; /* allow natural height */
  padding: 0;
}
body[data-scrollytelling="1"] .slide.compact .panel{
  margin-top: clamp(0px, .3vh, 4px);
  margin-bottom: 0;
  padding: clamp(8px, .8vw, 14px);
  box-shadow: 0 6px 18px rgba(0,0,0,.14);
  background: rgba(0,0,0,.08);
}
@supports(backdrop-filter: blur(8px)){
  body[data-scrollytelling="1"] .slide.compact .panel{ backdrop-filter: blur(10px); background: rgba(0,0,0,.06); }
}
