/* ============================================================
   SOLIGRAF — landing styles
   ============================================================ */
:root{
  --bg:        #07080c;
  --bg-soft:   #0b0d14;
  --panel:     #0e1119;
  --gold:      #c8a84b;
  --gold-lt:   #e2c97e;
  --gold-deep: #a9863a;
  --gold-dim:  #8a7035;
  --cream:     #d8d0b8;
  --cream-dim: rgba(216,208,184,.58);
  --cream-faint: rgba(216,208,184,.34);
  --blue:      #5b8fc7;
  --line:      rgba(200,168,75,.16);
  --line-soft: rgba(216,208,184,.10);
  --border:    rgba(200,168,75,.15);
  --border-strong: rgba(200,168,75,.35);
  --text-muted:#8a8070;
  --text-faint:#4a4438;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', system-ui, sans-serif;
  --maxw: 1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--cream);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:italic}
section{position:relative}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:400;
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1.4rem;
}
.section-label{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:1rem;
}
.section-title{
  font-family:var(--serif);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:300;
  color:var(--gold-lt);
  line-height:1.15;
  margin-bottom:1.5rem;
}
.section-title em{color:var(--gold-lt)}
.section-body{
  font-size:.95rem;
  line-height:1.9;
  color:var(--text-muted);
  max-width:560px;
}
.section-body em{
  color:var(--cream);font-style:normal;
  border-bottom:1px solid var(--gold-deep);padding-bottom:1px;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-weight:400;
  font-size:.84rem;letter-spacing:.22em;text-transform:uppercase;
  padding:1.05em 1.9em;
  border:1px solid var(--gold);
  color:var(--gold-lt);
  background:linear-gradient(180deg, rgba(200,168,75,.06), rgba(200,168,75,0));
  position:relative;cursor:pointer;
  transition:color .4s, border-color .4s, box-shadow .5s, background .4s;
  border-radius:999px;
}
.btn .btn__arr{transition:transform .4s}
.btn--gold{
  box-shadow:0 0 18px 2px rgba(200,168,75,.25), 0 0 50px 0 rgba(200,168,75,.10);
}
.btn--gold:hover{
  color:var(--bg);
  background:linear-gradient(180deg,var(--gold-lt),var(--gold));
  border-color:var(--gold-lt);
  box-shadow:0 0 28px 4px rgba(200,168,75,.45), 0 0 70px 0 rgba(200,168,75,.18);
}
.btn--gold:hover .btn__arr{transform:translateX(5px)}
.btn--lg{font-size:.92rem;padding:1.25em 2.4em}
.btn--ghost{
  border-color:var(--border-strong);
  color:var(--text-muted);
  background:rgba(200,168,75,.03);
  box-shadow:none;
}
.btn--ghost:hover{
  border-color:rgba(200,168,75,.6);
  color:var(--gold);
  background:rgba(200,168,75,.07);
  box-shadow:0 0 14px 1px rgba(200,168,75,.15);
}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem clamp(1.2rem,4vw,3rem);
  transition:background .5s, border-color .5s, padding .5s, backdrop-filter .5s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(7,8,12,.78);
  backdrop-filter:blur(14px) saturate(120%);
  border-bottom-color:var(--line);
  padding-top:1rem;padding-bottom:1rem;
}
.nav__brand{display:flex;align-items:center;gap:.85rem}
.nav__logo{width:44px;height:44px;filter:drop-shadow(0 2px 12px rgba(200,168,75,.3))}
.nav__wordmark{display:flex;flex-direction:column;line-height:1}
.nav__name{
  font-family:var(--serif);font-weight:400;
  font-size:1.15rem;letter-spacing:.38em;color:var(--gold-lt);
}
.nav__tag{
  font-family:'Montserrat',sans-serif;font-weight:300;
  font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--text-muted);margin-top:.3rem;
}
.nav__links{display:flex;align-items:center;gap:clamp(1.2rem,2.5vw,2.4rem)}
.nav__links a{
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cream-dim);position:relative;padding:.4rem 0;
  transition:color .35s;
}
.nav__links a:not(.nav__cta)::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--gold);transition:width .4s;
}
.nav__links a:hover{color:var(--cream)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{
  border:1px solid var(--line);padding:.7rem 1.25rem !important;
  color:var(--gold-lt)!important;border-radius:999px;
  transition:border-color .4s, background .4s !important;
}
.nav__cta:hover{border-color:var(--gold);background:rgba(200,168,75,.07)}

/* ============================================================
   LANG TOGGLE
   ============================================================ */
.lang-toggle{
  display:flex;align-items:center;gap:.3em;
  font-family:var(--sans);font-size:.72rem;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;
  background:none;border:1px solid var(--line);
  color:var(--cream-dim);padding:.45rem .75rem;
  cursor:pointer;border-radius:999px;
  transition:border-color .35s, background .35s;
  white-space:nowrap;
}
.lang-toggle:hover{border-color:var(--gold);background:rgba(200,168,75,.06)}
.lang-toggle__sep{color:var(--line);margin:0 .1em}
.lang-toggle__pl,
.lang-toggle__en{transition:color .3s}
.lang-toggle__pl.is-active,
.lang-toggle__en.is-active{color:var(--gold-lt)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100svh;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  padding:6rem 1.5rem 0;
  background:var(--bg);
  position:relative;overflow:hidden;
}
.hero__dust{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:0;
}
.hero__inner{
  position:relative;z-index:1;max-width:820px;width:100%;
  display:flex;flex-direction:column;align-items:center;
  flex:1;
}
.hero__top{
  display:flex;flex-direction:column;align-items:center;
  flex:1;justify-content:center;
}
.hero__bottom{
  display:flex;flex-direction:column;align-items:center;
  padding-bottom:6rem;
}
.hero__logo-wrap{
  position:relative;
  width:clamp(200px,24vw,320px);
  margin:0 auto .5rem;
  animation:floaty 9s ease-in-out infinite;
}
.hero__logo{
  width:100%;height:auto;display:block;
  filter:drop-shadow(0 6px 30px rgba(200,168,75,.4));
}
/* glow dot — pozycja dopasowana do kółka w logo2.png */
.hero__logo-glow{
  position:absolute;
  left:87%;top:52%;
  width:14px;height:14px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle, rgba(226,201,126,.9) 0%, rgba(200,168,75,.4) 40%, transparent 70%);
  animation:logoGlow 2.8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes logoGlow{
  0%,100%{ opacity:.55; transform:translate(-50%,-50%) scale(1);   box-shadow:0 0 8px 4px rgba(200,168,75,.25); }
  50%    { opacity:1;   transform:translate(-50%,-50%) scale(1.55); box-shadow:0 0 18px 8px rgba(200,168,75,.45); }
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.hero__brand-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(2.8rem,8vw,6.4rem);
  line-height:1;letter-spacing:.22em;
  color:var(--gold-lt);
  text-shadow:0 0 38px rgba(200,168,75,.32);
  margin-bottom:0;
  animation:fadeUp 1s .6s both;
}
.hero__divider{
  width:140px;height:1px;
  margin:.9rem auto;
  background:rgba(212,177,96,.55);
  animation:fadeUp 1s .7s both;
}
.hero__brand-sub{
  font-family:'Montserrat', sans-serif;font-weight:300;
  font-size:clamp(.75rem,1.4vw,.95rem);
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:1.8rem;
  animation:fadeUp 1s .8s both;
}
.hero__desc{
  font-size:clamp(.9rem,1.5vw,1rem);
  font-weight:300;line-height:1.9;
  color:var(--text-muted);
  max-width:560px;margin:0 auto 2.6rem;
  animation:fadeUp 1s 1s both;
}
.hero__actions{
  display:flex;align-items:center;justify-content:center;
  gap:1.2rem;flex-wrap:wrap;
  animation:fadeUp 1s 1.2s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.hero__scroll{
  position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  z-index:3;width:24px;height:40px;border:1px solid var(--line);border-radius:14px;
  display:flex;justify-content:center;padding-top:7px;
}
.hero__scroll span{width:3px;height:8px;border-radius:2px;background:var(--gold);animation:scrolly 1.8s ease-in-out infinite}
@keyframes scrolly{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(10px)}}

/* ============================================================
   SECTION DIVIDER
   ============================================================ */
.sec-divider{
  display:flex;align-items:center;gap:1.5rem;
  padding:0 clamp(1.2rem,4vw,3rem);
  max-width:var(--maxw);margin:0 auto;
}
.sec-divider__line{flex:1;height:1px;background:var(--border)}
.sec-divider__mark{color:var(--gold-dim);font-size:.9rem;opacity:.7}

/* ============================================================
   CO TO JEST (WHAT-IS)
   ============================================================ */
.czym{padding:clamp(5rem,11vw,9rem) clamp(1.2rem,4vw,3rem);max-width:var(--maxw);margin:0 auto}
.czym__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,6vw,5rem);align-items:center;
}
.czym__illo{position:relative}
.screen-frame{
  border:1px solid var(--border-strong);
  overflow:hidden;position:relative;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9), 0 0 0 1px rgba(0,0,0,.4);
  transition:border-color .5s, box-shadow .6s;
}
.screen-frame:hover{
  border-color:rgba(200,168,75,.5);
  box-shadow:0 50px 120px -50px rgba(200,168,75,.18), 0 40px 90px -50px rgba(0,0,0,.9);
}
.screen-frame::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom, transparent 60%, var(--bg) 100%);
  pointer-events:none;
}

/* scrub widget */
.czym__scrub{margin-top:1.4rem;border-top:1px solid var(--line);padding-top:1.4rem}
.scrub__head{display:flex;align-items:baseline;gap:.9rem;margin-bottom:1rem}
.scrub__date{font-family:var(--serif);font-size:1.5rem;color:var(--gold-lt)}
.scrub__alt{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-faint)}
.scrub__slider{
  -webkit-appearance:none;appearance:none;width:100%;height:1px;
  background:linear-gradient(90deg,var(--gold),var(--blue));outline:none;cursor:pointer;
}
.scrub__slider::-webkit-slider-thumb{
  -webkit-appearance:none;width:16px;height:16px;border-radius:50%;
  background:var(--gold-lt);border:1px solid var(--bg);
  box-shadow:0 0 0 4px rgba(200,168,75,.18), 0 0 16px rgba(200,168,75,.7);cursor:grab;
}
.scrub__slider::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;background:var(--gold-lt);border:1px solid var(--bg);
  box-shadow:0 0 0 4px rgba(200,168,75,.18);cursor:grab;
}
.scrub__labels{display:flex;justify-content:space-between;margin-top:.7rem;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-faint)}

/* ============================================================
   FEATURES — numbered 3×2 grid
   ============================================================ */
.features{padding:clamp(4rem,9vw,7rem) clamp(1.2rem,4vw,3rem) clamp(3rem,6vw,5rem)}
.features .sec__head{max-width:var(--maxw);margin:0 auto clamp(2.5rem,5vw,4rem);text-align:center}
.features .sec__head .section-label{margin-bottom:1rem}
.features__grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:var(--line);border:1px solid var(--line);
}
.feature-card{
  background:var(--bg);
  padding:clamp(2rem,3.2vw,2.8rem) clamp(1.6rem,2.4vw,2.2rem);
  position:relative;overflow:hidden;
  transition:background .4s;
}
.feature-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:0;transition:opacity .4s;
}
.feature-card:hover::before{opacity:1}
.feature-card:hover{background:rgba(200,168,75,.04)}
.feature-num{
  font-family:var(--serif);font-size:2.4rem;font-weight:300;
  color:var(--text-faint);line-height:1;margin-bottom:1.4rem;
}
.feature-title{
  font-family:var(--serif);font-size:1.3rem;font-weight:400;
  color:var(--gold);margin-bottom:.75rem;letter-spacing:.03em;
}
.feature-body{
  font-size:.88rem;line-height:1.8;
  color:var(--text-muted);font-weight:300;
}

/* analemma glow animation */
@keyframes ana8glow {
  0%   { stroke-dasharray: 20 180; stroke-dashoffset: 0;    stroke: rgba(200,184,122,.95); }
  100% { stroke-dasharray: 20 180; stroke-dashoffset: -200; stroke: rgba(200,184,122,.95); }
}
.ana-glow-path { animation: ana8glow 5s ease-in-out infinite; }

/* feat articles inside features__grid */
.feat{
  background:var(--bg);padding:clamp(2.2rem,3.4vw,3rem) clamp(1.8rem,2.6vw,2.4rem);
  transition:background .5s;
}
.feat:hover{background:linear-gradient(180deg, rgba(200,168,75,.05), transparent)}
.feat__ico{width:100%;margin-bottom:1.4rem}
.feat__ico--anim{width:100%;max-width:90px;opacity:.75}
.feat__ico svg{width:100%;height:100%;fill:none;stroke:var(--gold);stroke-width:1.4;
  stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 10px rgba(200,168,75,.25));transition:stroke .4s}
.feat:hover .feat__ico svg{stroke:var(--gold-lt)}
.feat__title{font-family:var(--serif);font-weight:500;font-size:1.7rem;color:var(--cream);margin-bottom:.9rem}
.feat__body{font-size:.98rem;color:var(--cream-dim);max-width:32ch}

/* ============================================================
   GALLERY (shots)
   ============================================================ */
.gallery{padding:clamp(4rem,9vw,7rem) clamp(1.2rem,4vw,3rem) clamp(5rem,10vw,8rem);max-width:var(--maxw);margin:0 auto}
.shot__frame{
  border:1px solid var(--line);background:var(--panel);
  overflow:hidden;position:relative;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9), 0 0 0 1px rgba(0,0,0,.4);
  transition:border-color .5s, box-shadow .6s;
}
.shot__frame:hover{border-color:rgba(200,168,75,.35);box-shadow:0 50px 120px -50px rgba(200,168,75,.18), 0 40px 90px -50px rgba(0,0,0,.9)}
.shot__bar{
  display:flex;align-items:center;gap:.5rem;
  padding:.75rem 1rem;border-bottom:1px solid var(--line-soft);
  background:rgba(255,255,255,.012);
}
.shot__bar span{width:9px;height:9px;border-radius:50%;background:rgba(216,208,184,.18)}
.shot__bar span:first-child{background:rgba(200,168,75,.5)}
.shot__bar em{margin-left:auto;font-family:var(--sans);font-style:normal;
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-faint)}
.shot__frame img{width:100%;height:auto;display:block}
.shot__cap{display:flex;gap:1.2rem;margin-top:1.6rem;align-items:flex-start}
.shot__num{font-family:var(--serif);font-size:1.5rem;color:var(--gold);line-height:1;min-width:2rem}
.shot__cap h3{font-family:var(--serif);font-weight:500;font-size:1.4rem;color:var(--cream);margin-bottom:.35rem}
.shot__cap p{font-size:.94rem;color:var(--cream-dim);max-width:46ch}
.shot--wide{margin-bottom:clamp(3rem,6vw,5rem)}

/* slideshow */
.shot__slides{position:relative;overflow:hidden}
.shot__slide{
  width:100%;display:block;
  transition:opacity .65s ease;
}
.shot__slide.is-active{
  position:static;opacity:1;
}
.shot__slide:not(.is-active){
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  opacity:0;object-fit:cover;
}

/* dots — inside shot__bar */
.shot__dots{
  display:flex;align-items:center;gap:.4rem;
}
.shot__dot{
  width:8px;height:8px;border-radius:50%;
  border:1px solid rgba(200,168,75,.55);
  background:rgba(200,168,75,.18);
  padding:0;cursor:pointer;
  transition:background .3s, border-color .3s, transform .25s;
}
.shot__dot.is-active{
  background:var(--gold);
  border-color:var(--gold-lt);
  transform:scale(1.25);
  box-shadow:0 0 5px rgba(200,168,75,.5);
}
.shot__dot:hover:not(.is-active){background:rgba(200,168,75,.35)}
.shot__row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.5rem)}

/* ============================================================
   SCREENS SHOWCASE
   ============================================================ */
.screens-section{padding:clamp(4rem,8vw,6rem) 0}
.screens-header{
  padding:0 clamp(1.2rem,4vw,3rem);
  max-width:var(--maxw);margin:0 auto clamp(2.5rem,4vw,3.5rem);
  text-align:center;
}
.screens-strip{
  display:flex;gap:2px;
  padding:0 clamp(1.2rem,4vw,3rem);
  max-width:var(--maxw);margin:0 auto;
}
.screen-desktop{
  flex:3;border:1px solid var(--border);overflow:hidden;
  transition:border-color .4s;
}
.screen-desktop:hover{border-color:var(--border-strong)}
.screen-mobile-wrap{flex:1;display:flex;flex-direction:column;gap:2px}
.screen-mobile{
  border:1px solid var(--border);overflow:hidden;flex:1;
  transition:border-color .4s;min-height:160px;
}
.screen-mobile:hover{border-color:var(--border-strong)}

/* ============================================================
   TAGLINE
   ============================================================ */
.tagline-section{
  text-align:center;
  padding:clamp(6rem,13vw,11rem) clamp(1.2rem,4vw,3rem);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
  background:radial-gradient(90% 120% at 50% 50%, rgba(200,168,75,.05), transparent 70%);
}
.tagline-section::before{
  content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:600px;height:600px;border-radius:50%;
  border:1px solid var(--border);pointer-events:none;
}
.tagline-section::after{
  content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:340px;height:340px;border-radius:50%;
  border:1px solid var(--border);pointer-events:none;
}
.tagline-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.tagline-quote{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1.8rem,4.5vw,3.4rem);line-height:1.3;
  color:var(--cream);margin-bottom:2rem;
}
.tagline-quote span{color:var(--gold-lt)}
.tagline-sub{
  font-size:.76rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--text-muted);
}

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-final{
  text-align:center;
  padding:clamp(6rem,12vw,10rem) 1.5rem;
  border-top:1px solid var(--border);
  position:relative;overflow:hidden;
  background:radial-gradient(100% 100% at 50% 120%, rgba(200,168,75,.12), transparent 60%), var(--bg);
}
.cta__arcs{position:absolute;inset:0;width:100%;height:100%;opacity:.5;z-index:1}
.cta__inner{position:relative;z-index:2;max-width:680px;margin:0 auto}
.cta__inner .section-label{margin-bottom:1.2rem}
.cta__inner .section-title{
  max-width:560px;margin:0 auto 1.2rem;
  font-size:clamp(2rem,5.5vw,3.8rem);
}
.cta__inner .section-body{
  margin:0 auto 2.6rem;
  text-align:center;
  max-width:480px;
}

/* ============================================================
   SECTION HEADS (shared)
   ============================================================ */
.sec__head{max-width:var(--maxw);margin:0 auto clamp(2.5rem,5vw,4rem);padding:0 clamp(1.2rem,4vw,3rem);text-align:center}

/* CTA buttons row */
.cta__buttons{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:2.6rem}

/* ============================================================
   PWA PANEL
   ============================================================ */
.pwa-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(7,8,12,.7);backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .4s;
}
.pwa-overlay.is-open{opacity:1;pointer-events:all}

.pwa-panel{
  position:fixed;top:0;right:0;bottom:0;z-index:201;
  width:min(480px,100vw);
  background:var(--bg-soft);
  border-left:1px solid var(--border-strong);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .45s cubic-bezier(.22,.8,.3,1);
  overflow-y:auto;
}
.pwa-panel.is-open{transform:translateX(0)}

.pwa-panel__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.8rem 2rem 1.2rem;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;background:var(--bg-soft);z-index:2;
}
.pwa-panel__title{
  font-family:var(--serif);font-weight:400;
  font-size:1.7rem;color:var(--gold-lt);letter-spacing:.04em;
  margin-bottom:.6rem;
}
.pwa-panel__desc{
  font-size:.85rem;line-height:1.7;
  color:var(--text-muted);max-width:32ch;
}
.pwa-panel__close{
  background:none;border:1px solid var(--line);
  color:var(--cream-dim);width:36px;height:36px;
  border-radius:50%;cursor:pointer;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .3s, color .3s;
}
.pwa-panel__close:hover{border-color:var(--gold);color:var(--gold)}

.pwa-panel__tabs{
  display:flex;gap:0;
  border-bottom:1px solid var(--line);
}
.pwa-tab{
  flex:1;padding:1rem .5rem;
  font-family:var(--sans);font-size:.72rem;font-weight:500;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--cream-dim);background:none;border:none;cursor:pointer;
  border-bottom:2px solid transparent;
  transition:color .3s, border-color .3s;
  margin-bottom:-1px;
}
.pwa-tab.is-active{color:var(--gold);border-bottom-color:var(--gold)}
.pwa-tab:hover:not(.is-active){color:var(--cream)}

.pwa-content{display:none;flex-direction:column;gap:0;padding:2rem}
.pwa-content.is-active{display:flex}

.pwa-step{
  display:flex;gap:1.4rem;align-items:flex-start;
  padding:1.4rem 0;border-bottom:1px solid var(--line);
}
.pwa-step:last-child{border-bottom:none}
.pwa-step__num{
  font-family:var(--serif);font-size:1.8rem;font-weight:300;
  color:var(--text-faint);line-height:1;min-width:2rem;flex-shrink:0;
}
.pwa-step__title{
  font-family:var(--sans);font-weight:500;font-size:.9rem;
  color:var(--cream);margin-bottom:.4rem;letter-spacing:.04em;
}
.pwa-step__body{
  font-size:.88rem;line-height:1.75;color:var(--text-muted);
}
.pwa-step__body strong{color:var(--gold-lt);font-weight:400}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding:clamp(2.5rem,5vw,3.5rem) clamp(1.2rem,4vw,3rem);border-top:1px solid var(--line)}
.footer__inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
}
.footer__brand{display:flex;align-items:center;gap:.7rem;font-size:.95rem;letter-spacing:.4em;color:var(--cream)}
.footer__logo{width:30px;height:30px}
.footer__nav{display:flex;gap:1.8rem}
.footer__nav a{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-dim);transition:color .35s}
.footer__nav a:hover{color:var(--gold-lt)}
.footer__copy{font-size:.8rem;letter-spacing:.06em;color:var(--cream-faint)}
.footer__copy a{color:var(--gold);transition:color .35s}
.footer__copy a:hover{color:var(--gold-lt)}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* scroll-margin for fixed nav */
#czym,#funkcje,#jak,#pobierz{scroll-margin-top:90px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:960px){
  .screens-strip{flex-direction:column}
  .screen-mobile-wrap{flex-direction:row}
  .screen-mobile{min-height:220px}
}
@media(max-width:880px){
  .czym__grid{grid-template-columns:1fr}
  .czym__illo{order:-1}
  .features__grid{grid-template-columns:1fr 1fr}
  .nav__tag{display:none}
  .tagline-section::before{width:90vw;height:90vw}
  .tagline-section::after{width:50vw;height:50vw}
}
@media(max-width:620px){
  .nav__links a:not(.nav__cta):not([href="#pobierz"]){display:none}
  .nav__links .nav__cta{display:none}
  .nav__name{font-size:.95rem;letter-spacing:.32em}
  .features__grid{grid-template-columns:1fr}
  .screen-mobile-wrap{flex-direction:column}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}
