/* ============================================================
   NaUrbex.pl — "The Threshold"
   Design: portal & explorer's-light motif drawn from the logo.
   Palette: graphite black, cold blue-white beam, danger red.
   ============================================================ */

:root{
  /* core */
  --black:#070809;
  --ink:#0c0e10;
  --graphite:#15181b;
  --graphite-2:#1d2126;
  --steel:#2a2f36;
  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.05);

  /* text */
  --fg:#e9ecef;
  --fg-dim:#a4abb3;
  --fg-mute:#6b7178;

  /* signature: the beam */
  --beam-1:#dff1ff;
  --beam-2:#8fc6f0;
  --beam-3:#3d7fb8;
  --beam-glow:rgba(143,198,240,.45);

  /* danger accent */
  --red:#e03a32;
  --red-deep:#9c1f1a;
  --gold:#c9a24b;

  /* type */
  --display:'Oswald',sans-serif;
  --narrow:'Archivo Narrow',sans-serif;
  --body:'Archivo',system-ui,sans-serif;

  --wrap:1200px;
  --r:4px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--black);
  color:var(--fg);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
em{font-style:normal}

/* selection + focus */
::selection{background:var(--beam-3);color:#fff}
:focus-visible{outline:2px solid var(--beam-2);outline-offset:3px;border-radius:2px}

/* ---------- shared section heads ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.32em;font-size:.72rem;font-weight:600;
  color:var(--beam-2);margin-bottom:1.1rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--beam-3)}
.eyebrow--light{color:var(--beam-1)}
.eyebrow--light::before{background:var(--beam-2)}

.sec-head{max-width:680px;margin:0 auto 2rem;text-align:center}
.sec-head .eyebrow::after{content:"";width:26px;height:1px;background:var(--beam-3)}
.sec-title{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2rem,4.6vw,3.3rem);line-height:1.02;
  letter-spacing:-.01em;text-transform:uppercase;
}
.sec-sub{margin-top:1.1rem;color:var(--fg-dim);font-size:1.02rem}
.muted-h{color:var(--fg-mute)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  --bg:var(--fg);--c:var(--black);
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--narrow);font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;font-size:.86rem;
  padding:.85rem 1.5rem;border:1px solid transparent;border-radius:var(--r);
  background:var(--bg);color:var(--c);cursor:pointer;
  position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s,background .25s,color .25s;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px -12px rgba(0,0,0,.8)}
.btn .btn__arr{transition:transform .25s}
.btn:hover .btn__arr{transform:translateX(4px)}
.btn--lg{padding:1.05rem 2rem;font-size:.95rem}
.btn--full{width:100%;justify-content:center}
.btn--sm{padding:.6rem 1.1rem;font-size:.78rem}

/* ghost */
.btn--ghost{background:transparent;color:var(--fg);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--beam-2);color:var(--beam-1);background:rgba(143,198,240,.06)}

/* nav cta */
.btn--nav{background:var(--red);color:#fff;padding:.7rem 1.35rem}
.btn--nav:hover{background:#ef4a42}

/* red CTA (hero, footer, popup) */
.btn--red{background:var(--red);color:#fff}
.btn--red:hover{background:#ef4a42}

/* attention-grabbing hero CTA: gentle pulse + recurring shine sweep */
.hero__cta .btn--red{position:relative;overflow:hidden;
  animation:ctaPulse 2.8s ease-in-out infinite}
.hero__cta .btn--red::after{content:"";position:absolute;top:0;left:-30%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);
  transform:translateX(-200%) skewX(-18deg);
  animation:ctaShine 3.2s ease-in-out infinite;pointer-events:none}
@keyframes ctaPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(224,58,50,.5),0 10px 30px -12px rgba(0,0,0,.8)}
  50%{box-shadow:0 0 0 12px rgba(224,58,50,0),0 10px 30px -12px rgba(0,0,0,.8)}}
@keyframes ctaShine{
  0%{transform:translateX(-200%) skewX(-18deg)}
  22%,100%{transform:translateX(420%) skewX(-18deg)}}
.hero__cta .btn--red:hover{animation-play-state:paused}

/* submit — solid, confident CTA with refined shine + glow */
.btn--submit{
  margin-top:.4rem;
  background:var(--red);
  color:#fff;letter-spacing:.16em;font-weight:700;
  padding:1.15rem 2rem;border:0;
  box-shadow:0 14px 34px -16px rgba(224,58,50,.7),0 0 0 1px rgba(255,255,255,.04) inset;
}
.btn--submit:hover{
  background:#ef4a42;transform:translateY(-2px);
  box-shadow:0 20px 44px -16px rgba(224,58,50,.85),0 0 0 1px rgba(255,255,255,.06) inset;
}
.btn--submit::after{
  content:"";position:absolute;top:0;left:0;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);
  transform:translateX(-180%) skewX(-18deg);transition:transform .7s;pointer-events:none;
}
.btn--submit:hover::after{transform:translateX(280%) skewX(-18deg)}
.btn--submit:disabled{opacity:.7;cursor:default;transform:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s,border-color .3s,backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,9,10,.82);backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
}
.nav__inner{max-width:var(--wrap);margin:0 auto;padding:.85rem 28px;
  display:flex;align-items:center;gap:1.5rem;
}
.brand{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.brand__mark{width:44px;height:44px;border-radius:6px;filter:drop-shadow(0 2px 8px rgba(143,198,240,.25))}
.brand__text{font-family:var(--display);font-weight:600;font-size:1.35rem;
  letter-spacing:.01em;text-transform:uppercase;line-height:1}
.brand__accent{color:var(--beam-2)}
.brand__tld{color:var(--fg-mute);font-weight:400}

.nav__links{display:flex;gap:1.6rem;margin-left:auto}
.nav__links a{font-family:var(--narrow);font-size:.92rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;color:var(--fg-dim);
  position:relative;padding:.3rem 0;transition:color .2s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--beam-2);transition:width .25s}
.nav__links a:hover{color:var(--fg)}
.nav__links a:hover::after{width:100%}
.nav .btn--nav{flex-shrink:0}

.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:6px;margin-left:auto}
.nav__burger span{width:26px;height:2px;background:var(--fg);transition:.3s}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__mobile{display:none;flex-direction:column;gap:.2rem;padding:1rem 28px 1.6rem;
  background:rgba(8,9,10,.97);border-bottom:1px solid var(--line)}
.nav__mobile.open{display:flex}
.nav__mobile a{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.06em;
  padding:.85rem .2rem;color:var(--fg-dim);border-bottom:1px solid var(--line-soft)}
.nav__mobile .btn--full{margin-top:1rem}

/* ============================================================
   HERO — the signature beam
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;overflow:hidden;padding:6rem 0 5.5rem;
  background:radial-gradient(120% 90% at 50% -10%,#1a1f25 0%,var(--black) 60%);
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__photo{position:absolute;inset:0;
  background:url("https://images.pexels.com/photos/4863123/pexels-photo-4863123.jpeg?auto=compress&cs=tinysrgb&w=1920") center/cover no-repeat;
  filter:grayscale(.35) brightness(.42) contrast(1.05);
  transform:scale(1.04)}
.hero__vignette{position:absolute;inset:0;
  background:radial-gradient(80% 70% at 50% 35%,transparent 40%,rgba(0,0,0,.7) 100%)}
.hero__grain{position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E")}

/* the explorer's light beam — central column */
.beam{position:absolute;top:-12%;left:50%;width:46vw;max-width:560px;height:118%;
  transform:translateX(-50%);pointer-events:none;
  background:
    radial-gradient(60% 38% at 50% 8%,var(--beam-glow) 0%,transparent 62%),
    linear-gradient(180deg,rgba(223,241,255,.42) 0%,rgba(143,198,240,.16) 38%,transparent 72%);
  clip-path:polygon(40% 0,60% 0,100% 100%,0 100%);
  filter:blur(2px);opacity:.9;
  animation:beamPulse 7s ease-in-out infinite;
}
.beam::before{content:"";position:absolute;top:4%;left:50%;width:60px;height:60px;
  transform:translateX(-50%);border-radius:50%;
  background:radial-gradient(circle,var(--beam-1),transparent 70%);
  filter:blur(6px);opacity:.95}
@keyframes beamPulse{0%,100%{opacity:.85;filter:blur(2px)}50%{opacity:1;filter:blur(1px)}}

.hero__dust{position:absolute;inset:0;pointer-events:none}
.dust-mote{position:absolute;width:2px;height:2px;border-radius:50%;
  background:var(--beam-1);opacity:0;
  animation:float linear infinite}
@keyframes float{
  0%{transform:translateY(20px) translateX(0);opacity:0}
  15%{opacity:.7}
  85%{opacity:.5}
  100%{transform:translateY(-90px) translateX(14px);opacity:0}
}

.hero__content{position:relative;z-index:2;max-width:var(--wrap);width:100%;
  margin:0 auto;padding:0 28px;text-align:center}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.28em;
  font-size:.74rem;font-weight:600;color:var(--beam-2);margin-bottom:1.6rem;
  padding:.5rem 1rem;border:1px solid var(--line);border-radius:40px;
  background:rgba(143,198,240,.04)}
.hero__eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--red);
  box-shadow:0 0 10px var(--red);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero__title{font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:clamp(2.7rem,8.5vw,6.2rem);line-height:.98;letter-spacing:-.015em;
  margin-bottom:1.6rem}
.hero__title span{display:block}
.hero__title--glow{
  background:linear-gradient(180deg,var(--beam-1),var(--beam-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px var(--beam-glow)}
.hero__lead{max-width:600px;margin:0 auto 2.4rem;font-size:clamp(1.05rem,2vw,1.3rem);
  color:var(--fg-dim);font-weight:400}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.hero__slogan{display:block;margin-bottom:1.4rem;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.34em;
  font-size:.82rem;color:var(--fg-mute)}
.hero__slogan em{color:var(--red);font-weight:700;letter-spacing:.28em}

.hero__scroll{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  opacity:.85;transition:opacity .3s}
.hero__scroll:hover{opacity:1}
.hero__scroll::before{content:"Przewiń";font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.24em;font-size:.62rem;font-weight:600;color:var(--beam-2)}
.hero__scroll-dot{width:22px;height:34px;border:1.5px solid var(--beam-3);
  border-radius:12px;position:relative;display:block;
  box-shadow:0 0 18px -6px var(--beam-glow)}
.hero__scroll-dot::after{content:"";position:absolute;top:6px;left:50%;width:3px;height:7px;
  border-radius:3px;background:var(--beam-1);transform:translateX(-50%);
  box-shadow:0 0 6px var(--beam-2);
  animation:scrollDot 1.8s ease-in-out infinite}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,-3px)}
  40%{opacity:1}80%{opacity:0;transform:translate(-50%,10px)}}
/* hide the scroll cue when the viewport is too short to fit it below the CTA,
   so it never overlaps the buttons */
@media(max-height:760px),(max-width:560px){
  .hero__scroll{display:none}
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.strip{background:var(--ink);border-block:1px solid var(--line)}
.strip__inner{max-width:var(--wrap);margin:0 auto;padding:1.8rem 28px;
  display:flex;align-items:center;justify-content:center;gap:clamp(1rem,4vw,3.4rem);
  flex-wrap:wrap}
.stat{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:90px}
.stat__num{font-family:var(--display);font-size:clamp(1.8rem,3.2vw,2.5rem);font-weight:600;
  color:var(--beam-1);line-height:1}
.stat__lab{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.7rem;color:var(--fg-mute);margin-top:.4rem}
.strip__div{width:1px;height:38px;background:var(--line)}

/* ============================================================
   INTRO
   ============================================================ */
.intro{padding:3.25rem 0}
.intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.intro__h{font-family:var(--display);font-weight:500;text-transform:uppercase;
  font-size:clamp(1.7rem,3.4vw,2.7rem);line-height:1.06;letter-spacing:-.01em}
.intro__right p{color:var(--fg-dim);font-size:1.08rem;margin-bottom:1.3rem}
.intro__right strong{color:var(--beam-1);font-weight:600}

/* ============================================================
   OFFER
   ============================================================ */
.offer{padding:3rem 0;background:linear-gradient(180deg,var(--black),var(--ink) 50%,var(--black))}
.offer__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}

.card{position:relative;background:var(--graphite);border:1px solid var(--line);
  border-radius:var(--r);padding:2rem 1.8rem 2.2rem;display:flex;flex-direction:column;
  transition:transform .3s,border-color .3s,background .3s;overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--beam-3),transparent);
  transform:scaleX(0);transition:transform .4s}
/* hover lift + gentle scale — high specificity so it beats the .io.in reveal reset */
.card.io,.card{transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,background .3s,box-shadow .3s,opacity .8s}
.card.io:hover,.card.io:focus,.card:hover,.card:focus{
  transform:translateY(-8px) scale(1.03);border-color:rgba(143,198,240,.35);
  background:var(--graphite-2);box-shadow:0 24px 50px -28px #000,0 0 30px -16px var(--beam-glow);z-index:2}
.card:hover::before,.card:focus::before{transform:scaleX(1)}
.card__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.3rem}
.card__no{font-family:var(--display);font-size:2.4rem;font-weight:700;
  color:var(--steel);line-height:1}
.card__tag{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.66rem;font-weight:600;padding:.35rem .7rem;border:1px solid var(--line);
  border-radius:30px;color:var(--fg-dim)}
.card__tag--red{color:var(--red);border-color:rgba(224,58,50,.4);background:rgba(224,58,50,.06)}
.card__tag--gold{color:var(--gold);border-color:rgba(201,162,75,.4);background:rgba(201,162,75,.06)}
.card__title{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.5rem;letter-spacing:.01em;margin-bottom:.8rem}

/* difficulty meter */
.diff{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.1rem}
.diff__lab{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.62rem;color:var(--fg-mute)}
.diff__bars{display:flex;gap:5px}
.diff__bar{flex:1;height:7px;border-radius:2px;background:var(--steel);
  transition:background .3s,box-shadow .3s}
.diff__bar.on.g{background:#46b755;box-shadow:0 0 10px -2px #46b755}
.diff__bar.on.y{background:#d8c031;box-shadow:0 0 10px -2px #d8c031}
.diff__bar.on.o{background:#e08a2a;box-shadow:0 0 10px -2px #e08a2a}
.diff__bar.on.r{background:#e03a32;box-shadow:0 0 10px -2px #e03a32}
.diff__bar.on.gold{background:var(--gold);box-shadow:0 0 10px -2px var(--gold)}
.diff__name{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.72rem;font-weight:600;align-self:flex-start}
.diff__name.g{color:#46b755}.diff__name.y{color:#d8c031}
.diff__name.o{color:#e08a2a}.diff__name.r{color:#e03a32}.diff__name.gold{color:var(--gold)}

.card__get{margin-top:auto;margin-bottom:1.4rem}
.card__get-h{display:block;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.14em;font-size:.66rem;color:var(--beam-2);margin-bottom:.6rem}
.card__desc{color:var(--fg-dim);font-size:.96rem;margin-bottom:1.3rem;flex-grow:0}
.card__list{list-style:none}
.card__list li{font-size:.9rem;color:var(--fg-dim);padding:.4rem 0 .4rem 1.4rem;
  position:relative;border-top:1px solid var(--line-soft)}
.card__list li::before{content:"";position:absolute;left:0;top:50%;width:7px;height:7px;
  transform:translateY(-50%) rotate(45deg);border:1px solid var(--beam-3)}
.card__cta{display:flex;align-items:center;justify-content:center;gap:.4rem;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.86rem;font-weight:600;color:#fff;background:var(--red);
  padding:.85rem 1.2rem;border-radius:var(--r);transition:background .25s,transform .25s}
.card__cta .btn__arr,.card__cta::after{transition:transform .25s}
.card--click{cursor:pointer}
.card--click:hover .card__cta{background:#ef4a42}
.card--feature{border-color:rgba(224,58,50,.25)}
.card--feature .card__no{color:rgba(224,58,50,.35)}
.card--vip{border-color:rgba(201,162,75,.22)}
.card--vip .card__no{color:rgba(201,162,75,.3)}

/* FOMO scarcity badge on cards */
.card__fomo{position:absolute;top:0;right:0;z-index:3;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.64rem;font-weight:700;color:var(--beam-1);
  background:rgba(143,198,240,.14);border-left:1px solid rgba(143,198,240,.35);
  border-bottom:1px solid rgba(143,198,240,.35);
  padding:.4rem .7rem;border-bottom-left-radius:var(--r)}
.card__fomo--hot{color:#ffd9d6;background:rgba(224,58,50,.16);
  border-left-color:rgba(224,58,50,.45);border-bottom-color:rgba(224,58,50,.45)}
.card__fomo::before{content:"●";font-size:.5em;vertical-align:middle;margin-right:.4em;
  color:var(--red);animation:fomoBlink 1.6s ease-in-out infinite}
.card__fomo--hot::before{color:#ff6b63}
@keyframes fomoBlink{0%,100%{opacity:1}50%{opacity:.25}}

/* ============================================================
   TERMINY / KALENDARZ REZERWACJI
   ============================================================ */
.terms{margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.terms__bar{max-width:760px;margin:0 auto 2.4rem;display:flex;align-items:center;gap:.9rem;
  padding:.9rem 1.3rem;border:1px solid rgba(224,58,50,.3);border-radius:var(--r);
  background:rgba(224,58,50,.06);font-size:.96rem;color:var(--fg-dim)}
.terms__bar-ic{color:var(--red);font-size:1.1rem;flex-shrink:0}
.terms__bar-txt strong{color:#ffd9d6}
.terms__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.term{position:relative;display:flex;flex-direction:column;gap:.9rem;
  background:var(--graphite);border:1px solid var(--line);border-radius:var(--r);
  padding:1.5rem 1.5rem 1.6rem;overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s}
.term:hover{transform:translateY(-6px);border-color:rgba(143,198,240,.35);
  box-shadow:0 24px 50px -28px #000,0 0 30px -16px var(--beam-glow)}
.term--full{opacity:.6}
.term--full:hover{transform:none;border-color:var(--line);box-shadow:none}
.term__date{display:flex;align-items:baseline;gap:.6rem}
.term__day{font-family:var(--display);font-weight:700;font-size:2.2rem;line-height:1;color:var(--fg)}
.term__mo{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.12em;
  font-size:.8rem;color:var(--beam-2)}
.term__dow{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.68rem;color:var(--fg-mute);margin-left:auto;align-self:center}
.term__type{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.15rem;color:var(--beam-1);letter-spacing:.01em}
.term__meta{display:flex;flex-direction:column;gap:.35rem;font-size:.86rem;color:var(--fg-dim)}
.term__meta span{display:flex;align-items:center;gap:.5rem}
.term__meta span::before{content:"";width:6px;height:6px;border-radius:50%;
  background:var(--beam-3);flex-shrink:0}
/* seats indicator */
.term__seats{margin-top:.2rem}
.term__seats-bar{height:7px;border-radius:4px;background:var(--steel);overflow:hidden}
.term__seats-fill{height:100%;border-radius:4px;
  background:linear-gradient(90deg,var(--beam-3),var(--beam-2))}
.term__seats-txt{display:block;margin-top:.45rem;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:600}
.term__seats-txt.low{color:var(--red)}
.term__seats-txt.mid{color:var(--gold)}
.term__seats-txt.ok{color:var(--beam-2)}
.term__cta{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:.4rem;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;font-size:.84rem;
  font-weight:700;color:#fff;background:var(--red);padding:.8rem 1rem;border-radius:var(--r);
  border:0;cursor:pointer;width:100%;transition:background .25s,transform .25s}
.term__cta:hover{background:#ef4a42;transform:translateY(-2px)}
.term__cta .btn__arr{transition:transform .25s}
.term__cta:hover .btn__arr{transform:translateX(4px)}
.term__full-lab{margin-top:auto;text-align:center;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;font-weight:600;
  color:var(--fg-mute);padding:.8rem;border:1px dashed var(--steel);border-radius:var(--r)}
.term__ribbon{position:absolute;top:0;right:0;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.1em;font-size:.62rem;font-weight:700;padding:.35rem .7rem;
  border-bottom-left-radius:var(--r)}
.term__ribbon--last{color:#ffd9d6;background:rgba(224,58,50,.18);
  border-left:1px solid rgba(224,58,50,.4);border-bottom:1px solid rgba(224,58,50,.4)}
.terms__foot{margin-top:2.2rem;text-align:center;color:var(--fg-mute);font-size:.95rem}
.terms__foot a{color:var(--beam-2);text-decoration:underline}

/* collapsible toggle (sekcja otwierana, nie zajmuje miejsca na stałe) */
.terms__toggle-wrap{display:flex;justify-content:center;margin-top:.5rem}
.terms__toggle{display:inline-flex;align-items:center;gap:.9rem;cursor:pointer;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.12em;font-weight:700;
  font-size:.92rem;color:var(--fg);
  background:var(--graphite);border:1px solid rgba(143,198,240,.25);border-radius:40px;
  padding:.9rem 1.6rem;transition:border-color .25s,background .25s,transform .25s}
.terms__toggle:hover{border-color:var(--beam-2);background:var(--graphite-2);transform:translateY(-2px)}
.terms__toggle-count{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.08em;
  font-size:.74rem;font-weight:600;color:var(--beam-2);
  padding:.2rem .65rem;border:1px solid rgba(143,198,240,.3);border-radius:30px}
.terms__toggle-ic{position:relative;width:14px;height:14px;flex-shrink:0}
.terms__toggle-ic::before,.terms__toggle-ic::after{content:"";position:absolute;
  background:var(--beam-2);transition:transform .3s,opacity .3s}
.terms__toggle-ic::before{top:6px;left:0;width:14px;height:2px}
.terms__toggle-ic::after{top:0;left:6px;width:2px;height:14px}
.terms__toggle.is-open .terms__toggle-ic::after{transform:rotate(90deg);opacity:0}
/* animated open/close panel */
.terms__panel{overflow:hidden;max-height:0;opacity:0;
  transition:max-height .55s cubic-bezier(.2,.8,.2,1),opacity .4s,margin-top .4s;margin-top:0}
.terms__panel.is-open{max-height:4000px;opacity:1;margin-top:2.2rem}

/* ============================================================
   MAP CITY DETAIL MODAL (opis miasta po kliknięciu)
   ============================================================ */
.citymodal{position:fixed;inset:0;z-index:240;display:flex;align-items:center;justify-content:center;padding:20px}
.citymodal[hidden]{display:none}
.citymodal__overlay{position:absolute;inset:0;background:rgba(4,5,6,.84);backdrop-filter:blur(7px);
  opacity:0;transition:opacity .35s}
.citymodal.is-open .citymodal__overlay{opacity:1}
.citymodal__box{position:relative;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;
  background:linear-gradient(180deg,var(--graphite),var(--ink));
  border:1px solid rgba(143,198,240,.22);border-radius:14px;padding:2.2rem 2rem;
  box-shadow:0 50px 110px -30px #000,0 0 80px -36px var(--beam-glow);
  transform:translateY(24px) scale(.97);opacity:0;
  transition:transform .4s cubic-bezier(.2,.8,.2,1),opacity .35s}
.citymodal.is-open .citymodal__box{transform:none;opacity:1}
.citymodal__close{position:absolute;top:14px;right:16px;background:none;border:0;color:var(--fg-mute);
  font-size:1.1rem;cursor:pointer;line-height:1;padding:4px;transition:color .2s}
.citymodal__close:hover{color:var(--fg)}
.citymodal__head{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem}
.citymodal__pin{flex-shrink:0;width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--beam-1);
  background:rgba(143,198,240,.10);border:1px solid rgba(143,198,240,.3)}
.citymodal__kicker{display:block;font-family:var(--narrow);text-transform:uppercase;letter-spacing:.2em;
  font-size:.66rem;font-weight:600;color:var(--beam-2)}
.citymodal__name{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.7rem;letter-spacing:.01em;line-height:1.05;margin-top:.2rem}
.citymodal__lead{font-family:var(--display);font-weight:300;font-size:1.1rem;line-height:1.4;
  color:var(--fg);border-left:3px solid var(--beam-3);padding-left:1rem;margin-bottom:1.1rem}
.citymodal__why{color:var(--fg-dim);font-size:.96rem;line-height:1.65;margin-bottom:1.5rem}
.citymodal__foot{border-top:1px solid var(--line);padding-top:1.3rem;
  display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.citymodal__foot-note{font-size:.84rem;color:var(--fg-mute)}
.citymodal__cta{flex-shrink:0}
@media(max-width:560px){
  .citymodal__box{padding:1.7rem 1.3rem}
  .citymodal__cta{width:100%;justify-content:center}
}

/* ============================================================
   WYPRAWA DETAIL MODAL (pełny opis po kliknięciu kafelka)
   ============================================================ */
.wdetail{position:fixed;inset:0;z-index:240;display:flex;align-items:center;justify-content:center;padding:20px}
.wdetail[hidden]{display:none}
.wdetail__overlay{position:absolute;inset:0;background:rgba(4,5,6,.86);backdrop-filter:blur(8px);
  opacity:0;transition:opacity .35s}
.wdetail.is-open .wdetail__overlay{opacity:1}
.wdetail__box{position:relative;width:100%;max-width:880px;max-height:92vh;overflow:hidden;
  display:grid;grid-template-columns:1fr 1.05fr;
  background:var(--graphite);border:1px solid rgba(143,198,240,.22);border-radius:14px;
  box-shadow:0 50px 110px -30px #000,0 0 80px -36px var(--beam-glow);
  transform:translateY(26px) scale(.97);opacity:0;
  transition:transform .42s cubic-bezier(.2,.8,.2,1),opacity .35s}
.wdetail.is-open .wdetail__box{transform:none;opacity:1}
.wdetail__close{position:absolute;top:12px;right:14px;z-index:5;background:rgba(7,8,9,.6);
  border:1px solid rgba(255,255,255,.12);color:#fff;width:34px;height:34px;border-radius:50%;
  font-size:1rem;cursor:pointer;line-height:1;transition:background .2s,transform .2s}
.wdetail__close:hover{background:rgba(7,8,9,.9);transform:rotate(90deg)}
/* media side */
.wdetail__media{position:relative;min-height:340px;overflow:hidden}
.wdetail__img{position:absolute;inset:0;
  background:#06080b center 35%/cover no-repeat;
  transform:scale(1.05);animation:wdetailZoom 16s ease-in-out infinite alternate}
@keyframes wdetailZoom{0%{transform:scale(1.05)}100%{transform:scale(1.14)}}
.wdetail__media-tint{position:absolute;inset:0;mix-blend-mode:multiply}
.wdetail__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 60%,var(--graphite) 99%),
             linear-gradient(0deg,rgba(7,8,9,.5),transparent 50%)}
.wdetail__media-info{position:absolute;left:1.3rem;top:1.3rem;z-index:2;display:flex;align-items:center;gap:.8rem}
.wdetail__no{font-family:var(--display);font-weight:700;font-size:2.4rem;line-height:1;
  color:#fff;opacity:.85;text-shadow:0 2px 14px rgba(0,0,0,.6)}
.wdetail__tag{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.66rem;font-weight:700;color:#fff;
  padding:.35rem .75rem;border:1px solid rgba(255,255,255,.4);border-radius:30px;
  background:rgba(7,8,9,.45)}
/* body side */
.wdetail__body{padding:2.2rem 2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}
.wdetail__title{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.7rem;letter-spacing:.01em;line-height:1.05}
.wdetail__diff{display:flex;flex-direction:column;gap:.4rem}
.wdetail__desc{color:var(--fg-dim);font-size:.98rem;line-height:1.6}
.wdetail__get-h{display:block;font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.7rem;font-weight:600;color:var(--beam-2);margin-bottom:.5rem}
.wdetail__list{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.wdetail__list li{position:relative;padding-left:1.5rem;color:var(--fg-dim);font-size:.94rem}
.wdetail__list li::before{content:"";position:absolute;left:0;top:.5rem;width:8px;height:8px;
  transform:rotate(45deg);border:1px solid var(--beam-3)}
.wdetail__cta{margin-top:.6rem;width:100%;justify-content:center}
/* reuse the .diff styling inside modal (inherits from offer) */
.wdetail__diff .diff__lab{font-size:.66rem}
@media(max-width:720px){
  .wdetail__box{grid-template-columns:1fr;max-height:90vh;overflow-y:auto}
  .wdetail__media{min-height:200px;max-height:34vh}
  .wdetail__media::after{background:linear-gradient(0deg,var(--graphite) 1%,transparent 40%)}
  .wdetail__body{padding:1.6rem 1.4rem}
}

/* ============================================================
   SEAT PICKER (rezerwacja miejsc jak w kinie)
   ============================================================ */
.seat{position:fixed;inset:0;z-index:220;display:flex;align-items:center;justify-content:center;padding:20px}
.seat[hidden]{display:none}
.seat__overlay{position:absolute;inset:0;background:rgba(4,5,6,.85);backdrop-filter:blur(7px);
  opacity:0;transition:opacity .35s}
.seat.is-open .seat__overlay{opacity:1}
.seat__box{position:relative;width:100%;max-width:620px;max-height:92vh;overflow-y:auto;
  background:var(--graphite);border:1px solid rgba(143,198,240,.22);border-radius:12px;
  padding:2.2rem 2rem;box-shadow:0 50px 100px -30px #000,0 0 70px -34px var(--beam-glow);
  transform:translateY(26px) scale(.97);opacity:0;
  transition:transform .4s cubic-bezier(.2,.8,.2,1),opacity .35s}
.seat.is-open .seat__box{transform:none;opacity:1}
.seat__close{position:absolute;top:14px;right:16px;background:none;border:0;color:var(--fg-mute);
  font-size:1.1rem;cursor:pointer;z-index:2;transition:color .2s;padding:4px;line-height:1}
.seat__close:hover{color:var(--fg)}
.seat__head{text-align:center;margin-bottom:1.4rem}
.seat__kicker{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.22em;
  font-size:.68rem;font-weight:600;color:var(--beam-2)}
.seat__title{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.6rem;letter-spacing:.01em;margin:.4rem 0 .5rem}
.seat__meta{color:var(--fg-dim);font-size:.92rem}
.seat__meta strong{color:var(--beam-1)}
.seat__legend{display:flex;justify-content:center;flex-wrap:wrap;gap:1.2rem;margin-bottom:1.2rem}
.seat__leg{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--fg-dim)}
.seat__demo{width:16px;height:16px;border-radius:4px;display:inline-block}
.seat__demo--free{background:var(--graphite-2);border:1px solid rgba(143,198,240,.4)}
.seat__demo--sel{background:var(--beam-3);border:1px solid var(--beam-2);box-shadow:0 0 10px -3px var(--beam-glow)}
.seat__demo--taken{background:#23272d;border:1px solid var(--steel);opacity:.6}
/* "stage" — punkt zbiórki/przewodnik, jak ekran w kinie */
.seat__stage{position:relative;margin:0 auto 1.6rem;max-width:80%;text-align:center}
.seat__stage-line{display:block;height:30px;
  border-radius:50%/0 0 100% 100%;
  border-bottom:2px solid rgba(143,198,240,.5);
  box-shadow:0 14px 30px -18px var(--beam-glow)}
.seat__stage-lab{display:inline-block;margin-top:.5rem;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.18em;font-size:.64rem;color:var(--fg-mute)}
.seat__map{display:grid;grid-template-columns:repeat(var(--per-row,5),1fr);gap:.7rem;
  max-width:420px;margin:0 auto 1.6rem}
.seat__cell{aspect-ratio:1/1;min-height:46px;border-radius:6px;cursor:pointer;
  background:var(--graphite-2);border:1px solid rgba(143,198,240,.35);color:var(--fg-dim);
  font-family:var(--narrow);font-weight:700;font-size:.92rem;
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s,background .2s,border-color .2s,box-shadow .2s}
.seat__cell:hover:not(.is-taken){transform:translateY(-2px);border-color:var(--beam-2);
  color:var(--fg);box-shadow:0 0 16px -6px var(--beam-glow)}
.seat__cell.is-sel{background:var(--beam-3);border-color:var(--beam-1);color:#fff;
  box-shadow:0 0 20px -4px var(--beam-glow);transform:translateY(-2px)}
.seat__cell.is-taken{background:#23272d;border-color:var(--steel);color:transparent;
  opacity:.55;cursor:not-allowed;position:relative}
.seat__cell.is-taken::after{content:"✕";position:absolute;inset:0;display:flex;
  align-items:center;justify-content:center;color:var(--fg-mute);font-size:.85rem}
.seat__bar{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;
  flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1.3rem}
.seat__summary{display:flex;flex-direction:column;gap:.2rem}
.seat__sel-lab{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.66rem;color:var(--fg-mute)}
.seat__sel-list{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--beam-1)}
.seat__confirm{flex-shrink:0}
.seat__confirm:disabled{opacity:.55;cursor:not-allowed;transform:none}
@media(max-width:560px){
  .seat__box{padding:1.6rem 1.2rem}
  .seat__bar{flex-direction:column;align-items:stretch}
  .seat__confirm{width:100%;justify-content:center}
}

/* reservation banner inside the contact form (spójność z kalendarzem) */
.form__resv{margin-bottom:1.3rem;border:1px solid rgba(143,198,240,.3);border-radius:var(--r);
  background:rgba(143,198,240,.06);overflow:hidden}
.form__resv[hidden]{display:none}
.form__resv-row{display:flex;align-items:center;gap:.9rem;padding:.9rem 1.1rem}
.form__resv-ic{flex-shrink:0;width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(143,198,240,.18);color:var(--beam-1);font-size:.85rem;font-weight:700}
.form__resv-txt{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}
.form__resv-lab{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.64rem;font-weight:600;color:var(--beam-2)}
.form__resv-detail{font-size:.92rem;color:var(--fg)}
.form__resv-clear{flex-shrink:0;background:none;border:0;color:var(--fg-mute);cursor:pointer;
  font-size:.95rem;padding:4px;transition:color .2s}
.form__resv-clear:hover{color:var(--red)}
/* gift / voucher variant of the banner */
.form__resv--gift{border-color:rgba(201,162,75,.4);background:rgba(201,162,75,.07)}
.form__resv--gift .form__resv-lab{color:var(--gold)}
.form__resv-ic--gift{background:rgba(201,162,75,.18);color:var(--gold)}
/* gentle flash to draw the eye when a voucher pre-fills the form */
@keyframes formFlash{0%{box-shadow:0 0 0 0 rgba(201,162,75,.5)}100%{box-shadow:0 0 0 18px rgba(201,162,75,0)}}
.form--flash{animation:formFlash 1.2s ease-out}

/* ============================================================
   FORM PICKERS — triggery + modale (osoby / termin / rodzaj)
   ============================================================ */
.picker-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.8rem;
  background:var(--graphite);border:1px solid var(--line);border-radius:var(--r);
  padding:.85rem 1rem;cursor:pointer;text-align:left;color:var(--fg);
  font-family:inherit;font-size:1rem;transition:border-color .25s,background .25s,box-shadow .25s}
.picker-trigger:hover{border-color:rgba(143,198,240,.4);background:var(--graphite-2)}
.picker-trigger.err{border-color:var(--red);box-shadow:0 0 0 1px var(--red)}
.picker-trigger__val{color:var(--fg-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.picker-trigger__val.is-set{color:var(--fg)}
.picker-trigger__ic{flex-shrink:0;color:var(--beam-2);display:flex}

.picker{position:fixed;inset:0;z-index:230;display:flex;align-items:center;justify-content:center;padding:20px}
.picker[hidden]{display:none}
.picker__overlay{position:absolute;inset:0;background:rgba(4,5,6,.85);backdrop-filter:blur(7px);
  opacity:0;transition:opacity .3s}
.picker.is-open .picker__overlay{opacity:1}
.picker__box{position:relative;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;
  background:var(--graphite);border:1px solid rgba(143,198,240,.22);border-radius:12px;
  padding:2.2rem 2rem;text-align:center;
  box-shadow:0 50px 100px -30px #000,0 0 70px -34px var(--beam-glow);
  transform:translateY(24px) scale(.97);opacity:0;
  transition:transform .38s cubic-bezier(.2,.8,.2,1),opacity .32s}
.picker.is-open .picker__box{transform:none;opacity:1}
.picker__box--narrow{max-width:400px}
.picker__box--wide{max-width:760px}
.picker__close{position:absolute;top:14px;right:16px;background:none;border:0;color:var(--fg-mute);
  font-size:1.1rem;cursor:pointer;z-index:2;transition:color .2s;padding:4px;line-height:1}
.picker__close:hover{color:var(--fg)}
.picker__kicker{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.22em;
  font-size:.68rem;font-weight:600;color:var(--beam-2)}
.picker__title{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.5rem;letter-spacing:.01em;margin:.4rem 0 .5rem}
.picker__sub{color:var(--fg-dim);font-size:.92rem;margin-bottom:1.6rem}
.picker__confirm{margin-top:1.6rem;width:100%;justify-content:center}
/* stopka pickera — elegancki blok z linkiem do pełnej sekcji Wyprawy */
.picker__foot{margin-top:1.6rem;padding:1.3rem 1.4rem;border-radius:var(--r);
  background:rgba(143,198,240,.05);border:1px solid rgba(143,198,240,.18);
  display:flex;align-items:center;justify-content:space-between;gap:1.2rem;flex-wrap:wrap}
.picker__foot-row{display:flex;align-items:center;gap:.9rem;flex:1;min-width:240px;text-align:left}
.picker__foot-ic{flex-shrink:0;width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--beam-1);
  background:rgba(143,198,240,.1);border:1px solid rgba(143,198,240,.25)}
.picker__foot-txt{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.picker__foot-h{font-family:var(--display);text-transform:uppercase;font-weight:500;
  font-size:.98rem;letter-spacing:.01em;color:var(--fg);line-height:1.2}
.picker__foot-sub{font-size:.84rem;color:var(--fg-mute);line-height:1.4}
.picker__foot-btn{flex-shrink:0;white-space:nowrap}

/* stepper (liczba osób) */
.stepper{display:flex;align-items:center;justify-content:center;gap:1.4rem;margin:.5rem 0 1.4rem}
.stepper__btn{width:56px;height:56px;border-radius:50%;flex-shrink:0;
  background:var(--graphite-2);border:1px solid rgba(143,198,240,.35);color:var(--beam-1);
  font-size:1.7rem;font-weight:300;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s,border-color .2s,background .2s,box-shadow .2s}
.stepper__btn:hover{transform:translateY(-2px);border-color:var(--beam-2);
  box-shadow:0 0 20px -6px var(--beam-glow)}
.stepper__btn:active{transform:scale(.94)}
.stepper__btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.stepper__val{min-width:120px;display:flex;flex-direction:column;gap:.1rem}
.stepper__val span:first-child{font-family:var(--display);font-weight:700;font-size:3rem;
  line-height:1;color:var(--fg)}
.stepper__unit{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.16em;
  font-size:.72rem;color:var(--fg-mute)}
.stepper__quick{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.4rem}
.stepper__quick button{font-family:var(--narrow);font-weight:600;font-size:.85rem;
  padding:.45rem .9rem;border-radius:30px;cursor:pointer;color:var(--fg-dim);
  background:rgba(255,255,255,.02);border:1px solid var(--line);transition:.2s}
.stepper__quick button:hover{border-color:var(--beam-2);color:var(--beam-1)}

/* date picker */
.datepick{text-align:left}
.datepick__lab{display:block;font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.68rem;font-weight:600;color:var(--beam-2);margin-bottom:.7rem}
.datepick__list{display:flex;flex-direction:column;gap:.55rem;max-height:230px;overflow-y:auto;
  padding-right:.3rem}
.datechip{display:flex;align-items:center;gap:1rem;width:100%;text-align:left;cursor:pointer;
  background:var(--graphite-2);border:1px solid var(--line);border-radius:var(--r);
  padding:.7rem .9rem;transition:border-color .2s,background .2s,transform .2s}
.datechip:hover{border-color:rgba(143,198,240,.4);transform:translateX(3px)}
.datechip.is-sel{border-color:var(--beam-1);background:rgba(143,198,240,.1);
  box-shadow:0 0 18px -8px var(--beam-glow)}
.datechip__d{font-family:var(--display);font-weight:700;font-size:1.5rem;line-height:1;color:var(--fg)}
.datechip__mo{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.72rem;color:var(--beam-2)}
.datechip__info{display:flex;flex-direction:column;gap:.1rem;margin-left:auto;text-align:right}
.datechip__dow{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.12em;
  font-size:.66rem;color:var(--fg-mute)}
.datechip__type{font-size:.86rem;color:var(--fg-dim)}
.datepick__empty{color:var(--fg-mute);font-size:.9rem;padding:.5rem 0}
.datepick__customwrap[hidden]{display:none}
.datepick__or{display:flex;align-items:center;gap:.9rem;margin:1.3rem 0 1rem;
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--fg-mute)}
.datepick__or::before,.datepick__or::after{content:"";flex:1;height:1px;background:var(--line)}
.datepick__custom{display:flex;flex-direction:column;gap:.6rem}
.datepick__native,.datepick__free{width:100%;background:var(--ink);border:1px solid var(--line);
  border-radius:var(--r);padding:.75rem .9rem;color:var(--fg);font-family:inherit;font-size:.95rem}
.datepick__native{color-scheme:dark}
.datepick__free.err{border-color:var(--red)}
.datepick__native:focus,.datepick__free:focus{outline:none;border-color:var(--beam-2)}

/* type tiles (rodzaj wyprawy) */
.typetiles{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;text-align:left}
.typetile{position:relative;display:flex;flex-direction:column;gap:.4rem;cursor:pointer;
  background:var(--graphite-2);border:1px solid var(--line);border-radius:var(--r);
  padding:1.1rem 1rem 1.15rem;transition:border-color .25s,transform .25s,box-shadow .25s,background .25s}
.typetile:hover{transform:translateY(-4px);border-color:rgba(143,198,240,.4);
  box-shadow:0 18px 40px -22px #000,0 0 24px -16px var(--beam-glow)}
.typetile.is-sel{border-color:var(--beam-1);background:rgba(143,198,240,.08);
  box-shadow:0 0 26px -10px var(--beam-glow)}
.typetile.is-sel::after{content:"✓";position:absolute;top:.7rem;right:.8rem;
  width:20px;height:20px;border-radius:50%;background:var(--beam-1);color:#06243b;
  display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700}
.typetile--feature{border-color:rgba(224,58,50,.3)}
.typetile--vip{border-color:rgba(201,162,75,.3)}
.typetile--wide{grid-column:1/-1;flex-direction:row;align-items:center;gap:1rem}
.typetile--wide .typetile__desc{margin:0}
.typetile__no{font-family:var(--display);font-weight:700;font-size:1.3rem;line-height:1;color:var(--steel)}
.typetile__name{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.02rem;letter-spacing:.01em;color:var(--fg)}
.typetile__desc{font-size:.84rem;color:var(--fg-dim);line-height:1.45}
.typetile__diff{align-self:flex-start;margin-top:.2rem;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.1em;font-size:.62rem;font-weight:600;
  padding:.25rem .6rem;border-radius:30px;border:1px solid var(--line);color:var(--fg-mute)}
.typetile__diff--easy{color:#5fd16e;border-color:rgba(70,183,85,.4)}
.typetile__diff--mid{color:var(--gold);border-color:rgba(201,162,75,.4)}
.typetile__diff--hard{color:#ffa64d;border-color:rgba(255,140,40,.4)}
.typetile__diff--x{color:#ff7b73;border-color:rgba(224,58,50,.45)}
.typetile__diff--vip{color:var(--gold);border-color:rgba(201,162,75,.5);background:rgba(201,162,75,.08)}

@media(max-width:640px){
  .typetiles{grid-template-columns:1fr 1fr}
  .picker__box{padding:1.7rem 1.2rem}
  .stepper{gap:1rem}
  .stepper__btn{width:50px;height:50px}
  /* stopka pickera: ułóż pionowo i przycisk na pełną szerokość */
  .picker__foot{flex-direction:column;align-items:stretch;gap:1rem;padding:1.2rem}
  .picker__foot-btn{width:100%;justify-content:center}
}
@media(max-width:430px){
  .typetiles{grid-template-columns:1fr}
  .typetile--wide{flex-direction:column;align-items:flex-start}
}

/* selectable voucher cards */
.vcard{cursor:pointer;text-align:left;font-family:inherit;color:var(--fg);width:100%;
  display:flex;flex-direction:column;align-items:flex-start}
.vcard__tag{align-self:flex-start;width:auto;flex:0 0 auto}
.vcard__h{color:var(--fg)}
.vcard p{color:var(--fg-dim)}
.vcard__pick{margin-top:auto;padding-top:1rem;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.1em;font-size:.74rem;font-weight:700;color:var(--beam-2);
  display:inline-flex;align-items:center;gap:.4rem;opacity:.85;transition:opacity .2s,gap .2s}
.vcard:hover .vcard__pick{opacity:1;gap:.6rem}
.vcard.is-sel{border-color:var(--beam-1);box-shadow:0 0 26px -10px var(--beam-glow)}
.vcard.is-sel .vcard__pick{opacity:1;color:var(--beam-1)}
.vcard.is-sel::before{content:"✓";position:absolute;top:1rem;right:1rem;z-index:2;
  width:24px;height:24px;border-radius:50%;background:var(--beam-1);color:#06243b;
  display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}

/* ============================================================
   PROCESS
   ============================================================ */
.proc{padding:3rem 0;background:var(--black)}
.proc__grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:3rem;align-items:start;
  max-width:1040px;margin:0 auto}
.proc__visual{position:sticky;top:110px}
.proc__visual-inner{position:relative;
  padding:0;display:flex;flex-direction:column;align-items:center;gap:1.4rem;
  overflow:visible}
/* soft radial glow behind the graphic */
.proc__visual-inner::before{content:"";position:absolute;top:50%;left:50%;
  width:118%;height:96%;transform:translate(-50%,-50%);
  background:radial-gradient(60% 50% at 50% 30%,rgba(143,198,240,.12),transparent 70%);
  pointer-events:none;z-index:0}
/* portal image (ChatGPT) with subtle animation layers */
.proc__portal{position:relative;z-index:1;width:100%;max-width:340px;aspect-ratio:3/4.4;
  min-height:420px;border-radius:10px;overflow:hidden;margin:0;
  border:1px solid rgba(143,198,240,.18);
  box-shadow:0 36px 90px -34px #000,0 0 70px -34px var(--beam-glow)}
.proc__portal-img{position:absolute;inset:0;
  background:#06080b url("assets/img/proces-portal.jpg") center 35%/cover no-repeat;
  transform:scale(1.04);
  animation:portalZoom 18s ease-in-out infinite alternate}
@keyframes portalZoom{0%{transform:scale(1.04)}100%{transform:scale(1.13)}}
/* pulsing glow from the doorway light */
.proc__portal-glow{position:absolute;left:50%;top:42%;width:55%;height:70%;
  transform:translate(-50%,-50%);pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(150,200,245,.35),rgba(120,175,225,.08) 45%,transparent 70%);
  mix-blend-mode:screen;animation:portalGlow 4.5s ease-in-out infinite}
@keyframes portalGlow{0%,100%{opacity:.55}50%{opacity:1}}
/* slow diagonal light sweep / shimmer */
.proc__portal-shine{position:absolute;top:-40%;left:-60%;width:50%;height:200%;
  pointer-events:none;mix-blend-mode:screen;
  background:linear-gradient(100deg,transparent,rgba(200,225,255,.22),transparent);
  transform:rotate(16deg);animation:portalShine 7s ease-in-out infinite}
@keyframes portalShine{0%{left:-60%}55%,100%{left:150%}}
/* floating dust motes rising through the light */
.proc__portal-dust{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.proc__portal-dust span{position:absolute;bottom:-6px;width:3px;height:3px;border-radius:50%;
  background:rgba(210,230,255,.7);box-shadow:0 0 6px rgba(180,215,255,.8);
  animation:portalDust linear infinite}
.proc__portal-dust span:nth-child(1){left:44%;animation-duration:7s;animation-delay:0s}
.proc__portal-dust span:nth-child(2){left:50%;animation-duration:9s;animation-delay:1.2s}
.proc__portal-dust span:nth-child(3){left:47%;animation-duration:6s;animation-delay:2.4s}
.proc__portal-dust span:nth-child(4){left:53%;animation-duration:8.5s;animation-delay:.6s;width:2px;height:2px}
.proc__portal-dust span:nth-child(5){left:41%;animation-duration:10s;animation-delay:3s;width:2px;height:2px}
.proc__portal-dust span:nth-child(6){left:56%;animation-duration:7.5s;animation-delay:1.8s}
.proc__portal-dust span:nth-child(7){left:49%;animation-duration:11s;animation-delay:4s;width:2px;height:2px}
.proc__portal-dust span:nth-child(8){left:45%;animation-duration:8s;animation-delay:2.8s;width:2px;height:2px}
@keyframes portalDust{0%{transform:translateY(0);opacity:0}
  15%{opacity:.9}85%{opacity:.6}100%{transform:translateY(-360px);opacity:0}}
/* bottom veil for the caption */
.proc__portal-veil{position:absolute;left:0;right:0;bottom:0;height:42%;pointer-events:none;
  background:linear-gradient(0deg,rgba(6,8,11,.95),transparent)}
.proc__portal-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;
  display:flex;flex-direction:column;gap:.25rem;padding:1.3rem 1.4rem;text-align:left}
.proc__portal-k{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.24em;
  font-size:.66rem;font-weight:600;color:var(--beam-2)}
.proc__portal-t{font-family:var(--display);text-transform:uppercase;font-weight:500;
  font-size:1rem;letter-spacing:.01em;color:var(--fg);line-height:1.2}

.proc__steps{list-style:none;counter-reset:s;position:relative}
/* base track line */
.proc__steps::before{content:"";position:absolute;left:42px;top:30px;bottom:30px;width:2px;
  background:var(--steel);border-radius:2px}
/* animated light traveling down the line so it never looks static */
.proc__steps::after{content:"";position:absolute;left:41px;top:30px;width:4px;height:70px;
  border-radius:4px;
  background:linear-gradient(180deg,transparent,var(--beam-2),var(--beam-1),var(--beam-2),transparent);
  box-shadow:0 0 16px -2px var(--beam-glow);
  animation:procFlow 3.6s ease-in-out infinite}
@keyframes procFlow{
  0%{top:30px;opacity:0}
  12%{opacity:1}
  88%{opacity:1}
  100%{top:calc(100% - 100px);opacity:0}}
.proc__step{display:flex;gap:1.6rem;padding:1.2rem 1.2rem;align-items:flex-start;
  position:relative;border-radius:var(--r);border:1px solid transparent;
  transition:background .35s,border-color .35s,box-shadow .35s}
.proc__step:hover{background:rgba(255,255,255,.05);
  border-color:rgba(143,198,240,.25);box-shadow:0 18px 44px -20px #000;z-index:2}
.proc__n{flex-shrink:0;width:48px;height:48px;border-radius:50%;
  background:var(--graphite);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.25rem;font-weight:600;color:var(--beam-2);
  position:relative;z-index:1;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,background .3s,box-shadow .3s;
  will-change:transform}
/* the node ring that grows on hover so the line feels connected, not frozen */
.proc__n::before{content:"";position:absolute;inset:-6px;border-radius:50%;
  border:1px solid transparent;transition:inset .3s,border-color .3s,box-shadow .3s}
/* number tile grows on hover (works whether you hover the row or the number itself) */
.proc__step:hover .proc__n,
.proc__n:hover{transform:scale(1.15);border-color:var(--beam-2);background:var(--graphite-2);
  box-shadow:0 0 26px -6px var(--beam-glow)}
.proc__step:hover .proc__n::before,
.proc__n:hover::before{inset:-9px;border-color:rgba(143,198,240,.4);
  box-shadow:0 0 22px -8px var(--beam-glow)}
.proc__step h3{font-family:var(--display);text-transform:uppercase;font-weight:500;
  font-size:1.2rem;letter-spacing:.01em;margin-bottom:.3rem;padding-top:.4rem}
.proc__step p{color:var(--fg-dim);font-size:.98rem}

/* ============================================================
   PLACES
   ============================================================ */
.places{padding:3rem 0;background:linear-gradient(180deg,var(--black),var(--ink))}
.places__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.place{position:relative;border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;background:var(--graphite);transition:border-color .3s,transform .3s}
.place:hover,.place:focus{border-color:rgba(143,198,240,.3);transform:translateY(-4px)}
.place__img{height:240px;position:relative;overflow:hidden;
  background-color:#1a1f24;
  background-size:cover;background-position:center;filter:grayscale(.4) contrast(1.05) brightness(.85)}
.place:hover .place__img{filter:grayscale(.1) contrast(1.1) brightness(1)}
.place__img{transition:filter .5s}
.place__img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,8,9,.1) 30%,rgba(7,8,9,.85))}
.place__noise{position:absolute;inset:0;opacity:.4;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
/* Real urbex photos (Pexels, free for commercial use) — each distinct */
.place__img--hospital{background-image:url("https://images.pexels.com/photos/4863123/pexels-photo-4863123.jpeg?auto=compress&cs=tinysrgb&w=900")}
.place__img--factory{background-image:url("https://images.pexels.com/photos/5503864/pexels-photo-5503864.jpeg?auto=compress&cs=tinysrgb&w=900")}
.place__img--palace{background-image:url("https://images.pexels.com/photos/1411408/pexels-photo-1411408.jpeg?auto=compress&cs=tinysrgb&w=900")}
.place__img--house{background-image:url("https://images.pexels.com/photos/17336533/pexels-photo-17336533.jpeg?auto=compress&cs=tinysrgb&w=900")}
.place__img--bunker{background-image:url("https://images.pexels.com/photos/16813983/pexels-photo-16813983.jpeg?auto=compress&cs=tinysrgb&w=900")}
.place__img--military{background-image:url("https://images.pexels.com/photos/8551121/pexels-photo-8551121.jpeg?auto=compress&cs=tinysrgb&w=900")}
.place__body{padding:1.4rem 1.6rem 1.7rem}
.place__kicker{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.18em;
  font-size:.68rem;color:var(--beam-2);font-weight:600}
.place__body h3{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.45rem;margin:.35rem 0 .55rem}
.place__body p{color:var(--fg-dim);font-size:.95rem}

/* ============================================================
   ORGANIZER
   ============================================================ */
.org{padding:3.25rem 0;background:var(--black)}
.org__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:4rem;align-items:center}
.org__photo{position:relative}
.org__frame{position:relative;border:1px solid rgba(143,198,240,.18);border-radius:6px;
  overflow:hidden;aspect-ratio:4/5;background:#15191d;
  box-shadow:0 30px 70px -34px #000,0 0 50px -28px var(--beam-glow)}
.org__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(.15) contrast(1.04);z-index:1;
  animation:orgZoom 18s ease-in-out infinite alternate}
@keyframes orgZoom{from{transform:scale(1)}to{transform:scale(1.07)}}
/* soft gradient fade at edges for a finished, non-boxy look */
.org__frame::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(7,8,9,.35) 0%,transparent 22%,transparent 62%,rgba(7,8,9,.85) 100%)}
/* subtle beam-blue corner accents */
.org__frame::before{content:"";position:absolute;inset:10px;z-index:3;pointer-events:none;
  border:1px solid transparent;
  border-image:linear-gradient(135deg,rgba(143,198,240,.5),transparent 40%,transparent 60%,rgba(143,198,240,.5)) 1;
  opacity:.6}
/* placeholder shown only if image is missing */
.org__ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(135deg,#1a1e22 0 20px,#1f242a 20px 22px);z-index:0}
.org__ph-hint{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.14em;
  font-size:.72rem;color:var(--fg-mute);border:1px dashed var(--steel);
  padding:.5rem .9rem;border-radius:30px}
.org__beam{position:absolute;top:-10%;left:50%;width:55%;height:120%;transform:translateX(-50%);
  background:linear-gradient(180deg,rgba(143,198,240,.18),transparent 70%);
  clip-path:polygon(42% 0,58% 0,100% 100%,0 100%);pointer-events:none;filter:blur(3px);z-index:4;
  animation:orgBeam 5s ease-in-out infinite}
@keyframes orgBeam{0%,100%{opacity:.7}50%{opacity:1}}
.org__name{position:absolute;bottom:-16px;right:-10px;background:var(--graphite-2);
  border:1px solid rgba(143,198,240,.25);border-radius:var(--r);padding:.7rem 1.3rem;z-index:5;
  box-shadow:0 14px 34px -12px #000;text-align:right}
.org__name-main{display:block;font-family:var(--display);text-transform:uppercase;
  font-weight:600;font-size:1.05rem;letter-spacing:.02em;color:var(--fg);line-height:1.1}
.org__name-alias{display:block;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.14em;font-size:.72rem;color:var(--beam-2);margin-top:.2rem}
.org__text .sec-title{line-height:1.08;margin-bottom:1.3rem}
.org__text p{color:var(--fg-dim);font-size:1.05rem;margin-bottom:1.2rem}
.org__text strong{color:var(--beam-1);font-weight:600}
.org__facts{list-style:none;margin:1.8rem 0;display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.org__facts li{display:flex;align-items:baseline;gap:.7rem;font-size:.96rem;color:var(--fg-dim);
  padding:.7rem 0;border-top:1px solid var(--line)}
.org__facts li span{font-family:var(--display);font-size:1.5rem;font-weight:700;
  color:var(--beam-1);min-width:54px}
.org__sign{font-size:.95rem;color:var(--fg-mute);border-left:2px solid var(--red);
  padding-left:1rem;margin-top:1.5rem}

/* hook quote — the strong "I take people where they'd never go" line */
.org__hook{position:relative;font-family:var(--display);font-weight:300;
  font-size:clamp(1.15rem,2vw,1.45rem)!important;line-height:1.4;color:var(--fg)!important;
  border-left:3px solid var(--beam-3);padding:.2rem 0 .2rem 1.3rem;margin:0 0 1.6rem!important}
.org__hook strong{color:var(--beam-1)}

/* ============================================================
   PARANORMAL
   ============================================================ */
.para{position:relative;padding:3.5rem 0;overflow:hidden;
  background:
    linear-gradient(180deg,var(--black) 0%,transparent 18%,transparent 82%,var(--ink) 100%),
    radial-gradient(100% 80% at 50% 60%,#10161d,var(--black) 75%)}
.para__bg{position:absolute;inset:0;overflow:hidden}
.para__beam{position:absolute;bottom:-5%;left:50%;width:50vw;max-width:600px;height:115%;
  transform:translateX(-50%);
  background:linear-gradient(0deg,rgba(143,198,240,.16),transparent 70%);
  clip-path:polygon(45% 100%,55% 100%,100% 0,0 0);filter:blur(4px)}
.para__inner{position:relative;text-align:center;max-width:860px;margin:0 auto}
.para__h{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:clamp(1.9rem,4.4vw,3.2rem);line-height:1.04;margin-bottom:1.4rem}
.para__lead{color:var(--fg-dim);font-size:1.15rem;max-width:620px;margin:0 auto 3rem}
.para__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-bottom:3rem;text-align:left}
.para__col{padding:1.6rem;border:1px solid var(--line);border-radius:var(--r);
  background:rgba(255,255,255,.02);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,background .35s,box-shadow .35s}
.para__col.io:hover,.para__col:hover{transform:scale(1.05);border-color:rgba(143,198,240,.4);
  background:rgba(143,198,240,.06);box-shadow:0 18px 44px -22px #000;z-index:2}
.para__col h3{font-family:var(--display);text-transform:uppercase;font-weight:500;
  font-size:1.15rem;margin-bottom:.5rem;color:var(--beam-1)}
.para__col p{color:var(--fg-dim);font-size:.94rem}

/* ============================================================
   GALLERY
   ============================================================ */
.gal{padding:3rem 0;background:var(--ink)}
.gal__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem;
  grid-auto-flow:row dense}
.gal__item{position:relative;border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(135deg,#15191d 0 22px,#1a1f24 22px 24px);
  background-size:cover;background-position:center;
  transition:border-color .3s,transform .3s,background-image .4s}
.gal__item.bg-loaded{animation:galFade .5s ease}
@keyframes galFade{from{opacity:.4}to{opacity:1}}
.gal__item::after{content:attr(data-cap);position:absolute;left:0;right:0;bottom:0;
  padding:.7rem .9rem;font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.68rem;color:var(--fg-dim);
  background:linear-gradient(transparent,rgba(7,8,9,.92));
  opacity:0;transform:translateY(8px);transition:.3s}
.gal__item:hover,.gal__item:focus{border-color:rgba(143,198,240,.35);transform:scale(.985)}
.gal__item:hover::after,.gal__item:focus::after{opacity:1;transform:translateY(0)}
.gal__item--tall{grid-row:span 2}
.gal__item--wide{grid-column:span 2}
.gal__item--photo{background-size:cover;background-position:center;
  background-color:#15191d;
  filter:grayscale(.4) contrast(1.05) brightness(.92)}
.gal__item--photo::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(7,8,9,.7));transition:opacity .3s}
.gal__item--photo:hover{filter:grayscale(.1) contrast(1.1) brightness(1)}
/* video tiles */
.gal__item--video{background:#0a0c0e}
.gal__item--video video{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;pointer-events:none;
  filter:grayscale(.3) contrast(1.05) brightness(.85);transition:filter .4s}
.gal__item--video video::-webkit-media-controls{display:none!important}
.gal__item--video video::-webkit-media-controls-start-playback-button{display:none!important;-webkit-appearance:none}
.gal__item--video:hover video{filter:grayscale(.05) contrast(1.1) brightness(1)}
.gal__ph{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.16em;
  font-size:.74rem;color:var(--fg-mute);border:1px dashed var(--steel);
  padding:.5rem 1rem;border-radius:30px}
.gal__ph--video{color:var(--beam-2);border-color:var(--beam-3)}

/* ============================================================
   MAP
   ============================================================ */
.map{padding:3rem 0;background:linear-gradient(180deg,var(--ink),var(--black))}
.map__wrap{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:visible;
  background:var(--graphite);padding:2.5rem}
.map__poland{height:520px;position:relative}
.map__poland svg{width:100%;height:100%}
.poland-path{fill:#1d2227;stroke:var(--steel);stroke-width:1.2;
  transition:fill .4s}
.map__wrap:hover .poland-path{fill:#232a31}
.map-dot{fill:var(--beam-1);transition:r .2s}
.map-pulse{fill:var(--beam-2);opacity:.5;transform-origin:center}
.map-obj{fill:var(--beam-2)}
.map-label{fill:var(--fg-dim);font-family:var(--narrow),sans-serif;
  font-size:13px;font-weight:500;letter-spacing:.04em;
  paint-order:stroke;stroke:rgba(7,8,9,.85);stroke-width:3px;transition:fill .2s}
.map__wrap:hover .map-label{fill:var(--fg)}
/* interactive city groups */
.map-city{cursor:pointer;outline:none}
.map-hit{cursor:pointer}
.map-city .map-dot{transition:r .2s,fill .2s,filter .2s}
.map-city:hover .map-dot,.map-city:focus .map-dot{fill:#fff;r:7;
  filter:drop-shadow(0 0 8px rgba(143,198,240,.9))}
.map-city:hover .map-label,.map-city:focus .map-label{fill:#fff;font-weight:600}
.map-city:focus-visible .map-dot{stroke:var(--beam-1);stroke-width:2}
/* highlight ring that appears on hover so it's obvious the city is interactive */
.map-ring{opacity:0;transform-origin:center;transition:opacity .2s}
.map-city:hover .map-ring,.map-city:focus .map-ring{opacity:1}
/* hover tooltip */
.map__tip{position:absolute;z-index:5;pointer-events:none;max-width:240px;
  background:linear-gradient(180deg,var(--graphite-2),var(--ink));
  border:1px solid rgba(143,198,240,.35);border-radius:10px;
  padding:.75rem .9rem;box-shadow:0 18px 44px -18px #000,0 0 30px -16px var(--beam-glow);
  opacity:0;transform:translateY(6px) scale(.97);
  transition:opacity .2s,transform .2s}
.map__tip.is-on{opacity:1;transform:translateY(0) scale(1)}
.map__tip[hidden]{display:none}
.map__tip-name{display:block;font-family:var(--display);text-transform:uppercase;
  font-weight:600;font-size:1rem;letter-spacing:.02em;color:var(--beam-1);margin-bottom:.25rem}
.map__tip-desc{display:block;font-size:.84rem;line-height:1.45;color:var(--fg-dim)}
.map__legend{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;
  gap:1rem;margin-top:1.6rem;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.1em;font-size:.74rem;color:var(--fg-dim)}
/* tylko pierwszy element legendy (kropka + etykieta) jest flexem */
.map__legend>span:first-child{display:inline-flex;align-items:center;gap:.5rem}
.map__dot{width:9px;height:9px;border-radius:50%;background:var(--beam-1);
  box-shadow:0 0 8px var(--beam-glow);flex-shrink:0}
/* podpowiedź to zwykły tekst — bez flexa, żeby słowa się nie nakładały */
.map__note{display:block;color:var(--fg-mute);letter-spacing:.06em;line-height:1.5;max-width:46ch}
.map__note strong{color:var(--beam-2)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{padding:3rem 0;background:var(--black)}
.faq__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:3.5rem;align-items:start}
.faq__head{position:sticky;top:120px}
.faq__head .sec-title{text-align:left}
.faq__head .sec-sub{margin-top:1rem}
.faq__list{display:flex;flex-direction:column;gap:.7rem}
.faq__item{border:1px solid var(--line);border-radius:var(--r);background:var(--graphite);
  overflow:hidden;transition:border-color .3s,background .3s,box-shadow .3s,transform .25s}
/* hover highlight so it's clear which question is focused */
.faq__item:hover{border-color:rgba(143,198,240,.4);background:var(--graphite-2);
  box-shadow:0 14px 34px -22px #000,0 0 22px -16px var(--beam-glow);transform:translateX(3px)}
.faq__item[open]{border-color:rgba(143,198,240,.25);background:var(--graphite-2)}
.faq__item[open]:hover{border-color:rgba(143,198,240,.45)}
.faq__item summary{list-style:none;cursor:pointer;padding:1.2rem 1.4rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-family:var(--display);text-transform:uppercase;font-weight:500;font-size:1.08rem;
  letter-spacing:.01em;transition:color .2s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item:hover summary{color:var(--beam-1)}
/* left accent bar appears on hover/open */
.faq__item summary::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--beam-2);transform:scaleY(0);transform-origin:center;transition:transform .25s}
.faq__item{position:relative}
.faq__item:hover summary::before,.faq__item[open] summary::before{transform:scaleY(1)}
.faq__ic{position:relative;width:16px;height:16px;flex-shrink:0}
.faq__ic::before,.faq__ic::after{content:"";position:absolute;background:var(--beam-2);
  transition:.3s}
.faq__ic::before{top:7px;left:0;width:16px;height:2px}
.faq__ic::after{top:0;left:7px;width:2px;height:16px}
.faq__item:hover .faq__ic::before,.faq__item:hover .faq__ic::after{background:var(--beam-1)}
.faq__item[open] .faq__ic::after{transform:rotate(90deg);opacity:0}
.faq__a{padding:0 1.4rem 1.3rem}
.faq__a p{color:var(--fg-dim);font-size:.98rem}

/* ============================================================
   REVIEWS / OPINIE
   ============================================================ */
.revs{padding:3rem 0;background:linear-gradient(180deg,var(--black),var(--ink))}
/* carousel: 3 visible at a time, sliding track */
.revs__carousel{display:flex;align-items:center;gap:.8rem}
.revs__viewport{overflow:hidden;flex:1;padding:.5rem 0}
.revs__track{display:flex;transition:transform .55s cubic-bezier(.3,.8,.3,1)}
.revs__track .rev{flex:0 0 calc((100% - 2*1.4rem)/3);margin-right:1.4rem;
  box-sizing:border-box}
.revs__arrow{flex-shrink:0;width:46px;height:46px;border-radius:50%;cursor:pointer;
  background:var(--graphite);border:1px solid rgba(143,198,240,.3);color:var(--beam-1);
  font-size:1.6rem;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,transform .25s,box-shadow .25s}
.revs__arrow:hover{background:var(--graphite-2);border-color:var(--beam-2);
  transform:translateY(-2px);box-shadow:0 0 20px -6px var(--beam-glow)}
.revs__arrow:active{transform:scale(.94)}
.revs__arrow:disabled{opacity:.3;cursor:not-allowed;transform:none;box-shadow:none}
.revs__dots{display:flex;justify-content:center;gap:.6rem;margin-top:1.8rem}
.revs__dotbtn{width:9px;height:9px;border-radius:50%;cursor:pointer;padding:0;
  background:var(--steel);border:0;transition:background .25s,transform .25s,width .25s}
.revs__dotbtn:hover{background:var(--beam-2)}
.revs__dotbtn.is-active{background:var(--beam-1);width:26px;border-radius:5px;
  box-shadow:0 0 12px -2px var(--beam-glow)}

.rev{position:relative;background:var(--graphite);border:1px solid var(--line);
  border-radius:var(--r);padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1.1rem;
  transition:border-color .35s,transform .35s,box-shadow .35s}
.rev::before{content:"\201C";position:absolute;top:.4rem;right:1.2rem;
  font-family:var(--display);font-size:4.5rem;line-height:1;color:var(--steel);opacity:.5}
.rev:hover{border-color:rgba(143,198,240,.3);transform:translateY(-6px);
  box-shadow:0 22px 50px -24px #000}
.rev:hover .rev__av{border-color:var(--beam-2);color:var(--beam-1);
  box-shadow:0 0 18px -6px var(--beam-glow);transition:.3s}
.rev__stars{color:var(--gold);letter-spacing:.18em;font-size:1rem}
.rev__q{font-size:1.02rem;color:var(--fg-dim);line-height:1.55;font-style:italic;margin:0}
.rev__by{display:flex;align-items:center;gap:.85rem;margin-top:auto}
.rev__av{width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:var(--graphite-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.2rem;color:var(--beam-2)}
.rev__name{display:block;font-family:var(--display);text-transform:uppercase;
  letter-spacing:.02em;font-size:1rem;color:var(--fg)}
.rev__meta{display:block;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.12em;font-size:.7rem;color:var(--fg-mute);margin-top:.15rem}
@media(max-width:860px){
  .revs__track .rev{flex-basis:calc((100% - 1.4rem)/2)}
}
@media(max-width:560px){
  .revs__track .rev{flex-basis:100%;margin-right:1.4rem}
  .revs__arrow{display:none}
}

/* ============================================================
   CZY TO LEGALNE — boczny panel rozwijany (side tab)
   ============================================================ */
.legalside{position:fixed;top:0;right:0;height:100%;z-index:120;pointer-events:none}
/* vertical tab anchored to the right edge */
.legalside__tab{position:fixed;top:50%;right:0;transform:translateY(-50%);pointer-events:auto;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;cursor:pointer;
  background:linear-gradient(180deg,var(--red),var(--red-deep));color:#fff;border:0;
  padding:1rem .55rem;border-radius:10px 0 0 10px;
  box-shadow:-6px 0 24px -10px rgba(0,0,0,.7);
  transition:padding-right .25s,box-shadow .25s,background .25s}
.legalside__tab:hover{padding-right:.9rem;box-shadow:-8px 0 30px -10px rgba(224,58,50,.6)}
.legalside__tab-ic{display:flex}
.legalside__tab-txt{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);
  font-family:var(--narrow);text-transform:uppercase;letter-spacing:.16em;
  font-size:.82rem;font-weight:700}
.legalside.is-open .legalside__tab{right:min(420px,92vw);border-radius:10px 0 0 10px}
@media(max-width:480px){
  .legalside.is-open .legalside__tab{opacity:0;pointer-events:none}
}
/* overlay */
.legalside__overlay{position:fixed;inset:0;background:rgba(4,5,6,.7);backdrop-filter:blur(4px);
  pointer-events:auto;opacity:0;transition:opacity .35s}
.legalside__overlay[hidden]{display:none}
.legalside.is-open .legalside__overlay{opacity:1}
/* sliding panel from the right */
.legalside__panel{position:fixed;top:0;right:0;height:100%;width:min(420px,92vw);
  pointer-events:auto;overflow-y:auto;
  background:linear-gradient(180deg,var(--graphite),var(--ink));
  border-left:1px solid rgba(143,198,240,.22);
  box-shadow:-30px 0 80px -30px #000;
  padding:2.4rem 1.9rem;
  transform:translateX(100%);transition:transform .42s cubic-bezier(.2,.8,.2,1)}
.legalside__panel[hidden]{display:none}
.legalside.is-open .legalside__panel{transform:translateX(0)}
.legalside__close{position:absolute;top:14px;right:16px;background:none;border:0;color:var(--fg-mute);
  font-size:1.1rem;cursor:pointer;transition:color .2s;padding:4px;line-height:1}
.legalside__close:hover{color:var(--fg)}
.legalside__head{margin-bottom:1.2rem}
.legalside__shield{display:inline-flex;width:44px;height:44px;border-radius:10px;
  align-items:center;justify-content:center;color:var(--beam-1);margin-bottom:.9rem;
  background:rgba(143,198,240,.10);border:1px solid rgba(143,198,240,.3)}
.legalside__kicker{display:block;font-family:var(--narrow);text-transform:uppercase;letter-spacing:.22em;
  font-size:.66rem;font-weight:600;color:var(--beam-2)}
.legalside__h{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.5rem;letter-spacing:.01em;line-height:1.12;margin-top:.3rem}
.legalside__lead{color:var(--fg-dim);font-size:.95rem;margin-bottom:1.3rem}
.legalside__items{display:flex;flex-direction:column;gap:.6rem}
.legalside__item{border:1px solid var(--line);border-radius:var(--r);
  background:rgba(255,255,255,.02);overflow:hidden;transition:border-color .3s,background .3s}
.legalside__item[open]{border-color:rgba(143,198,240,.28);background:rgba(143,198,240,.04)}
.legalside__item summary{list-style:none;cursor:pointer;padding:.9rem 1rem;
  display:flex;justify-content:space-between;align-items:center;gap:.8rem;
  font-family:var(--display);text-transform:uppercase;font-weight:500;font-size:.96rem;
  letter-spacing:.01em;color:var(--fg)}
.legalside__item summary::-webkit-details-marker{display:none}
.legalside__icx{position:relative;width:14px;height:14px;flex-shrink:0}
.legalside__icx::before,.legalside__icx::after{content:"";position:absolute;background:var(--beam-2);transition:.3s}
.legalside__icx::before{top:6px;left:0;width:14px;height:2px}
.legalside__icx::after{top:0;left:6px;width:2px;height:14px}
.legalside__item[open] .legalside__icx::after{transform:rotate(90deg);opacity:0}
.legalside__a{padding:0 1rem 1rem}
.legalside__a p{color:var(--fg-dim);font-size:.92rem;line-height:1.6}
.legalside__a strong{color:var(--fg)}
.legalside__note{margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--line);
  font-size:.88rem;color:var(--fg-mute)}
.legalside__note strong{color:var(--beam-2)}

/* ============================================================
   DLA KOGO TO JEST
   ============================================================ */
.forwho{padding:3rem 0;background:linear-gradient(180deg,var(--ink),var(--black))}
.forwho__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.forwho__col{border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.9rem;
  background:var(--graphite);transition:border-color .3s,transform .3s}
.forwho__col--yes{border-color:rgba(70,183,85,.25)}
.forwho__col--no{border-color:rgba(224,58,50,.2)}
.forwho__col--yes:hover{transform:translateY(-4px);border-color:rgba(70,183,85,.45)}
.forwho__col--no:hover{transform:translateY(-4px);border-color:rgba(224,58,50,.4)}
.forwho__h{display:flex;align-items:center;gap:.7rem;font-family:var(--display);
  text-transform:uppercase;font-weight:600;font-size:1.3rem;letter-spacing:.01em;
  margin-bottom:1.3rem}
.forwho__ic{flex-shrink:0;width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700}
.forwho__ic--yes{background:rgba(70,183,85,.16);color:#5fd16e;
  box-shadow:0 0 16px -6px #46b755}
.forwho__ic--no{background:rgba(224,58,50,.16);color:#ff7b73;
  box-shadow:0 0 16px -6px #e03a32}
.forwho__list{list-style:none;display:flex;flex-direction:column;gap:.8rem}
.forwho__list li{position:relative;padding-left:1.7rem;color:var(--fg-dim);font-size:.98rem}
.forwho__col--yes .forwho__list li::before{content:"✓";position:absolute;left:0;top:0;
  color:#5fd16e;font-weight:700}
.forwho__col--no .forwho__list li::before{content:"✕";position:absolute;left:0;top:0;
  color:#ff7b73;font-weight:700}
.forwho__hint{margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid var(--line);
  font-size:.92rem;color:var(--fg-mute)}
.forwho__hint a{color:var(--beam-2);text-decoration:underline}

/* ============================================================
   CERTYFIKAT UCZESTNICTWA
   ============================================================ */
.cert{padding:3.25rem 0;background:var(--black)}
.cert__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center}
.cert__text .sec-title{line-height:1.08;margin-bottom:1.2rem}
.cert__lead{color:var(--fg-dim);font-size:1.08rem;margin-bottom:1.6rem}
.cert__lead strong{color:var(--beam-1)}
.cert__pts{list-style:none;display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.9rem}
.cert__pts li{position:relative;padding-left:1.8rem;color:var(--fg-dim)}
.cert__pts li::before{content:"";position:absolute;left:0;top:.5rem;width:9px;height:9px;
  transform:rotate(45deg);background:var(--beam-2);box-shadow:0 0 10px var(--beam-glow)}
/* the visual certificate mock */
.cert__visual{display:flex;justify-content:center}
.cert__paper{position:relative;width:100%;max-width:380px;aspect-ratio:1/1.18;
  background:linear-gradient(160deg,#1a1f25,#12161a);
  border:1px solid rgba(201,162,75,.3);border-radius:6px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;
  padding:2.5rem;text-align:center;overflow:hidden;
  box-shadow:0 34px 80px -36px #000,0 0 60px -30px rgba(201,162,75,.35);
  transform:rotate(-2deg);transition:transform .5s}
.cert__paper::before{content:"";position:absolute;inset:14px;border:1px solid rgba(201,162,75,.25);
  border-radius:4px;pointer-events:none;z-index:3}
/* premium diagonal light sweep across the whole certificate */
.cert__paper::after{content:"";position:absolute;top:-60%;left:-80%;width:60%;height:220%;
  background:linear-gradient(100deg,transparent,rgba(255,245,210,.28),rgba(255,255,255,.12),transparent);
  transform:rotate(18deg);pointer-events:none;z-index:2;
  animation:certSweep 5.5s ease-in-out infinite}
@keyframes certSweep{0%{left:-80%}55%,100%{left:140%}}
.cert:hover .cert__paper{transform:rotate(0deg) scale(1.02)}
.cert__paper>*{position:relative;z-index:4}
/* the gold seal — pulsing premium glow + rotating sheen */
.cert__seal{position:relative;width:74px;height:74px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#f3dd9b,#e6c878 45%,#a9842f);
  display:flex;align-items:center;justify-content:center;margin-bottom:.4rem;
  border:2px solid rgba(255,255,255,.35);
  box-shadow:0 0 26px -6px rgba(201,162,75,.6);
  animation:certSealGlow 3s ease-in-out infinite}
@keyframes certSealGlow{
  0%,100%{box-shadow:0 0 24px -6px rgba(201,162,75,.55),0 0 0 0 rgba(201,162,75,.4)}
  50%{box-shadow:0 0 40px -4px rgba(201,162,75,.85),0 0 0 8px rgba(201,162,75,0)}}
/* rotating conic sheen behind the star */
.cert__seal::before{content:"";position:absolute;inset:-3px;border-radius:50%;z-index:0;
  background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.65),transparent 35%,transparent 65%,rgba(255,255,255,.45),transparent);
  animation:certSealSpin 4s linear infinite;opacity:.8;mix-blend-mode:screen}
@keyframes certSealSpin{to{transform:rotate(360deg)}}
.cert__seal-in{position:relative;z-index:1;font-size:1.9rem;color:#3a2c0c;
  text-shadow:0 1px 1px rgba(255,255,255,.5);
  animation:certStarPulse 3s ease-in-out infinite}
@keyframes certStarPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.cert__paper-k{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.2em;
  font-size:.72rem;color:var(--gold)}
.cert__paper-t{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.35rem;color:var(--fg);line-height:1.15}
.cert__paper-line{width:60px;height:1px;background:rgba(201,162,75,.5)}
.cert__paper-meta{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.16em;
  font-size:.66rem;color:var(--fg-mute)}

/* ============================================================
   VOUCHERY PREZENTOWE
   ============================================================ */
.vouch{position:relative;padding:3.5rem 0;overflow:hidden;
  background:radial-gradient(90% 80% at 50% 0,#11171e,var(--black) 70%)}
.vouch__bg{position:absolute;inset:0;overflow:hidden}
.vouch__beam{position:absolute;top:-15%;left:50%;width:55vw;max-width:640px;height:120%;
  transform:translateX(-50%);
  background:linear-gradient(180deg,rgba(201,162,75,.12),transparent 60%);
  clip-path:polygon(42% 0,58% 0,100% 100%,0 100%);filter:blur(5px)}
.vouch>.wrap{position:relative}
.vouch__occ-wrap{text-align:center;margin-bottom:2.4rem}
.vouch__occ-lab{display:block;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.2em;font-size:.72rem;font-weight:600;color:var(--gold);margin-bottom:1rem}
.vouch__occ{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-bottom:0}
.vouch__chip{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.78rem;font-weight:600;color:var(--fg-dim);
  padding:.55rem 1.1rem;border:1px solid var(--line);border-radius:30px;
  background:rgba(255,255,255,.02);transition:.25s}
.vouch__chip:hover{border-color:rgba(201,162,75,.4);color:var(--gold)}
.vouch__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-bottom:2.6rem}
.vcard{position:relative;background:var(--graphite);border:1px solid var(--line);
  border-radius:var(--r);padding:2rem 1.8rem;overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s}
.vcard:hover{transform:translateY(-6px);border-color:rgba(143,198,240,.3);
  box-shadow:0 22px 50px -28px #000,0 0 30px -18px var(--beam-glow)}
.vcard--feature{border-color:rgba(224,58,50,.3)}
.vcard__tag{display:inline-block;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.14em;font-size:.66rem;font-weight:600;color:var(--fg-dim);
  padding:.35rem .75rem;border:1px solid var(--line);border-radius:30px;margin-bottom:1rem}
.vcard__tag--red{color:var(--red);border-color:rgba(224,58,50,.4);background:rgba(224,58,50,.06)}
.vcard__tag--gold{color:var(--gold);border-color:rgba(201,162,75,.4);background:rgba(201,162,75,.06)}
.vcard__h{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.35rem;letter-spacing:.01em;margin-bottom:.7rem}
.vcard p{color:var(--fg-dim);font-size:.96rem;line-height:1.6}
.vouch__how{max-width:760px;margin:0 auto;text-align:center;
  border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.8rem;
  background:rgba(255,255,255,.02)}
.vouch__how-lab{display:block;font-family:var(--narrow);text-transform:uppercase;
  letter-spacing:.18em;font-size:.72rem;font-weight:600;color:var(--beam-2);margin-bottom:1.4rem}
.vouch__steps{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
  margin-bottom:1.8rem;text-align:left}
.vouch__steps li{display:flex;align-items:flex-start;gap:.7rem;font-size:.94rem;color:var(--fg-dim)}
.vouch__steps li span{flex-shrink:0;width:30px;height:30px;border-radius:50%;
  background:var(--graphite-2);border:1px solid rgba(143,198,240,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:700;font-size:1rem;color:var(--beam-2)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{position:relative;padding:3.25rem 0;overflow:hidden;
  background:radial-gradient(90% 70% at 50% 0,#11171e,var(--black) 65%)}
.contact__bg{position:absolute;inset:0}
.contact__beam{position:absolute;top:-15%;left:50%;width:50vw;max-width:620px;height:120%;
  transform:translateX(-50%);
  background:linear-gradient(180deg,rgba(143,198,240,.16),transparent 60%);
  clip-path:polygon(42% 0,58% 0,100% 100%,0 100%);filter:blur(4px)}
.contact__grid{position:relative;display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;
  align-items:start}
.contact__h{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:clamp(1.9rem,4vw,3rem);line-height:1.04;margin-bottom:1.3rem}
.contact__lead{color:var(--fg-dim);font-size:1.08rem;margin-bottom:2rem}
.contact__pts{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.contact__pts li{padding-left:1.8rem;position:relative;color:var(--fg-dim)}
.contact__pts li::before{content:"";position:absolute;left:0;top:.55rem;width:9px;height:9px;
  transform:rotate(45deg);background:var(--beam-2);box-shadow:0 0 10px var(--beam-glow)}

/* form */
.form{background:var(--graphite);border:1px solid var(--line);border-radius:var(--r);
  padding:2.2rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{margin-bottom:1.1rem;display:flex;flex-direction:column}
.field label{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.12em;
  font-size:.72rem;font-weight:600;color:var(--fg-dim);margin-bottom:.5rem}
.field input,.field select,.field textarea{
  background:var(--black);border:1px solid var(--line);border-radius:var(--r);
  padding:.85rem 1rem;color:var(--fg);font-family:var(--body);font-size:.96rem;
  transition:border-color .25s,box-shadow .25s;width:100%}
.field input::placeholder,.field textarea::placeholder{color:var(--fg-mute)}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--beam-2);box-shadow:0 0 0 3px rgba(143,198,240,.12);outline:none}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238fc6f0' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.field input.err,.field select.err{border-color:var(--red);box-shadow:0 0 0 3px rgba(224,58,50,.12)}
.field textarea{resize:vertical;min-height:90px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}

.chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{position:relative;cursor:pointer}
.chip input{position:absolute;opacity:0;pointer-events:none}
.chip span{display:inline-block;padding:.6rem 1.1rem;border:1px solid var(--line);
  border-radius:30px;font-family:var(--narrow);text-transform:uppercase;letter-spacing:.08em;
  font-size:.78rem;color:var(--fg-dim);transition:.25s}
.chip:hover span{border-color:var(--beam-3);color:var(--fg)}
.chip input:checked+span{background:var(--beam-3);border-color:var(--beam-2);color:#fff;
  box-shadow:0 0 18px -6px var(--beam-glow)}
.chip input:focus-visible+span{outline:2px solid var(--beam-2);outline-offset:2px}

.form__note{font-size:.82rem;color:var(--fg-mute);text-align:center;margin-top:1rem}
.form__note.ok{color:var(--beam-2)}
.form__note.bad{color:var(--red)}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.news{padding:2.75rem 0;background:var(--ink);border-block:1px solid var(--line)}
.news__inner{display:grid;grid-template-columns:1.3fr .7fr;gap:3rem;align-items:center}
.news__h{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.06;margin-bottom:.8rem}
.news__txt p{color:var(--fg-dim);font-size:1rem}
.news__form{display:flex;gap:.7rem}
.news__form input{flex:1;background:var(--black);border:1px solid var(--line);
  border-radius:var(--r);padding:.95rem 1.1rem;color:var(--fg);font-family:var(--body)}
.news__form input:focus{border-color:var(--beam-2);outline:none;
  box-shadow:0 0 0 3px rgba(143,198,240,.12)}
.news__ok{grid-column:1/-1;color:var(--beam-2);font-size:.9rem;min-height:1.2em}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--black);border-top:1px solid var(--line);padding-top:4rem}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem;
  padding-bottom:3rem}
.foot__brand .brand{margin-bottom:1.2rem}
.foot__slo{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.2em;
  font-size:.8rem;color:var(--fg-mute);margin-bottom:.8rem}
.foot__slo em{color:var(--red);font-weight:700}
.foot__small{color:var(--fg-mute);font-size:.9rem;max-width:280px}
.foot__col h4{font-family:var(--display);text-transform:uppercase;font-size:.95rem;
  letter-spacing:.06em;margin-bottom:1.1rem;color:var(--fg)}
.foot__col a{display:block;color:var(--fg-dim);font-size:.92rem;padding:.32rem 0;
  transition:color .2s}
.foot__col a:hover{color:var(--beam-2)}
.foot__soon{display:block;color:var(--fg-mute);font-size:.92rem;padding:.32rem 0;font-style:italic}
.foot__contact .btn{margin-top:1rem;white-space:nowrap;align-self:flex-start;display:inline-flex}
/* footer CTA must keep white text — beats the generic .foot__col a colour */
.foot__col a.foot__btn{color:#fff;padding:.7rem 1.35rem}
.foot__col a.foot__btn:hover{color:#fff}
.foot__bar{border-top:1px solid var(--line);padding:1.6rem 28px;
  max-width:var(--wrap);margin:0 auto;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:.8rem;font-size:.82rem;color:var(--fg-mute)}
.foot__bar-r{color:var(--fg-mute)}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(24px);
  animation:reveal .8s cubic-bezier(.2,.7,.2,1) forwards;animation-delay:var(--d,0s)}
@keyframes reveal{to{opacity:1;transform:none}}

.io{opacity:0;transform:translateY(34px);transition:opacity .8s,transform .8s}
.io.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .nav__links{display:none}
  .nav .btn--nav{display:none}
  .nav__burger{display:flex}
  .intro__grid,.org__grid,.contact__grid,.faq__grid,.news__inner,.cert__grid{grid-template-columns:1fr;gap:2.4rem}
  .faq__head{position:static}
  .faq__head .sec-title{text-align:center}
  .offer__grid{grid-template-columns:repeat(2,1fr)}
  .para__cols{grid-template-columns:1fr}
  .gal__grid{grid-template-columns:repeat(2,1fr)}
  .foot__grid{grid-template-columns:1fr 1fr}
  .terms__grid{grid-template-columns:repeat(2,1fr)}
  .vouch__grid{grid-template-columns:1fr}
  .cert__visual{order:-1}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  .intro,.offer,.terms,.proc,.places,.org,.forwho,.para,.gal,.map,.faq,.contact,.news,.revs,.cert,.vouch{padding:2.25rem 0}
  .offer__grid,.places__grid,.org__facts{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .strip__div{display:none}
  .strip__inner{gap:1.6rem 2.4rem}
  .gal__grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .gal__item--wide{grid-column:span 2}
  .foot__grid{grid-template-columns:1fr}
  .news__form{flex-direction:column}
  .hero__slogan{letter-spacing:.24em;font-size:.74rem}
  .form{padding:1.5rem}
  .map__wrap{padding:1.3rem}
  .sec-head{text-align:left}
  .sec-head .eyebrow::after{display:none}
  .terms__grid{grid-template-columns:1fr}
  .forwho__grid{grid-template-columns:1fr}
  .vouch__steps{grid-template-columns:1fr}
  .org__facts{grid-template-columns:1fr 1fr}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,.io{opacity:1;transform:none}
  .beam{animation:none}
}

/* ============================================================
   PROMO POPUP — 50 zł zniżki
   ============================================================ */
.promo{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:24px}
.promo[hidden]{display:none}
.promo__overlay{position:absolute;inset:0;background:rgba(4,5,6,.82);
  backdrop-filter:blur(6px);animation:promoFade .4s ease}
@keyframes promoFade{from{opacity:0}to{opacity:1}}
.promo__box{position:relative;width:100%;max-width:440px;background:var(--graphite);
  border:1px solid rgba(224,58,50,.35);border-radius:10px;padding:2.6rem 2rem 2rem;
  text-align:center;overflow:hidden;
  box-shadow:0 40px 90px -30px #000,0 0 60px -20px rgba(224,58,50,.4);
  animation:promoPop .5s cubic-bezier(.2,.8,.2,1)}
@keyframes promoPop{from{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:none}}
.promo__beam{position:absolute;top:-30%;left:50%;width:60%;height:80%;transform:translateX(-50%);
  background:linear-gradient(180deg,rgba(224,58,50,.22),transparent 70%);
  clip-path:polygon(40% 0,60% 0,100% 100%,0 100%);filter:blur(6px);pointer-events:none}
.promo__close{position:absolute;top:12px;right:14px;background:none;border:0;color:var(--fg-mute);
  font-size:1.1rem;cursor:pointer;z-index:2;transition:color .2s;line-height:1;padding:4px}
.promo__close:hover{color:var(--fg)}
.promo__badge{position:relative;display:inline-block;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.22em;font-size:.66rem;font-weight:600;color:var(--red);
  padding:.4rem .9rem;border:1px solid rgba(224,58,50,.4);border-radius:30px;
  background:rgba(224,58,50,.07);margin-bottom:1.2rem}
.promo__amount{position:relative;font-family:var(--display);font-weight:700;line-height:1;
  font-size:1.6rem;color:var(--fg-dim);margin-bottom:.6rem}
.promo__amount span{font-size:4rem;color:#fff;
  background:linear-gradient(180deg,#fff,#ef9a96);-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:0 0 40px rgba(224,58,50,.5)}
.promo__h{position:relative;font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.6rem;letter-spacing:-.01em;margin-bottom:.7rem}
.promo__desc{position:relative;color:var(--fg-dim);font-size:.98rem;margin-bottom:1.4rem}
.promo__desc strong{color:var(--beam-1)}
.promo__timer{position:relative;display:flex;flex-direction:column;align-items:center;gap:.2rem;
  margin-bottom:1.4rem}
.promo__time{font-family:var(--display);font-weight:700;font-size:2.4rem;color:var(--red);
  letter-spacing:.04em;font-variant-numeric:tabular-nums}
.promo__time-lab{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.16em;
  font-size:.66rem;color:var(--fg-mute)}
.promo__skip{display:block;width:100%;margin-top:.9rem;background:none;border:0;
  color:var(--fg-mute);font-family:var(--narrow);text-transform:uppercase;letter-spacing:.1em;
  font-size:.76rem;cursor:pointer;transition:color .2s;padding:.4rem}
.promo__skip:hover{color:var(--fg-dim)}
.promo--expired .promo__time{color:var(--fg-mute)}
@media(max-width:480px){
  .promo__box{padding:2.2rem 1.4rem 1.6rem}
  .promo__amount span{font-size:3.2rem}
}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie{position:fixed;left:0;right:0;bottom:0;z-index:180;padding:0 16px 16px}
.cookie[hidden]{display:none}
.cookie__inner{max-width:1000px;margin:0 auto;background:rgba(15,18,21,.97);
  backdrop-filter:blur(12px);border:1px solid rgba(143,198,240,.2);border-radius:10px;
  padding:1.2rem 1.4rem;display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;
  box-shadow:0 24px 60px -24px #000;animation:cookieUp .5s cubic-bezier(.2,.8,.2,1)}
@keyframes cookieUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.cookie__text{flex:1;min-width:260px}
.cookie__text strong{display:block;font-family:var(--display);text-transform:uppercase;
  letter-spacing:.02em;font-size:1rem;margin-bottom:.3rem}
.cookie__text p{color:var(--fg-dim);font-size:.88rem;margin:0}
.cookie__text a{color:var(--beam-2);text-decoration:underline}
.cookie__actions{display:flex;gap:.7rem;flex-wrap:wrap}
@media(max-width:560px){
  .cookie__actions{width:100%}
  .cookie__actions .btn{flex:1;justify-content:center}
}

/* ============================================================
   LEGAL PAGES (privacy / terms)
   ============================================================ */
.legal{padding:7rem 0 4rem;min-height:70vh}
.legal__wrap{max-width:780px}
.legal__title{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:clamp(2rem,5vw,3rem);line-height:1.05;margin:.6rem 0 .4rem}
.legal__updated{color:var(--fg-mute);font-size:.85rem;font-family:var(--narrow);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.8rem}
.legal__note{background:rgba(224,58,50,.07);border:1px solid rgba(224,58,50,.25);
  border-radius:var(--r);padding:1.1rem 1.3rem;color:var(--fg-dim);font-size:.92rem;
  margin-bottom:2.4rem}
.legal__note strong{color:var(--red)}
.legal section{margin-bottom:1.8rem}
.legal h2{font-family:var(--display);text-transform:uppercase;font-weight:500;
  font-size:1.25rem;letter-spacing:.01em;margin-bottom:.6rem;color:var(--beam-1)}
.legal p{color:var(--fg-dim);font-size:1rem;line-height:1.65}
.legal a{color:var(--beam-2)}
.legal strong{color:var(--fg)}
.legal__back{margin-top:2.5rem}

/* ════════════════════════════════════════════════════════════
   ███  MOBILE EXPERIENCE  ███
   Dedykowany, dopracowany wariant mobilny (mobile-first premium).
   Desktop pozostaje bez zmian — te reguły działają tylko ≤768px.
   ════════════════════════════════════════════════════════════ */

/* ---- zapobiegaj poziomemu przewijaniu na całej stronie ---- */
html,body{max-width:100%;overflow-x:hidden}
*{-webkit-tap-highlight-color:transparent}

@media(max-width:768px){
  :root{--wrap:100%}

  /* === PŁYNNE PRZEWIJANIE + bezpieczne marginesy === */
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{font-size:16px}
  .wrap{padding:0 18px}

  /* === NAV (mobilny pasek) === */
  .nav__inner{padding:.7rem 18px;gap:.8rem}
  .nav__links{display:none}
  .nav .btn--nav{display:none}
  .nav__burger{display:flex;margin-left:auto;z-index:120;position:relative}
  .brand__mark{width:38px;height:38px}
  .brand__text{font-size:1.18rem}
  /* pasek zawsze z tłem na mobile (czytelność na zdjęciu hero) */
  .nav{background:rgba(8,9,10,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}

  /* === PEŁNOEKRANOWE MENU (Netflix-style) === */
  .nav__mobile{display:flex;flex-direction:column;justify-content:space-between;
    position:fixed;inset:0;z-index:110;padding:5.2rem 1.6rem 1.8rem;
    background:linear-gradient(180deg,rgba(10,13,16,.99),rgba(6,8,10,.99));
    backdrop-filter:blur(8px);
    opacity:0;visibility:hidden;transform:translateY(-12px);
    transition:opacity .35s ease,transform .4s cubic-bezier(.2,.8,.2,1),visibility .35s;
    overflow-y:auto;-webkit-overflow-scrolling:touch;height:100dvh;gap:1rem}
  .nav__mobile.open{opacity:1;visibility:visible;transform:none}
  .nav__mobile-inner{display:flex;flex-direction:column;gap:.1rem}
  .nav__mobile-lab{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.24em;
    font-size:.62rem;font-weight:600;color:var(--beam-2);margin-bottom:.8rem;opacity:.8}
  .nav__mobile a{display:flex;align-items:baseline;gap:.9rem;
    font-family:var(--display);text-transform:uppercase;letter-spacing:.01em;font-weight:500;
    font-size:1.5rem;color:var(--fg);padding:.62rem 0;border-bottom:1px solid rgba(255,255,255,.06);
    text-decoration:none;
    opacity:0;transform:translateX(-14px);transition:color .2s}
  .nav__mobile.open a{opacity:1;transform:none;
    transition:opacity .4s ease,transform .4s cubic-bezier(.2,.8,.2,1)}
  /* schodkowe wejście pozycji menu */
  .nav__mobile.open .nav__mobile-inner a:nth-child(2){transition-delay:.06s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(3){transition-delay:.10s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(4){transition-delay:.14s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(5){transition-delay:.18s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(6){transition-delay:.22s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(7){transition-delay:.26s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(8){transition-delay:.30s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(9){transition-delay:.34s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(10){transition-delay:.38s}
  .nav__mobile.open .nav__mobile-inner a:nth-child(11){transition-delay:.42s}
  .nav__mobile a:active{color:var(--beam-1)}
  .nav__mobile-no{font-family:var(--narrow);font-size:.72rem;font-weight:600;
    color:var(--beam-3);letter-spacing:.05em;min-width:1.6rem}
  .nav__mobile-foot{display:flex;flex-direction:column;gap:.9rem;align-items:center;
    padding-top:1rem}
  .nav__mobile-foot .btn{width:100%;justify-content:center;font-size:1rem;padding:1.05rem 1.5rem}
  .nav__mobile-tag{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.18em;
    font-size:.62rem;color:var(--fg-mute)}
  /* blokada scrolla tła, gdy menu otwarte */
  body.nav-open{overflow:hidden}

  /* === HERO pełnoekranowy === */
  .hero{min-height:100svh;min-height:100dvh;padding:5.5rem 0 4rem;
    display:flex;align-items:center}
  .hero__content{padding:0 18px;width:100%}
  .hero__slogan{font-size:.66rem;letter-spacing:.18em;margin-bottom:1rem}
  .hero__title{font-size:clamp(2.4rem,11vw,3.4rem);line-height:1.02;margin-bottom:1.1rem}
  .hero__lead{font-size:1.02rem;line-height:1.55;max-width:100%;margin-bottom:1.8rem}
  .hero__eyebrow{font-size:.72rem}
  /* CTA: pełna szerokość, duże, łatwe do kliknięcia */
  .hero__cta{flex-direction:column;gap:.8rem;width:100%}
  .hero__cta .btn{width:100%;justify-content:center;font-size:1rem;padding:1.15rem 1.5rem}
  .hero__cta .btn--ghost{padding:1.05rem 1.5rem}
  /* ukryj wskaźnik przewijania na małych ekranach (kolidował z CTA) */
  .hero__scroll{display:none}

  /* === TYPOGRAFIA SEKCJI === */
  .sec-title{font-size:clamp(1.8rem,7vw,2.4rem);line-height:1.08}
  .sec-sub{font-size:.98rem;line-height:1.55}
  .sec-head{margin-bottom:2rem}
  .eyebrow{font-size:.68rem}

  /* === ODSTĘPY MIĘDZY SEKCJAMI (oddech) === */
  .intro,.offer,.terms,.proc,.places,.org,.forwho,.para,.gal,.map,.faq,.contact,.news,.revs,.cert,.vouch{
    padding:3.2rem 0}

  /* === TRUST STRIP (statystyki) — siatka 2x2 === */
  .strip__inner{flex-wrap:wrap;justify-content:center;gap:1.6rem 1.2rem;padding:1.8rem 18px}
  .strip__div{display:none}
  .stat{flex:0 0 calc(50% - 1.2rem);text-align:center;align-items:center}
  .stat__num{font-size:2rem}
  .stat__lab{font-size:.74rem}

  /* === WSZYSTKIE SIATKI → 1 kolumna === */
  .offer__grid,.places__grid,.org__grid,.org__facts,.forwho__grid,.contact__grid,
  .faq__grid,.cert__grid,.news__inner,.para__cols,.intro__grid,.terms__grid,
  .vouch__grid,.vouch__steps{grid-template-columns:1fr!important}

  /* === KARTY WYPRAW === */
  .card{padding:1.6rem 1.4rem}
  .card__title{font-size:1.4rem}
  .card--feature{transform:none}
  .card__cta{font-size:.92rem}

  /* === GALERIA — czytelny układ kafelków === */
  .gal__grid{grid-template-columns:1fr 1fr;grid-auto-rows:140px;gap:.6rem}
  .gal__item--wide{grid-column:span 2}
  .gal__item--tall{grid-row:span 1}

  /* === FORMULARZ === */
  .form{padding:1.5rem 1.3rem}
  .form__row{grid-template-columns:1fr;gap:1rem}
  .field input,.field textarea,.picker-trigger{font-size:16px;padding:.95rem 1rem} /* 16px = brak zoomu iOS */
  .chip{font-size:.82rem}

  /* === MAPA ZASIĘG === */
  .map__wrap{padding:1.1rem}
  .map__poland{height:380px}
  .map__legend{flex-direction:column;align-items:flex-start;gap:.8rem;font-size:.72rem}
  .map__note{max-width:100%;line-height:1.55}
  .map-label{font-size:15px} /* większe podpisy miast */

  /* === OPINIE (karuzela) — 1 na ekran === */
  .revs__arrow{display:none}
  .rev{padding:1.6rem 1.4rem}
  .rev__q{font-size:1rem}

  /* === PROCES „Jak to działa" — 1 kolumna, opisy w pełni widoczne === */
  .proc__grid{grid-template-columns:1fr!important;gap:2.4rem}
  .proc__visual{position:static!important;top:auto}
  .proc__portal{max-width:300px;margin:0 auto}
  /* linia czasu i kropki wyrównane do lewej, opisy obok mają pełną szerokość */
  .proc__steps::before{left:26px}
  .proc__steps::after{left:25px}
  .proc__step{padding:.9rem .4rem;gap:1rem;align-items:flex-start}
  .proc__n{width:42px;height:42px;font-size:1.1rem}
  .proc__step h3{font-size:1.12rem;padding-top:.4rem}
  .proc__step p{font-size:.94rem}
  /* upewnij się, że tekst kroku nie jest ściskany */
  .proc__step>div{flex:1;min-width:0}

  /* === CERTYFIKAT === */
  .cert__visual{order:-1}
  .cert__paper{max-width:300px}

  /* === VOUCHERY === */
  .vouch__occ{gap:.5rem}
  .vouch__chip{font-size:.72rem;padding:.5rem .9rem}
  .vcard{padding:1.6rem 1.4rem}

  /* === ORGANIZATOR — poprawiony układ mobilny === */
  .org__photo{max-width:320px;margin:0 auto;width:100%}
  .org__frame{aspect-ratio:4/5}
  /* tabliczka z imieniem: wyśrodkowana pod zdjęciem, bez ujemnych offsetów */
  .org__name{position:relative;bottom:auto;right:auto;left:50%;transform:translateX(-50%);
    margin-top:-14px;display:inline-block;text-align:center;white-space:nowrap}
  .org__name-main{font-size:1rem}
  .org__hook{font-size:1.1rem!important}
  .org__text{text-align:left}
  .org__text p{font-size:1rem}
  /* fakty organizatora: 1 kolumna dla czytelności */
  .org__facts{grid-template-columns:1fr!important;margin:1.4rem 0}
  .org__facts li{padding:.6rem 0}

  /* === STOPKA === */
  .foot__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .foot__brand{grid-column:1/-1}
  .foot__bar{flex-direction:column;text-align:center;gap:.6rem}

  /* === MODALE (pełna szerokość, wygodne) === */
  .wdetail__box,.citymodal__box,.seat__box,.picker__box{max-width:100%;max-height:92dvh}
  .wdetail__box{grid-template-columns:1fr}
  .picker__box{padding:1.6rem 1.2rem}
  /* przyciski zamykania większe (łatwiej trafić palcem) */
  .wdetail__close,.citymodal__close,.seat__close,.picker__close{width:40px;height:40px;
    display:flex;align-items:center;justify-content:center;font-size:1.2rem}

  /* === LEGAL SIDE PANEL — pełna szerokość na mobile === */
  .legalside__panel{width:100%}
  .legalside.is-open .legalside__tab{opacity:0;pointer-events:none}

  /* === COOKIE / PROMO === */
  .cookie__inner{flex-direction:column;align-items:stretch;text-align:center}
  .cookie__actions{width:100%}
  .cookie__actions .btn{flex:1;justify-content:center}

  /* === przyciski globalnie większe (touch target ≥ 48px) === */
  .btn{min-height:48px;display:inline-flex;align-items:center}
  .btn--lg{padding:1.05rem 1.6rem}

  /* === MOBILNY PASEK CTA (app-like, pojawia się przy scrollu) === */
  .mcta{position:fixed;left:0;right:0;bottom:0;z-index:95;
    display:flex;align-items:center;gap:1rem;
    padding:.7rem 16px calc(.7rem + env(safe-area-inset-bottom,0));
    background:linear-gradient(180deg,rgba(12,15,18,.92),rgba(8,10,12,.98));
    backdrop-filter:blur(14px);border-top:1px solid rgba(143,198,240,.18);
    transform:translateY(120%);transition:transform .4s cubic-bezier(.2,.8,.2,1);
    box-shadow:0 -12px 40px -16px rgba(0,0,0,.7)}
  .mcta.show{transform:translateY(0)}
  .mcta__txt{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}
  .mcta__lab{font-family:var(--display);text-transform:uppercase;font-weight:600;
    font-size:.94rem;letter-spacing:.01em;color:var(--fg);line-height:1.1}
  .mcta__sub{font-family:var(--narrow);text-transform:uppercase;letter-spacing:.08em;
    font-size:.64rem;color:var(--beam-2)}
  .mcta__btn{flex-shrink:0;padding:.85rem 1.4rem;font-size:.92rem;min-height:46px}
  /* gdy menu otwarte, chowaj pasek */
  body.nav-open .mcta{transform:translateY(120%)}
}

/* pasek CTA tylko na mobile — na desktopie nigdy */
@media(min-width:769px){ .mcta{display:none!important} }

/* === bardzo małe ekrany (≤380px, np. iPhone SE/mini) === */
@media(max-width:380px){
  .wrap{padding:0 14px}
  .hero__title{font-size:2.1rem}
  .sec-title{font-size:1.6rem}
  .stat{flex:0 0 calc(50% - .8rem)}
  .gal__grid{grid-template-columns:1fr 1fr;grid-auto-rows:120px}
  .org__facts{grid-template-columns:1fr!important}
  .nav__mobile a{font-size:1.32rem}
}

/* === ograniczenie ciężkich animacji na telefonach (wydajność/CWV) === */
@media(max-width:768px){
  /* wyłącz drogie, ciągłe efekty tła na mobile */
  .hero__dust{display:none}
  .proc__portal-dust{display:none}
  .map-pulse{animation-duration:4.5s} /* wolniej = mniej pracy GPU */
  /* ogranicz blur (kosztowny na mobile) */
  .hero__photo{filter:none}
  /* płynne wejścia przy scrollu zostają (lekkie transformy) */
}
