﻿:root{
  --red:#E30613;
  --red-600:#C4050F;
  --red-50:#FFF2F3;
  --ink:#0B1B33;
  --ink-800:#16284A;
  --ink-500:#475772;
  --ink-300:#8A97AD;
  --line:#E6EAF2;
  --bg:#F5F7FB;
  --white:#fff;
  --r-sm:2px;
  --r:4px;
  --r-lg:6px;
  --shadow-sm:0 1px 2px rgba(11,27,51,.06), 0 1px 3px rgba(11,27,51,.04);
  --shadow:0 8px 24px -10px rgba(11,27,51,.18), 0 2px 6px rgba(11,27,51,.06);
  --shadow-lg:0 30px 60px -20px rgba(11,27,51,.25);
  --green:#1FA968;
  --green-50:#E8F8F0;
  --gold:#D4A93C;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--white);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;border:0;cursor:pointer;background:none}
.container{max-width:1440px;margin:0 auto;padding:0 24px}

/* ===== TOP UTILITY BAR ===== */
.topbar{background:var(--ink);color:#D7DEEC;font-size:13px}
.topbar .row{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar a{color:#D7DEEC;opacity:.85}
.topbar a:hover{opacity:1;color:#fff}
.topbar .meta{display:flex;gap:22px;align-items:center}
.topbar .meta span{display:inline-flex;gap:6px;align-items:center}
.topbar .lang{display:flex;gap:14px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:rgba(255,255,255,.08);font-weight:500;border-radius:var(--r-sm)}

/* ===== HEADER ===== */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.header .row{display:grid;grid-template-columns:220px 1fr auto;gap:32px;align-items:center;padding:18px 24px}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:46px;width:auto;display:block}
/* Tall search */
.search{display:flex;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:46px;transition:border-color .2s, box-shadow .2s;width:100%}
.search:focus-within{border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
.search select{border:0;background:#F7F8FC;padding:0 14px;font-weight:600;color:var(--ink);border-right:1px solid var(--line);outline:0;font-size:13px;min-width:170px}
.search input{flex:1;border:0;padding:0 16px;font-size:14px;outline:0;background:transparent}
.search button{background:var(--red);color:#fff;padding:0 22px;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;transition:background .2s}
.search button:hover{background:var(--red-600)}
.icons{display:flex;gap:4px;align-items:center}
.icon-btn{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:3px;padding:10px 14px;border-radius:var(--r);color:var(--ink-500);font-size:12px;font-weight:500;transition:background .2s,color .2s}
.icon-btn:hover{background:var(--bg);color:var(--ink)}
.icon-btn svg{width:22px;height:22px}
.icon-btn .badge{position:absolute;top:4px;right:8px;background:var(--red);color:#fff;font-size:10px;font-weight:800;min-width:16px;height:16px;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;padding:0 4px}
.cart-price{color:var(--ink);font-weight:700}

/* ===== NAV ===== */
.nav{background:#fff;border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:58px}
.nav-left,.nav-right{display:flex;align-items:center;gap:4px}
.dept-wrap{position:relative;margin-right:14px}
.dept{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:12px 22px;border-radius:var(--r);font-weight:700;font-size:14px;cursor:pointer}
.dept:hover,.dept-wrap:hover .dept{background:var(--ink-800)}

/* Mega-menu panel */
.dept-panel{
  position:absolute;top:calc(100% + 6px);left:0;z-index:70;
  display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s, transform .18s, visibility .18s;
}
.dept-wrap:hover .dept-panel,
.dept-wrap:focus-within .dept-panel{opacity:1;visibility:visible;transform:translateY(0)}

.dept-col{width:300px;padding:10px;display:flex;flex-direction:column;gap:2px}

.dept-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:600;color:var(--ink-800);text-transform:none;letter-spacing:0;
  transition:background .15s,color .15s;cursor:pointer;
}
.dept-item:hover,.dept-item.has-drawer:hover{background:var(--bg);color:var(--red)}
.dept-item .ico{width:24px;height:24px;color:var(--ink-500);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:color .15s}
.dept-item:hover .ico{color:var(--red)}
.dept-item .ico svg{width:100%;height:100%;stroke-width:1.7}
.dept-item .name{flex:1}
.dept-item .chev{width:14px;height:14px;color:var(--ink-300);flex-shrink:0;opacity:0;transition:opacity .15s, transform .15s}
.dept-item.has-drawer .chev{opacity:.6}
.dept-item.has-drawer:hover .chev{opacity:1;color:var(--red);transform:translateX(2px)}

/* Drawer (druga szuflada na prawo) */
.dept-drawer{
  position:absolute;top:0;left:300px;
  width:760px;min-height:100%;
  background:#fff;border-left:1px solid var(--line);border-radius:0 var(--r-lg) var(--r-lg) 0;
  padding:26px 28px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .15s, visibility .15s;
  z-index:2;
}
.dept-item.has-drawer:hover .dept-drawer,
.dept-item.has-drawer:focus-within .dept-drawer,
.dept-drawer:hover{opacity:1;visibility:visible;pointer-events:auto}
/* VIRSAL: pakuj rzedy szuflady do gory + rozciagnij na pelna wysokosc kolumny.
   top:0+bottom:0 daje pewna pelna wysokosc (min-height:100% nie rozwiazywalo sie przy auto-wysokim panelu,
   przez co "most" pokrywal tylko gorne itemy, a nizsze gubily hover w luce). */
.dept-drawer{align-content:start;bottom:0}
/* VIRSAL: niewidzialny "most" na 10px luce (prawy padding kolumny) miedzy itemem a szuflada.
   Bez niego mysz w drodze do szuflady traci :hover, szuflada dostaje pointer-events:none i znika/nie da sie kliknac. */
.dept-drawer::before{content:"";position:absolute;top:0;left:-20px;width:20px;height:100%}
/* naglowek root rozciagniety na 3 kolumny (plaska szuflada 2-poziomowa) */
.dept-drawer .dg-head{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:2px}
.dept-drawer .dg-head h4{margin-bottom:0}
.dept-drawer .dg-head .see-all{margin-top:0}

.dg h4{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--red);display:inline-block}
.dg a{display:block;padding:6px 0;font-size:13.5px;font-weight:500;color:var(--ink-500);text-transform:none;letter-spacing:0;transition:color .15s, padding .15s}
.dg a:hover{color:var(--red);padding-left:4px}
.dg .see-all{margin-top:8px;color:var(--red);font-weight:700;display:inline-flex;align-items:center;gap:4px;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em}

.dept-promo{grid-column:span 3;margin-top:4px;padding:16px 20px;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);display:flex;align-items:center;justify-content:space-between;gap:20px}
.dept-promo b{color:#fff;font-size:14px}
.dept-promo span{color:#B4C0D9;font-size:12.5px;display:block;margin-top:2px}
.dept-promo .pill{background:var(--red);color:#fff;padding:8px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.nav a.link{padding:10px 16px;border-radius:var(--r-sm);font-weight:600;color:var(--ink-800);transition:background .2s,color .2s;font-size:14px;text-transform:uppercase;letter-spacing:.03em}
.nav a.link:hover{background:var(--bg);color:var(--red)}
.nav .sale{color:var(--red)}
.nav .has-sub{position:relative}
.nav .has-sub > .link{display:inline-flex;align-items:center;gap:6px}
.nav .has-sub > .link svg{width:12px;height:12px;transition:transform .2s}
.nav .has-sub:hover > .link svg{transform:rotate(180deg)}
.nav .submenu{
  position:absolute;top:calc(100% + 4px);left:0;z-index:60;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);min-width:240px;padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s, transform .18s, visibility .18s;
}
.nav .has-sub:hover .submenu,
.nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .submenu a{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:600;color:var(--ink-800);
  text-transform:none;letter-spacing:0;
  transition:background .15s, color .15s;
}
.nav .submenu a:hover{background:var(--bg);color:var(--red)}
.nav .submenu a svg{width:14px;height:14px;color:var(--red);flex-shrink:0}
.contact-btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:12px 22px;border-radius:var(--r);font-weight:700;transition:background .2s,transform .2s;font-size:14px;text-transform:uppercase;letter-spacing:.03em}
.contact-btn:hover{background:var(--red-600)}

/* ===== HERO (split layout: slider + visual + tiles) ===== */
.hero-wrap{padding:28px 0 0}
.hero{
  display:grid;grid-template-columns:1fr 30%;gap:16px;align-items:stretch;
  min-height:320px;
}

/* Lewa część = biały panel ze sliderem + duże zdjęcie produktu */
.hero-main{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
  display:grid;grid-template-columns:1fr 1fr;align-items:center;
}
.hero-text{padding:32px 36px;position:relative;z-index:2}
.hero-text .logo-mark{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.hero-text .logo-mark img{height:38px;width:auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--red-50);color:var(--red);padding:6px 14px;border-radius:var(--r);font-size:12px;font-weight:800;margin-bottom:18px;text-transform:uppercase;letter-spacing:.08em}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--red)}
.hero h1{font-size:clamp(32px,3.6vw,48px);line-height:1.05;margin:0 0 14px;font-weight:900;letter-spacing:-.025em;color:var(--ink)}
.hero h1 em{color:var(--red);font-style:normal}
.hero p{color:var(--ink-500);font-size:16px;margin:0 0 28px;max-width:420px}
.hero .cta{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;padding:14px 28px;border-radius:var(--r);font-weight:800;font-size:14px;transition:background .2s,transform .2s;box-shadow:0 8px 24px -8px rgba(227,6,19,.45);text-transform:uppercase;letter-spacing:.05em}
.hero .cta:hover{background:var(--red-600);transform:translateY(-2px)}
.hero .cta-ghost{margin-left:8px;display:inline-flex;align-items:center;gap:8px;padding:14px 22px;border-radius:var(--r);color:var(--ink);border:1.5px solid var(--line);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:13px;transition:all .2s}
.hero .cta-ghost:hover{border-color:var(--ink);background:var(--bg)}

.hero-visual{position:relative;height:100%;min-height:290px;background:#0B1B33;overflow:hidden}
.hero-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-visual::after{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,.0) 60%,rgba(11,27,51,.0) 100%),
    radial-gradient(circle at 10% 100%, rgba(227,6,19,.22), transparent 40%);
}

.hero-nav{position:absolute;right:16px;top:50%;transform:translateY(-50%);z-index:4;display:flex;flex-direction:column;gap:8px}
.hero-nav button{width:38px;height:38px;border-radius:var(--r-sm);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.hero-nav button:hover{background:var(--red);color:#fff;border-color:var(--red)}
.hero-nav svg{width:16px;height:16px}

.hero-dots{position:absolute;left:48px;bottom:28px;display:flex;gap:8px;z-index:3}
.hero-dots span{width:8px;height:8px;border-radius:50%;background:var(--line);transition:all .2s}
.hero-dots span.active{background:var(--red);width:24px;border-radius:4px}

/* Prawa część = kafelki 2x3 */
.hero-tiles{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr);gap:12px}
.hero-tile{
  background:linear-gradient(135deg,#1a2942,#0f1a30);color:#fff;border-radius:var(--r);
  border:1px solid rgba(255,255,255,.06);
  padding:0 16px;display:flex;flex-direction:row;align-items:center;gap:14px;
  min-height:86px;position:relative;overflow:hidden;
  transition:border-color .2s, transform .2s, box-shadow .2s;cursor:pointer;
}
.hero-tile::before{
  content:"";position:absolute;inset:0;background:
    radial-gradient(circle at 110% 110%, rgba(227,6,19,.18), transparent 55%);
  opacity:0;transition:opacity .3s;
}
.hero-tile:hover{border-color:rgba(227,6,19,.45);transform:translateY(-2px);box-shadow:0 8px 18px -10px rgba(0,0,0,.5)}
.hero-tile:hover::before{opacity:1}
.hero-tile .ic{width:34px;height:34px;color:#fff;opacity:.9;flex-shrink:0}
.hero-tile .ic svg{width:100%;height:100%;stroke-width:1.6}
.hero-tile .ft{flex:1;display:flex;align-items:center;justify-content:space-between;gap:8px;position:relative;z-index:2}
.hero-tile b{font-size:14px;font-weight:700;letter-spacing:-.005em;line-height:1.2}
.hero-tile .arr{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.hero-tile:hover .arr{background:var(--red);transform:translateX(2px)}
.hero-tile .arr svg{width:12px;height:12px}

/* ===== SECTION HEAD ===== */
section{padding:72px 0}
.section-head{text-align:center;max-width:900px;margin:0 auto 44px}
.section-head h2.nowrap{white-space:nowrap}
@media (max-width:640px){.section-head h2.nowrap{white-space:normal}}
.section-head .eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px}
.section-head .eyebrow::before,.section-head .eyebrow::after{content:"";width:28px;height:2px;background:var(--red)}
.section-head h2{font-size:clamp(28px,3vw,40px);line-height:1.1;margin:0 0 10px;letter-spacing:-.025em;font-weight:900}
.section-head p{color:var(--ink-500);margin:0;font-size:16px}

/* ===== CATEGORIES (Pneumat-style tiles) ===== */
.cats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.cat{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;transition:border-color .2s, box-shadow .2s, transform .2s;overflow:hidden}
.cat:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.cat .photo{aspect-ratio:4/3;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0}
.cat .photo img{width:100%;height:100%;object-fit:contain;object-position:center;transition:transform .35s}
.cat:hover .photo img{transform:scale(1.08)}
.cat .info{border-top:1px solid var(--line);padding:12px 14px 14px;display:flex;gap:8px;align-items:baseline}
.cat .num{font-size:13.5px;font-weight:800;color:var(--red);line-height:1.3;flex-shrink:0;letter-spacing:-.005em;font-variant-numeric:tabular-nums}
.cat h3{font-size:13.5px;margin:0;font-weight:600;line-height:1.3;color:var(--ink);letter-spacing:-.005em}
.cat:hover h3{color:var(--red)}

/* ===== GALLERY ===== */
.gallery-section{background:linear-gradient(180deg,#0B1B33,#16284A);color:#fff;border-radius:0}
.gallery-section .section-head h2{color:#fff}
.gallery-section .section-head p{color:#B4C0D9}
.gallery-section .eyebrow{color:#FF4756}
.gallery-section .eyebrow::before,.gallery-section .eyebrow::after{background:#FF4756}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gphoto{aspect-ratio:16/9;border-radius:var(--r);background:#1E3360;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);cursor:pointer;display:block}
.gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gphoto:hover img{transform:scale(1.05)}
.gphoto::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,transparent 30%,transparent 55%,rgba(0,0,0,.85));transition:opacity .3s;z-index:1}
.gphoto .play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;
  width:60px;height:60px;border-radius:50%;background:#FF0000;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,.35);transition:transform .25s, background .2s;
}
.gphoto:hover .play{transform:translate(-50%,-50%) scale(1.12);background:#FF0000}
.gphoto .play svg{width:22px;height:22px;color:#fff;margin-left:3px}
.gphoto .duration{
  position:absolute;right:10px;bottom:10px;z-index:3;
  background:rgba(0,0,0,.85);color:#fff;font-size:12px;font-weight:700;
  padding:3px 7px;border-radius:4px;letter-spacing:.02em;font-variant-numeric:tabular-nums;
}
.gphoto .vtitle{
  position:absolute;left:16px;right:16px;bottom:14px;z-index:3;
  color:#fff;font-weight:700;font-size:14px;line-height:1.3;letter-spacing:-.005em;
  text-shadow:0 1px 4px rgba(0,0,0,.6);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  padding-right:58px;
}
.gphoto .views{
  position:absolute;left:16px;bottom:6px;z-index:3;
  color:#B4C0D9;font-size:11px;font-weight:600;
  opacity:0;transform:translateY(4px);transition:all .25s;
}
.gphoto:hover .views{opacity:1;transform:translateY(0)}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:all .25s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.post-img{aspect-ratio:16/10;position:relative;background:#E8ECF5;overflow:hidden}
.post-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post:hover .post-img img{transform:scale(1.05)}
.post-date{position:absolute;top:14px;left:14px;background:var(--ink);color:#fff;padding:10px 14px;text-align:center;line-height:1;border-radius:var(--r-sm);z-index:2}
.post-date b{display:block;font-size:20px;font-weight:900;color:#fff}
.post-date span{font-size:11px;font-weight:700;text-transform:uppercase;color:#B4C0D9;letter-spacing:.05em}
.post-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-meta{display:flex;gap:14px;font-size:12px;color:var(--ink-500);align-items:center}
.post-meta span{display:inline-flex;gap:5px;align-items:center}
.post h3{font-size:18px;margin:4px 0 6px;line-height:1.3;font-weight:700}
.post p{color:var(--ink-500);font-size:14px;margin:0 0 14px;flex:1}
.post .readmore{display:inline-flex;align-items:center;gap:6px;color:var(--red);font-weight:700;font-size:13px;margin-top:auto;text-transform:uppercase;letter-spacing:.05em}
.post .readmore:hover{gap:10px}

/* ===== GOOGLE REVIEWS ===== */
.greviews{padding:36px 0}
.greviews-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px 28px;display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;
  box-shadow:var(--shadow-sm);transition:box-shadow .25s, transform .25s;
}
.greviews-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.greviews-left{display:flex;align-items:center;gap:16px}
.greviews-g{width:54px;height:54px;border-radius:50%;background:#fff;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.greviews-g svg{width:30px;height:30px}
.greviews-score b{display:block;font-size:30px;font-weight:900;color:var(--ink);line-height:1;letter-spacing:-.02em}
.greviews-score .stars{display:inline-flex;gap:2px;margin-top:4px}
.greviews-score .stars svg{width:15px;height:15px;color:#FBBC04;fill:#FBBC04}
.greviews-score small{display:block;font-size:12px;color:var(--ink-500);margin-top:3px;font-weight:600}
.greviews-quote{color:var(--ink-800);font-size:14.5px;line-height:1.5;font-style:italic;position:relative;padding-left:18px;border-left:3px solid var(--red)}
.greviews-quote cite{display:block;font-style:normal;font-size:12px;color:var(--ink-500);margin-top:6px;font-weight:600;letter-spacing:.02em}
.greviews-cta{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;padding:12px 20px;border-radius:var(--r-sm);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.05em;transition:background .2s,transform .2s;white-space:nowrap}
.greviews-cta:hover{background:var(--red);transform:translateX(2px)}
.greviews-cta svg{width:14px;height:14px}
@media (max-width:900px){
  .greviews-card{grid-template-columns:1fr;text-align:center;gap:18px}
  .greviews-left{justify-content:center}
  .greviews-quote{border-left:0;border-top:2px solid var(--red);padding:12px 0 0;text-align:center}
}
.greviews-list{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:14px}
.greview-mini{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .25s, border-color .2s, transform .25s;text-align:left}
.greview-mini:hover{box-shadow:var(--shadow-sm);border-color:var(--red);transform:translateY(-2px)}
.greview-mini .mini-head{display:flex;align-items:center;gap:10px}
.greview-mini .avatar{width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;letter-spacing:.02em}
.greview-mini .who{flex:1;min-width:0}
.greview-mini .who b{display:block;font-size:13px;font-weight:800;color:var(--ink);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.greview-mini .who .stars{display:inline-flex;gap:1px;margin-top:3px}
.greview-mini .who .stars svg{width:11px;height:11px;color:#FBBC04;fill:#FBBC04}
.greview-mini p{margin:0;font-size:12.5px;color:var(--ink-500);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.greview-mini.all{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-color:transparent;justify-content:center;align-items:center;text-align:center;gap:6px;padding:18px}
.greview-mini.all:hover{background:var(--red);border-color:transparent;transform:translateY(-2px)}
.greview-mini.all b{font-size:28px;font-weight:900;color:#fff;line-height:1;letter-spacing:-.02em}
.greview-mini.all span{font-size:11px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.greview-mini.all:hover span{color:#fff}
.greview-mini.all .go{display:inline-flex;align-items:center;gap:6px;color:#fff;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
.greview-mini.all .go svg{width:14px;height:14px}
@media (max-width:900px){
  .greviews-list{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .greviews-list{grid-template-columns:1fr}
}

/* ===== ABOUT ===== */
.about{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
.about-img{border-radius:var(--r);background:#0B1B33;position:relative;overflow:hidden;box-shadow:var(--shadow-lg);min-height:480px}
.about-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.about-img .overlay{position:absolute;left:24px;bottom:24px;z-index:2;color:#fff;background:rgba(11,27,51,.7);padding:14px 20px;border-radius:var(--r);backdrop-filter:blur(6px)}
.about-img .overlay b{display:block;font-weight:800;font-size:16px;letter-spacing:.05em}
.about-img .overlay span{font-size:12px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.08em}
.about-content h2{font-size:36px;line-height:1.1;margin:0 0 8px;font-weight:900;letter-spacing:-.025em}
.about-content .eyebrow{color:var(--red);font-weight:800;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px;display:block}
.about-content p{color:var(--ink-500);font-size:16px;margin:0 0 16px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin:28px 0 22px;background:var(--line);border-radius:var(--r);overflow:hidden;padding:2px}
.stat{padding:22px 16px;background:var(--bg);text-align:center}
.stat b{display:block;font-size:30px;font-weight:900;color:var(--red);letter-spacing:-.02em;line-height:1}
.stat span{font-size:12px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.05em;margin-top:6px;display:block;font-weight:600}
.ceo{display:flex;gap:14px;align-items:center;margin-top:22px;padding-top:22px;border-top:1px solid var(--line)}
.ceo .av{width:64px;height:64px;border-radius:50%;background:var(--bg);flex-shrink:0;overflow:hidden;border:2px solid var(--line)}
.ceo .av img{width:100%;height:100%;object-fit:cover}
.ceo b{display:block;font-weight:800}
.ceo span{font-size:13px;color:var(--ink-500)}

/* ===== FOOTER ===== */
footer{background:var(--ink);color:#B4C0D9;padding:64px 0 0;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.5fr;gap:48px;padding-bottom:48px}
.foot h4{color:#fff;font-size:13px;font-weight:800;margin:0 0 18px;text-transform:uppercase;letter-spacing:.1em;position:relative;padding-bottom:10px}
.foot h4::after{content:"";position:absolute;left:0;bottom:0;width:28px;height:2px;background:var(--red)}
.foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot a{color:#B4C0D9;font-size:14px;transition:color .2s}
.foot a:hover{color:#fff}
.foot-about .logo{background:#fff;padding:12px 16px;border-radius:var(--r);display:inline-flex;margin-bottom:4px}
.foot-about .logo img{height:40px;width:auto;display:block}
.foot-about p{font-size:14px;margin:16px 0 20px;line-height:1.6}
.foot-contact{font-size:14px;line-height:1.8}
.foot-contact b{color:#fff}
.foot-branch{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px}
.foot-branch svg{color:var(--red);flex-shrink:0;margin-top:2px}
.newsletter{display:flex;gap:6px;margin-top:10px}
.newsletter input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff;padding:14px 16px;border-radius:var(--r-sm);font-family:inherit;font-size:14px;outline:0;transition:border-color .2s}
.newsletter input:focus{border-color:var(--red)}
.newsletter input::placeholder{color:#7A8AA8}
.newsletter button{background:var(--red);color:#fff;padding:0 20px;border-radius:var(--r-sm);font-weight:700;transition:background .2s}
.newsletter button:hover{background:var(--red-600)}
.consent{font-size:12px;margin-top:12px;display:flex;gap:8px;align-items:flex-start}
.consent input{margin-top:2px}
.socials{display:flex;gap:8px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:all .2s}
.socials a:hover{background:var(--red);transform:translateY(-2px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#7A8AA8;flex-wrap:wrap;gap:12px}
.foot-bottom .pays{display:flex;gap:8px}
.foot-bottom .pays span{background:rgba(255,255,255,.08);padding:6px 12px;border-radius:var(--r-sm);font-size:11px;font-weight:700;color:#fff;letter-spacing:.03em}

/* ===== BRANDS CAROUSEL ===== */
.brands-wrap{padding:0 0 24px;margin-top:-24px}
.brands-head{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:22px;gap:20px;flex-wrap:wrap}
.brands-head .ttl{display:flex;flex-direction:column;gap:4px;text-align:center;align-items:center}
.brands-head .all{position:absolute;right:0;bottom:0}
@media (max-width: 720px){.brands-head .all{position:static}}
.brands-head .eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.brands-head .eyebrow::before,.brands-head .eyebrow::after{content:"";width:28px;height:2px;background:var(--red)}
.brands-head h2{font-size:clamp(22px,2.2vw,30px);margin:0;font-weight:900;letter-spacing:-.02em}
.brands-head .all{color:var(--ink-500);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:6px;transition:color .2s}
.brands-head .all:hover{color:var(--red)}

.brands-carousel{position:relative}
.brands-track{
  display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 5*16px) / 6);
  gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:4px 0 16px;
  scrollbar-width:none;
}
.brands-track::-webkit-scrollbar{display:none}
.brand{
  scroll-snap-align:start;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  aspect-ratio:2/1;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  transition:border-color .2s, transform .2s, box-shadow .2s;
  cursor:pointer;position:relative;
}
.brand:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.brand img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:filter .25s, opacity .25s}
.brand:hover img{filter:none;opacity:1}
.brand .cnt{position:absolute;top:8px;right:8px;font-size:11px;font-weight:800;color:var(--ink-500);background:var(--bg);padding:3px 8px;border-radius:var(--r-sm)}
.brand:hover .cnt{background:var(--red);color:#fff}

.brands-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:44px;height:44px;border-radius:50%;background:#fff;
  border:1px solid var(--line);box-shadow:var(--shadow);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink);cursor:pointer;transition:all .2s;
}
.brands-arrow:hover{background:var(--red);color:#fff;border-color:var(--red)}
.brands-arrow.prev{left:-22px}
.brands-arrow.next{right:-22px}
.brands-arrow svg{width:18px;height:18px}

@media (max-width:1024px){.brands-track{grid-auto-columns:calc((100% - 3*16px) / 4)}}
@media (max-width:640px){.brands-track{grid-auto-columns:calc((100% - 2*16px) / 3)}.brands-arrow{display:none}}

/* ===== MARQUEE STRIP (Journal-style) ===== */
.marquee{
  background:var(--red);color:#fff;
  overflow:hidden;position:relative;
  padding:22px 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.marquee::before,.marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,var(--red),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--red),transparent)}
.marquee-track{
  display:flex;align-items:center;gap:60px;white-space:nowrap;
  animation:scroll 32s linear infinite;
  width:max-content;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{
  display:inline-flex;align-items:center;gap:14px;
  font-weight:800;font-size:17px;text-transform:uppercase;letter-spacing:.08em;
  color:#fff;
}
.marquee-item svg{width:26px;height:26px;flex-shrink:0;color:#fff;opacity:.95}
.marquee-item .dot{width:6px;height:6px;border-radius:50%;background:#fff;opacity:.5}
.marquee-item span.amt{font-weight:700;color:#FFE2E4}
@keyframes scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ===== RESPONSIVE ===== */
@media (max-width:1280px){
  .cats-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:1024px){
  .cats-grid{grid-template-columns:repeat(3,1fr)}
  .hero{grid-template-columns:1fr}
  .hero-main{grid-template-columns:1fr}
  .hero-visual{min-height:300px}
  .hero-tiles{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .about{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:640px){
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .hero-tiles{grid-template-columns:1fr 1fr}
  .hero-text{padding:32px}
  .blog-grid,.gallery{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .header .row{grid-template-columns:auto 1fr auto}
  .search select{display:none}
  .nav-right{display:none}
  section{padding:48px 0}
}
</style>
<style>
.seo-cities{background:#0e1c33;padding:22px 0;border-top:1px solid rgba(255,255,255,.06)}
.seo-cities .container{display:flex;align-items:center;flex-wrap:wrap;gap:8px 10px}
.seo-cities strong{color:#fff;font-size:14px;font-weight:700;margin-right:18px}
.seo-cities a{display:inline-block;padding:7px 13px;background:#1d4ed8;color:#fff;border-radius:6px;font-size:12.5px;font-weight:600;text-decoration:none;transition:background .15s}
.seo-cities a:hover{background:#2563eb}
/* === category page additional styles === */
:root{
  --red:#E30613;
  --red-600:#C4050F;
  --red-50:#FFF2F3;
  --ink:#0B1B33;
  --ink-800:#16284A;
  --ink-500:#475772;
  --ink-300:#8A97AD;
  --line:#E6EAF2;
  --bg:#F5F7FB;
  --white:#fff;
  --r-sm:2px;
  --r:4px;
  --r-lg:6px;
  --shadow-sm:0 1px 2px rgba(11,27,51,.06), 0 1px 3px rgba(11,27,51,.04);
  --shadow:0 8px 24px -10px rgba(11,27,51,.18), 0 2px 6px rgba(11,27,51,.06);
  --shadow-lg:0 30px 60px -20px rgba(11,27,51,.25);
  --green:#1FA968;
  --green-50:#E8F8F0;
  --gold:#D4A93C;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;border:0;cursor:pointer;background:none}
.container{max-width:1440px;margin:0 auto;padding:0 24px}

/* ===== TOP UTILITY BAR ===== */
.topbar{background:var(--ink);color:#D7DEEC;font-size:13px}
.topbar .row{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar a{color:#D7DEEC;opacity:.85}
.topbar a:hover{opacity:1;color:#fff}
.topbar .meta{display:flex;gap:22px;align-items:center}
.topbar .meta span{display:inline-flex;gap:6px;align-items:center}
.topbar .lang{display:flex;gap:14px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:rgba(255,255,255,.08);font-weight:500;border-radius:var(--r-sm)}

/* ===== HEADER ===== */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.header .row{display:grid;grid-template-columns:220px 1fr auto;gap:32px;align-items:center;padding:18px 24px}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:46px;width:auto;display:block}
.search{display:flex;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:46px;transition:border-color .2s, box-shadow .2s;width:100%}
.search:focus-within{border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
.search select{border:0;background:#F7F8FC;padding:0 14px;font-weight:600;color:var(--ink);border-right:1px solid var(--line);outline:0;font-size:13px;min-width:170px}
.search input{flex:1;border:0;padding:0 16px;font-size:14px;outline:0;background:transparent}
.search button{background:var(--red);color:#fff;padding:0 22px;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;transition:background .2s}
.search button:hover{background:var(--red-600)}
.icons{display:flex;gap:4px;align-items:center}
.icon-btn{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:3px;padding:10px 14px;border-radius:var(--r);color:var(--ink-500);font-size:12px;font-weight:500;transition:background .2s,color .2s}
.icon-btn:hover{background:var(--bg);color:var(--ink)}
.icon-btn svg{width:22px;height:22px}
.icon-btn .badge{position:absolute;top:4px;right:8px;background:var(--red);color:#fff;font-size:10px;font-weight:800;min-width:16px;height:16px;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;padding:0 4px}
.cart-price{color:var(--ink);font-weight:700}

/* ===== NAV ===== */
.nav{background:#fff;border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:58px}
.nav-left,.nav-right{display:flex;align-items:center;gap:4px}
.dept-wrap{position:relative;margin-right:14px}
.dept{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:12px 22px;border-radius:var(--r);font-weight:700;font-size:14px;cursor:pointer}
.dept:hover,.dept-wrap:hover .dept{background:var(--ink-800)}
.dept-panel{position:absolute;top:calc(100% + 6px);left:0;z-index:70;display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s, transform .18s, visibility .18s}
.dept-wrap:hover .dept-panel,.dept-wrap:focus-within .dept-panel{opacity:1;visibility:visible;transform:translateY(0)}
.dept-col{width:300px;padding:10px;display:flex;flex-direction:column;gap:2px}
.dept-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--r-sm);font-size:13.5px;font-weight:600;color:var(--ink-800);transition:background .15s,color .15s;cursor:pointer}
.dept-item:hover,.dept-item.has-drawer:hover{background:var(--bg);color:var(--red)}
.dept-item .ico{width:24px;height:24px;color:var(--ink-500);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:color .15s}
.dept-item:hover .ico{color:var(--red)}
.dept-item .ico svg{width:100%;height:100%;stroke-width:1.7}
.dept-item .name{flex:1}
.dept-item .chev{width:14px;height:14px;color:var(--ink-300);flex-shrink:0;opacity:0;transition:opacity .15s, transform .15s}
.dept-item.has-drawer .chev{opacity:.6}
.dept-item.has-drawer:hover .chev{opacity:1;color:var(--red);transform:translateX(2px)}
.dept-drawer{position:absolute;top:0;left:300px;width:760px;min-height:100%;background:#fff;border-left:1px solid var(--line);border-radius:0 var(--r-lg) var(--r-lg) 0;padding:26px 28px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s, visibility .15s;z-index:2}
.dept-item.has-drawer:hover .dept-drawer,.dept-drawer:hover{opacity:1;visibility:visible;pointer-events:auto}
.dg h4{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--red);display:inline-block}
.dg a{display:block;padding:6px 0;font-size:13.5px;font-weight:500;color:var(--ink-500);transition:color .15s, padding .15s}
.dg a:hover,.dg a.is-current{color:var(--red);padding-left:4px}
.dg a.is-current{font-weight:700}
.dg .see-all{margin-top:8px;color:var(--red);font-weight:700;display:inline-flex;align-items:center;gap:4px;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em}
.dept-promo{grid-column:span 3;margin-top:4px;padding:16px 20px;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);display:flex;align-items:center;justify-content:space-between;gap:20px}
.dept-promo b{color:#fff;font-size:14px}
.dept-promo span{color:#B4C0D9;font-size:12.5px;display:block;margin-top:2px}
.dept-promo .pill{background:var(--red);color:#fff;padding:8px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.nav a.link{padding:10px 16px;border-radius:var(--r-sm);font-weight:600;color:var(--ink-800);transition:background .2s,color .2s;font-size:14px;text-transform:uppercase;letter-spacing:.03em}
.nav a.link:hover{background:var(--bg);color:var(--red)}
.nav .has-sub{position:relative}
.nav .has-sub > .link{display:inline-flex;align-items:center;gap:6px}
.nav .has-sub > .link svg{width:12px;height:12px;transition:transform .2s}
.nav .has-sub:hover > .link svg{transform:rotate(180deg)}
.nav .submenu{position:absolute;top:calc(100% + 4px);left:0;z-index:60;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);min-width:240px;padding:8px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s, transform .18s, visibility .18s}
.nav .has-sub:hover .submenu,.nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .submenu a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-sm);font-size:13.5px;font-weight:600;color:var(--ink-800);transition:background .15s, color .15s}
.nav .submenu a:hover{background:var(--bg);color:var(--red)}
.nav .submenu a svg{width:14px;height:14px;color:var(--red);flex-shrink:0}
.contact-btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:12px 22px;border-radius:var(--r);font-weight:700;transition:background .2s,transform .2s;font-size:14px;text-transform:uppercase;letter-spacing:.03em}
.contact-btn:hover{background:var(--red-600)}

/* ===== BREADCRUMBS ===== */
.breadcrumbs{background:#fff;border-bottom:1px solid var(--line)}
.breadcrumbs .row{display:flex;align-items:center;gap:8px;padding:14px 24px;font-size:13px;color:var(--ink-500);flex-wrap:wrap}
.breadcrumbs a{color:var(--ink-500);transition:color .15s}
.breadcrumbs a:hover{color:var(--red)}
.breadcrumbs svg{width:12px;height:12px;color:var(--ink-300);flex-shrink:0}
.breadcrumbs .current{color:var(--ink);font-weight:700}

/* ===== CATEGORY PAGE LAYOUT ===== */
.cat-page{display:grid;grid-template-columns:280px 1fr;gap:28px;padding:24px 24px 32px;align-items:start}
.side-overlay{display:none;position:fixed;inset:0;background:rgba(11,27,51,.5);z-index:115}
.side-overlay.show{display:block}

/* ----- SIDE PANEL ----- */
.side-block{background:#fff;border:1px solid var(--line);border-radius:var(--r);margin-bottom:16px;overflow:hidden}
.side-block-head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;background:#FAFBFD}
.side-block-head h3{margin:0;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink)}
.side-block-head .toggle-all{font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.05em;font-weight:700;cursor:pointer}
.side-block-head .toggle-all:hover{color:var(--red)}

.side-tree{list-style:none;margin:0;padding:6px 0}
.side-tree li{position:relative;list-style:none}
.side-tree li > a{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13.5px;color:var(--ink-800);font-weight:600;transition:background .15s,color .15s,border-left-color .15s;border-left:3px solid transparent}
.side-tree li > a:hover{background:var(--bg);color:var(--red)}
.side-tree li > a .toggle{width:20px;height:20px;color:var(--ink-300);font-weight:700;font-size:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s, color .15s}
.side-tree li.open > a .toggle{transform:rotate(45deg);color:var(--red)}
.side-tree li.active > a{background:var(--red-50);color:var(--red);border-left-color:var(--red);font-weight:700}
.side-tree li.active > a .toggle{color:var(--red)}
/* Wcięcia per poziom (4 poziomy) */
.side-tree li.lvl-1 > a{padding:11px 18px}
.side-tree li.lvl-2 > a{padding:8px 18px 8px 36px;font-size:13px;color:var(--ink-700);font-weight:600}
.side-tree li.lvl-3 > a{padding:7px 18px 7px 54px;font-size:12.5px;color:var(--ink-500);font-weight:500}
.side-tree li.lvl-4 > a{padding:6px 18px 6px 72px;font-size:12px;color:var(--ink-500);font-weight:500}
/* Kontener dzieci — tylko bezpośredni potomek się rozwija */
.side-tree ul.children{list-style:none;margin:0;padding:2px 0 6px;display:none}
.side-tree li.open > ul.children{display:block}
.side-tree li.lvl-1 > ul.children{background:#FAFBFD}
.side-tree li.lvl-2 > ul.children{background:#F5F7FA}
.side-tree li.lvl-3 > ul.children{background:#EFF2F6}

/* Brand checkboxes */
.side-brands{padding:14px 18px}
.brand-search{position:relative;margin-bottom:12px}
.brand-search input{width:100%;border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 10px 8px 32px;font-family:inherit;font-size:13px;outline:0;transition:border-color .15s}
.brand-search input:focus{border-color:var(--red)}
.brand-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink-300)}
.brand-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto}
.brand-list::-webkit-scrollbar{width:6px}
.brand-list::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.brand-list label{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:var(--r-sm);cursor:pointer;transition:background .15s;font-size:13px;color:var(--ink-800);font-weight:500}
.brand-list label:hover{background:var(--bg)}
.brand-list .lg{width:34px;height:24px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:2px}
.brand-list .lg img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(.5);opacity:.85;transition:all .2s}
.brand-list label:hover .lg img{filter:none;opacity:1}
.brand-list .name{flex:1;letter-spacing:-.005em}
.brand-list .cnt{font-size:11px;color:var(--ink-500);font-weight:600;background:var(--bg);padding:2px 7px;border-radius:var(--r-sm);font-variant-numeric:tabular-nums}
.brand-list input[type=checkbox]{accent-color:var(--red);width:14px;height:14px;cursor:pointer}

/* Side help card */
.side-help{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);padding:18px;display:flex;flex-direction:column;gap:8px}
.side-help b{font-size:14px;font-weight:800}
.side-help p{margin:0;font-size:12.5px;color:#B4C0D9;line-height:1.45}
.side-help a{display:inline-flex;align-items:center;gap:6px;background:var(--red);color:#fff;padding:8px 14px;font-size:12px;font-weight:800;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em;margin-top:6px;transition:background .2s}
.side-help a:hover{background:var(--red-600)}

/* ----- MAIN COLUMN ----- */
.cat-main{min-width:0}

/* Page head */
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:4px 0 18px}
.cat-head h1{margin:0;font-size:30px;line-height:1.1;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.cat-head .meta{font-size:13px;color:var(--ink-500);margin-top:6px;display:flex;gap:14px}
.cat-head .meta b{color:var(--ink);font-weight:700}
.cat-head .show-all{display:inline-flex;align-items:center;gap:6px;color:var(--red);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.cat-head .show-all:hover{gap:10px}

/* Subcategory strip */
.subcat-strip{position:relative;margin:0 0 18px}
.subcat-track{display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 5*12px) / 6);gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:4px 0;scrollbar-width:none}
.subcat-track::-webkit-scrollbar{display:none}
.subcat-tile{scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;transition:all .2s;overflow:hidden;cursor:pointer}
.subcat-tile:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.subcat-tile .photo{aspect-ratio:1/1;background:#fff;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden}
.subcat-tile .photo img{width:112%;height:112%;object-fit:contain;object-position:center;transition:transform .3s}
.subcat-tile:hover .photo img{transform:scale(1.06)}
.subcat-tile .info{border-top:1px solid var(--line);padding:10px 12px;display:flex;gap:8px;align-items:baseline}
.subcat-tile .num{font-size:12.5px;font-weight:800;color:var(--red);flex-shrink:0;font-variant-numeric:tabular-nums}
.subcat-tile h3{margin:0;font-size:12.5px;font-weight:600;line-height:1.3;color:var(--ink)}
.subcat-tile.is-current{border-color:var(--red);box-shadow:0 0 0 2px var(--red-50) inset}
.subcat-tile.is-current h3{color:var(--red)}
.subcat-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);display:inline-flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;transition:all .2s}
.subcat-arrow:hover{background:var(--red);color:#fff;border-color:var(--red)}
.subcat-arrow.prev{left:-18px}
.subcat-arrow.next{right:-18px}
.subcat-arrow svg{width:14px;height:14px}

/* Description block */
.cat-desc{background:#fff;border:1px solid var(--line);border-left:3px solid var(--red);border-radius:var(--r);padding:18px 22px;margin:0 0 16px;font-size:14px;color:var(--ink-500);line-height:1.65}
.cat-desc b{color:var(--ink);font-weight:700}

/* Filter bar */
.filterbar{background:#fff;border:1px solid var(--line);border-radius:var(--r);margin:0 0 16px;overflow:hidden}
.filter-brands{display:flex;flex-wrap:wrap;gap:6px 18px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);background:#FAFBFD}
.filter-brands .lbl{font-size:11px;font-weight:800;color:var(--ink-500);text-transform:uppercase;letter-spacing:.1em;margin-right:6px}
.filter-brands label{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-size:13px;color:var(--ink-800);font-weight:600;padding:5px 0;transition:color .15s}
.filter-brands label:hover{color:var(--red)}
.filter-brands input[type=checkbox]{accent-color:var(--red);width:14px;height:14px;cursor:pointer}

.filter-row{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;padding:14px 18px}
.filter-row .sel{position:relative}
.filter-row select{width:100%;appearance:none;-webkit-appearance:none;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 30px 9px 12px;font-family:inherit;font-size:13px;color:var(--ink);font-weight:600;cursor:pointer;outline:0;transition:border-color .15s,box-shadow .15s}
.filter-row select:hover{border-color:var(--ink-300)}
.filter-row select:focus{border-color:var(--red);box-shadow:0 0 0 2px var(--red-50)}
.filter-row .sel::after{content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%) rotate(45deg);width:6px;height:6px;border:1.5px solid var(--ink-500);border-top:0;border-left:0;pointer-events:none}

.tools-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 18px;border-top:1px solid var(--line);background:#FAFBFD;flex-wrap:wrap}
.tools-row .lhs,.tools-row .rhs{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:#fff}
.view-toggle button{padding:8px 12px;color:var(--ink-500);transition:all .15s;display:inline-flex;align-items:center;justify-content:center}
.view-toggle button.active{background:var(--ink);color:#fff}
.view-toggle button svg{width:16px;height:16px}
.view-toggle button:not(.active):hover{background:var(--bg);color:var(--ink)}
.tools-row .label{font-size:12.5px;color:var(--ink-500);font-weight:600}
.tools-row .mini-sel{appearance:none;-webkit-appearance:none;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 28px 7px 12px;font-family:inherit;font-size:13px;color:var(--ink);font-weight:700;cursor:pointer;outline:0;background-image:linear-gradient(45deg,transparent 50%,var(--ink-500) 50%),linear-gradient(135deg,var(--ink-500) 50%,transparent 50%);background-position:calc(100% - 14px) 50%, calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
.reset-btn{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:#fff;padding:9px 16px;border-radius:var(--r-sm);font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;transition:background .2s}
.reset-btn:hover{background:var(--red)}
.reset-btn svg{width:13px;height:13px}

/* Active filter chips */
.active-chips{display:flex;flex-wrap:wrap;gap:6px;padding:12px 18px;border-top:1px dashed var(--line);background:#fff}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--red-50);color:var(--red);font-size:12px;font-weight:700;padding:5px 8px 5px 12px;border-radius:var(--r-sm);border:1px solid #FFD0D3}
.chip button{color:var(--red);width:16px;height:16px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;line-height:1;transition:background .15s}
.chip button:hover{background:rgba(227,6,19,.15)}

/* ===== PRODUCT LIST ===== */
.product-list{display:flex;flex-direction:column;gap:8px}
.product-row{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:12px;display:grid;grid-template-columns:90px 1fr 170px 170px 200px;gap:18px;align-items:center;transition:border-color .15s, box-shadow .15s}
.product-row:hover{border-color:#D6DDED;box-shadow:var(--shadow-sm)}
.product-row .img{aspect-ratio:1;background:var(--bg);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;padding:6px;overflow:hidden;border:1px solid var(--line)}
.product-row .img img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .3s}
.product-row:hover .img img{transform:scale(1.06)}
.product-row .meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.product-row .code{font-size:14px;font-weight:800;color:var(--ink);letter-spacing:-.005em;font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;gap:8px}
.product-row .code .brand-tag{font-size:10px;font-weight:800;background:var(--ink);color:#fff;padding:2px 6px;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em}
.product-row .name{color:var(--ink-500);font-size:13px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-row .name a{color:var(--ink-500);transition:color .15s}
.product-row .name a:hover{color:var(--red)}
.product-row .specs{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.product-row .specs span{font-size:11px;background:var(--bg);color:var(--ink-500);padding:2px 7px;border-radius:var(--r-sm);font-weight:600;letter-spacing:-.005em}

.product-row .stock{display:flex;align-items:center;gap:10px}
.product-row .stock .ico{width:36px;height:36px;border-radius:var(--r-sm);background:var(--red-50);color:var(--red);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.product-row .stock .ico svg{width:18px;height:18px}
.product-row .stock.in .ico{background:#E8F8F0;color:#1FA968}
.product-row .stock .qty-label{font-size:11px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.04em;display:block}
.product-row .stock b{font-size:13px;font-weight:700;color:var(--ink);display:block}
.product-row .stock .lead{font-size:12px;color:#1FA968;font-weight:700;margin-top:2px}
.product-row .stock.out .lead{color:#E2A100}

.product-row .price{text-align:right}
.product-row .price b{font-size:18px;font-weight:900;color:var(--ink);letter-spacing:-.015em;font-variant-numeric:tabular-nums;display:block}
.product-row .price .net{font-size:11px;color:var(--ink-500);font-weight:600;margin-left:3px;text-transform:lowercase}
.product-row .price .gross{font-size:12px;color:var(--ink-500);font-weight:600;margin-top:2px;font-variant-numeric:tabular-nums}

.product-row .actions{display:flex;gap:6px;align-items:center;justify-content:flex-end}
.qty-pick{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-sm);height:42px;background:#fff}
.qty-pick button{width:30px;height:42px;color:var(--ink-500);font-weight:700;font-size:16px;transition:color .15s, background .15s}
.qty-pick button:hover{color:var(--red);background:var(--bg)}
.qty-pick input{width:42px;height:42px;border:0;text-align:center;font-weight:700;font-family:inherit;color:var(--ink);font-size:14px;outline:0;background:transparent;font-variant-numeric:tabular-nums}
.qty-pick input::-webkit-inner-spin-button,.qty-pick input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.cart-btn{width:46px;height:42px;background:var(--red);color:#fff;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;transition:background .2s, transform .15s;flex-shrink:0}

/* ===== KONFIGURATORY W LIŚCIE KATEGORII (v1: karta → strona produktu) ===== */
.product-row.cfg{grid-template-columns:90px 1fr 168px 234px;position:relative;overflow:hidden}
.product-row.cfg::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ink)}
.product-row.cfg.cfg--heavy::before{background:var(--red)}
.cfg-badge{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:3px 9px;border-radius:var(--r-sm);width:max-content;margin-bottom:3px}
.cfg-badge svg{width:12px;height:12px}
.cfg-badge--light{background:#E7EDFA;color:var(--ink)}
.cfg-badge--heavy{background:var(--red-50);color:var(--red)}
.product-row.cfg .code{color:var(--ink);font-size:14.5px}
.product-row.cfg .name{font-size:12.5px}
.cfg-count{display:flex;align-items:center;gap:11px}
.cfg-hex{width:40px;height:40px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);background:#E7EDFA;border-radius:var(--r-sm)}
.cfg--heavy .cfg-hex{color:var(--red);background:var(--red-50)}
.cfg-hex svg{width:21px;height:21px}
.cfg-count .cfg-count-lbl{font-size:10px;color:var(--ink-500);font-weight:800;text-transform:uppercase;letter-spacing:.07em;display:block}
.cfg-count b{font-size:19px;font-weight:900;color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums;display:block;line-height:1.05}
.cfg-count .cfg-count-sub{font-size:10.5px;color:var(--ink-300);font-weight:700;display:block}
.cfg-actions{display:flex;flex-direction:column;gap:7px;justify-content:center}
.cfg-toggle{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:46px;border-radius:var(--r);font-weight:800;font-size:13px;letter-spacing:.03em;transition:all .18s;width:100%;text-transform:uppercase;background:var(--red);color:#fff}
.cfg-toggle:hover{background:var(--red-600);transform:translateY(-1px)}
.cfg-toggle .chev{width:15px;height:15px}
.cfg-link{text-align:center;font-size:11.5px;font-weight:700;color:var(--ink-500);transition:color .15s}
.cfg-link:hover{color:var(--red)}
@media (max-width:768px){
  .product-row.cfg{grid-template-columns:80px 1fr;row-gap:12px}
  .product-row.cfg .cfg-count{grid-column:2}
  .product-row.cfg .cfg-actions{grid-column:1 / -1}
}
/* v2: rozwijana szuflada z realnym widgetem konfiguratora (lazy-load) */
.cfg-block{display:flex;flex-direction:column}
.cfg-block.open .product-row.cfg{border-bottom-left-radius:0;border-bottom-right-radius:0;border-color:#cdd7ea}
.cfg-toggle{border:0;font-family:inherit;cursor:pointer}
.cfg-toggle .chev{transition:transform .25s}
.cfg-block.open .cfg-toggle .chev{transform:rotate(180deg)}
.cfg-drawer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.cfg-block.open .cfg-drawer{max-height:700px}
.cfg-drawer-inner{border:1px solid #cdd7ea;border-top:0;border-radius:0 0 var(--r) var(--r);background:#FAFBFD;padding:16px;max-height:640px;overflow-y:auto}
.cfg-drawer-inner::-webkit-scrollbar{width:9px}
.cfg-drawer-inner::-webkit-scrollbar-track{background:#EFF3FA;border-radius:6px}
.cfg-drawer-inner::-webkit-scrollbar-thumb{background:#c4cde0;border-radius:6px;border:2px solid #EFF3FA}
.cfg-drawer-loading{padding:24px;text-align:center;color:var(--ink-500);font-size:13px;font-weight:600}
.cfg-drawer-loading a{color:var(--red);font-weight:800}
@media (max-width:768px){
  .cfg-drawer{display:none}
  .cfg-toggle .chev,.cfg-block.open .cfg-toggle .chev{transform:rotate(-90deg)}
}
/* === INLINE konfigurator w szufladzie — styl 1:1 z makiety (light + heavy) === */
/* LIGHT: faceted filterbar */
.cfg-fbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.cfg-fbar-lbl{font-size:11px;font-weight:800;color:var(--ink-500);text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:6px;margin-right:2px}
.cfg-fbar-lbl svg{width:14px;height:14px;color:var(--ink-300)}
.cfg-sel{position:relative}
.cfg-fbar .cfg-sel{min-width:154px}
.cfg-fbar select{width:100%;appearance:none;-webkit-appearance:none;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 28px 8px 11px;font-family:inherit;font-size:12.5px;color:var(--ink);font-weight:600;cursor:pointer;outline:0;transition:border-color .15s,box-shadow .15s}
.cfg-fbar select:hover{border-color:var(--ink-300)}
.cfg-fbar select:focus{border-color:var(--red);box-shadow:0 0 0 2px var(--red-50)}
.cfg-sel::after{content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%) rotate(45deg);width:5px;height:5px;border:1.5px solid var(--ink-500);border-top:0;border-left:0;pointer-events:none}
.cfg-count-tag{font-size:11.5px;color:var(--ink-500);font-weight:700;background:#fff;border:1px solid var(--line);padding:7px 11px;border-radius:var(--r-sm);font-variant-numeric:tabular-nums;margin-left:auto}
.cfg-count-tag b{color:var(--red);font-weight:900}
.cfg-reset{display:inline-flex;align-items:center;gap:5px;background:transparent;color:var(--ink-500);font-size:12px;font-weight:700;padding:7px 4px;transition:color .15s;cursor:pointer;font-family:inherit;border:0}
.cfg-reset:hover{color:var(--red)}
.cfg-reset svg{width:13px;height:13px}
/* LIGHT: scrollable variant list */
.cfg-scroll{max-height:430px;overflow-y:auto;border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:2px 4px}
.cfg-scroll::-webkit-scrollbar{width:10px}
.cfg-scroll::-webkit-scrollbar-track{background:#EFF3FA;border-radius:8px}
.cfg-scroll::-webkit-scrollbar-thumb{background:#c4cde0;border-radius:8px;border:2px solid #EFF3FA}
.cfg-vrow{display:grid;grid-template-columns:minmax(208px,1.5fr) 1.05fr 108px 142px auto;gap:12px;align-items:center;padding:9px 10px;border-bottom:1px solid var(--line);transition:background .12s}
.cfg-vrow:last-child{border-bottom:0}
.cfg-vrow:hover{background:#FAFBFD}
.cfg-vrow.is-out{opacity:.6}
.cfg-vrow .v-code b{font-size:13px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;display:block;letter-spacing:-.005em}
.cfg-vrow .v-code small{font-size:11.5px;color:var(--ink-500);line-height:1.35;display:block;margin-top:1px}
.cfg-vrow .v-pills{display:flex;flex-wrap:wrap;gap:4px}
.cfg-vrow .v-pill{font-size:11px;background:var(--bg);color:var(--ink-500);padding:2px 8px;border-radius:var(--r-sm);font-weight:700;white-space:nowrap}
.cfg-vrow .v-stock{font-size:12px;font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:6px}
.cfg-vrow .v-stock i{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}
.cfg-vrow .v-stock.out{color:var(--gold)}
.cfg-vrow .v-stock.out i{background:var(--gold)}
.cfg-vrow .v-price{text-align:right}
.cfg-vrow .v-price b{font-size:14px;font-weight:900;color:var(--ink);font-variant-numeric:tabular-nums;display:block}
.cfg-vrow .v-price b span{font-size:10px;color:var(--ink-500);font-weight:600;margin-left:3px}
.cfg-vrow .v-price small{font-size:11px;color:var(--ink-500);display:block;margin-top:1px;font-variant-numeric:tabular-nums}
.cfg-vrow .v-buy{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.cfg-vrow .qmini{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-sm);height:34px;background:#fff}
.cfg-vrow .qmini button{width:24px;height:34px;color:var(--ink-500);font-weight:700;font-size:15px;transition:color .15s;border:0;background:none;cursor:pointer}
.cfg-vrow .qmini button:hover{color:var(--red)}
.cfg-vrow .qmini input{width:30px;height:34px;border:0;text-align:center;font-weight:700;font-family:inherit;color:var(--ink);font-size:13px;outline:0;background:transparent}
.cfg-vrow .qmini input::-webkit-inner-spin-button,.cfg-vrow .qmini input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.cfg-vrow .cmini{width:38px;height:34px;background:var(--red);color:#fff;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0;border:0;cursor:pointer}
.cfg-vrow .cmini:hover{background:var(--red-600)}
.cfg-vrow .cmini svg{width:17px;height:17px}
.cfg-vrow.is-out .cmini{background:var(--ink-300);cursor:not-allowed}
.cfg-empty{padding:26px;text-align:center;color:var(--ink-500);font-size:13px;font-weight:600}
.cfg-drawer-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 4px 2px;font-size:12px;color:var(--ink-500);flex-wrap:wrap}
.cfg-drawer-foot a{color:var(--red);font-weight:800}
/* HEAVY: axes + navy panel */
.cfg-cfgwrap{display:grid;grid-template-columns:1fr 316px;gap:18px;align-items:start}
.cfg-axes{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
.cfg-field{display:flex;flex-direction:column;gap:5px}
.cfg-field > span{font-size:10.5px;font-weight:800;color:var(--ink-500);text-transform:uppercase;letter-spacing:.05em}
.cfg-field .cfg-sel select{width:100%;appearance:none;-webkit-appearance:none;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 30px 10px 12px;font-family:inherit;font-size:13px;color:var(--ink);font-weight:600;cursor:pointer;outline:0;transition:border-color .15s,box-shadow .15s}
.cfg-field .cfg-sel select:focus{border-color:var(--red);box-shadow:0 0 0 2px var(--red-50)}
.cfg-live{background:linear-gradient(160deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);padding:18px;position:sticky;top:90px;display:flex;flex-direction:column;gap:7px}
.cfg-live-lbl{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#9fb0cf}
.cfg-sku{font-family:'Courier New',ui-monospace,monospace;font-size:15px;font-weight:700;letter-spacing:.01em;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-sm);padding:11px 12px;word-break:break-all}
.cfg-price-big{display:flex;align-items:baseline;gap:6px;margin-top:6px}
.cfg-price-big b{font-size:27px;font-weight:900;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.cfg-price-big span{font-size:12px;color:#9fb0cf;font-weight:700}
.cfg-price-gross{font-size:12.5px;color:#b9c6de;font-weight:600;font-variant-numeric:tabular-nums}
.cfg-addcart{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--red);color:#fff;height:48px;border-radius:var(--r);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.04em;margin-top:8px;transition:background .18s,transform .15s;border:0;cursor:pointer;font-family:inherit}
.cfg-addcart:hover{background:var(--red-600);transform:translateY(-1px)}
.cfg-addcart:disabled{opacity:.5;cursor:not-allowed;transform:none}
.cfg-addcart svg{width:19px;height:19px}
.cfg-fulllink{text-align:center;color:#fff;font-size:12.5px;font-weight:700;opacity:.85;transition:opacity .15s;margin-top:2px}
.cfg-fulllink:hover{opacity:1;text-decoration:underline}
.cfg-note{margin:6px 0 0;font-size:11px;color:#8aa0c4;line-height:1.5}
@media (max-width:1024px){
  .cfg-cfgwrap{grid-template-columns:1fr}
  .cfg-axes{grid-template-columns:repeat(2,1fr)}
  .cfg-live{position:static}
}
/* Toast potwierdzenia dodania do koszyka */
.cfg-toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:13px 22px;border-radius:var(--r);font-weight:700;font-size:13.5px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:2000}
.cfg-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
/* ===== /KONFIGURATORY ===== */
.cart-btn:hover{background:var(--red-600);transform:translateY(-1px)}
.cart-btn svg{width:20px;height:20px}

/* Load more & pagination */
.load-more{text-align:center;padding:18px 0 6px}
.load-more button{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);padding:13px 28px;border-radius:var(--r);font-weight:700;font-size:13px;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;transition:all .15s}
.load-more button:hover{border-color:var(--red);color:var(--red)}
.load-more svg{width:14px;height:14px}

.pagination{display:flex;justify-content:space-between;align-items:center;padding:20px 0;flex-wrap:wrap;gap:12px}
.pages{display:inline-flex;gap:4px;flex-wrap:wrap}
.pages a,.pages span,.pages button{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--line);border-radius:var(--r-sm);font-weight:700;font-size:13.5px;color:var(--ink);background:#fff;cursor:pointer;transition:all .15s;font-family:inherit}
.pages a:hover,.pages button:hover{background:var(--bg);border-color:var(--ink-300);color:var(--red)}
.pages .current{background:var(--red);color:#fff;border-color:var(--red);cursor:default}
.pages .gap{border:0;background:transparent;color:var(--ink-300);min-width:24px;cursor:default}
.pages .nav-arrow{font-weight:800}
.page-info{font-size:13px;color:var(--ink-500);font-weight:600}
.page-info b{color:var(--ink);font-weight:800}
/* OC pagination markup (<ul.pagination><li>) → makieta look */
.pages > ul.pagination{list-style:none;padding:0;margin:0;display:inline-flex;gap:4px;flex-wrap:wrap}
.pages > ul.pagination > li{list-style:none;margin:0;padding:0;display:contents}
.pages > ul.pagination > li.active > span{background:var(--red);color:#fff;border-color:var(--red);cursor:default}

/* ===== OPIEKUN KATEGORII ===== */
.opiekun-section{padding:24px 0}
.opiekun-section h2{margin:0 0 16px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-500);text-align:center;position:relative}
.opiekun-section h2::before,.opiekun-section h2::after{content:"";display:inline-block;width:60px;height:1px;background:var(--line);vertical-align:middle;margin:0 14px}
.opiekun{display:grid;grid-template-columns:200px 1fr 1.4fr;gap:32px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 32px}
.opiekun .av{width:140px;height:140px;border-radius:50%;overflow:hidden;border:4px solid var(--bg);justify-self:center;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:42px;font-weight:900;letter-spacing:-.02em;box-shadow:0 6px 22px -8px rgba(11,27,51,.3)}
.opiekun .av img{width:100%;height:100%;object-fit:cover}
.opiekun .info span.role{display:block;font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.1em;font-weight:800;margin-bottom:8px}
.opiekun .info b{font-size:24px;font-weight:900;color:var(--ink);letter-spacing:-.015em;line-height:1.1;display:block;margin-bottom:14px}
.opiekun .info .sub{display:flex;flex-direction:column;gap:6px;font-size:13.5px;color:var(--ink-500)}
.opiekun .info .sub b{font-size:13.5px;color:var(--ink);margin:0;font-weight:700}
.opiekun .info a.mailto{color:var(--red);font-weight:700;display:inline-flex;align-items:center;gap:6px}
.opiekun .info a.mailto:hover{text-decoration:underline}
.opiekun .biogram h4{font-size:11px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.1em;margin:0 0 10px;display:inline-block;padding-bottom:6px;border-bottom:2px solid var(--red)}
.opiekun .biogram p{margin:0 0 10px;font-size:13.5px;color:var(--ink-500);line-height:1.65}
.opiekun .biogram p:last-child{margin:0}

/* ===== REGIONAL CONTACT ===== */
.regions-section{padding:8px 0 28px}
.regions-section .head{text-align:center;margin-bottom:16px;font-size:13px;color:var(--ink-500);font-weight:600;letter-spacing:.02em}
.regions{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.region{background:#1F4D9C;color:#fff;border-radius:var(--r);padding:24px 20px 18px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .25s;cursor:pointer;position:relative;overflow:hidden}
.region::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.08), transparent 50%);opacity:0;transition:opacity .3s}
.region:hover{background:#1A4290;transform:translateY(-3px);box-shadow:0 12px 28px -10px rgba(31,77,156,.6)}
.region:hover::before{opacity:1}
.region .number{font-size:32px;font-weight:900;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums;position:relative;z-index:2}
.region .map{padding:8px 0 0;opacity:.85;transition:opacity .25s;position:relative;z-index:2}
.region:hover .map{opacity:1}
.region .map svg{width:140px;height:90px;display:block}
.region .map img{width:140px;height:90px;display:block;object-fit:contain}
.region .map svg path{fill:none;stroke:#fff;stroke-width:1.4;stroke-linejoin:round;stroke-linecap:round}
.region .map svg circle{fill:var(--red);stroke:#fff;stroke-width:1.5}
.region .city{font-size:12px;color:rgba(255,255,255,.85);font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-top:4px;position:relative;z-index:2}
.region .label{font-size:11px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em;position:relative;z-index:2}

/* ===== SEO CONTENT ===== */
.seo-section{padding:8px 0 32px}
.seo-content{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 36px}
.seo-content h2{margin:0 0 14px;font-size:24px;font-weight:900;color:var(--ink);letter-spacing:-.02em;line-height:1.2}
.seo-content h3{margin:24px 0 10px;font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.seo-content h4{margin:18px 0 8px;font-size:14.5px;font-weight:800;color:var(--ink);letter-spacing:-.005em}
.seo-content p{margin:0 0 12px;font-size:14px;color:var(--ink-500);line-height:1.7}
.seo-content ul{margin:0 0 14px;padding-left:20px}
.seo-content li{font-size:13.5px;color:var(--ink-500);line-height:1.7;margin-bottom:4px}
.seo-content li b{color:var(--ink);font-weight:700}
.seo-content .lead{font-size:15px;color:var(--ink-800);font-weight:500;line-height:1.7;border-left:3px solid var(--red);padding-left:16px;margin:0 0 18px}
.seo-content table{width:100%;border-collapse:collapse;margin:14px 0 18px;font-size:13px}
.seo-content table th{background:var(--ink);color:#fff;padding:10px 12px;text-align:left;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.seo-content table td{padding:10px 12px;border-bottom:1px solid var(--line);color:var(--ink-500)}
.seo-content table tr:hover td{background:var(--bg)}
.seo-content table td:first-child{font-weight:700;color:var(--ink)}

/* ===== POPULAR TAGS ===== */
.popular-section{padding:8px 0 32px}
.popular-section h3{margin:0 0 16px;font-size:13px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.1em;display:inline-flex;align-items:center;gap:8px}
.popular-section h3 svg{width:14px;height:14px;color:var(--red)}
.tags-row{display:flex;flex-wrap:wrap;gap:8px}
.tag{display:inline-flex;align-items:center;padding:8px 14px;border:1.5px solid var(--red);border-radius:var(--r-sm);color:var(--red);font-weight:700;font-size:12.5px;background:#fff;transition:all .15s;letter-spacing:-.005em}
.tag:hover{background:var(--red);color:#fff;transform:translateY(-1px)}

/* ===== MARQUEE STRIP ===== */
.marquee{background:var(--red);color:#fff;overflow:hidden;position:relative;padding:20px 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--red),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--red),transparent)}
.marquee-track{display:flex;align-items:center;gap:60px;white-space:nowrap;animation:scroll 32s linear infinite;width:max-content}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:14px;font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.08em;color:#fff}
.marquee-item svg{width:24px;height:24px;flex-shrink:0;color:#fff;opacity:.95}
.marquee-item .dot{width:6px;height:6px;border-radius:50%;background:#fff;opacity:.5}
.marquee-item span.amt{font-weight:700;color:#FFE2E4}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== FOOTER ===== */
footer{background:var(--ink);color:#B4C0D9;padding:64px 0 0;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.5fr;gap:48px;padding-bottom:48px}
.foot h4{color:#fff;font-size:13px;font-weight:800;margin:0 0 18px;text-transform:uppercase;letter-spacing:.1em;position:relative;padding-bottom:10px}
.foot h4::after{content:"";position:absolute;left:0;bottom:0;width:28px;height:2px;background:var(--red)}
.foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot a{color:#B4C0D9;font-size:14px;transition:color .2s}
.foot a:hover{color:#fff}
.foot-about .logo{background:#fff;padding:12px 16px;border-radius:var(--r);display:inline-flex;margin-bottom:4px}
.foot-about .logo img{height:40px;width:auto;display:block}
.foot-about p{font-size:14px;margin:16px 0 20px;line-height:1.6}
.foot-contact{font-size:14px;line-height:1.8}
.foot-contact b{color:#fff}
.foot-branch{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px}
.foot-branch svg{color:var(--red);flex-shrink:0;margin-top:2px}
.newsletter{display:flex;gap:6px;margin-top:10px}
.newsletter input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff;padding:14px 16px;border-radius:var(--r-sm);font-family:inherit;font-size:14px;outline:0;transition:border-color .2s}
.newsletter input:focus{border-color:var(--red)}
.newsletter input::placeholder{color:#7A8AA8}
.newsletter button{background:var(--red);color:#fff;padding:0 20px;border-radius:var(--r-sm);font-weight:700;transition:background .2s}
.newsletter button:hover{background:var(--red-600)}
.consent{font-size:12px;margin-top:12px;display:flex;gap:8px;align-items:flex-start}
.consent input{margin-top:2px}
.socials{display:flex;gap:8px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:all .2s}
.socials a:hover{background:var(--red);transform:translateY(-2px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#7A8AA8;flex-wrap:wrap;gap:12px}
.foot-bottom .pays{display:flex;gap:8px}
.foot-bottom .pays span{background:rgba(255,255,255,.08);padding:6px 12px;border-radius:var(--r-sm);font-size:11px;font-weight:700;color:#fff;letter-spacing:.03em}

/* ===== MOBILE BOTTOM NAV ===== */
.mobile-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:#fff;border-top:1px solid var(--line);box-shadow:0 -4px 12px -4px rgba(11,27,51,.1)}
.mobile-nav .row{display:grid;grid-template-columns:repeat(4,1fr)}
.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 4px 8px;color:var(--ink-500);font-size:11px;font-weight:700;letter-spacing:.02em;transition:color .15s;border-top:2px solid transparent}
.mobile-nav a.active{color:var(--red);border-top-color:var(--red)}
.mobile-nav svg{width:20px;height:20px}

/* Sticky CTA on mobile */
.mobile-help{display:none;background:linear-gradient(90deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);padding:14px 16px;margin:10px 0;align-items:center;justify-content:space-between;gap:10px}
.mobile-help b{font-size:13px;font-weight:800;display:block}
.mobile-help span{font-size:11px;color:#B4C0D9;display:block;margin-top:1px}
.mobile-help a{background:var(--red);color:#fff;padding:8px 14px;font-size:11px;font-weight:800;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}

/* Mobile categories trigger */
.mobile-cats-btn{display:none;width:100%;align-items:center;justify-content:space-between;background:var(--ink);color:#fff;padding:13px 18px;border-radius:var(--r);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 14px}
.mobile-cats-btn svg{width:18px;height:18px}

/* ===== RESPONSIVE ===== */
@media (max-width:1240px){
  .filter-row{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:1024px){
  .cat-page{grid-template-columns:1fr;gap:0;padding:14px 0 24px}
  .side-panel{display:none;position:fixed;top:0;left:0;bottom:0;width:340px;max-width:90vw;z-index:120;background:#fff;overflow-y:auto;padding:18px;box-shadow:0 0 60px rgba(11,27,51,.4);transform:translateX(-100%);transition:transform .25s}
  .side-panel.open{display:block;transform:translateX(0)}
  .mobile-cats-btn{display:flex}
  .opiekun{grid-template-columns:1fr;text-align:center;gap:18px}
  .opiekun .av{justify-self:center}
  .opiekun .info .sub{align-items:center}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .subcat-track{grid-auto-columns:calc((100% - 2*12px) / 3)}
  .subcat-arrow{display:none}
}
@media (max-width:768px){
  .topbar .meta span:not(:first-child){display:none}
  .topbar .lang a:not(:last-child){display:none}
  .header .row{grid-template-columns:auto 1fr auto;gap:12px;padding:12px 0}
  .header .icons .icon-btn:not(:last-child){display:none}
  .icon-btn .badge{top:0;right:0}
  .cart-price{display:none}
  .search select{display:none}
  .search input{font-size:13px}
  .search button span{display:none}
  .nav-right{display:none}
  .nav .has-sub > .link{font-size:12px;padding:8px 10px}
  .breadcrumbs .row{font-size:12px;gap:6px}
  .breadcrumbs span:not(.current),.breadcrumbs a:not(:last-child){display:none}
  .cat-head h1{font-size:22px}
  .cat-head .show-all{font-size:11px}
  .filter-row{grid-template-columns:repeat(2,1fr)}
  .filter-brands{padding:12px 14px;gap:6px 14px}
  .filter-brands label{font-size:12.5px}
  .tools-row{padding:10px 14px;gap:10px}
  .tools-row .lhs,.tools-row .rhs{flex:1;min-width:0}
  .view-toggle{display:none}
  /* Product row stacks to card */
  .product-row{grid-template-columns:80px 1fr;gap:10px;padding:12px;row-gap:10px}
  .product-row .meta{grid-column:2}
  .product-row .stock{grid-column:1 / -1;padding:10px 0;border-top:1px solid var(--line)}
  .product-row .price{grid-column:1 / -1;text-align:left;display:flex;align-items:baseline;gap:8px}
  .product-row .actions{grid-column:1 / -1;justify-content:flex-end}
  .product-row .price b{font-size:20px}
  .seo-content{padding:24px 20px}
  .seo-content h2{font-size:20px}
  .seo-content table{font-size:12px}
  .seo-content table th,.seo-content table td{padding:8px}
  .opiekun{padding:24px 20px}
  .opiekun .info b{font-size:20px}
  .regions{grid-template-columns:1fr;gap:10px}
  .region{padding:18px 20px;flex-direction:row;justify-content:space-between;text-align:left}
  .region .map svg{width:90px;height:60px}
  .region .map img{width:90px;height:60px}
  .pagination{justify-content:center}
  .page-info{order:2;width:100%;text-align:center}
  .pages{justify-content:center}
  .foot-grid{grid-template-columns:1fr;gap:28px;padding-bottom:32px}
  .marquee-item{font-size:13px;gap:10px}
  .marquee-item svg{width:18px;height:18px}
  .mobile-nav{display:block}
  .mobile-help{display:flex}
  body{padding-bottom:62px}
}
@media (max-width:480px){
  .subcat-track{grid-auto-columns:calc((100% - 12px) / 2)}
  .container{padding:0 14px}
  .opiekun-section h2::before,.opiekun-section h2::after{width:30px;margin:0 8px}
}

/* === SYNCED NAV CSS (from index.html) === */
.topbar .row{display:flex;justify-content:space-between;align-items:center;height:40px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:rgba(255,255,255,.08);font-weight:500;border-radius:var(--r-sm)}
.header .row{display:grid;grid-template-columns:220px 1fr auto;gap:32px;align-items:center;padding:18px 24px}
/* ===== NAV ===== */
.nav{background:#fff;border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:58px}
.nav-left,.nav-right{display:flex;align-items:center;gap:4px}
.dept-wrap{position:relative;margin-right:14px}
.dept{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:12px 22px;border-radius:var(--r);font-weight:700;font-size:14px;cursor:pointer}
.dept:hover,.dept-wrap:hover .dept{background:var(--ink-800)}
/* Mega-menu panel */
.dept-panel{position:absolute;top:calc(100% + 6px);left:0;z-index:70;
  display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s, transform .18s, visibility .18s;}
.dept-wrap:hover .dept-panel,
.dept-wrap:focus-within .dept-panel{opacity:1;visibility:visible;transform:translateY(0)}
.dept-col{width:300px;padding:10px;display:flex;flex-direction:column;gap:2px}
.dept-item{display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:600;color:var(--ink-800);text-transform:none;letter-spacing:0;
  transition:background .15s,color .15s;cursor:pointer;}
.dept-item:hover,.dept-item.has-drawer:hover{background:var(--bg);color:var(--red)}
.dept-item .ico{width:24px;height:24px;color:var(--ink-500);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:color .15s}
.dept-item:hover .ico{color:var(--red)}
.dept-item .ico svg{width:100%;height:100%;stroke-width:1.7}
.dept-item .name{flex:1}
.dept-item .chev{width:14px;height:14px;color:var(--ink-300);flex-shrink:0;opacity:0;transition:opacity .15s, transform .15s}
.dept-item.has-drawer .chev{opacity:.6}
.dept-item.has-drawer:hover .chev{opacity:1;color:var(--red);transform:translateX(2px)}
/* Drawer (druga szuflada na prawo) */
.dept-drawer{position:absolute;top:0;left:300px;
  width:760px;min-height:100%;
  background:#fff;border-left:1px solid var(--line);border-radius:0 var(--r-lg) var(--r-lg) 0;
  padding:26px 28px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .15s, visibility .15s;
  z-index:2;}
.dept-item.has-drawer:hover .dept-drawer,
.dept-drawer:hover{opacity:1;visibility:visible;pointer-events:auto}
.dg h4{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--red);display:inline-block}
.dg a{display:block;padding:6px 0;font-size:13.5px;font-weight:500;color:var(--ink-500);text-transform:none;letter-spacing:0;transition:color .15s, padding .15s}
.dg a:hover{color:var(--red);padding-left:4px}
.dg .see-all{margin-top:8px;color:var(--red);font-weight:700;display:inline-flex;align-items:center;gap:4px;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em}
.dept-promo{grid-column:span 3;margin-top:4px;padding:16px 20px;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);display:flex;align-items:center;justify-content:space-between;gap:20px}
.dept-promo b{color:#fff;font-size:14px}
.dept-promo span{color:#B4C0D9;font-size:12.5px;display:block;margin-top:2px}
.dept-promo .pill{background:var(--red);color:#fff;padding:8px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.nav a.link{padding:10px 16px;border-radius:var(--r-sm);font-weight:600;color:var(--ink-800);transition:background .2s,color .2s;font-size:14px;text-transform:uppercase;letter-spacing:.03em}
.nav a.link:hover{background:var(--bg);color:var(--red)}
.nav .sale{color:var(--red)}
.nav .has-sub{position:relative}
.nav .has-sub > .link{display:inline-flex;align-items:center;gap:6px}
.nav .has-sub > .link svg{width:12px;height:12px;transition:transform .2s}
.nav .has-sub:hover > .link svg{transform:rotate(180deg)}
.nav .submenu{position:absolute;top:calc(100% + 4px);left:0;z-index:60;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);min-width:240px;padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s, transform .18s, visibility .18s;}
.nav .has-sub:hover .submenu,
.nav .has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .submenu a{display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:600;color:var(--ink-800);
  text-transform:none;letter-spacing:0;
  transition:background .15s, color .15s;}
.nav .submenu a:hover{background:var(--bg);color:var(--red)}
.nav .submenu a svg{width:14px;height:14px;color:var(--red);flex-shrink:0}
/* === /SYNCED NAV CSS === */
.seo-cities{background:#0e1c33;padding:22px 0;border-top:1px solid rgba(255,255,255,.06)}
.seo-cities .container{display:flex;align-items:center;flex-wrap:wrap;gap:8px 10px}
.seo-cities strong{color:#fff;font-size:14px;font-weight:700;margin-right:18px}
.seo-cities a{display:inline-block;padding:7px 13px;background:#1d4ed8;color:#fff;border-radius:6px;font-size:12.5px;font-weight:600;text-decoration:none;transition:background .15s}
.seo-cities a:hover{background:#2563eb}
/* ===== PRODUCT PAGE — mobile overrides (max-width:767px) ===== */
@media (max-width:767px){
  .breadcrumbs span:not(.current),.breadcrumbs a:not(:last-child):not(.home){display:none}
  .cart-row .add-to-cart{font-size:12px;padding:0 14px}
  .gallery-main{padding:20px}
  .gallery-thumbs{grid-template-columns:repeat(4,1fr)}
  .gallery{position:static}
  .mobile-buy-bar{display:flex}
  .price-box .net-row b{font-size:28px}
  .prod-title{font-size:22px}
  .product-page{grid-template-columns:1fr;gap:18px}
  .rec-grid{grid-template-columns:repeat(2,1fr)}
  .recommended-head h2{font-size:20px}
  .trust-row{grid-template-columns:1fr;gap:6px}
  body{padding-bottom:120px}
}
.advisor .av img{width:100%;height:100%;object-fit:cover}
.advisor .av{width:60px;height:60px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--ink),var(--ink-800));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.advisor .body{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center}
.advisor .info .ln b{color:var(--ink);font-weight:800;font-size:13.5px}
.advisor .info .ln small{color:var(--ink-500);font-weight:600;margin-left:auto;font-size:12px;background:var(--bg);padding:2px 8px;border-radius:var(--r-sm)}
.advisor .info .ln svg{width:14px;height:14px;color:var(--red);flex-shrink:0}
.advisor .info .ln{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.advisor .info a:hover{color:var(--red)}
.advisor .info a{color:var(--ink);font-weight:700}
.advisor .info{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-500);min-width:0}
.advisor .text{font-size:13.5px;color:var(--ink-800);font-weight:700;line-height:1.45;margin-bottom:14px}
.advisor{padding:18px 20px;background:#FAFBFD;border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px}
.breadcrumbs .home svg{width:14px;height:14px;color:var(--ink-500)}
.breadcrumbs .home{display:inline-flex;align-items:center}
.cart-row .add-to-cart svg{width:20px;height:20px}
.cart-row .add-to-cart:hover{background:var(--red-600);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(227,6,19,.55)}
.cart-row .add-to-cart{flex:1;background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 28px;border-radius:var(--r);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.06em;height:54px;transition:all .2s;box-shadow:0 6px 20px -6px rgba(227,6,19,.45)}
.cart-row .qty-pick button:hover{color:var(--red);background:var(--bg)}
.cart-row .qty-pick button{width:46px;height:54px;color:var(--ink-500);font-weight:700;font-size:20px;transition:color .15s, background .15s}
.cart-row .qty-pick input::-webkit-inner-spin-button,.cart-row .qty-pick input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.cart-row .qty-pick input{width:54px;height:54px;border:0;text-align:center;font-weight:800;font-family:inherit;color:var(--ink);font-size:16px;outline:0;background:transparent;font-variant-numeric:tabular-nums}
.cart-row .qty-pick{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r);height:54px;background:#fff}
.cart-row .quick-buy svg{width:22px;height:22px}
.cart-row .quick-buy:hover{background:var(--ink-800)}
.cart-row .quick-buy{width:54px;height:54px;background:var(--ink);color:#fff;border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}
.cart-row{display:flex;gap:10px;align-items:stretch;margin-bottom:14px}
.contact-btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:12px 22px;border-radius:var(--r);font-weight:700;transition:background .2s;font-size:14px;text-transform:uppercase;letter-spacing:.03em}
.dept-item .ico{width:24px;height:24px;color:var(--ink-500);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}
.dl-arrow{margin-left:auto;color:var(--ink-300);width:18px;height:18px}
.dl-icon::before{content:"";position:absolute;top:0;right:0;border:6px solid transparent;border-top-color:rgba(0,0,0,.2);border-right-color:rgba(0,0,0,.2)}
.dl-icon{width:40px;height:48px;background:var(--red);color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;font-weight:800;letter-spacing:.05em;position:relative}
.dl-info b{display:block;font-size:14px;color:var(--ink);font-weight:700;margin-bottom:2px}
.dl-info span{font-size:12px;color:var(--ink-500)}
.dl-item:hover .dl-arrow{color:var(--red)}
.dl-item:hover{border-color:var(--red);background:#fff;transform:translateY(-1px)}
.dl-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);transition:all .15s;cursor:pointer}
.downloads{display:grid;grid-template-columns:1fr;gap:10px;margin:0}
.gallery-action svg{width:18px;height:18px}
.gallery-action:hover{color:var(--red);border-color:var(--red);background:#fff}
.gallery-actions{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:6px;z-index:2}
.gallery-action{width:38px;height:38px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink-500);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.gallery-badge.bestseller{background:var(--ink)}
.gallery-badge.new{background:var(--green)}
.gallery-badge.sale{background:var(--red)}
.gallery-badges{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;gap:6px;z-index:2}
.gallery-badge{padding:6px 12px;border-radius:var(--r-sm);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff}
.gallery-main img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .3s}
.gallery-main:hover img{transform:scale(1.04)}
.gallery-main{background:#fff;border:1px solid var(--line);border-radius:var(--r);aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}
.gallery-thumb img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .2s}
.gallery-thumb.active{border-color:var(--red);box-shadow:0 0 0 1px var(--red) inset}
.gallery-thumb.video::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:var(--red);border-radius:50%;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M8 5v14l11-7z'/></svg>");background-size:14px;background-position:center;background-repeat:no-repeat}
.gallery-thumb.video{position:relative}
.gallery-thumb:hover img{transform:scale(1.06)}
.gallery-thumb:hover{border-color:var(--red)}
.gallery-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}
.gallery-thumb{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:8px;cursor:pointer;transition:all .15s;overflow:hidden}
.gallery{position:sticky;top:80px}
.login-notice a:hover{color:var(--red-600)}
.login-notice a{color:var(--red);font-weight:800;text-decoration:underline}
.login-notice svg{width:20px;height:20px;flex-shrink:0;color:#1F4D9C}
.login-notice{display:flex;align-items:center;gap:12px;background:#EBF1FB;border:1px solid #C8DAF5;border-radius:var(--r);padding:14px 18px;color:#1F4D9C;font-size:13.5px;line-height:1.4;margin-bottom:14px}
.marquee{background:var(--red);color:#fff;overflow:hidden;position:relative;padding:20px 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);margin-top:32px}
.mobile-buy-bar .btn svg{width:18px;height:18px}
.mobile-buy-bar .btn{flex:1;background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px;height:46px;border-radius:var(--r);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em}
.mobile-buy-bar .price-mini b{font-size:18px;font-weight:900;color:var(--ink);letter-spacing:-.015em;display:block;line-height:1}
.mobile-buy-bar .price-mini span{font-size:11px;color:var(--ink-500);font-weight:600}
.mobile-buy-bar{display:none;position:fixed;left:0;right:0;bottom:62px;z-index:55;background:#fff;border-top:1px solid var(--line);padding:10px 14px;gap:10px;align-items:center;box-shadow:0 -8px 20px -8px rgba(11,27,51,.15)}
.opiekun .av{width:120px;height:120px;border-radius:50%;overflow:hidden;border:4px solid var(--bg);justify-self:center;background:linear-gradient(135deg,var(--ink),var(--ink-800));display:flex;align-items:center;justify-content:center;color:#fff;font-size:36px;font-weight:900;box-shadow:0 6px 22px -8px rgba(11,27,51,.3)}
.opiekun .biogram p{margin:0 0 8px;font-size:13.5px;color:var(--ink-500);line-height:1.6}
.opiekun .info .sub b{font-size:13px;color:var(--ink);margin:0;font-weight:700}
.opiekun .info .sub{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--ink-500)}
.opiekun .info b{font-size:22px;font-weight:900;color:var(--ink);letter-spacing:-.015em;line-height:1.1;display:block;margin-bottom:12px}
.opiekun .info span.role{display:block;font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.1em;font-weight:800;margin-bottom:6px}
.opiekun{display:grid;grid-template-columns:160px 1fr 1.4fr;gap:28px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 28px}
.price-box .extras .save{color:var(--red);font-weight:800}
.price-box .extras b{color:var(--ink);font-weight:800}
.price-box .extras{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line);font-size:12.5px;color:var(--ink-500)}
.price-box .gross-row b{color:var(--ink);font-weight:700}
.price-box .gross-row{font-size:13.5px;color:var(--ink-500);margin-top:6px;font-variant-numeric:tabular-nums}
.price-box .net-row .ccy{font-size:18px;font-weight:800;color:var(--ink-500);margin-right:2px}
.price-box .net-row .net{font-size:13px;color:var(--ink-500);font-weight:600}
.price-box .net-row b{font-size:36px;font-weight:900;color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}
.price-box .net-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.price-box::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red)}
.price-box{background:linear-gradient(135deg,var(--bg) 0%,#fff 100%);border:1px solid var(--line);border-radius:var(--r);padding:18px 22px;margin-bottom:14px;position:relative}
.prod-brand .info span{font-size:12.5px;color:var(--ink-500)}
.prod-brand .info{display:flex;flex-direction:column;gap:4px}
.prod-brand .label{font-size:11px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.prod-brand .logo-box img{max-width:100%;max-height:100%;object-fit:contain}
.prod-brand .logo-box{width:90px;height:54px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;padding:8px;flex-shrink:0}
.prod-brand b{font-size:15px;color:var(--ink);font-weight:800}
.prod-brand{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:16px}
.prod-code-row .copy:hover{color:var(--red)}
.prod-code-row .copy{color:var(--ink-300);cursor:pointer;transition:color .15s}
.prod-code-row b{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.005em}
.prod-code-row span{display:inline-flex;align-items:center;gap:6px}
.prod-code-row svg{width:13px;height:13px}
.prod-code-row{display:flex;gap:18px;font-size:13px;color:var(--ink-500);margin-bottom:16px;flex-wrap:wrap}
.prod-info .prod-meta-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.prod-meta-top .cat-tag svg{width:12px;height:12px}
.prod-meta-top .cat-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.prod-meta-top .rating .stars svg{width:14px;height:14px;color:#FBBC04;fill:#FBBC04}
.prod-meta-top .rating .stars{display:inline-flex;gap:1px}
.prod-meta-top .rating a{color:var(--ink-500);text-decoration:underline}
.prod-meta-top .rating{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;color:var(--ink-500);font-weight:600}
.prod-stock .label{font-size:12px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.prod-stock .lead b{color:var(--ink);font-weight:800}
.prod-stock .lead{font-size:12.5px;color:var(--ink-500);font-weight:600}
.prod-stock .stock-pill b{color:var(--green);font-weight:900;font-variant-numeric:tabular-nums;font-size:15px}
.prod-stock .stock-pill::before{content:"";width:8px;height:8px;background:var(--green);border-radius:50%;display:inline-block;box-shadow:0 0 0 3px rgba(31,169,104,.18)}
.prod-stock .stock-pill{display:inline-flex;align-items:center;gap:8px;color:var(--green);font-weight:800;font-size:14px}
.prod-stock{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:6px 0 14px;border-bottom:1px solid var(--line);margin-bottom:16px}
.prod-title{font-size:28px;line-height:1.15;font-weight:900;letter-spacing:-.02em;margin:0 0 16px;color:var(--ink)}
.product-page{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:36px;align-items:start}
.product-wrap{padding:24px 24px 32px}
.qs b{color:var(--red);font-weight:800;font-size:12.5px;font-variant-numeric:tabular-nums}
.qs{display:inline-flex;align-items:center;gap:6px;font-size:12px;background:var(--bg);color:var(--ink-800);font-weight:700;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--line)}
.quick-specs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.rec-action svg{width:14px;height:14px}
.rec-action:hover{color:var(--red);border-color:var(--red)}
.rec-actions{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:4px;opacity:0;transition:opacity .2s}
.rec-action{width:32px;height:32px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink-500);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.rec-badge.new{background:var(--green)}
.rec-badge{position:absolute;top:10px;left:10px;background:var(--red);color:#fff;padding:4px 9px;font-size:10px;font-weight:800;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em}
.rec-buy svg{width:18px;height:18px}
.rec-buy:hover{background:var(--red-600);transform:translateY(-1px)}
.rec-buy{width:42px;height:42px;background:var(--red);color:#fff;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.rec-card:hover .rec-actions{opacity:1}
.rec-card:hover .rec-photo img{transform:scale(1.07)}
.rec-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.rec-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:all .2s;position:relative}
.rec-foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:8px;background:#FAFBFD}
.rec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rec-info .brand-tag::before{content:"";width:6px;height:6px;background:var(--red);border-radius:50%}
.rec-info .brand-tag{display:inline-flex;align-items:center;gap:6px;font-size:10px;color:var(--ink-500);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.rec-info .code{font-size:13.5px;font-weight:800;color:var(--ink);letter-spacing:-.005em;font-variant-numeric:tabular-nums}
.rec-info .name{font-size:12.5px;color:var(--ink-500);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.rec-info .stock-mini.out::before{background:#E2A100}
.rec-info .stock-mini.out{color:#E2A100}
.rec-info .stock-mini::before{content:"";width:6px;height:6px;background:var(--green);border-radius:50%}
.rec-info .stock-mini{font-size:11px;color:var(--green);font-weight:700;display:inline-flex;align-items:center;gap:5px}
.rec-info{padding:14px 16px 12px;display:flex;flex-direction:column;gap:6px;flex:1}
.rec-photo img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .35s}
.rec-photo{aspect-ratio:1;background:#fff;padding:18px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.rec-price .ccy{font-size:11px;color:var(--ink-500);font-weight:700;margin-left:2px}
.rec-price .gross{display:block;font-size:11px;color:var(--ink-500);font-weight:600;margin-top:1px;font-variant-numeric:tabular-nums}
.rec-price b{font-size:17px;font-weight:900;color:var(--ink);letter-spacing:-.015em;font-variant-numeric:tabular-nums}
.recommended-head .all svg{width:14px;height:14px}
.recommended-head .all:hover{color:var(--red)}
.recommended-head .all{color:var(--ink-500);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:6px;transition:color .15s}
.recommended-head .eyebrow{display:block;font-size:12px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.12em}
.recommended-head .ttl{display:flex;flex-direction:column;gap:4px}
.recommended-head h2{margin:0;font-size:24px;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.recommended-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:20px;flex-wrap:wrap}
.recommended{padding:36px 0 8px}
.sec-actions a:hover{color:var(--red)}
.sec-actions a{display:inline-flex;align-items:center;gap:7px;color:var(--ink-500);font-size:13px;font-weight:700;transition:color .15s}
.sec-actions svg{width:16px;height:16px}
.sec-actions{display:flex;gap:24px;padding:12px 0;border-bottom:1px solid var(--line);margin-bottom:16px}
.share-row .sb svg{width:14px;height:14px}
.share-row .sb:hover{background:var(--red);color:#fff}
.share-row .sb{width:32px;height:32px;border-radius:50%;background:var(--bg);color:var(--ink-500);display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.share-row .share-buttons{display:flex;gap:6px}
.share-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding:12px 16px;background:#fff;border:1px solid var(--line);border-radius:var(--r);font-size:12.5px;color:var(--ink-500);font-weight:600}
.spec-table td:first-child{font-weight:700;color:var(--ink-800);background:var(--bg);width:40%}
.spec-table td:last-child b{color:var(--red);font-weight:800}
.spec-table td:last-child{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.spec-table td{padding:11px 16px}
.spec-table tr:last-child{border-bottom:0}
.spec-table tr{border-bottom:1px solid var(--line)}
.spec-table{width:100%;border-collapse:collapse;margin:8px 0 14px;font-size:13.5px}
/* ===== TABS (mobile-first) ===== */
.tabs-section{margin:24px 0 0}
.tabs-bar{display:flex;gap:0;background:#fff;border-radius:var(--r) var(--r) 0 0;border:1px solid var(--line);border-bottom:0;overflow-x:auto;scrollbar-width:none}
.tabs-bar::-webkit-scrollbar{display:none}
.tab{padding:12px 14px;font-size:11px;font-weight:800;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;border-bottom:3px solid transparent;transition:all .15s;white-space:nowrap;background:none;display:inline-flex;align-items:center;gap:5px}
.tab svg{width:13px;height:13px}
.tab .cnt{font-size:10px;background:var(--bg);color:var(--ink-500);padding:2px 5px;border-radius:var(--r-sm);font-weight:700;letter-spacing:0;text-transform:none}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--ink);border-bottom-color:var(--red);background:var(--bg)}
.tab.active .cnt{background:var(--red);color:#fff}
.tab-panel{background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 var(--r) var(--r);padding:20px 16px;display:none}
.tab-panel.active{display:block}
.tab-panel h2{margin:0 0 12px;font-size:20px;font-weight:900;color:var(--ink);letter-spacing:-.015em}
.tab-panel h3:first-child{margin-top:0}
.tab-panel h3{margin:20px 0 8px;font-size:15px;font-weight:800;color:var(--ink)}
.tab-panel h4{margin:14px 0 6px;font-size:13.5px;font-weight:800;color:var(--ink-800)}
.tab-panel p{margin:0 0 12px;font-size:13.5px;color:var(--ink-500);line-height:1.7}
.tab-panel ul{margin:0 0 14px;padding-left:18px}
.tab-panel li{font-size:13px;color:var(--ink-500);line-height:1.7;margin-bottom:5px}
.tab-panel li b{color:var(--ink);font-weight:700}
.tab-panel .lead{font-size:14px;color:var(--ink-800);font-weight:500;line-height:1.7;border-left:3px solid var(--red);padding-left:14px;margin:0 0 16px}
@media (min-width:768px){
  .tabs-section{margin:32px 0 0}
  .tab{padding:18px 24px;font-size:13px;gap:8px}
  .tab svg{width:14px;height:14px}
  .tab .cnt{font-size:11px;padding:2px 8px}
  .tab-panel{padding:32px 40px}
  .tab-panel h2{font-size:22px}
  .tab-panel h3{margin:24px 0 10px;font-size:16px}
  .downloads{grid-template-columns:repeat(2,1fr)}
}
.trust b{color:var(--ink);font-weight:800;display:block;font-size:12.5px}
.trust svg{width:22px;height:22px;color:var(--red);flex-shrink:0}
.trust-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 0}
.trust{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);font-size:12px;color:var(--ink-500);font-weight:600;line-height:1.3}
/* ===== MARQUEE ===== */
/* ===== OPIEKUN (compact dla product page) ===== */
/* ===== PRODUCT INFO ===== */
/* ===== PRODUCT PAGE ===== */
/* ===== RECOMMENDED PRODUCTS ===== */
/* ===== TABS ===== */
/* ===== TOPBAR ===== */
/* Advisor box */
/* Brand row */
/* Cart row */
/* GALLERY */
/* Login notice */
/* Mobile sticky add-to-cart */
/* Price box */
/* Quick specs */
/* SHARING ROW */
/* Secondary actions */
/* Stock row */
/* Trust row */
/* downloads */
/* spec table */
footer{background:var(--ink);color:#B4C0D9;padding:64px 0 0}
/* ===== CHECKOUT / CART PAGE ===== */
.checkout-wrap{padding:24px 24px 32px}
.checkout-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:20px}
.checkout-head h1{margin:0;font-size:30px;line-height:1.1;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.checkout-head .meta{font-size:13px;color:var(--ink-500);margin-top:4px}
.checkout-head .meta b{color:var(--ink);font-weight:700}
.steps-progress{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.06em;flex-wrap:wrap}
.steps-progress .stp{display:inline-flex;align-items:center;gap:6px}
.steps-progress .stp .num{width:22px;height:22px;border-radius:50%;background:var(--bg);border:1.5px solid var(--ink-300);color:var(--ink-500);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.steps-progress .stp.done .num{background:var(--green);border-color:var(--green);color:#fff}
.steps-progress .stp.done{color:var(--ink-800)}
.steps-progress .stp.active .num{background:var(--red);border-color:var(--red);color:#fff}
.steps-progress .stp.active{color:var(--red)}
.steps-progress .sep{width:24px;height:1.5px;background:var(--ink-300)}
.steps-progress .stp.done + .sep{background:var(--green)}
.checkout-page{display:grid;grid-template-columns:minmax(0,1fr) 400px;gap:24px;align-items:start}
.sec-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:14px}
.sec-head{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--line);background:#FAFBFD}
.sec-head .num{width:32px;height:32px;border-radius:50%;background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;flex-shrink:0}
.sec-head h2{margin:0;font-size:16px;font-weight:800;color:var(--ink);letter-spacing:-.005em}
.sec-head .ico{margin-left:auto;color:var(--ink-300)}
.sec-head .ico svg{width:20px;height:20px}
.sec-head .badge-ok{margin-left:auto;display:inline-flex;align-items:center;gap:6px;color:var(--green);font-size:12px;font-weight:800}
.sec-head .badge-ok svg{width:14px;height:14px}
.sec-body{padding:22px}
.acc-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:18px}
.acc-tab{padding:14px 16px;border:2px solid var(--line);border-radius:var(--r);background:#fff;text-align:center;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:6px}
.acc-tab:hover{border-color:var(--ink-300)}
.acc-tab.active{border-color:var(--red);background:var(--red-50);color:var(--red)}
.acc-tab svg{width:22px;height:22px;color:var(--ink-500);transition:color .15s}
.acc-tab.active svg{color:var(--red)}
.acc-tab b{font-size:13px;font-weight:800;letter-spacing:-.005em}
.acc-tab span{font-size:11px;color:var(--ink-500);font-weight:600;display:block;margin-top:2px}
.acc-tab.active span{color:var(--red);opacity:.75}
.login-mini{background:var(--bg);border-radius:var(--r-sm);padding:16px;display:none;align-items:center;gap:14px;flex-wrap:wrap}
.login-mini.show{display:flex}
.login-mini b{font-size:14px;color:var(--ink);font-weight:800}
.login-mini span{font-size:13px;color:var(--ink-500);flex:1;min-width:160px}
.login-mini a{background:var(--ink);color:#fff;padding:10px 18px;border-radius:var(--r-sm);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.05em;transition:background .2s}
.login-mini a:hover{background:var(--red)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
.form-row.split{grid-template-columns:1fr 2fr}
.form-row:last-child{margin-bottom:0}
.form-field{display:flex;flex-direction:column;gap:6px;position:relative}
.form-field.full{grid-column:1/-1}
.form-field label{font-size:12.5px;font-weight:700;color:var(--ink-800);letter-spacing:-.005em}
.form-field label .req{color:var(--red);margin-left:2px}
.form-field input,.form-field select,.form-field textarea{width:100%;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:12px 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;outline:0;transition:border-color .15s,box-shadow .15s;}
.form-field input:hover,.form-field select:hover,.form-field textarea:hover{border-color:var(--ink-300)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
.form-field.has-value input{border-color:var(--green);padding-right:36px}
.form-field.has-value::after{content:"";position:absolute;right:12px;top:36px;width:18px;height:18px;background:var(--green);border-radius:50%;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:11px;background-position:center;background-repeat:no-repeat}
.form-field .hint{font-size:11px;color:var(--ink-500)}
.form-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238A97AD' stroke-width='2.5' stroke-linecap='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:36px}
.form-field textarea{resize:vertical;min-height:90px;font-family:inherit}
.expander{margin-top:12px;border-top:1px dashed var(--line);padding-top:14px}
.expander label{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-800);font-weight:600;cursor:pointer}
.expander input[type=checkbox]{accent-color:var(--red);width:16px;height:16px;cursor:pointer}
.expander .body{display:none;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.expander.open .body{display:block}
.checkbox-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--ink-800);margin-top:14px;cursor:pointer;line-height:1.5}
.checkbox-row input[type=checkbox]{accent-color:var(--red);width:16px;height:16px;cursor:pointer;margin-top:2px;flex-shrink:0}
.checkbox-row b{font-weight:700;color:var(--ink)}
.checkbox-row a{color:var(--red);text-decoration:underline;font-weight:700}
.radio-list{display:flex;flex-direction:column;gap:8px}
.radio-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:14px 18px;border:2px solid var(--line);border-radius:var(--r);background:#fff;cursor:pointer;transition:all .15s;position:relative;}
.radio-card:hover{border-color:var(--ink-300)}
.radio-card.checked{border-color:var(--red);background:linear-gradient(135deg,#FFF8F8 0%,#fff 50%)}
.radio-card .radio-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--ink-300);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:border-color .15s;}
.radio-card.checked .radio-dot{border-color:var(--red)}
.radio-card.checked .radio-dot::after{content:"";width:10px;height:10px;background:var(--red);border-radius:50%}
.radio-card .body{display:flex;flex-direction:column;gap:4px;min-width:0}
.radio-card .body-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.radio-card .ic{width:42px;height:42px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;font-weight:900;color:var(--ink);letter-spacing:.02em;padding:4px}
.radio-card .ic.dhl{background:#FFCC00;color:#D40511}
.radio-card .ic.ups{background:#351C15;color:#FFB500}
.radio-card .ic.inpost{background:#FFCC00;color:#000}
.radio-card .ic.poczta{background:#D40511;color:#FFCC00}
.radio-card .ic.virsal{background:var(--ink);color:#fff}
.radio-card .ic.blik{background:#000;color:#fff;font-size:10px}
.radio-card .ic.card{background:#fff;color:var(--ink);border-color:var(--line);padding:0}
.radio-card .ic.card svg{width:24px;height:24px;color:var(--ink-500)}
.radio-card .ic.payu{background:#A6C307;color:#fff}
.radio-card .ic.cod{background:#fff;color:var(--ink);padding:6px}
.radio-card .ic.cod svg{width:22px;height:22px;color:var(--ink-500)}
.radio-card .name{font-size:14px;font-weight:800;color:var(--ink);letter-spacing:-.005em}
.radio-card .desc{font-size:12.5px;color:var(--ink-500);font-weight:500}
.radio-card .badge-eta{display:inline-flex;align-items:center;gap:5px;background:var(--green-50);color:var(--green);font-size:11px;font-weight:800;padding:3px 8px;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.04em}
.radio-card .badge-eta svg{width:11px;height:11px}
.radio-card .badge-promo{background:var(--red);color:#fff;padding:3px 8px;border-radius:var(--r-sm);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.radio-card .price{text-align:right;font-size:16px;font-weight:900;color:var(--ink);letter-spacing:-.015em;font-variant-numeric:tabular-nums;flex-shrink:0}
.radio-card .price.free{color:var(--green)}
.radio-card .price small{display:block;font-size:11px;color:var(--ink-500);font-weight:600;margin-top:2px;text-transform:uppercase;letter-spacing:.04em}
.radio-card .extra-content{grid-column:1/-1;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line);display:none}
.radio-card.checked .extra-content{display:block}
.radio-card .extra-content .picker-info{display:flex;align-items:center;gap:10px;background:var(--bg);border-radius:var(--r-sm);padding:10px 14px;font-size:12.5px;color:var(--ink-800)}
.radio-card .extra-content .picker-info b{color:var(--ink);font-weight:800}
.radio-card .extra-content .picker-info a{margin-left:auto;color:var(--red);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.radio-card .logos{display:flex;gap:4px;align-items:center}
.radio-card .lo{height:18px;padding:2px 7px;background:#fff;border:1px solid var(--line);border-radius:2px;font-size:9px;font-weight:900;color:var(--ink);display:inline-flex;align-items:center;letter-spacing:.04em}
.radio-card .lo.visa{background:#1A1F71;color:#fff}
.radio-card .lo.mc{background:#fff;color:#EB001B}
.radio-card .lo.maestro{background:#0099DF;color:#fff}

/* ===== B2B NIP / GUS block (data section) ===== */
.b2b-note{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;margin-bottom:16px;background:var(--red-50);border:1px solid #F5C6CB;border-radius:var(--r);font-size:12.5px;color:var(--ink-800);font-weight:600;line-height:1.45}
.b2b-note svg{width:18px;height:18px;color:var(--red);flex-shrink:0;margin-top:1px}
.nip-group{display:flex;gap:8px;align-items:stretch}
.nip-group input{flex:1;min-width:0}
.nip-group button{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;background:var(--ink);color:#fff;border-radius:var(--r-sm);font-weight:700;font-size:12.5px;white-space:nowrap;transition:background .2s;cursor:pointer;font-family:inherit;min-width:48px}
.nip-group button:hover{background:var(--red)}
.nip-group button:disabled{opacity:.6;cursor:default}
.nip-msg{margin-top:8px;padding:9px 12px;border-radius:var(--r-sm);font-size:12px;font-weight:600;line-height:1.45}
.nip-msg.ok{background:var(--green-50);color:#137a4d;border:1px solid #B6E2C6}
.nip-msg.ok strong{color:var(--ink);font-weight:800}
.nip-msg.warn{background:#FEF3C7;color:#92400E;border:1px solid #FDE2A4}
.nip-msg.err{background:#FFE8EB;color:#7A0613;border:1px solid #F5A5AC}
/* inline form validation (one-page checkout) */
.form-field.has-error input,.form-field.has-error select{border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
.form-field .field-err{font-size:11px;color:var(--red);font-weight:700;margin-top:2px}
.order-error{background:#FFE8EB;color:#7A0613;border:1px solid #F5A5AC;border-radius:var(--r-sm);padding:10px 12px;font-size:12.5px;font-weight:700;line-height:1.4}
.cta-btn:disabled{opacity:.7;cursor:default;transform:none}
.mobile-checkout-bar .btn:disabled{opacity:.7;cursor:default}

/* ===== WIDE CART (left column, top) ===== */
.cart-wide{padding:0}
.cart-wide-head{display:grid;grid-template-columns:60px minmax(0,1fr) 104px 102px 118px 26px;gap:12px;align-items:center;padding:11px 22px;background:#FAFBFD;border-bottom:1px solid var(--line);font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-500)}
.cart-wide-head .ce{text-align:center}
.cart-wide-head .re{text-align:right}
.cart-wrow{display:grid;grid-template-columns:60px minmax(0,1fr) 104px 102px 118px 26px;gap:12px;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line);position:relative;transition:background .15s}
.cart-wrow:last-child{border-bottom:0}
.cart-wrow:hover{background:#FAFBFD}
.cart-wrow .img{width:60px;height:60px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:6px;display:flex;align-items:center;justify-content:center}
.cart-wrow .img img{max-width:100%;max-height:100%;object-fit:contain}
.cart-wrow .info{min-width:0}
.cart-wrow .sku-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cart-wrow .brand-tag{font-size:10px;background:var(--ink);color:#fff;padding:2px 7px;border-radius:var(--r-sm);font-weight:800;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}
.cart-wrow .sku{font-size:17px;font-weight:900;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:.01em;line-height:1.1;word-break:break-all;user-select:all}
.cart-wrow .sku a{color:inherit}
.cart-wrow .copy{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink-300);background:#fff;transition:all .15s;flex-shrink:0;cursor:pointer;padding:0;font-family:inherit}
.cart-wrow .copy:hover{color:var(--red);border-color:var(--red)}
.cart-wrow .copy.done{color:var(--green);border-color:var(--green)}
.cart-wrow .copy svg{width:13px;height:13px}
.cart-wrow .name{font-size:13px;color:var(--ink-500);line-height:1.4;margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cart-wrow .name a{color:inherit}
.cart-wrow .opts{font-size:11px;color:var(--ink-500);margin-top:5px;line-height:1.4}
.cart-wrow .opts b{color:var(--ink-800);font-weight:700}
.cart-wrow .tags{display:flex;gap:12px;flex-wrap:wrap;margin-top:7px}
.cart-wrow .tag-av{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;color:var(--green)}
.cart-wrow .tag-av svg{width:12px;height:12px}
.cart-wrow .tag-mu{font-size:11px;color:var(--ink-500);font-weight:600}
.cart-wrow .qty-wrap{display:flex;justify-content:center}
.cart-wrow .qty-mini{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:var(--r-sm);height:38px;background:#fff}
.cart-wrow .qty-mini button{width:34px;height:36px;color:var(--ink-500);font-weight:700;font-size:16px;transition:color .15s;cursor:pointer;padding:0;font-family:inherit;background:none;border:0}
.cart-wrow .qty-mini button:hover{color:var(--red)}
.cart-wrow .qty-mini input{width:40px;height:36px;border:0;text-align:center;font-weight:800;font-family:inherit;color:var(--ink);font-size:14px;outline:0;background:transparent;font-variant-numeric:tabular-nums}
.cart-wrow .qty-mini input::-webkit-inner-spin-button,.cart-wrow .qty-mini input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.cart-wrow .unit{text-align:right}
.cart-wrow .unit small{display:block;font-size:9.5px;color:var(--ink-300);font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.cart-wrow .unit b{display:block;font-size:14px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;line-height:1.15}
.cart-wrow .unit span{font-size:11px;color:var(--ink-500);font-weight:600;font-variant-numeric:tabular-nums}
.cart-wrow .sum{text-align:right}
.cart-wrow .sum b{display:block;font-size:16px;font-weight:900;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1.15}
.cart-wrow .sum span{font-size:11px;color:var(--ink-500);font-weight:600;font-variant-numeric:tabular-nums}
.cart-wrow .remove{justify-self:center;width:28px;height:28px;color:var(--ink-300);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);transition:all .15s;cursor:pointer;padding:0;font-family:inherit}
.cart-wrow .remove:hover{color:var(--red);border-color:var(--red)}
.cart-wrow .remove svg{width:13px;height:13px}
.cart-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;background:#FAFBFD;border-top:1px solid var(--line);flex-wrap:wrap}
.cart-foot a{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--ink-500);transition:color .15s}
.cart-foot a:hover{color:var(--red)}
.cart-foot a svg{width:15px;height:15px}
.cart-foot .sub{font-size:13px;color:var(--ink-500)}
.cart-foot .sub b{font-size:17px;color:var(--ink);font-weight:900;font-variant-numeric:tabular-nums;margin-left:6px}

.order-sidebar{position:sticky;top:80px}
.order-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.order-card .head{padding:16px 20px;border-bottom:1px solid var(--line);background:#FAFBFD;display:flex;align-items:center;justify-content:space-between}
.order-card .head h3{margin:0;font-size:14px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:10px}
.order-card .head h3 svg{width:18px;height:18px;color:var(--red)}
.order-card .head .cnt{font-size:11px;color:var(--ink-500);font-weight:700;background:var(--bg);padding:3px 9px;border-radius:var(--r-sm)}
.order-card .head .cnt b{color:var(--ink);font-weight:800}
.cart-list{max-height:340px;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.cart-list::-webkit-scrollbar{width:6px}
.cart-list::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.cart-item{display:grid;grid-template-columns:60px 1fr auto;gap:12px;padding:12px 20px;align-items:center;border-bottom:1px solid var(--line);position:relative;transition:background .15s}
.cart-item:last-child{border-bottom:0}
.cart-item:hover{background:#FAFBFD}
.cart-item .img{aspect-ratio:1;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:4px;display:flex;align-items:center;justify-content:center}
.cart-item .img img{max-width:100%;max-height:100%;object-fit:contain}
.cart-item .body .code{font-size:12px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:6px}
.cart-item .body .brand-tag{font-size:9px;background:var(--ink);color:#fff;padding:1px 5px;border-radius:var(--r-sm);font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.cart-item .body .name{font-size:11.5px;color:var(--ink-500);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:2px 0}
.cart-item .body .qty-mini{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-sm);height:26px;background:#fff;margin-top:4px}
.cart-item .body .qty-mini button{width:22px;height:24px;color:var(--ink-500);font-weight:700;font-size:12px}
.cart-item .body .qty-mini input{width:30px;height:24px;border:0;text-align:center;font-weight:700;font-family:inherit;color:var(--ink);font-size:12px;outline:0;background:transparent}
.cart-item .body .qty-mini input::-webkit-inner-spin-button,.cart-item .body .qty-mini input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.cart-item .price{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.cart-item .price b{font-size:13px;font-weight:900;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1.1}
.cart-item .price .gross{font-size:10.5px;color:var(--ink-500);font-weight:600;font-variant-numeric:tabular-nums}
.cart-item .remove{position:absolute;top:8px;right:10px;width:22px;height:22px;color:var(--ink-300);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;opacity:0;transition:all .15s;background:#fff;border:1px solid var(--line);padding:0;cursor:pointer;font-family:inherit}
.cart-item:hover .remove{opacity:1}
.cart-item .remove:hover{color:var(--red);border-color:var(--red)}
.cart-item .remove svg{width:11px;height:11px}
.promo-applied{padding:10px 20px;background:var(--green-50);border-bottom:1px solid var(--line);font-size:12.5px;color:var(--green);font-weight:700;display:flex;align-items:center;gap:8px}
.promo-applied svg{width:14px;height:14px}
.promo-applied b{color:var(--ink);font-weight:800}
.promo-applied .rm{margin-left:auto;color:var(--ink-500);cursor:pointer;font-weight:600}
.promo-applied .rm:hover{color:var(--red)}
.promo-row{padding:14px 20px;border-bottom:1px solid var(--line);display:flex;gap:6px;background:#FAFBFD}
.promo-row input{flex:1;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:9px 12px;font-family:inherit;font-size:13px;color:var(--ink);background:#fff;outline:0;text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.promo-row input:focus{border-color:var(--red);box-shadow:0 0 0 2px var(--red-50)}
.promo-row input::placeholder{font-weight:500;letter-spacing:0;text-transform:none}
.promo-row button{background:var(--ink);color:#fff;padding:0 18px;border-radius:var(--r-sm);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.05em;transition:background .2s}
.promo-row button:hover{background:var(--red)}
.summary{padding:16px 20px;display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--ink-500)}
.summary .row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.summary .row b{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums}
.summary .row.discount{color:var(--green)}
.summary .row.discount b{color:var(--green);font-weight:800}
.summary .sep{height:1px;background:var(--line);margin:4px 0}
.summary .total{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0 6px;border-top:2px solid var(--ink);margin-top:6px}
.summary .total .lbl{font-size:14px;color:var(--ink);font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.summary .total b{font-size:26px;font-weight:900;color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.summary .total b .ccy{font-size:14px;font-weight:700;color:var(--ink-500);margin-left:4px}
.summary .vat-info{font-size:11px;color:var(--ink-500);text-align:right}
.order-cta{padding:16px 20px;display:flex;flex-direction:column;gap:10px;background:#FAFBFD;border-top:1px solid var(--line)}
.cta-btn{background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 22px;border-radius:var(--r);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.05em;height:54px;width:100%;transition:all .2s;box-shadow:0 6px 20px -6px rgba(227,6,19,.45);}
.cta-btn:hover{background:var(--red-600);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(227,6,19,.55)}
.cta-btn svg{width:18px;height:18px}
.cta-btn .total-mini{font-size:13px;font-weight:800;letter-spacing:0;text-transform:none;margin-left:auto;font-variant-numeric:tabular-nums}
.cta-consent{font-size:12px;color:var(--ink-500);line-height:1.55;display:flex;align-items:flex-start;gap:8px}
.cta-consent input{accent-color:var(--red);width:16px;height:16px;cursor:pointer;margin-top:2px;flex-shrink:0}
.cta-consent a{color:var(--ink);font-weight:600;text-decoration:underline;text-decoration-color:var(--ink-300);text-underline-offset:2px;transition:color .15s,text-decoration-color .15s}
.cta-consent a:hover{color:var(--red);text-decoration-color:var(--red)}
.cta-consent .ct-text{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.cta-consent .ct-sub{font-size:11px;color:var(--ink-300);line-height:1.4;font-weight:500}
/* Koszyk (order-sidebar): trust-row z .secure/.pay — zawężone, by NIE nadpisywać 3-kolumnowego trust-row na stronie produktu (kolizja nazw klas) */
.order-sidebar .trust-row{padding:14px 20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.trust-row .secure{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--green);font-weight:800}
.trust-row .secure svg{width:14px;height:14px}
.trust-row .pay-icons{display:flex;gap:4px;flex-wrap:wrap}
.trust-row .pay{height:22px;padding:2px 8px;background:#fff;border:1px solid var(--line);border-radius:2px;font-size:9.5px;font-weight:900;color:var(--ink);display:inline-flex;align-items:center;letter-spacing:.04em}
.trust-row .pay.visa{background:#1A1F71;color:#fff}
.trust-row .pay.mc{background:#fff;color:#EB001B}
.trust-row .pay.blik{background:#000;color:#fff}
.trust-row .pay.payu{background:#A6C307;color:#fff}
.trust-row .pay.applepay{background:#000;color:#fff}
.trust-row .pay.gpay{background:#fff;color:#5F6368}
.side-help-mini{margin-top:14px;padding:18px 20px;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);display:flex;flex-direction:column;gap:8px}
.side-help-mini b{font-size:14px;font-weight:800}
.side-help-mini p{margin:0;font-size:12.5px;color:#B4C0D9;line-height:1.45}
.side-help-mini .row-h{display:flex;gap:10px;margin-top:6px}
.side-help-mini a{flex:1;background:rgba(255,255,255,.08);color:#fff;padding:10px 12px;font-size:11.5px;font-weight:800;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em;text-align:center;transition:background .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.side-help-mini a:hover{background:var(--red)}
.side-help-mini a svg{width:13px;height:13px}
.mobile-checkout-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:#fff;border-top:1px solid var(--line);box-shadow:0 -8px 20px -8px rgba(11,27,51,.15);padding:12px 14px;gap:12px;align-items:center}
.mobile-checkout-bar .total{flex:1;min-width:0}
.mobile-checkout-bar .total b{font-size:20px;font-weight:900;color:var(--ink);letter-spacing:-.015em;display:block;line-height:1}
.mobile-checkout-bar .total span{font-size:11px;color:var(--ink-500);font-weight:600;display:block;margin-top:2px}
.mobile-checkout-bar .btn{flex:1;background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px;height:50px;border-radius:var(--r);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.mobile-checkout-bar .btn svg{width:18px;height:18px}
@media (max-width:1240px){
  .checkout-page{grid-template-columns:minmax(0,1fr) 360px;gap:18px}
  .form-row.three{grid-template-columns:1fr 1fr}
}
@media (max-width:1024px){
  .checkout-page{grid-template-columns:1fr;gap:16px}
  .order-sidebar{position:static}
  .checkout-head{margin-bottom:14px}
}
@media (max-width:768px){
  .checkout-head h1{font-size:22px}
  .steps-progress{display:none}
  .form-row,.form-row.three,.form-row.split{grid-template-columns:1fr}
  .acc-tabs{grid-template-columns:1fr}
  .acc-tab{padding:12px 8px}
  .sec-body{padding:16px}
  .sec-head{padding:14px 16px}
  .radio-card{grid-template-columns:auto 1fr;gap:12px;padding:12px 14px}
  .radio-card .price{grid-column:2;text-align:left;font-size:14px}
  .radio-card .body-row .ic{order:-1}
  .order-card .head{padding:14px 16px}
  .cart-wide-head{display:none}
  .cart-wrow{grid-template-columns:54px minmax(0,1fr);gap:6px 12px;padding:14px 16px}
  .cart-wrow .img{grid-row:1;grid-column:1;width:54px;height:54px}
  .cart-wrow .info{grid-row:1;grid-column:2}
  .cart-wrow .sku{font-size:15px}
  .cart-wrow .qty-wrap{grid-column:1/-1;justify-content:flex-start;margin-top:8px}
  .cart-wrow .unit{grid-column:1;text-align:left;align-self:center}
  .cart-wrow .sum{grid-column:2;text-align:right;align-self:center}
  .cart-wrow .remove{position:absolute;top:10px;right:12px;border-color:transparent;width:24px;height:24px}
  .cart-foot{padding:14px 16px}
  .cart-item{padding:10px 16px;grid-template-columns:50px 1fr auto}
  .cart-item .body .name{font-size:11px}
  .cart-item .price b{font-size:12px}
  .summary,.order-cta,.order-sidebar .trust-row{padding:14px 16px}
  .summary .total b{font-size:22px}
  .cta-btn{height:48px;font-size:12px}
  .mobile-checkout-bar{display:flex}
  body{padding-bottom:74px}
  .order-sidebar{display:block}
}

/* ===== VIRSAL FIX-UPS po końcowych testach ===== */

/* Override .gallery z home YT-section dla product-page kontekstu */
.product-page .gallery{display:block !important;grid-template-columns:none !important;gap:0 !important}

/* Odstęp między konfiguratorem a przyciskiem Dodaj do koszyka — failsafe na widget i sibling */
.virsal-config{ margin-bottom:32px !important }
.virsal-config + .cart-row{ margin-top:32px !important }
.virsal-config .axes-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px}
.virsal-config .axis{display:flex;flex-direction:column;gap:6px}
.virsal-config .axis label{font-size:13px;font-weight:700;color:var(--ink);text-align:left;line-height:1.3;display:inline-flex;align-items:center;gap:5px}
.virsal-config .axis label .req{color:var(--red);font-weight:800}
.virsal-config .axis select,
.virsal-config .axis input[type=number],
.virsal-config .axis input[type=range]{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--r);
  font-size:14px;font-family:inherit;outline:0;background:#fff;color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
}
.virsal-config .axis select:focus,
.virsal-config .axis input[type=number]:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
.virsal-config .missing{padding:14px 16px;background:#FFF8E1;border:1px solid #FFC107;border-radius:var(--r);color:#7C5C00;font-size:13.5px;margin-top:18px;display:flex;align-items:center;gap:10px}
.virsal-config .err{color:#7A0613;background:#FFE8EB;border:1px solid #F5A5AC;padding:10px 14px;border-radius:var(--r);font-size:13px;margin-top:14px}

@media (max-width:640px){
  .virsal-config{padding:18px}
  .virsal-config .axes-grid{grid-template-columns:1fr;gap:14px}
}

/* ============================================================
   HEAVY-NEW v2 — port z makiety heavy-new.html (2026-05-18)
   - Galeria: pionowe thumbs po lewej krawędzi + scroll-y
   - Gallery-info box pod galerią (HEAVY): Typy w rodzinie / Klucz konfiguracji / Opcje wariantowe
   - prod-meta-row: 50/50 — lewa Dostępność | prawa Marka+logo
   - Tab panels: collapse z "Pokaż więcej" (max-height + fade + button)
   - Akcesoria: tabela zamiast rec-grid kart (HEAVY)
   ============================================================ */

/* === GALERIA: pionowe thumbs po lewej krawędzi głównego obrazu === */
.gallery-side{display:grid;grid-template-columns:84px 1fr;gap:12px;align-items:start}
/* Brak dodatkowych zdjęć — bez kolumny thumbów; główny obraz na pełną szerokość (inaczej wpadał w wąską kolumnę 84px) */
.gallery-side.no-thumbs{grid-template-columns:1fr}
.gallery-side .gallery-thumbs{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--line) transparent;grid-template-columns:none;margin-top:0}
.gallery-side .gallery-thumbs::-webkit-scrollbar{width:4px}
.gallery-side .gallery-thumbs::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}
.gallery-side .gallery-thumbs::-webkit-scrollbar-track{background:transparent}
.gallery-side .gallery-thumb{width:100%;aspect-ratio:1;flex-shrink:0;margin:0}
.gallery-side .gallery-main{aspect-ratio:auto;height:340px;padding:24px}

/* === GALLERY INFO — biały box z opisem rodziny (HEAVY) === */
.gallery-info{margin-top:18px;font-size:13px;color:var(--ink);line-height:1.55;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px 22px}
.gallery-info h4{margin:18px 0 8px;font-size:14px;font-weight:800;color:var(--ink);text-transform:none;letter-spacing:0;padding:0;border:0;display:block}
.gallery-info h4:first-child{margin-top:0}
.gallery-info p{margin:4px 0;font-size:13px;color:var(--ink);line-height:1.55}
.gallery-info p b{color:var(--ink);font-weight:700}
.gallery-info dl{margin:0;padding-left:22px}
.gallery-info dl div{display:block;font-size:13px;line-height:1.55;color:var(--ink);margin:2px 0}
.gallery-info dl b{color:var(--ink);font-weight:700}

/* === PROD META ROW: 50/50 — Dostępność | Marka+logo === */
.prod-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:16px}
.prod-meta-row .prod-stock,.prod-meta-row .prod-brand{border:0;margin:0;padding:12px 0;min-width:0}
.prod-meta-row .prod-stock{padding-right:18px;border-right:1px solid var(--line);justify-content:space-between;gap:10px;flex-wrap:wrap}
.prod-meta-row .prod-brand{padding-left:18px;justify-content:space-between}
@media (max-width:768px){
  .prod-meta-row{grid-template-columns:1fr}
  .prod-meta-row .prod-stock{padding-right:0;border-right:0;border-bottom:1px solid var(--line);padding-bottom:12px}
  .prod-meta-row .prod-brand{padding-left:0;padding-top:12px}
}

/* === TAB PANELS — collapse z "Pokaż więcej" === */
.tab-panel{position:relative}
.tab-panel.is-collapsed{max-height:700px;overflow:hidden;padding-bottom:56px}
.tab-panel.is-collapsed.expanded{max-height:none}
.tab-panel.is-collapsed:not(.expanded)::after{content:"";position:absolute;left:1px;right:1px;bottom:0;height:170px;background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,#fff 55%,#fff 100%);pointer-events:none;z-index:1}
.tab-toggle{position:absolute;left:50%;bottom:8px;transform:translateX(-50%);background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:10px 24px;font-size:11.5px;font-weight:800;color:var(--ink-800);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:8px;z-index:2;transition:all .15s;white-space:nowrap;font-family:inherit}
.tab-toggle:hover{border-color:var(--red);color:var(--red)}
.tab-panel:not(.is-collapsed) > .tab-toggle{display:none}
.tab-toggle svg{width:13px;height:13px;transition:transform .25s}
.tab-panel.expanded .tab-toggle svg{transform:rotate(180deg)}
.tab-panel.expanded .tab-toggle .tx-more{display:none}
.tab-panel:not(.expanded) .tab-toggle .tx-less{display:none}

/* === AKCESORIA — tabela zamiast rec-grid (HEAVY) === */
.acc-table-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.acc-table{width:100%;border-collapse:collapse;font-size:13px}
.acc-table thead th{background:var(--bg);color:var(--ink-500);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:14px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
.acc-table thead th.col-c{text-align:center}
.acc-table thead th.col-r{text-align:right}
.acc-table tbody td{padding:14px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:13px}
.acc-table tbody tr:last-child td{border-bottom:0}
.acc-table tbody tr:hover td{background:#FAFBFD}

.acc-thumb-th,.acc-thumb-cell{width:80px}
.acc-thumb{width:64px;height:64px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:5px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;transition:border-color .15s}
.acc-table tbody tr:hover .acc-thumb{border-color:var(--red)}
.acc-thumb img{max-width:100%;max-height:100%;object-fit:contain;display:block}

.acc-code{display:flex;flex-direction:column;gap:5px;min-width:170px}
.acc-code-top{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:13.5px;color:var(--ink);font-variant-numeric:tabular-nums}
.acc-code-top .badge-virsal{background:var(--ink);color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:var(--r-sm);letter-spacing:.06em}
.acc-code-desc{font-size:11.5px;color:var(--ink-500);font-weight:500;line-height:1.4}
.acc-cell{font-weight:700;color:var(--ink-800);font-size:13px;white-space:nowrap}

.acc-avail{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:80px;text-align:center}
.acc-avail svg{width:24px;height:24px}
.acc-avail span{font-size:11px;font-weight:700;white-space:nowrap}
.acc-avail.warn svg,.acc-avail.warn span{color:#E2A100}
.acc-avail.ok svg,.acc-avail.ok span{color:var(--green)}

.acc-price{display:flex;flex-direction:column;gap:1px;align-items:flex-end;min-width:88px;font-variant-numeric:tabular-nums}
.acc-price b{font-size:15px;font-weight:900;color:var(--ink);line-height:1.1}
.acc-price b .net{font-size:10.5px;color:var(--ink-500);font-weight:600;margin-left:3px}
.acc-price .gross{font-size:11.5px;color:var(--ink-500);font-weight:600}

.acc-cart{display:inline-flex;align-items:center;gap:8px}
.acc-qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r);height:38px;background:#fff;flex-shrink:0}
.acc-qty button{width:30px;height:38px;color:var(--ink-500);font-weight:700;font-size:15px;background:none;border:0;cursor:pointer;font-family:inherit;padding:0}
.acc-qty button:hover{color:var(--red)}
.acc-qty input{width:30px;height:38px;border:0;text-align:center;font-weight:800;color:var(--ink);font-size:13px;outline:0;background:transparent;font-variant-numeric:tabular-nums;font-family:inherit;padding:0}
.acc-qty input::-webkit-inner-spin-button,.acc-qty input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.acc-cart-btn{background:var(--red);color:#fff;height:38px;padding:0 16px;border-radius:var(--r);font-weight:800;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:7px;transition:background .15s;font-family:inherit;border:0;cursor:pointer;white-space:nowrap}
.acc-cart-btn:hover{background:var(--red-600)}
.acc-cart-btn svg{width:16px;height:16px}

.acc-actions{display:flex;flex-direction:column;gap:6px;min-width:108px}
.acc-actions a{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--ink-500);transition:color .15s}
.acc-actions a:hover{color:var(--red)}
.acc-actions svg{width:12px;height:12px;color:var(--red);flex-shrink:0}

@media (max-width:1024px){
  .acc-table thead{display:none}
  .acc-table,.acc-table tbody,.acc-table tr,.acc-table td{display:block;width:100%}
  .acc-table tbody tr{border-bottom:1px solid var(--line);padding:14px 16px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .acc-table tbody tr:last-child{border-bottom:0}
  .acc-table tbody td{padding:0;border:0}
  .acc-table tbody td:first-child{grid-column:1/-1}
  .acc-table tbody td.acc-thumb-cell{display:none}
  .acc-cart{justify-content:flex-end}
  .acc-actions{flex-direction:row;gap:14px}
}

@media (max-width:768px){
  .gallery-side{grid-template-columns:1fr;gap:10px}
  .gallery-side .gallery-thumbs{flex-direction:row;max-height:none;overflow-x:auto;overflow-y:visible;padding-right:0;padding-bottom:4px}
  .gallery-side .gallery-thumb{width:84px;height:84px;aspect-ratio:auto}
  .gallery-side .gallery-main{height:auto;padding:30px}
}

/* ============================================================
   VIRSAL — live search (autocomplete) panel  (2026-05-26)
   .search-cell = grid item (centruje + wymiaruje), .search = width:100% w środku.
   Panel poza .search (które ma overflow:hidden), więc nie jest obcinany.
   ============================================================ */
.search-cell{position:relative;justify-self:center;width:780px;max-width:100%}
.virsal-ac{position:absolute;top:calc(100% + 8px);left:0;width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden auto;max-height:72vh;z-index:60}
.virsal-ac[hidden]{display:none}
.virsal-ac-head{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--line);background:#FAFBFD}
.virsal-ac-head .lbl{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-300)}
.virsal-ac-head .hint{font-size:11px;color:var(--ink-300)}
.virsal-ac-head .hint kbd{background:#fff;border:1px solid var(--line);border-radius:3px;padding:1px 5px;font-family:inherit;font-size:10px;color:var(--ink-500)}
.virsal-ac-item{display:flex;align-items:center;gap:14px;padding:11px 16px;border-left:3px solid transparent;border-bottom:1px solid #F1F4F9;color:var(--ink)}
.virsal-ac-item:hover,.virsal-ac-item.active,.virsal-ac-foot.active{background:var(--red-50);border-left-color:var(--red)}
.virsal-ac-thumb{width:46px;height:46px;flex-shrink:0;border:1px solid var(--line);border-radius:var(--r);background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--ink-300)}
.virsal-ac-thumb img{width:100%;height:100%;object-fit:contain}
.virsal-ac-thumb svg{width:28px;height:28px}
.virsal-ac-bd{flex:1;min-width:0}
.virsal-ac-bd .nm{display:block;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.virsal-ac-bd .nm em{font-style:normal;background:#FFE9A8;border-radius:2px;padding:0 1px}
.virsal-ac-bd .mt{display:block;font-size:12px;color:var(--ink-300);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.virsal-ac-bd .mt .sku{color:var(--ink-500);font-weight:600}
.virsal-ac-bd .mt .sku em{font-style:normal;background:#FFE9A8;border-radius:2px;padding:0 1px}
.virsal-ac-bd .mt .vtag{display:inline-block;margin:0 7px;padding:1px 6px;border-radius:3px;background:var(--red-50);color:var(--red);font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;vertical-align:1px}
.virsal-ac-bd .mt .vti{color:var(--ink-300)}
.virsal-ac-pr{text-align:right;flex-shrink:0;padding-left:10px}
.virsal-ac-pr b{display:block;font-size:14px;font-weight:800;font-variant-numeric:tabular-nums}
.virsal-ac-pr span{font-size:11px;color:var(--ink-300)}
.virsal-ac-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;background:#FAFBFD;color:var(--red);font-weight:700;font-size:13px;border-left:3px solid transparent;cursor:pointer}
.virsal-ac-foot:hover{background:var(--red-50)}
.virsal-ac-foot .l{display:inline-flex;align-items:center;gap:8px;min-width:0}
.virsal-ac-foot .l svg{width:16px;height:16px;flex-shrink:0}
.virsal-ac-foot .cnt{background:var(--red);color:#fff;border-radius:999px;font-size:11px;font-weight:800;padding:2px 9px;white-space:nowrap}
.virsal-ac-empty{padding:18px 16px;color:var(--ink-500);font-size:13px}
@media (max-width:768px){
  .m-search{position:relative}
  .virsal-ac{top:calc(100% + 6px);border-radius:var(--r);max-height:64vh}
}

/* ============================================================
   BLOG  (zakładka Blog — information_id=10)
   Ported 1:1 z makieta/blog.html. Cały blok scope'owany pod
   .vblog, bo makieta reużywa generycznych nazw (.chip .cat
   .info .meta .badge .av …) które kolidują z home/category.
   ============================================================ */
.vblog{background:var(--bg)}

/* EMPTY STATE (brak artykułów) */
.vblog .posts{padding:48px 0 56px}
.vblog .blog-empty{text-align:center;padding:64px 24px 72px;border:1px dashed var(--line);border-radius:var(--r-lg);background:#fff}
.vblog .blog-empty-ic{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--red-50);color:var(--red);margin-bottom:18px}
.vblog .blog-empty-ic svg{width:30px;height:30px}
.vblog .blog-empty h3{margin:0 0 10px;font-size:22px;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.vblog .blog-empty p{margin:0 auto;max-width:480px;font-size:15px;line-height:1.6;color:var(--ink-500)}

/* HERO */
.vblog .bhero{background:linear-gradient(135deg,#0B1B33 0%,#16284A 60%,#1D3360 100%);color:#fff;padding:72px 0 96px;position:relative;overflow:hidden}
.vblog .bhero::after{content:"";position:absolute;left:-10%;top:-30%;width:60%;height:160%;background:radial-gradient(closest-side,rgba(227,6,19,.32),transparent 70%);filter:blur(28px)}
.vblog .bhero .row{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end}
.vblog .bhero .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:rgba(227,6,19,.18);border:1px solid rgba(227,6,19,.5);padding:8px 14px;border-radius:var(--r-sm);margin-bottom:24px}
.vblog .bhero .eyebrow .dot{width:6px;height:6px;background:var(--red);border-radius:50%;box-shadow:0 0 0 4px rgba(227,6,19,.25)}
.vblog .bhero h1{font-size:64px;line-height:1.02;letter-spacing:-.03em;margin:0 0 20px;font-weight:900;max-width:920px}
.vblog .bhero h1 em{color:var(--red);font-style:normal;background:linear-gradient(180deg,#FF4854,#E30613);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vblog .bhero p.lead{font-size:18px;line-height:1.65;color:#C7D1E5;margin:0 0 32px;max-width:680px}
.vblog .bhero-stats{display:flex;gap:32px;flex-wrap:wrap}
.vblog .bhero-stat b{display:block;font-size:32px;font-weight:900;color:#fff;letter-spacing:-.02em;line-height:1}
.vblog .bhero-stat span{display:block;font-size:12px;color:#A6B5D2;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-top:4px}
.vblog .bhero-search{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-lg);padding:24px;backdrop-filter:blur(8px);min-width:320px}
.vblog .bhero-search h3{margin:0 0 14px;font-size:14px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff}
.vblog .bhero-search .field{display:flex;align-items:center;background:#fff;border-radius:var(--r);overflow:hidden;height:46px}
.vblog .bhero-search input{flex:1;border:0;padding:0 16px;font-size:14px;outline:0;font-family:inherit;color:var(--ink)}
.vblog .bhero-search button{background:var(--red);color:#fff;padding:0 18px;height:100%;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:13px;transition:background .2s}
.vblog .bhero-search button:hover{background:var(--red-600)}
.vblog .bhero-search button svg{width:14px;height:14px}
.vblog .bhero-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.vblog .bhero-tags a{font-size:11.5px;font-weight:700;color:#fff;background:rgba(255,255,255,.1);padding:6px 11px;border-radius:var(--r-sm);transition:all .15s;text-transform:uppercase;letter-spacing:.04em}
.vblog .bhero-tags a:hover{background:var(--red)}

/* FILTER BAR */
.vblog .filter-bar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:88px;z-index:40}
.vblog .filter-bar .row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:20px;flex-wrap:wrap}
.vblog .filter-chips{display:flex;gap:6px;flex-wrap:wrap}
.vblog .chip{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:700;color:var(--ink-500);background:var(--bg);transition:all .15s;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;border:1px solid transparent}
.vblog .chip:hover{background:#fff;color:var(--ink);border-color:var(--line)}
.vblog .chip.active{background:var(--ink);color:#fff}
.vblog .chip .cnt{font-size:11px;background:rgba(255,255,255,.18);padding:1px 7px;border-radius:var(--r-sm);font-weight:800}
.vblog .chip:not(.active) .cnt{background:rgba(11,27,51,.06);color:var(--ink-500)}
.vblog .sort{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-500);font-weight:600}
.vblog .sort select{border:1px solid var(--line);background:#fff;padding:8px 14px;border-radius:var(--r-sm);font-family:inherit;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer;outline:0}
.vblog .sort select:focus{border-color:var(--red)}

/* FEATURED */
.vblog .featured{padding:48px 0 24px}
.vblog .featured-card{display:grid;grid-template-columns:1.2fr .8fr;background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);transition:all .25s}
.vblog .featured-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}
.vblog .featured-card .img{position:relative;aspect-ratio:auto;min-height:380px;background:#0B1B33;overflow:hidden}
.vblog .featured-card .img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.vblog .featured-card .img::after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(11,27,51,.45),transparent 60%)}
.vblog .featured-card .img .badge{position:absolute;top:20px;left:20px;background:var(--red);color:#fff;padding:7px 14px;border-radius:var(--r-sm);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;gap:7px;z-index:2}
.vblog .featured-card .img .badge svg{width:13px;height:13px}
.vblog .featured-card .body{padding:48px 56px;display:flex;flex-direction:column;justify-content:center}
.vblog .featured-card .cat{display:inline-block;color:var(--red);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.18em;margin-bottom:14px}
.vblog .featured-card h2{font-size:36px;font-weight:900;letter-spacing:-.025em;line-height:1.15;margin:0 0 16px;color:var(--ink)}
.vblog .featured-card .lede{font-size:16.5px;line-height:1.65;color:var(--ink-500);margin:0 0 24px}
.vblog .featured-card .meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-500);margin-bottom:28px}
.vblog .featured-card .meta .author{display:flex;align-items:center;gap:10px}
.vblog .featured-card .meta .av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--red),#FF4D5C);display:inline-flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:13px}
.vblog .featured-card .meta b{color:var(--ink);font-weight:700}
.vblog .featured-card .meta .dot{width:4px;height:4px;background:var(--ink-300);border-radius:50%}
.vblog .featured-card .meta .item{display:inline-flex;align-items:center;gap:6px}
.vblog .featured-card .meta svg{width:14px;height:14px;color:var(--red)}
.vblog .featured-card .read-cta{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;padding:14px 24px;border-radius:var(--r);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:13px;transition:all .2s;align-self:flex-start}
.vblog .featured-card .read-cta:hover{background:var(--red-600);transform:translateX(4px)}
.vblog .featured-card .read-cta svg{width:14px;height:14px}

/* POSTS GRID */
.vblog .posts{padding:24px 0 56px}
.vblog .posts-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:14px}
.vblog .posts-head h2{margin:0;font-size:28px;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.vblog .posts-head .info{font-size:13px;color:var(--ink-500);font-weight:600}
.vblog .posts-head .info b{color:var(--ink)}
.vblog .posts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.vblog .post-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:all .25s}
.vblog .post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.vblog .post-card .img{aspect-ratio:16/10;background:linear-gradient(135deg,#16284A,#0B1B33);overflow:hidden;position:relative;display:block}
.vblog .post-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.vblog .post-card:hover .img img{transform:scale(1.05)}
.vblog .post-card .img .cat{position:absolute;top:14px;left:14px;background:var(--red);color:#fff;padding:5px 11px;border-radius:var(--r-sm);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.vblog .post-card .img .read-time{position:absolute;bottom:14px;right:14px;background:rgba(11,27,51,.85);color:#fff;padding:5px 11px;border-radius:var(--r-sm);font-size:11px;font-weight:700;backdrop-filter:blur(4px);display:inline-flex;align-items:center;gap:5px}
.vblog .post-card .img .read-time svg{width:11px;height:11px}
.vblog .post-card .body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column}
.vblog .post-card .meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--ink-500);font-weight:600;margin-bottom:10px}
.vblog .post-card .meta .item{display:inline-flex;align-items:center;gap:4px}
.vblog .post-card .meta svg{width:12px;height:12px;color:var(--ink-300)}
.vblog .post-card h3{font-size:18px;font-weight:800;letter-spacing:-.01em;line-height:1.3;margin:0 0 10px;color:var(--ink);transition:color .15s}
.vblog .post-card:hover h3{color:var(--red)}
.vblog .post-card p{font-size:14px;line-height:1.55;color:var(--ink-500);margin:0 0 16px;flex:1}
.vblog .post-card .foot{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line)}
.vblog .post-card .author{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-500);font-weight:600}
.vblog .post-card .author .av{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--red),#FF4D5C);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:10px}
.vblog .post-card .arr{color:var(--red);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:4px;transition:transform .2s}
.vblog .post-card:hover .arr{transform:translateX(4px)}
.vblog .post-card .arr svg{width:13px;height:13px}

/* PAGINATION */
.vblog .pager{display:flex;justify-content:center;align-items:center;gap:6px;margin:48px 0 0;flex-wrap:wrap}
.vblog .pager a,.vblog .pager span{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 14px;border-radius:var(--r-sm);font-weight:700;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line);transition:all .15s}
.vblog .pager a:hover{background:var(--red);color:#fff;border-color:var(--red)}
.vblog .pager .current{background:var(--red);color:#fff;border-color:var(--red)}
.vblog .pager .nav-arr{padding:0 16px}
.vblog .pager .dots{border:0;background:transparent;color:var(--ink-300)}

/* NEWSLETTER STRIP */
.vblog .nl-strip{background:linear-gradient(135deg,#0B1B33,#16284A);color:#fff;padding:64px 0;position:relative;overflow:hidden}
.vblog .nl-strip::before{content:"";position:absolute;left:-10%;top:-30%;width:50%;height:160%;background:radial-gradient(closest-side,rgba(227,6,19,.4),transparent 70%);filter:blur(28px)}
.vblog .nl-strip .row{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.vblog .nl-strip h2{font-size:36px;font-weight:900;letter-spacing:-.025em;line-height:1.15;margin:0 0 14px}
.vblog .nl-strip h2 em{color:var(--red);font-style:normal;background:linear-gradient(180deg,#FF4854,#E30613);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vblog .nl-strip p{color:#C7D1E5;font-size:16px;line-height:1.65;margin:0;max-width:520px}
.vblog .nl-form{display:flex;flex-direction:column;gap:14px}
.vblog .nl-form .field{display:flex;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-lg);overflow:hidden;height:60px}
.vblog .nl-form input{flex:1;background:transparent;border:0;padding:0 22px;color:#fff;font-size:15px;outline:0;font-family:inherit}
.vblog .nl-form input::placeholder{color:#7A8AA8}
.vblog .nl-form button{background:var(--red);color:#fff;padding:0 32px;font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:10px;transition:background .2s}
.vblog .nl-form button:hover{background:var(--red-600)}
.vblog .nl-form button svg{width:14px;height:14px}
.vblog .nl-form .hint{font-size:12.5px;color:#A6B5D2;display:flex;gap:6px;align-items:center}
.vblog .nl-form .hint svg{width:13px;height:13px;color:var(--green);flex-shrink:0}

/* RESPONSIVE */
@media (max-width:1280px){
  .vblog .posts-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1024px){
  .vblog .bhero{padding:56px 0 72px}
  .vblog .bhero h1{font-size:48px}
  .vblog .bhero .row{grid-template-columns:1fr;gap:32px}
  .vblog .bhero-search{min-width:0}
  .vblog .featured-card{grid-template-columns:1fr}
  .vblog .featured-card .img{min-height:280px;aspect-ratio:16/9}
  .vblog .featured-card .body{padding:32px 28px}
  .vblog .featured-card h2{font-size:26px}
  .vblog .posts-grid{grid-template-columns:repeat(2,1fr)}
  .vblog .nl-strip .row{grid-template-columns:1fr;gap:24px}
  .vblog .nl-strip h2{font-size:28px}
}
@media (max-width:768px){
  .vblog .bhero{padding:40px 0 56px}
  .vblog .bhero h1{font-size:30px}
  .vblog .bhero p.lead{font-size:14px}
  .vblog .bhero-stat b{font-size:24px}
  .vblog .filter-bar{position:static}
  .vblog .filter-bar .row{padding:14px 0}
  .vblog .chip{padding:7px 12px;font-size:11.5px}
  .vblog .featured{padding:32px 0 16px}
  .vblog .featured-card .img{min-height:200px}
  .vblog .featured-card .body{padding:24px 20px}
  .vblog .featured-card h2{font-size:22px}
  .vblog .featured-card .lede{font-size:14.5px}
  .vblog .posts-grid{grid-template-columns:1fr;gap:16px}
  .vblog .pager a,.vblog .pager span{min-width:36px;height:36px;font-size:13px}
  .vblog .pager .nav-arr{padding:0 12px}
  .vblog .nl-strip{padding:48px 0}
  .vblog .nl-form .field{height:54px}
}

/* ============================================================
   KONTAKT PAGE  (makieta/kontakt.html → information/contact.twig)
   All rules scoped under .kontakt-page so shared .sec-card /
   .form-field / .form-row rules from the checkout section stay intact.
   ============================================================ */
@keyframes kpulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes kpin-bounce{0%,100%{transform:rotate(-45deg) translateY(0)}50%{transform:rotate(-45deg) translateY(-6px)}}

/* ===== PAGE HERO ===== */
.kontakt-page .page-hero{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;padding:54px 0 48px;position:relative;overflow:hidden}
.kontakt-page .page-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle, rgba(255,255,255,.05) 1px, transparent 1px);background-size:28px 28px;pointer-events:none}
.kontakt-page .page-hero::after{content:"";position:absolute;right:-180px;top:-100px;width:520px;height:520px;background:radial-gradient(circle, rgba(227,6,19,.18) 0%, transparent 60%);pointer-events:none}
.kontakt-page .page-hero .row{display:grid;grid-template-columns:1.6fr 1fr;gap:36px;align-items:end;position:relative;z-index:2}
.kontakt-page .page-hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(227,6,19,.18);color:#FFB3B7;padding:6px 14px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.kontakt-page .page-hero .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(31,169,104,.3);animation:kpulse 2s ease infinite}
.kontakt-page .page-hero h1{font-size:42px;font-weight:900;margin:0 0 16px;letter-spacing:-.025em;line-height:1.05;color:#fff}
.kontakt-page .page-hero h1 em{color:var(--red);font-style:normal}
.kontakt-page .page-hero p{font-size:16px;color:#B4C0D9;margin:0 0 20px;max-width:600px;line-height:1.6}
.kontakt-page .page-hero .quick-call{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.kontakt-page .page-hero .qc{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:10px 16px;border-radius:var(--r);font-size:13px;color:#fff;font-weight:600;transition:all .2s}
.kontakt-page .page-hero .qc:hover{background:rgba(255,255,255,.12);border-color:rgba(227,6,19,.5);transform:translateY(-1px)}
.kontakt-page .page-hero .qc svg{width:18px;height:18px;color:var(--red)}
.kontakt-page .page-hero .qc b{color:#fff;font-weight:800;font-variant-numeric:tabular-nums}
.kontakt-page .page-hero .info-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:22px 24px;display:flex;flex-direction:column;gap:14px;backdrop-filter:blur(6px)}
.kontakt-page .page-hero .info-card .ttl{display:flex;align-items:center;gap:10px;font-size:12px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.kontakt-page .page-hero .info-card .ttl::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(31,169,104,.3)}
.kontakt-page .page-hero .info-card .now{font-size:14px;color:#fff;font-weight:700}
.kontakt-page .page-hero .info-card .now b{color:var(--green)}
.kontakt-page .page-hero .info-card .row-mini{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 0;border-top:1px solid rgba(255,255,255,.08);font-size:12.5px;color:#B4C0D9}
.kontakt-page .page-hero .info-card .row-mini b{color:#fff;font-variant-numeric:tabular-nums}

/* ===== QUICK CARDS ROW ===== */
.kontakt-page .quick-row{margin-top:-24px;position:relative;z-index:5}
.kontakt-page .quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kontakt-page .quick-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 22px;display:flex;align-items:center;gap:16px;transition:all .2s;box-shadow:var(--shadow-sm);cursor:pointer;position:relative;overflow:hidden}
.kontakt-page .quick-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);transform:scaleY(0);transform-origin:center;transition:transform .25s}
.kontakt-page .quick-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.kontakt-page .quick-card:hover::before{transform:scaleY(1)}
.kontakt-page .quick-card .ic{width:48px;height:48px;background:var(--red-50);color:var(--red);border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.kontakt-page .quick-card:hover .ic{background:var(--red);color:#fff}
.kontakt-page .quick-card .ic svg{width:24px;height:24px}
.kontakt-page .quick-card .label{font-size:11px;color:var(--ink-500);font-weight:800;text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:2px}
.kontakt-page .quick-card .value{font-size:16px;font-weight:900;color:var(--ink);letter-spacing:-.015em;display:block;line-height:1.2}
.kontakt-page .quick-card .sub{font-size:11.5px;color:var(--ink-500);font-weight:600;display:block;margin-top:2px}

/* ===== MAIN CONTACT GRID ===== */
.kontakt-page .contact-wrap{padding:36px 0 24px}
.kontakt-page .contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;align-items:start}
.kontakt-page .sec-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:18px}
.kontakt-page .sec-card .head{padding:18px 24px;border-bottom:1px solid var(--line);background:#FAFBFD;display:flex;align-items:center;gap:12px}
.kontakt-page .sec-card .head h2{margin:0;font-size:18px;font-weight:900;color:var(--ink);letter-spacing:-.015em;display:inline-flex;align-items:center;gap:12px}
.kontakt-page .sec-card .head h2::before{content:"";width:4px;height:22px;background:var(--red);border-radius:2px}
.kontakt-page .sec-card .head .meta{margin-left:auto;font-size:12px;color:var(--ink-500);font-weight:700}
.kontakt-page .sec-card .body{padding:24px}

/* ===== CONTACT FORM ===== */
.kontakt-page .cform-intro{font-size:14px;color:var(--ink-500);margin:0 0 18px;line-height:1.6}
.kontakt-page .cform-intro b{color:var(--ink);font-weight:700}
.kontakt-page .topic-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.kontakt-page .topic{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1.5px solid var(--line);border-radius:999px;font-size:12.5px;font-weight:700;color:var(--ink-800);background:#fff;cursor:pointer;transition:all .15s}
.kontakt-page .topic:hover{border-color:var(--ink-300)}
.kontakt-page .topic.active{background:var(--red);border-color:var(--red);color:#fff}
.kontakt-page .topic.active svg{color:#fff}
.kontakt-page .topic svg{width:14px;height:14px;color:var(--ink-500);transition:color .15s}
.kontakt-page .form-field textarea{min-height:130px;line-height:1.5}
.kontakt-page .form-field .counter{position:absolute;right:8px;bottom:8px;font-size:10px;color:var(--ink-300);font-weight:700;font-variant-numeric:tabular-nums;background:#fff;padding:2px 6px;border-radius:var(--r-sm)}
.kontakt-page .field-error{font-size:11.5px;color:var(--red);font-weight:700;margin-top:2px}
.kontakt-page .file-drop{margin-top:14px;border:2px dashed var(--line);border-radius:var(--r);padding:20px;text-align:center;cursor:pointer;transition:all .15s;background:#FAFBFD}
.kontakt-page .file-drop:hover{border-color:var(--red);background:var(--red-50)}
.kontakt-page .file-drop svg{width:28px;height:28px;color:var(--ink-300);margin:0 auto 6px}
.kontakt-page .file-drop:hover svg{color:var(--red)}
.kontakt-page .file-drop b{display:block;font-size:13px;color:var(--ink);font-weight:700}
.kontakt-page .file-drop span{display:block;font-size:11.5px;color:var(--ink-500);margin-top:2px}
.kontakt-page .gdpr-row{margin-top:18px;padding:16px;background:var(--bg);border-radius:var(--r);display:flex;flex-direction:column;gap:10px}
.kontakt-page .gdpr-row label{display:flex;gap:10px;font-size:12px;color:var(--ink-800);line-height:1.5;cursor:pointer;align-items:flex-start}
.kontakt-page .gdpr-row input[type=checkbox]{accent-color:var(--red);width:14px;height:14px;cursor:pointer;margin-top:2px;flex-shrink:0}
.kontakt-page .gdpr-row a{color:var(--red);font-weight:700;text-decoration:underline}
.kontakt-page .gdpr-row b{color:var(--ink);font-weight:700}
.kontakt-page .cform-bottom{margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.kontakt-page .cform-bottom .send-btn{background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 28px;border-radius:var(--r);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.05em;height:52px;transition:all .2s;box-shadow:0 6px 20px -6px rgba(227,6,19,.45)}
.kontakt-page .cform-bottom .send-btn:hover{background:var(--red-600);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(227,6,19,.55)}
.kontakt-page .cform-bottom .send-btn svg{width:18px;height:18px}
.kontakt-page .cform-bottom .reply-info{font-size:12.5px;color:var(--ink-500);font-weight:600;display:inline-flex;align-items:center;gap:8px}
.kontakt-page .cform-bottom .reply-info svg{width:16px;height:16px;color:var(--green)}
.kontakt-page .cform-bottom .reply-info b{color:var(--ink);font-weight:800}
.kontakt-page .cform-captcha{margin-top:18px}

/* ===== SIDE INFO ===== */
.kontakt-page .side-stack{display:flex;flex-direction:column;gap:14px}
.kontakt-page .side-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 22px}
.kontakt-page .side-card h3{margin:0 0 14px;font-size:13px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:2px solid var(--red)}
.kontakt-page .side-card h3 svg{width:14px;height:14px;color:var(--red)}
.kontakt-page .direct-list{display:flex;flex-direction:column;gap:10px}
.kontakt-page .direct-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);transition:background .15s;cursor:pointer}
.kontakt-page .direct-item:hover{background:var(--bg)}
.kontakt-page .direct-item .ic{width:38px;height:38px;background:var(--bg);color:var(--red);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.kontakt-page .direct-item:hover .ic{background:var(--red);color:#fff}
.kontakt-page .direct-item .ic svg{width:18px;height:18px}
.kontakt-page .direct-item .body{flex:1;min-width:0}
.kontakt-page .direct-item .name{font-size:13px;font-weight:800;color:var(--ink);letter-spacing:-.005em;line-height:1.2}
.kontakt-page .direct-item .num{font-size:12.5px;color:var(--ink-500);font-weight:700;font-variant-numeric:tabular-nums;display:block;margin-top:2px}
.kontakt-page .direct-item .num b{color:var(--red);font-weight:800}
.kontakt-page .hours-table{display:flex;flex-direction:column;gap:6px}
.kontakt-page .hours-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px dashed var(--line);font-size:13px;color:var(--ink-500)}
.kontakt-page .hours-row:last-child{border-bottom:0}
.kontakt-page .hours-row.now{color:var(--green);font-weight:800}
.kontakt-page .hours-row.now::after{content:"online";font-size:10px;background:var(--green-50);color:var(--green);padding:2px 8px;border-radius:var(--r-sm);text-transform:uppercase;letter-spacing:.05em;font-weight:800;margin-left:auto}
.kontakt-page .hours-row b{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums}
.kontakt-page .hours-row.weekend{color:var(--ink-300)}
.kontakt-page .hours-row.weekend b{color:var(--ink-300);text-decoration:line-through}
.kontakt-page .socials-big{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.kontakt-page .social-tile{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:var(--r-sm);font-size:12.5px;font-weight:700;color:var(--ink);transition:all .15s}
.kontakt-page .social-tile:hover{background:var(--red);color:#fff}
.kontakt-page .social-tile .ic{width:30px;height:30px;border-radius:50%;background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-500);transition:all .15s}
.kontakt-page .social-tile:hover .ic{background:rgba(255,255,255,.2);color:#fff}
.kontakt-page .social-tile .ic svg{width:14px;height:14px}
.kontakt-page .social-tile small{display:block;font-size:10px;color:var(--ink-500);font-weight:600;margin-top:1px}
.kontakt-page .social-tile:hover small{color:rgba(255,255,255,.8)}

/* ===== BRANCHES ===== */
.kontakt-page .branches-section{padding:28px 0 16px}
.kontakt-page .branches-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:18px;flex-wrap:wrap}
.kontakt-page .branches-head .ttl{display:flex;flex-direction:column;gap:4px}
.kontakt-page .branches-head .eyebrow{display:block;font-size:12px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.12em}
.kontakt-page .branches-head h2{margin:0;font-size:26px;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.kontakt-page .branches-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.kontakt-page .branch-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:all .25s}
.kontakt-page .branch-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.kontakt-page .branch-card.hq{position:relative}
.kontakt-page .branch-card.hq::before{content:"Centrala";position:absolute;top:14px;right:14px;z-index:3;background:var(--red);color:#fff;padding:4px 10px;border-radius:var(--r-sm);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.kontakt-page .branch-map{aspect-ratio:16/10;background:linear-gradient(135deg,#1F4D9C 0%,#1A4290 100%);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.kontakt-page .branch-map::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:30px 30px;pointer-events:none}
.kontakt-page .branch-map svg.poland{width:60%;height:auto;color:rgba(255,255,255,.85);position:relative;z-index:1}
.kontakt-page .branch-map .pin{position:absolute;width:32px;height:32px;background:var(--red);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 4px 14px rgba(227,6,19,.6);z-index:2;animation:kpin-bounce 2s ease infinite;display:flex;align-items:center;justify-content:center}
.kontakt-page .branch-map .pin::after{content:"";width:10px;height:10px;background:#fff;border-radius:50%;transform:rotate(45deg)}
.kontakt-page .branch-map img.branch-map-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;display:block}
.kontakt-page .branches-mapbox{margin:0 0 24px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);line-height:0;background:linear-gradient(135deg,#1F4D9C,#1A4290)}
.kontakt-page .branches-mapbox img{width:100%;height:auto;display:block}
.kontakt-page .branch-info{padding:20px 22px;display:flex;flex-direction:column;gap:14px;flex:1}
.kontakt-page .branch-info .city{font-size:18px;font-weight:900;color:var(--ink);letter-spacing:-.015em;line-height:1.1;display:flex;align-items:center;gap:10px}
.kontakt-page .branch-info .city svg{width:18px;height:18px;color:var(--red)}
.kontakt-page .branch-info .addr{font-size:13px;color:var(--ink-500);line-height:1.5}
.kontakt-page .branch-info .addr b{color:var(--ink);font-weight:700}
.kontakt-page .branch-contacts{display:flex;flex-direction:column;gap:8px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.kontakt-page .branch-contacts a{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-800);font-weight:600;transition:color .15s}
.kontakt-page .branch-contacts a:hover{color:var(--red)}
.kontakt-page .branch-contacts a svg{width:14px;height:14px;color:var(--red);flex-shrink:0}
.kontakt-page .branch-contacts a b{color:var(--ink);font-weight:800;font-variant-numeric:tabular-nums}
.kontakt-page .branch-manager{display:flex;align-items:center;gap:10px;padding:6px 0}
.kontakt-page .branch-manager .av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--ink),var(--ink-800));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;letter-spacing:-.01em;flex-shrink:0;overflow:hidden}
.kontakt-page .branch-manager .av img{width:100%;height:100%;object-fit:cover}
.kontakt-page .branch-manager .info{flex:1;min-width:0}
.kontakt-page .branch-manager .info b{display:block;font-size:13px;color:var(--ink);font-weight:800;line-height:1.1;letter-spacing:-.005em}
.kontakt-page .branch-manager .info span{display:block;font-size:11px;color:var(--ink-500);font-weight:600;margin-top:2px}
.kontakt-page .branch-cta{display:flex;gap:6px;margin-top:auto}
.kontakt-page .branch-cta a{flex:1;text-align:center;padding:10px 12px;border-radius:var(--r-sm);font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.kontakt-page .branch-cta a.primary{background:var(--ink);color:#fff}
.kontakt-page .branch-cta a.primary:hover{background:var(--red)}
.kontakt-page .branch-cta a.ghost{background:var(--bg);color:var(--ink-800);border:1px solid var(--line)}
.kontakt-page .branch-cta a.ghost:hover{background:#fff;border-color:var(--red);color:var(--red)}
.kontakt-page .branch-cta svg{width:13px;height:13px}

/* ===== TEAM ===== */
.kontakt-page .team-section{padding:32px 0 16px}
.kontakt-page .team-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:18px;flex-wrap:wrap}
.kontakt-page .team-head .ttl{display:flex;flex-direction:column;gap:4px}
.kontakt-page .team-head .eyebrow{display:block;font-size:12px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.12em}
.kontakt-page .team-head h2{margin:0;font-size:26px;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.kontakt-page .team-head p{font-size:13.5px;color:var(--ink-500);margin:6px 0 0;max-width:560px;line-height:1.5}
.kontakt-page .team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.kontakt-page .team-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;display:flex;align-items:center;gap:14px;transition:all .2s;position:relative}
.kontakt-page .team-card:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.kontakt-page .team-card .av{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--ink),var(--ink-800));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;letter-spacing:-.02em;flex-shrink:0;overflow:hidden;border:3px solid var(--bg)}
.kontakt-page .team-card .av img{width:100%;height:100%;object-fit:cover}
.kontakt-page .team-card .body{flex:1;min-width:0}
.kontakt-page .team-card .name{font-size:15px;font-weight:900;color:var(--ink);letter-spacing:-.015em;line-height:1.15;margin-bottom:2px}
.kontakt-page .team-card .role{font-size:11.5px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:block}
.kontakt-page .team-card .lines{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--ink-500)}
.kontakt-page .team-card .lines a{display:inline-flex;align-items:center;gap:6px;color:var(--ink-500);transition:color .15s}
.kontakt-page .team-card .lines a:hover{color:var(--red)}
.kontakt-page .team-card .lines svg{width:12px;height:12px;color:var(--red);flex-shrink:0}
.kontakt-page .team-card .lines b{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums}

/* ===== COMPANY DATA ===== */
.kontakt-page .company-section{padding:24px 0}
.kontakt-page .company-card{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);padding:32px 36px;position:relative;overflow:hidden}
.kontakt-page .company-card::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle, rgba(255,255,255,.05) 1px, transparent 1px);background-size:24px 24px;pointer-events:none}
.kontakt-page .company-card .head{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);flex-wrap:wrap}
.kontakt-page .company-card .head h2{margin:0;font-size:22px;font-weight:900;letter-spacing:-.02em;color:#fff;display:inline-flex;align-items:center;gap:12px}
.kontakt-page .company-card .head h2::before{content:"";width:4px;height:24px;background:var(--red);border-radius:2px}
.kontakt-page .company-card .head .legal-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);padding:8px 14px;border-radius:999px;font-size:11px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.08em;font-weight:800}
.kontakt-page .company-card .head .legal-pill svg{width:13px;height:13px;color:var(--red)}
.kontakt-page .company-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;position:relative;z-index:2}
.kontakt-page .cd-cell{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);padding:16px 18px}
.kontakt-page .cd-cell .lbl{display:block;font-size:10.5px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.08em;font-weight:800;margin-bottom:6px}
.kontakt-page .cd-cell .val{display:block;font-size:14.5px;color:#fff;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.005em;line-height:1.3;word-break:break-word}
.kontakt-page .cd-cell .val.bank{font-size:12.5px;letter-spacing:.04em}
.kontakt-page .company-court{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:2;font-size:12px;color:#B4C0D9;line-height:1.6}
.kontakt-page .company-court b{color:#fff;font-weight:700}

/* ===== BIG MAP ===== */
.kontakt-page .bigmap-section{padding:24px 0 32px}
.kontakt-page .bigmap-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:14px;flex-wrap:wrap}
.kontakt-page .bigmap-head h3{margin:0;font-size:14px;font-weight:900;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:10px}
.kontakt-page .bigmap-head h3::before{content:"";width:4px;height:18px;background:var(--red);border-radius:2px}
.kontakt-page .bigmap{aspect-ratio:21/9;background:linear-gradient(135deg,#E8EEF7 0%,#D6DDED 100%);border:1px solid var(--line);border-radius:var(--r);position:relative;overflow:hidden}

/* ===== FAQ ===== */
.kontakt-page .faq-section{padding:24px 0}
.kontakt-page .faq-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:18px;flex-wrap:wrap}
.kontakt-page .faq-head h2{margin:0;font-size:24px;font-weight:900;color:var(--ink);letter-spacing:-.02em}
.kontakt-page .faq-head .eyebrow{display:block;font-size:12px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px}
.kontakt-page .faq-list{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kontakt-page .faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px 22px;transition:all .15s;cursor:pointer}
.kontakt-page .faq-item:hover{border-color:var(--red)}
.kontakt-page .faq-item summary{font-size:14px;font-weight:800;color:var(--ink);cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;letter-spacing:-.005em}
.kontakt-page .faq-item summary::-webkit-details-marker{display:none}
.kontakt-page .faq-item summary::after{content:"+";font-size:22px;font-weight:300;color:var(--red);line-height:1;transition:transform .2s}
.kontakt-page .faq-item[open] summary::after{transform:rotate(45deg)}
.kontakt-page .faq-item .ans{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-500);line-height:1.6}
.kontakt-page .faq-item .ans b{color:var(--ink);font-weight:700}
.kontakt-page .faq-item .ans a{color:var(--red);font-weight:700;text-decoration:underline}

/* ===== KONTAKT RESPONSIVE ===== */
@media (max-width:1240px){
  .kontakt-page .quick-grid{grid-template-columns:repeat(2,1fr)}
  .kontakt-page .branches-grid{grid-template-columns:1fr}
  .kontakt-page .team-grid{grid-template-columns:1fr 1fr}
  .kontakt-page .company-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:1024px){
  .kontakt-page .page-hero .row{grid-template-columns:1fr;gap:24px;align-items:start}
  .kontakt-page .contact-grid{grid-template-columns:1fr;gap:18px}
  .kontakt-page .quick-row{margin-top:-18px}
  .kontakt-page .form-row,.kontakt-page .form-row.three{grid-template-columns:1fr}
  .kontakt-page .faq-list{grid-template-columns:1fr}
}
@media (max-width:768px){
  .kontakt-page .page-hero{padding:36px 0 32px}
  .kontakt-page .page-hero h1{font-size:28px}
  .kontakt-page .page-hero p{font-size:14px}
  .kontakt-page .page-hero .quick-call{gap:8px}
  .kontakt-page .page-hero .qc{padding:8px 12px;font-size:12px}
  .kontakt-page .quick-grid{grid-template-columns:1fr;gap:10px}
  .kontakt-page .quick-card{padding:16px}
  .kontakt-page .quick-card .value{font-size:14px}
  .kontakt-page .sec-card .body{padding:18px}
  .kontakt-page .sec-card .head{padding:14px 18px}
  .kontakt-page .branches-head h2,.kontakt-page .team-head h2,.kontakt-page .faq-head h2{font-size:20px}
  .kontakt-page .team-grid{grid-template-columns:1fr;gap:10px}
  .kontakt-page .company-grid{grid-template-columns:1fr;gap:8px}
  .kontakt-page .company-card{padding:24px 20px}
  .kontakt-page .bigmap{aspect-ratio:1/1}
}

/* ============================================================
   B2B  (zakładka Strefa B2B — information_id=9)
   Ported 1:1 z makieta/b2b.html. Cały blok scope'owany pod
   .vb2b, bo makieta reużywa generycznych nazw (.section .sec-head
   .eyebrow .steps .step .tier .case .faq .cta .name .badge …)
   kolidujących z checkout/home/category. Nagłówek/stopka/topbar/
   nav/breadcrumbs/mobile = theme (header.twig + footer.twig).
   ============================================================ */
.vb2b{background:var(--bg)}

/* HERO */
.vb2b .b2b-hero{background:linear-gradient(135deg,#0B1B33 0%,#142848 50%,#1D3360 100%);color:#fff;padding:96px 0 140px;position:relative;overflow:hidden}
.vb2b .b2b-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:64px 64px;opacity:.6}
.vb2b .b2b-hero::after{content:"";position:absolute;right:-15%;top:-40%;width:70%;height:180%;background:radial-gradient(closest-side,rgba(227,6,19,.4),transparent 70%);filter:blur(40px)}
.vb2b .b2b-hero .row{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.vb2b .b2b-hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:rgba(212,169,60,.16);border:1px solid rgba(212,169,60,.5);padding:9px 16px;border-radius:var(--r-sm);margin-bottom:28px}
.vb2b .b2b-hero .eyebrow .dot{width:7px;height:7px;background:var(--gold);border-radius:50%;box-shadow:0 0 0 5px rgba(212,169,60,.18)}
.vb2b .b2b-hero h1{font-size:72px;line-height:.98;letter-spacing:-.04em;margin:0 0 28px;font-weight:900}
.vb2b .b2b-hero h1 em{color:var(--red);font-style:normal;background:linear-gradient(180deg,#FF4854,#E30613);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vb2b .b2b-hero p.lead{font-size:19px;line-height:1.6;color:#C7D1E5;margin:0 0 36px;max-width:620px}
.vb2b .b2b-hero p.lead strong{color:#fff;font-weight:700}
.vb2b .b2b-hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.vb2b .btn-gold{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#E8C055,var(--gold));color:var(--ink);padding:18px 32px;border-radius:var(--r);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:13px;transition:all .25s;box-shadow:0 14px 30px -10px rgba(212,169,60,.5)}
.vb2b .btn-gold:hover{transform:translateY(-2px);box-shadow:0 20px 40px -12px rgba(212,169,60,.6)}
.vb2b .btn-gold svg{width:16px;height:16px}
.vb2b .btn-ghost{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);color:#fff;padding:18px 32px;border-radius:var(--r);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:13px;border:1px solid rgba(255,255,255,.18);transition:all .2s}
.vb2b .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.4)}
.vb2b .btn-ghost svg{width:16px;height:16px}
.vb2b .b2b-trust{display:flex;align-items:center;gap:24px;color:#A6B5D2;font-size:13px;flex-wrap:wrap}
.vb2b .b2b-trust .ico{width:28px;height:28px;background:rgba(31,169,104,.18);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;color:#3DD68C}
.vb2b .b2b-trust .ico svg{width:15px;height:15px}
.vb2b .b2b-trust .item{display:inline-flex;align-items:center;gap:8px}
.vb2b .b2b-trust b{color:#fff;font-weight:700}
.vb2b .b2b-hero-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:32px;backdrop-filter:blur(8px);position:relative;overflow:hidden}
.vb2b .b2b-hero-card::before{content:"";position:absolute;left:-30%;top:-30%;width:60%;height:60%;background:radial-gradient(closest-side,rgba(212,169,60,.3),transparent 70%);filter:blur(28px);pointer-events:none}
.vb2b .b2b-hero-card h3{margin:0 0 6px;font-size:14px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);position:relative}
.vb2b .b2b-hero-card .sub{font-size:13px;color:#A6B5D2;margin:0 0 24px;position:relative}
.vb2b .bhc-form{position:relative;display:flex;flex-direction:column;gap:14px}
.vb2b .bhc-form .field{display:flex;flex-direction:column;gap:6px}
.vb2b .bhc-form label{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#A6B5D2}
.vb2b .bhc-form input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--r);padding:14px 16px;color:#fff;font-size:14px;font-family:inherit;outline:0;transition:all .15s}
.vb2b .bhc-form input:focus{border-color:var(--gold);background:rgba(255,255,255,.1)}
.vb2b .bhc-form input::placeholder{color:#7A8AA8}
.vb2b .bhc-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.vb2b .bhc-form button{margin-top:6px;background:var(--red);color:#fff;padding:16px;border-radius:var(--r);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:all .2s}
.vb2b .bhc-form button:hover{background:var(--red-600)}
.vb2b .bhc-form button svg{width:14px;height:14px}
.vb2b .bhc-form .nb{font-size:11.5px;color:#A6B5D2;margin-top:6px;display:flex;gap:6px;align-items:flex-start;line-height:1.5}
.vb2b .bhc-form .nb svg{width:14px;height:14px;color:#3DD68C;flex-shrink:0;margin-top:1px}

/* KPI BAR */
.vb2b .b2b-kpi{background:#fff;border-bottom:1px solid var(--line);position:relative;margin-top:-72px;z-index:3}
.vb2b .b2b-kpi .container{padding-top:0;padding-bottom:0}
.vb2b .b2b-kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.vb2b .b2b-kpi-card{padding:32px 28px;border-right:1px solid var(--line);transition:all .2s}
.vb2b .b2b-kpi-card:last-child{border-right:0}
.vb2b .b2b-kpi-card:hover{background:var(--bg)}
.vb2b .b2b-kpi-card .ico{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;background:var(--ink);color:var(--gold);border-radius:var(--r);margin-bottom:14px}
.vb2b .b2b-kpi-card .ico svg{width:22px;height:22px}
.vb2b .b2b-kpi-card b{display:block;font-size:32px;font-weight:900;color:var(--ink);letter-spacing:-.025em;line-height:1;margin-bottom:6px}
.vb2b .b2b-kpi-card span{display:block;font-size:12.5px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.08em}

/* SECTION HEAD (reset display/padding/border/bg — neutralizuje przeciek checkout .sec-head) */
.vb2b .section{padding:96px 0}
.vb2b .section.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.vb2b .section.dark{background:linear-gradient(180deg,#0B1B33,#142848);color:#fff}
.vb2b .section.dark .sec-head h2{color:#fff}
.vb2b .section.dark .sec-head p{color:#A6B5D2}
.vb2b .sec-head{display:block;text-align:center;max-width:840px;margin:0 auto 64px;padding:0;border:0;background:none}
.vb2b .sec-head .eyebrow{display:inline-block;color:var(--red);font-weight:800;font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px}
.vb2b .section.dark .sec-head .eyebrow{color:var(--gold)}
.vb2b .sec-head h2{font-size:48px;font-weight:900;line-height:1.08;letter-spacing:-.03em;margin:0 0 16px}
.vb2b .sec-head p{color:var(--ink-500);font-size:17px;margin:0;line-height:1.65}

/* BENEFITS */
.vb2b .benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vb2b .bnf-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:36px 32px;transition:all .25s;position:relative;overflow:hidden}
.vb2b .bnf-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,var(--red),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.vb2b .bnf-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.vb2b .bnf-card:hover::before{transform:scaleX(1)}
.vb2b .bnf-card .ico{width:64px;height:64px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--ink),var(--ink-800));color:var(--gold);border-radius:var(--r-lg);margin-bottom:24px;transition:all .3s}
.vb2b .bnf-card:hover .ico{background:linear-gradient(135deg,var(--red),#FF4D5C);color:#fff;transform:rotate(-3deg) scale(1.05)}
.vb2b .bnf-card .ico svg{width:30px;height:30px}
.vb2b .bnf-card h3{font-size:22px;font-weight:900;letter-spacing:-.015em;margin:0 0 10px;color:var(--ink)}
.vb2b .bnf-card p{font-size:15px;line-height:1.65;color:var(--ink-500);margin:0 0 18px}
.vb2b .bnf-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.vb2b .bnf-card ul li{position:relative;padding-left:22px;font-size:14px;color:var(--ink-800);font-weight:600}
.vb2b .bnf-card ul li::before{content:"";position:absolute;left:0;top:.5em;width:12px;height:12px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E30613' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/contain no-repeat}

/* TIERS */
.vb2b .tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.vb2b .tier{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:40px 36px;display:flex;flex-direction:column;position:relative;transition:all .25s}
.vb2b .tier:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.vb2b .tier.featured{background:linear-gradient(180deg,#0B1B33,#142848);color:#fff;border-color:transparent;transform:scale(1.04);box-shadow:var(--shadow-lg)}
.vb2b .tier.featured:hover{transform:scale(1.04) translateY(-4px)}
.vb2b .tier .badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#E8C055,var(--gold));color:var(--ink);padding:6px 16px;border-radius:var(--r-sm);font-weight:800;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;box-shadow:0 8px 18px -6px rgba(212,169,60,.5)}
.vb2b .tier h3{margin:0 0 6px;font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}
.vb2b .tier.featured h3{color:var(--gold)}
.vb2b .tier .name{font-size:32px;font-weight:900;letter-spacing:-.02em;margin:0 0 6px}
.vb2b .tier.featured .name{color:#fff}
.vb2b .tier .desc{font-size:14px;color:var(--ink-500);margin:0 0 28px;line-height:1.55}
.vb2b .tier.featured .desc{color:#A6B5D2}
.vb2b .tier .feat{flex:1;display:flex;flex-direction:column;gap:14px;margin:0 0 32px;padding:0;list-style:none}
.vb2b .tier .feat li{position:relative;padding-left:30px;font-size:14.5px;line-height:1.5;color:var(--ink-800)}
.vb2b .tier.featured .feat li{color:#E2EAF7}
.vb2b .tier .feat li::before{content:"";position:absolute;left:0;top:.2em;width:18px;height:18px;background:var(--green-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231FA968' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;border-radius:50%}
.vb2b .tier.featured .feat li::before{background-color:rgba(31,169,104,.18)}
.vb2b .tier .feat li b{color:var(--ink);font-weight:700}
.vb2b .tier.featured .feat li b{color:#fff}
.vb2b .tier .feat li.no::before{background:var(--bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238A97AD' stroke-width='3' stroke-linecap='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") center/10px no-repeat}
.vb2b .tier .feat li.no{color:var(--ink-300)}
.vb2b .tier .cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 22px;border-radius:var(--r);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:13px;transition:all .2s;text-align:center}
.vb2b .tier .cta-out{background:var(--bg);color:var(--ink)}
.vb2b .tier .cta-out:hover{background:var(--ink);color:#fff}
.vb2b .tier.featured .cta-out{background:rgba(255,255,255,.1);color:#fff}
.vb2b .tier.featured .cta-out:hover{background:#fff;color:var(--ink)}
.vb2b .tier .cta-fill{background:var(--red);color:#fff}
.vb2b .tier .cta-fill:hover{background:var(--red-600)}
.vb2b .tier.featured .cta-fill{background:linear-gradient(135deg,#E8C055,var(--gold));color:var(--ink)}
.vb2b .tier.featured .cta-fill:hover{filter:brightness(1.05)}
.vb2b .tier .cta svg{width:14px;height:14px}

/* PROCESS */
.vb2b .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.vb2b .step{position:relative;padding:32px 28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);transition:all .25s}
.vb2b .step:hover{background:rgba(255,255,255,.08);border-color:rgba(212,169,60,.4);transform:translateY(-4px)}
.vb2b .step .num{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,var(--red),#FF4D5C);color:#fff;font-size:20px;font-weight:900;border-radius:var(--r-lg);letter-spacing:-.02em;margin-bottom:18px;box-shadow:0 12px 24px -8px rgba(227,6,19,.45)}
.vb2b .step h3{font-size:18px;font-weight:800;letter-spacing:-.01em;margin:0 0 10px;color:#fff}
.vb2b .step p{font-size:14px;line-height:1.6;color:#C7D1E5;margin:0}
.vb2b .step .when{display:inline-block;margin-top:14px;padding:5px 11px;background:rgba(212,169,60,.18);color:var(--gold);border-radius:var(--r-sm);font-size:11.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}

/* INTEGRATIONS */
.vb2b .integrations{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.vb2b .integ-content h2{font-size:44px;font-weight:900;letter-spacing:-.025em;line-height:1.1;margin:0 0 20px}
.vb2b .integ-content p{font-size:16.5px;line-height:1.7;color:var(--ink-500);margin:0 0 28px;max-width:560px}
.vb2b .integ-content .feat{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.vb2b .integ-content .feat li{display:flex;gap:14px;align-items:flex-start;font-size:15px}
.vb2b .integ-content .feat .ico{width:32px;height:32px;background:var(--ink);color:var(--gold);border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.vb2b .integ-content .feat .ico svg{width:16px;height:16px}
.vb2b .integ-content .feat b{display:block;color:var(--ink);font-weight:700;margin-bottom:2px}
.vb2b .integ-content .feat span{color:var(--ink-500);font-size:14px;line-height:1.55}
.vb2b .integ-logos{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:#fff;padding:40px;border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow)}
.vb2b .integ-logo{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:var(--r);font-weight:900;font-size:14px;letter-spacing:-.02em;color:var(--ink-500);transition:all .2s;text-align:center;padding:8px}
.vb2b .integ-logo:hover{background:var(--ink);color:#fff;transform:scale(1.05)}
.vb2b .integ-logo b{display:block;font-size:11px;color:var(--red);font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-top:4px;line-height:1}
.vb2b .integ-logo:hover b{color:var(--gold)}

/* TESTIMONIALS */
.vb2b .cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vb2b .case{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;display:flex;flex-direction:column;transition:all .25s;position:relative}
.vb2b .case::before{content:"\201D";position:absolute;top:18px;right:24px;font-size:96px;line-height:1;color:rgba(227,6,19,.1);font-family:Georgia,serif;font-weight:900}
.vb2b .case:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.vb2b .case .stars{display:flex;gap:2px;margin-bottom:18px;color:var(--gold)}
.vb2b .case .stars svg{width:18px;height:18px;fill:currentColor}
.vb2b .case blockquote{margin:0 0 24px;font-size:16.5px;line-height:1.65;color:var(--ink-800);font-weight:500;flex:1}
.vb2b .case .who{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line)}
.vb2b .case .who .av{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--ink),var(--ink-800));color:var(--gold);display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:16px}
.vb2b .case .who b{display:block;font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.vb2b .case .who span{display:block;font-size:12.5px;color:var(--ink-500);font-weight:600}
.vb2b .case .save{position:absolute;bottom:24px;right:24px;background:var(--green-50);color:var(--green);padding:6px 12px;border-radius:var(--r-sm);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}

/* INDUSTRIES */
.vb2b .ind-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.vb2b .ind-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 20px;text-align:center;transition:all .25s;cursor:pointer}
.vb2b .ind-card:hover{transform:translateY(-4px);background:var(--ink);color:#fff;border-color:transparent;box-shadow:var(--shadow)}
.vb2b .ind-card .ico{width:48px;height:48px;background:var(--bg);color:var(--ink);border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;margin:0 auto 14px;transition:all .2s}
.vb2b .ind-card:hover .ico{background:var(--red);color:#fff}
.vb2b .ind-card .ico svg{width:24px;height:24px}
.vb2b .ind-card b{display:block;font-size:14px;font-weight:800;letter-spacing:-.01em;line-height:1.3;margin-bottom:4px}
.vb2b .ind-card span{display:block;font-size:12px;color:var(--ink-500);font-weight:600}
.vb2b .ind-card:hover span{color:#A6B5D2}

/* FAQ */
.vb2b .faq{max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.vb2b .faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:all .2s}
.vb2b .faq-item:hover{border-color:var(--ink-300)}
.vb2b .faq-item summary{padding:22px 28px;font-size:16px;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;letter-spacing:-.005em;list-style:none;color:var(--ink)}
.vb2b .faq-item summary::-webkit-details-marker{display:none}
.vb2b .faq-item summary::after{content:"";width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230B1B33' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") center/contain no-repeat;transition:transform .25s;flex-shrink:0;margin-left:14px}
.vb2b .faq-item[open] summary::after{transform:rotate(180deg)}
.vb2b .faq-item .body{padding:0 28px 24px;font-size:14.5px;line-height:1.7;color:var(--ink-500)}
.vb2b .faq-item .body strong{color:var(--ink);font-weight:700}

/* CTA BAND */
.vb2b .cta-final{background:linear-gradient(135deg,#0B1B33 0%,#142848 50%,#1D3360 100%);color:#fff;padding:96px 0;position:relative;overflow:hidden}
.vb2b .cta-final::before{content:"";position:absolute;left:-15%;top:-50%;width:60%;height:200%;background:radial-gradient(closest-side,rgba(212,169,60,.35),transparent 70%);filter:blur(28px)}
.vb2b .cta-final::after{content:"";position:absolute;right:-15%;bottom:-50%;width:60%;height:200%;background:radial-gradient(closest-side,rgba(227,6,19,.35),transparent 70%);filter:blur(28px)}
.vb2b .cta-final .container{position:relative;z-index:2;text-align:center;max-width:920px}
.vb2b .cta-final .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);background:rgba(212,169,60,.16);border:1px solid rgba(212,169,60,.4);padding:8px 16px;border-radius:var(--r-sm);margin-bottom:24px}
.vb2b .cta-final h2{font-size:56px;font-weight:900;letter-spacing:-.03em;line-height:1.05;margin:0 0 20px}
.vb2b .cta-final h2 em{color:var(--red);font-style:normal;background:linear-gradient(180deg,#FF4854,#E30613);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vb2b .cta-final p{font-size:18px;line-height:1.65;color:#C7D1E5;margin:0 0 36px;max-width:680px;margin-left:auto;margin-right:auto}
.vb2b .cta-final .actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* RESPONSIVE */
@media (max-width:1280px){
  .vb2b .b2b-kpi-grid{grid-template-columns:repeat(3,1fr)}
  .vb2b .b2b-kpi-card:nth-child(3){border-right:0}
  .vb2b .b2b-kpi-card:nth-child(1),.vb2b .b2b-kpi-card:nth-child(2),.vb2b .b2b-kpi-card:nth-child(3){border-bottom:1px solid var(--line)}
  .vb2b .ind-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1024px){
  .vb2b .b2b-hero{padding:64px 0 96px}
  .vb2b .b2b-hero h1{font-size:48px}
  .vb2b .b2b-hero .row{grid-template-columns:1fr;gap:40px}
  .vb2b .b2b-kpi-grid{grid-template-columns:repeat(2,1fr)}
  .vb2b .b2b-kpi-card:nth-child(3){border-right:1px solid var(--line)}
  .vb2b .b2b-kpi-card:nth-child(2n){border-right:0}
  .vb2b .b2b-kpi-card:nth-child(-n+4){border-bottom:1px solid var(--line)}
  .vb2b .benefits-grid{grid-template-columns:1fr}
  .vb2b .tiers-grid{grid-template-columns:1fr}
  .vb2b .tier.featured{transform:none}
  .vb2b .tier.featured:hover{transform:translateY(-4px)}
  .vb2b .steps{grid-template-columns:repeat(2,1fr)}
  .vb2b .integrations{grid-template-columns:1fr;gap:32px}
  .vb2b .cases-grid{grid-template-columns:1fr}
  .vb2b .ind-grid{grid-template-columns:repeat(2,1fr)}
  .vb2b .cta-final h2{font-size:40px}
}
@media (max-width:768px){
  .vb2b .b2b-hero{padding:40px 0 72px}
  .vb2b .b2b-hero h1{font-size:32px}
  .vb2b .b2b-hero p.lead{font-size:15px}
  .vb2b .btn-gold,.vb2b .btn-ghost{padding:14px 22px;font-size:12px}
  .vb2b .b2b-hero-card{padding:24px}
  .vb2b .bhc-form .row2{grid-template-columns:1fr}
  .vb2b .b2b-kpi{margin-top:-48px}
  .vb2b .b2b-kpi-grid{grid-template-columns:1fr 1fr}
  .vb2b .b2b-kpi-card{padding:18px 16px}
  .vb2b .b2b-kpi-card b{font-size:24px}
  .vb2b .section{padding:56px 0}
  .vb2b .sec-head{margin-bottom:36px}
  .vb2b .sec-head h2{font-size:30px}
  .vb2b .bnf-card{padding:28px 22px}
  .vb2b .tier{padding:32px 24px}
  .vb2b .tier .name{font-size:26px}
  .vb2b .steps{grid-template-columns:1fr}
  .vb2b .integ-content h2{font-size:28px}
  .vb2b .integ-logos{padding:24px;gap:8px}
  .vb2b .ind-grid{grid-template-columns:1fr 1fr}
  .vb2b .cta-final{padding:64px 0}
  .vb2b .cta-final h2{font-size:30px}
  .vb2b .cta-final p{font-size:15px}
}

/* ============================================================ */
/* O NAS PAGE — makieta o-nas.html → information/onas.twig      */
/* Wszystkie selektory scoped .vonas. Twarde nadpisania kolizji */
/* globalnych: .hero (grid home), .hero h1 (kolor), .brand      */
/* (loga aspect-ratio 2/1), .sec-head (karta flex+szare tło).   */
/* ============================================================ */
.vonas{background:var(--bg)}

/* ===== HERO ===== */
.vonas .hero{display:block;position:relative;background:linear-gradient(135deg,#0B1B33 0%,#16284A 65%,#1D3360 100%);color:#fff;padding:88px 0 120px;overflow:hidden;min-height:0}
.vonas .hero::before{content:"";position:absolute;inset:0;background:url(../../../../../image/catalog/virsal/asset/_about_band.png) center/cover no-repeat;opacity:.18;mix-blend-mode:luminosity}
.vonas .hero::after{content:"";position:absolute;left:-10%;top:-30%;width:60%;height:140%;background:radial-gradient(closest-side,rgba(227,6,19,.35),transparent 70%);filter:blur(20px);pointer-events:none}
.vonas .hero .row{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center}
.vonas .hero .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:rgba(227,6,19,.18);border:1px solid rgba(227,6,19,.5);padding:8px 14px;border-radius:var(--r-sm);margin-bottom:24px}
.vonas .hero .eyebrow .dot{width:6px;height:6px;background:var(--red);border-radius:50%;box-shadow:0 0 0 4px rgba(227,6,19,.25)}
.vonas .hero h1{font-size:64px;line-height:1.02;letter-spacing:-.03em;margin:0 0 24px;font-weight:900;color:#fff}
.vonas .hero h1 em{color:var(--red);font-style:normal;background:linear-gradient(180deg,#FF4854,#E30613);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vonas .hero p.lead{font-size:18px;line-height:1.65;color:#C7D1E5;margin:0 0 32px;max-width:560px}
.vonas .hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.vonas .btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;padding:14px 24px;border-radius:var(--r);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:13px;transition:all .2s}
.vonas .btn-primary:hover{background:var(--red-600);transform:translateY(-1px);box-shadow:0 12px 28px -8px rgba(227,6,19,.55)}
.vonas .btn-secondary{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);color:#fff;padding:14px 24px;border-radius:var(--r);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:13px;border:1px solid rgba(255,255,255,.18);transition:all .2s}
.vonas .btn-secondary:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.32)}
.vonas .btn-primary svg,.vonas .btn-secondary svg{width:16px;height:16px}
.vonas .hero-card{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);min-height:440px;background:#0B1B33}
.vonas .hero-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.72}
.vonas .hero-card .overlay{position:absolute;left:0;right:0;bottom:0;padding:28px;background:linear-gradient(to top,rgba(11,27,51,.95) 0%,rgba(11,27,51,.4) 70%,transparent 100%);z-index:2}
.vonas .hero-card .overlay b{display:block;font-size:18px;font-weight:800;color:#fff;letter-spacing:.02em;margin-bottom:4px}
.vonas .hero-card .overlay span{font-size:12px;color:#A6B5D2;text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.vonas .hero-card .since{position:absolute;top:24px;right:24px;background:var(--red);color:#fff;padding:14px 18px;border-radius:var(--r);font-weight:900;letter-spacing:.05em;text-align:center;line-height:1;box-shadow:0 12px 28px -10px rgba(227,6,19,.5);z-index:2}
.vonas .hero-card .since b{font-size:28px;display:block;margin-bottom:4px}
.vonas .hero-card .since span{font-size:10px;opacity:.92;text-transform:uppercase;letter-spacing:.08em}

/* ===== KPI STRIP ===== */
.vonas .kpi{background:#fff;border-bottom:1px solid var(--line);position:relative;margin-top:-56px;z-index:3}
.vonas .kpi .container{padding-top:24px;padding-bottom:24px}
.vonas .kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.vonas .kpi-card{padding:28px 24px;border-right:1px solid var(--line);position:relative;transition:background .2s}
.vonas .kpi-card:last-child{border-right:0}
.vonas .kpi-card:hover{background:var(--bg)}
.vonas .kpi-card .ico{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:var(--red-50);color:var(--red);border-radius:var(--r);margin-bottom:14px}
.vonas .kpi-card .ico svg{width:20px;height:20px}
.vonas .kpi-card b{display:block;font-size:36px;font-weight:900;color:var(--ink);letter-spacing:-.03em;line-height:1;margin-bottom:6px}
.vonas .kpi-card span{display:block;font-size:13px;color:var(--ink-500);font-weight:600}

/* ===== SECTION + SECTION HEAD ===== */
.vonas .section{padding:80px 0}
.vonas .section.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.vonas .sec-head{display:block;text-align:center;max-width:760px;margin:0 auto 56px;padding:0;border-bottom:0;background:none}
.vonas .sec-head .eyebrow{display:inline-block;color:var(--red);font-weight:800;font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px}
.vonas .sec-head h2{font-size:44px;font-weight:900;line-height:1.1;letter-spacing:-.025em;margin:0 0 14px;color:var(--ink)}
.vonas .sec-head p{color:var(--ink-500);font-size:16px;margin:0;line-height:1.65}

/* ===== STORY ===== */
.vonas .story-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center}
.vonas .story-img{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:520px;background:#0B1B33;box-shadow:var(--shadow-lg)}
.vonas .story-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.vonas .story-img .badge-stat{position:absolute;left:24px;bottom:24px;background:#fff;padding:18px 24px;border-radius:var(--r);box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
.vonas .story-img .badge-stat .ico{width:40px;height:40px;background:var(--red-50);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--red)}
.vonas .story-img .badge-stat .ico svg{width:22px;height:22px}
.vonas .story-img .badge-stat b{display:block;font-size:18px;font-weight:900;color:var(--ink);line-height:1.1;letter-spacing:-.01em}
.vonas .story-img .badge-stat span{display:block;font-size:11px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.vonas .story-content .eyebrow{color:var(--red);font-weight:800;font-size:12px;letter-spacing:.18em;text-transform:uppercase;display:block;margin-bottom:14px}
.vonas .story-content h2{font-size:44px;line-height:1.1;font-weight:900;letter-spacing:-.025em;margin:0 0 24px;color:var(--ink)}
.vonas .story-content p{font-size:16px;line-height:1.7;color:var(--ink-500);margin:0 0 16px}
.vonas .story-content p strong{color:var(--ink);font-weight:700}
.vonas .timeline{margin-top:32px;border-left:2px solid var(--line);padding-left:24px;display:flex;flex-direction:column;gap:18px;position:relative}
.vonas .tl-item{position:relative}
.vonas .tl-item::before{content:"";position:absolute;left:-31px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--red);border:3px solid #fff;box-shadow:0 0 0 2px var(--red)}
.vonas .tl-item .yr{font-weight:900;color:var(--red);font-size:13px;letter-spacing:.06em;display:block;margin-bottom:2px}
.vonas .tl-item p{font-size:14.5px;margin:0;color:var(--ink-800)}

/* ===== VALUES ===== */
.vonas .values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.vonas .val-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;transition:all .2s;position:relative;overflow:hidden}
.vonas .val-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.vonas .val-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.vonas .val-card:hover::before{transform:scaleX(1)}
.vonas .val-card .ico{width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;background:var(--red-50);color:var(--red);border-radius:var(--r-lg);margin-bottom:20px;transition:all .2s}
.vonas .val-card:hover .ico{background:var(--red);color:#fff;transform:scale(1.05)}
.vonas .val-card .ico svg{width:26px;height:26px}
.vonas .val-card h3{font-size:18px;font-weight:800;margin:0 0 10px;letter-spacing:-.01em;color:var(--ink)}
.vonas .val-card p{font-size:14.5px;line-height:1.6;color:var(--ink-500);margin:0}

/* ===== TEAM ===== */
.vonas .team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.vonas .team-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;display:flex;align-items:center;gap:14px;transition:all .2s;position:relative}
.vonas .team-card:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.vonas .team-card .av{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--ink),var(--ink-800));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;letter-spacing:-.02em;flex-shrink:0;overflow:hidden;border:3px solid var(--bg)}
.vonas .team-card .av img{width:100%;height:100%;object-fit:cover}
.vonas .team-card .body{flex:1;min-width:0}
.vonas .team-card .name{font-size:15px;font-weight:900;color:var(--ink);letter-spacing:-.015em;line-height:1.15;margin-bottom:2px}
.vonas .team-card .role{font-size:11.5px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:block}
.vonas .team-card .lines{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--ink-500)}
.vonas .team-card .lines a{display:inline-flex;align-items:center;gap:6px;color:var(--ink-500);transition:color .15s;word-break:break-all}
.vonas .team-card .lines a:hover{color:var(--red)}
.vonas .team-card .lines svg{width:12px;height:12px;color:var(--red);flex-shrink:0}
.vonas .team-card .lines b{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums}

/* ===== BRANCHES ===== */
.vonas .branches{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vonas .branch-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);transition:all .2s;position:relative}
.vonas .branch-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.vonas .branch-card .map{aspect-ratio:16/9;background:linear-gradient(135deg,#1F4D9C 0%,#1A4290 100%);position:relative;overflow:hidden;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.vonas .branch-card .map img.branch-map-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;display:block}
.vonas .branch-card .map::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:30px 30px;pointer-events:none}
.vonas .branch-card .map svg.poland{width:58%;height:auto;color:rgba(255,255,255,.85);position:relative;z-index:1}
.vonas .branch-card .map .pin{position:absolute;width:30px;height:30px;background:var(--red);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 4px 14px rgba(227,6,19,.6);z-index:2;display:flex;align-items:center;justify-content:center;animation:onasPinBounce 2s ease infinite}
.vonas .branch-card .map .pin::before{content:"";width:10px;height:10px;background:#fff;border-radius:50%;transform:rotate(45deg)}
@keyframes onasPinBounce{0%,100%{transform:rotate(-45deg) translateY(0)}50%{transform:rotate(-45deg) translateY(-4px)}}
.vonas .branch-card .body{padding:24px}
.vonas .branch-card h3{font-size:22px;font-weight:900;margin:0 0 6px;letter-spacing:-.02em;color:var(--ink)}
.vonas .branch-card .addr{color:var(--ink-500);font-size:14px;margin:0 0 16px}
.vonas .branch-card .info{display:flex;flex-direction:column;gap:8px;font-size:13.5px;color:var(--ink-800)}
.vonas .branch-card .info div{display:flex;align-items:center;gap:8px}
.vonas .branch-card .info svg{width:14px;height:14px;color:var(--red);flex-shrink:0}
.vonas .branch-card .links{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}
.vonas .branch-card .links a{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--r-sm);background:var(--bg);font-size:12px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;transition:all .15s}
.vonas .branch-card .links a:hover{background:var(--red);color:#fff}
.vonas .branch-card .links svg{width:13px;height:13px}
.vonas .branch-card .lead-tag{position:absolute;top:14px;right:14px;z-index:2;background:rgba(11,27,51,.85);color:#fff;padding:5px 11px;border-radius:var(--r-sm);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;backdrop-filter:blur(4px)}

/* ===== BRANDS ===== */
.vonas .brands-band{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:48px 0}
.vonas .brands-head{text-align:center;margin-bottom:32px}
.vonas .brands-head .eyebrow{display:inline-block;color:var(--red);font-weight:800;font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.vonas .brands-head h2{font-size:24px;font-weight:800;margin:0;letter-spacing:-.01em;color:var(--ink)}
.vonas .brands-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.vonas .brand{display:block;aspect-ratio:auto;padding:32px 16px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;font-weight:900;font-size:18px;letter-spacing:-.01em;color:var(--ink-500);transition:all .2s;background:#fff}
.vonas .brand:nth-child(8n){border-right:0}
.vonas .brand:nth-last-child(-n+8){border-bottom:0}
.vonas .brand:hover{color:var(--red);background:var(--red-50);transform:scale(1.04)}

/* ===== CERTIFICATES ===== */
.vonas .certs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vonas .cert-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 24px;display:flex;align-items:center;gap:18px;transition:all .2s}
.vonas .cert-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.vonas .cert-card .ico{width:56px;height:56px;flex-shrink:0;background:linear-gradient(135deg,var(--red),#FF4D5C);color:#fff;border-radius:var(--r-lg);display:inline-flex;align-items:center;justify-content:center}
.vonas .cert-card .ico svg{width:28px;height:28px}
.vonas .cert-card b{display:block;font-size:15px;font-weight:800;margin-bottom:2px;letter-spacing:-.01em;color:var(--ink)}
.vonas .cert-card span{display:block;font-size:13px;color:var(--ink-500)}

/* ===== TESTIMONIAL ===== */
.vonas .testimonial{background:linear-gradient(135deg,#0B1B33,#16284A);color:#fff;border-radius:var(--r-lg);padding:56px 64px;display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.vonas .testimonial::before{content:"\201C";position:absolute;left:32px;top:-12px;font-size:240px;color:rgba(227,6,19,.25);font-family:Georgia,serif;line-height:1;font-weight:700}
.vonas .testimonial .quote-mark{font-size:160px;color:var(--red);opacity:.4;font-family:Georgia,serif;line-height:1;font-weight:700;align-self:start}
.vonas .testimonial blockquote{margin:0;font-size:24px;line-height:1.5;font-weight:600;letter-spacing:-.01em;color:#fff}
.vonas .testimonial blockquote::before,.vonas .testimonial blockquote::after{display:none}
.vonas .testimonial cite{display:block;font-style:normal;margin-top:24px;font-size:14px;color:#A6B5D2;font-weight:600}
.vonas .testimonial cite b{color:#fff;font-weight:800;display:block;font-size:15px;margin-bottom:2px}

/* ===== CTA ===== */
.vonas .cta-band{background:#0B1B33;color:#fff;padding:72px 0;position:relative;overflow:hidden}
.vonas .cta-band::before{content:"";position:absolute;right:-10%;top:-30%;width:60%;height:160%;background:radial-gradient(closest-side,rgba(227,6,19,.45),transparent 70%);filter:blur(28px)}
.vonas .cta-band .row{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr .6fr;gap:48px;align-items:center}
.vonas .cta-band h2{font-size:42px;font-weight:900;letter-spacing:-.025em;line-height:1.1;margin:0 0 14px;color:#fff}
.vonas .cta-band p{color:#C7D1E5;font-size:16px;line-height:1.65;margin:0 0 24px;max-width:520px}
.vonas .cta-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.vonas .cta-actions .btn-primary{padding:18px 28px;font-size:14px}
.vonas .cta-actions .btn-secondary{padding:18px 28px;font-size:14px}

/* ===== RESPONSIVE ===== */
@media (max-width:1280px){
  .vonas .values-grid{grid-template-columns:repeat(2,1fr)}
  .vonas .team-grid{grid-template-columns:repeat(2,1fr)}
  .vonas .certs-grid{grid-template-columns:repeat(2,1fr)}
  .vonas .brands-grid{grid-template-columns:repeat(4,1fr)}
  .vonas .brand:nth-child(8n){border-right:1px solid var(--line)}
  .vonas .brand:nth-child(4n){border-right:0}
  .vonas .brand:nth-last-child(-n+8){border-bottom:1px solid var(--line)}
  .vonas .brand:nth-last-child(-n+4){border-bottom:0}
}
@media (max-width:1024px){
  .vonas .hero{padding:64px 0 96px}
  .vonas .hero .row{grid-template-columns:1fr;gap:40px}
  .vonas .hero h1{font-size:48px}
  .vonas .story-grid{grid-template-columns:1fr;gap:40px}
  .vonas .story-img{min-height:380px}
  .vonas .branches{grid-template-columns:1fr}
  .vonas .testimonial{grid-template-columns:1fr;padding:40px}
  .vonas .testimonial .quote-mark{font-size:96px}
  .vonas .cta-band .row{grid-template-columns:1fr;gap:24px}
  .vonas .cta-actions{justify-content:flex-start}
  .vonas .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .vonas .kpi-card:nth-child(3){border-right:0}
  .vonas .kpi-card:nth-child(1),.vonas .kpi-card:nth-child(2),.vonas .kpi-card:nth-child(3){border-bottom:1px solid var(--line)}
}
@media (max-width:768px){
  .vonas .hero{padding:48px 0 80px}
  .vonas .hero h1{font-size:34px}
  .vonas .hero p.lead{font-size:15px}
  .vonas .hero-card{min-height:280px}
  .vonas .hero-card .since b{font-size:22px}
  .vonas .kpi{margin-top:-40px}
  .vonas .kpi-grid{grid-template-columns:1fr 1fr}
  .vonas .kpi-card{padding:18px 16px;border-right:1px solid var(--line) !important;border-bottom:1px solid var(--line)}
  .vonas .kpi-card:nth-child(2n){border-right:0 !important}
  .vonas .kpi-card:nth-last-child(-n+2){border-bottom:0}
  .vonas .kpi-card b{font-size:26px}
  .vonas .section{padding:56px 0}
  .vonas .sec-head{margin-bottom:36px}
  .vonas .sec-head h2{font-size:28px}
  .vonas .story-content h2{font-size:28px}
  .vonas .values-grid{grid-template-columns:1fr;gap:14px}
  .vonas .team-grid{grid-template-columns:1fr 1fr;gap:14px}
  .vonas .certs-grid{grid-template-columns:1fr;gap:12px}
  .vonas .brands-grid{grid-template-columns:repeat(2,1fr)}
  .vonas .brand{padding:22px 10px;font-size:15px;border-right:1px solid var(--line) !important}
  .vonas .brand:nth-child(2n){border-right:0 !important}
  .vonas .testimonial{padding:32px 24px}
  .vonas .testimonial blockquote{font-size:18px}
  .vonas .cta-band h2{font-size:28px}
  .vonas .cta-band{padding:48px 0}
}
@media (max-width:480px){
  .vonas .team-grid{grid-template-columns:1fr}
  .vonas .hero h1{font-size:28px}
  .vonas .sec-head h2{font-size:24px}
  .vonas .story-content h2{font-size:24px}
}
/* === /O NAS PAGE === */

/* ============== BLOG — pojedynczy artykuł (.vart) ============== */
.vart{background:var(--white)}
.vart-hero{padding:48px 0 26px}
.vart-hero .container{max-width:880px}
.vart-cat{display:inline-block;background:var(--red-50);color:var(--red);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:var(--r-sm);margin-bottom:18px}
.vart-hero h1{font-size:38px;line-height:1.18;color:var(--ink);margin:0 0 22px;font-weight:800;letter-spacing:-.02em}
.vart-meta{display:flex;align-items:center;flex-wrap:wrap;gap:13px;color:var(--ink-500);font-size:13.5px}
.vart-meta .author{display:flex;align-items:center;gap:10px}
.vart-meta .author .av{width:38px;height:38px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.vart-meta .author b{color:var(--ink);font-weight:700}
.vart-meta .item{display:inline-flex;align-items:center;gap:6px}
.vart-meta .item svg{width:15px;height:15px;opacity:.7}
.vart-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--ink-300)}
.vart-cover{padding:8px 0 0}
.vart-cover .container{max-width:1060px}
.vart-cover img{width:100%;height:auto;max-height:520px;object-fit:cover;border-radius:var(--r-lg);display:block}
.vart-body{padding:36px 0 64px}
.vart-body .container{max-width:880px}
.vart-prose{color:var(--ink-800);font-size:17px;line-height:1.75}
.vart-prose > *:first-child{margin-top:0}
.vart-prose h1,.vart-prose h2,.vart-prose h3,.vart-prose h4{color:var(--ink);font-weight:800;line-height:1.25;letter-spacing:-.01em}
.vart-prose h1{font-size:30px;margin:34px 0 14px}
.vart-prose h2{font-size:26px;margin:38px 0 14px}
.vart-prose h3{font-size:20px;margin:28px 0 10px}
.vart-prose h4{font-size:17px;margin:22px 0 8px}
.vart-prose p{margin:0 0 18px}
.vart-prose a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
.vart-prose strong{color:var(--ink);font-weight:700}
.vart-prose ul,.vart-prose ol{margin:0 0 18px;padding-left:24px}
.vart-prose li{margin:0 0 8px}
.vart-prose img{max-width:100%;height:auto;border-radius:var(--r);margin:18px 0}
.vart-prose code{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:2px 6px;font-size:14px}
.vart-prose blockquote{margin:22px 0;padding:14px 20px;border-left:3px solid var(--red);background:var(--bg);border-radius:0 var(--r) var(--r) 0;color:var(--ink-500)}
.vart-prose table{width:100%;border-collapse:collapse;margin:22px 0;font-size:14.5px}
.vart-prose th,.vart-prose td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.vart-prose thead th{background:var(--ink);color:#fff;font-weight:700}
.vart-prose tbody tr:nth-child(even){background:var(--bg)}
.vart-back{margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.vart-back a{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-weight:700;text-decoration:none;font-size:14px}
.vart-back a svg{width:18px;height:18px}
.vart-back a:hover{color:var(--red)}
@media (max-width:768px){.vart-hero{padding:30px 0 18px}.vart-hero h1{font-size:27px}.vart-prose{font-size:16px}.vart-prose h2{font-size:22px}}
/* === /BLOG ARTYKUŁ === */

/* ============== DO POBRANIA (.vdl) — port makiety ============== */
.vdl .page-hero{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;padding:42px 0 38px;position:relative;overflow:hidden}
.vdl .page-hero::before{content:"";position:absolute;right:-100px;top:-50px;width:400px;height:400px;background:radial-gradient(circle, rgba(227,6,19,.15) 0%, transparent 70%)}
.vdl .page-hero .row{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:center;position:relative;z-index:2}
.vdl .page-hero h1{font-size:36px;font-weight:900;margin:0 0 12px;letter-spacing:-.025em;line-height:1.1}
.vdl .page-hero h1 em{color:var(--red);font-style:normal}
.vdl .page-hero p{font-size:15px;color:#B4C0D9;margin:0;max-width:580px;line-height:1.6}
.vdl .page-hero .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.vdl .page-hero .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:14px 16px}
.vdl .page-hero .stat b{display:block;font-size:24px;font-weight:900;color:#fff;letter-spacing:-.02em;line-height:1}
.vdl .page-hero .stat span{display:block;font-size:11px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.08em;margin-top:6px;font-weight:700}
.vdl .dl-wrap{padding:36px 0 24px}
.vdl .dl-section{margin-bottom:32px}
.vdl .dl-section .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:18px;flex-wrap:wrap}
.vdl .dl-section h2{margin:0;font-size:22px;font-weight:900;color:var(--ink);letter-spacing:-.015em;display:inline-flex;align-items:center;gap:12px;line-height:1.1}
.vdl .dl-section h2::before{content:"";width:4px;height:26px;background:var(--red);border-radius:2px}
.vdl .dl-section .head .meta{font-size:12.5px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.vdl .dl-section .head .meta b{color:var(--ink);font-weight:800}
.vdl .dl-panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px}
.vdl .dl-grid-cat{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.vdl .dl-grid-form{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.vdl .dl-grid-tbl{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.vdl .dl-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:10px;display:flex;align-items:center;gap:12px;transition:all .15s;cursor:pointer;text-align:left;position:relative;min-height:84px}
.vdl .dl-card:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.vdl .dl-card.catalog .thumb{width:64px;height:80px;flex-shrink:0;background:linear-gradient(135deg,#E8EEF7 0%,#D6DDED 100%);border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:6px;position:relative}
.vdl .dl-card.catalog .thumb img{width:100%;height:100%;object-fit:cover;border-radius:1px}
.vdl .dl-card.catalog .thumb::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);opacity:0;transition:opacity .15s}
.vdl .dl-card.catalog:hover .thumb::after{opacity:1}
.vdl .dl-card .title{flex:1;font-size:13px;font-weight:700;color:var(--ink);line-height:1.35;letter-spacing:-.005em;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-width:0}
.vdl .dl-card .meta-bottom{font-size:11px;color:var(--ink-500);font-weight:600;margin-top:4px;display:flex;align-items:center;gap:6px}
.vdl .dl-card .meta-bottom span::after{content:"·";margin-left:6px;color:var(--ink-300)}
.vdl .dl-card .meta-bottom span:last-child::after{display:none}
.vdl .dl-icon-btn{width:54px;height:64px;background:var(--red);color:#fff;border-radius:var(--r-sm);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;gap:2px;transition:all .2s;position:relative}
.vdl .dl-icon-btn::before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 8px 8px 0;border-color:transparent rgba(0,0,0,.18) transparent transparent}
.vdl .dl-icon-btn svg{width:22px;height:22px}
.vdl .dl-icon-btn .lbl{font-size:9px;font-weight:800;letter-spacing:.06em;line-height:1;margin-top:2px}
.vdl .dl-card:hover .dl-icon-btn{background:var(--red-600);transform:scale(1.05)}
.vdl .dl-icon-btn.doc{background:var(--ink-800)}
.vdl .dl-card:hover .dl-icon-btn.doc{background:var(--ink)}
.vdl .dl-icon-btn.xls{background:var(--green)}
.vdl .dl-card:hover .dl-icon-btn.xls{background:#168552}
.vdl .dl-card.form{padding:14px 14px;min-height:80px}
.vdl .dl-card.form .title{font-size:13px;line-height:1.4}
.vdl .dl-card.tbl{padding:14px 16px;min-height:64px;justify-content:space-between;background:#fff;border-color:var(--line)}
.vdl .dl-card.tbl .title{font-size:12.5px;font-weight:600;color:var(--ink-800);-webkit-line-clamp:3}
.vdl .dl-card.tbl .arrow{color:var(--ink-300);width:18px;height:18px;flex-shrink:0;transition:all .15s}
.vdl .dl-card.tbl:hover{border-color:var(--red);background:var(--red-50)}
.vdl .dl-card.tbl:hover .title{color:var(--ink)}
.vdl .dl-card.tbl:hover .arrow{color:var(--red);transform:translateX(2px)}
.vdl .dl-card.tbl .ico{width:32px;height:32px;background:var(--bg);color:var(--red);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:10px;transition:all .15s}
.vdl .dl-card.tbl .ico svg{width:16px;height:16px}
.vdl .dl-card.tbl:hover .ico{background:#fff;color:var(--red)}
.vdl .contact-cta{background:linear-gradient(90deg,#1F4D9C 0%,#2A5FB7 100%);color:#fff;border-radius:var(--r);padding:20px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin:24px 0 32px;flex-wrap:wrap;box-shadow:0 8px 28px -10px rgba(31,77,156,.4)}
.vdl .contact-cta .ttl{display:flex;align-items:center;gap:14px}
.vdl .contact-cta .ic{width:44px;height:44px;background:rgba(255,255,255,.15);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.vdl .contact-cta .ic svg{width:22px;height:22px;color:#fff}
.vdl .contact-cta b{font-size:15px;font-weight:800;display:block;color:#fff}
.vdl .contact-cta span{font-size:13px;color:rgba(255,255,255,.8);display:block;margin-top:2px}
.vdl .contact-cta .cta-btn{background:#fff;color:var(--ink);padding:12px 22px;border-radius:var(--r);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:10px;transition:all .2s;white-space:nowrap}
.vdl .contact-cta .cta-btn:hover{background:var(--red);color:#fff;transform:translateY(-1px)}
.vdl .contact-cta .cta-btn svg{width:16px;height:16px}
.vdl .help-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:16px 0 32px}
.vdl .help-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;display:flex;flex-direction:column;gap:8px;transition:all .15s}
.vdl .help-card:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.vdl .help-card .ic{width:46px;height:46px;background:var(--red-50);color:var(--red);border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;margin-bottom:6px}
.vdl .help-card .ic svg{width:22px;height:22px}
.vdl .help-card b{font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.vdl .help-card p{margin:4px 0 0;font-size:13px;color:var(--ink-500);line-height:1.5}
.vdl .help-card a{color:var(--red);font-weight:700;font-size:12.5px;margin-top:8px;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.05em}
.vdl .help-card a:hover{gap:10px}
.vdl .marquee{background:var(--red);color:#fff;overflow:hidden;position:relative;padding:20px 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);margin-top:32px}
.vdl .marquee::before,.vdl .marquee::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.vdl .marquee::before{left:0;background:linear-gradient(90deg,var(--red),transparent)}
.vdl .marquee::after{right:0;background:linear-gradient(270deg,var(--red),transparent)}
.vdl .marquee-track{display:flex;align-items:center;gap:60px;white-space:nowrap;animation:vdl-scroll 32s linear infinite;width:max-content}
.vdl .marquee:hover .marquee-track{animation-play-state:paused}
.vdl .marquee-item{display:inline-flex;align-items:center;gap:14px;font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.08em;color:#fff}
.vdl .marquee-item svg{width:24px;height:24px;flex-shrink:0;color:#fff;opacity:.95}
.vdl .marquee-item .dot{width:6px;height:6px;border-radius:50%;background:#fff;opacity:.5}
.vdl .marquee-item span.amt{font-weight:700;color:#FFE2E4}
@keyframes vdl-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (max-width:1240px){
  .vdl .dl-grid-cat{grid-template-columns:repeat(3,1fr)}
  .vdl .dl-grid-form{grid-template-columns:repeat(4,1fr)}
  .vdl .dl-grid-tbl{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:1024px){
  .vdl .page-hero .row{grid-template-columns:1fr}
  .vdl .page-hero .stats{margin-top:8px}
  .vdl .help-row{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .vdl .page-hero{padding:30px 0 26px}
  .vdl .page-hero h1{font-size:26px}
  .vdl .page-hero p{font-size:14px}
  .vdl .page-hero .stats{grid-template-columns:repeat(3,1fr);gap:8px}
  .vdl .page-hero .stat{padding:10px 12px}
  .vdl .page-hero .stat b{font-size:18px}
  .vdl .dl-section h2{font-size:18px}
  .vdl .dl-grid-cat{grid-template-columns:repeat(2,1fr)}
  .vdl .dl-grid-form{grid-template-columns:repeat(2,1fr)}
  .vdl .dl-grid-tbl{grid-template-columns:repeat(2,1fr)}
  .vdl .contact-cta{padding:16px 20px;text-align:left}
  .vdl .contact-cta .cta-btn{width:100%;justify-content:center}
  .vdl .help-row{grid-template-columns:1fr}
  .vdl .marquee-item{font-size:13px;gap:10px}
  .vdl .marquee-item svg{width:18px;height:18px}
}
@media (max-width:480px){
  .vdl .dl-grid-cat,.vdl .dl-grid-form,.vdl .dl-grid-tbl{grid-template-columns:1fr}
  .vdl .page-hero h1{font-size:22px}
}
/* === /DO POBRANIA === */

/* ============== KONFIGURATORY PAGE (.vkonf) ============== */
.vkonf{background:var(--bg)}
/* PAGE HERO */
.vkonf .page-hero{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;padding:48px 0 42px;position:relative;overflow:hidden}
.vkonf .page-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle, rgba(255,255,255,.06) 1px, transparent 1px);background-size:24px 24px;pointer-events:none}
.vkonf .page-hero::after{content:"";position:absolute;right:-150px;top:-100px;width:500px;height:500px;background:radial-gradient(circle, rgba(227,6,19,.18) 0%, transparent 60%);pointer-events:none}
.vkonf .page-hero .row{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;align-items:center;position:relative;z-index:2}
.vkonf .page-hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(227,6,19,.18);color:#FFB3B7;padding:6px 14px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.vkonf .page-hero .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:vkpulse 2s ease infinite}
@keyframes vkpulse{0%,100%{opacity:1}50%{opacity:.5}}
.vkonf .page-hero h1{font-size:38px;font-weight:900;margin:0 0 14px;letter-spacing:-.025em;line-height:1.1}
.vkonf .page-hero h1 em{color:var(--red);font-style:normal}
.vkonf .page-hero p{font-size:15px;color:#B4C0D9;margin:0;max-width:580px;line-height:1.6}
.vkonf .page-hero .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.vkonf .page-hero .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:16px 18px;text-align:center}
.vkonf .page-hero .stat b{display:block;font-size:28px;font-weight:900;color:#fff;letter-spacing:-.02em;line-height:1}
.vkonf .page-hero .stat span{display:block;font-size:11px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.08em;margin-top:6px;font-weight:700}
/* CONFIGURATORS GRID */
.vkonf .cfg-wrap{padding:36px 0 28px}
.vkonf .cfg-section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:18px;flex-wrap:wrap}
.vkonf .cfg-section-head h2{margin:0;font-size:22px;font-weight:900;color:var(--ink);letter-spacing:-.015em;display:inline-flex;align-items:center;gap:12px;line-height:1.1}
.vkonf .cfg-section-head h2::before{content:"";width:4px;height:26px;background:var(--red);border-radius:2px}
.vkonf .cfg-section-head .meta{font-size:12.5px;color:var(--ink-500);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.vkonf .cfg-section-head .meta b{color:var(--ink);font-weight:800}
.vkonf .cfg-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vkonf .cfg-card{position:relative;display:grid;grid-template-columns:84px 1fr 84px;align-items:center;gap:14px;background:linear-gradient(135deg,var(--ink) 0%,var(--ink-800) 100%);color:#fff;border-radius:var(--r);padding:26px 26px;min-height:108px;cursor:pointer;overflow:hidden;border:2px solid transparent;transition:all .25s;text-align:left}
.vkonf .cfg-card::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle, rgba(255,255,255,.07) 1.2px, transparent 1.2px);background-size:20px 20px;opacity:.7;transition:opacity .3s;pointer-events:none}
.vkonf .cfg-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--red);transform:scaleY(0);transform-origin:center;transition:transform .25s}
.vkonf .cfg-card:hover{background:linear-gradient(135deg,#0E1F3C 0%,#1A2D52 100%);border-color:var(--red);transform:translateY(-3px);box-shadow:0 18px 40px -14px rgba(11,27,51,.6), 0 0 0 1px rgba(227,6,19,.2)}
.vkonf .cfg-card:hover::before{opacity:1}
.vkonf .cfg-card:hover::after{transform:scaleY(1)}
.vkonf .cfg-card .ico{width:80px;height:80px;display:flex;align-items:center;justify-content:center;position:relative;z-index:2;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);color:#fff;transition:all .3s}
.vkonf .cfg-card .ico svg{width:40px;height:40px;stroke-width:1.6;transition:transform .3s, color .3s}
.vkonf .cfg-card:hover .ico{background:var(--red);border-color:var(--red);color:#fff;transform:scale(1.05)}
.vkonf .cfg-card:hover .ico svg{transform:rotate(-8deg)}
.vkonf .cfg-card .ico-mirror{width:80px;height:80px;display:flex;align-items:center;justify-content:center;position:relative;z-index:2;color:rgba(255,255,255,.18);transition:all .3s;justify-self:end}
.vkonf .cfg-card .ico-mirror svg{width:40px;height:40px;stroke-width:1.6;transform:scaleX(-1);transition:transform .3s, color .3s}
.vkonf .cfg-card:hover .ico-mirror{color:rgba(227,6,19,.5)}
.vkonf .cfg-card:hover .ico-mirror svg{transform:scaleX(-1) rotate(8deg)}
.vkonf .cfg-card .body{position:relative;z-index:2;text-align:center;min-width:0}
.vkonf .cfg-card .label{display:block;font-size:11px;color:#B4C0D9;text-transform:uppercase;letter-spacing:.12em;font-weight:800;margin-bottom:6px;transition:color .25s}
.vkonf .cfg-card:hover .label{color:#FFB3B7}
.vkonf .cfg-card .ttl{display:block;font-size:22px;font-weight:900;color:#fff;letter-spacing:-.015em;line-height:1.1;text-transform:uppercase}
.vkonf .cfg-card .sub{display:block;font-size:12.5px;color:#B4C0D9;font-weight:600;margin-top:6px}
.vkonf .cfg-card .sub b{color:#fff;font-weight:800}
/* HOW IT WORKS */
.vkonf .how-section{padding:36px 0 8px}
.vkonf .how-section .head{text-align:center;margin-bottom:28px}
.vkonf .how-section .eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px}
.vkonf .how-section .eyebrow::before,.vkonf .how-section .eyebrow::after{content:"";width:24px;height:2px;background:var(--red)}
.vkonf .how-section h2{margin:0;font-size:28px;font-weight:900;color:var(--ink);letter-spacing:-.02em}
.vkonf .how-section .lead{margin:8px auto 0;font-size:15px;color:var(--ink-500);max-width:620px}
.vkonf .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative}
.vkonf .steps::before{content:"";position:absolute;top:42px;left:80px;right:80px;height:2px;background:repeating-linear-gradient(90deg,var(--ink-300) 0,var(--ink-300) 6px,transparent 6px,transparent 12px);z-index:1}
.vkonf .step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;position:relative;z-index:2;transition:all .2s}
.vkonf .step:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.vkonf .step .num{width:44px;height:44px;border-radius:50%;background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;font-variant-numeric:tabular-nums;letter-spacing:-.02em;margin-bottom:6px;border:5px solid var(--bg);box-shadow:0 0 0 2px var(--red)}
.vkonf .step h3{margin:0;font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.005em}
.vkonf .step p{margin:0;font-size:13px;color:var(--ink-500);line-height:1.5}
/* CONTACT CTA */
.vkonf .contact-cta{background:linear-gradient(90deg,#1F4D9C 0%,#2A5FB7 100%);color:#fff;border-radius:var(--r);padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin:36px 0 0;flex-wrap:wrap;box-shadow:0 8px 28px -10px rgba(31,77,156,.4)}
.vkonf .contact-cta .ttl{display:flex;align-items:center;gap:14px}
.vkonf .contact-cta .ic{width:46px;height:46px;background:rgba(255,255,255,.15);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.vkonf .contact-cta .ic svg{width:22px;height:22px;color:#fff}
.vkonf .contact-cta b{font-size:15px;font-weight:800;display:block;color:#fff}
.vkonf .contact-cta span{font-size:13px;color:rgba(255,255,255,.8);display:block;margin-top:2px}
.vkonf .contact-cta .cta-btn{background:#fff;color:var(--ink);padding:13px 24px;border-radius:var(--r);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:10px;transition:all .2s;white-space:nowrap}
.vkonf .contact-cta .cta-btn:hover{background:var(--red);color:#fff;transform:translateY(-1px)}
.vkonf .contact-cta .cta-btn svg{width:16px;height:16px}
/* RESPONSIVE */
@media (max-width:1024px){
  .vkonf .page-hero .row{grid-template-columns:1fr;gap:24px}
  .vkonf .cfg-card{padding:22px 20px;grid-template-columns:64px 1fr 64px;min-height:96px}
  .vkonf .cfg-card .ico,.vkonf .cfg-card .ico-mirror{width:64px;height:64px}
  .vkonf .cfg-card .ico svg,.vkonf .cfg-card .ico-mirror svg{width:32px;height:32px}
  .vkonf .cfg-card .ttl{font-size:18px}
  .vkonf .steps{grid-template-columns:repeat(2,1fr);gap:14px}
  .vkonf .steps::before{display:none}
}
@media (max-width:768px){
  .vkonf .page-hero{padding:32px 0 28px}
  .vkonf .page-hero h1{font-size:26px}
  .vkonf .page-hero p{font-size:14px}
  .vkonf .page-hero .stats{gap:8px}
  .vkonf .page-hero .stat{padding:12px 10px}
  .vkonf .page-hero .stat b{font-size:20px}
  .vkonf .page-hero .stat span{font-size:10px}
  .vkonf .cfg-grid{grid-template-columns:1fr;gap:10px}
  .vkonf .cfg-card{grid-template-columns:56px 1fr 36px;gap:12px;padding:18px;min-height:84px}
  .vkonf .cfg-card .ico,.vkonf .cfg-card .ico-mirror{width:56px;height:56px}
  .vkonf .cfg-card .ico-mirror{width:36px;height:36px}
  .vkonf .cfg-card .ico svg,.vkonf .cfg-card .ico-mirror svg{width:26px;height:26px}
  .vkonf .cfg-card .ico-mirror svg{width:18px;height:18px}
  .vkonf .cfg-card .body{text-align:left}
  .vkonf .cfg-card .ttl{font-size:16px}
  .vkonf .cfg-card .sub{font-size:11.5px}
  .vkonf .cfg-card .label{font-size:10px}
  .vkonf .how-section h2{font-size:22px}
  .vkonf .steps{grid-template-columns:1fr;gap:10px}
  .vkonf .step{padding:20px 18px;flex-direction:row;text-align:left;gap:16px}
  .vkonf .step .num{margin-bottom:0;flex-shrink:0}
  .vkonf .contact-cta{padding:18px 20px}
  .vkonf .contact-cta .cta-btn{width:100%;justify-content:center}
}
@media (max-width:480px){
  .vkonf .page-hero h1{font-size:22px}
  .vkonf .page-hero .stats{grid-template-columns:1fr;gap:6px}
}
/* === /KONFIGURATORY PAGE === */

/* ============================================================ */
/* SEO MIASTO (landing) — makieta seo-miasto-*.html → twig      */
/* Reużywa .kontakt-page (page-hero, quick, faq, marquee).      */
/* Tu tylko NOWE klasy, wszystkie scoped .kontakt-page.         */
/* ============================================================ */
.kontakt-page .lsec{padding:38px 0 6px}
.kontakt-page .lsec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:18px;flex-wrap:wrap}
.kontakt-page .lsec-head .ttl{display:flex;flex-direction:column;gap:4px}
.kontakt-page .lsec-head .eyebrow{display:block;font-size:12px;color:var(--red);font-weight:800;text-transform:uppercase;letter-spacing:.12em}
.kontakt-page .lsec-head h2{margin:0;font-size:26px;font-weight:900;letter-spacing:-.02em;color:var(--ink)}
.kontakt-page .lsec-head p{font-size:13.5px;color:var(--ink-500);margin:0;max-width:560px;line-height:1.55;text-align:right}

.kontakt-page .local-lead{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 30px;box-shadow:var(--shadow-sm)}
.kontakt-page .local-lead p{margin:0 0 12px;font-size:14.5px;color:var(--ink-500);line-height:1.75}
.kontakt-page .local-lead p:last-child{margin-bottom:0}
.kontakt-page .local-lead b{color:var(--ink);font-weight:700}
.kontakt-page .local-lead .kw{color:var(--red);font-weight:700}

/* OFFER GRID */
.kontakt-page .offer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kontakt-page .offer-tile{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;display:flex;flex-direction:column;gap:11px;transition:all .2s;position:relative;overflow:hidden}
.kontakt-page .offer-tile:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}
.kontakt-page .offer-tile .ic{width:46px;height:46px;border-radius:var(--r);background:var(--red-50);color:var(--red);display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.kontakt-page .offer-tile:hover .ic{background:var(--red);color:#fff}
.kontakt-page .offer-tile .ic svg{width:24px;height:24px}
.kontakt-page .offer-tile h3{margin:0;font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.kontakt-page .offer-tile p{margin:0;font-size:12.5px;color:var(--ink-500);line-height:1.55;flex:1}
.kontakt-page .offer-tile .go{font-size:11.5px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:6px}
.kontakt-page .offer-tile .go svg{width:13px;height:13px;transition:transform .15s}
.kontakt-page .offer-tile:hover .go svg{transform:translateX(3px)}

/* SERVICES GRID */
.kontakt-page .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.kontakt-page .svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;gap:12px;transition:all .2s}
.kontakt-page .svc-card:hover{border-color:var(--ink);box-shadow:0 0 0 4px rgba(11,27,51,.06),0 10px 26px rgba(11,27,51,.12);transform:translateY(-3px)}
.kontakt-page .svc-card.feature{background:linear-gradient(135deg,var(--ink),var(--ink-800));border-color:transparent}
.kontakt-page .svc-card .ic{width:44px;height:44px;border-radius:var(--r);background:var(--bg);color:var(--red);display:inline-flex;align-items:center;justify-content:center}
.kontakt-page .svc-card.feature .ic{background:rgba(255,255,255,.1);color:#fff}
.kontakt-page .svc-card .ic svg{width:22px;height:22px}
.kontakt-page .svc-card h3{margin:0;font-size:15.5px;font-weight:800;color:var(--ink);letter-spacing:-.01em;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.kontakt-page .svc-card.feature h3{color:#fff}
.kontakt-page .svc-card .tag{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;background:var(--red);color:#fff;padding:3px 9px;border-radius:999px}
.kontakt-page .svc-card p{margin:0;font-size:13px;color:var(--ink-500);line-height:1.6;flex:1}
.kontakt-page .svc-card.feature p{color:#B4C0D9}
.kontakt-page .svc-card .slink{font-size:11.5px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:6px}
.kontakt-page .svc-card.feature .slink{color:#fff}
.kontakt-page .svc-card .slink svg{width:13px;height:13px}

/* OPIEKUN */
.kontakt-page .opiekun-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;align-items:stretch}
.kontakt-page .opiekun-card{background:linear-gradient(135deg,var(--ink),var(--ink-800));color:#fff;border-radius:var(--r);padding:30px 32px;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:20px}
.kontakt-page .opiekun-card::before{content:"";position:absolute;right:-120px;top:-90px;width:380px;height:380px;background:radial-gradient(circle,rgba(227,6,19,.22),transparent 60%);pointer-events:none}
.kontakt-page .opiekun-card .who{display:flex;align-items:center;gap:18px;position:relative;z-index:2}
.kontakt-page .opiekun-card .av{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--red-600));display:inline-flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:#fff;flex-shrink:0;border:3px solid rgba(255,255,255,.15);letter-spacing:-.02em}
.kontakt-page .opiekun-card .who .nm{font-size:22px;font-weight:900;letter-spacing:-.02em;line-height:1.1}
.kontakt-page .opiekun-card .who .role{font-size:12px;color:#FFB3B7;font-weight:800;text-transform:uppercase;letter-spacing:.07em;margin-top:7px;display:block}
.kontakt-page .opiekun-card .who .sub{font-size:12.5px;color:#B4C0D9;margin-top:5px;display:block}
.kontakt-page .opiekun-lines{display:flex;flex-direction:column;gap:10px;position:relative;z-index:2}
.kontakt-page .opiekun-lines a{display:flex;align-items:center;gap:14px;padding:13px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);color:#fff;transition:all .2s}
.kontakt-page .opiekun-lines a:hover{background:rgba(255,255,255,.12);border-color:rgba(227,6,19,.5)}
.kontakt-page .opiekun-lines a svg{width:18px;height:18px;color:var(--red);flex-shrink:0}
.kontakt-page .opiekun-lines a .lbl{font-size:10.5px;color:#B4C0D9;font-weight:700;text-transform:uppercase;letter-spacing:.05em;display:block}
.kontakt-page .opiekun-lines a b{font-size:15px;font-weight:800;font-variant-numeric:tabular-nums;display:block;margin-top:2px}
.kontakt-page .opiekun-note{position:relative;z-index:2;font-size:11px;color:#8FA0BC;line-height:1.55;border-top:1px solid rgba(255,255,255,.1);padding-top:14px}
.kontakt-page .opiekun-side{display:flex;flex-direction:column;gap:14px}
.kontakt-page .coverage-card,.kontakt-page .nearby-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px}
.kontakt-page .coverage-card h3,.kontakt-page .nearby-card h3{margin:0 0 14px;font-size:13px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:2px solid var(--red)}
.kontakt-page .coverage-card h3 svg,.kontakt-page .nearby-card h3 svg{width:14px;height:14px;color:var(--red)}
.kontakt-page .powiaty{display:flex;flex-wrap:wrap;gap:6px}
.kontakt-page .powiaty span{font-size:11.5px;font-weight:700;color:var(--ink-800);background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:5px 11px}
.kontakt-page .nearby-card .addr{font-size:13px;color:var(--ink-500);line-height:1.6}
.kontakt-page .nearby-card .addr b{color:var(--ink);font-weight:800}
.kontakt-page .nearby-card .mini-map{aspect-ratio:16/9;margin-top:14px;border-radius:var(--r);overflow:hidden;background:linear-gradient(135deg,#1F4D9C,#1A4290);position:relative;display:flex;align-items:center;justify-content:center}
.kontakt-page .nearby-card .mini-map::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:24px 24px}
.kontakt-page .nearby-card .mini-map .poland{width:58%;color:rgba(255,255,255,.85);position:relative;z-index:1}
.kontakt-page .nearby-card .mini-map .pin{position:absolute;width:26px;height:26px;background:var(--red);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 4px 12px rgba(227,6,19,.6);z-index:2}
.kontakt-page .nearby-card .mini-map .pin::after{content:"";position:absolute;left:8px;top:8px;width:10px;height:10px;background:#fff;border-radius:50%;transform:rotate(45deg)}
.kontakt-page .nearby-card .mini-map img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;display:block}
.kontakt-page .nearby-card .nb-cta{display:flex;gap:6px;margin-top:14px}
.kontakt-page .nearby-card .nb-cta a{flex:1;text-align:center;padding:10px;border-radius:var(--r-sm);font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;transition:all .15s}
.kontakt-page .nearby-card .nb-cta a.primary{background:var(--ink);color:#fff}
.kontakt-page .nearby-card .nb-cta a.primary:hover{background:var(--red)}
.kontakt-page .nearby-card .nb-cta a.ghost{background:var(--bg);color:var(--ink-800);border:1px solid var(--line)}
.kontakt-page .nearby-card .nb-cta a.ghost:hover{border-color:var(--red);color:var(--red)}

/* CITIES STRIP */
.kontakt-page .cities-strip{display:flex;flex-wrap:wrap;gap:8px}
.kontakt-page .cities-strip a{display:inline-block;padding:8px 14px;background:#fff;border:1px solid var(--line);color:var(--ink-800);border-radius:999px;font-size:12.5px;font-weight:700;transition:all .15s}
.kontakt-page .cities-strip a:hover{border-color:var(--red);color:var(--red)}
.kontakt-page .cities-strip a.active{background:var(--red);border-color:var(--red);color:#fff}

/* RESPONSIVE (nowe siatki) */
@media (max-width:1240px){
  .kontakt-page .offer-grid{grid-template-columns:repeat(2,1fr)}
  .kontakt-page .svc-grid{grid-template-columns:1fr 1fr}
  .kontakt-page .opiekun-grid{grid-template-columns:1fr}
}
@media (max-width:1024px){
  .kontakt-page .lsec-head p{text-align:left}
}
@media (max-width:768px){
  .kontakt-page .offer-grid{grid-template-columns:1fr}
  .kontakt-page .svc-grid{grid-template-columns:1fr}
  .kontakt-page .opiekun-card{padding:24px 20px}
  .kontakt-page .opiekun-card .who{flex-direction:column;text-align:center;align-items:center}
  .kontakt-page .lsec-head h2{font-size:20px}
}
/* === /SEO MIASTO === */

/* ===== Polityka prywatnosci - tabele RODO (info_id=3) ===== */
.info-content table.tabelaprywatnosci{width:100%;border-collapse:collapse;margin:20px 0 28px;font-size:14.5px;line-height:1.55;color:var(--ink-800)}
.info-content table.tabelaprywatnosci th,
.info-content table.tabelaprywatnosci td{border:1px solid var(--line);padding:12px 14px;text-align:left;vertical-align:top}
.info-content table.tabelaprywatnosci th{background:var(--ink);color:#fff;font-weight:700;font-size:13.5px;letter-spacing:.01em}
.info-content table.tabelaprywatnosci tbody tr:nth-child(even){background:var(--bg)}
.info-content table.tabelaprywatnosci td span,
.info-content table.tabelaprywatnosci th span{font-size:inherit !important}