/*
Theme Name: Happy Desperados
Theme URI: https://happydesperados.pl
Author: Happy Desperados
Description: Autorski motyw – dark, multi-page, IT/WordPress Agency. v21 — krytyczne poprawki: formularz /cennik/, konsolidacja AJAX, ujednolicenie cen i terminów, cleanup Google Ads z treści, usunięcie fake reviews, LCP fix.
Version: 21.0.0
License: GNU General Public License v2 or later
Text Domain: happydesperados
*/

/* ============================================================
   TOKENS
   ============================================================ */
:root {
  --bg:    #070d18;
  --bg1:   #0a1220;
  --bg2:   #0d1828;
  --card:  #0f1e30;
  --card2: #152338;

  --or:  #e8621a;
  --or2: #f0793a;
  --red: #c0392b;
  --bl:  #3b82f6;

  --t1: #eef2f7;
  --t2: #8fa3bc;
  --t3: #4e6278;

  --b1: rgba(255,255,255,.055);
  --b2: rgba(232,98,26,.28);
  --glow: rgba(232,98,26,.13);

  --fh: 'Syne', sans-serif;
  --fb: 'DM Sans', sans-serif;
  --fm: 'JetBrains Mono', monospace;

  --r:  10px;
  --r2: 18px;
  --r3: 28px;
  --S:  96px;
  --W:  1160px;
  --ease: cubic-bezier(0.22,1,0.36,1);
  --t:  0.3s cubic-bezier(0.4,0,0.2,1);
  --ts: 0.65s cubic-bezier(0.22,1,0.36,1);
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--t1);font-family:var(--fb);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--or);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--or2)}
ul{list-style:none}

/* ============================================================
   CURSOR
   ============================================================ */
@media(hover:hover)and(pointer:fine){
  body{cursor:none}
  a,button,.btn{cursor:none}
  .cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:999999 !important;border-radius:50%;transform:translate(-50%,-50%)}
  .cursor-dot{width:5px;height:5px;background:var(--or)}
  .cursor-ring{width:30px;height:30px;border:1.5px solid rgba(232,98,26,.4);transition:width .15s var(--ease),height .15s var(--ease),border-color .15s}
  .cursor-ring.hov{width:52px;height:52px;border-color:var(--or)}
}
@media(hover:none){.cursor-dot,.cursor-ring{display:none}}

/* Noise */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9990;opacity:.016;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='256' height='256' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4{font-family:var(--fh);font-weight:700;line-height:1.1;color:var(--t1)}
h1{font-size:clamp(2.1rem,5vw,4rem);letter-spacing:-.02em}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem);letter-spacing:-.02em}
h3{font-size:clamp(1.05rem,2vw,1.5rem)}
h4{font-size:1rem}
p{color:var(--t2);margin-bottom:1rem}
p:last-child{margin-bottom:0}
.accent{color:var(--or)}

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{max-width:var(--W);margin-inline:auto;padding-inline:24px}
.sec{padding-block:var(--S)}
.sec-dark{background:var(--bg)}
.sec-alt{background:var(--bg2)}

.eye{display:inline-flex;align-items:center;gap:10px;font-family:var(--fm);font-size:.66rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-bottom:12px}
.eye::before{content:'';width:18px;height:1px;background:var(--or);flex-shrink:0}
.eye-c{justify-content:center}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--fb);font-weight:600;font-size:.9rem;padding:12px 24px;border-radius:100px;border:none;transition:all var(--t);text-decoration:none;white-space:nowrap}
.btn-sm{padding:9px 18px;font-size:.82rem}
.btn-p{background:var(--or);color:#fff}
.btn-p:hover{background:var(--or2);color:#fff;transform:translateY(-2px);box-shadow:0 10px 32px rgba(232,98,26,.42)}
.btn-o{background:transparent;color:var(--t1);border:1px solid rgba(255,255,255,.13)}
.btn-o:hover{border-color:var(--or);color:var(--or);transform:translateY(-2px)}
.btn-g{background:transparent;color:var(--or);padding-inline:0;border-radius:0}
.btn-g:hover{color:var(--or2);gap:13px}
.btn svg{width:16px;height:16px;flex-shrink:0}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position: fixed !important;
  top: 0; left: 0; right: 0;
  z-index: 99999 !important;
  padding: 18px 0;
  background: transparent;
  transition: background .35s ease, backdrop-filter .35s ease,
              padding .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.site-header.scrolled{
  background: rgba(7,13,24,.95) !important;
  backdrop-filter: blur(24px) saturate(1.6);
  -webkit-backdrop-filter: blur(24px) saturate(1.6);
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(232,98,26,.12) !important;
  box-shadow: 0 4px 40px rgba(0,0,0,.6), 0 1px 0 rgba(232,98,26,.06) !important;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}

/* Header logo – keep normal size */
.site-logo{display:flex;align-items:center}
.site-logo img{height:40px;width:auto;transition:transform var(--t)}
.site-logo:hover img{transform:scale(1.04)}
.site-logo-text{font-family:var(--fh);font-size:1.3rem;font-weight:800;color:var(--t1)}
.site-logo-text span{color:var(--or)}

.main-nav{display:flex;align-items:center;gap:2px}
.main-nav a{font-size:.845rem;font-weight:500;color:var(--t2);padding:7px 12px;border-radius:100px;transition:all var(--t)}
.main-nav a:hover,.main-nav a.active{color:var(--t1);background:rgba(255,255,255,.055)}
.main-nav a.active{color:var(--or);background:rgba(232,98,26,.08)}

.header-actions{display:flex;align-items:center;gap:9px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px}
.nav-toggle span{display:block;width:21px;height:1.5px;background:var(--t1);border-radius:2px;transition:all var(--t);transform-origin:center}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;inset:0;background:rgba(7,13,24,.97);backdrop-filter:blur(20px);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.mobile-nav.open{display:flex}
.mobile-nav-close{position:absolute;top:22px;right:22px;background:rgba(255,255,255,.06);border:1px solid var(--b1);border-radius:10px;padding:10px;color:var(--t2);transition:all var(--t);cursor:pointer}
.mobile-nav-close:hover{background:rgba(232,98,26,.1);color:var(--or)}
.mobile-nav a{font-family:var(--fh);font-size:1.9rem;font-weight:700;color:var(--t2);padding:10px 28px;border-radius:10px;transition:all var(--t)}
.mobile-nav a:hover{color:var(--t1);background:rgba(255,255,255,.04)}

/* ============================================================
   PAGE HERO (subpages)
   ============================================================ */
.page-hero{padding-top:130px;padding-bottom:70px;background:var(--bg);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(232,98,26,.07),transparent 60%)}
.page-hero-inner{position:relative;z-index:1}
.page-hero h1{margin-bottom:16px}
.page-hero p{font-size:1.08rem;max-width:580px}

/* ============================================================
   HERO – CARD STYLE (front page, jak na screen 1)
   ============================================================ */
.hero-wrap{
  min-height:100svh;
  display:flex;
  align-items:center;
  padding-top:88px;
  padding-bottom:40px;
  position:relative;
  overflow:hidden;
}

/* Animated background */
.hero-bg{position:absolute;inset:0;background:var(--bg)}
.hero-bg::before{
  content:'';position:absolute;inset:-40%;width:180%;height:180%;
  background:radial-gradient(ellipse 55% 45% at 60% 30%,rgba(232,98,26,.11) 0%,transparent 55%),
             radial-gradient(ellipse 45% 50% at 15% 75%,rgba(59,130,246,.07) 0%,transparent 50%);
  animation:bgR 18s linear infinite;
}
@keyframes bgR{0%,100%{transform:rotate(0deg) scale(1)}50%{transform:rotate(180deg) scale(1.06)}}

/* Grid */
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 15%,transparent 80%);
}
#hero-canvas{position:absolute;inset:0;pointer-events:none;opacity:.5}

/* The card */
.hero-card{
  position:relative;z-index:2;
  width:100%;
  background:rgba(15,30,48,.8);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  overflow:hidden;
  display:grid;
  grid-template-columns:1fr 400px;
  gap:0;
  box-shadow:0 32px 100px rgba(0,0,0,.5),0 0 0 1px rgba(232,98,26,.08),inset 0 1px 0 rgba(255,255,255,.06);
}

.hero-card-body{padding:52px 48px}

/* Top tags */
.hero-tags{
  display:flex;gap:10px;align-items:center;
  font-family:var(--fm);font-size:.68rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--t3);margin-bottom:28px;
}
.hero-tags span{display:flex;align-items:center;gap:6px}
.hero-tags span::before{content:'•';color:var(--or);font-size:.55rem}
.hero-tags span:first-child::before{display:none}

/* Headline */
.hero-card-body h1{
  font-size:clamp(1.9rem,4vw,3.2rem);
  margin-bottom:18px;
  line-height:1.15;
}
.hero-card-body h1 .hl{color:var(--or);position:relative;display:inline-block}

/* Desc */
.hero-card-body > p{font-size:1rem;line-height:1.8;max-width:500px;margin-bottom:24px}

/* Bullet list */
.hero-bullets{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.hero-bullets li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--t2)}
.hero-bullets li::before{
  content:'';display:block;width:8px;height:8px;border-radius:50%;
  background:var(--or);flex-shrink:0;margin-top:6px;
  box-shadow:0 0 8px rgba(232,98,26,.5);
}

/* CTA buttons */
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}

/* Badge chips */
.hero-badges{display:flex;gap:8px;flex-wrap:wrap}
.hero-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.74rem;font-weight:500;
  color:var(--t2);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:100px;
  padding:5px 13px;
  transition:all var(--t);
}
.hero-badge:hover{border-color:var(--b2);color:var(--or)}
.hero-badge strong{color:var(--t1);font-weight:600}

/* Right image panel */
.hero-card-img{
  position:relative;
  overflow:hidden;
  background:rgba(7,13,24,.6);
  border-left:1px solid rgba(255,255,255,.07);
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:440px;
}
.hero-card-img img{
  width:100%;height:100%;object-fit:cover;
  opacity:.9;
  transition:transform .8s var(--ease);
}
.hero-card-img:hover img{transform:scale(1.04)}
.hero-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(232,98,26,.06),transparent 60%),
             linear-gradient(to right,rgba(15,30,48,.4) 0%,transparent 40%);
}

/* Placeholder when no image */
.hero-card-img-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  padding:40px;
  background:linear-gradient(135deg,rgba(232,98,26,.05),rgba(59,130,246,.03));
}
.hero-mock-browser{
  width:100%;max-width:320px;
  background:rgba(7,13,24,.8);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;overflow:hidden;
}
.hero-mock-bar{
  height:30px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;gap:6px;padding:0 12px;
}
.hero-mock-dot{width:8px;height:8px;border-radius:50%}
.hero-mock-content{padding:16px;display:flex;flex-direction:column;gap:8px}
.hero-mock-line{height:8px;border-radius:4px;background:rgba(255,255,255,.07)}
.hero-mock-line.accent{background:var(--or);opacity:.4;width:60%}
.hero-mock-line.short{width:40%}
.hero-mock-line.medium{width:75%}

/* Hero animations */
.hero-card-body > *{opacity:0;animation:cardIn .6s var(--ease) forwards}
.hero-tags{animation-delay:.15s}
.hero-card-body h1{animation-delay:.28s}
.hero-card-body > p{animation-delay:.4s}
.hero-bullets{animation-delay:.5s}
.hero-btns{animation-delay:.6s}
.hero-badges{animation-delay:.7s}
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   LOGOS MARQUEE
   ============================================================ */
.logos-sec{padding-block:44px;background:var(--bg);border-top:1px solid var(--b1);border-bottom:1px solid var(--b1);overflow:hidden;position:relative}
.logos-sec::before,.logos-sec::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2}
.logos-sec::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.logos-sec::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.logos-label{text-align:center;font-family:var(--fm);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--t3);margin-bottom:20px}
.mq-wrap{display:flex;overflow:hidden}
.mq-track{display:flex;gap:12px;align-items:center;animation:mq 34s linear infinite;flex-shrink:0;padding-right:12px}
.mq-wrap:hover .mq-track{animation-play-state:paused}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-100%)}}
.logo-chip{display:flex;align-items:center;gap:7px;padding:7px 16px;background:rgba(255,255,255,.025);border:1px solid var(--b1);border-radius:8px;flex-shrink:0;transition:all var(--t)}
.logo-chip:hover{border-color:var(--b2);background:rgba(232,98,26,.05)}
.logo-chip span{font-family:var(--fh);font-size:.84rem;font-weight:700;color:var(--t3);white-space:nowrap;transition:color var(--t)}
.logo-chip:hover span{color:var(--t2)}

/* ============================================================
   WHY CARDS
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.why-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);padding:28px 24px;transition:all var(--ts);position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--or),var(--red));transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.why-card:hover{border-color:var(--b2);transform:translateY(-5px);box-shadow:0 22px 64px rgba(0,0,0,.4),0 0 48px var(--glow)}
.why-card:hover::before{transform:scaleX(1)}
.why-icon{width:46px;height:46px;border-radius:12px;background:rgba(232,98,26,.07);border:1px solid rgba(232,98,26,.13);display:grid;place-items:center;margin-bottom:18px;color:var(--or);transition:all var(--t)}
.why-icon svg{width:21px;height:21px}
.why-card:hover .why-icon{background:var(--or);color:#fff;border-color:transparent;box-shadow:0 6px 20px rgba(232,98,26,.4);transform:rotate(-8deg) scale(1.1)}
.why-card h3{font-size:1rem;margin-bottom:8px}
.why-card p{font-size:.84rem;line-height:1.72;margin:0}

/* ============================================================
   PROCESS
   ============================================================ */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;position:relative}
.proc-grid::after{content:'';position:absolute;top:44px;left:calc(12.5% + 20px);right:calc(12.5% + 20px);height:1px;background:linear-gradient(90deg,transparent,rgba(232,98,26,.35) 20%,rgba(232,98,26,.35) 80%,transparent)}
.p-step{background:var(--card);border:1px solid var(--b1);padding:28px 22px;transition:all var(--ts);position:relative}
.p-step:first-child{border-radius:var(--r2) 0 0 var(--r2)}
.p-step:last-child{border-radius:0 var(--r2) var(--r2) 0}
.p-step:hover{background:var(--card2);border-color:var(--b2);transform:translateY(-5px);z-index:2;box-shadow:0 18px 56px rgba(0,0,0,.4),0 0 36px var(--glow)}
.p-num{width:40px;height:40px;border-radius:10px;background:rgba(232,98,26,.07);border:1px solid rgba(232,98,26,.18);display:grid;place-items:center;font-family:var(--fm);font-size:.72rem;font-weight:600;color:var(--or);margin-bottom:18px;transition:all var(--t)}
.p-step:hover .p-num{background:var(--or);color:#fff;border-color:transparent;box-shadow:0 5px 18px rgba(232,98,26,.4)}
.p-icon{color:var(--or);margin-bottom:11px;transition:transform var(--t)}
.p-icon svg{width:22px;height:22px}
.p-step:hover .p-icon{transform:scale(1.15) rotate(-5deg)}
.p-step h3{font-size:.96rem;margin-bottom:7px}
.p-step p{font-size:.82rem;line-height:1.7;margin:0}
.p-time{margin-top:13px;font-family:var(--fm);font-size:.62rem;color:var(--t3);letter-spacing:.08em}

/* ============================================================
   SERVICES
   ============================================================ */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.srv-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);padding:28px 24px;transition:all var(--ts);position:relative;overflow:hidden}
.srv-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--or),var(--red));transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.srv-card:hover{border-color:var(--b2);transform:translateY(-6px);box-shadow:0 24px 68px rgba(0,0,0,.4),0 0 52px var(--glow)}
.srv-card:hover::before{transform:scaleX(1)}
.srv-icon{width:46px;height:46px;border-radius:12px;background:rgba(232,98,26,.07);border:1px solid rgba(232,98,26,.13);display:grid;place-items:center;margin-bottom:17px;color:var(--or);transition:all var(--t)}
.srv-icon svg{width:20px;height:20px}
.srv-card:hover .srv-icon{background:var(--or);color:#fff;border-color:transparent;box-shadow:0 6px 20px rgba(232,98,26,.38);transform:rotate(-8deg) scale(1.1)}
.srv-card h3{font-size:1.03rem;margin-bottom:8px}
.srv-card p{font-size:.84rem;line-height:1.7;margin-bottom:14px}
.srv-tags{display:flex;flex-wrap:wrap;gap:5px}
.srv-tag{font-size:.66rem;font-family:var(--fm);color:var(--t3);background:rgba(255,255,255,.03);border:1px solid var(--b1);border-radius:4px;padding:2px 7px}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.port-item{border-radius:var(--r2);overflow:hidden;position:relative;aspect-ratio:4/3;background:var(--card);border:1px solid var(--b1)}
.port-item--lg{grid-column:span 2;aspect-ratio:16/9}
.port-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.port-item:hover img{transform:scale(1.06)}
.port-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(7,13,24,.96) 100%);padding:20px;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity .4s var(--ease)}
.port-item:hover .port-overlay{opacity:1}
.port-overlay h3{font-size:.93rem;color:#fff;margin-bottom:4px}
.port-overlay p{font-size:.74rem;color:rgba(255,255,255,.5);margin:0}
.port-actions{display:flex;gap:7px;margin-top:10px}
.port-actions a{width:30px;height:30px;border-radius:7px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);display:grid;place-items:center;color:#fff;transition:background var(--t)}
.port-actions a:hover{background:var(--or)}
.port-actions svg{width:12px;height:12px}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.testi-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);padding:24px;transition:all var(--ts);position:relative;overflow:hidden}
.testi-card::before{content:'"';position:absolute;top:10px;right:18px;font-family:var(--fh);font-size:4.5rem;line-height:1;font-weight:800;color:rgba(232,98,26,.07)}
.testi-card:hover{border-color:var(--b2);transform:translateY(-4px);box-shadow:0 16px 52px rgba(0,0,0,.35)}
.testi-stars{display:flex;gap:3px;margin-bottom:12px}
.testi-stars svg{width:13px;height:13px;fill:var(--or);color:var(--or)}
.testi-card blockquote{font-size:.87rem;line-height:1.8;color:var(--t2);margin-bottom:17px}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-av{width:36px;height:36px;border-radius:50%;flex-shrink:0;border:2px solid var(--b2);display:grid;place-items:center;font-family:var(--fh);font-weight:700;font-size:.84rem;overflow:hidden;background:rgba(232,98,26,.08)}
.testi-name{font-size:.81rem;color:var(--t1);font-weight:600;display:block}
.testi-role{font-size:.71rem;color:var(--t3)}

/* ============================================================
   WHY2 (Dlaczego firma potrzebuje)
   ============================================================ */
.why2-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.why2-list{display:flex;flex-direction:column;gap:14px;margin:20px 0 28px}
.why2-item{display:flex;align-items:flex-start;gap:12px}
.why2-check{width:26px;height:26px;border-radius:7px;background:rgba(232,98,26,.1);border:1px solid rgba(232,98,26,.25);display:grid;place-items:center;flex-shrink:0;color:var(--or)}
.why2-check svg{width:13px;height:13px}
.why2-item p{font-size:.88rem;line-height:1.65;margin:0}
.why2-visual{position:relative}
.why2-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);overflow:hidden}
.why2-card-hdr{padding:20px 24px;border-bottom:1px solid var(--b1);background:rgba(232,98,26,.04)}
.why2-stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:20px 24px}
.why2-stat{background:rgba(255,255,255,.03);border:1px solid var(--b1);border-radius:var(--r);padding:14px;text-align:center}
.why2-stat-val{font-family:var(--fh);font-size:1.7rem;font-weight:800;color:var(--t1);letter-spacing:-.03em;line-height:1}
.why2-stat-val span{color:var(--or)}
.why2-stat-lbl{font-size:.7rem;color:var(--t3);margin-top:4px}
.why2-badge{position:absolute;top:-14px;right:-14px;background:var(--or);color:#fff;border-radius:var(--r);padding:12px 18px;text-align:center;box-shadow:0 8px 28px rgba(232,98,26,.4)}
.why2-badge strong{display:block;font-family:var(--fh);font-size:1.5rem;line-height:1}
.why2-badge span{font-size:.7rem;opacity:.9}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:7px}
.faq-item{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);overflow:hidden;transition:border-color var(--t)}
.faq-item.open{border-color:var(--b2)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;background:none;border:none;text-align:left;font-family:var(--fb);font-size:.93rem;font-weight:600;color:var(--t1);cursor:pointer;transition:color var(--t)}
.faq-q:hover{color:var(--or)}
.faq-item.open .faq-q{color:var(--or)}
.faq-icon{width:26px;height:26px;border-radius:7px;background:rgba(255,255,255,.04);border:1px solid var(--b1);display:grid;place-items:center;flex-shrink:0;transition:all var(--t)}
.faq-icon svg{width:13px;height:13px;color:var(--t3);transition:transform var(--t)}
.faq-item.open .faq-icon{background:rgba(232,98,26,.1);border-color:var(--b2)}
.faq-item.open .faq-icon svg{transform:rotate(45deg);color:var(--or)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 22px 18px;font-size:.86rem;line-height:1.8;color:var(--t2)}
.faq-item.open .faq-a{max-height:280px}

/* ============================================================
   PRICING
   ============================================================ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.price-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);padding:30px 26px;transition:all var(--ts);position:relative}
.price-card--feat{border-color:var(--b2);background:var(--card2);transform:scale(1.02)}
.price-card--feat::before{content:'Najpopularniejszy';position:absolute;top:0;left:0;right:0;text-align:center;background:var(--or);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:7px;border-radius:var(--r2) var(--r2) 0 0}
.price-card--feat .price-body{margin-top:26px}
.price-card:hover:not(.price-card--feat){border-color:var(--b2);transform:translateY(-4px);box-shadow:0 18px 56px rgba(0,0,0,.35)}
.price-name{font-family:var(--fh);font-size:.76rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--t3);margin-bottom:5px}
.price-val{display:flex;align-items:baseline;gap:3px;margin-bottom:5px}
.price-from{font-size:.74rem;color:var(--t3)}
.price-amount{font-family:var(--fh);font-size:2.6rem;font-weight:800;line-height:1;color:var(--t1);letter-spacing:-.03em}
.price-card--feat .price-amount{color:var(--or)}
.price-currency{font-size:.95rem;color:var(--t2);align-self:flex-end;margin-bottom:3px}
.price-desc{font-size:.8rem;color:var(--t3);margin-bottom:18px}
.price-hr{height:1px;background:var(--b1);margin-block:18px}
.price-feats{display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.price-feat{display:flex;align-items:flex-start;gap:9px;font-size:.83rem;color:var(--t2)}
.pf-icon{width:17px;height:17px;border-radius:50%;background:rgba(232,98,26,.1);border:1px solid rgba(232,98,26,.25);display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.pf-icon svg{width:9px;height:9px;color:var(--or)}
.pf-icon.no{background:rgba(255,255,255,.03);border-color:var(--b1)}
.pf-icon.no svg{color:var(--t3)}
.price-feat.dim{color:var(--t3)}
.price-badge-sm{display:inline-flex;align-items:center;gap:5px;font-size:.7rem;font-family:var(--fm);color:var(--or);background:rgba(232,98,26,.08);border:1px solid rgba(232,98,26,.2);border-radius:4px;padding:3px 8px;margin-bottom:18px}

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.blog-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r2);overflow:hidden;transition:all var(--ts);display:flex;flex-direction:column}
.blog-card:hover{border-color:var(--b2);transform:translateY(-5px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.blog-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--bg2);flex-shrink:0}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.blog-card:hover .blog-thumb img{transform:scale(1.05)}
.blog-body{padding:20px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;align-items:center;gap:8px;margin-bottom:9px;flex-wrap:wrap}
.blog-cat{font-size:.63rem;font-family:var(--fm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--or);background:rgba(232,98,26,.08);border-radius:4px;padding:2px 7px}
.blog-date{font-size:.72rem;color:var(--t3)}
.blog-body h3{font-size:.96rem;margin-bottom:7px;line-height:1.45}
.blog-body h3 a{color:var(--t1);transition:color var(--t)}
.blog-card:hover h3 a{color:var(--or)}
.blog-body p{font-size:.82rem;line-height:1.7;margin-bottom:12px}
.blog-more{display:inline-flex;align-items:center;gap:5px;font-size:.77rem;font-weight:600;color:var(--or);transition:gap var(--t);margin-top:auto}
.blog-more:hover{gap:9px;color:var(--or2)}
.blog-more svg{width:12px;height:12px}

/* ============================================================
   CTA
   ============================================================ */
.cta-sec{padding-block:100px;position:relative;overflow:hidden;background:var(--bg)}
.cta-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 90% at 50% 50%,rgba(232,98,26,.09),transparent 68%);animation:ctaB 5s ease-in-out infinite alternate}
@keyframes ctaB{0%{opacity:.6;transform:scale(.94)}100%{opacity:1;transform:scale(1.06)}}
.cta-inner{position:relative;text-align:center;max-width:620px;margin:0 auto}
.cta-inner h2{margin-bottom:12px}
.cta-inner p{font-size:1.03rem;margin-bottom:32px}
.cta-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:50px;align-items:start}
.contact-items{display:flex;flex-direction:column;gap:14px;margin-top:20px}
.contact-item{display:flex;gap:12px;align-items:flex-start}
.ci-icon{width:36px;height:36px;border-radius:9px;background:rgba(232,98,26,.07);border:1px solid rgba(232,98,26,.18);display:grid;place-items:center;flex-shrink:0;color:var(--or)}
.ci-icon svg{width:16px;height:16px}
.contact-item h4{font-size:.73rem;color:var(--t3);margin-bottom:2px;font-weight:500}
.contact-item a,.contact-item span{color:var(--t1);font-weight:500;font-size:.88rem;transition:color var(--t)}
.contact-item a:hover{color:var(--or)}
.form-wrap{background:var(--card);border:1px solid var(--b1);border-radius:var(--r3);padding:36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-g{margin-bottom:12px}
.form-g label{display:block;font-size:.75rem;font-weight:500;color:var(--t2);margin-bottom:5px}
.form-g input,.form-g textarea,.form-g select{width:100%;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07);border-radius:var(--r);color:var(--t1);font-family:var(--fb);font-size:.88rem;padding:11px 13px;transition:all var(--t);outline:none;-webkit-appearance:none}
.form-g input:focus,.form-g textarea:focus,.form-g select:focus{border-color:var(--or);background:rgba(232,98,26,.04);box-shadow:0 0 0 3px rgba(232,98,26,.08)}
.form-g textarea{resize:vertical;min-height:115px}
.form-g input::placeholder,.form-g textarea::placeholder{color:var(--t3)}
.form-g select option{background:var(--card);color:var(--t1)}
#form-msg{display:none;margin-bottom:11px;padding:10px 13px;border-radius:8px;font-size:.83rem}

/* ============================================================
   FOOTER – logo fix + clean layout
   ============================================================ */
.site-footer{background:var(--bg);border-top:1px solid var(--b1);padding-top:64px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--b1)}

/* CRITICAL: Limit logo size in footer */
.footer-logo-link{display:inline-flex;align-items:center;margin-bottom:0}
.footer-logo-link img{
  height:52px !important;
  width:auto !important;
  max-width:160px !important;
  object-fit:contain;
}
.footer-logo-link .custom-logo-link img{
  height:52px !important;
  width:auto !important;
  max-width:160px !important;
}
/* WordPress wraps logo in .custom-logo-link */
.footer-logo-link .custom-logo-link{display:inline-flex}

.footer-tagline{font-size:.82rem;color:var(--t2);margin-top:13px;margin-bottom:18px;max-width:240px;line-height:1.75}
.footer-socials{display:flex;gap:7px}
.f-social{width:32px;height:32px;border-radius:7px;background:rgba(255,255,255,.03);border:1px solid var(--b1);display:grid;place-items:center;color:var(--t2);transition:all var(--t)}
.f-social:hover{background:rgba(232,98,26,.1);border-color:var(--b2);color:var(--or);transform:translateY(-2px)}
.f-social svg{width:14px;height:14px}

.footer-col h4{font-size:.68rem;font-weight:700;color:var(--t1);margin-bottom:12px;letter-spacing:.12em;text-transform:uppercase}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col ul a{font-size:.8rem;color:var(--t2);transition:color var(--t)}
.footer-col ul a:hover{color:var(--or)}
.f-contact-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--t2);transition:color var(--t);text-decoration:none}
.f-contact-item:hover{color:var(--or)}
.f-contact-item svg{width:13px;height:13px;color:var(--t3);flex-shrink:0}

.footer-bottom{padding:16px 0;display:flex;align-items:center;justify-content:space-between;gap:13px;flex-wrap:wrap}
.footer-bottom p{font-size:.74rem;color:var(--t3);margin:0}
.footer-bottom strong{color:var(--t2)}
.footer-made{color:var(--t3)!important}

/* ============================================================
   POST CONTENT
   ============================================================ */
.post-hdr{padding-top:122px;padding-bottom:48px;background:var(--bg);border-bottom:1px solid var(--b1)}
.post-hdr h1{max-width:800px;margin-bottom:16px}
.post-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:.78rem;color:var(--t3)}
.post-meta span{display:flex;align-items:center;gap:4px}
.post-meta svg{width:13px;height:13px}
.post-img{max-width:840px;margin:48px auto;border-radius:var(--r2);overflow:hidden;border:1px solid var(--b1)}
.post-img img{width:100%;height:auto}
.post-body{max-width:700px;margin:0 auto;padding-block:48px}
.post-body h2,.post-body h3,.post-body h4{margin:2em 0 .7em}
.post-body p{margin-bottom:1.4em;font-size:1.02rem;line-height:1.9;color:var(--t2)}
.post-body ul,.post-body ol{margin:1.2em 0 1.4em 1.5em}
.post-body li{margin-bottom:.5em;color:var(--t2)}
.post-body strong{color:var(--t1)}
.post-body a{color:var(--or)}
.post-body code{font-family:var(--fm);font-size:.82em;background:rgba(255,255,255,.06);border:1px solid var(--b1);border-radius:5px;padding:2px 6px;color:var(--or2)}
.post-body pre{background:var(--bg);border:1px solid var(--b1);border-radius:var(--r);padding:20px;overflow-x:auto;margin:1.5em 0}
.post-body pre code{background:none;border:none;padding:0}
.post-body blockquote{border-left:2px solid var(--or);padding:13px 20px;background:var(--card);border-radius:0 var(--r) var(--r) 0;margin:1.5em 0;color:var(--t2)}

/* ============================================================
   ARCHIVE & PAGINATION
   ============================================================ */
.archive-hdr{padding-top:122px;padding-bottom:48px;background:var(--bg)}
.arc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding-block:68px}
.pagination{display:flex;justify-content:center;gap:7px;padding:48px 0}
.page-numbers{width:40px;height:40px;border-radius:7px;display:grid;place-items:center;font-weight:600;font-size:.84rem;background:var(--card);border:1px solid var(--b1);color:var(--t2);transition:all var(--t)}
.page-numbers:hover,.page-numbers.current{background:var(--or);border-color:var(--or);color:#fff}
.breadcrumbs{font-size:.75rem;color:var(--t3);display:flex;align-items:center;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.breadcrumbs a{color:var(--t3);transition:color var(--t)}
.breadcrumbs a:hover{color:var(--or)}
.breadcrumbs .sep{opacity:.3}
.breadcrumbs .current{color:var(--or)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.rev{opacity:0;transform:translateY(22px);transition:opacity .68s var(--ease),transform .68s var(--ease)}
.rev.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.07s}.d2{transition-delay:.13s}.d3{transition-delay:.2s}
.d4{transition-delay:.27s}.d5{transition-delay:.34s}.d6{transition-delay:.41s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  :root{--S:80px}
  .hero-card{grid-template-columns:1fr}
  .hero-card-img{display:none}
  .srv-grid,.testi-grid,.blog-grid,.arc-grid{grid-template-columns:repeat(2,1fr)}
  .port-grid{grid-template-columns:repeat(2,1fr)}
  .port-item--lg{grid-column:span 1;aspect-ratio:4/3}
  .proc-grid{grid-template-columns:repeat(2,1fr)}
  .proc-grid::after{display:none}
  .p-step:first-child{border-radius:var(--r2) 0 0 0}
  .p-step:nth-child(2){border-radius:0 var(--r2) 0 0}
  .p-step:nth-child(3){border-radius:0 0 0 var(--r2)}
  .p-step:last-child{border-radius:0 0 var(--r2) 0}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .why2-grid{grid-template-columns:1fr;gap:36px}
  .why2-visual{display:none}
  .pricing-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .price-card--feat{transform:none}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
}
@media(max-width:768px){
  :root{--S:60px}
  .main-nav,.header-actions .btn-o{display:none}
  .nav-toggle{display:flex}
  .srv-grid,.port-grid,.testi-grid,.blog-grid,.arc-grid,.why-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr}
  .p-step{border-radius:var(--r2)!important}
  .footer-top{grid-template-columns:1fr;gap:24px}
  .form-row{grid-template-columns:1fr}
  .hero-card-body{padding:32px 24px}
  .hero-badges{gap:6px}
  .form-wrap{padding:24px 18px}
}
@media(max-width:480px){
  h1{font-size:1.9rem}
  .hero-btns,.cta-btns{flex-direction:column}
  .hero-btns .btn,.cta-btns .btn{justify-content:center}
}

/* ============================================================
   LOGO FIX – header i footer
   ============================================================ */
.site-logo img,
.site-logo .custom-logo-link img,
.site-logo .custom-logo {
  height: 40px !important;
  width: auto !important;
  max-width: 160px !important;
  max-height: 40px !important;
  object-fit: contain !important;
}
.site-logo .custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  max-height: 40px !important;
  overflow: hidden !important;
}
.footer-logo-link img,
.footer-logo-link .custom-logo-link img,
.footer-logo-link .custom-logo,
.footer-brand img,
.footer-brand .custom-logo {
  height: 50px !important;
  width: auto !important;
  max-width: 180px !important;
  max-height: 50px !important;
  object-fit: contain !important;
}
.footer-logo-link,
.footer-logo-link .custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  max-height: 50px !important;
  overflow: hidden !important;
}

/* ============================================================
   AURORA ANIMATED BACKGROUND
   ============================================================ */
.hd-aurora {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.hd-aurora::before {
  content: '';
  position: absolute;
  width: 150vw; height: 150vw;
  top: -50vw; left: -25vw;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(232,98,26,.07) 0%,
    rgba(59,130,246,.04) 35%,
    transparent 65%);
  animation: auroraR 22s linear infinite;
  transform-origin: 60% 50%;
}
.hd-aurora::after {
  content: '';
  position: absolute;
  width: 130vw; height: 130vw;
  bottom: -45vw; right: -20vw;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(192,57,43,.05) 0%,
    rgba(232,98,26,.04) 30%,
    transparent 60%);
  animation: auroraR 30s linear infinite reverse;
  transform-origin: 40% 50%;
}
@keyframes auroraR {
  0%   { transform: rotate(0deg) scale(1); }
  50%  { transform: rotate(180deg) scale(1.08); }
  100% { transform: rotate(360deg) scale(1); }
}
.aurora-orb {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  filter: blur(70px);
  animation: orbF 12s ease-in-out infinite;
}
.aurora-orb-1 {
  width: 480px; height: 480px;
  top: -80px; right: -80px;
  background: radial-gradient(circle, rgba(232,98,26,.09), transparent 70%);
}
.aurora-orb-2 {
  width: 380px; height: 380px;
  bottom: 25%; left: -60px;
  background: radial-gradient(circle, rgba(59,130,246,.07), transparent 70%);
  animation-delay: -4s; animation-duration: 16s;
}
.aurora-orb-3 {
  width: 320px; height: 320px;
  top: 45%; right: 12%;
  background: radial-gradient(circle, rgba(192,57,43,.06), transparent 70%);
  animation-delay: -8s; animation-duration: 19s;
}
@keyframes orbF {
  0%,100% { transform: translateY(0) scale(1); }
  33% { transform: translateY(-28px) scale(1.04); }
  66% { transform: translateY(18px) scale(0.97); }
}
.hero-wrap, section, .page-hero,
.site-footer, .blog-page-hero {
  position: relative;
  z-index: 1;
}

/* ============================================================
   TESTIMONIALS SLIDER – Google style
   ============================================================ */
.testi-slider-outer {
  position: relative;
  overflow: hidden;
}
.testi-slider {
  display: flex;
  gap: 20px;
  transition: transform 0.5s cubic-bezier(0.22,1,0.36,1);
  will-change: transform;
  cursor: grab;
  user-select: none;
}
.testi-slider:active { cursor: grabbing; }
.testi-slide {
  flex: 0 0 calc(33.333% - 14px);
  min-width: 0;
}

/* Google-style card */
.tg-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 22px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: all var(--ts);
}
.tg-card:hover {
  border-color: var(--b2);
  transform: translateY(-3px);
  box-shadow: 0 14px 44px rgba(0,0,0,.3);
}
.tg-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.tg-author {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tg-av {
  width: 42px; height: 42px;
  border-radius: 50%;
  flex-shrink: 0;
  display: grid; place-items: center;
  font-family: var(--fh);
  font-weight: 700; font-size: .95rem;
  border: 2px solid transparent;
}
.tg-name {
  font-size: .85rem; font-weight: 600;
  color: var(--t1); display: block; line-height: 1.2;
}
.tg-role {
  font-size: .72rem; color: var(--t3);
  display: block; margin-top: 2px;
}
.tg-google {
  display: flex; align-items: center; gap: 4px; flex-shrink: 0;
}
.tg-google svg { width: 18px; height: 18px; }
.tg-stars { display: flex; gap: 2px; }
.tg-stars svg { width: 14px; height: 14px; fill: #fbbc04; color: #fbbc04; }
.tg-card blockquote {
  font-size: .87rem; line-height: 1.8;
  color: var(--t2); flex: 1;
  padding-left: 12px;
  border-left: 2px solid rgba(232,98,26,.35);
}
.tg-date { font-size: .7rem; color: var(--t3); font-family: var(--fm); }

/* Slider controls */
.testi-controls {
  display: flex; align-items: center;
  justify-content: center;
  gap: 14px; margin-top: 28px;
}
.testi-btn {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--card);
  border: 1px solid var(--b1);
  display: grid; place-items: center;
  color: var(--t2);
  transition: all var(--t);
  cursor: pointer;
}
.testi-btn:hover:not(:disabled) {
  background: var(--card2);
  border-color: var(--b2);
  color: var(--or);
  transform: scale(1.08);
}
.testi-btn:disabled { opacity: .3; cursor: default; }
.testi-btn svg { width: 17px; height: 17px; }
.testi-dots { display: flex; gap: 6px; align-items: center; }
.testi-dot {
  width: 6px; height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,.1);
  transition: all .3s;
  cursor: pointer;
}
.testi-dot.active { width: 22px; background: var(--or); }

/* Google rating bar */
.testi-rating-row {
  display: flex; align-items: center; gap: 20px;
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 20px 24px;
  margin-bottom: 28px;
}
.testi-avg-num {
  font-family: var(--fh);
  font-size: 3.2rem; font-weight: 800;
  line-height: 1; color: var(--t1);
  letter-spacing: -.03em;
}
.testi-avg-stars { display: flex; gap: 3px; margin: 5px 0 3px; }
.testi-avg-stars svg { width: 14px; height: 14px; fill: #fbbc04; color: #fbbc04; }
.testi-avg-label { font-size: .72rem; color: var(--t3); }
.testi-divider { width: 1px; height: 56px; background: var(--b1); flex-shrink: 0; }
.testi-bars { flex: 1; display: flex; flex-direction: column; gap: 5px; }
.testi-bar-row { display: flex; align-items: center; gap: 8px; font-size: .72rem; }
.testi-bar-lbl { color: var(--t3); width: 38px; text-align: right; flex-shrink: 0; }
.testi-bar-track { flex: 1; height: 5px; background: rgba(255,255,255,.06); border-radius: 3px; overflow: hidden; }
.testi-bar-fill { height: 100%; border-radius: 3px; background: #fbbc04; }
.testi-bar-n { color: var(--t3); width: 16px; flex-shrink: 0; }

/* ============================================================
   BLOG – professional agency layout
   ============================================================ */
.blog-page-hero {
  padding-top: 128px; padding-bottom: 56px;
  background: var(--bg); position: relative; overflow: hidden;
}
.blog-page-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 80% at 80% 40%, rgba(232,98,26,.07), transparent 60%);
}
.blog-page-inner { position: relative; z-index: 1; }

.blog-filters {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px;
}
.blog-filter-btn {
  font-size: .77rem; font-weight: 600;
  color: var(--t2); background: var(--card);
  border: 1px solid var(--b1); border-radius: 100px;
  padding: 7px 16px; cursor: pointer; transition: all var(--t);
  text-decoration: none;
}
.blog-filter-btn:hover, .blog-filter-btn.active {
  color: var(--t1);
  background: rgba(232,98,26,.1);
  border-color: var(--b2);
}

.blog-layout { display: grid; grid-template-columns: 1fr 290px; gap: 28px; align-items: start; }
.blog-sidebar { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 90px; }

.sidebar-widget {
  background: var(--card); border: 1px solid var(--b1);
  border-radius: var(--r2); padding: 20px;
}
.sidebar-widget h4 {
  font-size: .72rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--t1); margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 1px solid var(--b1);
}
.sidebar-cats { display: flex; flex-direction: column; gap: 5px; }
.sidebar-cat {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 11px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--b1); border-radius: 7px;
  font-size: .8rem; color: var(--t2);
  text-decoration: none; transition: all var(--t);
}
.sidebar-cat:hover { border-color: var(--b2); color: var(--or); background: rgba(232,98,26,.05); }
.sidebar-cat-count {
  font-size: .68rem; font-family: var(--fm); color: var(--t3);
  background: rgba(255,255,255,.04); border-radius: 4px; padding: 1px 6px;
}
.sidebar-recent-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 9px 0; border-bottom: 1px solid var(--b1);
}
.sidebar-recent-item:last-child { border-bottom: none; padding-bottom: 0; }
.sidebar-recent-thumb {
  width: 50px; height: 40px; border-radius: 6px;
  overflow: hidden; flex-shrink: 0; background: var(--bg2);
}
.sidebar-recent-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sidebar-recent-title {
  font-size: .79rem; font-weight: 600; color: var(--t1);
  line-height: 1.4; text-decoration: none; transition: color var(--t); display: block;
}
.sidebar-recent-title:hover { color: var(--or); }
.sidebar-recent-date { font-size: .68rem; color: var(--t3); margin-top: 3px; }
.sidebar-cta {
  background: linear-gradient(135deg, rgba(232,98,26,.1), rgba(192,57,43,.06));
  border: 1px solid var(--b2); border-radius: var(--r2); padding: 22px; text-align: center;
}
.sidebar-cta h4 { border-bottom: none; letter-spacing: 0; text-transform: none; font-size: .92rem; margin-bottom: 8px; }
.sidebar-cta p { font-size: .8rem; margin-bottom: 14px; }

/* Featured post */
.blog-featured {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 0;
  background: var(--card); border: 1px solid var(--b1);
  border-radius: var(--r2); overflow: hidden; margin-bottom: 24px;
  transition: all var(--ts);
}
.blog-featured:hover { border-color: var(--b2); box-shadow: 0 18px 56px rgba(0,0,0,.4); }
.blog-featured-img { aspect-ratio: 16/10; overflow: hidden; position: relative; }
.blog-featured-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.blog-featured:hover .blog-featured-img img { transform: scale(1.04); }
.blog-featured-badge {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  background: var(--or); color: #fff;
  font-size: .65rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; padding: 4px 11px; border-radius: 100px;
}
.blog-featured-body {
  padding: 32px 28px; display: flex; flex-direction: column; justify-content: center; gap: 14px;
}
.blog-featured-body h2 { font-size: clamp(1.1rem,2vw,1.6rem); line-height: 1.3; margin: 0; }
.blog-featured-body h2 a { color: var(--t1); transition: color var(--t); }
.blog-featured:hover .blog-featured-body h2 a { color: var(--or); }
.blog-featured-body > p { font-size: .88rem; line-height: 1.72; margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.blog-author { display: flex; align-items: center; gap: 9px; padding-top: 14px; border-top: 1px solid var(--b1); margin-top: auto; }
.blog-author-av { width: 32px; height: 32px; border-radius: 50%; background: rgba(232,98,26,.1); border: 2px solid var(--b2); display: grid; place-items: center; font-family: var(--fh); font-weight: 700; font-size: .78rem; color: var(--or); flex-shrink: 0; }
.blog-author-name { font-size: .79rem; font-weight: 600; color: var(--t1); }
.blog-author-date { font-size: .7rem; color: var(--t3); }
.blog-read-time { margin-left: auto; font-size: .7rem; color: var(--t3); font-family: var(--fm); display: flex; align-items: center; gap: 3px; }
.blog-read-time svg { width: 11px; height: 11px; }

.blog-tag {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .62rem; font-family: var(--fm); font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--or); background: rgba(232,98,26,.08);
  border-radius: 4px; padding: 3px 8px; margin-bottom: 9px;
  text-decoration: none; transition: background var(--t); display: inline-block;
}
.blog-tag:hover { background: rgba(232,98,26,.15); color: var(--or); }

.blog-card-v2 {
  background: var(--card); border: 1px solid var(--b1);
  border-radius: var(--r2); overflow: hidden;
  transition: all var(--ts); display: flex; flex-direction: column; height: 100%;
}
.blog-card-v2:hover { border-color: var(--b2); transform: translateY(-4px); box-shadow: 0 18px 56px rgba(0,0,0,.4); }
.blog-card-v2 .blog-thumb { aspect-ratio: 16/9; overflow: hidden; background: var(--bg2); flex-shrink: 0; }
.blog-card-v2 .blog-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
.blog-card-v2:hover .blog-thumb img { transform: scale(1.05); }
.blog-card-v2 .blog-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.blog-card-v2 h3 { font-size: .94rem; margin-bottom: 7px; line-height: 1.45; }
.blog-card-v2 h3 a { color: var(--t1); transition: color var(--t); }
.blog-card-v2:hover h3 a { color: var(--or); }
.blog-card-v2 p { font-size: .81rem; line-height: 1.7; margin-bottom: 12px; }
.blog-more {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .77rem; font-weight: 600; color: var(--or);
  transition: gap var(--t); margin-top: auto; text-decoration: none;
}
.blog-more:hover { gap: 9px; color: var(--or2); }
.blog-more svg { width: 12px; height: 12px; }

@media(max-width:1024px){
  .blog-layout { grid-template-columns: 1fr; }
  .blog-sidebar { position: static; }
  .blog-featured { grid-template-columns: 1fr; }
  .testi-slide { flex: 0 0 calc(50% - 10px); }
}
@media(max-width:768px){
  .testi-slide { flex: 0 0 100%; }
  .testi-rating-row { flex-direction: column; gap: 12px; }
  .testi-divider { width: 80%; height: 1px; }
  .blog-featured { grid-template-columns: 1fr; }
}

/* ============================================================
   LOGO FIX – bardzo agresywne ograniczenie rozmiaru
   ============================================================ */

/* Header logo */
.site-header .site-logo,
.site-header .site-logo a,
.site-header .site-logo .custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  max-height: 42px !important;
  overflow: hidden !important;
  line-height: 1 !important;
}
.site-header .site-logo img,
.site-header .site-logo .custom-logo,
.site-header .custom-logo-link img,
header .custom-logo {
  height: 38px !important;
  width: auto !important;
  max-height: 38px !important;
  max-width: 160px !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Footer logo – ograniczamy do rozsądnego rozmiaru */
.site-footer .footer-logo-link,
.site-footer .footer-logo-link .custom-logo-link,
.footer-brand .footer-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  max-height: 54px !important;
  overflow: hidden !important;
}
.site-footer .footer-logo-link img,
.site-footer .footer-logo-link .custom-logo,
.site-footer .custom-logo-link img,
.footer-brand img,
.footer-brand .custom-logo,
footer .custom-logo {
  height: 48px !important;
  width: auto !important;
  max-height: 48px !important;
  max-width: 180px !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 !important;
}

/* ============================================================
   AURORA ANIMATED BACKGROUND
   ============================================================ */
.hd-aurora {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; overflow: hidden;
}
.hd-aurora::before {
  content: ''; position: absolute;
  width: 150vw; height: 150vw; top: -50vw; left: -25vw;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(232,98,26,.07) 0%, rgba(59,130,246,.04) 35%, transparent 65%);
  animation: auroraR 22s linear infinite;
  transform-origin: 60% 50%;
}
.hd-aurora::after {
  content: ''; position: absolute;
  width: 130vw; height: 130vw; bottom: -45vw; right: -20vw;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(192,57,43,.05) 0%, rgba(232,98,26,.04) 30%, transparent 60%);
  animation: auroraR 30s linear infinite reverse;
  transform-origin: 40% 50%;
}
@keyframes auroraR {
  0%   { transform: rotate(0deg) scale(1); }
  50%  { transform: rotate(180deg) scale(1.08); }
  100% { transform: rotate(360deg) scale(1); }
}
.aurora-orb {
  position: fixed; border-radius: 50%; pointer-events: none; z-index: 0;
  filter: blur(70px); animation: orbF 12s ease-in-out infinite;
}
.aurora-orb-1 { width:480px;height:480px;top:-80px;right:-80px;background:radial-gradient(circle,rgba(232,98,26,.09),transparent 70%); }
.aurora-orb-2 { width:380px;height:380px;bottom:25%;left:-60px;background:radial-gradient(circle,rgba(59,130,246,.07),transparent 70%);animation-delay:-4s;animation-duration:16s; }
.aurora-orb-3 { width:320px;height:320px;top:45%;right:12%;background:radial-gradient(circle,rgba(192,57,43,.06),transparent 70%);animation-delay:-8s;animation-duration:19s; }
@keyframes orbF {
  0%,100% { transform: translateY(0) scale(1); }
  33% { transform: translateY(-28px) scale(1.04); }
  66% { transform: translateY(18px) scale(0.97); }
}
.hero-wrap,section,.page-hero,.site-footer,
.blog-page-hero { position:relative; z-index:1; }

/* ============================================================
   BLOG HOME – kompletny ciemny styl
   ============================================================ */
.blog-page-hero {
  padding-top: 110px; padding-bottom: 52px;
  background: var(--bg); position: relative; overflow: hidden;
}
.blog-page-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 80% at 80% 40%,
    rgba(232,98,26,.07), transparent 60%);
}
.blog-page-inner { position: relative; z-index: 1; }
.blog-page-hero h1 { color: var(--t1); margin-top: 10px; }
.blog-page-hero p  { color: var(--t2); max-width: 520px; margin-top: 10px; }

/* Filtry */
.blog-filters { display:flex; gap:8px; flex-wrap:wrap; margin-top:22px; }
.blog-filter-btn {
  font-size:.76rem; font-weight:600; color:var(--t2);
  background:var(--card); border:1px solid var(--b1);
  border-radius:100px; padding:7px 16px;
  cursor:pointer; transition:all var(--t); text-decoration:none;
}
.blog-filter-btn:hover, .blog-filter-btn.active {
  color:var(--t1); background:rgba(232,98,26,.1); border-color:var(--b2);
}

/* Layout */
.blog-layout { display:grid; grid-template-columns:1fr 280px; gap:28px; align-items:start; }
.blog-posts-main { min-width: 0; }

/* Featured */
.blog-featured {
  display:grid; grid-template-columns:1.3fr 1fr; gap:0;
  background:var(--card); border:1px solid var(--b1);
  border-radius:var(--r2); overflow:hidden; margin-bottom:20px;
  transition:all var(--ts);
}
.blog-featured:hover { border-color:var(--b2); box-shadow:0 16px 52px rgba(0,0,0,.4); }
.blog-featured-img { aspect-ratio:16/10; overflow:hidden; position:relative; background:var(--card2); }
.blog-featured-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.blog-featured:hover .blog-featured-img img { transform:scale(1.04); }
.blog-featured-badge {
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--or); color:#fff;
  font-size:.63rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; padding:4px 11px; border-radius:100px;
}
.blog-featured-body {
  padding:28px 24px; display:flex; flex-direction:column;
  justify-content:center; gap:12px; background:var(--card);
}
.blog-featured-body h2 { font-size:clamp(1rem,2vw,1.5rem); line-height:1.3; margin:0; color:var(--t1); }
.blog-featured-body h2 a { color:var(--t1); transition:color var(--t); }
.blog-featured:hover .blog-featured-body h2 a { color:var(--or); }
.blog-featured-body > p { font-size:.86rem; line-height:1.72; margin:0; color:var(--t2); }
.blog-author {
  display:flex; align-items:center; gap:9px;
  padding-top:12px; border-top:1px solid var(--b1); margin-top:auto;
}
.blog-author-av {
  width:30px; height:30px; border-radius:50%;
  background:rgba(232,98,26,.1); border:2px solid var(--b2);
  display:grid; place-items:center;
  font-family:var(--fh); font-weight:700; font-size:.76rem;
  color:var(--or); flex-shrink:0;
}
.blog-author-name { font-size:.77rem; font-weight:600; color:var(--t1); }
.blog-author-date { font-size:.68rem; color:var(--t3); }
.blog-read-time { margin-left:auto; font-size:.68rem; color:var(--t3); font-family:var(--fm); display:flex; align-items:center; gap:3px; }
.blog-read-time svg { width:11px; height:11px; }

/* Blog tag */
.blog-tag {
  display:inline-block; font-size:.62rem; font-family:var(--fm);
  font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--or); background:rgba(232,98,26,.08);
  border-radius:4px; padding:3px 8px; margin-bottom:8px;
  text-decoration:none; transition:background var(--t);
}
.blog-tag:hover { background:rgba(232,98,26,.15); color:var(--or); }

/* Cards grid */
.blog-cards-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:16px; margin-top:16px;
}

/* Blog card v2 */
.blog-card-v2 {
  background:var(--card) !important; border:1px solid var(--b1) !important;
  border-radius:var(--r2); overflow:hidden;
  transition:all var(--ts); display:flex; flex-direction:column;
}
.blog-card-v2:hover { border-color:var(--b2) !important; transform:translateY(-4px); box-shadow:0 16px 48px rgba(0,0,0,.4); }
.blog-card-v2 .blog-thumb { aspect-ratio:16/9; overflow:hidden; background:var(--card2); flex-shrink:0; }
.blog-card-v2 .blog-thumb.blog-thumb-placeholder {
  display:flex; align-items:center; justify-content:center; min-height:120px;
  background:linear-gradient(135deg,var(--card),var(--card2));
}
.blog-card-v2 .blog-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.blog-card-v2:hover .blog-thumb img { transform:scale(1.05); }
.blog-card-v2 .blog-body { padding:18px; flex:1; display:flex; flex-direction:column; background:var(--card); }
.blog-card-v2 h3 { font-size:.9rem; margin-bottom:7px; line-height:1.45; color:var(--t1); }
.blog-card-v2 h3 a { color:var(--t1) !important; transition:color var(--t); }
.blog-card-v2:hover h3 a { color:var(--or) !important; }
.blog-card-v2 p { font-size:.8rem; line-height:1.7; margin-bottom:10px; color:var(--t2); }

.blog-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  margin-top:auto; padding-top:10px; border-top:1px solid var(--b1);
}
.blog-card-date { font-size:.7rem; color:var(--t3); }

.blog-more {
  display:inline-flex; align-items:center; gap:4px;
  font-size:.76rem; font-weight:600; color:var(--or);
  transition:gap var(--t); text-decoration:none;
}
.blog-more:hover { gap:8px; color:var(--or2); }
.blog-more svg { width:11px; height:11px; }

/* Paginacja bloga */
.blog-pagination { display:flex; justify-content:flex-start; gap:7px; padding:32px 0 0; flex-wrap:wrap; }
.blog-pagination .page-numbers {
  width:40px; height:40px; border-radius:7px; display:grid;
  place-items:center; font-weight:600; font-size:.83rem;
  background:var(--card); border:1px solid var(--b1);
  color:var(--t2); transition:all var(--t); text-decoration:none;
}
.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current { background:var(--or); border-color:var(--or); color:#fff; }
.blog-pagination .prev,
.blog-pagination .next { width:auto; padding:0 14px; font-size:.78rem; }

/* Sidebar */
.blog-sidebar { display:flex; flex-direction:column; gap:16px; position:sticky; top:86px; }
.sidebar-widget {
  background:var(--card); border:1px solid var(--b1);
  border-radius:var(--r2); padding:18px;
}
.sidebar-widget h4 {
  font-size:.7rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--t1);
  margin-bottom:13px; padding-bottom:9px; border-bottom:1px solid var(--b1);
}
.sidebar-search-form { display:flex; gap:7px; }
.sidebar-search-input {
  flex:1; background:rgba(255,255,255,.03); border:1px solid var(--b1);
  border-radius:var(--r); color:var(--t1); font-family:var(--fb);
  font-size:.83rem; padding:9px 12px; outline:none; min-width:0;
  transition:border-color var(--t);
}
.sidebar-search-input:focus { border-color:var(--or); }
.sidebar-search-input::placeholder { color:var(--t3); }
.sidebar-search-btn { padding:9px 12px; border-radius:var(--r); flex-shrink:0; }

.sidebar-cats { display:flex; flex-direction:column; gap:5px; }
.sidebar-cat {
  display:flex; align-items:center; justify-content:space-between;
  padding:7px 10px; background:rgba(255,255,255,.025);
  border:1px solid var(--b1); border-radius:7px;
  font-size:.79rem; color:var(--t2); text-decoration:none; transition:all var(--t);
}
.sidebar-cat:hover { border-color:var(--b2); color:var(--or); background:rgba(232,98,26,.05); }
.sidebar-cat-count {
  font-size:.67rem; font-family:var(--fm); color:var(--t3);
  background:rgba(255,255,255,.04); border-radius:4px; padding:1px 6px;
}
.sidebar-recent-item {
  display:flex; gap:10px; align-items:flex-start;
  padding:9px 0; border-bottom:1px solid var(--b1);
}
.sidebar-recent-item:last-child { border-bottom:none; padding-bottom:0; }
.sidebar-recent-thumb { width:50px; height:40px; border-radius:6px; overflow:hidden; flex-shrink:0; background:var(--bg2); }
.sidebar-recent-thumb img { width:100%; height:100%; object-fit:cover; }
.sidebar-recent-title { font-size:.78rem; font-weight:600; color:var(--t1); line-height:1.4; text-decoration:none; transition:color var(--t); display:block; }
.sidebar-recent-title:hover { color:var(--or); }
.sidebar-recent-date { font-size:.67rem; color:var(--t3); margin-top:3px; }
.sidebar-cta {
  background:linear-gradient(135deg,rgba(232,98,26,.1),rgba(192,57,43,.06));
  border:1px solid var(--b2); border-radius:var(--r2); padding:20px; text-align:center;
}
.sidebar-cta h4 { border-bottom:none; letter-spacing:0; text-transform:none; font-size:.9rem; margin-bottom:8px; }
.sidebar-cta p { font-size:.79rem; margin-bottom:13px; color:var(--t2); }

/* ============================================================
   TESTIMONIALS SLIDER – Google style
   ============================================================ */
.testi-slider-outer { position:relative; overflow:hidden; }
.testi-slider {
  display:flex; gap:20px;
  transition:transform 0.5s cubic-bezier(0.22,1,0.36,1);
  will-change:transform; cursor:grab; user-select:none;
}
.testi-slider:active { cursor:grabbing; }
.testi-slide { flex:0 0 calc(33.333% - 14px); min-width:0; }

.tg-card {
  background:var(--card); border:1px solid var(--b1);
  border-radius:var(--r2); padding:20px; height:100%;
  display:flex; flex-direction:column; gap:13px; transition:all var(--ts);
}
.tg-card:hover { border-color:var(--b2); transform:translateY(-3px); box-shadow:0 13px 40px rgba(0,0,0,.3); }
.tg-header { display:flex; align-items:center; justify-content:space-between; }
.tg-author { display:flex; align-items:center; gap:10px; }
.tg-av {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  display:grid; place-items:center;
  font-family:var(--fh); font-weight:700; font-size:.9rem;
}
.tg-name { font-size:.83rem; font-weight:600; color:var(--t1); display:block; line-height:1.2; }
.tg-role { font-size:.7rem; color:var(--t3); display:block; margin-top:2px; }
.tg-google { display:flex; align-items:center; gap:3px; flex-shrink:0; }
.tg-google svg { width:18px; height:18px; }
.tg-stars { display:flex; gap:2px; }
.tg-stars svg { width:13px; height:13px; fill:#fbbc04; color:#fbbc04; }
.tg-card blockquote {
  font-size:.85rem; line-height:1.78; color:var(--t2); flex:1;
  padding-left:11px; border-left:2px solid rgba(232,98,26,.35);
}
.tg-date { font-size:.68rem; color:var(--t3); font-family:var(--fm); }

.testi-controls { display:flex; align-items:center; justify-content:center; gap:13px; margin-top:24px; }
.testi-btn {
  width:40px; height:40px; border-radius:50%;
  background:var(--card); border:1px solid var(--b1);
  display:grid; place-items:center; color:var(--t2);
  transition:all var(--t); cursor:pointer;
}
.testi-btn:hover:not(:disabled) { background:var(--card2); border-color:var(--b2); color:var(--or); transform:scale(1.08); }
.testi-btn:disabled { opacity:.3; cursor:default; }
.testi-btn svg { width:16px; height:16px; }
.testi-dots { display:flex; gap:6px; align-items:center; }
.testi-dot { width:6px; height:6px; border-radius:3px; background:rgba(255,255,255,.1); transition:all .3s; cursor:pointer; }
.testi-dot.active { width:22px; background:var(--or); }

/* ============================================================
   RESPONSIVE – blog
   ============================================================ */
@media(max-width:1024px){
  .blog-layout { grid-template-columns:1fr; }
  .blog-sidebar { position:static; }
  .blog-featured { grid-template-columns:1fr; }
  .testi-slide { flex:0 0 calc(50% - 10px); }
}
@media(max-width:768px){
  .blog-cards-grid { grid-template-columns:1fr; }
  .testi-slide { flex:0 0 100%; }
}

/* ============================================================
   KINOWY SLIDER OPINII – Cinematic testimonials
   ============================================================ */
.testi-cinematic-sec {
  position: relative;
  padding-block: 100px;
  background: #050a12;
  overflow: hidden;
}

/* Tło z poświatą */
.tci-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.tci-glow {
  position: absolute;
  top: 0; bottom: 0;
  width: 28%;
  pointer-events: none;
}
.tci-glow-left {
  left: 0;
  background: radial-gradient(ellipse 80% 100% at 0% 50%,
    rgba(232,98,26,.22) 0%,
    rgba(192,57,43,.1) 30%,
    transparent 70%);
  animation: glowPulse 4s ease-in-out infinite alternate;
}
.tci-glow-right {
  right: 0;
  background: radial-gradient(ellipse 80% 100% at 100% 50%,
    rgba(232,98,26,.22) 0%,
    rgba(192,57,43,.1) 30%,
    transparent 70%);
  animation: glowPulse 4s ease-in-out infinite alternate-reverse;
}
@keyframes glowPulse {
  0%   { opacity: 0.6; transform: scaleX(0.9); }
  100% { opacity: 1;   transform: scaleX(1.1); }
}

/* Cząsteczki canvas */
#tci-particles {
  position: absolute;
  inset: 0;
  opacity: 0.5;
}

/* Nagłówek sekcji */
.tci-header {
  text-align: center;
  margin-bottom: 48px;
}
.tci-header h2 { color: var(--t1); }

/* Wrapper slidera */
.tci-slider-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  position: relative;
}

/* Strzałki */
.tci-arrow {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(232,98,26,.25);
  display: grid; place-items: center;
  color: rgba(255,255,255,.5);
  cursor: pointer;
  transition: all .3s;
  flex-shrink: 0;
  z-index: 2;
}
.tci-arrow:hover {
  background: rgba(232,98,26,.12);
  border-color: rgba(232,98,26,.6);
  color: #fff;
  transform: scale(1.08);
  box-shadow: 0 0 20px rgba(232,98,26,.25);
}
.tci-arrow svg { width: 22px; height: 22px; }

/* Karta */
.tci-card-wrap {
  flex: 1;
  max-width: 700px;
  position: relative;
  min-height: 340px;
}
.tci-card {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 20px;
  padding: 44px 48px;
  background: linear-gradient(145deg, #131a24, #0d1520);
  border: 1px solid rgba(232,98,26,.3);
  border-radius: 20px;
  box-shadow:
    0 0 0 1px rgba(232,98,26,.08),
    0 0 40px rgba(232,98,26,.08),
    0 32px 80px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(255,255,255,.06);
  opacity: 0;
  transform: scale(0.96) translateY(10px);
  transition: opacity .5s cubic-bezier(0.22,1,0.36,1), transform .5s cubic-bezier(0.22,1,0.36,1);
  pointer-events: none;
}
.tci-card.active {
  opacity: 1;
  transform: scale(1) translateY(0);
  pointer-events: auto;
}
.tci-card.exit-left  { opacity: 0; transform: scale(0.95) translateX(-30px); }
.tci-card.exit-right { opacity: 0; transform: scale(0.95) translateX(30px); }

/* Gwiazdki */
.tci-stars {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.tci-stars svg {
  width: 32px; height: 32px;
  filter: drop-shadow(0 0 6px rgba(255,180,0,.5));
}

/* Cytat */
.tci-quote {
  font-family: var(--fh);
  font-size: clamp(1.4rem, 3vw, 2.1rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
  letter-spacing: -.01em;
}

/* Opis */
.tci-desc {
  font-size: .96rem;
  color: rgba(255,255,255,.55);
  line-height: 1.75;
  max-width: 520px;
}

/* Autor */
.tci-author {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 4px;
}
.tci-avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: rgba(232,98,26,.1);
  border: 2px solid rgba(232,98,26,.35);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.tci-author-name {
  font-family: var(--fh);
  font-size: .95rem;
  font-weight: 700;
  color: #fff;
  display: block;
}
.tci-author-role {
  font-size: .78rem;
  color: var(--or);
  font-weight: 500;
}

/* Dots */
.tci-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 4px;
}
.tci-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
  cursor: pointer;
  transition: all .3s;
  border: none;
}
.tci-dot.active {
  background: var(--or);
  box-shadow: 0 0 8px rgba(232,98,26,.5);
  transform: scale(1.3);
}

/* Responsive */
@media (max-width: 768px) {
  .tci-card { padding: 32px 24px; gap: 16px; }
  .tci-stars svg { width: 24px; height: 24px; }
  .tci-quote { font-size: 1.3rem; }
  .tci-arrow { width: 40px; height: 40px; }
  .tci-arrow svg { width: 18px; height: 18px; }
  .tci-slider-wrap { gap: 10px; }
  .tci-card-wrap { min-height: 380px; }
}
@media (max-width: 480px) {
  .tci-card { padding: 24px 18px; }
  .tci-arrow { width: 36px; height: 36px; }
}

/* ============================================================
   LOGO FIX – header (inline style + CSS override)
   ============================================================ */
.site-header .site-logo,
.site-header .site-logo a,
.site-header .site-logo .custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  max-height: 40px !important;
  overflow: hidden !important;
}
.site-header .site-logo img,
.site-header .site-logo .custom-logo,
.site-header .custom-logo-link img,
header img.custom-logo {
  height: 36px !important;
  width: auto !important;
  max-height: 36px !important;
  max-width: 150px !important;
  object-fit: contain !important;
  display: block !important;
}

/* ============================================================
   GLOW EFFECTS – wzmocnione efekty poświaty
   ============================================================ */

/* Przyciski */
.btn-p {
  box-shadow: 0 0 18px rgba(232,98,26,.25), 0 0 50px rgba(232,98,26,.08);
}
.btn-p:hover {
  box-shadow: 0 0 28px rgba(232,98,26,.55), 0 0 70px rgba(232,98,26,.22), 0 10px 28px rgba(232,98,26,.4) !important;
}

/* Karty usług */
.srv-card:hover {
  box-shadow: 0 0 0 1px rgba(232,98,26,.3), 0 20px 60px rgba(232,98,26,.15), 0 0 80px rgba(232,98,26,.08) !important;
}

/* Portfolio */
.port-item:hover {
  box-shadow: 0 0 40px rgba(232,98,26,.22), 0 20px 60px rgba(0,0,0,.55) !important;
  border-color: rgba(232,98,26,.5) !important;
}

/* Hero highlight glow */
.hero-hl {
  text-shadow: 0 0 40px rgba(232,98,26,.6), 0 0 80px rgba(232,98,26,.3);
}

/* Aurora orbs – wzmocnione */
.aurora-orb-1 { opacity: 0.15 !important; }
.aurora-orb-2 { opacity: 0.12 !important; }

/* Testimonials glow */
.tci-glow-left, .tci-glow-right {
  opacity: 1 !important;
  filter: blur(60px) !important;
}

/* Karty procesu */
.p-step:hover {
  box-shadow: 0 18px 56px rgba(0,0,0,.45), 0 0 50px rgba(232,98,26,.18) !important;
}

/* Karty why */
.why-card:hover {
  box-shadow: 0 20px 60px rgba(0,0,0,.4), 0 0 50px rgba(232,98,26,.14) !important;
}

/* Karty blog na stronie głównej */
.blog-card:hover, .blog-card-v2:hover {
  box-shadow: 0 20px 60px rgba(0,0,0,.45), 0 0 30px rgba(232,98,26,.1) !important;
}

/* ============================================================
   BLOG HOME – pełny dark mode, agency style
   ============================================================ */

/* Hero bloga */
.hblog-hero {
  padding-top: 112px;
  padding-bottom: 52px;
  background: #070d18;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.hblog-hero-glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at 85% 50%, rgba(232,98,26,.09), transparent 60%),
    radial-gradient(ellipse 50% 60% at 10% 60%, rgba(59,130,246,.05), transparent 55%);
  pointer-events: none;
}
.hblog-hero-inner { position: relative; z-index: 1; }
.hblog-hero-content { margin: 14px 0 28px; }
.hblog-hero-content h1 { color: #eef2f7; margin-top: 8px; }
.hblog-hero-content p  { color: #8fa3bc; max-width: 500px; font-size: 1rem; line-height: 1.75; }

/* Filtry */
.hblog-filters {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.hblog-filter {
  font-size: .76rem; font-weight: 600; color: #8fa3bc;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 100px; padding: 7px 16px;
  text-decoration: none; transition: all .3s;
}
.hblog-filter:hover, .hblog-filter.active {
  color: #eef2f7;
  background: rgba(232,98,26,.1);
  border-color: rgba(232,98,26,.35);
  box-shadow: 0 0 16px rgba(232,98,26,.15);
}

/* Main layout */
.hblog-main { background: #070d18; padding-block: 56px; }
.hblog-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 32px;
  align-items: start;
}
.hblog-posts { min-width: 0; }

/* Featured */
.hblog-featured {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 18px;
  overflow: hidden;
  margin-bottom: 24px;
  transition: all .6s cubic-bezier(0.22,1,0.36,1);
}
.hblog-featured:hover {
  border-color: rgba(232,98,26,.3);
  box-shadow: 0 0 40px rgba(232,98,26,.12), 0 20px 60px rgba(0,0,0,.5);
}
.hblog-featured-img {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: #0a1628;
}
.hblog-featured-img a:not(.hblog-no-thumb) { display: block; width: 100%; height: 100%; }
.hblog-featured-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(0.22,1,0.36,1);
}
.hblog-featured:hover .hblog-featured-img img { transform: scale(1.04); }
.hblog-no-thumb {
  width: 100%; height: 100%; min-height: 220px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #0f1e30, #152338);
}
.hblog-featured-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, transparent 55%, rgba(15,30,48,.7));
  pointer-events: none;
}
.hblog-badge {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  background: #e8621a; color: #fff;
  font-size: .63rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 4px 12px; border-radius: 100px;
  box-shadow: 0 0 16px rgba(232,98,26,.5);
}

.hblog-featured-body {
  padding: 32px 28px;
  display: flex; flex-direction: column; justify-content: center; gap: 14px;
  background: #0f1e30;
}
.hblog-featured-body h2 {
  font-size: clamp(1.1rem, 2vw, 1.55rem);
  line-height: 1.3; margin: 0; color: #eef2f7;
}
.hblog-featured-body h2 a { color: #eef2f7; transition: color .3s; }
.hblog-featured:hover .hblog-featured-body h2 a { color: #e8621a; }
.hblog-excerpt { font-size: .87rem; line-height: 1.74; color: #8fa3bc; margin: 0; }
.hblog-meta {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap; margin-top: auto;
  padding-top: 14px; border-top: 1px solid rgba(255,255,255,.06);
}
.hblog-author-av {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(232,98,26,.1); border: 2px solid rgba(232,98,26,.3);
  display: grid; place-items: center;
  font-family: var(--fh); font-weight: 700; font-size: .78rem;
  color: #e8621a; flex-shrink: 0;
}
.hblog-author-name { font-size: .78rem; font-weight: 600; color: #eef2f7; }
.hblog-date, .hblog-rt { font-size: .74rem; color: #4e6278; }
.hblog-meta-sep { color: #4e6278; font-size: .7rem; }
.hblog-read-more {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: .84rem; font-weight: 600; color: #e8621a;
  text-decoration: none; transition: gap .3s;
}
.hblog-read-more:hover { gap: 11px; color: #f07a38; }
.hblog-read-more svg { width: 16px; height: 16px; }

/* Tag kategorii */
.hblog-cat-tag {
  display: inline-block;
  font-size: .63rem; font-family: var(--fm); font-weight: 700;
  letter-spacing: .11em; text-transform: uppercase;
  color: #e8621a; background: rgba(232,98,26,.09);
  border-radius: 4px; padding: 3px 9px; margin-bottom: 9px;
  text-decoration: none; transition: background .3s;
}
.hblog-cat-tag:hover { background: rgba(232,98,26,.17); color: #e8621a; }

/* Grid kart */
.hblog-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

/* Karta */
.hblog-card {
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px; overflow: hidden;
  transition: all .6s cubic-bezier(0.22,1,0.36,1);
  display: flex; flex-direction: column;
}
.hblog-card:hover {
  border-color: rgba(232,98,26,.3);
  transform: translateY(-5px);
  box-shadow: 0 0 36px rgba(232,98,26,.12), 0 18px 56px rgba(0,0,0,.5);
}
.hblog-card-thumb {
  aspect-ratio: 16/9; overflow: hidden;
  background: #0a1628; flex-shrink: 0;
}
.hblog-card-thumb a:not(.hblog-no-thumb) { display: block; width: 100%; height: 100%; }
.hblog-card-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .7s cubic-bezier(0.22,1,0.36,1);
}
.hblog-card:hover .hblog-card-thumb img { transform: scale(1.06); }
.hblog-card-thumb .hblog-no-thumb {
  width: 100%; height: 100%; min-height: 130px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #0f1e30, #152338);
}
.hblog-card-body {
  padding: 20px; flex: 1;
  display: flex; flex-direction: column;
  background: #0f1e30;
}
.hblog-card-body h3 {
  font-size: .94rem; margin-bottom: 8px;
  line-height: 1.44; color: #eef2f7;
}
.hblog-card-body h3 a { color: #eef2f7; transition: color .3s; }
.hblog-card:hover .hblog-card-body h3 a { color: #e8621a; }
.hblog-card-body p {
  font-size: .81rem; line-height: 1.7;
  color: #8fa3bc; margin-bottom: 12px;
}
.hblog-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: auto; padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.05);
}
.hblog-more {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .76rem; font-weight: 600; color: #e8621a;
  text-decoration: none; transition: gap .3s;
}
.hblog-more:hover { gap: 8px; color: #f07a38; }
.hblog-more svg { width: 13px; height: 13px; }

/* Paginacja */
.hblog-pagination {
  display: flex; flex-wrap: wrap; gap: 7px;
  padding: 36px 0 0; justify-content: flex-start;
}
.hblog-pagination .page-numbers {
  width: 40px; height: 40px; border-radius: 8px;
  display: grid; place-items: center;
  font-weight: 600; font-size: .83rem;
  background: #0f1e30; border: 1px solid rgba(255,255,255,.06);
  color: #8fa3bc; text-decoration: none; transition: all .3s;
}
.hblog-pagination .page-numbers:hover,
.hblog-pagination .page-numbers.current {
  background: #e8621a; border-color: #e8621a; color: #fff;
  box-shadow: 0 0 16px rgba(232,98,26,.4);
}
.hblog-pagination .prev,
.hblog-pagination .next { width: auto; padding: 0 14px; font-size: .78rem; }

/* ── SIDEBAR ── */
.hblog-sidebar {
  display: flex; flex-direction: column; gap: 16px;
  position: sticky; top: 84px;
}
.hblog-widget {
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px; padding: 20px;
}
.hblog-widget-title {
  font-size: .7rem; font-weight: 700;
  letter-spacing: .13em; text-transform: uppercase;
  color: #eef2f7; margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.05);
}

/* Search */
.hblog-search { display: flex; gap: 8px; }
.hblog-search-input {
  flex: 1; min-width: 0;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 8px; color: #eef2f7;
  font-family: var(--fb); font-size: .83rem;
  padding: 9px 12px; outline: none;
  transition: border-color .3s;
}
.hblog-search-input:focus { border-color: rgba(232,98,26,.45); }
.hblog-search-input::placeholder { color: #4e6278; }
.hblog-search-btn {
  width: 38px; height: 38px; border-radius: 8px;
  background: #e8621a; border: none; color: #fff;
  display: grid; place-items: center; cursor: pointer;
  transition: all .3s; flex-shrink: 0;
}
.hblog-search-btn:hover {
  background: #f07a38;
  box-shadow: 0 0 16px rgba(232,98,26,.5);
}

/* Cats */
.hblog-cats { display: flex; flex-direction: column; gap: 5px; }
.hblog-cat-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 11px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px; font-size: .8rem; color: #8fa3bc;
  text-decoration: none; transition: all .3s;
}
.hblog-cat-item:hover {
  border-color: rgba(232,98,26,.35); color: #e8621a;
  background: rgba(232,98,26,.06);
  box-shadow: 0 0 12px rgba(232,98,26,.1);
}
.hblog-cat-count {
  font-size: .67rem; font-family: var(--fm); color: #4e6278;
  background: rgba(255,255,255,.04); border-radius: 4px; padding: 1px 6px;
}

/* Recent */
.hblog-recent-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.05);
  text-decoration: none; transition: opacity .3s;
}
.hblog-recent-item:last-child { border-bottom: none; padding-bottom: 0; }
.hblog-recent-item:hover { opacity: .8; }
.hblog-recent-thumb {
  width: 52px; height: 42px; border-radius: 6px;
  overflow: hidden; flex-shrink: 0; background: #0a1628;
}
.hblog-recent-thumb img { width: 100%; height: 100%; object-fit: cover; }
.hblog-recent-info { display: flex; flex-direction: column; gap: 3px; }
.hblog-recent-title { font-size: .79rem; font-weight: 600; color: #eef2f7; line-height: 1.4; }
.hblog-recent-date  { font-size: .68rem; color: #4e6278; }

/* CTA widget */
.hblog-cta-widget {
  background: linear-gradient(135deg, rgba(232,98,26,.12), rgba(192,57,43,.07));
  border: 1px solid rgba(232,98,26,.28);
  border-radius: 16px; padding: 22px; text-align: center;
  box-shadow: 0 0 30px rgba(232,98,26,.08);
}
.hblog-cta-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: rgba(232,98,26,.15); border: 1px solid rgba(232,98,26,.3);
  display: grid; place-items: center; margin: 0 auto 14px;
  color: #e8621a;
  box-shadow: 0 0 20px rgba(232,98,26,.25);
}
.hblog-cta-widget h4 { font-size: .92rem; color: #eef2f7; margin-bottom: 8px; }
.hblog-cta-widget p  { font-size: .8rem; color: #8fa3bc; margin-bottom: 16px; }
.hblog-cta-note { font-size: .7rem; color: #4e6278; margin-top: 10px; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .hblog-layout { grid-template-columns: 1fr; }
  .hblog-sidebar { position: static; }
  .hblog-featured { grid-template-columns: 1fr; }
  .hblog-featured-img { aspect-ratio: 16/9; }
}
@media (max-width: 768px) {
  .hblog-grid { grid-template-columns: 1fr; }
  .hblog-hero { padding-top: 96px; }
}

/* ============================================================
   BLOG – dark agency design (matching reference)
   ============================================================ */

/* ── HERO ── */
.bd-hero {
  position: relative;
  padding: 120px 0 70px;
  overflow: hidden;
  background: #06090f;
}
.bd-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 90% 80% at 100% 0%, rgba(192,57,43,.35) 0%, transparent 50%),
    radial-gradient(ellipse 60% 60% at 80% 20%, rgba(120,40,180,.25) 0%, transparent 45%),
    radial-gradient(ellipse 50% 50% at 95% 50%, rgba(232,98,26,.2) 0%, transparent 45%),
    #06090f;
}
.bd-hero-nebula {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 40% 60% at 85% 15%, rgba(232,98,26,.12) 0%, transparent 55%),
    radial-gradient(ellipse 30% 40% at 75% 40%, rgba(180,60,200,.1) 0%, transparent 50%);
  animation: nebulaShift 8s ease-in-out infinite alternate;
}
@keyframes nebulaShift {
  0%   { opacity: .7; transform: scale(1); }
  100% { opacity: 1; transform: scale(1.05); }
}
.bd-hero-stars {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.6), transparent),
    radial-gradient(1px 1px at 40% 10%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 60% 50%, rgba(255,255,255,.4), transparent),
    radial-gradient(1px 1px at 80% 20%, rgba(255,255,255,.6), transparent),
    radial-gradient(1px 1px at 90% 70%, rgba(255,255,255,.3), transparent),
    radial-gradient(1px 1px at 15% 80%, rgba(255,255,255,.4), transparent),
    radial-gradient(1px 1px at 55% 85%, rgba(255,255,255,.3), transparent),
    radial-gradient(2px 2px at 70% 60%, rgba(255,200,150,.4), transparent),
    radial-gradient(1px 1px at 35% 65%, rgba(255,255,255,.5), transparent);
}
.bd-hero-inner { position: relative; z-index: 2; }
.bd-hero-title {
  font-family: var(--fh);
  font-size: clamp(2rem, 5vw, 3.4rem);
  font-weight: 700; color: #fff;
  line-height: 1.12; letter-spacing: -.02em;
  margin-bottom: 14px;
}
.bd-hero-sub {
  font-size: 1rem; color: rgba(255,255,255,.6);
  max-width: 480px; line-height: 1.7; margin-bottom: 28px;
}
.bd-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* ── FILTER BAR ── */
.bd-filters-bar {
  background: #08101a;
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 14px 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.bd-filters {
  display: flex; gap: 8px;
  min-width: max-content;
}
.bd-filter-btn {
  font-size: .78rem; font-weight: 600;
  color: rgba(255,255,255,.5);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 100px; padding: 7px 18px;
  white-space: nowrap; text-decoration: none;
  transition: all .25s;
}
.bd-filter-btn:hover, .bd-filter-btn.active {
  color: #fff;
  background: rgba(232,98,26,.15);
  border-color: rgba(232,98,26,.4);
  box-shadow: 0 0 14px rgba(232,98,26,.2);
}

/* ── MAIN SECTION ── */
.bd-main { background: #070d18; padding: 44px 0 60px; }

/* ── FEATURED POST ── */
.bd-featured {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: #0d1a28;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  overflow: hidden;
  margin-bottom: 28px;
  transition: border-color .4s, box-shadow .4s;
}
.bd-featured:hover {
  border-color: rgba(232,98,26,.35);
  box-shadow: 0 0 50px rgba(232,98,26,.1), 0 20px 60px rgba(0,0,0,.5);
}
.bd-featured-content {
  padding: 40px 36px;
  display: flex; flex-direction: column;
  justify-content: center; gap: 16px;
}
.bd-featured-title {
  font-family: var(--fh);
  font-size: clamp(1.2rem, 2.5vw, 1.8rem);
  line-height: 1.25; color: #fff; margin: 0;
}
.bd-featured-title a { color: #fff; transition: color .3s; }
.bd-featured:hover .bd-featured-title a { color: #e8621a; }
.bd-featured-desc { font-size: .9rem; color: rgba(255,255,255,.55); line-height: 1.72; margin: 0; }
.bd-featured-img {
  position: relative; overflow: hidden;
  min-height: 280px;
}
.bd-featured-img a { display: block; width: 100%; height: 100%; }
.bd-featured-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(0.22,1,0.36,1);
}
.bd-featured:hover .bd-featured-img img { transform: scale(1.04); }
.bd-featured-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(13,26,40,.4) 0%, transparent 60%);
  pointer-events: none;
}
.bd-featured-img-placeholder { background: linear-gradient(135deg, #0d1a28, #152338); }
.bd-placeholder-inner {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; min-height: 260px;
}
.bd-read-more {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: .85rem; font-weight: 600;
  color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 100px; padding: 9px 20px;
  text-decoration: none; transition: all .3s;
  align-self: flex-start;
}
.bd-read-more:hover {
  background: rgba(232,98,26,.15);
  border-color: rgba(232,98,26,.4);
  color: #e8621a;
  box-shadow: 0 0 16px rgba(232,98,26,.2);
}
.bd-cat-tag {
  display: inline-block;
  font-size: .66rem; font-family: var(--fm); font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: #fff; background: rgba(232,98,26,.8);
  border-radius: 6px; padding: 4px 10px;
  text-decoration: none; align-self: flex-start;
}

/* ── CARDS GRID ── */
.bd-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 40px;
}
.bd-card {
  background: #0d1a28;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; overflow: hidden;
  transition: border-color .35s, transform .35s, box-shadow .35s;
  display: flex; flex-direction: column;
}
.bd-card:hover {
  border-color: rgba(232,98,26,.35);
  transform: translateY(-5px);
  box-shadow: 0 0 36px rgba(232,98,26,.12), 0 16px 50px rgba(0,0,0,.5);
}
.bd-card-img {
  position: relative;
  aspect-ratio: 16/9; overflow: hidden;
  background: #0a1420;
}
.bd-card-img a:not(.bd-card-no-img) { display: block; width: 100%; height: 100%; }
.bd-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .7s cubic-bezier(0.22,1,0.36,1);
}
.bd-card:hover .bd-card-img img { transform: scale(1.07); }
.bd-card-no-img {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; min-height: 140px;
  background: linear-gradient(135deg, #0d1a28, #152338);
}
.bd-card-cat {
  position: absolute; bottom: 10px; left: 10px; z-index: 2;
  font-size: .62rem; font-family: var(--fm); font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: #fff; background: rgba(232,98,26,.85);
  border-radius: 6px; padding: 3px 9px;
  text-decoration: none;
  backdrop-filter: blur(4px);
}
.bd-card-body { padding: 18px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.bd-card-title { font-family: var(--fh); font-size: .94rem; line-height: 1.4; color: #eef2f7; margin: 0; }
.bd-card-title a { color: #eef2f7; transition: color .3s; }
.bd-card:hover .bd-card-title a { color: #e8621a; }
.bd-card-excerpt { font-size: .8rem; color: rgba(255,255,255,.45); line-height: 1.65; margin: 0; flex: 1; }
.bd-card-meta {
  display: flex; align-items: center; gap: 6px;
  font-size: .72rem; color: rgba(255,255,255,.3);
  font-family: var(--fm);
  padding-top: 10px; border-top: 1px solid rgba(255,255,255,.05);
}
.bd-meta-dot { opacity: .4; }

/* ── NEWSLETTER ── */
.bd-newsletter {
  position: relative; overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(232,98,26,.2);
  margin-bottom: 40px;
  padding: 36px 40px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px; flex-wrap: wrap;
}
.bd-newsletter-bg {
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(232,98,26,.1) 0%, rgba(192,57,43,.06) 50%, rgba(13,26,40,.95) 100%),
    #0d1a28;
  z-index: 0;
}
.bd-newsletter-inner { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; width: 100%; }
.bd-newsletter-title {
  font-family: var(--fh); font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  font-weight: 700; color: #fff; margin: 0 0 6px;
}
.bd-newsletter-sub { font-size: .86rem; color: rgba(255,255,255,.5); margin: 0 0 10px; }
.bd-newsletter-note {
  display: flex; align-items: center; gap: 6px;
  font-size: .76rem; color: rgba(255,255,255,.35);
}
.bd-newsletter-note svg { width: 12px; height: 12px; color: #e8621a; }
.bd-newsletter-form { display: flex; gap: 0; border-radius: 10px; overflow: hidden; flex-shrink: 0; }
.bd-newsletter-input {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-right: none;
  border-radius: 10px 0 0 10px;
  color: #eef2f7; font-family: var(--fb);
  font-size: .88rem; padding: 11px 18px;
  outline: none; width: 220px;
  transition: border-color .3s;
}
.bd-newsletter-input::placeholder { color: rgba(255,255,255,.3); }
.bd-newsletter-input:focus { border-color: rgba(232,98,26,.4); }
.bd-newsletter-btn {
  display: inline-flex; align-items: center; gap: 7px;
  background: #e8621a; color: #fff;
  border: none; border-radius: 0 10px 10px 0;
  padding: 11px 20px; font-family: var(--fb);
  font-size: .86rem; font-weight: 600; cursor: pointer;
  transition: background .3s, box-shadow .3s; white-space: nowrap;
}
.bd-newsletter-btn:hover {
  background: #f07a38;
  box-shadow: 0 0 20px rgba(232,98,26,.4);
}

/* ── PAGINACJA ── */
.bd-pagination {
  display: flex; justify-content: flex-start; gap: 7px; flex-wrap: wrap;
  padding: 16px 0;
}
.bd-pagination .page-numbers {
  width: 40px; height: 40px; border-radius: 8px;
  display: grid; place-items: center;
  font-weight: 600; font-size: .83rem;
  background: #0d1a28; border: 1px solid rgba(255,255,255,.07);
  color: rgba(255,255,255,.5); text-decoration: none; transition: all .3s;
}
.bd-pagination .page-numbers:hover,
.bd-pagination .page-numbers.current {
  background: #e8621a; border-color: #e8621a; color: #fff;
  box-shadow: 0 0 16px rgba(232,98,26,.4);
}
.bd-pagination .prev, .bd-pagination .next { width: auto; padding: 0 14px; font-size: .78rem; }

/* ── CTA ── */
.bd-cta {
  position: relative; overflow: hidden;
  background: #06090f;
  padding: 64px 0;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.05);
}
.bd-cta-glow {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(232,98,26,.1), transparent 65%);
  animation: ctaGlow 4s ease-in-out infinite alternate;
}
@keyframes ctaGlow { 0%{opacity:.6;transform:scale(.95)} 100%{opacity:1;transform:scale(1.05)} }
.bd-cta-inner { position: relative; z-index: 1; }
.bd-cta-title {
  font-family: var(--fh); font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700; color: #fff; margin-bottom: 12px;
}
.bd-cta-sub { font-size: .95rem; color: rgba(255,255,255,.5); margin-bottom: 28px; max-width: 500px; margin-inline: auto; }
.bd-cta-btn { font-size: .92rem; padding: 13px 28px; }

/* ── LOGO FIX ── */
.site-header .site-logo img,
.site-header .site-logo .custom-logo,
.site-header .custom-logo-link img,
header img.custom-logo {
  height: 36px !important;
  width: auto !important;
  max-height: 36px !important;
  max-width: 150px !important;
  object-fit: contain !important;
}
.site-header .custom-logo-link,
.site-header .site-logo a {
  display: inline-flex !important;
  max-height: 40px !important;
  overflow: hidden !important;
  align-items: center !important;
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .bd-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .bd-featured { grid-template-columns: 1fr; }
  .bd-featured-img { order: -1; min-height: 200px; }
  .bd-featured-content { padding: 24px 20px; }
  .bd-grid { grid-template-columns: 1fr; }
  .bd-newsletter { padding: 24px 20px; }
  .bd-newsletter-form { width: 100%; }
  .bd-newsletter-input { flex: 1; width: auto; }
  .bd-hero { padding: 100px 0 50px; }
  .bd-hero-title { font-size: 1.9rem; }
  .bd-hero-btns { flex-direction: column; }
}

/* ============================================================
   PEŁNA RESPONSYWNOŚĆ
   Breakpointy:
   – 1440px+   : duże ekrany / 4K
   – 1280px    : desktop standard
   – 1024px    : desktop mały / tablet landscape
   – 768px     : tablet portrait
   – 600px     : duży telefon landscape
   – 480px     : telefon standard
   – 360px     : telefon mały
   ============================================================ */

/* ── GLOBAL BOX SIZING & OVERFLOW ── */
html, body { overflow-x: hidden; }
*, *::before, *::after { box-sizing: border-box; }
img, video, iframe { max-width: 100%; height: auto; }

/* ── FLUID CONTAINER ── */
.wrap, .container {
  max-width: var(--W, 1160px);
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 28px);
  width: 100%;
}

/* ============================================================
   1440px+ – bardzo duże ekrany
   ============================================================ */
@media (min-width: 1440px) {
  :root { --W: 1280px; --sec: 120px; }
  h1 { font-size: 5.2rem; }
  h2 { font-size: 3.4rem; }
  .hero-card { grid-template-columns: 1fr 460px; }
  .bd-hero-title { font-size: 3.8rem; }
  .srv-grid { grid-template-columns: repeat(3,1fr); gap: 24px; }
  .port-grid { gap: 24px; }
  .blog-grid, .bd-grid { grid-template-columns: repeat(3,1fr); gap: 24px; }
  .footer-top { gap: 56px; }
  .pricing-grid { gap: 24px; }
}

/* ============================================================
   1280px – desktop standard
   ============================================================ */
@media (max-width: 1280px) {
  :root { --W: 1100px; }
  .hero-card { grid-template-columns: 1fr 380px; }
  .hero-card-body { padding: 44px 40px; }
  .hero-card-body h1 { font-size: clamp(2rem, 3.5vw, 3rem); }
  .proc-grid { grid-template-columns: repeat(4,1fr); }
  .footer-top { gap: 36px; }
  .why2-badge { right: -10px; top: -10px; }
}

/* ============================================================
   1024px – małe deskopy / tablet landscape
   ============================================================ */
@media (max-width: 1024px) {
  :root { --S: 80px; --W: 960px; }

  /* Header */
  .main-nav { gap: 1px; }
  .main-nav a { font-size: .8rem; padding: 6px 10px; }
  .header-actions .btn-sm { padding: 8px 14px; font-size: .78rem; }

  /* Hero card */
  .hero-wrap { padding-block: 70px 40px; }
  .hero-card { grid-template-columns: 1fr; }
  .hero-card-img { display: none; }
  .hero-card-body { padding: 40px 36px; }
  .hero-card-body h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
  .hero-stats { flex-wrap: wrap; gap: 0; }
  .hero-stat { min-width: 140px; }

  /* Grids */
  .srv-grid { grid-template-columns: repeat(2,1fr); }
  .why-grid { grid-template-columns: repeat(2,1fr); }
  .port-grid { grid-template-columns: repeat(2,1fr); }
  .port-item--lg { grid-column: span 1; aspect-ratio: 4/3; }
  .blog-grid, .bd-grid { grid-template-columns: repeat(2,1fr); }
  .testi-grid { grid-template-columns: repeat(2,1fr); }
  .pricing-grid { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
  .price-card--feat { transform: none; }

  /* Process */
  .proc-grid { grid-template-columns: repeat(2,1fr); gap: 2px; }
  .proc-grid::after { display: none; }
  .p-step:first-child { border-radius: var(--r2) 0 0 0; }
  .p-step:nth-child(2) { border-radius: 0 var(--r2) 0 0; }
  .p-step:nth-child(3) { border-radius: 0 0 0 var(--r2); }
  .p-step:last-child   { border-radius: 0 0 var(--r2) 0; }

  /* Why2 */
  .why2-grid { grid-template-columns: 1fr; gap: 36px; }
  .why2-visual { display: none; }

  /* Blog featured */
  .bd-featured { grid-template-columns: 1fr; }
  .bd-featured-img { order: -1; min-height: 240px; }
  .bd-featured-content { padding: 28px 24px; }
  .hblog-featured { grid-template-columns: 1fr; }
  .hblog-featured-img { aspect-ratio: 16/8; }

  /* Layout blog */
  .blog-layout, .hblog-layout { grid-template-columns: 1fr; }
  .blog-sidebar, .hblog-sidebar { position: static; }

  /* Footer */
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }

  /* Contact */
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }

  /* Single post */
  .post-body, .single .blog-layout { grid-template-columns: 1fr; }
}

/* ============================================================
   768px – tablet portrait
   ============================================================ */
@media (max-width: 768px) {
  :root { --S: 64px; --W: 100%; }

  /* Header – hamburger mode */
  .main-nav { display: none; }
  .header-actions .btn-o { display: none; }
  .nav-toggle { display: flex; }
  .site-header { padding: 14px 0; }
  .site-header.scrolled { padding: 10px 0; }

  /* Logo */
  .site-header .site-logo img,
  .site-header .custom-logo-link img { height: 32px !important; max-height: 32px !important; }

  /* Hero */
  .hero-wrap { padding-block: 88px 44px; min-height: auto; }
  .hero-card { border-radius: 16px; }
  .hero-card-body { padding: 28px 22px; gap: 14px; }
  .hero-card-body h1 { font-size: clamp(1.55rem, 5vw, 2.2rem); }
  .hero-bullets li { font-size: .84rem; }
  .hero-btns { flex-direction: column; gap: 10px; }
  .hero-btns .btn { justify-content: center; width: 100%; }
  .hero-badges { gap: 6px; }
  .hero-badge { font-size: .68rem; padding: 4px 10px; }
  .hero-stats { flex-direction: column; gap: 0; }
  .hero-stat { border-right: none !important; border-top: 1px solid var(--b1); padding: 12px 0; }
  .hero-stat:first-child { border-top: none; padding-top: 16px; }
  .stat-n { font-size: 1.8rem; }
  .hero-scroll { display: none; }

  /* Logos marquee */
  .logos-sec { padding-block: 36px; }
  .logo-chip, .mq-track .logo-chip { padding: 6px 13px; }
  .logo-chip span { font-size: .78rem; }

  /* Grids → single column */
  .srv-grid,
  .port-grid,
  .blog-grid,
  .bd-grid,
  .why-grid,
  .testi-grid,
  .arc-grid,
  .hblog-grid,
  .blog-cards-grid { grid-template-columns: 1fr !important; }

  /* Process → single column */
  .proc-grid { grid-template-columns: 1fr !important; }
  .p-step { border-radius: var(--r2) !important; }
  .p-step h3 { font-size: 1rem; }

  /* Services */
  .srv-card { padding: 24px 20px; }

  /* Portfolio */
  .port-item--lg { grid-column: span 1 !important; aspect-ratio: 4/3 !important; }

  /* Blog hero */
  .bd-hero { padding: 96px 0 44px; }
  .bd-hero-title { font-size: 1.8rem; }
  .bd-hero-sub { font-size: .9rem; }
  .bd-hero-btns { flex-direction: column; gap: 10px; }
  .bd-hero-btns .btn { width: 100%; justify-content: center; }
  .bd-filters-bar { padding: 12px 0; }
  .bd-filters { padding-inline: 16px; }
  .hblog-hero { padding-top: 90px; padding-bottom: 36px; }

  /* Blog grid */
  .hblog-grid { grid-template-columns: 1fr !important; }
  .bd-grid { grid-template-columns: 1fr !important; }

  /* Newsletter */
  .bd-newsletter { padding: 24px 20px; flex-direction: column; }
  .bd-newsletter-inner { flex-direction: column; gap: 20px; }
  .bd-newsletter-form { width: 100%; border-radius: 10px; flex-direction: column; gap: 10px; }
  .bd-newsletter-input { width: 100%; border-radius: 10px !important; border-right: 1px solid rgba(255,255,255,.1) !important; }
  .bd-newsletter-btn { border-radius: 10px !important; justify-content: center; }

  /* Featured post */
  .bd-featured { grid-template-columns: 1fr; }
  .bd-featured-img { min-height: 200px; }
  .hblog-featured { grid-template-columns: 1fr; }

  /* Contact form */
  .form-row, .form-wrap .form-row { grid-template-columns: 1fr; gap: 10px; }
  .form-wrap { padding: 22px 18px; }
  .contact-grid { gap: 32px; }

  /* Footer */
  .footer-top { grid-template-columns: 1fr; gap: 24px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 8px; text-align: left; }
  .footer-brand p { max-width: 100%; }
  .footer-logo-link img { height: 40px !important; max-height: 40px !important; }

  /* Pricing */
  .pricing-grid { grid-template-columns: 1fr; max-width: 100%; }
  .price-card--feat { transform: none; }
  .price-card--feat::before { border-radius: var(--r2) var(--r2) 0 0; }

  /* FAQ */
  .faq-list { max-width: 100%; }
  .faq-q { font-size: .88rem; padding: 16px 18px; }
  .faq-a-inner { padding: 0 18px 16px; }

  /* Why2 */
  .why2-grid { grid-template-columns: 1fr; gap: 28px; }
  .why2-visual { display: none; }
  .why2-list { gap: 12px; }
  .why2-stat-row { grid-template-columns: repeat(2,1fr); }

  /* CTA */
  .cta-sec { padding-block: 64px; }
  .cta-btns, .cta-actions { flex-direction: column; gap: 10px; align-items: center; }
  .cta-btns .btn, .cta-actions .btn { width: 100%; max-width: 320px; justify-content: center; }
  .bd-cta { padding: 48px 0; }
  .bd-cta-title { font-size: 1.6rem; }

  /* Testimonials cinematic */
  .tci-slider-wrap { gap: 8px; }
  .tci-arrow { width: 36px; height: 36px; }
  .tci-card { padding: 28px 20px; }
  .tci-quote { font-size: 1.2rem; }
  .tci-stars svg { width: 22px; height: 22px; }
  .tci-card-wrap { min-height: 360px; }

  /* Slider */
  .testi-slide { flex: 0 0 100% !important; }
  .testi-cinematic-sec { padding-block: 64px; }

  /* Single post */
  .post-hdr { padding-top: 96px; padding-bottom: 36px; }
  .post-body { padding-block: 36px; max-width: 100%; }
  .post-body p { font-size: .97rem; }
  .post-img { margin-block: 32px; }

  /* Page hero */
  .page-hero { padding-top: 100px; padding-bottom: 40px; }
  .page-hero h1 { font-size: clamp(1.6rem, 5vw, 2.4rem); }

  /* Mobile nav */
  .mobile-nav a { font-size: 1.7rem; }
}

/* ============================================================
   600px – duży telefon landscape / mały tablet
   ============================================================ */
@media (max-width: 600px) {
  .why2-stat-row { grid-template-columns: 1fr 1fr; gap: 8px; }
  .why2-stat-val { font-size: 1.5rem; }
  .hero-card-body h1 { font-size: 1.55rem; }
  .testi-rating-row { flex-direction: column; gap: 12px; text-align: center; }
  .testi-divider { width: 80%; height: 1px; }
  .testi-bars { width: 100%; }
  .bd-newsletter-title { font-size: 1.2rem; }
  .hblog-layout { grid-template-columns: 1fr; }
  .hblog-sidebar { display: none; } /* Sidebar ukryty na małych ekranach */
  .proc-grid { gap: 8px; }
}

/* ============================================================
   480px – telefon standard
   ============================================================ */
@media (max-width: 480px) {
  :root { --S: 52px; }

  /* Typography */
  h1 { font-size: clamp(1.4rem, 6vw, 1.9rem) !important; }
  h2 { font-size: clamp(1.3rem, 5vw, 1.7rem) !important; }
  h3 { font-size: 1.05rem; }

  /* Wrap padding */
  .wrap, .container { padding-inline: 16px; }

  /* Header */
  .site-header { padding: 12px 0; }
  .site-header .site-logo img,
  .site-header .custom-logo-link img { height: 30px !important; max-height: 30px !important; }
  .header-actions .btn { font-size: .76rem; padding: 8px 14px; }

  /* Hero */
  .hero-wrap { padding-top: 84px; }
  .hero-card-body { padding: 22px 18px; }
  .hero-card-body > p { font-size: .88rem; }
  .hero-bullets li { font-size: .82rem; }
  .stat-n { font-size: 1.6rem; }
  .stat-l { font-size: .7rem; }

  /* Logos */
  .mq-track { gap: 10px; padding-right: 10px; }
  .logo-chip { padding: 5px 11px; }
  .logo-chip span { font-size: .74rem; }

  /* Sections */
  .eye { font-size: .62rem; }
  .section-eyebrow, .eye { margin-bottom: 10px; }

  /* Cards */
  .srv-card { padding: 20px 18px; }
  .srv-icon { width: 44px; height: 44px; }
  .why-card { padding: 22px 18px; }
  .why-icon { width: 42px; height: 42px; }
  .p-step { padding: 24px 18px; }
  .p-num { width: 38px; height: 38px; font-size: .7rem; }

  /* Blog */
  .bd-hero { padding: 88px 0 36px; }
  .bd-hero-title { font-size: 1.5rem; }
  .bd-featured-content { padding: 20px 18px; gap: 12px; }
  .bd-featured-title { font-size: 1.1rem; }
  .bd-card-body { padding: 14px; }
  .bd-card-title { font-size: .86rem; }
  .bd-card-meta { font-size: .67rem; }
  .bd-newsletter-title { font-size: 1.1rem; }
  .bd-cta-title { font-size: 1.3rem; }

  /* Testimonials */
  .tci-card { padding: 22px 16px; gap: 12px; }
  .tci-quote { font-size: 1.05rem; }
  .tci-stars svg { width: 18px; height: 18px; }
  .tci-desc { font-size: .82rem; }
  .tci-arrow { width: 32px; height: 32px; }
  .tci-arrow svg { width: 16px; height: 16px; }
  .tci-card-wrap { min-height: 400px; }

  /* Contact */
  .contact-items { gap: 14px; }
  .ci-icon { width: 34px; height: 34px; }
  .form-g input, .form-g textarea, .form-g select { padding: 10px 12px; font-size: .85rem; }

  /* Footer */
  .footer-top { padding-bottom: 36px; }
  .f-social { width: 30px; height: 30px; }
  .footer-col h4 { font-size: .67rem; }
  .footer-col ul a { font-size: .78rem; }
  .footer-logo-link img { height: 36px !important; max-height: 36px !important; }

  /* Pricing */
  .price-amount { font-size: 2.2rem; }
  .price-card { padding: 24px 20px; }

  /* FAQ */
  .faq-q { font-size: .84rem; padding: 14px 16px; }

  /* Pagination */
  .page-numbers { width: 36px; height: 36px; font-size: .8rem; }
  .pagination { gap: 5px; padding: 36px 0; }
  .bd-pagination .page-numbers { width: 36px; height: 36px; }

  /* Portfolio overlay */
  .port-overlay { padding: 16px; }
  .port-overlay h3 { font-size: .88rem; }

  /* CTA section */
  .cta-inner p { font-size: .92rem; }

  /* Mobile nav */
  .mobile-nav a { font-size: 1.4rem; padding: 8px 20px; }
  .mobile-nav-close { top: 16px; right: 16px; padding: 8px; }
}

/* ============================================================
   360px – małe telefony (np. Samsung Galaxy S5, iPhone SE)
   ============================================================ */
@media (max-width: 360px) {
  :root { --S: 48px; }

  .wrap, .container { padding-inline: 14px; }

  h1 { font-size: 1.3rem !important; }
  h2 { font-size: 1.2rem !important; }

  .site-header .site-logo img,
  .site-header .custom-logo-link img { height: 28px !important; max-height: 28px !important; }

  .hero-card-body { padding: 18px 14px; }
  .hero-card-body h1 { font-size: 1.25rem !important; }
  .hero-badge { font-size: .64rem; padding: 3px 8px; }
  .stat-n { font-size: 1.4rem; }

  .btn { font-size: .82rem; padding: 10px 16px; }
  .btn-sm { padding: 8px 12px; font-size: .76rem; }

  .srv-icon { width: 40px; height: 40px; }
  .srv-card h3 { font-size: .95rem; }
  .why-icon { width: 38px; height: 38px; }

  .tci-card { padding: 18px 14px; }
  .tci-quote { font-size: .95rem; }
  .tci-card-wrap { min-height: 420px; }
  .tci-arrow { width: 28px; height: 28px; }

  .footer-logo-link img { height: 30px !important; max-height: 30px !important; }

  .bd-hero-title { font-size: 1.3rem; }
  .bd-featured-title { font-size: 1rem; }
  .bd-newsletter { padding: 18px 14px; }
  .bd-newsletter-title { font-size: 1rem; }
  .bd-cta-title { font-size: 1.15rem; }

  .mobile-nav a { font-size: 1.3rem; }
}

/* ============================================================
   TOUCH – wyłącz hover efekty na urządzeniach dotykowych
   ============================================================ */
@media (hover: none) {
  .srv-card:hover,
  .why-card:hover,
  .blog-card:hover,
  .bd-card:hover,
  .hblog-card:hover,
  .port-item:hover,
  .testi-card:hover,
  .tg-card:hover,
  .p-step:hover,
  .price-card:hover { transform: none; }

  .srv-card:hover .srv-icon,
  .why-card:hover .why-icon { transform: none; background: rgba(232,98,26,.07); color: var(--or); box-shadow: none; }

  .btn-p:hover,
  .btn-o:hover { transform: none; }

  .bd-featured:hover .bd-featured-img img,
  .hblog-featured:hover .hblog-featured-img img,
  .port-item:hover img,
  .blog-card:hover .blog-thumb img { transform: none; }
}

/* ============================================================
   PRINT – uproszczony wygląd do druku
   ============================================================ */
@media print {
  .site-header, .site-footer, .mobile-nav,
  .cursor-dot, .cursor-ring, .hd-aurora,
  .aurora-orb, .bd-newsletter, .bd-cta,
  .cta-sec, .hero-scroll { display: none !important; }

  body { background: #fff; color: #000; }
  .post-body p, .post-body li { color: #333; }
  a { color: #000; text-decoration: underline; }
}

/* ============================================================
   LANDSCAPE TELEFON – specjalne poprawki
   ============================================================ */
@media (max-width: 768px) and (orientation: landscape) {
  .hero-wrap { min-height: auto; padding-block: 80px 32px; }
  .bd-hero { padding: 80px 0 32px; }
  .mobile-nav { justify-content: flex-start; padding-top: 60px; overflow-y: auto; }
  .mobile-nav a { font-size: 1.2rem; padding: 7px 20px; }
  .tci-card-wrap { min-height: 300px; }
  .tci-card { padding: 20px 16px; gap: 10px; }
}

/* ============================================================
   SAFE AREA – iPhone X+ z notchem
   ============================================================ */
@supports (padding: env(safe-area-inset-top)) {
  .site-header { padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); }
  .wrap, .container { padding-left: max(env(safe-area-inset-left), clamp(16px,4vw,28px)); padding-right: max(env(safe-area-inset-right), clamp(16px,4vw,28px)); }
  .mobile-nav { padding-bottom: env(safe-area-inset-bottom); }
  .site-footer { padding-bottom: max(env(safe-area-inset-bottom), 16px); }
}


/* ============================================================
   ACCESSIBILITY — skip nav, focus styles
   ============================================================ */
.skip-nav {
  position: absolute;
  top: -100px;
  left: 16px;
  z-index: 9999;
  background: var(--or);
  color: #fff;
  padding: 10px 20px;
  border-radius: 0 0 var(--r) var(--r);
  font-weight: 600;
  font-size: .88rem;
  text-decoration: none;
  transition: top .3s;
}
.skip-nav:focus { top: 0; }

/* Better focus outlines */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--or) !important;
  outline-offset: 3px !important;
}

/* ============================================================
   PERF — optimised transitions (avoid transition:all)
   ============================================================ */
.btn {
  transition: background-color var(--t), transform var(--t), box-shadow var(--t), color var(--t) !important;
}
.main-nav a {
  transition: color var(--t), background-color var(--t) !important;
}
.site-header {
  transition: padding var(--t), background-color var(--t), backdrop-filter var(--t) !important;
}
.nav-toggle span {
  transition: transform var(--t), opacity var(--t), background-color var(--t) !important;
}

/* ============================================================
   VISUAL — "Dodaj zdjęcie" placeholder ukryty w produkcji
   ============================================================ */
.hero-card-img-placeholder p[style*="Dodaj zdjęcie"] {
  display: none;
}

/* ============================================================
   VISUAL — lepsze wyrównanie hero na małych desktopach
   ============================================================ */
@media (min-width: 769px) and (max-width: 1100px) {
  .hero-card { grid-template-columns: 1fr; }
  .hero-card-img { display: none; }
  .hero-card-body { padding: 44px; }
  .hero-card-body h1 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); }
}

/* ============================================================
   VISUAL — hero stats ukryte na mobile < 480px
   ============================================================ */
@media (max-width: 480px) {
  .hero-stats { display: none; }
  .hero-badges { gap: 5px; }
  .hero-badge { font-size: .65rem; padding: 4px 9px; }
}

/* ============================================================
   VISUAL — smooth scroll
   ============================================================ */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   VISUAL — sekcja blog, lepsze wyrównanie kart na mobile
   ============================================================ */
@media (max-width: 600px) {
  .blog-grid { grid-template-columns: 1fr !important; }
  .hblog-grid { grid-template-columns: 1fr !important; }
}

/* ============================================================
   SEO — image alt fallback visible outline
   ============================================================ */
img { max-width: 100%; height: auto; }
img[alt=""] { outline: 1px dashed rgba(232,98,26,.3); }

/* ============================================================
   VISUAL — better selection color
   ============================================================ */
::selection { background: rgba(232,98,26,.25); color: var(--t1); }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: rgba(232,98,26,.4); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--or); }

/* ============================================================
   SEKCJA PRZED I PO (ba = before/after)
   ============================================================ */
.ba-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.ba-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 22px;
  transition: all var(--ts);
}
.ba-card:hover {
  border-color: var(--b2);
  transform: translateY(-4px);
  box-shadow: 0 18px 50px rgba(0,0,0,.4), 0 0 30px rgba(232,98,26,.08);
}
.ba-firm { margin-bottom: 16px; }
.ba-tag {
  display: inline-block;
  font-size: .63rem; font-family: var(--fm); font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 100px; margin-bottom: 6px;
}
.ba-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.ba-col {
  padding: 12px;
  border-radius: var(--r);
}
.ba-before { background: rgba(229,62,62,.06); border: 1px solid rgba(229,62,62,.15); }
.ba-after  { background: rgba(16,185,129,.06); border: 1px solid rgba(16,185,129,.15); }
.ba-col-header {
  display: flex; align-items: center; gap: 7px;
  font-size: .65rem; font-family: var(--fm); font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--t2); margin-bottom: 10px;
}
.ba-dot {
  width: 7px; height: 7px; border-radius: 50%;
}
.ba-dot.red   { background: #e53e3e; box-shadow: 0 0 6px rgba(229,62,62,.5); }
.ba-dot.green { background: #10b981; box-shadow: 0 0 6px rgba(16,185,129,.5); }
.ba-item {
  display: flex; align-items: flex-start; gap: 7px;
  font-size: .78rem; line-height: 1.5; color: var(--t2);
  padding: 4px 0;
}
.ba-item svg { flex-shrink: 0; margin-top: 2px; }

@media (max-width: 1024px) { .ba-grid { grid-template-columns: 1fr; max-width: 560px; margin-inline: auto; } }
@media (max-width: 768px)  { .ba-grid { grid-template-columns: 1fr; } }

/* ============================================================
   TRUST SIGNALS — contact page
   ============================================================ */
.trust-list { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; }
.trust-item {
  display: flex; align-items: center; gap: 10px;
  font-size: .83rem; color: var(--t2);
}
.trust-item svg { color: var(--or); flex-shrink: 0; }

/* ============================================================
   VISUAL — poprawiony hero na wszystkich desktopach
   ============================================================ */
.hero-card-body h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.12;
}
.hero-card-body h1 br { display: none; }
@media (min-width: 1024px) {
  .hero-card-body h1 br { display: block; }
}

/* ============================================================
   VISUAL — why grid icons bez overflow
   ============================================================ */
.why-icon {
  width: 48px; height: 48px; border-radius: 13px;
  flex-shrink: 0;
}
.why-card h3 { font-size: 1.02rem; margin-bottom: 7px; }
.why-card p  { font-size: .85rem; line-height: 1.7; }

/* ============================================================
   VISUAL — stats poprawa typografii
   ============================================================ */
.stat-n { font-size: clamp(1.8rem, 3vw, 2.8rem); }
.stat-suf { font-size: clamp(1rem, 1.5vw, 1.4rem); }
.stat-l { font-size: .75rem; line-height: 1.4; }

/* ============================================================
   VISUAL — sekcja przed/po na mobile
   ============================================================ */
@media (max-width: 768px) {
  .ba-cols { grid-template-columns: 1fr; gap: 8px; }
  .ba-col  { padding: 10px; }
}

/* ============================================================
   VISUAL — cennik - nowe features
   ============================================================ */
.price-feats { display: flex; flex-direction: column; gap: 8px; margin: 16px 0 20px; }
.price-feat  { display: flex; align-items: flex-start; gap: 8px; font-size: .83rem; line-height: 1.5; }
.price-feat.dim { opacity: .4; }

/* ============================================================
   VISUAL — sekcja dlaczego my na usługach
   ============================================================ */
@media (max-width: 768px) {
  .why-us-stats { grid-template-columns: 1fr !important; }
}

/* ============================================================
   V2 LAYOUT — Reference Design Implementation
   ============================================================ */

/* ── HERO v2 ── */
.v2-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: #06090f;
  overflow: hidden;
  padding-top: 80px;
}
.v2-hero-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: .6;
}
.v2-hero-glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 70% 30%, rgba(232,98,26,.12), transparent 55%),
    radial-gradient(ellipse 40% 60% at 90% 60%, rgba(192,57,43,.08), transparent 50%),
    radial-gradient(ellipse 50% 40% at 10% 80%, rgba(59,130,246,.06), transparent 55%);
  pointer-events: none;
}
.v2-hero-inner {
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 56px;
  align-items: center;
  position: relative;
  z-index: 2;
  padding-block: 80px;
}
.v2-hero-content { display: flex; flex-direction: column; gap: 20px; }

.v2-hero-tags {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.v2-hero-tags span {
  font-family: var(--fm);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--or);
  background: rgba(232,98,26,.1);
  border: 1px solid rgba(232,98,26,.2);
  padding: 4px 11px;
  border-radius: 100px;
}

.v2-hero-h1 {
  font-family: var(--fh);
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -.03em;
  color: #fff;
  margin: 0;
}
.v2-hero-accent {
  color: var(--or);
  position: relative;
  display: inline-block;
}
.v2-hero-accent::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--or), transparent);
  border-radius: 2px;
}

.v2-hero-lead {
  font-size: 1rem;
  color: rgba(255,255,255,.6);
  line-height: 1.75;
  max-width: 520px;
  margin: 0;
}

.v2-hero-bullets { display: flex; flex-direction: column; gap: 10px; }
.v2-hero-bullet {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .88rem;
  color: rgba(255,255,255,.75);
}
.v2-hero-bullet svg { color: var(--or); flex-shrink: 0; }

.v2-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.v2-btn-ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.8);
}
.v2-btn-ghost:hover {
  border-color: rgba(255,255,255,.5);
  background: rgba(255,255,255,.05);
  color: #fff;
}

.v2-hero-badges { display: flex; gap: 8px; flex-wrap: wrap; }
.v2-badge {
  font-size: .72rem;
  color: rgba(255,255,255,.5);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  padding: 5px 12px;
  border-radius: 100px;
  font-family: var(--fm);
}
.v2-badge strong { color: rgba(255,255,255,.85); }

/* Browser mockup */
.v2-hero-mockup { position: relative; }
.v2-hero-img { width: 100%; border-radius: 16px; box-shadow: 0 32px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06); }
.v2-browser {
  background: #0d1a28;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.6), 0 0 60px rgba(232,98,26,.06);
  animation: browserFloat 6s ease-in-out infinite;
}
@keyframes browserFloat {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}
.v2-browser-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: #152338;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.v2-browser-dots { display: flex; gap: 5px; }
.v2-browser-dots span {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.v2-browser-url {
  flex: 1;
  background: rgba(255,255,255,.06);
  border-radius: 6px;
  padding: 3px 10px;
  font-size: 8px;
  color: rgba(255,255,255,.3);
  font-family: var(--fm);
  text-align: center;
}
.v2-browser-body { padding: 0; }

/* Scroll hint */
.v2-scroll-hint {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: .6rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  z-index: 2;
}
.v2-scroll-line {
  width: 1px;
  height: 36px;
  background: linear-gradient(to bottom, rgba(232,98,26,.5), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100% { opacity: .4; transform: scaleY(1); }
  50% { opacity: 1; transform: scaleY(1.2); }
}

/* ── LOGOS v2 ── */
.v2-logos {
  background: #08101a;
  border-top: 1px solid rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.04);
  padding-block: 20px;
  overflow: hidden;
}
.v2-logos-label {
  font-family: var(--fm);
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  text-align: center;
  margin-bottom: 14px;
}

/* ── SHARED SECTION UTILITIES ── */
.v2-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--fm);
  font-size: .64rem;
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--or);
  margin-bottom: 10px;
}
.v2-eyebrow::before {
  content: '';
  width: 20px;
  height: 1px;
  background: var(--or);
  flex-shrink: 0;
}
.v2-sec-hdr {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 40px;
}
.v2-sec-hdr--center {
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 48px;
}
.v2-sec-hdr--center p {
  max-width: 480px;
  color: var(--t2);
  margin-top: 10px;
}
.v2-dot { color: var(--or); }

/* ── WHY SECTION ── */
.v2-why {
  background: #0a1220;
  padding-block: var(--S);
}
.v2-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.v2-why-card {
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px;
  padding: 24px;
  transition: all .5s cubic-bezier(0.22,1,0.36,1);
}
.v2-why-card:hover {
  border-color: rgba(232,98,26,.25);
  transform: translateY(-5px);
  box-shadow: 0 18px 48px rgba(0,0,0,.4), 0 0 30px rgba(232,98,26,.08);
}
.v2-why-icon {
  width: 46px; height: 46px;
  border-radius: 12px;
  display: grid; place-items: center;
  margin-bottom: 14px;
  flex-shrink: 0;
}
.v2-why-card h3 { font-size: .97rem; margin-bottom: 8px; color: var(--t1); }
.v2-why-card p  { font-size: .83rem; color: var(--t2); line-height: 1.7; margin: 0; }

/* ── SERVICES SECTION ── */
.v2-services {
  background: var(--bg);
  padding-block: var(--S);
}
.v2-services-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 40px;
}
.v2-services-header h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  margin: 0;
}
.v2-services-right {
  text-align: right;
  max-width: 280px;
}
.v2-services-right p {
  font-size: .88rem;
  color: var(--t2);
  margin-bottom: 12px;
}
.v2-services-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .85rem;
  font-weight: 600;
  color: var(--or);
  text-decoration: none;
  border: 1px solid rgba(232,98,26,.3);
  padding: 9px 18px;
  border-radius: 100px;
  transition: all .3s;
}
.v2-services-link:hover {
  background: rgba(232,98,26,.1);
  border-color: var(--or);
  color: var(--or);
  box-shadow: 0 0 20px rgba(232,98,26,.2);
}
.v2-srv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.v2-srv-card {
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: all .5s cubic-bezier(0.22,1,0.36,1);
}
.v2-srv-card:hover {
  border-color: rgba(232,98,26,.3);
  transform: translateY(-6px);
  box-shadow: 0 22px 60px rgba(0,0,0,.45), 0 0 40px rgba(232,98,26,.1);
}
.v2-srv-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.v2-srv-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: grid; place-items: center;
}
.v2-srv-num {
  font-family: var(--fm);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  color: rgba(255,255,255,.2);
}
.v2-srv-card h3 { font-size: 1.1rem; color: var(--t1); margin: 0; }
.v2-srv-card p  { font-size: .84rem; color: var(--t2); line-height: 1.75; margin: 0; flex: 1; }
.v2-srv-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.v2-srv-tag {
  font-size: .64rem;
  font-family: var(--fm);
  font-weight: 600;
  letter-spacing: .08em;
  color: rgba(255,255,255,.45);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  padding: 3px 9px;
  border-radius: 100px;
}
.v2-srv-more {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .79rem;
  font-weight: 600;
  color: var(--or);
  text-decoration: none;
  margin-top: auto;
  transition: gap .3s;
}
.v2-srv-more:hover { gap: 9px; }

/* ── PORTFOLIO ── */
.v2-portfolio {
  background: #0a1220;
  padding-block: var(--S);
}
.v2-port-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.v2-port-item {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: #0f1e30;
}
.v2-port-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s cubic-bezier(0.22,1,0.36,1);
}
.v2-port-item:hover img { transform: scale(1.06); }
.v2-port-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(7,13,24,.95) 0%, rgba(7,13,24,.4) 60%, transparent 100%);
  opacity: 0;
  transition: opacity .4s;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px;
}
.v2-port-item:hover .v2-port-overlay { opacity: 1; }
.v2-port-overlay h3 { font-size: 1rem; color: #fff; margin-bottom: 4px; }
.v2-port-overlay p  { font-size: .78rem; color: rgba(255,255,255,.5); margin-bottom: 12px; }
.v2-port-actions { display: flex; gap: 7px; }

/* ── PRZED I PO ── */
.v2-bao {
  background: var(--bg);
  padding-block: var(--S);
}
.v2-bao-wrap {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: center;
}
.v2-bao-label {
  display: flex;
  align-items: center;
  font-family: var(--fm);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.v2-bao-before-lbl { color: #e53e3e; }
.v2-bao-after-lbl  { color: #10b981; }
.v2-bao-screen {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
.v2-bao-screen--before { border-color: rgba(229,62,62,.2); }
.v2-bao-screen--after  { border-color: rgba(16,185,129,.2); }
.v2-bao-bar {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 8px 12px;
  background: #152338;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.v2-bao-dot-r { width:8px;height:8px;border-radius:50%;background:#ff5f56;flex-shrink:0; }
.v2-bao-dot-y { width:8px;height:8px;border-radius:50%;background:#ffbd2e;flex-shrink:0;margin:0 2px; }
.v2-bao-dot-g { width:8px;height:8px;border-radius:50%;background:#27c93f;flex-shrink:0; }
.v2-bao-url-txt {
  flex: 1;
  text-align: center;
  font-size: 8px;
  color: rgba(255,255,255,.25);
  font-family: var(--fm);
  background: rgba(255,255,255,.04);
  border-radius: 4px;
  padding: 2px 8px;
}
.v2-bao-body { min-height: 120px; }
.v2-bao-stats {
  display: flex;
  gap: 0;
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  margin-top: 12px;
  overflow: hidden;
}
.v2-bao-stat {
  flex: 1;
  padding: 10px 12px;
  border-right: 1px solid rgba(255,255,255,.06);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.v2-bao-stat:last-child { border-right: none; }
.v2-bao-stat-l { font-size: .69rem; color: var(--t3); font-family: var(--fm); }
.v2-bao-stat-v { font-size: .83rem; font-weight: 600; }
.v2-bao-arrow-col { display: flex; align-items: center; justify-content: center; }
.v2-bao-arrow-circle {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(232,98,26,.1);
  border: 1px solid rgba(232,98,26,.25);
  display: grid; place-items: center;
  box-shadow: 0 0 20px rgba(232,98,26,.15);
}

/* ── ARTICLES ── */
.v2-articles {
  background: #0a1220;
  padding-block: var(--S);
}
.v2-articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.v2-article-card {
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  overflow: hidden;
  transition: all .5s cubic-bezier(0.22,1,0.36,1);
  display: flex;
  flex-direction: column;
}
.v2-article-card:hover {
  border-color: rgba(232,98,26,.25);
  transform: translateY(-5px);
  box-shadow: 0 20px 52px rgba(0,0,0,.45), 0 0 30px rgba(232,98,26,.08);
}
.v2-article-thumb {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #152338;
  position: relative;
  flex-shrink: 0;
}
.v2-article-thumb a { display: block; width: 100%; height: 100%; }
.v2-article-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(0.22,1,0.36,1); }
.v2-article-card:hover .v2-article-thumb img { transform: scale(1.06); }
.v2-article-no-thumb { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; min-height: 130px; background: linear-gradient(135deg,#0f1e30,#152338); }
.v2-article-cat {
  position: absolute;
  bottom: 10px; left: 10px;
  font-size: .62rem;
  font-family: var(--fm);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(232,98,26,.85);
  padding: 3px 9px;
  border-radius: 6px;
  text-decoration: none;
  backdrop-filter: blur(4px);
}
.v2-article-body { padding: 18px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.v2-article-body h3 { font-size: .94rem; line-height: 1.42; color: var(--t1); margin: 0; }
.v2-article-body h3 a { color: var(--t1); transition: color .3s; }
.v2-article-card:hover .v2-article-body h3 a { color: var(--or); }
.v2-article-body p { font-size: .81rem; color: var(--t2); line-height: 1.68; margin: 0; flex: 1; }
.v2-article-meta { display: flex; align-items: center; gap: 6px; font-size: .71rem; color: var(--t3); font-family: var(--fm); }
.v2-meta-sep { opacity: .4; }
.v2-article-more {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .78rem;
  font-weight: 600;
  color: var(--or);
  text-decoration: none;
  transition: gap .3s;
  margin-top: auto;
}
.v2-article-more:hover { gap: 9px; }

/* ── CTA SPLIT ── */
.v2-cta-split {
  position: relative;
  overflow: hidden;
  padding-block: var(--S);
  background: #06090f;
}
.v2-cta-split-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 20% 50%, rgba(232,98,26,.08), transparent 55%),
    radial-gradient(ellipse 40% 60% at 80% 30%, rgba(59,130,246,.05), transparent 50%);
  pointer-events: none;
}
.v2-cta-split-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 56px;
  align-items: start;
}
.v2-cta-text h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  line-height: 1.15;
  margin-bottom: 14px;
}
.v2-cta-text p { color: var(--t2); max-width: 440px; margin-bottom: 28px; }
.v2-cta-trust { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.v2-trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .85rem;
  color: var(--t2);
}
.v2-contact-links { display: flex; flex-direction: column; gap: 10px; }
.v2-contact-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: .88rem;
  color: var(--t2);
  text-decoration: none;
  transition: color .3s;
}
.v2-contact-link:hover { color: var(--or); }
.v2-contact-link svg { color: var(--or); }

/* Form card */
.v2-form-card {
  background: #0f1e30;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 32px;
  box-shadow: 0 24px 64px rgba(0,0,0,.5), 0 0 0 1px rgba(232,98,26,.06);
}
.v2-form-card h3 { font-size: 1.2rem; margin-bottom: 4px; color: var(--t1); }
.v2-form-sub { font-size: .83rem; color: var(--t2); margin-bottom: 22px; }
.v2-form { display: flex; flex-direction: column; gap: 14px; }
.v2-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.v2-form-group { display: flex; flex-direction: column; gap: 5px; }
.v2-label { font-size: .73rem; font-weight: 600; color: var(--t2); letter-spacing: .04em; }
.v2-input {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r);
  color: var(--t1);
  font-family: var(--fb);
  font-size: .87rem;
  padding: 11px 14px;
  outline: none;
  transition: border-color .3s, background .3s;
  width: 100%;
  box-sizing: border-box;
}
.v2-input:focus {
  border-color: rgba(232,98,26,.5);
  background: rgba(255,255,255,.06);
}
.v2-input::placeholder { color: rgba(255,255,255,.2); }
.v2-input option { background: #0f1e30; }
.v2-textarea { resize: vertical; min-height: 90px; }

/* Testimonial avatar circle */
.v2-tci-avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: rgba(232,98,26,.12);
  border: 2px solid rgba(232,98,26,.35);
  display: grid; place-items: center;
  font-family: var(--fh);
  font-weight: 700;
  font-size: 1rem;
  color: var(--or);
  flex-shrink: 0;
}

/* ── RESPONSIVE v2 ── */
@media (max-width: 1100px) {
  .v2-hero-inner { grid-template-columns: 1fr; }
  .v2-hero-mockup { display: none; }
  .v2-cta-split-inner { grid-template-columns: 1fr; }
  .v2-cta-split-inner .v2-form-card { max-width: 560px; }
}
@media (max-width: 1024px) {
  .v2-why-grid { grid-template-columns: repeat(2, 1fr); }
  .v2-srv-grid { grid-template-columns: repeat(2, 1fr); }
  .v2-port-grid { grid-template-columns: repeat(2, 1fr); }
  .v2-articles-grid { grid-template-columns: repeat(2, 1fr); }
  .v2-services-header { flex-direction: column; align-items: flex-start; }
  .v2-services-right { text-align: left; max-width: none; }
  .v2-bao-wrap { grid-template-columns: 1fr; }
  .v2-bao-arrow-col { transform: rotate(90deg); margin: 8px 0; }
}
@media (max-width: 768px) {
  .v2-hero { min-height: auto; padding-block: 100px 60px; }
  .v2-why-grid { grid-template-columns: 1fr; }
  .v2-srv-grid { grid-template-columns: 1fr; }
  .v2-port-grid { grid-template-columns: 1fr; }
  .v2-articles-grid { grid-template-columns: 1fr; }
  .v2-form-row { grid-template-columns: 1fr; }
  .v2-hero-h1 { font-size: 2rem; }
  .v2-hero-h1 br { display: none; }
}
@media (max-width: 480px) {
  .v2-hero-btns { flex-direction: column; }
  .v2-hero-btns .btn { justify-content: center; }
  .v2-form-card { padding: 22px 18px; }
}

/* ============================================================
   FIXES v3
   ============================================================ */

/* ── Usługi stats bar ── */
.uslugi-stats {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 0;
  background: var(--card2);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 0;
  margin-bottom: 40px;
  overflow: hidden;
}
.uslugi-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 28px 16px;
  border-right: 1px solid var(--b1);
  text-align: center;
}
.uslugi-stat:last-child { border-right: none; }
.uslugi-stat-n {
  font-family: var(--fh);
  font-size: 2.6rem;
  font-weight: 800;
  color: var(--or);
  line-height: 1;
}
.uslugi-stat-l {
  font-size: .79rem;
  color: var(--t2);
  line-height: 1.45;
}
@media(max-width:600px){
  .uslugi-stats { grid-template-columns: 1fr; }
  .uslugi-stat { border-right: none; border-bottom: 1px solid var(--b1); }
  .uslugi-stat:last-child { border-bottom: none; }
}

/* ── AURORA tło — wszystkie strony ── */
.hd-aurora {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.hd-aurora::before {
  content: '';
  position: absolute;
  width: 150vw; height: 150vw;
  top: -50vw; left: -25vw;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(232,98,26,.07) 0%,
    rgba(59,130,246,.04) 35%,
    transparent 65%);
  animation: auroraR 22s linear infinite;
  transform-origin: 60% 50%;
}
.hd-aurora::after {
  content: '';
  position: absolute;
  width: 130vw; height: 130vw;
  bottom: -45vw; right: -20vw;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(192,57,43,.05) 0%,
    rgba(232,98,26,.04) 30%,
    transparent 60%);
  animation: auroraR 30s linear infinite reverse;
  transform-origin: 40% 50%;
}
@keyframes auroraR {
  0%   { transform: rotate(0deg) scale(1); }
  50%  { transform: rotate(180deg) scale(1.08); }
  100% { transform: rotate(360deg) scale(1); }
}
.aurora-orb {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  filter: blur(70px);
  animation: orbF 12s ease-in-out infinite;
}
.aurora-orb-1 {
  width: 500px; height: 500px;
  top: -80px; right: -80px;
  background: radial-gradient(circle, rgba(232,98,26,.12), transparent 70%);
  opacity: .15;
}
.aurora-orb-2 {
  width: 400px; height: 400px;
  bottom: 25%; left: -60px;
  background: radial-gradient(circle, rgba(59,130,246,.09), transparent 70%);
  animation-delay: -4s;
  animation-duration: 16s;
  opacity: .12;
}
.aurora-orb-3 {
  width: 340px; height: 340px;
  top: 45%; right: 12%;
  background: radial-gradient(circle, rgba(192,57,43,.07), transparent 70%);
  animation-delay: -8s;
  animation-duration: 19s;
}
@keyframes orbF {
  0%,100% { transform: translateY(0) scale(1); }
  33% { transform: translateY(-30px) scale(1.04); }
  66% { transform: translateY(18px) scale(0.97); }
}

/* Wszystko nad tłem */
section, .v2-hero, .v2-logos, .v2-why, .v2-services,
.v2-portfolio, .v2-bao, .testi-cinematic-sec,
.v2-articles, .v2-cta-split,
.page-hero, .hblog-hero, .hblog-main,
.bd-hero, .bd-main, .bd-cta,
.sec, .logos-sec, .cta-sec,
.site-footer {
  position: relative;
  z-index: 1;
}

/* ── Page hero glow — wszystkie podstrony ── */
.page-hero {
  position: relative;
  overflow: hidden;
}
.page-hero-glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 65% 80% at 85% 40%, rgba(232,98,26,.1), transparent 55%),
    radial-gradient(ellipse 40% 60% at 10% 70%, rgba(59,130,246,.06), transparent 50%);
  pointer-events: none;
  z-index: 0;
}
.page-hero-inner { position: relative; z-index: 1; }
.page-hero .wrap.page-hero-inner { position: relative; z-index: 1; }

/* ── Testimonials — fix overflow ── */
.tci-card {
  word-break: break-word;
  overflow: hidden;
}
.tci-quote {
  font-size: clamp(1.1rem, 2.5vw, 1.8rem);
  line-height: 1.3;
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: auto;
}
.tci-desc {
  font-size: .9rem;
  line-height: 1.75;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  word-break: normal;
  overflow-wrap: break-word;
}
.tci-author {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.tci-card-wrap {
  min-height: 380px;
}
@media(max-width:480px){
  .tci-card { padding: 24px 18px; gap: 14px; }
  .tci-quote { font-size: 1.1rem; }
  .tci-desc  { font-size: .84rem; -webkit-line-clamp: 4; }
  .tci-card-wrap { min-height: 420px; }
}

/* ── Artykuły na HP — usunięto kategori-tag ── */
.v2-article-thumb { position: relative; }
/* Zostawiamy kategorię tylko na blogu, nie na HP */

/* ── Page hero na podstronach — wyraźne tło ── */
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 60%,
    rgba(7,13,24,.6) 100%
  );
  pointer-events: none;
  z-index: 0;
}

/* Naprawia nakładanie się nav z pierwszą sekcją */
.hblog-hero, .bd-hero { position: relative; z-index: 1; }

/* ============================================================
   MOBILE FIX v4 — Samsung S23 Ultra i inne telefony
   Priorytet: naprawienie layoutu na małych ekranach
   ============================================================ */

/* ── Globalne ── */
* { box-sizing: border-box !important; }
html, body { overflow-x: hidden !important; max-width: 100vw !important; }
img, video, iframe, svg { max-width: 100% !important; height: auto; }

/* ── HEADER mobile ── */
@media (max-width: 900px) {
  .main-nav { display: none !important; }
  .nav-toggle { display: flex !important; }
  .header-actions .btn-o { display: none !important; }
  .header-inner { gap: 12px !important; }
  .site-header .site-logo img,
  .site-header .custom-logo-link img,
  header img.custom-logo { height: 32px !important; max-height: 32px !important; }
}

/* ── V2 HERO mobile ── */
@media (max-width: 900px) {
  .v2-hero { min-height: auto !important; padding: 90px 0 48px !important; }
  .v2-hero-inner { grid-template-columns: 1fr !important; gap: 0 !important; padding-block: 0 !important; }
  .v2-hero-mockup { display: none !important; }
  .v2-hero-h1 { font-size: clamp(1.7rem, 6vw, 2.4rem) !important; }
  .v2-hero-h1 br { display: none !important; }
  .v2-hero-lead { font-size: .92rem !important; }
  .v2-hero-btns { flex-direction: column !important; gap: 10px !important; }
  .v2-hero-btns .btn { width: 100% !important; justify-content: center !important; }
  .v2-hero-badges { gap: 6px !important; }
  .v2-badge { font-size: .68rem !important; padding: 4px 10px !important; }
  .v2-scroll-hint { display: none !important; }
  .v2-hero-content { gap: 16px !important; }
}

/* ── LOGOS ── */
@media (max-width: 900px) {
  .mq-track { gap: 12px !important; }
  .logo-chip span { font-size: .75rem !important; }
}

/* ── WHY GRID ── */
@media (max-width: 900px) {
  .v2-why-grid { grid-template-columns: 1fr !important; gap: 12px !important; }
  .v2-why-card { padding: 20px !important; }
}
@media (min-width: 600px) and (max-width: 900px) {
  .v2-why-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── SERVICES ── */
@media (max-width: 900px) {
  .v2-services-header { flex-direction: column !important; align-items: flex-start !important; }
  .v2-services-right { text-align: left !important; max-width: 100% !important; }
  .v2-srv-grid { grid-template-columns: 1fr !important; }
}
@media (min-width: 600px) and (max-width: 900px) {
  .v2-srv-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── PORTFOLIO ── */
@media (max-width: 900px) {
  .v2-port-grid { grid-template-columns: 1fr !important; }
  .v2-port-item { aspect-ratio: 16/9 !important; }
}
@media (min-width: 600px) and (max-width: 900px) {
  .v2-port-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── PRZED I PO ── */
@media (max-width: 900px) {
  .v2-bao-wrap { grid-template-columns: 1fr !important; gap: 16px !important; }
  .v2-bao-arrow-col { transform: rotate(90deg) !important; margin: 0 !important; display: flex !important; justify-content: center !important; }
  .v2-bao-stats { gap: 0 !important; }
}

/* ── TESTIMONIALS ── */
@media (max-width: 900px) {
  .testi-cinematic-sec { padding-block: 56px !important; }
  .tci-slider-wrap { gap: 8px !important; }
  .tci-arrow { width: 36px !important; height: 36px !important; }
  .tci-arrow svg { width: 18px !important; height: 18px !important; }
  .tci-card { padding: 24px 18px !important; gap: 12px !important; }
  .tci-quote { font-size: clamp(1rem,4vw,1.4rem) !important; }
  .tci-desc { font-size: .83rem !important; -webkit-line-clamp: 4 !important; }
  .tci-card-wrap { min-height: 400px !important; }
  .tci-stars svg { width: 22px !important; height: 22px !important; }
}

/* ── ARTICLES ── */
@media (max-width: 900px) {
  .v2-articles-grid { grid-template-columns: 1fr !important; }
}
@media (min-width: 600px) and (max-width: 900px) {
  .v2-articles-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── CTA SPLIT ── */
@media (max-width: 900px) {
  .v2-cta-split-inner { grid-template-columns: 1fr !important; gap: 36px !important; }
  .v2-form-row { grid-template-columns: 1fr !important; }
  .v2-form-card { padding: 22px 18px !important; max-width: 100% !important; }
  .v2-cta-text h2 { font-size: clamp(1.6rem,5vw,2.2rem) !important; }
}

/* ── SEKCJE OGÓLNE ── */
@media (max-width: 900px) {
  .wrap, .container { padding-inline: 16px !important; }
  .sec { padding-block: 56px !important; }
  h1 { font-size: clamp(1.6rem,6vw,2.4rem) !important; }
  h2 { font-size: clamp(1.4rem,5vw,2rem) !important; }

  /* Sekcja headers */
  .v2-sec-hdr { flex-direction: column !important; align-items: flex-start !important; gap: 12px !important; }
  .v2-sec-hdr--center { align-items: center !important; }
}

/* ── PAGE HERO podstrony ── */
@media (max-width: 900px) {
  .page-hero { padding-top: 96px !important; padding-bottom: 36px !important; }
  .page-hero h1 { font-size: clamp(1.5rem,5vw,2rem) !important; }
}

/* ── BLOG / ARCHIVE ── */
@media (max-width: 900px) {
  .hblog-hero { padding-top: 88px !important; padding-bottom: 32px !important; }
  .hblog-layout { grid-template-columns: 1fr !important; }
  .hblog-sidebar { display: none !important; }
  .hblog-featured { grid-template-columns: 1fr !important; }
  .hblog-grid { grid-template-columns: 1fr !important; }
  .bd-grid { grid-template-columns: 1fr !important; }
  .bd-featured { grid-template-columns: 1fr !important; }
}
@media (min-width: 600px) and (max-width: 900px) {
  .hblog-grid { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── FOOTER ── */
@media (max-width: 900px) {
  .footer-top { grid-template-columns: 1fr !important; gap: 20px !important; }
  .footer-bottom { flex-direction: column !important; gap: 6px !important; font-size: .78rem !important; }
  .footer-logo-link img,
  footer img.custom-logo { height: 36px !important; max-height: 36px !important; }
}

/* ── CENNIK ── */
@media (max-width: 900px) {
  .pricing-grid { grid-template-columns: 1fr !important; max-width: 100% !important; }
  .price-card--feat { transform: none !important; }
}

/* ── FAQ ── */
@media (max-width: 900px) {
  .faq-q { font-size: .86rem !important; padding: 14px 16px !important; }
}

/* ── KONTAKT ── */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .form-row { grid-template-columns: 1fr !important; }
}

/* ── USŁUGI stats ── */
@media (max-width: 900px) {
  .uslugi-stats { grid-template-columns: repeat(3,1fr) !important; }
  .uslugi-stat-n { font-size: 1.8rem !important; }
}
@media (max-width: 480px) {
  .uslugi-stats { grid-template-columns: 1fr !important; }
  .uslugi-stat { border-right: none !important; border-bottom: 1px solid var(--b1) !important; padding: 18px !important; }
  .uslugi-stat:last-child { border-bottom: none !important; }
}

/* ── PRZED I PO cards ── */
@media (max-width: 900px) {
  .ba-grid { grid-template-columns: 1fr !important; }
  .ba-cols { grid-template-columns: 1fr 1fr !important; }
}

/* ── TOUCH — wyłącz hover na mobile ── */
@media (hover: none) {
  .v2-why-card:hover,
  .v2-srv-card:hover,
  .v2-port-item:hover img,
  .v2-article-card:hover,
  .v2-browser { animation: none !important; transform: none !important; }
  .v2-port-overlay { opacity: 1 !important; }
}

/* ── iOS / notch safe area ── */
@supports (padding: env(safe-area-inset-top)) {
  .site-header { padding-left: max(env(safe-area-inset-left),16px) !important; padding-right: max(env(safe-area-inset-right),16px) !important; }
  .wrap, .container { padding-inline: max(env(safe-area-inset-left),16px) max(env(safe-area-inset-right),16px) !important; }
  .mobile-nav { padding-bottom: env(safe-area-inset-bottom) !important; }
}

/* ── PREVENT ZOOM on input iOS ── */
input, textarea, select { font-size: 16px !important; }

/* ── Poprawka: v2-article-cat USUNIĘTY z HP ── */
.v2-articles .v2-article-cat { display: none !important; }

/* ============================================================
   AUDIT v4 — TOP AGENCY UPGRADES
   ============================================================ */

/* ── 1. DESIGN TOKENS — dodatkowe zmienne ── */
:root {
  --glass:   rgba(255,255,255,.04);
  --glass2:  rgba(255,255,255,.07);
  --or-glow: 0 0 30px rgba(232,98,26,.3);
  --card-shadow: 0 20px 60px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.05);
  --section-gap: 120px;
}

/* ── 2. STATS BAR ── */
.v2-stats-bar {
  background: linear-gradient(135deg, #08101c, #0d1828);
  border-top: 1px solid rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.04);
  padding-block: 48px;
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.v2-stats-bar::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 100% at 50% 50%, rgba(232,98,26,.04), transparent 65%);
  pointer-events: none;
}
.v2-stats-inner {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 0;
  position: relative;
  z-index: 1;
}
.v2-stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 0 24px;
  border-right: 1px solid rgba(255,255,255,.06);
  text-align: center;
}
.v2-stat-item:last-child { border-right: none; }
.v2-stat-num {
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.v2-stat-n {
  font-family: var(--fh);
  font-size: clamp(2.4rem, 4vw, 3.4rem);
  font-weight: 800;
  color: var(--or);
  line-height: 1;
  letter-spacing: -.04em;
}
.v2-stat-suf {
  font-family: var(--fh);
  font-size: clamp(1rem, 2vw, 1.4rem);
  font-weight: 700;
  color: var(--or);
  opacity: .7;
}
.v2-stat-label {
  font-size: .78rem;
  color: var(--t2);
  line-height: 1.45;
}

@media(max-width:900px) {
  .v2-stats-inner { grid-template-columns: repeat(2,1fr); gap: 0; }
  .v2-stat-item { padding: 16px; border-right: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.06); }
  .v2-stat-item:nth-child(2) { border-right: none; }
  .v2-stat-item:nth-child(3), .v2-stat-item:nth-child(4) { border-bottom: none; }
}
@media(max-width:480px) {
  .v2-stats-inner { grid-template-columns: 1fr 1fr; }
  .v2-stat-n { font-size: 2rem; }
}

/* ── 3. PROCESS SECTION ── */
.v2-process {
  background: #08101c;
  padding-block: var(--S);
  position: relative;
  overflow: hidden;
}
.v2-process::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 100% 50%, rgba(232,98,26,.06), transparent 55%),
    radial-gradient(ellipse 40% 50% at 0% 50%, rgba(59,130,246,.04), transparent 55%);
  pointer-events: none;
}
.v2-proc-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 0;
  position: relative;
}
/* Connecting line */
.v2-proc-grid::before {
  content: '';
  position: absolute;
  top: 28px;
  left: calc(12.5% + 12px);
  right: calc(12.5% + 12px);
  height: 1px;
  background: linear-gradient(90deg,
    rgba(232,98,26,.5) 0%,
    rgba(232,98,26,.2) 33%,
    rgba(232,98,26,.2) 66%,
    rgba(232,98,26,.5) 100%
  );
  z-index: 0;
}
.v2-proc-card {
  position: relative;
  z-index: 1;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.v2-proc-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.v2-proc-num {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: rgba(232,98,26,.1);
  border: 1px solid rgba(232,98,26,.3);
  display: grid; place-items: center;
  font-family: var(--fm);
  font-size: .88rem;
  font-weight: 700;
  color: var(--or);
  position: relative;
  z-index: 2;
  box-shadow: 0 0 20px rgba(232,98,26,.15);
}
.v2-proc-time {
  font-family: var(--fm);
  font-size: .62rem;
  color: var(--t3);
  letter-spacing: .08em;
  font-weight: 600;
}
.v2-proc-icon {
  width: 36px; height: 36px;
  color: rgba(255,255,255,.35);
}
.v2-proc-card h3 { font-size: 1.05rem; color: var(--t1); }
.v2-proc-card p  { font-size: .83rem; color: var(--t2); line-height: 1.7; flex: 1; }
.v2-proc-arrow {
  display: none;
  color: var(--or);
}

@media(max-width:900px) {
  .v2-proc-grid { grid-template-columns: 1fr; gap: 24px; }
  .v2-proc-grid::before { display: none; }
  .v2-proc-card { padding: 20px; background: #0f1e30; border: 1px solid rgba(255,255,255,.06); border-radius: 14px; flex-direction: column; }
  .v2-proc-arrow { display: flex; margin-top: auto; }
}
@media(min-width:600px) and (max-width:900px) {
  .v2-proc-grid { grid-template-columns: repeat(2,1fr); }
}

/* ── 4. HERO — wzmocnienie efektów ── */
.v2-hero-h1 {
  font-size: clamp(2.2rem, 4.5vw, 4rem) !important;
  letter-spacing: -.04em !important;
}
.v2-hero-accent {
  background: linear-gradient(135deg, var(--or), #f59e0b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.v2-hero-accent::after { display: none; }

/* ── 5. SEKCJE — spójna typografia ── */
h2 {
  letter-spacing: -.025em;
}
.v2-sec-hdr h2 {
  font-size: clamp(1.6rem, 3vw, 2.6rem);
}

/* ── 6. KARTY — unifikacja cieni i hover ── */
.v2-why-card,
.v2-srv-card,
.v2-article-card,
.v2-port-item,
.v2-bao-screen {
  transition: transform .45s cubic-bezier(0.22,1,0.36,1),
              border-color .35s ease,
              box-shadow .45s cubic-bezier(0.22,1,0.36,1) !important;
}

/* ── 7. BUTTONS — wzmocnienie ── */
.btn-p {
  background: linear-gradient(135deg, var(--or), #d45510) !important;
  box-shadow: 0 4px 20px rgba(232,98,26,.3), 0 0 0 1px rgba(232,98,26,.2) !important;
  position: relative;
  overflow: hidden;
}
.btn-p::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 200%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transition: left .6s ease;
}
.btn-p:hover::before { left: 100%; }
.btn-p:hover {
  box-shadow: 0 8px 32px rgba(232,98,26,.5), 0 0 60px rgba(232,98,26,.2) !important;
  transform: translateY(-2px) !important;
}

/* ── 8. SERVICES — gradient border on hover ── */
.v2-srv-card {
  position: relative;
}
.v2-srv-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(135deg, transparent, rgba(232,98,26,.3), transparent);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity .4s;
}
.v2-srv-card:hover::before { opacity: 1; }

/* ── 9. HERO BROWSER — floating tags ── */
.v2-browser {
  position: relative;
}
.v2-browser::after {
  content: 'LIVE';
  position: absolute;
  top: -10px; right: -10px;
  background: #10b981;
  color: #fff;
  font-family: var(--fm);
  font-size: .56rem;
  font-weight: 700;
  letter-spacing: .12em;
  padding: 3px 8px;
  border-radius: 100px;
  box-shadow: 0 0 12px rgba(16,185,129,.5);
}

/* ── 10. SCROLL PROGRESS BAR ── */
.v2-scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--or), #f59e0b);
  z-index: 9999;
  width: 0%;
  transition: width .1s linear;
  box-shadow: 0 0 8px rgba(232,98,26,.5);
}

/* ── 11. BACK TO TOP ── */
.v2-back-top {
  position: fixed;
  bottom: 28px;
  right: 24px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--or);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 500;
  border: none;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .35s, transform .35s, box-shadow .35s;
  box-shadow: 0 4px 20px rgba(232,98,26,.4);
}
.v2-back-top.show {
  opacity: 1;
  transform: translateY(0);
}
.v2-back-top:hover {
  box-shadow: 0 8px 30px rgba(232,98,26,.6);
  transform: translateY(-3px);
}
.v2-back-top svg { width: 18px; height: 18px; }

/* ── 12. HERO TAGS — animowane ── */
.v2-hero-tags span {
  animation: tagPop .6s cubic-bezier(0.22,1,0.36,1) both;
}
.v2-hero-tags span:nth-child(1) { animation-delay: .1s; }
.v2-hero-tags span:nth-child(2) { animation-delay: .2s; }
.v2-hero-tags span:nth-child(3) { animation-delay: .3s; }
@keyframes tagPop {
  from { opacity: 0; transform: translateY(8px) scale(.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── 13. TESTIMONIALS — poprawa ── */
.tci-card {
  background: linear-gradient(145deg, #101c2c, #0d1825) !important;
  border: 1px solid rgba(232,98,26,.2) !important;
}
.tci-cinematic-sec { padding-block: 100px; }

/* ── 14. FOOTER — ulepszenia ── */
.site-footer {
  border-top: 1px solid rgba(255,255,255,.04);
}
.footer-top {
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.footer-bottom {
  padding-top: 24px;
}
.f-social {
  position: relative;
  overflow: hidden;
}
.f-social::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 10px;
  background: var(--or);
  opacity: 0;
  transition: opacity .3s;
  z-index: -1;
}
.f-social:hover::after { opacity: .12; }
.f-social:hover { border-color: rgba(232,98,26,.4) !important; color: var(--or) !important; }

/* ── 15. BREADCRUMBS — poprawa ── */
.breadcrumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: .76rem;
  color: var(--t3);
  margin-bottom: 20px;
  font-family: var(--fm);
}
.breadcrumbs a { color: var(--t3); transition: color .25s; }
.breadcrumbs a:hover { color: var(--or); }
.breadcrumbs .sep { opacity: .3; }
.breadcrumbs .current { color: var(--or); font-weight: 600; }

/* ── 16. PAGE HERO — spójny design ── */
.page-hero {
  background: var(--bg);
  padding-top: 120px;
  padding-bottom: 60px;
}
.page-hero h1 { margin-top: 10px; }
.page-hero p {
  font-size: 1.05rem;
  color: var(--t2);
  max-width: 520px;
  margin-top: 12px;
  line-height: 1.75;
}

/* ── 17. SCROLL REVEAL — wzmocnienie ── */
.rev {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s cubic-bezier(0.22,1,0.36,1), transform .7s cubic-bezier(0.22,1,0.36,1);
}
.rev.in {
  opacity: 1;
  transform: translateY(0);
}
.rev.d1 { transition-delay: .05s; }
.rev.d2 { transition-delay: .12s; }
.rev.d3 { transition-delay: .19s; }
.rev.d4 { transition-delay: .26s; }
.rev.d5 { transition-delay: .33s; }
.rev.d6 { transition-delay: .40s; }

/* ── 18. LOGO CHIP — hover ── */
.logo-chip {
  transition: background .3s, transform .3s !important;
}
.logo-chip:hover {
  background: rgba(255,255,255,.06) !important;
  transform: translateY(-2px) !important;
}

/* ── 19. PRZED I PO — wzmocnienie ── */
.v2-bao-screen--after {
  box-shadow: 0 0 40px rgba(16,185,129,.08), 0 16px 48px rgba(0,0,0,.4) !important;
}
.v2-bao-arrow-circle {
  animation: arrowPulse 2s ease-in-out infinite;
}
@keyframes arrowPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(232,98,26,.3); }
  50% { box-shadow: 0 0 0 12px rgba(232,98,26,.0); }
}

/* ── 20. MOBILE NAV — poprawa ── */
.mobile-nav {
  background: #06090f !important;
}
.mobile-nav a:hover {
  background: rgba(232,98,26,.08) !important;
  color: var(--or) !important;
}

/* ── RESPONSIVE dodatkowe ── */
@media(max-width:900px) {
  .v2-stats-bar { padding-block: 32px; }
  .v2-process { padding-block: 56px; }
  .v2-sec-hdr--center p { font-size: .9rem; }
}

/* ============================================================
   PORTFOLIO v2 — nowy layout z mockupami
   ============================================================ */

/* Hero stats */
.port-hero-stats {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 32px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  overflow: hidden;
  max-width: 560px;
}
.port-hero-stat {
  flex: 1;
  padding: 18px 20px;
  text-align: center;
  border-right: 1px solid rgba(255,255,255,.06);
}
.port-hero-stat:last-child { border-right: none; }
.port-hero-n {
  display: block;
  font-family: var(--fh);
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--or);
  line-height: 1;
}
.port-hero-l {
  display: block;
  font-size: .72rem;
  color: var(--t3);
  margin-top: 4px;
  line-height: 1.35;
}
.port-hero-sep { width: 1px; background: rgba(255,255,255,.06); align-self: stretch; }

/* Portfolio grid */
.port-v2-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 36px;
}
.port-v2-featured {
  grid-column: 1 / -1;
}
.port-v2-item {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: #0d1828;
  border: 1px solid rgba(255,255,255,.06);
  transition: border-color .4s, box-shadow .4s;
}
.port-v2-item:hover {
  border-color: rgba(232,98,26,.3);
  box-shadow: 0 0 40px rgba(232,98,26,.1), 0 20px 60px rgba(0,0,0,.5);
}

/* SVG mockup */
.port-v2-mock {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
  display: block;
}
.port-v2-featured .port-v2-mock {
  aspect-ratio: 16/7;
}

/* Overlay */
.port-v2-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(6,9,15,.97) 0%,
    rgba(6,9,15,.85) 35%,
    rgba(6,9,15,.3) 65%,
    transparent 100%
  );
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px;
  opacity: 0;
  transition: opacity .4s;
}
.port-v2-item:hover .port-v2-overlay { opacity: 1; }

.port-v2-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.port-v2-type {
  font-size: .63rem;
  font-family: var(--fm);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--or);
  background: rgba(232,98,26,.12);
  border: 1px solid rgba(232,98,26,.25);
  padding: 3px 10px;
  border-radius: 100px;
}
.port-v2-year {
  font-size: .63rem;
  font-family: var(--fm);
  color: var(--t3);
}
.port-v2-overlay h3 {
  font-size: 1.15rem;
  color: #fff;
  margin-bottom: 8px;
  line-height: 1.3;
}
.port-v2-featured .port-v2-overlay h3 { font-size: 1.5rem; }
.port-v2-overlay p {
  font-size: .84rem;
  color: rgba(255,255,255,.6);
  line-height: 1.65;
  margin-bottom: 14px;
}
.port-v2-results {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.port-v2-results span {
  font-size: .68rem;
  font-family: var(--fm);
  font-weight: 700;
  color: #10b981;
  background: rgba(16,185,129,.1);
  border: 1px solid rgba(16,185,129,.2);
  padding: 3px 10px;
  border-radius: 100px;
}
.port-v2-actions { display: flex; gap: 8px; }

/* Portfolio CTA box */
.port-v2-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  background: linear-gradient(135deg, rgba(232,98,26,.1), rgba(192,57,43,.06));
  border: 1px solid rgba(232,98,26,.25);
  border-radius: 18px;
  padding: 36px 40px;
  flex-wrap: wrap;
}
.port-v2-cta-left h3 {
  font-size: 1.2rem;
  color: var(--t1);
  margin-bottom: 8px;
  max-width: 540px;
}
.port-v2-cta-left p {
  font-size: .88rem;
  color: var(--t2);
  max-width: 480px;
}
.port-v2-cta-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.port-v2-cta-note {
  font-size: .72rem;
  color: var(--t3);
  text-align: center;
}

/* Blog cat tag override — usunięcie pomarańczowych tagów */
.bd-card-cat { display: none !important; }
.v2-article-cat { display: none !important; }
.hblog-cat-tag { display: none !important; }

/* Ale zostaw na featured post tylko label */
.bd-cat-label {
  display: inline-block;
  font-size: .62rem;
  font-family: var(--fm);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--t3);
  margin-bottom: 9px;
}

/* Responsive */
@media(max-width:900px) {
  .port-v2-grid { grid-template-columns: 1fr; }
  .port-v2-featured { grid-column: auto; }
  .port-v2-featured .port-v2-mock { aspect-ratio: 16/10; }
  .port-v2-overlay { opacity: 1; background: linear-gradient(to top, rgba(6,9,15,.96) 0%, rgba(6,9,15,.7) 40%, transparent 80%); }
  .port-v2-cta { flex-direction: column; padding: 24px 20px; }
  .port-v2-cta-right { width: 100%; }
  .port-v2-cta-right .btn { width: 100%; justify-content: center; }
  .port-hero-stats { max-width: 100%; }
  .port-hero-n { font-size: 1.4rem; }
}

/* ══ PORTFOLIO PAGE — v7 fixes ══ */
.port-section-label {
  margin-bottom: 28px;
}
.port-section-label p {
  font-size: .9rem;
  color: var(--t2);
  margin-top: 6px;
}
/* Mock SVG containers — fixed height so SVGs always visible */
.port-v2-mock {
  width: 100%;
  display: block;
  overflow: hidden;
  background: #0a1420;
}
.port-v2-item:not(.port-v2-featured) .port-v2-mock {
  height: 320px;
}
.port-v2-featured .port-v2-mock {
  height: 360px;
}
.port-v2-mock svg {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}
/* On mobile always show overlay */
@media(max-width:900px) {
  .port-v2-item:not(.port-v2-featured) .port-v2-mock { height: 260px; }
  .port-v2-featured .port-v2-mock { height: 280px; }
}

/* ══ HEADER STICKY — final override ══ */
.site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 99999 !important;
}
/* Remove site-header from any z-index:1 bulk rules */
.hero-wrap, section, .page-hero, .v2-hero,
.v2-logos, .v2-why, .v2-services, .v2-portfolio,
.v2-bao, .v2-articles, .v2-cta-split,
.testi-cinematic-sec, .logos-sec, .cta-sec,
.sec, .site-footer, .blog-page-hero, .hblog-hero {
  position: relative;
  z-index: 1;
}

/* ================================================================
   AGENCY UPGRADE — v8 patch
   Blog cards, sekcje z tłem, cursor upgrade
   ================================================================ */

/* ── CURSOR — premium magnetic ───────────────────────────── */
@media(pointer:fine){
  body,body * { cursor: none !important; }

  /* Kursor MUSI być ponad WSZYSTKIM — z-index: 999999 */
  .cursor-dot,
  .cursor-ring {
    position: fixed !important;
    top: 0 !important; left: 0 !important;
    pointer-events: none !important;
    z-index: 999999 !important; /* ponad headerem, sekcjami, wszystkim */
    border-radius: 50%;
    transform: translate(-50%,-50%);
    will-change: transform;
  }
  .cursor-dot {
    width: 6px !important; height: 6px !important;
    background: var(--or) !important;
    transition: width .2s var(--ease), height .2s var(--ease), background .2s !important;
  }
  .cursor-ring {
    width: 36px !important; height: 36px !important;
    border: 1.5px solid rgba(232,98,26,.5) !important;
    transition: width .4s var(--ease), height .4s var(--ease),
                border-color .3s, background .3s !important;
  }
  .cursor-ring.hov {
    width: 56px !important; height: 56px !important;
    background: rgba(232,98,26,.08) !important;
    border-color: var(--or) !important;
  }
  .cursor-ring.text {
    width: 3px !important; height: 28px !important;
    border-radius: 2px !important;
    border: none !important;
    background: var(--or) !important;
  }
  .cursor-ring.click {
    transform: translate(-50%,-50%) scale(0.75) !important;
  }
}

/* ── SEKCJE Z WIDOCZNYM TŁEM — glassmorphism bloki ───────── */
/* Każda sekcja dostaje subtelny glass border */
.v2-why,
.v2-services,
.v2-process,
.v2-portfolio,
.v2-bao,
.testi-cinematic-sec,
.ag-blog,
.v2-cta-split,
.v2-stats-bar {
  position: relative;
  /* isolation: isolate; -- REMOVED: breaks cursor + header stacking */
}

/* NAPRAWIONE: brak ::before overlay — kursor i header muszą przebić się przez wszystko */
/* Tło osiągane przez background rgba bezpośrednio na sekcji */
.v2-why .wrap,
.v2-services .wrap,
.v2-portfolio .wrap,
.testi-cinematic-sec .wrap,
.v2-cta-split .wrap { position: relative; z-index: 1; }

/* Sekcje "okienkowane" — widać tło przez border */
.v2-why,
.v2-portfolio {
  background: rgba(7,13,24,.75) !important;
  border-top: 1px solid rgba(255,255,255,.05);
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.v2-services,
.v2-bao {
  background: rgba(10,18,40,.8) !important;
}
.v2-stats-bar {
  background: rgba(8,16,32,.85) !important;
  border-top: 1px solid rgba(255,255,255,.05);
  border-bottom: 1px solid rgba(255,255,255,.05);
}

/* ── BLOG AGENCYJNY ──────────────────────────────────────── */
.ag-blog {
  padding-block: var(--S);
  background: rgba(7,13,24,.7) !important;
  position: relative;
  overflow: hidden;
}
.ag-blog-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 10% 80%, rgba(232,98,26,.06), transparent 55%),
    radial-gradient(ellipse 40% 50% at 90% 20%, rgba(59,130,246,.04), transparent 50%);
  pointer-events: none; z-index: 1;
}
.ag-blog-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--or);
  text-decoration: none;
  border: 1px solid rgba(232,98,26,.25);
  padding: 9px 18px;
  border-radius: 100px;
  transition: all .3s;
  white-space: nowrap;
  align-self: flex-end;
}
.ag-blog-link:hover {
  background: rgba(232,98,26,.08);
  border-color: var(--or);
  gap: 12px;
  color: var(--or);
}

/* Blog grid */
.ag-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: rgba(255,255,255,.04);
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.06);
}

/* Post card */
.ag-post-card {
  background: #0a1220;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: background .4s;
}
.ag-post-card:hover { background: #0d1828; }

/* Numer dekoracyjny w tle */
.ag-post-num {
  position: absolute;
  top: 12px; right: 16px;
  font-family: var(--fh);
  font-size: 5rem;
  font-weight: 800;
  color: rgba(255,255,255,.025);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  transition: color .4s;
}
.ag-post-card:hover .ag-post-num { color: rgba(232,98,26,.06); }

/* Thumb */
.ag-post-thumb {
  position: relative;
  height: 200px;
  overflow: hidden;
  flex-shrink: 0;
  background: #0f1e30;
}
.ag-post-thumb a { display: block; width: 100%; height: 100%; }
.ag-post-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s cubic-bezier(0.22,1,0.36,1), filter .5s;
  filter: brightness(.9) saturate(.85);
}
.ag-post-card:hover .ag-post-thumb img {
  transform: scale(1.06);
  filter: brightness(1) saturate(1);
}

/* No-thumb fallback */
.ag-post-no-thumb {
  display: flex;
  align-items: flex-end;
  padding: 20px;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, #0d1828, #152338);
  text-decoration: none;
}
.ag-post-no-thumb-label {
  font-family: var(--fh);
  font-size: 1.1rem;
  font-weight: 700;
  color: rgba(255,255,255,.4);
  line-height: 1.3;
}

/* Category badge on image */
.ag-post-cat-badge {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(7,13,24,.85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--t2);
  font-family: var(--fm);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 100px;
}

/* Body */
.ag-post-body {
  padding: 22px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
  position: relative;
  z-index: 1;
}

/* Meta */
.ag-post-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: .65rem;
  color: var(--t3);
}
.ag-post-dot {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--t3);
  flex-shrink: 0;
}

/* Title */
.ag-post-title {
  font-size: 1rem;
  line-height: 1.4;
  margin: 0;
}
.ag-post-title a {
  color: var(--t1);
  text-decoration: none;
  transition: color .3s;
}
.ag-post-card:hover .ag-post-title a { color: var(--or); }

/* Excerpt */
.ag-post-excerpt {
  font-size: .83rem;
  color: var(--t2);
  line-height: 1.68;
  margin: 0;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Read more */
.ag-post-read {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.05);
  text-decoration: none;
  margin-top: auto;
  transition: all .3s;
}
.ag-post-read span {
  font-size: .8rem;
  font-weight: 600;
  color: var(--or);
  transition: color .3s;
}
.ag-post-arrow {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: rgba(232,98,26,.1);
  border: 1px solid rgba(232,98,26,.2);
  display: grid; place-items: center;
  color: var(--or);
  transition: all .35s var(--ease);
  flex-shrink: 0;
}
.ag-post-card:hover .ag-post-arrow {
  background: var(--or);
  color: #fff;
  transform: translate(3px, -3px);
  box-shadow: 0 4px 16px rgba(232,98,26,.4);
}

/* Featured first card (larger) */
.ag-blog-grid .ag-post-card:first-child {
  grid-row: span 1;
}
.ag-blog-grid .ag-post-card:first-child .ag-post-thumb { height: 220px; }

/* Divider between cards */
.ag-blog-grid .ag-post-card:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 10%; bottom: 10%;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(255,255,255,.06), transparent);
}

/* Hover bottom border accent */
.ag-post-card::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--or), transparent);
  opacity: 0;
  transition: opacity .4s;
}
.ag-post-card:hover::before { opacity: 1; }

/* ── HERO UPGRADE — gradient title + glow ────────────────── */
.v2-hero-accent {
  background: linear-gradient(135deg, var(--or), #f59e0b, var(--or));
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmerText 4s linear infinite;
}
@keyframes shimmerText {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}

/* ── HERO — lekki glow pod napisem ───────────────────────── */
.v2-hero-h1 {
  filter: drop-shadow(0 0 40px rgba(232,98,26,.12));
}

/* ── DLACZEGO — karty z gradient border on hover ─────────── */
.v2-why-card {
  background: rgba(15,30,48,.7) !important;
  backdrop-filter: blur(4px);
  position: relative;
}
.v2-why-card::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: var(--r2);
  border: 1px solid transparent;
  background: linear-gradient(135deg,rgba(232,98,26,.3),transparent,rgba(59,130,246,.2)) border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity .4s;
  pointer-events: none;
}
.v2-why-card:hover::after { opacity: 1; }

/* ── SERVICE CARDS — glass ───────────────────────────────── */
.v2-srv-card {
  background: rgba(15,30,48,.75) !important;
  backdrop-filter: blur(6px);
}

/* ── PROCESS — transparent cards ────────────────────────── */
.v2-proc-card {
  background: rgba(15,30,48,.6) !important;
  border: 1px solid rgba(255,255,255,.05) !important;
  backdrop-filter: blur(4px);
}
.v2-proc-num {
  box-shadow: 0 0 24px rgba(232,98,26,.2) !important;
}

/* ── STATS BAR — neon numbers ────────────────────────────── */
.v2-stat-n {
  text-shadow: 0 0 30px rgba(232,98,26,.4);
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .ag-blog-grid {
    grid-template-columns: 1fr !important;
    gap: 1px;
    border-radius: 16px;
  }
  .ag-post-card::after { display: none !important; }
  .ag-post-thumb { height: 180px !important; }
}
@media (min-width: 600px) and (max-width: 900px) {
  .ag-blog-grid { grid-template-columns: repeat(2,1fr) !important; }
}


/* ================================================================
   CRITICAL STACKING FIX — kursor i header ZAWSZE na wierzchu
   ================================================================ */

/* 1. Kursor — absolutnie najwyższy element na stronie */
.cursor-dot,
.cursor-ring {
  position: fixed !important;
  z-index: 2147483647 !important; /* MAX możliwy z-index w przeglądarkach */
  pointer-events: none !important;
  /* will-change pozwala przeglądarce wyodrębnić warstwę kompozytową */
  will-change: transform;
  /* transform tworzy nowy stacking context dla TEGO elementu */
  transform: translate(-50%, -50%);
}

/* 2. Header — ponad wszystkimi sekcjami */
#site-header,
.site-header {
  position: fixed !important;
  z-index: 2147483646 !important; /* jeden mniej niż kursor */
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  /* Transparentne tło na starcie — bez tego header może być niewidoczny */
  /* background ustawia JS po scroll */
}

/* 3. Mobile nav — powyżej treści ale poniżej kursora */
.mobile-nav {
  z-index: 2147483640 !important;
}

/* 4. Sekcje — z-index:1 ale BEZ tworzenia nowych stacking contextów */
/* ZAKAZ używania: isolation, transform (na sekcjach), filter, will-change */
section,
.v2-hero,
.v2-why,
.v2-services,
.v2-process,
.v2-portfolio,
.v2-bao,
.testi-cinematic-sec,
.v2-articles,
.ag-blog,
.v2-cta-split,
.v2-stats-bar,
.v2-logos,
.page-hero,
.site-footer {
  position: relative;
  z-index: 1;
  /* CRITICAL: nie dodawaj tu isolation, transform, filter — psują stacking */
}

/* 5. Aurora w tle — pod wszystkim */
.hd-aurora,
.aurora-orb {
  z-index: 0 !important;
}

/* ================================================================
   SEKCJA PRZED / PO — prawdziwe screenshoty
   ================================================================ */
.bao-real-wrap {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 28px;
  align-items: start;
}

/* Label */
.bao-real-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fm);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.bao-real-label--before { color: #e53e3e; }
.bao-real-label--after  { color: #22c55e; }
.bao-real-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

/* Browser frame */
.bao-real-browser {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  transition: box-shadow .4s, border-color .4s;
}
.bao-real-browser--before {
  border-color: rgba(229,62,62,.2);
}
.bao-real-browser--before:hover {
  box-shadow: 0 24px 72px rgba(229,62,62,.15), 0 20px 60px rgba(0,0,0,.5);
  border-color: rgba(229,62,62,.35);
}
.bao-real-browser--after {
  border-color: rgba(34,197,94,.2);
}
.bao-real-browser--after:hover {
  box-shadow: 0 24px 72px rgba(34,197,94,.12), 0 20px 60px rgba(0,0,0,.5);
  border-color: rgba(34,197,94,.35);
}

/* Browser top bar */
.bao-real-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  background: var(--card2);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.bao-real-dots {
  display: flex;
  gap: 5px;
  flex-shrink: 0;
}
.bao-real-dots span {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.bao-real-url {
  flex: 1;
  text-align: center;
  background: rgba(255,255,255,.05);
  border-radius: 6px;
  padding: 3px 10px;
  font-size: 8px;
  color: var(--t3);
  font-family: var(--fm);
}

/* Image wrapper */
.bao-real-img-wrap {
  position: relative;
  overflow: hidden;
  background: #f0f0f0;
  /* Ograniczamy wysokość żeby oba screeny były równej wielkości */
  max-height: 360px;
}
.bao-real-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .8s cubic-bezier(0.22,1,0.36,1);
}
.bao-real-browser:hover .bao-real-img-wrap img {
  transform: scale(1.02) translateY(-1%);
}

/* Badge na zdjęciu */
.bao-real-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--fm);
  font-size: .63rem;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 5px 11px;
  border-radius: 100px;
  backdrop-filter: blur(8px);
}
.bao-real-badge--bad {
  background: rgba(229,62,62,.85);
  color: #fff;
}
.bao-real-badge--good {
  background: rgba(34,197,94,.85);
  color: #fff;
}

/* Metryki */
.bao-real-metrics {
  display: flex;
  gap: 0;
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 12px;
  margin-top: 14px;
  overflow: hidden;
}
.bao-real-metric {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 12px;
  border-right: 1px solid var(--b1);
}
.bao-real-metric:last-child { border-right: none; }
.bao-real-metric-ico {
  font-size: 1rem;
  flex-shrink: 0;
  line-height: 1;
}
.bao-real-metric-val {
  font-size: .82rem;
  font-weight: 700;
  line-height: 1.2;
}
.bao-real-metric-lbl {
  font-size: .65rem;
  color: var(--t3);
  font-family: var(--fm);
  margin-top: 1px;
}

/* Strzałka środkowa */
.bao-real-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 60px; /* wyrównanie z browserem */
}
.bao-real-arrow-circle {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(232,98,26,.1);
  border: 1px solid rgba(232,98,26,.3);
  display: grid;
  place-items: center;
  color: var(--or);
  box-shadow: 0 0 24px rgba(232,98,26,.15);
  animation: arrowPulse 2.5s ease-in-out infinite;
}
@keyframes arrowPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(232,98,26,.3); }
  50%      { box-shadow: 0 0 0 10px rgba(232,98,26,.0); }
}

/* Responsive */
@media (max-width: 900px) {
  .bao-real-wrap {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  .bao-real-arrow {
    transform: rotate(90deg);
    padding-top: 0;
    justify-content: center;
    margin: -4px 0;
  }
  .bao-real-metrics {
    flex-direction: row;
  }
  .bao-real-metric {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 4px;
  }
  .bao-real-img-wrap { max-height: 240px; }
}

/* ================================================================
   CRO v10 — nowe sekcje
   ================================================================ */

/* ── HERO TRUST BAR ── */
.hero-trust-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.hero-trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  color: rgba(255,255,255,.6);
}
.hero-trust-item strong { color: rgba(255,255,255,.9); }
.hero-trust-sep { color: rgba(255,255,255,.2); font-size: .9rem; }
@media(max-width:480px) { .hero-trust-sep { display:none; } .hero-trust-bar { gap:8px; } }

/* ── CRO BELT — pomarańczowa belka CTA ── */
.cro-belt {
  background: linear-gradient(135deg, #e8621a, #d45510);
  padding: 20px 0;
  position: relative;
  z-index: 1;
}
.cro-belt-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.cro-belt-inner p {
  color: rgba(255,255,255,.92);
  font-size: .95rem;
  font-weight: 500;
  margin: 0;
}
.cro-belt .btn-p {
  background: rgba(0,0,0,.2) !important;
  border: 1px solid rgba(255,255,255,.3) !important;
  box-shadow: none !important;
  color: #fff !important;
  flex-shrink: 0;
}
.cro-belt .btn-p:hover {
  background: rgba(0,0,0,.35) !important;
  box-shadow: none !important;
  transform: translateY(-1px) !important;
}
@media(max-width:700px) {
  .cro-belt-inner { flex-direction:column; text-align:center; }
  .cro-belt .btn-p { width:100%; justify-content:center; }
}

/* ── DLA KOGO ── */
.sec-dla-kogo {
  background: var(--bg2);
  padding-block: var(--S);
  position: relative;
  z-index: 1;
}
.dla-kogo-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 18px;
}
.dla-kogo-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: border-color .4s, transform .4s var(--ease), box-shadow .4s;
}
.dla-kogo-card:hover {
  border-color: rgba(232,98,26,.3);
  transform: translateY(-5px);
  box-shadow: 0 20px 52px rgba(0,0,0,.4), 0 0 30px rgba(232,98,26,.08);
}
.dla-kogo-icon {
  width: 48px; height: 48px;
  border-radius: 13px;
  display: grid; place-items: center;
}
.dla-kogo-tag {
  font-family: var(--fh);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--t1);
}
.dla-kogo-problem,
.dla-kogo-rozwiazanie {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dla-kogo-label {
  font-family: var(--fm);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
  display: inline-block;
  align-self: flex-start;
}
.dla-kogo-label--problem { background: rgba(229,62,62,.12); color: #ef4444; }
.dla-kogo-label--ok      { background: rgba(34,197,94,.1);  color: #22c55e; }
.dla-kogo-problem p,
.dla-kogo-rozwiazanie p { font-size:.84rem; color:var(--t2); line-height:1.65; margin:0; }
.dla-kogo-przyklad {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font-size: .75rem;
  color: var(--t3);
  font-family: var(--fm);
  padding-top: 12px;
  border-top: 1px solid var(--b1);
  margin-top: auto;
}
.dla-kogo-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-top: 40px;
  padding: 24px 32px;
  background: rgba(232,98,26,.06);
  border: 1px solid rgba(232,98,26,.18);
  border-radius: var(--r2);
  flex-wrap: wrap;
}
.dla-kogo-cta p { color: var(--t2); font-size: .9rem; margin: 0; }
@media(max-width:900px) {
  .dla-kogo-grid { grid-template-columns:1fr; }
  .dla-kogo-cta { flex-direction:column; }
  .dla-kogo-cta .btn { width:100%; justify-content:center; }
}

/* ── SERVICE CARDS CRO — co/dla kogo/efekt ── */
.v2-srv-card--cro .srv-cro-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.srv-cro-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.srv-cro-lbl {
  font-family: var(--fm);
  font-size: .59rem;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--or);
  opacity: .7;
}

/* ── CASE STUDY ── */
.sec-casestudy {
  background: var(--bg2);
  padding-block: var(--S);
  position: relative; z-index: 1;
}
.cs-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px;
}
.cs-card-cro {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  overflow: hidden;
  transition: border-color .4s, box-shadow .4s;
}
.cs-card-cro:hover {
  border-color: rgba(232,98,26,.3);
  box-shadow: 0 20px 52px rgba(0,0,0,.4);
}
.cs-cro-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 24px;
  background: rgba(232,98,26,.06);
  border-bottom: 1px solid var(--b1);
}
.cs-cro-nr {
  font-family: var(--fh);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--or);
  opacity: .5;
  line-height: 1;
  flex-shrink: 0;
}
.cs-cro-klient {
  font-size: .82rem;
  color: var(--t2);
  font-family: var(--fm);
}
.cs-cro-body {
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cs-cro-row {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.cs-cro-lbl {
  font-family: var(--fm);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
  display: inline-block;
  align-self: flex-start;
}
.cs-cro-lbl--problem { background: rgba(229,62,62,.1); color: #ef4444; }
.cs-cro-lbl--ok      { background: rgba(34,197,94,.1); color: #22c55e; }
.cs-cro-body p { font-size: .84rem; color: var(--t2); line-height: 1.65; margin: 0; }
.cs-cro-metrics {
  display: flex;
  gap: 0;
  border-top: 1px solid var(--b1);
}
.cs-cro-metric {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px 12px;
  border-right: 1px solid var(--b1);
  text-align: center;
  gap: 2px;
}
.cs-cro-metric:last-child { border-right: none; }
.cs-cro-metric-n {
  font-family: var(--fh);
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--mc, var(--or));
  line-height: 1;
  letter-spacing: -.04em;
}
.cs-cro-metric-l {
  font-size: .78rem;
  font-weight: 600;
  color: var(--t1);
  line-height: 1.2;
}
.cs-cro-metric-sub {
  font-size: .65rem;
  color: var(--t3);
  font-family: var(--fm);
}
@media(max-width:900px) {
  .cs-grid { grid-template-columns:1fr; }
  .cs-cro-metrics { flex-direction: column; }
  .cs-cro-metric { border-right: none; border-bottom: 1px solid var(--b1); }
  .cs-cro-metric:last-child { border-bottom: none; }
}

/* ── FAQ section ── */
.sec-faq {
  background: var(--bg);
  padding-block: var(--S);
  position: relative; z-index: 1;
}
.faq-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 10px;
  max-width: 900px;
  margin: 0 auto;
}
.faq-item {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  overflow: hidden;
  transition: border-color .3s;
}
.faq-item.open { border-color: rgba(232,98,26,.3); }
.faq-q {
  width: 100%;
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 20px;
  background: none; border: none; text-align: left;
  font-family: var(--fb); font-size: .9rem; font-weight: 600;
  color: var(--t1); cursor: pointer;
  transition: color var(--t);
}
.faq-q:hover { color: var(--or); }
.faq-icon {
  width: 26px; height: 26px; border-radius: 7px; flex-shrink: 0;
  background: rgba(232,98,26,.1); color: var(--or);
  display: grid; place-items: center;
  transition: transform .35s var(--ease), background .3s;
}
.faq-item.open .faq-icon { transform: rotate(45deg); background: rgba(232,98,26,.2); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .45s var(--ease);
  font-size: .85rem; color: var(--t2); line-height: 1.78;
}
.faq-a div { padding: 0 20px 18px; }
@media(max-width:700px) {
  .faq-grid { grid-template-columns:1fr; }
}

/* ── STICKY MOBILE CTA ── */
.sticky-mobile-cta {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 8888;
  background: var(--bg1);
  border-top: 1px solid var(--b1);
  padding: 12px 16px;
  gap: 10px;
}
.sticky-mobile-cta a {
  flex: 1;
  justify-content: center;
  min-height: 48px;
  font-size: .88rem;
}
@media(max-width:900px) {
  .sticky-mobile-cta { display:flex; }
  /* Daj padding body żeby footer nie chował się pod sticky */
  .site-footer { padding-bottom: 80px; }
}

/* ================================================================
   CENNIK — nowe style v11
   ================================================================ */

/* ── CENNIK HERO NOTE ── */
.cennik-hero-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .85rem;
  color: var(--t2);
  margin-top: 20px;
  padding: 10px 18px;
  background: rgba(232,98,26,.07);
  border: 1px solid rgba(232,98,26,.2);
  border-radius: 100px;
}
.cennik-hero-link {
  color: var(--or) !important;
  font-weight: 600;
  text-decoration: none;
}

/* ── PAKIETY GRID ── */
.cn-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 20px;
  align-items: start;
}

/* Karta pakietu */
.cn-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 20px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  transition: border-color .35s, box-shadow .35s, transform .35s var(--ease);
}
.cn-card:hover {
  border-color: rgba(232,98,26,.25);
  transform: translateY(-4px);
  box-shadow: 0 20px 52px rgba(0,0,0,.4);
}
.cn-card--hot {
  border-color: rgba(232,98,26,.4) !important;
  background: linear-gradient(160deg, var(--card), rgba(232,98,26,.04));
  box-shadow: 0 8px 40px rgba(232,98,26,.12);
}
.cn-card--hot:hover { box-shadow: 0 20px 56px rgba(232,98,26,.2); }

.cn-hot-badge {
  position: absolute;
  top: -13px; left: 50%;
  transform: translateX(-50%);
  background: var(--or);
  color: #fff;
  font-family: var(--fm);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 100px;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 5px;
}

.cn-header { display: flex; flex-direction: column; gap: 6px; }
.cn-badge {
  font-family: var(--fm);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .16em;
  color: var(--t3);
}
.cn-badge--hot { color: var(--or); }

.cn-price-wrap {
  display: flex;
  align-items: baseline;
  gap: 4px;
  line-height: 1;
}
.cn-od { font-size: .8rem; color: var(--t3); }
.cn-kwota {
  font-family: var(--fh);
  font-size: 2.8rem;
  font-weight: 800;
  color: var(--t1);
  letter-spacing: -.04em;
}
.cn-card--hot .cn-kwota { color: var(--or); }
.cn-zl { font-size: 1rem; font-weight: 600; color: var(--t2); }
.cn-price-sub { font-family: var(--fm); font-size: .65rem; color: var(--t3); }

.cn-opis { font-size: .84rem; color: var(--t2); line-height: 1.7; margin: 0; }
.cn-hr { height: 1px; background: var(--b1); }

.cn-lista {
  display: flex;
  flex-direction: column;
  gap: 9px;
  list-style: none;
  flex: 1;
}
.cn-item {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  font-size: .83rem;
  color: var(--t2);
  line-height: 1.5;
}
.cn-item svg { flex-shrink: 0; margin-top: 2px; }
.cn-item--off { opacity: .32; }

.cn-cta {
  width: 100%;
  justify-content: center;
  text-decoration: none;
  min-height: 46px;
}
.cn-cta-note {
  font-size: .68rem;
  color: var(--t3);
  text-align: center;
  font-family: var(--fm);
  margin: -8px 0 0;
}

/* Nota */
.cn-nota {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 36px;
  padding: 20px 24px;
  background: rgba(232,98,26,.05);
  border: 1px solid rgba(232,98,26,.15);
  border-radius: var(--r2);
  font-size: .84rem;
  color: var(--t2);
  line-height: 1.7;
}
.cn-nota svg { flex-shrink: 0; margin-top: 3px; }

/* Opieka techniczna */
.cn-opieka-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
}
.cn-opieka-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color .3s, transform .3s var(--ease);
}
.cn-opieka-card:hover {
  border-color: rgba(232,98,26,.2);
  transform: translateY(-3px);
}
.cn-opieka-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.cn-opieka-name { font-weight: 700; font-size: .95rem; color: var(--t1); }
.cn-opieka-price { font-family: var(--fh); font-weight: 700; color: var(--or); font-size: 1rem; }
.cn-opieka-feats {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.cn-opieka-feats li {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: .8rem;
  color: var(--t2);
}

/* ── RADIO GRAFICZNE — wybór pakietu ── */
.cn-radio-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 8px;
}
.cn-radio-card { display: block; cursor: pointer; }
.cn-radio-card input[type="radio"] { display: none; }
.cn-radio-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 12px 8px;
  background: var(--glass);
  border: 1.5px solid var(--b1);
  border-radius: 12px;
  text-align: center;
  transition: all .25s;
}
.cn-radio-card input:checked + .cn-radio-inner {
  border-color: var(--or);
  background: rgba(232,98,26,.08);
  box-shadow: 0 0 16px rgba(232,98,26,.15);
}
.cn-radio-card:hover .cn-radio-inner { border-color: rgba(232,98,26,.3); }
.cn-radio-hot {
  font-size: .6rem;
  color: var(--or);
  font-weight: 700;
  font-family: var(--fm);
  line-height: 1;
}
.cn-radio-name { font-weight: 700; font-size: .88rem; color: var(--t1); }
.cn-radio-price { font-family: var(--fm); font-size: .65rem; color: var(--or); font-weight: 700; }
.cn-radio-sub { font-size: .65rem; color: var(--t3); font-family: var(--fm); }

/* ── CHECKBOXY — cele klienta ── */
.cn-check-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.cn-check-grid--compact {
  grid-template-columns: 1fr 1fr;
}
.cn-check-label {
  display: flex;
  align-items: center;
  gap: 9px;
  cursor: pointer;
  padding: 10px 12px;
  background: var(--glass);
  border: 1.5px solid var(--b1);
  border-radius: 10px;
  transition: all .22s;
  user-select: none;
}
.cn-check-label:hover { border-color: rgba(232,98,26,.3); background: rgba(232,98,26,.04); }
.cn-check-label input { display: none; }
.cn-check-box {
  width: 18px; height: 18px;
  border-radius: 5px;
  border: 1.5px solid var(--b2);
  background: transparent;
  display: grid; place-items: center;
  flex-shrink: 0;
  transition: all .2s;
}
.cn-check-label input:checked ~ .cn-check-box {
  background: var(--or);
  border-color: var(--or);
}
.cn-check-tick {
  color: #fff;
  opacity: 0;
  transition: opacity .15s;
}
.cn-check-label input:checked ~ .cn-check-box .cn-check-tick { opacity: 1; }
.cn-check-label input:checked ~ .cn-check-text { color: var(--t1); }
.cn-check-text { font-size: .82rem; color: var(--t2); line-height: 1.4; transition: color .2s; }

/* Po zaznaczeniu — cały wiersz podświetlony */
.cn-check-label:has(input:checked) {
  border-color: var(--or);
  background: rgba(232,98,26,.06);
}

/* ── MINI BLOK CENNIKOWY na front-page ── */
.sec-pricing-mini {
  background: var(--bg2);
  padding-block: var(--S);
  position: relative; z-index: 1;
}
.pm-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.pm-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 18px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  transition: border-color .35s, transform .35s var(--ease), box-shadow .35s;
}
.pm-card:hover { border-color: rgba(232,98,26,.25); transform: translateY(-4px); box-shadow: 0 16px 44px rgba(0,0,0,.4); }
.pm-card--hot { border-color: rgba(232,98,26,.4); background: linear-gradient(145deg,var(--card),rgba(232,98,26,.05)); }
.pm-hot {
  position: absolute; top: -12px; left: 50%;
  transform: translateX(-50%);
  background: var(--or); color: #fff;
  font-family: var(--fm); font-size: .62rem; font-weight: 700;
  letter-spacing: .08em; padding: 3px 12px; border-radius: 100px;
  white-space: nowrap;
}
.pm-top { display: flex; flex-direction: column; gap: 4px; }
.pm-name {
  font-family: var(--fm); font-size: .65rem; font-weight: 700;
  letter-spacing: .15em; color: var(--t3); text-transform: uppercase;
}
.pm-card--hot .pm-name { color: var(--or); }
.pm-price-wrap { display: flex; align-items: baseline; gap: 3px; }
.pm-od { font-size: .75rem; color: var(--t3); }
.pm-kwota { font-family: var(--fh); font-size: 2.2rem; font-weight: 800; color: var(--t1); letter-spacing: -.04em; }
.pm-card--hot .pm-kwota { color: var(--or); }
.pm-zl { font-size: .9rem; font-weight: 600; color: var(--t2); }
.pm-sub { font-size: .72rem; color: var(--t3); font-family: var(--fm); }
.pm-feat { font-size: .8rem; color: var(--t2); line-height: 1.65; margin: 0; flex: 1; }
.pm-btn { width: 100%; justify-content: center; min-height: 42px; text-decoration: none; margin-top: auto; }

.pm-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 16px 20px;
  background: var(--glass);
  border: 1px solid var(--b1);
  border-radius: 12px;
}
.pm-bottom p { font-size: .84rem; color: var(--t2); margin: 0; }
.pm-badges {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.pm-badges span {
  font-family: var(--fm); font-size: .65rem; font-weight: 700;
  color: var(--t3); background: var(--glass2); border: 1px solid var(--b1);
  padding: 4px 10px; border-radius: 100px;
}

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .cn-grid { grid-template-columns:1fr !important; }
  .cn-card--hot { margin-top: 12px; }
  .cn-opieka-grid { grid-template-columns:1fr !important; }
  .cn-radio-grid { grid-template-columns:1fr 1fr !important; }
  .cn-check-grid { grid-template-columns:1fr !important; }
  .cn-check-grid--compact { grid-template-columns:1fr !important; }
  .pm-grid { grid-template-columns:1fr !important; }
  .pm-bottom { flex-direction:column; }
  .pm-card--hot { margin-top:10px; }
}

/* ══ HERO PHOTO ══════════════════════════════════════════════════ */
.v2-hero-mockup--photo { display:flex; align-items:center; justify-content:center; }
.v2-hero-photo-wrap {
  position: relative;
  width: 100%;
  max-width: 580px;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06);
}
.v2-hero-photo {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 18px;
  object-fit: cover;
  object-position: center center;
}
.v2-hero-photo-glow {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(91,140,255,.10) 0%, transparent 60%, rgba(122,92,255,.08) 100%);
  pointer-events: none;
  border-radius: 18px;
}
.v2-hero-photo-badge {
  position: absolute;
  display: flex; align-items: center; gap: 6px;
  background: rgba(11,11,15,.85);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 100px;
  padding: 6px 13px;
  font-size: .73rem; font-weight: 600; color: #fff;
  white-space: nowrap;
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
}
.v2-hero-photo-badge--tl { top: 18px; left: 18px; }
.v2-hero-photo-badge--br { bottom: 18px; right: 18px; }

/* ══ CTA FINAL (bez formularza) ════════════════════════════════ */
.v2-cta-final {
  position: relative;
  padding: 80px 0;
  overflow: hidden;
}
.v2-cta-final-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.v2-cta-final-left h2 { font-size: clamp(1.5rem,3vw,2.2rem); margin-bottom: 16px; }
.v2-cta-final-left p { color: var(--t2); margin-bottom: 24px; }
.v2-cta-final-right {
  display: flex; flex-direction: column; align-items: flex-start; gap: 18px;
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 36px;
}
.v2-cta-final-btn {
  width: 100%; justify-content: center; min-height: 54px;
  font-size: 1.05rem;
}
.v2-cta-final-contacts { display: flex; flex-direction: column; gap: 10px; width: 100%; }
.v2-cta-final-note { font-size: .78rem; color: var(--t3); margin: 0; }

@media(max-width:900px){
  .v2-hero-photo-wrap { max-width: 100%; border-radius: 12px; }
  .v2-hero-mockup--photo { margin-top: 28px; }
  .v2-cta-final-inner { grid-template-columns: 1fr; gap: 32px; }
  .v2-cta-final-right { width: 100%; }
}

/* ══ KONTAKT — co się dzieje po wysłaniu ══════════════════════ */
.cn-co-dalej {
  margin-top: 32px;
  padding: 24px;
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
}
.cn-co-dalej-title {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ac1);
  margin-bottom: 18px;
}
.cn-co-dalej-steps { display: flex; flex-direction: column; gap: 16px; }
.cn-co-step {
  display: flex; align-items: flex-start; gap: 14px;
}
.cn-co-num {
  min-width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(91,140,255,.15);
  color: var(--ac1);
  font-size: .78rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cn-co-step strong { display: block; font-size: .88rem; color: var(--t1); margin-bottom: 2px; }
.cn-co-step span { font-size: .78rem; color: var(--t3); }

/* ══ KONTAKT — textarea ══════════════════════════════════════ */
.v2-textarea {
  resize: vertical;
  min-height: 100px;
  font-family: inherit;
  line-height: 1.55;
}

/* ══ BUDGET RADIO (kontakt) ══════════════════════════════════ */
.cn-radio-grid--budget {
  grid-template-columns: repeat(2, 1fr);
}
@media(max-width:480px){
  .cn-radio-grid--budget { grid-template-columns: 1fr 1fr; }
}

/* ══ WPCONSENT — RODO baner dopasowany do motywu ══════════════ */

/* Przesuń na dół strony */
.wpconsent-banner,
.wpconsent-bar,
#wpconsent-banner,
#wpconsent-bar,
[class*="wpconsent"] {
    top: auto !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    position: fixed !important;
    z-index: 999999 !important;
    transform: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
}

/* Ciemny styl pasujący do motywu */
.wpconsent-banner,
.wpconsent-bar,
#wpconsent-banner,
#wpconsent-bar {
    background: #13131a !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: 0 -8px 40px rgba(0,0,0,.5) !important;
    color: rgba(255,255,255,.75) !important;
    font-family: 'Plus Jakarta Sans', 'DM Sans', sans-serif !important;
    font-size: .82rem !important;
    padding: 14px 24px !important;
    max-width: 100% !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
    box-sizing: border-box !important;
}

/* Tekst w banerze */
.wpconsent-banner p,
.wpconsent-bar p,
#wpconsent-banner p,
#wpconsent-bar p,
.wpconsent-banner span,
.wpconsent-bar span,
.wpconsent-message,
.wpconsent-text {
    color: rgba(255,255,255,.65) !important;
    font-size: .82rem !important;
    margin: 0 !important;
    flex: 1 !important;
    min-width: 200px;
}

/* Linki */
.wpconsent-banner a,
.wpconsent-bar a,
#wpconsent-banner a,
#wpconsent-bar a {
    color: #5B8CFF !important;
    text-decoration: underline !important;
}

/* Przyciski — kontener */
.wpconsent-buttons,
.wpconsent-banner .wpconsent-buttons,
.wpconsent-bar .wpconsent-buttons {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Przycisk akceptacji */
.wpconsent-accept-button,
.wpconsent-btn-accept,
button[class*="wpconsent"][class*="accept"],
.wpconsent-buttons .wpconsent-button-accept {
    background: #5B8CFF !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 18px !important;
    font-size: .78rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: background .2s !important;
    box-shadow: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.wpconsent-accept-button:hover,
.wpconsent-btn-accept:hover {
    background: #4a7ae0 !important;
}

/* Przycisk odrzucenia / ustawień */
.wpconsent-decline-button,
.wpconsent-btn-decline,
.wpconsent-settings-button,
.wpconsent-btn-settings,
button[class*="wpconsent"][class*="decline"],
button[class*="wpconsent"][class*="setting"] {
    background: transparent !important;
    color: rgba(255,255,255,.45) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 8px !important;
    padding: 8px 14px !important;
    font-size: .75rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: border-color .2s, color .2s !important;
    box-shadow: none !important;
    text-transform: none !important;
}
.wpconsent-decline-button:hover,
.wpconsent-settings-button:hover {
    border-color: rgba(255,255,255,.3) !important;
    color: rgba(255,255,255,.7) !important;
}

/* Nakładka tła (modal szczegółów) — jeśli plugin ją pokazuje */
.wpconsent-overlay,
#wpconsent-overlay {
    background: rgba(0,0,0,.75) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
}

/* Modal szczegółów cookie */
.wpconsent-modal,
#wpconsent-modal,
.wpconsent-popup {
    background: #1a1a26 !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 14px !important;
    color: rgba(255,255,255,.8) !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.6) !important;
}
.wpconsent-modal h2,
.wpconsent-modal h3,
.wpconsent-popup h2,
.wpconsent-popup h3 {
    color: #fff !important;
}
.wpconsent-modal p,
.wpconsent-popup p {
    color: rgba(255,255,255,.6) !important;
}

/* Upewnij się że header NIE jest zasłonięty */
.site-header,
#masthead,
.v2-nav,
header {
    z-index: 9999 !important;
}

@media (max-width: 600px) {
    .wpconsent-banner,
    .wpconsent-bar,
    #wpconsent-banner,
    #wpconsent-bar {
        flex-direction: column !important;
        align-items: flex-start !important;
        padding: 16px !important;
        gap: 12px !important;
    }
    .wpconsent-buttons {
        width: 100% !important;
    }
    .wpconsent-accept-button,
    .wpconsent-btn-accept {
        width: 100% !important;
        text-align: center !important;
        justify-content: center !important;
    }
}

/* ============================================================
   v13 NOWE SEKCJE — dodane przez upgrade SEO/CRO
   ============================================================ */

/* ── PROBLEM SECTION ─────────────────────────────────────────── */
.sec-problem {
  padding-block: var(--S);
  background: var(--bg1);
  position: relative;
}
.sec-problem::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 50% at 50% 100%, rgba(232,98,26,.04), transparent 60%);
  pointer-events: none;
}
.problem-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px) {
  .problem-grid { grid-template-columns: 1fr; gap: 16px; }
}
.problem-card {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 32px 28px;
  position: relative;
  transition: border-color var(--t), transform var(--t);
}
.problem-card:hover {
  border-color: rgba(232,98,26,.2);
  transform: translateY(-4px);
}
.problem-nr {
  font-family: var(--fh);
  font-size: 3rem;
  font-weight: 800;
  line-height: 1;
  opacity: .15;
  position: absolute;
  top: 20px;
  right: 24px;
}
.problem-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.problem-card h3 {
  font-size: 1.05rem;
  margin-bottom: 12px;
  color: var(--t1);
}
.problem-card p {
  font-size: .9rem;
  color: var(--t2);
  line-height: 1.65;
}
.problem-cta { margin-top: 40px; }

/* ── SEO CONTENT SECTION ─────────────────────────────────────── */
.sec-seo-content {
  padding-block: 64px;
  background: var(--bg2);
  border-top: 1px solid var(--b1);
}
.seo-content-inner {
  max-width: 820px;
  margin: 0 auto;
}
.seo-content-inner h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  margin-bottom: 20px;
  color: var(--t1);
}
.seo-content-inner p {
  font-size: .95rem;
  color: var(--t2);
  line-height: 1.75;
  margin-bottom: 14px;
}
.seo-content-inner a {
  color: var(--ac1);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.seo-content-inner a:hover { color: var(--or); }
.seo-content-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
}
.seo-content-tag {
  font-size: .78rem;
  font-weight: 500;
  background: rgba(91,140,255,.08);
  border: 1px solid rgba(91,140,255,.15);
  color: var(--ac1);
  padding: 4px 12px;
  border-radius: 100px;
}

/* ── CITY LANDING PAGE ───────────────────────────────────────── */
.loc-hero {
  padding-top: 130px;
  padding-bottom: 80px;
  background: var(--bg);
  position: relative;
  overflow: hidden;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 60% at 75% 50%, rgba(91,140,255,.07), transparent 60%);
  pointer-events: none;
}
.loc-hero-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px) {
  .loc-hero-grid { grid-template-columns: 1fr; }
  .loc-hero-visual { display: none; }
}
.loc-breadcrumb {
  font-size: .8rem;
  color: var(--t3);
  margin-bottom: 24px;
}
.loc-breadcrumb a { color: var(--t2); }
.loc-breadcrumb a:hover { color: var(--or); }

.loc-hero-map {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
.loc-hero-stats {
  display: flex;
  gap: 16px;
  justify-content: center;
}
.loc-stat {
  text-align: center;
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r);
  padding: 14px 18px;
  flex: 1;
}
.loc-stat-n {
  display: block;
  font-family: var(--fh);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ac1);
}
.loc-stat-l {
  font-size: .72rem;
  color: var(--t3);
}

/* Oferta section (uses existing v2-srv-grid) */
.loc-oferta { padding-block: var(--S); }

/* SEO lokalny akapit */
.loc-seo-text {
  padding-block: var(--S);
  background: var(--bg1);
}
.loc-seo-inner {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  align-items: start;
}
@media (max-width: 900px) {
  .loc-seo-inner { grid-template-columns: 1fr; }
}
.loc-seo-content h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  margin-bottom: 20px;
}
.loc-seo-content p {
  font-size: .93rem;
  color: var(--t2);
  line-height: 1.75;
  margin-bottom: 14px;
}
.loc-seo-box {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: var(--r2);
  padding: 28px;
}
.loc-seo-box h3 {
  font-size: 1rem;
  margin-bottom: 16px;
  color: var(--t1);
}
.loc-seo-box ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.loc-seo-box li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .87rem;
  color: var(--t2);
}



/* ═══════════════════════════════════════════════════════════════
   v15 ADDITIONS — dropdown menu, equal heights, aurora off
   ═══════════════════════════════════════════════════════════════ */

/* 1. Wyłącz aurora orbs i hd-aurora (biały połysk przy wejściu) */
.hd-aurora,
.hd-aurora::before,
.hd-aurora::after,
.aurora-orb,
.aurora-orb-1,
.aurora-orb-2,
.aurora-orb-3 { display: none !important; }

/* Stonuj też v2-hero-glow (hero glow na front-page) */
.v2-hero-glow {
    background: radial-gradient(ellipse 50% 70% at 80% 20%, rgba(232,98,26,.06), transparent 60%) !important;
}

/* 2. Dropdown menu "Usługi" */
.menu-item-has-children {
    position: relative;
    display: inline-block;
}
.menu-parent {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .845rem;
    font-weight: 500;
    color: var(--t2);
    padding: 7px 12px;
    border-radius: 100px;
    transition: all var(--t);
    cursor: pointer;
}
.menu-parent svg {
    transition: transform .2s ease;
    opacity: .7;
}
.menu-parent:hover,
.menu-parent.active {
    color: var(--t1);
    background: rgba(255,255,255,.055);
}
.menu-parent.active {
    color: var(--or);
    background: rgba(232,98,26,.08);
}
.menu-item-has-children:hover .menu-parent svg {
    transform: rotate(180deg);
}

/* Submenu panel */
.nav-submenu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 320px;
    padding: 10px;
    background: rgba(10, 18, 32, .98);
    backdrop-filter: blur(20px) saturate(1.5);
    -webkit-backdrop-filter: blur(20px) saturate(1.5);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
    box-shadow: 0 20px 60px rgba(0,0,0,.4);
    display: flex;
    flex-direction: column;
    gap: 2px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 999999;
}
.menu-item-has-children:hover .nav-submenu,
.menu-item-has-children:focus-within .nav-submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.nav-submenu-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px 14px;
    border-radius: var(--r);
    transition: background .2s ease;
    text-decoration: none;
}
.nav-submenu-item:hover,
.nav-submenu-item.active {
    background: rgba(232,98,26,.1);
}
.nav-submenu-title {
    font-size: .9rem;
    font-weight: 600;
    color: var(--t1);
    line-height: 1.2;
}
.nav-submenu-desc {
    font-size: .75rem;
    color: var(--t3);
    line-height: 1.4;
}
.nav-submenu-item.active .nav-submenu-title {
    color: var(--or);
}

/* Mobile nav — parent i child */
.mobile-nav-parent {
    font-weight: 700 !important;
    color: var(--t1) !important;
    margin-top: 8px;
}
.mobile-nav-child {
    padding-left: 24px !important;
    font-size: .9rem !important;
    color: var(--t2) !important;
}

/* Ukryj dropdown na mobilu */
@media (max-width: 900px) {
    .nav-submenu { display: none !important; }
    .menu-item-has-children { display: block; }
}

/* 3. Case study — równe wysokości kart */
.cs-card-cro {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.cs-cro-body {
    flex: 1 1 auto;
}
.cs-cro-metrics {
    margin-top: auto;
}


/* 4. Globalne wyrównanie kart w gridach (treści wyrównane do góry, CTA do dołu) */
.problem-card,
.v2-why-card,
.branza-card {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.problem-card p,
.v2-why-card p,
.branza-card p {
    flex: 1 1 auto;
}

/* Cn-card (pakiety cenowe) — równe wysokości z CTA na dole */
.cn-card {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.cn-lista {
    flex: 1 1 auto;
}
.cn-cta {
    margin-top: auto;
}

/* v2-proc-card (kroki procesu) — równe wysokości */
.v2-proc-card {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.v2-proc-card p {
    flex: 1 1 auto;
}

/* ============================================================
   v16 — Nowe komponenty
   ============================================================ */

/* ── Helper list styles ────────────────────────────────────── */
.hd-list {
  list-style: none;
  padding: 0;
  margin: 12px 0;
}
.hd-list li {
  position: relative;
  padding-left: 24px;
  margin-bottom: 10px;
  color: var(--t2);
  line-height: 1.6;
}
.hd-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  color: #5B8CFF;
  font-weight: 700;
}

.hd-list-x {
  list-style: none;
  padding: 0;
  margin: 12px 0;
}
.hd-list-x li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 12px;
  color: var(--t2);
  line-height: 1.6;
}
.hd-list-x li::before {
  content: '✕';
  position: absolute;
  left: 0;
  top: 0;
  color: #c0392b;
  font-weight: 700;
  font-size: 1.1em;
}

.hd-list-ol {
  list-style: decimal outside;
  padding-left: 24px;
  margin: 16px 0;
  color: var(--t2);
}
.hd-list-ol li {
  padding-left: 8px;
  margin-bottom: 12px;
  line-height: 1.7;
}
.hd-list-ol li strong { color: var(--t1); }
.hd-list-ol ul.hd-list {
  margin: 8px 0;
}

/* ── FAQ accordion ─────────────────────────────────────────── */
.hd-faq {
  margin: 32px 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.hd-faq-item {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .3s ease;
}
.hd-faq-item[open] {
  border-color: rgba(91,140,255,.3);
}
.hd-faq-q {
  font-family: var(--fh);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--t1);
  padding: 20px 52px 20px 24px;
  cursor: pointer;
  list-style: none;
  position: relative;
  user-select: none;
  transition: color .2s ease;
}
.hd-faq-q::-webkit-details-marker { display: none; }
.hd-faq-q::after {
  content: '+';
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.6rem;
  font-weight: 300;
  color: #5B8CFF;
  transition: transform .2s ease;
  line-height: 1;
}
.hd-faq-item[open] .hd-faq-q::after {
  transform: translateY(-50%) rotate(45deg);
}
.hd-faq-q:hover { color: #5B8CFF; }
.hd-faq-a {
  padding: 0 24px 20px 24px;
  color: var(--t2);
  line-height: 1.7;
  font-size: .95rem;
}
.hd-faq-a p { margin-bottom: 10px; }
.hd-faq-a p:last-child { margin-bottom: 0; }
.hd-faq-a a {
  color: #5B8CFF;
  text-decoration: underline;
}
.hd-faq-a a:hover { color: #7A5CFF; }
.hd-faq-a ul.hd-list { margin: 8px 0; }

@media (max-width: 600px) {
  .hd-faq-q { font-size: .98rem; padding: 16px 44px 16px 18px; }
  .hd-faq-a { padding: 0 18px 16px 18px; font-size: .9rem; }
}

/* ── Formularz kontaktowy (hd_v16_contact_form) ────────────── */
.hd-form {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 18px;
  padding: 32px;
  max-width: 720px;
  margin: 0 auto;
}
.hd-form-head { margin-bottom: 24px; }
.hd-form-head h3 {
  font-size: 1.4rem;
  margin-bottom: 8px;
  color: var(--t1);
}
.hd-form-head p {
  color: var(--t2);
  font-size: .95rem;
  margin: 0;
}
.hd-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 600px) {
  .hd-form-grid { grid-template-columns: 1fr; }
  .hd-form { padding: 24px 20px; }
}
.hd-field { display: flex; flex-direction: column; gap: 6px; }
.hd-field-full { grid-column: 1 / -1; }
.hd-field span {
  font-size: .85rem;
  color: var(--t2);
  font-weight: 500;
}
.hd-field input,
.hd-field select,
.hd-field textarea {
  background: var(--bg1);
  border: 1px solid var(--b1);
  border-radius: 10px;
  padding: 12px 14px;
  color: var(--t1);
  font-family: var(--fb);
  font-size: .95rem;
  transition: border-color .2s ease;
  width: 100%;
  box-sizing: border-box;
}
.hd-field textarea { resize: vertical; min-height: 120px; }
.hd-field input:focus,
.hd-field select:focus,
.hd-field textarea:focus {
  outline: none;
  border-color: #5B8CFF;
}
.hd-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 20px 0 24px;
  font-size: .85rem;
  color: var(--t2);
  cursor: pointer;
}
.hd-check input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: #5B8CFF;
  flex-shrink: 0;
}
.hd-check a {
  color: #5B8CFF;
  text-decoration: underline;
}
.hd-form-submit {
  width: 100%;
  justify-content: center;
  min-height: 52px;
}
.hd-form-submit:disabled { opacity: .7; cursor: wait; }
.hd-form-status {
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: 10px;
  font-size: .9rem;
  text-align: center;
  display: none;
}
.hd-form-status.is-ok {
  display: block;
  background: rgba(34,197,94,.12);
  border: 1px solid rgba(34,197,94,.3);
  color: #22c55e;
}
.hd-form-status.is-err {
  display: block;
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.3);
  color: #ef4444;
}

/* ── Case study stats ──────────────────────────────────────── */
.case-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.case-stat {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 14px;
  padding: 24px 20px;
  text-align: center;
}
.case-stat-num {
  font-family: var(--fh);
  font-size: 2.4rem;
  font-weight: 800;
  color: #5B8CFF;
  line-height: 1;
  margin-bottom: 8px;
}
.case-stat-lbl {
  color: var(--t2);
  font-size: .85rem;
}

/* ── Team cards ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .team-grid { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: repeat(2,1fr) !important; }
  .client-types { grid-template-columns: 1fr !important; }
  .case-content { grid-template-columns: 1fr !important; gap: 32px !important; }
}

/* ── Usługi list (wyd-*) ──────────────────────────────────── */
.wyd-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.wyd-item {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 20px;
  align-items: start;
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 14px;
  padding: 24px;
  transition: border-color .3s ease;
}
.wyd-item:hover { border-color: rgba(91,140,255,.3); }
.wyd-num {
  font-family: var(--fm);
  font-size: 1.3rem;
  font-weight: 700;
  color: #5B8CFF;
  background: rgba(91,140,255,.08);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
  min-width: 52px;
}
.wyd-item h3 { margin-bottom: 6px; }
.wyd-item p { margin: 0; color: var(--t2); font-size: .95rem; line-height: 1.6; }
@media (max-width: 600px) {
  .wyd-item { grid-template-columns: 48px 1fr; gap: 14px; padding: 18px; }
  .wyd-num { font-size: 1rem; padding: 6px; min-width: 40px; }
}

/* ── pc-num dla problem-card ──────────────────────────────── */
.pc-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, #5B8CFF, #7A5CFF);
  border-radius: 10px;
  color: #fff;
  font-family: var(--fh);
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: 16px;
}

/* ── Story / O nas ────────────────────────────────────────── */
.story-content p strong { color: var(--t1); }

@media (max-width: 900px) {
  .client-card h3 { font-size: 1rem; }
}

/* ── CTA final v16 ────────────────────────────────────────── */
.sec-cta-final {
  padding-block: var(--S);
  background: linear-gradient(180deg, var(--bg1), var(--bg));
}
.v2-cta-final-card {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
  padding: 56px 32px;
  background: linear-gradient(135deg, rgba(91,140,255,.08), rgba(122,92,255,.06));
  border: 1px solid rgba(91,140,255,.2);
  border-radius: 24px;
}
.v2-cta-final-card h2 { margin-bottom: 16px; }
.v2-cta-final-card p {
  color: var(--t2);
  max-width: 520px;
  margin: 0 auto 28px;
  font-size: 1.02rem;
}
.v2-cta-final-btn { min-height: 54px; padding: 14px 28px; }

@media (max-width: 600px) {
  .v2-cta-final-card { padding: 40px 24px; }
}

/* ── Section helpers ──────────────────────────────────────── */
.sec-cta {
  text-align: center;
  max-width: 680px;
  margin-inline: auto;
  color: var(--t2);
}
.sec-head.center { text-align: center; }
.sec-head.center p { max-width: 680px; margin-inline: auto; }

/* ── Anti-grid ────────────────────────────────────────────── */
.anti-grid {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 18px;
  padding: 32px;
}


/* ============================================================
   PORTFOLIO — PREMIUM CONCEPTS (v18)
   Live iframe previews for 3 premium homepage concepts
   ============================================================ */

.port-concepts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}

.port-concept {
  --concept-accent: var(--or);
  position: relative;
  background: linear-gradient(180deg, #0f1e30 0%, #0d1828 100%);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .35s var(--ease), transform .35s var(--ease), box-shadow .35s var(--ease);
}
.port-concept:hover {
  border-color: color-mix(in srgb, var(--concept-accent) 45%, transparent);
  transform: translateY(-4px);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--concept-accent) 18%, transparent),
    0 24px 60px rgba(0,0,0,.55),
    0 0 80px color-mix(in srgb, var(--concept-accent) 12%, transparent);
}

/* Head: number + style label + url */
.port-concept-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  background: rgba(0,0,0,.25);
}
.port-concept-head-l { display: flex; align-items: center; gap: 12px; }
.port-concept-num {
  font-family: var(--fm);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  color: var(--concept-accent);
  background: color-mix(in srgb, var(--concept-accent) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--concept-accent) 28%, transparent);
  padding: 4px 10px;
  border-radius: 6px;
}
.port-concept-style {
  font-family: var(--fm);
  font-size: .68rem;
  color: var(--t2);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.port-concept-head-r { display: flex; align-items: center; gap: 8px; }
.port-concept-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--concept-accent);
  box-shadow: 0 0 8px color-mix(in srgb, var(--concept-accent) 70%, transparent);
}
.port-concept-url {
  font-family: var(--fm);
  font-size: .68rem;
  color: var(--t3);
  letter-spacing: .04em;
}

/* Frame: link wrapper containing chrome + iframe */
.port-concept-frame {
  position: relative;
  display: block;
  text-decoration: none;
  background: #0a0f1a;
  border-bottom: 1px solid rgba(255,255,255,.05);
  overflow: hidden;
}
.port-concept-chrome {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: rgba(6,10,20,.85);
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.port-concept-chrome .chrome-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #2a2e3a;
}
.port-concept-chrome .chrome-dot:nth-child(1) { background: #ff5f57; opacity: .55; }
.port-concept-chrome .chrome-dot:nth-child(2) { background: #febc2e; opacity: .55; }
.port-concept-chrome .chrome-dot:nth-child(3) { background: #28c840; opacity: .55; }
.port-concept-chrome .chrome-url {
  margin-left: 12px;
  flex: 1;
  font-family: var(--fm);
  font-size: .65rem;
  color: var(--t3);
  letter-spacing: .02em;
  background: rgba(255,255,255,.04);
  padding: 4px 10px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,.05);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Iframe wrapper with scaled-down preview */
.port-concept-iframe-wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 66%; /* 3:2 aspect */
  overflow: hidden;
  background: #fff;
}
.port-concept-iframe {
  position: absolute;
  top: 0; left: 0;
  width: 200%;   /* render at 2x viewport so desktop layout shows */
  height: 200%;
  border: 0;
  transform: scale(0.5);
  transform-origin: 0 0;
  pointer-events: none;
  background: #fff;
}
/* Shield prevents iframe from capturing clicks; link wrapper handles click */
.port-concept-shield {
  position: absolute;
  inset: 0;
  background: transparent;
  transition: background .3s;
  z-index: 2;
}
.port-concept:hover .port-concept-shield {
  background: linear-gradient(180deg,
    rgba(10,15,26,0) 50%,
    color-mix(in srgb, var(--concept-accent) 22%, transparent) 100%);
}

/* "Otwórz pełną stronę" overlay on hover */
.port-concept-open {
  position: absolute;
  left: 50%;
  bottom: 20px;
  transform: translate(-50%, 12px);
  z-index: 3;
  background: var(--concept-accent);
  color: #fff;
  font-family: var(--fm);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 10px 18px;
  border-radius: 100px;
  opacity: 0;
  transition: opacity .3s var(--ease), transform .3s var(--ease);
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
  white-space: nowrap;
}
.port-concept-open span { display: inline-flex; align-items: center; gap: 8px; }
.port-concept-open svg { display: block; }
.port-concept:hover .port-concept-open {
  opacity: 1;
  transform: translate(-50%, 0);
}

/* Body: content below the frame */
.port-concept-body {
  padding: 22px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.port-concept-industry {
  font-family: var(--fm);
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--concept-accent);
}
.port-concept-name {
  font-size: 1.3rem;
  line-height: 1.2;
  color: var(--t1);
  margin: 0;
}
.port-concept-desc {
  font-size: .88rem;
  line-height: 1.6;
  color: var(--t2);
  margin: 0;
}

.port-concept-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 2px;
}
.port-concept-tag {
  font-family: var(--fm);
  font-size: .64rem;
  font-weight: 600;
  letter-spacing: .06em;
  color: var(--t2);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  padding: 4px 9px;
  border-radius: 100px;
}

.port-concept-results {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
  padding-top: 14px;
  border-top: 1px dashed rgba(255,255,255,.07);
}
.port-concept-results span {
  font-family: var(--fm);
  font-size: .68rem;
  font-weight: 700;
  color: #10b981;
  background: rgba(16,185,129,.08);
  border: 1px solid rgba(16,185,129,.18);
  padding: 4px 10px;
  border-radius: 100px;
}

.port-concept-actions {
  display: flex;
  gap: 8px;
  margin-top: auto;
  padding-top: 6px;
  flex-wrap: wrap;
}

/* Tablet: 2-up */
@media (max-width: 1100px) {
  .port-concepts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile: 1-up, tighter spacing */
@media (max-width: 900px) {
  .port-concepts-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .port-concept-head { padding: 12px 14px; }
  .port-concept-body { padding: 18px 16px 20px; }
  .port-concept-name { font-size: 1.15rem; }
  .port-concept-desc { font-size: .85rem; }
  .port-concept-style { display: none; }
  .port-concept-url { font-size: .62rem; }

  /* On touch: always show "Open" button + gradient shield */
  .port-concept-open {
    opacity: 1;
    transform: translate(-50%, 0);
    bottom: 14px;
    font-size: .66rem;
    padding: 8px 14px;
  }
  .port-concept-shield {
    background: linear-gradient(180deg,
      rgba(10,15,26,0) 55%,
      rgba(10,15,26,.55) 100%);
  }
  .port-concept:hover { transform: none; }

  /* Iframe scales better on small screens */
  .port-concept-iframe-wrap { padding-bottom: 60%; }
  .port-concept-iframe {
    width: 280%;
    height: 280%;
    transform: scale(0.357);
  }
}

/* Very small phones */
@media (max-width: 480px) {
  .port-concept-chrome .chrome-url { font-size: .6rem; padding: 3px 8px; }
  .port-concept-actions .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   v19 — USLUGA HUB GRID (FIX: P0-4 z audytu v18)
   Brakujące reguły dla /uslugi/ — sekcje Cztery Rzeczy Które
   Robimy Dobrze. Bez tych reguł aside/content renderowały się
   pod sobą zamiast obok siebie, a sekcje SEO i Opieka miały
   aside PRZED nagłówkiem (accessibility/SEO issue).
   ============================================================ */
.usluga-hub-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 48px;
    align-items: start;
}

/* Sekcje 2 (SEO) i 4 (Opieka) mają aside w HTML przed content.
   Używamy direction:rtl na grid (tylko do odwrócenia kolejności)
   a wewnątrz dzieci przywracamy direction:ltr dla normalnego
   kierunku tekstu. */
.usluga-hub-grid--rev {
    direction: rtl;
}
.usluga-hub-grid--rev > * {
    direction: ltr;
}

.usluga-hub-content {
    min-width: 0; /* zapobiega rozpychaniu grida przez długie słowa */
}

.usluga-hub-aside {
    padding: 32px;
    background: var(--card);
    border: 1px solid var(--b1);
    border-radius: var(--r2);
}

.usluga-hub-aside h3 {
    font-size: 0.95rem;
    color: var(--or);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 12px 0;
    font-family: var(--fh);
}

.usluga-hub-aside h3 + ul,
.usluga-hub-aside > ul {
    list-style: none;
    padding: 0;
    margin: 0 0 24px 0;
}

.usluga-hub-aside ul li {
    position: relative;
    padding-left: 22px;
    padding-block: 6px;
    color: var(--t2);
    font-size: 0.92rem;
    line-height: 1.6;
}

.usluga-hub-aside ul li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 13px;
    width: 6px;
    height: 6px;
    background: var(--or);
    border-radius: 50%;
}

.usluga-hub-aside ul:last-child {
    margin-bottom: 0;
}

.usluga-hub-bullets {
    list-style: none;
    padding: 0;
    margin: 24px 0 32px;
}

.usluga-hub-bullets li {
    position: relative;
    padding-left: 28px;
    padding-block: 8px;
    color: var(--t1);
}

.usluga-hub-bullets li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 6px;
    color: var(--or);
    font-weight: 700;
}

.usluga-hub-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* Mobile breakpoint 900px — S23 Ultra target */
@media (max-width: 900px) {
    .usluga-hub-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    /* KLUCZOWE: na mobile ZAWSZE content przed aside,
       niezależnie czy sekcja jest --rev czy nie. Bez tego
       screen reader czyta "Dla kogo" przed nagłówkiem sekcji. */
    .usluga-hub-content { order: 1; }
    .usluga-hub-aside   { order: 2; }
    .usluga-hub-grid--rev,
    .usluga-hub-grid--rev > * {
        direction: ltr;
    }
    .usluga-hub-aside {
        padding: 24px;
    }
}
