:root{
  --bg:#F3F4F5; --surface:#FFFFFF; --ink:#26292D; --text:#282B2F;
  --green:#C8102E; --green-d:#A20C24; --brass:#C8102E; --beige:#ECEEF0;
  --line:#DBDEE2; --muted:#6A7077; --shadow:0 8px 30px rgba(38,41,45,.08);
  --shadow-lg:0 18px 50px rgba(38,41,45,.14); --radius:8px; --radius-sm:4px;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;color:var(--ink);font-weight:600;line-height:1.12;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:14px}
.eyebrow.brass{color:var(--brass)}
.tabnum{font-variant-numeric:tabular-nums}

/* proto bar */
.protobar{background:var(--ink);color:#E6E8EA;font-size:12px;letter-spacing:.04em;text-align:center;padding:6px 16px;position:sticky;top:0;z-index:200;border-bottom:1px solid rgba(200,16,46,.45)}
.protobar b{color:var(--brass);font-weight:600}

/* header */
.hdr{position:sticky;top:0;z-index:150;background:rgba(38,41,45,.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(200,16,46,.22);transition:background .3s}
.hdr-logo{display:flex;align-items:center;gap:12px;cursor:pointer}
.hdr-in{display:flex;align-items:center;gap:28px;height:74px}
.logo{height:38px;width:auto}
.logo-txt{font-family:'Fraunces';color:#fff;font-size:20px;font-weight:600;letter-spacing:.01em;white-space:nowrap}
.logo-txt b{color:var(--brass)}
.logo-plate{display:inline-flex;align-items:center;background:#fff;border-radius:10px;padding:6px 12px;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.logo-plate img{height:40px;width:auto;display:block}
.ftr-logo-plate{display:inline-flex;align-items:center;background:#fff;border-radius:10px;padding:7px 14px;box-shadow:0 4px 14px rgba(0,0,0,.2);margin-bottom:16px}
.ftr-logo-plate img{height:44px;width:auto;display:block}
.nav{display:flex;gap:4px;margin-left:auto;align-items:center}
.nav a{color:#D8D8D8;font-size:14px;font-weight:500;padding:9px 13px;border-radius:6px;transition:.2s;white-space:nowrap}
.nav a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav a.active{color:var(--brass)}
.hdr-cta{display:flex;align-items:center;gap:14px;margin-left:6px}
.phone-link{color:#fff;font-weight:600;font-size:14px;display:flex;align-items:center;gap:7px;white-space:nowrap}
.phone-link svg{stroke:var(--brass)}
.cart-btn{position:relative;color:#fff;display:flex;align-items:center;padding:8px}
.cart-btn svg{stroke:#fff}
.cart-badge{position:absolute;top:-2px;right:-4px;background:var(--green);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.burger{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:6px}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:15px;padding:14px 28px;border-radius:var(--radius-sm);transition:.22s;cursor:pointer;border:1.5px solid transparent;line-height:1}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--green);transform:translateY(-1px);box-shadow:0 8px 20px rgba(200,16,46,.28)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-d);transform:translateY(-1px)}
.btn-outline{border-color:var(--line);color:var(--ink);background:transparent}
.btn-outline:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn-ghost-light{border-color:rgba(255,255,255,.5);color:#fff}
.btn-ghost-light:hover{background:#fff;color:var(--ink)}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-block{width:100%}
.btn-brass{background:var(--brass);color:#fff}
.btn-brass:hover{background:#A20C24}

/* views */
.view{display:none;animation:fadeIn .4s ease}
.view.active{display:block}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);animation:slowZoom 18s ease-in-out infinite alternate}
@keyframes slowZoom{to{transform:scale(1.12)}}
.hero-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,29,33,.32) 0%,rgba(26,29,33,.18) 35%,rgba(26,29,33,.82) 100%)}
.hero-in{position:relative;padding:0 0 76px;width:100%}
.hero h1{color:#fff;font-size:clamp(38px,6vw,72px);font-weight:600;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero p{font-size:clamp(16px,2vw,21px);max-width:54ch;margin:22px 0 32px;color:rgba(255,255,255,.92)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(200,16,46,.18);border:1px solid rgba(200,16,46,.5);color:#FBE1E5;padding:7px 15px;border-radius:30px;font-size:13px;font-weight:600;margin-bottom:22px;backdrop-filter:blur(4px)}
.hero-watermark{position:absolute;right:-2%;bottom:8%;width:min(46%,560px);z-index:1;pointer-events:none;filter:brightness(0) invert(1);opacity:.12}
@media(max-width:900px){.hero-watermark{width:70%;right:-6%;bottom:auto;top:14%;opacity:.09}}

/* preloader */
#preloader{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:#FFFFFF;transition:opacity .5s ease}
#preloader.hide{opacity:0;pointer-events:none}
#preloader img{width:min(220px,52vw);height:auto;animation:plPulse 1.6s ease-in-out infinite}
.pl-bar{width:120px;height:3px;border-radius:3px;background:rgba(200,16,46,.18);overflow:hidden}
.pl-bar span{display:block;height:100%;width:40%;border-radius:3px;background:var(--brass);animation:plBar 1.1s ease-in-out infinite}
@keyframes plPulse{0%{transform:scale(.86)}50%{transform:scale(1.06)}100%{transform:scale(.94)}}
@keyframes plBar{0%{transform:translateX(-120%)}100%{transform:translateX(320%)}}
@media(prefers-reduced-motion:reduce){#preloader img{animation:none}.pl-bar span{animation:none}}

/* trust strip */
.trust{background:var(--ink);color:#fff;border-top:1px solid rgba(200,16,46,.25)}
.trust-in{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;padding:22px 0}
.trust-i{display:flex;align-items:center;gap:11px;font-size:14px;font-weight:500;color:#E3E3E3}
.trust-i svg{stroke:var(--brass);flex-shrink:0}

/* section */
.sec{padding:84px 0}
.sec-head{max-width:680px;margin-bottom:46px}
.sec-head.center{margin:0 auto 46px;text-align:center}
.sec-head h2{font-size:clamp(28px,3.6vw,42px)}
.sec-head p{color:var(--muted);font-size:17px;margin-top:14px}

/* category tiles */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat-tile{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;cursor:pointer;background:var(--beige)}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.cat-tile:hover img{transform:scale(1.07)}
.cat-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,29,33,0) 40%,rgba(26,29,33,.85) 100%)}
.cat-tile-c{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2;color:#fff}
.cat-tile-c h3{color:#fff;font-size:19px;margin-bottom:3px}
.cat-tile-c span{font-size:13px;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:6px}
.cat-tile-desc{font-size:12.5px;line-height:1.45;color:rgba(255,255,255,.82);margin:0 0 9px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.cat-tile .pill{position:absolute;top:14px;left:14px;z-index:2;background:rgba(200,16,46,.95);color:#fff;font-size:11px;font-weight:700;padding:5px 11px;border-radius:20px;letter-spacing:.03em}

/* how it works */
.how{background:var(--surface)}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.how-step{position:relative;padding-top:8px}
.how-num{font-family:'Fraunces';font-size:44px;color:var(--beige);font-weight:600;line-height:1}
.how-step h3{font-size:19px;margin:12px 0 8px}
.how-step p{color:var(--muted);font-size:14.5px}
.how-step .ic{width:46px;height:46px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;margin-bottom:14px;border:1px solid var(--line)}
.how-step .ic svg{stroke:var(--green)}

/* config promo split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--ink);border-radius:14px;overflow:hidden;color:#fff}
.split-l{padding:54px}
.split-l .eyebrow{color:var(--brass)}
.split-l h2{color:#fff;font-size:34px;margin-bottom:16px}
.split-l p{color:rgba(255,255,255,.8);margin-bottom:26px}
.split-l ul{list-style:none;margin-bottom:30px}
.split-l li{display:flex;gap:11px;align-items:center;padding:7px 0;font-size:15px;color:#E3E3E3}
.split-l li svg{stroke:var(--brass);flex-shrink:0}
.split-r{background-size:cover;background-position:center;min-height:420px;position:relative}
.split-mock{position:absolute;inset:auto 24px 24px auto;background:rgba(255,255,255,.97);border-radius:10px;padding:18px;width:230px;box-shadow:var(--shadow-lg);color:var(--text)}
.split-mock .lab{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.split-mock .price{font-family:'Fraunces';font-size:30px;color:var(--ink);font-weight:600;margin:2px 0 4px}
.split-mock .row{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;border-top:1px solid var(--line);color:var(--muted)}

/* product cards */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.26s;cursor:pointer;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.pcard-img{aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--beige)}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pcard:hover .pcard-img img{transform:scale(1.06)}
.pcard-badge{position:absolute;top:12px;left:12px;background:var(--green);color:#fff;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px}
.pcard-badge.brass{background:var(--brass);color:#fff}
.pcard-b{padding:18px;display:flex;flex-direction:column;flex:1}
.pcard-cat{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.pcard-b h3{font-size:17px;margin-bottom:8px;line-height:1.2}
.pcard-spec{font-size:13px;color:var(--muted);margin-bottom:14px;flex:1}
.pcard-price{display:flex;align-items:baseline;gap:7px;margin-top:auto}
.pcard-price .v{font-family:'Fraunces';font-size:23px;color:var(--ink);font-weight:600}
.pcard-price .u{font-size:13px;color:var(--muted)}
.pcard-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.pcard-raty{font-size:12px;color:var(--green);font-weight:600}

/* realizacje strip */
.gal-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.gal-strip .g{aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:pointer}
.gal-strip .g img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gal-strip .g:hover img{transform:scale(1.1)}

/* reviews */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.rev-stars{color:var(--brass);font-size:17px;letter-spacing:2px;margin-bottom:14px}
.rev-card p{font-size:15px;color:var(--text);margin-bottom:18px;font-style:italic}
.rev-meta{display:flex;align-items:center;gap:12px}
.rev-av{width:42px;height:42px;border-radius:50%;background:var(--beige);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--ink);font-family:'Fraunces'}
.rev-meta b{display:block;font-size:14px;color:var(--ink)}
.rev-meta span{font-size:12.5px;color:var(--muted)}

/* cta band */
.cta-band{background:linear-gradient(rgba(26,29,33,.82),rgba(26,29,33,.9)),var(--ink) url('https://ogrodzenia-a-z.pl/wp-content/uploads/2025/09/2-scaled.jpg') center/cover no-repeat;border-radius:14px;padding:60px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-band h2{color:#fff;font-size:clamp(28px,3.6vw,40px);max-width:20ch;margin:0 auto 16px}
.cta-band p{color:rgba(255,255,255,.78);max-width:46ch;margin:0 auto 28px}
.cta-band .hairline{width:60px;height:2px;background:var(--brass);margin:0 auto 22px}

/* footer */
.ftr{background:var(--ink);color:#cfcfcf;padding:68px 0 0}
.ftr-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:48px}
.ftr h4{color:#fff;font-size:15px;margin-bottom:18px;font-family:'Inter';font-weight:600;letter-spacing:.02em}
.ftr-logo{font-family:'Fraunces';color:#fff;font-size:22px;font-weight:600;margin-bottom:16px}
.ftr-logo b{color:var(--brass)}
.ftr p{font-size:14px;color:#9CA3AA;margin-bottom:8px;line-height:1.7}
.ftr ul{list-style:none}
.ftr li{margin-bottom:10px}
.ftr li a{font-size:14px;color:#9CA3AA;transition:.2s}
.ftr li a:hover{color:var(--brass)}
.ftr-contact div{display:flex;gap:10px;font-size:14px;color:#cfcfcf;margin-bottom:12px;align-items:flex-start}
.ftr-contact svg{stroke:var(--brass);flex-shrink:0;margin-top:3px}
.ftr-bot{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#7C828A}
.ftr-bot a{color:#9CA3AA}

/* breadcrumb */
.crumb{font-size:13px;color:var(--muted);padding:22px 0 0}
.crumb a:hover{color:var(--green)}
.crumb b{color:var(--ink);font-weight:500}

/* SHOP layout */
.shop-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin:18px 0 28px}
.shop-top h1{font-size:36px}
.shop-top .meta{font-size:14px;color:var(--muted);margin-top:6px}
.shop-tools{display:flex;align-items:center;gap:12px}
.shop-tools select{padding:10px 14px;border:1px solid var(--line);border-radius:6px;font-family:inherit;font-size:14px;background:#fff;color:var(--text)}
.shop-layout{display:grid;grid-template-columns:268px 1fr;gap:32px;align-items:start;padding-bottom:60px}
.filters{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:6px 22px 22px;position:sticky;top:128px}
.fgroup{padding:20px 0;border-bottom:1px solid var(--line)}
.fgroup:last-child{border-bottom:none}
.fgroup h4{font-family:'Inter';font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);margin-bottom:14px}
.fopt{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:14px;color:var(--text);cursor:pointer}
.fopt input{accent-color:var(--green);width:16px;height:16px;cursor:pointer}
.fopt .cnt{margin-left:auto;font-size:12px;color:var(--muted)}
.ral-swatches{display:flex;flex-wrap:wrap;gap:9px}
.ral-sw{width:34px;height:34px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer;position:relative;transition:.2s}
.ral-sw:hover{transform:scale(1.1)}
.ral-sw.on{box-shadow:0 0 0 2px var(--green)}
.ral-sw.on::after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.range-row{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-top:8px}
input[type=range]{width:100%;accent-color:var(--green)}
.filter-clear{font-size:13px;color:var(--green);font-weight:600;margin-top:4px;cursor:pointer}
.no-res{grid-column:1/-1;text-align:center;padding:60px;color:var(--muted)}

/* mobile filter toggle */
.mfilter-btn{display:none}

/* PDP */
.pdp{display:grid;grid-template-columns:1.15fr 1fr;gap:48px;padding:26px 0 60px;align-items:start}
.pdp-gal-main{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:var(--beige);margin-bottom:12px;position:relative}
.pdp-gal-main img{width:100%;height:100%;object-fit:cover}
.pdp-ral-overlay{position:absolute;inset:0;mix-blend-mode:multiply;opacity:0;transition:opacity .4s}
.pdp-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.pdp-thumb{aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent;background:var(--beige)}
.pdp-thumb.on{border-color:var(--green)}
.pdp-thumb img{width:100%;height:100%;object-fit:cover}
.pdp-info .pcat{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--green);font-weight:600}
.pdp-info h1{font-size:34px;margin:8px 0 12px}
.pdp-usp{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.pdp-usp span{background:var(--beige);color:var(--ink);font-size:12.5px;font-weight:500;padding:6px 12px;border-radius:20px}
.pdp-price-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:22px}
.pdp-price-main{display:flex;align-items:baseline;gap:10px}
.pdp-price-main .v{font-family:'Fraunces';font-size:42px;color:var(--ink);font-weight:600}
.pdp-price-main .u{font-size:15px;color:var(--muted)}
.pdp-price-sub{font-size:14px;color:var(--muted);margin-top:4px}
.pdp-raty{display:inline-flex;align-items:center;gap:7px;background:rgba(200,16,46,.1);color:var(--green-d);font-size:13px;font-weight:600;padding:7px 13px;border-radius:6px;margin-top:14px}
.opt-block{margin-bottom:20px}
.opt-block .lab{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px;display:flex;justify-content:space-between}
.opt-block .lab .val{color:var(--green);font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:9px 16px;border:1.5px solid var(--line);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:.2s;background:#fff}
.chip:hover{border-color:var(--ink)}
.chip.on{border-color:var(--green);background:var(--green);color:#fff}
.calc-box{background:var(--beige);border-radius:var(--radius);padding:20px;margin-bottom:20px}
.calc-box .lab{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px}
.calc-input{display:flex;gap:10px;align-items:center}
.calc-input input{flex:1;padding:12px 14px;border:1.5px solid var(--line);border-radius:6px;font-family:inherit;font-size:15px;background:#fff}
.calc-input input:focus{outline:none;border-color:var(--green)}
.calc-result{margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);font-size:14px}
.calc-result .row{display:flex;justify-content:space-between;padding:4px 0;color:var(--muted)}
.calc-result .row b{color:var(--ink)}
.calc-result .total{font-family:'Fraunces';font-size:24px;color:var(--green-d);font-weight:600}
.pdp-cta{display:flex;gap:12px;margin-bottom:14px}
.pdp-cta .btn{flex:1}
.pdp-note{font-size:12.5px;color:var(--muted);text-align:center}

/* PDP lower sections */
.pdp-sections{padding-bottom:70px}
.bundle{background:var(--ink);border-radius:14px;padding:40px;color:#fff;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center}
.bundle h3{color:#fff;font-size:26px;margin-bottom:10px}
.bundle p{color:rgba(255,255,255,.78);margin-bottom:16px}
.bundle ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px 20px}
.bundle li{font-size:14px;color:#E3E3E3;display:flex;gap:8px;align-items:center}
.bundle li svg{stroke:var(--brass)}
.bundle-price{text-align:right;white-space:nowrap}
.bundle-price .old{color:rgba(255,255,255,.5);text-decoration:line-through;font-size:15px}
.bundle-price .new{font-family:'Fraunces';font-size:34px;color:var(--brass);font-weight:600}
.spec-table{width:100%;border-collapse:collapse}
.spec-table td{padding:13px 16px;font-size:14.5px;border-bottom:1px solid var(--line)}
.spec-table tr td:first-child{color:var(--muted);width:42%}
.spec-table tr td:last-child{color:var(--ink);font-weight:500}
.spec-table tr:nth-child(odd){background:var(--surface)}
.viz{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:30px;text-align:center}
.viz-img{aspect-ratio:16/7;border-radius:var(--radius);overflow:hidden;margin:20px 0;position:relative;background:var(--beige)}
.viz-img img{width:100%;height:100%;object-fit:cover}
.viz-ov{position:absolute;inset:0;mix-blend-mode:multiply;opacity:0;transition:.4s}
.viz-rals{display:flex;justify-content:center;gap:12px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 0;cursor:pointer;font-weight:600;color:var(--ink);font-size:16px}
.faq-q svg{transition:.3s;stroke:var(--green);flex-shrink:0}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--muted);font-size:15px}
.faq-item.open .faq-a{max-height:240px}
.faq-a p{padding:0 0 18px}

/* steps row */
.steps4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step4{text-align:center}
.step4 .ic{width:62px;height:62px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.step4 .ic svg{stroke:var(--green)}
.step4 h3{font-size:18px;margin-bottom:8px}
.step4 p{color:var(--muted);font-size:14px}

/* animated process steps (montaz) */
.steps4-anim{position:relative}
.steps4-anim .step4{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.steps4-anim.play .step4{opacity:1;transform:none}
.steps4-anim.play .step4:nth-child(1){transition-delay:0ms}
.steps4-anim.play .step4:nth-child(2){transition-delay:120ms}
.steps4-anim.play .step4:nth-child(3){transition-delay:240ms}
.steps4-anim.play .step4:nth-child(4){transition-delay:360ms}
.steps4-anim .step4 .ic{transform:scale(.8);transition:transform .55s cubic-bezier(.34,1.56,.64,1)}
.steps4-anim.play .step4 .ic{transform:scale(1)}
.steps4-anim.play .step4:nth-child(1) .ic{transition-delay:80ms}
.steps4-anim.play .step4:nth-child(2) .ic{transition-delay:200ms}
.steps4-anim.play .step4:nth-child(3) .ic{transition-delay:320ms}
.steps4-anim.play .step4:nth-child(4) .ic{transition-delay:440ms}
.steps4-anim.play.floated .step4 .ic{animation:stepFloat 3s ease-in-out infinite}
.steps4-anim.play.floated .step4:nth-child(2) .ic{animation-delay:.4s}
.steps4-anim.play.floated .step4:nth-child(3) .ic{animation-delay:.8s}
.steps4-anim.play.floated .step4:nth-child(4) .ic{animation-delay:1.2s}
@keyframes stepFloat{0%,100%{transform:translateY(-4px)}50%{transform:translateY(4px)}}
/* connecting hairline behind the icon row */
.steps4-anim .steps-line{position:absolute;top:31px;left:12.5%;right:12.5%;height:2px;background:var(--brass);transform:scaleX(0);transform-origin:left center;transition:transform 1s ease .15s;z-index:0;border-radius:2px}
.steps4-anim.play .steps-line{transform:scaleX(1)}
.steps4-anim .step4{position:relative;z-index:1}
@media(max-width:900px){.steps4-anim .steps-line{display:none}}
@media(prefers-reduced-motion:reduce){
  .steps4-anim .step4,.steps4-anim.play .step4,
  .steps4-anim .step4 .ic,.steps4-anim.play .step4 .ic{opacity:1!important;transform:none!important;transition:none!important;animation:none!important}
  .steps4-anim .steps-line,.steps4-anim.play .steps-line{transform:scaleX(1)!important;transition:none!important}
}

/* CONFIGURATOR */
.cfg{padding:24px 0 70px}
.cfg-head{text-align:center;max-width:680px;margin:0 auto 30px}
.cfg-head h1{font-size:clamp(30px,4vw,46px)}
.cfg-head p{color:var(--muted);margin-top:12px}
.cfg-steps{display:flex;justify-content:center;gap:6px;margin-bottom:36px;flex-wrap:wrap}
.cfg-stp{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);padding:8px 12px;border-radius:30px;font-weight:500}
.cfg-stp .n{width:24px;height:24px;border-radius:50%;background:var(--beige);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.cfg-stp.on{color:var(--ink)}
.cfg-stp.on .n{background:var(--green);color:#fff}
.cfg-stp.done .n{background:var(--ink);color:#fff}
.cfg-stp.disabled{opacity:.4;cursor:not-allowed;text-decoration:line-through}
.cfg-stp.disabled .n{background:var(--line);color:var(--muted)}
.cfg-body{display:grid;grid-template-columns:1fr 380px;gap:32px;align-items:start}
.cfg-panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:34px;min-height:440px}
.cfg-panel h2{font-size:26px;margin-bottom:6px}
.cfg-panel .hint{color:var(--muted);font-size:14.5px;margin-bottom:26px}
.cfg-pane{display:none}
.cfg-pane.on{display:block;animation:fadeIn .35s}
.opt-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ocard{border:1.5px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.2s;background:#fff}
.ocard:hover{border-color:var(--ink)}
.ocard.on{border-color:var(--green);box-shadow:0 0 0 1px var(--green)}
.ocard-img{aspect-ratio:4/3;overflow:hidden;background:var(--beige)}
.ocard-img img{width:100%;height:100%;object-fit:cover}
.ocard-b{padding:13px 15px}
.ocard-b h4{font-family:'Inter';font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:3px}
.ocard-b span{font-size:12.5px;color:var(--muted)}
.cfg-grid-in{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cfg-field{margin-bottom:18px}
.cfg-field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:8px}
.cfg-field input,.cfg-field select{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:6px;font-family:inherit;font-size:15px;background:#fff}
.cfg-field input:focus,.cfg-field select:focus{outline:none;border-color:var(--green)}
.cfg-nav{display:flex;justify-content:space-between;margin-top:30px;gap:12px}
.toggle-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.tcard{border:1.5px solid var(--line);border-radius:var(--radius);padding:20px;cursor:pointer;transition:.2s}
.tcard:hover{border-color:var(--ink)}
.tcard.on{border-color:var(--green);box-shadow:0 0 0 1px var(--green)}
.tcard h4{font-family:'Inter';font-size:15px;font-weight:600;margin-bottom:4px}
.tcard span{font-size:13px;color:var(--muted)}
.tcard .pr{font-size:13px;color:var(--green);font-weight:600;margin-top:8px}

/* cfg summary sidebar */
.cfg-sum{background:var(--ink);border-radius:14px;padding:28px;color:#fff;position:sticky;top:128px}
.cfg-sum h3{color:#fff;font-size:19px;margin-bottom:4px;font-family:'Fraunces'}
.cfg-sum .sub{font-size:12.5px;color:rgba(255,255,255,.55);margin-bottom:20px}
.cfg-viz{aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;margin-bottom:18px;position:relative;background:#2f3338}
.cfg-viz img{width:100%;height:100%;object-fit:cover;transition:.4s}
.cfg-viz-ov{position:absolute;inset:0;mix-blend-mode:multiply;opacity:0;transition:.4s}
.cfg-viz-h{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(rgba(20,24,28,0),rgba(20,24,28,.30));transition:height .4s;border-top:1px dashed rgba(255,255,255,.6)}
.cfg-sum-rows{font-size:13.5px}
.cfg-sum-rows .r{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1);color:#cfcfcf}
.cfg-sum-rows .r b{color:#fff;font-weight:500;text-align:right}
.cfg-mat{margin-top:16px;background:rgba(255,255,255,.05);border-radius:8px;padding:14px}
.cfg-mat .h{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--brass);margin-bottom:10px;font-weight:600}
.cfg-mat .m{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:#cfcfcf}
.cfg-total{margin-top:20px;padding-top:18px;border-top:1px solid rgba(200,16,46,.32)}
.cfg-total .lab{font-size:12px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.08em}
.cfg-total .v{font-family:'Fraunces';font-size:38px;color:var(--brass);font-weight:600;line-height:1.1}
.cfg-total .net{font-size:12px;color:rgba(255,255,255,.55)}
.cfg-sum-cta{display:flex;flex-direction:column;gap:10px;margin-top:20px}

/* map mock */
.map-mock{background:repeating-linear-gradient(45deg,#ECEEF0,#ECEEF0 18px,#E2E5E8 18px,#E2E5E8 36px);border:1.5px dashed var(--line);border-radius:var(--radius);aspect-ratio:16/8;display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--muted);position:relative;margin-bottom:20px}
.map-mock .tag{position:absolute;top:14px;left:14px;background:var(--brass);color:var(--ink);font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}
.map-poly{width:55%;height:55%;border:2.5px solid var(--green);background:rgba(200,16,46,.08);border-radius:6px;position:relative}
.map-poly span{position:absolute;background:#fff;border:1px solid var(--green);color:var(--green-d);font-size:12px;font-weight:600;padding:2px 8px;border-radius:4px}

/* DRAWER cart */
.drawer-ov{position:fixed;inset:0;background:rgba(26,29,33,.5);z-index:300;opacity:0;visibility:hidden;transition:.3s}
.drawer-ov.on{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;background:var(--bg);z-index:301;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.drawer.on{transform:translateX(0)}
.drawer-h{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--line);background:var(--surface)}
.drawer-h h3{font-size:20px}
.drawer-close{font-size:24px;color:var(--muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.2s}
.drawer-close:hover{background:var(--beige)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px}
.drawer-foot{padding:22px 24px;border-top:1px solid var(--line);background:var(--surface)}
.ci{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.ci-img{width:78px;height:64px;border-radius:6px;object-fit:cover;background:var(--beige);flex-shrink:0}
.ci-b{flex:1;min-width:0}
.ci-b h4{font-family:'Inter';font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:3px}
.ci-b .sp{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.ci-row{display:flex;justify-content:space-between;align-items:center}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.qty button{width:30px;height:30px;color:var(--ink);font-size:16px;background:#fff;transition:.2s}
.qty button:hover{background:var(--beige)}
.qty span{width:36px;text-align:center;font-size:14px;font-weight:600}
.ci-price{font-family:'Fraunces';font-size:16px;color:var(--ink);font-weight:600}
.ci-rm{font-size:12px;color:var(--muted);cursor:pointer;margin-top:6px}
.ci-rm:hover{color:#b5453a}
.drawer-empty{text-align:center;padding:50px 20px;color:var(--muted)}
.drawer-sum{display:flex;justify-content:space-between;font-size:14px;padding:6px 0;color:var(--muted)}
.drawer-sum.tot{font-size:18px;color:var(--ink);font-weight:600;border-top:1px solid var(--line);padding-top:14px;margin-top:6px;font-family:'Fraunces'}

/* CART page */
.cart-page{display:grid;grid-template-columns:1fr 360px;gap:32px;padding:24px 0 70px;align-items:start}
.cart-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:8px 24px}
.cart-aside{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:sticky;top:128px}
.cart-aside h3{font-size:20px;margin-bottom:18px}
.coupon{display:flex;gap:8px;margin:16px 0}
.coupon input{flex:1;padding:11px 13px;border:1px solid var(--line);border-radius:6px;font-family:inherit;font-size:14px}

/* CHECKOUT */
.chk{padding:24px 0 70px}
.chk-toggle{display:flex;gap:0;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:6px;max-width:640px;margin:0 auto 36px}
.chk-toggle button{flex:1;padding:16px 20px;border-radius:7px;font-weight:600;font-size:15px;color:var(--muted);transition:.25s;text-align:center}
.chk-toggle button.on{background:var(--ink);color:#fff}
.chk-toggle button small{display:block;font-weight:400;font-size:12px;margin-top:3px;opacity:.8}
.chk-body{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}
.chk-tor{display:none}
.chk-tor.on{display:block;animation:fadeIn .35s}
.chk-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px;margin-bottom:22px}
.chk-card h3{font-size:20px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.chk-card h3 .stepn{width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;font-family:'Inter';font-weight:700}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px}
.fld{display:flex;flex-direction:column}
.fld.full{grid-column:1/-1}
.fld label{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:7px}
.fld input,.fld select,.fld textarea{padding:12px 14px;border:1.5px solid var(--line);border-radius:6px;font-family:inherit;font-size:14.5px;background:#fff}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--green)}
.pay-opts{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.pay-opt{display:flex;align-items:center;gap:14px;border:1.5px solid var(--line);border-radius:8px;padding:16px;cursor:pointer;transition:.2s}
.pay-opt:hover{border-color:var(--ink)}
.pay-opt.on{border-color:var(--green);background:rgba(200,16,46,.05)}
.pay-opt input{accent-color:var(--green);width:18px;height:18px}
.pay-opt .pi{font-weight:600;color:var(--ink);font-size:15px}
.pay-opt .pd{font-size:13px;color:var(--muted)}
.pay-opt .pbadge{margin-left:auto;background:var(--beige);font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px;color:var(--ink)}

/* REALIZACJE portfolio */
.rz-filters{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 28px}
.rz-fbtn{padding:9px 18px;border:1.5px solid var(--line);border-radius:30px;font-size:14px;font-weight:500;cursor:pointer;background:#fff;transition:.2s;color:var(--text)}
.rz-fbtn:hover{border-color:var(--ink)}
.rz-fbtn.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.rz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding-bottom:60px}
.rz-item{border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:4/3;background:var(--beige)}
.rz-item img{width:100%;height:100%;object-fit:cover;transition:.5s}
.rz-item:hover img{transform:scale(1.07)}
.rz-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(26,29,33,.8));opacity:0;transition:.3s}
.rz-item:hover::after{opacity:1}
.rz-cap{position:absolute;bottom:0;left:0;right:0;padding:18px;color:#fff;z-index:2;opacity:0;transform:translateY(8px);transition:.3s}
.rz-item:hover .rz-cap{opacity:1;transform:none}
.rz-cap b{font-size:16px;display:block;font-family:'Fraunces'}
.rz-cap span{font-size:13px;color:rgba(255,255,255,.8)}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(15,18,21,.94);z-index:400;display:none;align-items:center;justify-content:center;padding:30px}
.lb.on{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close{position:absolute;top:24px;right:30px;color:#fff;font-size:34px;cursor:pointer;line-height:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:40px;cursor:pointer;padding:20px;user-select:none;opacity:.7;transition:.2s}
.lb-nav:hover{opacity:1}
.lb-prev{left:10px}.lb-next{right:10px}

/* generic content page */
.cpage{padding:30px 0 70px;max-width:820px}
.cpage h1{font-size:clamp(30px,4vw,46px);margin-bottom:8px}
.cpage .lead{font-size:18px;color:var(--muted);margin-bottom:30px}
.cpage h2{font-size:26px;margin:36px 0 14px}
.cpage h3{font-size:20px;margin:26px 0 10px}
.cpage p{margin-bottom:14px;font-size:16px}
.cpage ul{margin:0 0 16px 22px}
.cpage li{margin-bottom:8px}
.placeholder-note{background:var(--beige);border-left:3px solid var(--brass);padding:14px 18px;border-radius:6px;font-size:14px;color:var(--ink);margin-bottom:24px}

/* about stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:40px 0}
.stat{text-align:center;padding:28px 16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.stat .v{font-family:'Fraunces';font-size:42px;color:var(--green-d);font-weight:600;line-height:1}
.stat .l{font-size:13.5px;color:var(--muted);margin-top:8px}
.about-hero{aspect-ratio:21/8;border-radius:14px;overflow:hidden;margin:24px 0 0;background:var(--beige)}
.about-hero img{width:100%;height:100%;object-fit:cover}
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin:50px 0}
.about-split img{border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover}
.about-split h2{font-size:32px;margin-bottom:16px}
.about-split p{color:var(--text);margin-bottom:14px;font-size:16px}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:50px}
.bcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.26s;display:flex;flex-direction:column}
.bcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.bcard-img{aspect-ratio:16/10;overflow:hidden;background:var(--beige)}
.bcard-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.bcard:hover .bcard-img img{transform:scale(1.06)}
.bcard-b{padding:22px;flex:1;display:flex;flex-direction:column}
.bcard-cat{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:10px}
.bcard-b h3{font-size:20px;margin-bottom:10px;line-height:1.25}
.bcard-b p{font-size:14px;color:var(--muted);flex:1}
.bcard-more{font-size:13px;color:var(--green);font-weight:600;margin-top:14px;display:flex;align-items:center;gap:6px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;padding-bottom:60px;align-items:start}
.contact-info .ci-line{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.contact-info .ci-line svg{stroke:var(--green);flex-shrink:0;margin-top:3px}
.contact-info .ci-line b{display:block;color:var(--ink);font-size:15px}
.contact-info .ci-line span{font-size:14px;color:var(--muted)}
.map-embed{margin-top:20px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10}
.map-embed iframe{width:100%;height:100%;border:0}

/* B2B */
.b2b-hero{background:var(--ink);border-radius:14px;padding:54px;color:#fff;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;margin-bottom:50px}
.b2b-hero h1{color:#fff;font-size:38px;margin-bottom:16px}
.b2b-hero p{color:rgba(255,255,255,.8);margin-bottom:20px}
.b2b-hero img{border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover}
.b2b-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:50px}
.b2b-feats-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1000px){.b2b-feats-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.b2b-feats-4{grid-template-columns:1fr}}
.b2b-feat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.b2b-feat .ic{width:48px;height:48px;border-radius:10px;background:var(--beige);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.b2b-feat .ic svg{stroke:var(--green)}
.b2b-feat h3{font-size:18px;margin-bottom:8px}
.b2b-feat p{font-size:14px;color:var(--muted)}
.b2b-feat .feat-photo{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:10px;margin-bottom:18px;display:block;box-shadow:0 6px 18px rgba(38,41,45,.08);transition:transform .5s ease}
.b2b-feat:hover .feat-photo{transform:scale(1.02)}

/* Projekt i konsultacje (montaż) — „dlaczego" karty + 5 etapów */
.proj-why{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.proj-why-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.proj-why-card .ic{width:48px;height:48px;border-radius:10px;background:var(--beige);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.proj-why-card .ic svg{stroke:var(--green)}
.proj-why-card h3{font-size:18px;margin-bottom:8px}
.proj-why-card p{font-size:14px;color:var(--muted)}
.proj-steps{list-style:none;margin:0;padding:0;display:grid;gap:14px;max-width:820px;margin-inline:auto}
.proj-step{display:flex;gap:18px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px}
.proj-step-n{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;font-family:Fraunces,serif;font-size:19px;display:flex;align-items:center;justify-content:center}
.proj-step h3{font-size:18px;margin-bottom:5px}
.proj-step p{font-size:14px;color:var(--muted);margin:0}
@media(max-width:760px){.proj-why{grid-template-columns:1fr}}

/* sticky bottom bar mobile PDP */
.pdp-sticky{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);padding:12px 16px;z-index:120;box-shadow:0 -4px 20px rgba(0,0,0,.08);align-items:center;gap:14px}
.pdp-sticky .p{flex:1}
.pdp-sticky .p .v{font-family:'Fraunces';font-size:22px;color:var(--ink);font-weight:600}
.pdp-sticky .p .u{font-size:12px;color:var(--muted)}

/* toast */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--ink);color:#fff;padding:15px 24px;border-radius:10px;z-index:500;font-size:14.5px;font-weight:500;box-shadow:var(--shadow-lg);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:11px}
.toast.on{transform:translateX(-50%) translateY(0)}
.toast svg{stroke:var(--brass)}

/* before/after slider (WOW) */
.ba-wrap{max-width:900px;margin:0 auto}
.ba{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg);user-select:none;touch-action:none;background:var(--beige)}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-lbl{position:absolute;top:16px;z-index:3;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:rgba(26,29,33,.72);padding:6px 13px;border-radius:30px;backdrop-filter:blur(4px);pointer-events:none}
.ba-lbl.before{left:16px}
.ba-lbl.after{right:16px;background:rgba(200,16,46,.88)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--brass);z-index:4;transform:translateX(-50%);cursor:ew-resize}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--brass);box-shadow:0 6px 18px rgba(38,41,45,.35),0 0 0 4px rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700}
.ba-knob::before{content:'‹ ›';letter-spacing:-1px}

/* quote modal */
.qm-ov{position:fixed;inset:0;background:rgba(26,29,33,.6);z-index:450;opacity:0;visibility:hidden;transition:.3s;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.qm-ov.on{opacity:1;visibility:visible}
.qm{background:var(--surface);border-radius:14px;max-width:640px;width:100%;box-shadow:var(--shadow-lg);transform:translateY(20px);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow:hidden}
.qm-ov.on .qm{transform:none}
.qm-top{background:var(--ink);color:#fff;padding:26px 30px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.qm-top .brand{font-family:'Fraunces';font-size:21px;font-weight:600}
.qm-top .brand b{color:var(--brass)}
.qm-top .sub{font-size:12.5px;color:rgba(255,255,255,.6);margin-top:4px}
.qm-top .meta{font-size:12px;color:rgba(255,255,255,.7);text-align:right;line-height:1.7}
.qm-top .meta a{color:var(--brass)}
.qm-x{position:absolute;top:14px;right:18px;color:#fff;font-size:26px;line-height:1;cursor:pointer;opacity:.8}
.qm-x:hover{opacity:1}
.qm-body{padding:26px 30px}
.qm-body h4{font-family:'Inter';font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin:0 0 12px;font-weight:600}
.qm-tbl{width:100%;border-collapse:collapse;margin-bottom:22px}
.qm-tbl td{padding:9px 4px;font-size:14px;border-bottom:1px solid var(--line)}
.qm-tbl td:first-child{color:var(--muted)}
.qm-tbl td:last-child{text-align:right;color:var(--ink);font-weight:500}
.qm-mat td:last-child{font-variant-numeric:tabular-nums}
.qm-tot{display:flex;justify-content:space-between;align-items:baseline;background:var(--beige);border-radius:10px;padding:16px 18px;margin-bottom:8px}
.qm-tot .l{font-size:13px;color:var(--ink);font-weight:600}
.qm-tot .v{font-family:'Fraunces';font-size:30px;color:var(--green-d);font-weight:600}
.qm-raty{font-size:13px;color:var(--muted);text-align:right;margin-bottom:20px}
.qm-foot{display:flex;gap:12px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:20px}
.qm-note{font-size:11.5px;color:var(--muted);margin-top:14px}
@media print{
  body *{visibility:hidden}
  .qm-ov,.qm-ov *{visibility:visible}
  .qm-ov{position:absolute;background:#fff;padding:0;overflow:visible}
  .qm{box-shadow:none;max-width:100%}
  .qm-x,.qm-foot{display:none}
  .protobar{display:none}
}

/* fade-up */
.fu{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.fu.in{opacity:1;transform:none}

/* mobile menu */
.mmenu{position:fixed;inset:0;background:var(--ink);z-index:180;transform:translateX(100%);transition:transform .35s;padding:90px 30px 30px;overflow-y:auto}
.mmenu.on{transform:none}
.mmenu a{display:block;color:#fff;font-size:20px;font-family:'Fraunces';padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.mmenu .mclose{position:absolute;top:24px;right:24px;color:#fff;font-size:32px}

@media(max-width:1080px){
  .cat-grid,.prod-grid{grid-template-columns:repeat(3,1fr)}
  .gal-strip{grid-template-columns:repeat(4,1fr)}
  .cfg-body{grid-template-columns:1fr}
  .cfg-sum{position:static}
}
@media(max-width:900px){
  .nav,.hdr-cta .phone-link{display:none}
  .burger{display:flex}
  .how-grid,.steps4,.stats,.b2b-feats{grid-template-columns:repeat(2,1fr)}
  .split,.bundle,.about-split,.b2b-hero,.contact-grid{grid-template-columns:1fr}
  .split-r{min-height:300px}
  .pdp{grid-template-columns:1fr}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:static;display:none}
  .filters.mopen{display:block}
  .mfilter-btn{display:inline-flex}
  .cart-page,.chk-body{grid-template-columns:1fr}
  .rev-grid,.rz-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .pdp-sticky{display:flex}
  .opt-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .wrap{padding:0 18px}
  .cat-grid,.prod-grid,.rev-grid,.rz-grid,.blog-grid,.toggle-cards,.cfg-grid-in,.form-grid{grid-template-columns:1fr}
  .gal-strip{grid-template-columns:repeat(2,1fr)}
  .how-grid,.steps4,.stats,.b2b-feats,.opt-cards{grid-template-columns:1fr}
  .sec{padding:54px 0}
  .split-l,.cta-band,.cfg-panel,.b2b-hero{padding:30px 22px}
  .chk-toggle{flex-direction:column}
  .ftr-grid{grid-template-columns:1fr 1fr;gap:28px}
  .hero{min-height:78vh}
}

/* ===== HERO KEN BURNS SLIDESHOW ===== */
.hero-slides{position:absolute;inset:0;overflow:hidden;background:#26292D}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease;will-change:opacity,transform}
.hero-slide.on{opacity:1}
.hero-slide.on.kb0{animation:kenburns-a 7.6s ease-out forwards}
.hero-slide.on.kb1{animation:kenburns-b 7.6s ease-out forwards}
.hero-slide.on.kb2{animation:kenburns-c 7.6s ease-out forwards}
@keyframes kenburns-a{from{transform:scale(1) translate(0,0)}to{transform:scale(1.12) translate(-2.5%,-1.5%)}}
@keyframes kenburns-b{from{transform:scale(1.12) translate(2.5%,1%)}to{transform:scale(1) translate(0,0)}}
@keyframes kenburns-c{from{transform:scale(1) translate(2%,-1%)}to{transform:scale(1.12) translate(-1.5%,1.5%)}}

/* ===== PARALLAX (split-r) ===== */
.split-r.parallax{overflow:hidden}
.split-r.parallax .px-bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;will-change:transform}

/* ===== HOW STEPS — photos ===== */
.how-step-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);margin-bottom:16px;transition:transform .5s ease,box-shadow .3s ease;box-shadow:0 6px 18px rgba(38,41,45,.06)}
.how-step:hover .how-step-img{transform:translateY(-4px) scale(1.015);box-shadow:var(--shadow)}

/* ===== FACEBOOK SECTION ===== */
.fb-sec{background:var(--surface)}
.fb-grid{display:grid;grid-template-columns:1fr 500px;gap:40px;align-items:stretch}
.fb-brand{display:flex;flex-direction:column;justify-content:center}
.fb-brand .fb-ico{width:54px;height:54px;border-radius:14px;background:#1877F2;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.fb-brand h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:14px}
.fb-brand p{color:var(--muted);font-size:17px;margin-bottom:26px;max-width:44ch}
.fb-embed{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--beige);min-height:620px;box-shadow:var(--shadow)}
.fb-embed iframe{display:block;width:100%}
.fb-live{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);margin-top:14px}
.fb-live .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(200,16,46,.5);animation:fbpulse 2s infinite}
@keyframes fbpulse{0%{box-shadow:0 0 0 0 rgba(200,16,46,.5)}70%{box-shadow:0 0 0 7px rgba(200,16,46,0)}100%{box-shadow:0 0 0 0 rgba(200,16,46,0)}}
@media(max-width:900px){.fb-grid{grid-template-columns:1fr}.fb-embed{min-height:520px}}

/* ===== CTA BAND dynamic bg ===== */
.cta-band.cta-dyn{padding:72px 56px}
.cta-band .cta-slides{position:absolute;inset:0;overflow:hidden;border-radius:14px}
.cta-band .cta-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .9s ease}
.cta-band .cta-slide.on{opacity:1}
.cta-band .cta-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,29,33,.82),rgba(26,29,33,.9));border-radius:14px}
.cta-band .cta-inner{position:relative;z-index:2}

/* ===== REVIEWS map background ===== */
.rev-sec{position:relative;overflow:hidden}
.rev-map{position:absolute;inset:0;z-index:0;pointer-events:none}
.rev-map iframe{width:100%;height:100%;border:0;filter:blur(1.5px) grayscale(.05);transform:scale(1.04)}
/* lekka winieta po bokach + delikatne rozjaśnienie góry/dołu — mapa wyraźnie
   widoczna (czytelne nazwy miejscowości), białe karty opinii nadal czytelne */
.rev-map-ov{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 50%,rgba(243,244,245,0) 38%,rgba(243,244,245,.55) 100%),
    linear-gradient(180deg,rgba(243,244,245,.42),rgba(243,244,245,.30) 45%,rgba(243,244,245,.42))}
.rev-sec .wrap{position:relative;z-index:2}
.rev-sec .rev-card{box-shadow:var(--shadow);background:rgba(255,255,255,.96);backdrop-filter:blur(2px)}

/* ===== prefers-reduced-motion ===== */
@media(prefers-reduced-motion:reduce){
  .hero-slide,.hero-slide.on,.hero-slide.on.kb0,.hero-slide.on.kb1,.hero-slide.on.kb2{animation:none!important;transform:none!important;transition:opacity .4s ease}
  .hero-bg{animation:none!important;transform:scale(1.04)!important}
  .split-r.parallax .px-bg{transform:none!important;inset:0}
  .cta-band .cta-slide{transition:opacity .4s ease}
  .rev-map iframe{filter:blur(1.5px)}
  .how-step:hover .how-step-img{transform:none}
  .fb-live .dot{animation:none}
}

/* =====================================================================
   A11Y — focus visibility (globalne) + klawiatura dla klikalnych divów
   ===================================================================== */
:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:2px}
/* elementy klikalne sterowane JS-em (kafelki, swatche, chipy, kroki…) */
[role="button"]{cursor:pointer}
.ral-sw[role="button"],.chip[role="button"]{cursor:pointer}

/* =====================================================================
   BLOCK-COMPAT — mapowanie natywnych bloków Gutenberga na wygląd 1:1
   (strona główna zbudowana z core/cover, core/columns, core/buttons…)
   ===================================================================== */

/* --- reset paddingu sekcji od WP root-padding (sekcje mają własny .wrap) --- */
.az-main{overflow-x:hidden}
.az-main > .sec{padding-left:0;padding-right:0}

/* --- przyciski: nadajemy klasom .btn wygląd z makiety, neutralizując core --- */
.wp-block-button.btn > .wp-block-button__link{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:600;font-size:15px;padding:14px 28px;border-radius:var(--radius-sm);
  transition:.22s;border:1.5px solid transparent;line-height:1;text-decoration:none}
.wp-block-button.btn svg{flex-shrink:0}
.wp-block-button.btn-green > .wp-block-button__link{background:var(--green);color:#fff}
.wp-block-button.btn-green > .wp-block-button__link:hover{background:var(--green-d);transform:translateY(-1px)}
.wp-block-button.btn-primary > .wp-block-button__link{background:var(--ink);color:#fff}
.wp-block-button.btn-primary > .wp-block-button__link:hover{background:var(--green);transform:translateY(-1px);box-shadow:0 8px 20px rgba(200,16,46,.28)}
.wp-block-button.btn-brass > .wp-block-button__link{background:var(--brass);color:#fff}
.wp-block-button.btn-brass > .wp-block-button__link:hover{background:#A20C24}
.wp-block-button.btn-outline > .wp-block-button__link{border-color:var(--line);color:var(--ink);background:transparent}
.wp-block-button.btn-outline > .wp-block-button__link:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.wp-block-button.btn-ghost-light > .wp-block-button__link{border-color:rgba(255,255,255,.5);color:#fff;background:transparent}
.wp-block-button.btn-ghost-light > .wp-block-button__link:hover{background:#fff;color:var(--ink)}
.wp-block-button.btn-sm > .wp-block-button__link{padding:10px 18px;font-size:13px}
.wp-block-buttons.hero-cta{gap:14px}

/* --- HERO jako core/cover --- */
.hero.az-hero{position:relative;display:flex;align-items:flex-end;color:#fff;overflow:hidden;padding:0}
.hero.az-hero .wp-block-cover__inner-container{width:100%;position:relative;z-index:2;padding:0 0 76px}
.hero.az-hero .hero-in{max-width:var(--maxw);margin:0 auto;padding-left:24px;padding-right:24px;width:100%}
.hero.az-hero h1.hero-h1{color:#fff;font-size:clamp(38px,6vw,72px);font-weight:600;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.3);margin:0}
.hero.az-hero .hero-lead{font-size:clamp(16px,2vw,21px);max-width:54ch;margin:22px 0 32px;color:rgba(255,255,255,.92)}
/* gradientowa nakładka makiety zamiast płaskiego dim z core/cover */
.hero.az-hero > .wp-block-cover__background{background:transparent!important;opacity:1!important}
.hero.az-hero .hero-ov{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(26,29,33,.32) 0%,rgba(26,29,33,.18) 35%,rgba(26,29,33,.82) 100%)}
.hero.az-hero .hero-slides{z-index:0}
.hero.az-hero .hero-watermark{z-index:1}

/* --- PASEK ZAUFANIA jako core/columns --- */
.trust-in.wp-block-columns{gap:8px;padding:22px 0;margin:0 auto;align-items:center}
.trust-in .wp-block-column{flex-basis:auto;flex-grow:1;min-width:0}
.trust .trust-i{justify-content:flex-start}

/* --- sekcja head w rzędzie (eyebrow+h2 obok przycisku) --- */
.sec-head-row{margin-bottom:46px;max-width:none;align-items:flex-end}
.sec-head-row .wp-block-buttons{margin:0}

/* --- JAK TO DZIAŁA jako core/columns --- */
.how-grid.wp-block-columns{gap:26px;align-items:stretch}
.how-grid .wp-block-column{padding-top:8px}
.how-grid .wp-block-column h3{font-size:19px;margin:12px 0 8px}
.how-grid .wp-block-column p{color:var(--muted);font-size:14.5px}
.how-grid .ic{width:46px;height:46px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;margin-bottom:14px;border:1px solid var(--line)}
.how-grid .ic svg{stroke:var(--green)}

/* --- PROMO KONFIGURATORA jako core/columns w .split --- */
.split.wp-block-columns{gap:0;background:var(--ink);border-radius:14px;overflow:hidden;color:#fff;align-items:stretch}
.split .split-l.wp-block-column{padding:54px;flex-basis:50%}
.split .split-l h2{color:#fff;font-size:34px;margin-bottom:16px}
.split .split-l p{color:rgba(255,255,255,.8);margin-bottom:26px}
.split .split-l .eyebrow{color:var(--brass)}
.split .split-feats{list-style:none;margin:0 0 30px;padding:0}
.split .split-feats li{display:flex;gap:11px;align-items:center;padding:7px 0;font-size:15px;color:#E3E3E3}
.split .split-feats li svg{stroke:var(--brass);flex-shrink:0}
.split .split-r.wp-block-column{flex-basis:50%;min-height:420px;position:relative;padding:0;overflow:hidden}

/* --- OPINIE jako core/columns --- */
.rev-grid.wp-block-columns{gap:22px;align-items:stretch}
.rev-grid .rev-card.wp-block-column{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;flex-basis:33%}

/* --- FACEBOOK jako core/columns --- */
.fb-grid.wp-block-columns{gap:40px;align-items:stretch}
.fb-grid .fb-brand.wp-block-column{display:flex;flex-direction:column;justify-content:center;flex-basis:auto}
.fb-grid .fb-embed.wp-block-column{flex:0 0 500px;max-width:500px}
.fb-grid .fb-brand h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:14px}
.fb-grid .fb-brand p{color:var(--muted);font-size:17px;margin-bottom:26px;max-width:44ch}

/* --- REALIZACJE jako core/gallery --- */
.gal-strip.wp-block-gallery{gap:10px!important;--wp--style--unstable-gallery-gap:10px}
.gal-strip.wp-block-gallery .wp-block-image.g{margin:0;width:auto;aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:pointer}
.gal-strip.wp-block-gallery .wp-block-image.g img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gal-strip.wp-block-gallery .wp-block-image.g:hover img{transform:scale(1.1)}

/* --- kafelki kategorii jako <a> (były <div onclick>) --- */
a.cat-tile{display:block;color:inherit;text-decoration:none}
a.cat-tile h3{color:#fff}

/* --- karty produktu jako <a> --- */
a.pcard{text-decoration:none;color:inherit}

/* --- CTA BAND jako core/cover --- */
.cta-band.wp-block-cover{padding:60px;text-align:center;border-radius:14px;overflow:hidden;min-height:0}
.cta-band.wp-block-cover .wp-block-cover__inner-container{position:relative;z-index:2;width:100%}
.cta-band.wp-block-cover h2{color:#fff;font-size:clamp(28px,3.6vw,40px);max-width:20ch;margin:0 auto 16px}
.cta-band.wp-block-cover p{color:rgba(255,255,255,.78);max-width:46ch;margin:0 auto 28px}
.cta-band.wp-block-cover .hairline{width:60px;height:2px;background:var(--brass);margin:0 auto 22px}

/* --- responsywność block-compat --- */
@media(max-width:900px){
  .trust-in.wp-block-columns{flex-wrap:wrap}
  .trust-in .wp-block-column{flex-basis:46%}
  .how-grid.wp-block-columns,.rev-grid.wp-block-columns{flex-wrap:wrap}
  .how-grid .wp-block-column,.rev-grid .rev-card.wp-block-column{flex-basis:46%}
  .split.wp-block-columns,.fb-grid.wp-block-columns{flex-wrap:wrap}
  .split .split-l.wp-block-column,.split .split-r.wp-block-column,
  .fb-grid .fb-brand.wp-block-column,.fb-grid .fb-embed.wp-block-column{flex-basis:100%;max-width:100%}
  .split .split-r.wp-block-column{min-height:300px}
}
@media(max-width:600px){
  .trust-in .wp-block-column,.how-grid .wp-block-column,.rev-grid .rev-card.wp-block-column{flex-basis:100%}
  .split .split-l.wp-block-column{padding:30px 22px}
  .cta-band.wp-block-cover{padding:30px 22px}
  .hero.az-hero .wp-block-cover__inner-container{padding-bottom:54px}
}

/* === HOME BLOCK SPACING FIX (1:1) ===
   Przyczyny nadmiarowych przerw w wersji blokowej (vs mockup.html):
   - theme.json: blockGap=true bez wartości -> WP wstrzykuje domyslny block-gap (~2em/32px)
     jako `> * + * { margin-block-start }` w KAZDYM layoucie grupy (.az-main, .sec>.wrap,
     .sec-head). To sumuje sie z paddingiem .sec(84px) -> gigantyczne przerwy miedzy
     sekcjami ORAZ wstawia ~32px nad siatka kategorii/produktow (pustka pod naglowkiem).
   - useRootPaddingAwareAlignments + styles.spacing.padding 24px -> podwojny padding poziomy
     (root-padding + wlasny .wrap padding).
   Ponizej: zerujemy te marginesy w obrebie home i przywracamy rytm makiety. */

/* a) Zeruj WP block-gap miedzy top-level sekcjami i wewnatrz grup home.
      WP renderuje gap jako margin-block-start na rodzenstwie (* + *). */
.az-main.is-layout-flow > * + *,
.az-main.is-layout-constrained > * + *,
.az-main > .wp-block-group + .wp-block-group{ margin-block-start:0 !important; }

/* Wewnetrzne grupy sekcji (.sec > .wrap) — kasujemy auto-gap, rytm robia nasze klasy. */
.az-main .sec .wrap.wp-block-group > * + *,
.az-main .sec > .wp-block-group > * + *{ margin-block-start:0 !important; }

/* b) Neutralizuj double horizontal padding od useRootPaddingAwareAlignments:
      sekcje i tak maja wlasny .wrap z padding:0 24px. */
.az-main.is-layout-constrained{
  padding-left:0; padding-right:0;
  --wp--style--root-padding-left:0; --wp--style--root-padding-right:0;
}
.az-main > .sec,
.az-main > .wp-block-group.sec{ padding-left:0; padding-right:0; margin-block:0; }

/* c) Rytm pionowy sekcji = makieta (.sec{padding:84px 0}). Wymuszamy spojnie,
      bo grupy blokowe potrafia zgubic/zdublowac padding. */
.az-main .wp-block-group.sec{ padding-top:84px; padding-bottom:84px; }
/* Pasek zaufania tuz pod hero — bez podwojnego odstepu (sam ma wew. padding 22px). */
.az-main .wp-block-group.trust{ padding-top:0; padding-bottom:0; margin-block:0; }

/* d) Sekcja kategorii: naglowek blisko siatki, siatka ciasna, zero pustki.
      .sec-head ma margin-bottom:46px (makieta) — przywracamy go po wyzerowaniu gap. */
.az-main .sec .sec-head{ margin-bottom:46px; }
.az-main .sec .sec-head.center{ margin-left:auto; margin-right:auto; margin-bottom:46px; }
/* Eyebrow/H2/opis wewnatrz sec-head — ciasny rytm jak w makiecie (bez block-gap). */
.az-main .sec-head .eyebrow{ margin-bottom:14px; }
.az-main .sec-head h2{ margin:0; }
.az-main .sec-head p{ margin-top:14px; }
/* Siatka kafelkow/kart przyklejona do naglowka (margin-block-start wyzerowany wyzej). */
.az-main .cat-grid,
.az-main .prod-grid,
.az-main .how-grid,
.az-main .gal-strip,
.az-main .rev-grid,
.az-main .ba-wrap{ margin-top:0; }
.az-main .cat-grid{ gap:18px; }      /* ciasna siatka kategorii (makieta) */
.az-main .prod-grid{ gap:20px; }

/* e) Hero (core/cover) — sensowna wysokosc zamiast 88vh giganta.
      Inline min-height:88vh w home.php nadpisujemy tu na ~78vh z sufitem 640px. */
.hero.az-hero.wp-block-cover{ min-height:calc(100vh - 64px) !important; }

/* f) Szerokosci: .wrap = 1240px (juz w :root --maxw). Pilnujemy, by constrained-layout
      WP (content 760 / wide 1200 z theme.json) nie zwezal naszych sekcji home. */
.az-main .sec .wrap{ max-width:var(--maxw); }
.az-main .sec > .wp-block-group.wrap{ max-width:var(--maxw); margin-left:auto; margin-right:auto; }

/* g) Promo konfiguratora + Jak to dziala: kolumny przyklejone do naglowka. */
.az-main .split.wp-block-columns{ margin-top:0; }
.az-main .how.sec .how-grid{ margin-top:0; }

@media(max-width:600px){
  /* Mobile: rytm jak w makiecie (.sec{padding:54px 0}) + nizszy hero (78->72vh). */
  .az-main .wp-block-group.sec{ padding-top:54px; padding-bottom:54px; }
  .az-main .sec .sec-head,
  .az-main .sec .sec-head.center{ margin-bottom:32px; }
  .hero.az-hero.wp-block-cover{ min-height:calc(100svh - 60px) !important; }
}
/* === /HOME BLOCK SPACING FIX === */

/* =====================================================================
   === WOOCOMMERCE SHOP/PDP FIX ===
   Sklep (templates/archive-product.html) i karta produktu
   (templates/single-product.html) używają core/query + post-template
   + bloków woocommerce/*. Bez tych reguł:
   - tytuł produktu renderuje się jako wielki Fraunces h2 (post-title),
   - siatka jest jednokolumnowa, karty bez stylu makiety.
   Poniżej: siatka 4->3->2->1, karty jak .pcard z makiety, normalny tytuł,
   miniatura cover ze stałą proporcją, czerwony przycisk pełnej szerokości,
   oraz 2-kolumnowy PDP. Targetujemy realne klasy WP/Woo.
   ===================================================================== */

/* ---------- SHOP top bar (tytuł archiwum + sortowanie) ---------- */
.az-main .shop-top{align-items:center}
.az-main .shop-top .wp-block-query-title,
.az-main .shop-top h1{font-family:'Fraunces',Georgia,serif;font-size:clamp(26px,3vw,36px);margin:0;color:var(--ink)}
.az-main .wc-block-product-results-count,
.az-main .woocommerce-result-count{font-size:14px;color:var(--muted);margin:0 0 22px}
.az-main .wc-block-catalog-sorting select,
.az-main .woocommerce-ordering select{padding:10px 14px;border:1px solid var(--line);border-radius:6px;font-family:inherit;font-size:14px;background:#fff;color:var(--text)}

/* ---------- SHOP grid (core/query: .prod-grid wrapper) ---------- */
.az-main .prod-grid .wp-block-post-template{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  list-style:none;margin:0;padding:0}
/* gdyby WP dodał własną klasę grid/flow do post-template — wymuś nasz grid */
.az-main .prod-grid .wp-block-post-template.is-layout-flow,
.az-main .prod-grid .wp-block-post-template.is-layout-grid,
.az-main .prod-grid .wp-block-post-template.is-layout-flex{
  display:grid !important;grid-template-columns:repeat(4,1fr);gap:20px}
/* fallback dla klasycznego szortkodu/markupu Woo (ul.products) */
.az-main ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;list-style:none;margin:0;padding:0}
.az-main ul.products::before,.az-main ul.products::after{display:none}
.az-main ul.products li.product{width:auto;margin:0;float:none}

/* ---------- karta produktu (.pcard z post-template) ---------- */
.az-main .prod-grid .pcard,
.az-main ul.products li.product{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:.26s;display:flex;flex-direction:column;height:100%;padding:0}
.az-main .prod-grid .pcard:hover,
.az-main ul.products li.product:hover{
  transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}

/* miniatura na górze: cover, stała proporcja 4/3 */
.az-main .pcard .pcard-img,
.az-main .pcard .wc-block-components-product-image,
.az-main ul.products li.product a img{margin:0}
.az-main .pcard .pcard-img,
.az-main .pcard .wc-block-components-product-image{
  aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--beige);display:block}
.az-main .pcard .pcard-img img,
.az-main .pcard .wc-block-components-product-image img{
  width:100%;height:100%;object-fit:cover;transition:transform .5s;border-radius:0}
.az-main .pcard:hover .pcard-img img{transform:scale(1.06)}

/* ciało karty */
.az-main .pcard .pcard-b{padding:18px;display:flex;flex-direction:column;flex:1;gap:0}

/* NAZWA produktu — normalny rozmiar, NIE wielki Fraunces h2 */
.az-main .pcard .pcard-title,
.az-main .pcard .wp-block-post-title{
  font-family:'Inter',system-ui,sans-serif !important;
  font-size:18px !important;line-height:1.3;font-weight:600;letter-spacing:0;
  color:var(--ink);margin:0 0 8px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.az-main .pcard .pcard-title a,
.az-main .pcard .wp-block-post-title a{color:inherit;text-decoration:none}
.az-main .pcard .pcard-title a:hover,
.az-main .pcard .wp-block-post-title a:hover{color:var(--green)}

/* cena brandowa */
.az-main .pcard .pcard-price,
.az-main .pcard .wc-block-components-product-price,
.az-main ul.products li.product .price{
  font-family:'Fraunces',Georgia,serif;font-size:22px;font-weight:600;color:var(--ink);
  margin:auto 0 14px;display:block}
.az-main .pcard .wc-block-components-product-price del,
.az-main ul.products li.product .price del{color:var(--muted);font-size:15px;font-weight:400;margin-right:6px}
.az-main .pcard .wc-block-components-product-price ins{text-decoration:none;color:var(--green-d)}

/* przycisk „Dodaj do koszyka" — czerwony, pełna szerokość */
.az-main .pcard .wp-block-button,
.az-main .pcard .wc-block-components-product-button{margin-top:auto;width:100%}
.az-main .pcard .wc-block-components-product-button .wp-block-button__link,
.az-main .pcard .wp-block-button .wp-block-button__link,
.az-main ul.products li.product a.button,
.az-main ul.products li.product a.add_to_cart_button{
  display:flex;align-items:center;justify-content:center;width:100%;
  background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);
  font-weight:600;font-size:14.5px;padding:12px 16px;line-height:1.2;
  transition:.2s;text-decoration:none}
.az-main .pcard .wc-block-components-product-button .wp-block-button__link:hover,
.az-main .pcard .wp-block-button .wp-block-button__link:hover,
.az-main ul.products li.product a.button:hover,
.az-main ul.products li.product a.add_to_cart_button:hover{background:var(--green-d)}
.az-main .pcard .wc-block-components-product-button .wp-block-button__link.loading,
.az-main .pcard .wc-block-components-product-button .wp-block-button__link.added{opacity:.85}

/* paginacja sklepu */
.az-main .prod-grid .wp-block-query-pagination{margin-top:40px;gap:6px}
.az-main .wp-block-query-pagination a,
.az-main .wp-block-query-pagination .wp-block-query-pagination-numbers .page-numbers{
  padding:8px 13px;border:1px solid var(--line);border-radius:6px;font-size:14px;color:var(--ink);transition:.2s}
.az-main .wp-block-query-pagination a:hover{border-color:var(--ink)}
.az-main .wp-block-query-pagination .page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- PDP (single-product.html: .pdp = core/columns) ---------- */
.az-main .crumb.wc-block-breadcrumbs{font-size:13px;color:var(--muted);padding:0 0 6px}
.az-main .crumb.wc-block-breadcrumbs a:hover{color:var(--green)}

.az-main .pdp.wp-block-columns{display:flex;gap:48px;align-items:flex-start;margin:18px 0 50px}
.az-main .pdp .wp-block-column{margin:0}

/* galeria PDP */
.az-main .pdp .wc-block-components-product-image-gallery,
.az-main .pdp .woocommerce-product-gallery{border-radius:var(--radius);overflow:hidden;background:var(--beige)}
.az-main .pdp .wc-block-components-product-image-gallery img,
.az-main .pdp .woocommerce-product-gallery img{border-radius:var(--radius)}

/* panel informacyjny */
.az-main .pdp .pdp-info{display:flex;flex-direction:column}
.az-main .pdp .pdp-info .wp-block-post-title{
  font-family:'Fraunces',Georgia,serif;font-size:clamp(26px,3vw,34px);line-height:1.12;
  margin:0 0 12px;color:var(--ink)}
.az-main .pdp .wc-block-components-product-rating,
.az-main .pdp .woocommerce-product-rating{margin-bottom:14px}

/* cena DUŻA */
.az-main .pdp .pdp-price-main,
.az-main .pdp-info .wc-block-components-product-price,
.az-main .pdp-info p.price{
  font-family:'Fraunces',Georgia,serif;font-size:38px;font-weight:600;color:var(--ink);
  margin:0 0 18px;display:block}
.az-main .pdp-info .wc-block-components-product-price del,
.az-main .pdp-info p.price del{color:var(--muted);font-size:22px;font-weight:400;margin-right:8px}
.az-main .pdp-info .wc-block-components-product-price ins,
.az-main .pdp-info p.price ins{text-decoration:none;color:var(--green-d)}

.az-main .pdp-info .wp-block-post-excerpt,
.az-main .pdp-info .woocommerce-product-details__short-description{
  color:var(--text);font-size:15.5px;margin:0 0 22px}

/* formularz dodawania do koszyka */
.az-main .pdp-info .wp-block-woocommerce-add-to-cart-form,
.az-main .pdp-info form.cart{margin-bottom:18px}
.az-main .pdp-info form.cart .quantity input.qty{
  padding:12px 10px;border:1.5px solid var(--line);border-radius:6px;font-family:inherit;
  font-size:15px;width:74px;background:#fff;margin-right:10px}
.az-main .pdp-info form.cart .single_add_to_cart_button,
.az-main .pdp-info form.cart button.button{
  background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);
  font-weight:600;font-size:16px;padding:15px 30px;transition:.2s;cursor:pointer}
.az-main .pdp-info form.cart .single_add_to_cart_button:hover,
.az-main .pdp-info form.cart button.button:hover{background:var(--green-d);transform:translateY(-1px)}
.az-main .pdp-info form.cart .variations select{
  padding:11px 12px;border:1.5px solid var(--line);border-radius:6px;font-family:inherit;font-size:14.5px;background:#fff}

.az-main .pdp-info .wc-block-components-product-meta,
.az-main .pdp-info .product_meta{font-size:13px;color:var(--muted);margin-top:18px;border-top:1px solid var(--line);padding-top:16px}

/* dolne sekcje PDP (opis/atrybuty, related) */
.az-main .pdp-sections.wc-block-components-product-details,
.az-main .woocommerce-tabs{margin:0 0 50px}
.az-main .pdp-sections .wc-block-components-product-details__summary,
.az-main .woocommerce-tabs h2{font-family:'Fraunces',Georgia,serif;color:var(--ink)}
.az-main .wp-block-woocommerce-related-products > h2,
.az-main .related.products > h2{font-family:'Fraunces',Georgia,serif;font-size:26px;margin-bottom:24px;color:var(--ink)}
/* related products dziedziczą wygląd kart sklepu */
.az-main .wp-block-woocommerce-related-products .wp-block-post-template,
.az-main .related.products ul.products{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;list-style:none;margin:0;padding:0}

/* ---------- responsywność sklepu/PDP: 4->3->2->1 ---------- */
@media(max-width:1080px){
  .az-main .prod-grid .wp-block-post-template,
  .az-main .prod-grid .wp-block-post-template.is-layout-flow,
  .az-main .prod-grid .wp-block-post-template.is-layout-grid,
  .az-main .prod-grid .wp-block-post-template.is-layout-flex,
  .az-main ul.products,
  .az-main .wp-block-woocommerce-related-products .wp-block-post-template,
  .az-main .related.products ul.products{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .az-main .pdp.wp-block-columns{flex-direction:column;gap:28px}
  .az-main .pdp .wp-block-column{flex-basis:100% !important;width:100%}
  .az-main .prod-grid .wp-block-post-template,
  .az-main .prod-grid .wp-block-post-template.is-layout-flow,
  .az-main .prod-grid .wp-block-post-template.is-layout-grid,
  .az-main .prod-grid .wp-block-post-template.is-layout-flex,
  .az-main ul.products,
  .az-main .wp-block-woocommerce-related-products .wp-block-post-template,
  .az-main .related.products ul.products{grid-template-columns:repeat(2,1fr);gap:14px}
}
@media(max-width:520px){
  .az-main .prod-grid .wp-block-post-template,
  .az-main .prod-grid .wp-block-post-template.is-layout-flow,
  .az-main .prod-grid .wp-block-post-template.is-layout-grid,
  .az-main .prod-grid .wp-block-post-template.is-layout-flex,
  .az-main ul.products,
  .az-main .wp-block-woocommerce-related-products .wp-block-post-template,
  .az-main .related.products ul.products{grid-template-columns:1fr}
  .az-main .pdp .pdp-price-main,.az-main .pdp-info p.price{font-size:32px}
}
/* === /WOOCOMMERCE SHOP/PDP FIX === */

/* === KONFIGURATOR: czyste podsumowanie dlugosci (zamiast schematu mapy) === */
.cfg-len-box{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding:18px 22px;background:var(--beige);border:1px solid var(--line);border-radius:10px}
.cfg-len-box span{font-weight:600;color:var(--ink);font-size:15px}
.cfg-len-box b{font-family:'Fraunces',serif;font-size:26px;color:var(--green);white-space:nowrap}
