/* ============================================================
   GRAMY WROCŁAW — dark club / graffiti-pro
   czarny · biały · srebrny · bordo
   ============================================================ */
:root{
  --bg:#0a0a0b;
  --bg2:#101013;
  --panel:#16161a;
  --panel2:#1c1c21;
  --line:#26262d;
  --white:#f4f4f5;
  --silver:#a9aeb9;
  --silver2:#6d7280;
  --bordo:#7d1128;
  --bordo2:#a51733;
  --bordo-glow:rgba(165,23,51,.4);
  --font-display:'Archivo Black',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-tag:'Kalam',cursive;
  --nav-h:72px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--white);
  font-family:var(--font-body);
  font-size:16px;line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--bordo2);color:#fff}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.12;letter-spacing:.5px;text-transform:uppercase}
h1{font-size:clamp(2.2rem,6vw,4.4rem)}
h2{font-size:clamp(1.6rem,4vw,2.7rem)}
h3{font-size:clamp(1.05rem,2vw,1.35rem)}
p{color:var(--silver)}
strong{color:var(--white)}

/* noise overlay — klubowy grunge */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
}
main,header,footer{position:relative;z-index:2}

.wrap{width:min(1200px,92vw);margin-inline:auto}

/* ---------- typo akcenty ---------- */
.tag{
  font-family:var(--font-tag);text-transform:none;letter-spacing:0;
  color:var(--bordo2);font-size:clamp(1.05rem,2.2vw,1.5rem);
  display:inline-block;transform:rotate(-2.5deg);
}
.kicker{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.78rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--silver);
}
.kicker::before{content:"";width:34px;height:2px;background:var(--bordo2)}
.spray{position:relative;display:inline-block}
.spray::after{
  content:"";position:absolute;left:-6%;bottom:.04em;width:112%;height:.42em;z-index:-1;
  background:radial-gradient(60% 130% at 30% 50%,var(--bordo) 0%,rgba(125,17,40,.65) 45%,transparent 78%);
  filter:blur(1px);transform:rotate(-1.2deg);
}
.outline-txt{
  color:transparent;-webkit-text-stroke:1.5px var(--silver2);
}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);
  display:flex;align-items:center;
  background:rgba(10,10,11,.55);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid transparent;
  transition:background .4s,border-color .4s;
}
.nav.scrolled{background:rgba(10,10,11,.88);border-bottom-color:var(--line)}
.nav-inner{width:min(1280px,94vw);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-logo img{height:44px;width:auto;transition:transform .35s var(--ease)}
.nav-logo:hover img{transform:scale(1.06) rotate(-2deg)}
.nav-links{display:flex;align-items:center;gap:.35rem;list-style:none}
.nav-links a{
  position:relative;padding:.55rem .85rem;font-size:.86rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--silver);
  border-radius:8px;transition:color .25s,background .25s,text-shadow .25s;
}
.nav-links a::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.3rem;height:2px;background:var(--bordo2);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--white);text-shadow:0 0 18px var(--bordo-glow)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{
  margin-left:.4rem;padding:.55rem 1.1rem;border:1px solid var(--bordo2);border-radius:99px;
  color:var(--white)!important;background:linear-gradient(120deg,var(--bordo),var(--bordo2));
  box-shadow:0 0 0 rgba(165,23,51,0);transition:box-shadow .3s,transform .3s;
}
.nav-cta::after{display:none}
.nav-cta:hover{box-shadow:0 6px 26px var(--bordo-glow);transform:translateY(-1px)}
.cart-pill{position:relative}
.cart-pill .cart-count{
  position:absolute;top:-2px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;
  background:var(--bordo2);color:#fff;font-size:.68rem;font-weight:700;display:none;align-items:center;justify-content:center;
}
.cart-pill .cart-count.show{display:inline-flex}

.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;position:relative;z-index:110}
.burger span{display:block;width:24px;height:2px;background:var(--white);margin:5px auto;transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:960px){
  .burger{display:block}
  .nav-links{
    position:fixed;inset:0;z-index:105;height:100dvh;
    background:#0a0a0b;
    flex-direction:column;align-items:center;gap:1.3rem;
    padding:calc(var(--nav-h) + 1rem) 1.5rem calc(env(safe-area-inset-bottom,0px) + 2rem);
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    opacity:0;pointer-events:none;transition:opacity .35s;
  }
  .nav-links.open{opacity:1;pointer-events:auto}
  /* wyśrodkowanie pionowe, ale z możliwością przewinięcia gdy pozycji nie mieści się na ekranie */
  .nav-links li:first-child{margin-top:auto}
  .nav-links li:last-child{margin-bottom:auto}
  .nav-links a{font-size:1.35rem}
}

/* ---------- hero ---------- */
.hero{
  min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;
  padding-top:var(--nav-h);
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 50% at 70% 30%,rgba(125,17,40,.28),transparent 70%),
    radial-gradient(45% 45% at 20% 80%,rgba(169,174,185,.08),transparent 70%),
    linear-gradient(180deg,rgba(10,10,11,.25),var(--bg) 92%);
}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.5}
#hero-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-content{position:relative;z-index:2;padding:6rem 0 4rem}
.hero h1{margin:.8rem 0 1.2rem;max-width:14ch}
.hero p.lead{max-width:52ch;font-size:1.08rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}
.scroll-hint{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;
  color:var(--silver2);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}
.scroll-hint::after{content:"";width:1px;height:42px;background:linear-gradient(var(--bordo2),transparent);animation:drop 1.8s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;padding:.85rem 1.7rem;border-radius:99px;
  font-weight:700;font-size:.9rem;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;border:0;
  transition:transform .3s var(--ease),box-shadow .3s;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:linear-gradient(120deg,var(--bordo),var(--bordo2));color:#fff}
.btn-primary:hover{box-shadow:0 10px 34px var(--bordo-glow);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--white);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--silver);transform:translateY(-2px)}
.btn-sm{padding:.55rem 1.1rem;font-size:.78rem}

/* ---------- sekcje ---------- */
section{padding:clamp(4rem,9vw,7.5rem) 0}
.sec-head{max-width:760px;margin-bottom:clamp(2rem,5vw,3.6rem)}
.sec-head h2{margin:.7rem 0 .9rem}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}

/* ---------- karty usług ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
@media(max-width:900px){.grid3{grid-template-columns:1fr}.grid2{grid-template-columns:1fr}}
.card{
  position:relative;background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  transition:transform .45s var(--ease),border-color .45s,box-shadow .45s;
}
.card:hover{transform:translateY(-8px);border-color:rgba(165,23,51,.55);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 40px rgba(165,23,51,.12)}
.card-img{aspect-ratio:4/3;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card-img img{transform:scale(1.07)}
.card-body{padding:1.4rem 1.5rem 1.7rem}
.card-body h3{margin-bottom:.55rem}
.card-body p{font-size:.94rem}
.card-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bordo2)}
.card-link svg{transition:transform .3s var(--ease)}
.card:hover .card-link svg{transform:translateX(5px)}

/* ---------- liczby ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}
@media(max-width:700px){.stats{grid-template-columns:1fr;gap:2rem}}
.stat b{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,4rem);display:block;color:var(--white)}
.stat b i{font-style:normal;color:var(--bordo2)}
.stat span{color:var(--silver2);letter-spacing:.2em;text-transform:uppercase;font-size:.75rem}

/* ---------- pasek klientów ---------- */
.clients{border-block:1px solid var(--line);padding:1.6rem 0;overflow:hidden;background:var(--bg2)}
.marquee{display:flex;gap:3.5rem;width:max-content;animation:marq 30s linear infinite}
.marquee span{white-space:nowrap;color:var(--silver2);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.85rem}
.marquee span::before{content:"◆";color:var(--bordo);margin-right:3.5rem;font-size:.6rem;vertical-align:2px}
@keyframes marq{to{transform:translateX(-50%)}}

/* ============================================================
   3D SCROLL STAGES
   ============================================================ */
.stage3d{position:relative;padding:0;border-top:1px solid var(--line)}
.stage-track{min-height:170vh;position:relative}
.stage-sticky{
  position:sticky;top:var(--nav-h);height:calc(100svh - var(--nav-h));
  display:grid;grid-template-columns:1.1fr 1fr;align-items:center;gap:2rem;overflow:hidden;
}
.stage-sticky.flip{grid-template-columns:1fr 1.1fr}
.stage-sticky.flip .stage-canvas{order:2}
.stage-canvas{position:relative;height:min(72vh,640px)}
.stage-canvas canvas{position:absolute;inset:0;width:100%!important;height:100%!important}
.stage-canvas::after{
  content:"";position:absolute;left:12%;right:12%;bottom:6%;height:40px;border-radius:50%;
  background:radial-gradient(50% 100% at 50% 50%,rgba(165,23,51,.22),transparent 75%);filter:blur(8px);
}
.stage-copy{padding:2rem 0}
.stage-copy .kicker{margin-bottom:.9rem}
.stage-copy h3{font-size:clamp(1.5rem,3.2vw,2.3rem);margin-bottom:1rem}
.stage-copy p{max-width:46ch}
.spec-list{list-style:none;margin-top:1.4rem;display:grid;gap:.55rem}
.spec-list li{display:flex;gap:.7rem;align-items:baseline;color:var(--silver);font-size:.93rem}
.spec-list li::before{content:"—";color:var(--bordo2);font-weight:700}
.stage-price{
  margin-top:1.6rem;display:inline-flex;align-items:center;gap:.9rem;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:.8rem 1.2rem;
}
.stage-price b{font-family:var(--font-display);font-size:1.3rem}
.stage-price small{color:var(--silver2)}
@media(max-width:900px){
  .stage-track{min-height:150vh}
  .stage-sticky,.stage-sticky.flip{grid-template-columns:1fr;align-items:start;gap:0}
  .stage-sticky.flip .stage-canvas{order:0}
  .stage-canvas{height:44vh;margin-top:1rem}
  .stage-copy{padding:1rem 0 3rem}
}

/* strona-usługa hero */
.page-hero{
  padding:calc(var(--nav-h) + clamp(3rem,8vw,6rem)) 0 clamp(2.5rem,6vw,4.5rem);
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(55% 60% at 75% 20%,rgba(125,17,40,.22),transparent 70%);
}
.page-hero .wrap{position:relative}
.page-hero p.lead{max-width:62ch;font-size:1.05rem;margin-top:1.1rem}

/* ============================================================
   WYPOŻYCZALNIA
   ============================================================ */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin:0 0 2rem}
.chip{
  padding:.5rem 1.05rem;border-radius:99px;border:1px solid var(--line);background:var(--panel);
  color:var(--silver);font-size:.82rem;font-weight:600;letter-spacing:.05em;cursor:pointer;
  transition:all .25s var(--ease);
}
.chip:hover{border-color:var(--silver2);color:var(--white);transform:translateY(-1px)}
.chip.active{background:linear-gradient(120deg,var(--bordo),var(--bordo2));border-color:transparent;color:#fff}
.rental-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:1.2rem}
.prod{
  background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1.35rem;display:flex;flex-direction:column;gap:.8rem;
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.prod:hover{transform:translateY(-6px);border-color:rgba(165,23,51,.5);box-shadow:0 18px 44px rgba(0,0,0,.45)}
.prod-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem}
.prod-ico{
  width:52px;height:52px;border-radius:13px;background:var(--panel2);border:1px solid var(--line);
  display:grid;place-items:center;color:var(--silver);flex:none;
  transition:color .3s,border-color .3s;
}
.prod:hover .prod-ico{color:var(--bordo2);border-color:rgba(165,23,51,.4)}
.stock{
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--silver2);
  border:1px solid var(--line);padding:.3rem .65rem;border-radius:99px;white-space:nowrap;
}
.stock i{font-style:normal;color:#3ecf6f}
.prod h3{font-size:1rem;letter-spacing:.03em}
.prod .cat-lab{font-size:.72rem;color:var(--bordo2);font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.prod p{font-size:.87rem;flex:1}
.prod-foot{display:flex;justify-content:space-between;align-items:center;gap:.8rem;border-top:1px solid var(--line);padding-top:.9rem}
.price b{font-family:var(--font-display);font-size:1rem;white-space:nowrap;letter-spacing:0}
.price small{display:block;color:var(--silver2);font-size:.68rem;white-space:nowrap}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:99px;overflow:hidden}
.qty button{width:30px;height:32px;background:none;border:0;color:var(--white);font-size:1rem;cursor:pointer;transition:background .2s}
.qty button:hover{background:var(--panel2)}
.qty input{width:34px;text-align:center;background:none;border:0;color:var(--white);font-weight:700;font-size:.9rem}
.qty input:focus{outline:none}
.add-btn{
  padding:.55rem 1rem;border-radius:99px;border:1px solid var(--bordo2);background:none;color:var(--white);
  font-weight:700;font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;
  transition:all .3s var(--ease);
}
.add-btn:hover{background:linear-gradient(120deg,var(--bordo),var(--bordo2));box-shadow:0 6px 20px var(--bordo-glow)}
.add-btn.added{background:#1d7a41;border-color:#1d7a41}

/* koszyk drawer */
.cart-fab{
  position:fixed;right:1.4rem;bottom:1.4rem;z-index:90;
  width:60px;height:60px;border-radius:50%;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--bordo),var(--bordo2));color:#fff;
  box-shadow:0 12px 34px rgba(0,0,0,.5),0 0 30px var(--bordo-glow);
  display:grid;place-items:center;transition:transform .3s var(--ease);
}
.cart-fab:hover{transform:scale(1.08)}
.cart-fab .cart-count{
  position:absolute;top:-4px;right:-4px;min-width:22px;height:22px;border-radius:11px;padding:0 5px;
  background:#fff;color:var(--bordo2);font-weight:800;font-size:.75rem;display:grid;place-items:center;
}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(430px,100vw);z-index:120;
  background:var(--bg2);border-left:1px solid var(--line);
  transform:translateX(105%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;
}
.drawer.open{transform:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:1.3rem 1.5rem;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:1rem}
.drawer-close{background:none;border:0;color:var(--silver);font-size:1.6rem;cursor:pointer;line-height:1}
.drawer-items{flex:1;overflow-y:auto;padding:1rem 1.5rem;display:grid;gap:.8rem;align-content:start}
.d-item{display:flex;justify-content:space-between;gap:.8rem;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem;font-size:.88rem}
.d-item b{display:block;font-size:.85rem}
.d-item small{color:var(--silver2)}
.d-item button{background:none;border:0;color:var(--silver2);cursor:pointer;font-size:1.1rem}
.d-item button:hover{color:var(--bordo2)}
.drawer-foot{border-top:1px solid var(--line);padding:1.2rem 1.5rem;display:grid;gap:.8rem}
.drawer-total{display:flex;justify-content:space-between;font-size:.95rem}
.drawer-total b{font-family:var(--font-display)}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:115;opacity:0;pointer-events:none;transition:opacity .4s}
.overlay.show{opacity:1;pointer-events:auto}
.empty-note{color:var(--silver2);text-align:center;padding:2rem 0;font-size:.9rem}

/* ============================================================
   FORMULARZE
   ============================================================ */
.form{display:grid;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:640px){.form-row{grid-template-columns:1fr}}
.field label{display:block;font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--silver2);margin-bottom:.45rem}
.field input,.field textarea,.field select{
  width:100%;background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:.85rem 1rem;color:var(--white);font-family:inherit;font-size:.95rem;
  transition:border-color .3s,box-shadow .3s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--bordo2);box-shadow:0 0 0 3px rgba(165,23,51,.18);
}
.field textarea{min-height:130px;resize:vertical}
.form-note{font-size:.78rem;color:var(--silver2)}
.form-status{display:none;padding:1rem 1.2rem;border-radius:12px;font-size:.92rem}
.form-status.ok{display:block;background:rgba(29,122,65,.15);border:1px solid #1d7a41;color:#7fe3a8}
.form-status.err{display:block;background:rgba(165,23,51,.12);border:1px solid var(--bordo2);color:#ff9fb0}

/* kontakt info */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.c-line{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line)}
.c-line svg{flex:none;color:var(--bordo2);margin-top:.2rem}
.c-line a:hover{color:var(--bordo2)}
.map-embed{border:1px solid var(--line);border-radius:18px;overflow:hidden;filter:grayscale(1) invert(.92) contrast(.9);aspect-ratio:16/10}
.map-embed iframe{width:100%;height:100%;border:0}

/* ============================================================
   REALIZACJE (blog)
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.4rem}
.post-card{cursor:pointer}
.post-meta{display:flex;gap:.9rem;align-items:center;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--silver2);margin-bottom:.5rem}
.post-meta i{font-style:normal;color:var(--bordo2)}
.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.post-tags span{font-size:.7rem;padding:.28rem .7rem;border-radius:99px;border:1px solid var(--line);color:var(--silver)}
/* modal */
.post-modal{
  position:fixed;inset:0;z-index:130;display:none;align-items:flex-start;justify-content:center;
  overflow-y:auto;background:rgba(5,5,6,.88);backdrop-filter:blur(14px);padding:4.5rem 1rem 3rem;
}
.post-modal.open{display:flex}
.post-modal-inner{
  width:min(880px,100%);background:var(--bg2);border:1px solid var(--line);border-radius:22px;overflow:hidden;
  animation:pop .45s var(--ease);
}
@keyframes pop{from{opacity:0;transform:translateY(26px) scale(.98)}to{opacity:1}}
.pm-cover{aspect-ratio:16/8;overflow:hidden}
.pm-cover img{width:100%;height:100%;object-fit:cover}
.pm-body{padding:clamp(1.4rem,4vw,2.6rem)}
.pm-body h2{margin:.5rem 0 1rem;font-size:clamp(1.3rem,3vw,2rem)}
.pm-body p{margin-bottom:1rem}
.pm-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.7rem;margin-top:1.4rem}
.pm-gallery img{border-radius:12px;aspect-ratio:4/3;object-fit:cover;width:100%;cursor:zoom-in;transition:transform .35s var(--ease)}
.pm-gallery img:hover{transform:scale(1.03)}
.pm-close{
  position:sticky;top:0;float:right;margin:.9rem;z-index:5;
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:rgba(10,10,11,.7);
  color:#fff;font-size:1.3rem;cursor:pointer;
}
.lightbox{position:fixed;inset:0;z-index:140;background:rgba(0,0,0,.94);display:none;place-items:center;padding:2rem;cursor:zoom-out}
.lightbox.open{display:grid}
.lightbox img{max-width:96vw;max-height:92vh;object-fit:contain;border-radius:8px}

/* ---------- CTA banner ---------- */
.cta-band{
  position:relative;overflow:hidden;text-align:center;
  background:linear-gradient(120deg,#140507 0%,var(--bordo) 55%,#33060f 100%);
  border-block:1px solid var(--line);
}
.cta-band h2{max-width:22ch;margin:0 auto 1.4rem}
.cta-band p{color:rgba(255,255,255,.75);max-width:52ch;margin:0 auto 2rem}

/* ---------- footer ---------- */
footer{background:var(--bg2);border-top:1px solid var(--line);padding:3.5rem 0 2rem;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2.5rem}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr}}
.foot-grid img{height:56px;width:auto;margin-bottom:1rem}
.foot-grid h4{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--silver2);margin-bottom:1rem}
.foot-grid ul{list-style:none;display:grid;gap:.55rem}
.foot-grid a{color:var(--silver);font-size:.92rem;transition:color .25s}
.foot-grid a:hover{color:var(--bordo2)}
.foot-bottom{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;color:var(--silver2);font-size:.8rem}
.socials{display:flex;gap:.7rem}
.socials a{
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--silver);
  transition:all .3s var(--ease);
}
.socials a:hover{color:#fff;border-color:var(--bordo2);box-shadow:0 0 20px var(--bordo-glow);transform:translateY(-3px)}

/* ============================================================
   ANIMOWANE PREZENTACJE SPRZĘTU (SVG/CSS)
   ============================================================ */
.feat-section{border-top:1px solid var(--line)}
.feat{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.feat.flip .anim-box{order:2}
@media(max-width:900px){.feat,.feat.flip{grid-template-columns:1fr}.feat.flip .anim-box{order:0}}
.anim-box{
  position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  background:radial-gradient(80% 90% at 50% 20%,#1a1a1f 0%,var(--panel) 55%,#0d0d0f 100%);
  aspect-ratio:4/3;display:grid;place-items:center;
  transition:border-color .5s,box-shadow .5s;
}
.anim-box:hover{border-color:rgba(165,23,51,.5);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 46px rgba(165,23,51,.12)}
.anim-box::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(50% 40% at 50% 88%,rgba(165,23,51,.16),transparent 75%);
}
.anim-box svg{width:min(78%,460px);height:auto;overflow:visible}
.anim-float{animation:floaty 6s ease-in-out infinite}
.feat-copy .kicker{margin-bottom:.9rem}
.feat-copy h3{font-size:clamp(1.5rem,3.2vw,2.2rem);margin-bottom:1rem}
.feat-copy p{max-width:48ch}
.feat-cta{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;font-weight:700;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bordo2)}
.feat-cta svg{transition:transform .3s var(--ease)}
.feat-cta:hover svg{transform:translateX(5px)}

/* keyframes */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes wavePulse{0%{transform:scale(.55);opacity:.9}100%{transform:scale(1.7);opacity:0}}
@keyframes faderMove{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}
@keyframes faderMoveSm{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes ledBlink{0%,100%{opacity:.12}50%{opacity:1}}
@keyframes beamSweep{0%,100%{transform:rotate(-24deg)}50%{transform:rotate(24deg)}}
@keyframes hueSpin{to{filter:hue-rotate(360deg)}}
@keyframes spinSlow{to{transform:rotate(360deg)}}
@keyframes bassThump{0%,8%,100%{transform:scale(1)}4%{transform:scale(1.035)}}
@keyframes glowPulse{0%,100%{opacity:.55}50%{opacity:1}}
@keyframes drawLoop{0%{stroke-dashoffset:600}55%,100%{stroke-dashoffset:0}}

/* klasy animacji wewnątrz SVG */
.sv-wave{transform-origin:center;transform-box:fill-box;animation:wavePulse 2.6s ease-out infinite}
.sv-wave.w2{animation-delay:.85s}
.sv-wave.w3{animation-delay:1.7s}
.sv-fader{animation:faderMove 3.2s ease-in-out infinite}
.sv-fader-sm{animation:faderMoveSm 2.8s ease-in-out infinite}
.sv-led{animation:ledBlink 1.6s ease-in-out infinite}
.sv-beam{transform-box:fill-box;transform-origin:50% 0%;animation:beamSweep 7s ease-in-out infinite}
.sv-head-sweep{transform-box:fill-box;transform-origin:50% 12%;animation:beamSweep 7s ease-in-out infinite}
.sv-hue{animation:hueSpin 9s linear infinite}
.sv-spin{transform-box:fill-box;transform-origin:center;animation:spinSlow 14s linear infinite}
.sv-thump{transform-box:fill-box;transform-origin:center;animation:bassThump 1.9s ease-out infinite}
.sv-glow{animation:glowPulse 2.4s ease-in-out infinite}
.sv-draw{stroke-dasharray:600;stroke-dashoffset:600;animation:drawLoop 6s ease-in-out infinite}
@keyframes faderSubtle{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.sv-fader-q{animation:faderSubtle 7s ease-in-out infinite}
@keyframes ledSoft{0%,100%{opacity:.25}50%{opacity:.9}}
.sv-led-soft{animation:ledSoft 3.6s ease-in-out infinite}
.sv-glow-slow{animation:glowPulse 6s ease-in-out infinite}
.sv-smoke{animation:smokeUp 5s ease-out infinite;transform-box:fill-box;transform-origin:center}
@keyframes smokeUp{0%{transform:translateY(0) scale(.6);opacity:0}15%{opacity:.5}100%{transform:translateY(-70px) scale(1.6);opacity:0}}
.sv-sway{transform-box:fill-box;transform-origin:top center;animation:sway 6s ease-in-out infinite}
@keyframes sway{0%,100%{transform:skewX(0deg)}50%{transform:skewX(2.5deg)}}
.sv-float-1{animation:floaty 5s ease-in-out infinite}
.sv-float-2{animation:floaty 5s ease-in-out infinite;animation-delay:.7s}
.sv-float-3{animation:floaty 5s ease-in-out infinite;animation-delay:1.4s}

/* ---------- HERO: animacja świateł i equalizera ---------- */
.hero-anim{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hbeam{
  position:absolute;bottom:-12%;width:170px;height:125vh;
  transform-origin:bottom center;filter:blur(6px);opacity:.5;
}
.hbeam.b1{left:12%;background:linear-gradient(to top,rgba(165,23,51,.5),transparent 75%)}
.hbeam.b2{left:38%;background:linear-gradient(to top,rgba(244,244,245,.28),transparent 70%)}
.hbeam.b3{left:64%;background:linear-gradient(to top,rgba(169,174,185,.3),transparent 72%)}
.hbeam.b4{left:85%;background:linear-gradient(to top,rgba(165,23,51,.4),transparent 75%)}
@media (prefers-reduced-motion:reduce){.hbeam{display:none}}
.eq{position:absolute;left:0;right:0;bottom:0;height:90px;display:flex;align-items:flex-end;gap:5px;padding:0 4vw;opacity:.4}
.eq i{flex:1;border-radius:3px 3px 0 0;background:linear-gradient(to top,var(--bordo2),rgba(165,23,51,.05));transform-origin:bottom;animation:eqBar 1.3s ease-in-out infinite}
.eq i:nth-child(3n){animation-duration:1.7s;animation-delay:.2s}
.eq i:nth-child(3n+1){animation-duration:1.1s;animation-delay:.45s}
.eq i:nth-child(4n){animation-duration:1.5s;animation-delay:.7s;background:linear-gradient(to top,var(--silver2),transparent)}
.eq i:nth-child(5n){animation-duration:.9s;animation-delay:.1s}
@keyframes eqBar{0%,100%{transform:scaleY(.15)}50%{transform:scaleY(1)}}
@media(max-width:700px){.hbeam{width:90px;opacity:.35}.eq{height:56px;gap:3px}}
/* subtelna wersja do nagłówków podstron */
.page-hero .hero-anim{z-index:0}
.page-hero .wrap{z-index:2}
.hero-anim.soft .hbeam{opacity:.32;filter:blur(9px)}
.hero-anim.soft .eq{opacity:.2;height:64px}

/* misc */
.divider-tag{text-align:center;padding:2.2rem 0;border-top:1px solid var(--line)}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* === Baner zgód (cookies / RODO) === */
.consent{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:200;max-width:720px;margin:0 auto;
  background:rgba(22,22,26,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.3rem;
  display:flex;gap:1rem;align-items:center;flex-wrap:wrap;justify-content:space-between;
  box-shadow:0 18px 50px rgba(0,0,0,.55);transform:translateY(150%);opacity:0;
  transition:transform .45s var(--ease),opacity .45s}
.consent.show{transform:translateY(0);opacity:1}
.consent-txt{font-size:.9rem;color:var(--silver);flex:1 1 320px;margin:0}
.consent-txt a{color:var(--bordo2);text-decoration:underline}
.consent-btns{display:flex;gap:.6rem;flex:0 0 auto}
.consent .btn{padding:.6rem 1.1rem;font-size:.82rem}
@media(max-width:560px){.consent{padding:1rem;left:.6rem;right:.6rem}.consent-btns{width:100%}.consent .btn{flex:1}}
.foot-priv{margin-left:1.2rem;color:var(--silver2);text-decoration:underline}
.foot-priv:hover{color:var(--silver)}

/* === Strona 404 === */
.err404{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;position:relative;overflow:hidden}
.err404 .wrap{position:relative;z-index:2;text-align:center;padding-top:4rem;padding-bottom:4rem}
.err404 .big404{font-family:var(--font-display);line-height:.9;
  font-size:clamp(6rem,26vw,18rem);letter-spacing:-.02em;
  background:linear-gradient(120deg,var(--bordo2),var(--white) 55%,var(--bordo2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px var(--bordo-glow);margin-bottom:.4rem}
.err404 h1{font-size:clamp(1.5rem,4.5vw,2.6rem);margin-bottom:1rem}
.err404 .lead{max-width:52ch;margin:0 auto 2rem}
.err404 .err-links{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
