/* =====================================================
   ARBUD WordPress Theme — main.css v1.3
   ===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --black:#0d0d0d;--dark:#161616;--card:#1c1c1c;--border:#2e2e2e;
  --white:#fff;--off:#c8c8c8;--muted:#808080;
  --accent:#c8932a;--accent2:#e0aa45;
  --nav-h:100px; /* wysokość navbara */
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{/* scroll-behavior zarządza JS */}
body{font-family:'Inter',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;}
img{max-width:100%;height:auto;display:block;}
a{transition:color .2s;}
/* Offsetuje sekcje żeby fixed navbar nie zasłaniał nagłówka */
#firma,#realizacje,#oferta,#lokalizacja{scroll-margin-top:calc(var(--nav-h) + 12px);}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;
  background:rgba(13,13,13,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:background .3s;
}
nav.site-nav.scrolled{background:rgba(13,13,13,.98);}
.nav-right{display:flex;align-items:center;gap:0;margin-left:auto;}
.nav-right .nav-links{margin-right:24px;}

/* ══ LOGO — kontekstowe, nadpisuje WP inline width/height ══ */
/* Topbar */
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;height:var(--nav-h);}
.arbud-logo-wrap{display:flex;align-items:center;}
.arbud-logo-wrap--nav{height:100%;}
.arbud-logo-wrap--nav a.custom-logo-link{display:flex!important;align-items:center!important;height:100%!important;line-height:0;}
.arbud-logo-wrap--nav img.custom-logo{
  height:100%!important;max-height:300px!important;
  width:auto!important;max-width:none!important;
  object-fit:contain!important;object-position:left center!important;display:block!important;
}
/* Stopka */
.footer-logo-inner{margin-bottom:25px;}
.arbud-logo-wrap--footer a.custom-logo-link{display:inline-flex!important;align-items:center!important;}
.arbud-logo-wrap--footer img.custom-logo{
  max-width:400px!important;max-height:80px!important;
  width:auto!important;height:auto!important;
  object-fit:contain!important;object-position:left center!important;display:block!important;
}
/* Fallback tekstowy */
.arbud-logo-text-wrap{display:flex;align-items:center;gap:10px;}
.nav-logo-icon{width:40px;height:40px;border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.nav-logo-icon span{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--accent);}
.nav-logo-text{display:flex;flex-direction:column;gap:1px;}
.nav-logo-name{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:4px;color:var(--white);line-height:1;}
.nav-logo-sub{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);}

/* Nav links */
.nav-links{display:flex;align-items:center;list-style:none;margin:0;padding:0;height:var(--nav-h);}
.nav-links li{height:100%;}
.nav-links a{
  display:flex;align-items:center;padding:0 16px;height:100%;
  font-size:15px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--off);text-decoration:none;white-space:nowrap;
  position:relative;transition:color .2s;
}
.nav-links a::after{content:'';position:absolute;bottom:0;left:16px;right:16px;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .25s;}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-links a.is-active{color:var(--white);}
.nav-links a.is-active::after{transform:scaleX(1);}

/* Telefon — wyśrodkowany, wyróżniony */
.nav-tel-li{display:flex;align-items:center;padding:0 4px;}
.nav-tel{
  display:flex!important;align-items:center!important;justify-content:center!important;
  height:44px!important;padding:0 22px!important;
  font-size:14px!important;font-weight:700!important;
  color:var(--accent)!important;letter-spacing:.5px!important;
  border:1px solid rgba(200,147,42,.45)!important;
  white-space:nowrap;transition:background .2s,border-color .2s!important;
  text-decoration:none!important;
}
.nav-tel svg{width:14px;height:14px;fill:var(--accent);flex-shrink:0;margin-right:6px;}
.nav-tel:hover{background:rgba(200,147,42,.12)!important;border-color:var(--accent)!important;}

.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;flex-shrink:0;}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--white);transition:all .3s;}

.nav-mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:149;}
.nav-mobile-overlay.open{display:block;}
.nav-mobile{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(13,13,13,.99);padding:20px 28px 28px;flex-direction:column;list-style:none;z-index:150;border-bottom:1px solid var(--border);}
.nav-mobile.open{display:flex;}
.nav-mobile a{display:block;padding:14px 0;font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--border);}
.nav-mobile a:last-child{border-bottom:none;}
.nav-mobile a:hover{color:var(--accent);}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero-section{min-height:100vh;display:grid;grid-template-columns:1fr 600px;padding-top:var(--nav-h);position:relative;overflow:hidden;}

.hero-slider{position:absolute;inset:0;z-index:0;}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease;}
.hero-slide.active{opacity:1;}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(13,13,13,.97) 0%,rgba(13,13,13,.82) 45%,rgba(13,13,13,.45) 100%);}
.hero-slider-fallback{position:absolute;inset:0;background:linear-gradient(105deg,#0d0d0d 0%,#0d0d0d 45%,#141210 55%,#1a1510 100%);}
.hero-slider-fallback::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-60deg,transparent,transparent 60px,rgba(255,255,255,.008) 60px,rgba(255,255,255,.008) 61px);}

.slider-dots{position:absolute;bottom:28px;left:52px;z-index:3;display:flex;gap:8px;}
.slider-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);border:none;cursor:pointer;padding:0;transition:background .3s,transform .3s;}
.slider-dot.active{background:var(--accent);transform:scale(1.3);}

.hero-left{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;padding:80px 52px;}
.hero-eyebrow{display:flex;align-items:center;gap:12px;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:36px;}
.hero-eyebrow::before{content:'';width:28px;height:1px;background:var(--accent);display:block;}
.hero-logo-sub{font-size:9px;letter-spacing:5px;text-transform:uppercase;color:var(--muted);font-weight:300;margin-bottom:6px;}
.hero-logo-main{font-family:'Bebas Neue',sans-serif;font-size:clamp(80px,10vw,130px);letter-spacing:6px;line-height:1;color:var(--white);margin-bottom:32px;}
.hero-logo-main .a-gold{color:var(--accent);}
.hero-custom-logo{margin-bottom:32px;}
.hero-custom-logo img{max-height:150px;width:auto;}
.hero-tagline{font-size:16px;line-height:1.8;color:var(--muted);font-weight:300;margin-bottom:48px;}
.hero-tagline strong{color:var(--off);font-weight:500;}
.hero-cta-row{display:flex;gap:16px;align-items:center;flex-wrap:wrap;}

/* Contact card */
.hero-right{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;padding:80px 52px 80px 16px;}
.contact-card{background:var(--card);border:1px solid var(--border);padding:44px 40px;position:relative;}
.contact-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--accent),transparent);}
.cc-name{font-size:30px;font-weight:700;color:var(--white);margin-bottom:6px;text-align:center;}
.cc-company{font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:34px;text-align:center;}
.cc-divider{height:1px;background:var(--border);margin-bottom:30px;}
.cc-rows{display:flex;flex-direction:column;gap:20px;margin-bottom:34px;align-items:center;}
/* Ikony wyrównane pionowo — stała szerokość kolumny ikony + tekst do lewej */
.cc-row{display:grid;grid-template-columns:42px 1fr;align-items:center;gap:16px;width:100%;max-width:260px;}
.cc-row-icon{width:42px;height:42px;background:rgba(200,147,42,.1);border:1px solid rgba(200,147,42,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cc-row-icon svg{width:18px;height:18px;fill:var(--accent);}
.cc-row-val{font-size:18px;color:var(--off);font-weight:500;text-decoration:none;transition:color .2s;text-align:left;}
a.cc-row-val:hover{color:var(--accent);}
.cc-address-box{background:var(--black);border:1px solid var(--border);padding:24px 26px;display:flex;flex-direction:column;gap:8px;align-items:center;}
.cc-address-box .line{font-size:16px;color:var(--muted);line-height:1.5;text-align:center;}
.cc-address-box .line.bold{font-weight:600;color:var(--off);font-size:18px;}
.cc-address-box .line.small{font-size:13px;color:#808080;letter-spacing:.5px;}

/* ── BUTTONS ── */
.btn-primary{background:var(--accent);color:var(--black);padding:15px 34px;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;text-decoration:none;display:inline-block;transition:background .2s,transform .2s,box-shadow .2s;}
.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(200,147,42,.3);color:var(--black);}
.btn-ghost{color:var(--muted);font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;display:flex;align-items:center;gap:8px;transition:color .2s;}
.btn-ghost:hover{color:var(--white);}
.btn-ghost::after{content:'→';font-size:14px;}
.btn-dark{background:var(--black);color:var(--white);padding:16px 36px;font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-decoration:none;display:inline-block;transition:background .2s,transform .2s;white-space:nowrap;}
.btn-dark:hover{background:#111;transform:translateY(-2px);color:var(--white);}
.btn-dark--cta{display:inline-flex;align-items:center;gap:10px;}
.btn-dark--cta svg{width:18px;height:18px;fill:var(--white);flex-shrink:0;}

/* ── SECTION HELPERS ── */
.section{padding:96px 56px;}
.section-dark{background:var(--dark);}
.section-black{background:var(--black);}
.sec-tag{display:flex;align-items:center;gap:10px;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:14px;}
.sec-tag::before{content:'';width:20px;height:1px;background:var(--accent);display:block;}
h2.sec-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(38px,4.5vw,58px);letter-spacing:3px;color:var(--white);line-height:1.05;margin-bottom:12px;}
.sec-rule{width:40px;height:2px;background:var(--accent);margin:14px 0 20px;}
.sec-lead{font-size:16px;line-height:1.75;color:var(--muted);font-weight:300;max-width:560px;}

/* ══ O FIRMIE ══ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.about-text p{font-size:16px;line-height:1.8;color:var(--muted);font-weight:300;margin-bottom:14px;}
.about-text p strong{color:var(--off);font-weight:500;}
.about-text--centered{display:flex;flex-direction:column;justify-content:center;}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:40px;border:1px solid var(--border);}
.stat-box{padding:24px 20px;text-align:center;border-right:1px solid var(--border);}
.stat-box:last-child{border-right:none;}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:44px;color:var(--accent);line-height:1;}
.stat-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:6px;}

/* Dynamiczna siatka zdjęć "O firmie" — layout przez PHP spans */
.about-gallery{display:grid;gap:3px;width:100%;
  grid-template-columns:repeat(var(--cols,3),1fr);
  grid-auto-rows:var(--row-h,160px);
}
.about-gallery-item{display:block;overflow:hidden;cursor:pointer;position:relative;background:var(--card);}
.about-gallery-item img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .45s ease;}
.about-gallery-item:hover img{transform:scale(1.07);}
.about-gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,.35);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;}
.about-gallery-item:hover .about-gallery-overlay{opacity:1;}
.about-gallery-ph{width:100%;min-height:280px;background:var(--card);display:flex;align-items:center;justify-content:center;font-size:11px;color:#333;text-transform:uppercase;letter-spacing:2px;grid-column:1/-1;}

/* ══ REALIZACJE ══ */
.projects-cats{display:grid;gap:6px;margin-top:56px;background:var(--black);line-height:0;isolation:isolate;overflow:hidden;}
.cats-1{grid-template-columns:1fr;}
.cats-2{grid-template-columns:1fr 1fr;}
.cats-3{grid-template-columns:repeat(3,1fr);}
.cats-4{grid-template-columns:repeat(2,1fr);}
.cats-5{grid-template-columns:repeat(3,1fr);}
.cats-6{grid-template-columns:repeat(3,1fr);}
.cats-1 .proj-cat,.cats-2 .proj-cat{aspect-ratio:16/7;}
.proj-cat{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:#111;display:block;font-size:0;will-change:transform;transform:translateZ(0);}
.proj-cat-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block;vertical-align:bottom;will-change:transform;transform:translateZ(0);}
.proj-cat:hover .proj-cat-img{transform:scale(1.06) translateZ(0);}
.proj-cat-ph{width:100%;height:100%;background:linear-gradient(140deg,#1a1e24,#242c38);}
.proj-cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.2) 60%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px 24px;}
.proj-cat-title{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:3px;color:var(--white);margin-bottom:25px;}
.proj-cat-btn{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);transition:gap .2s;}
.proj-cat:hover .proj-cat-btn{gap:12px;}

/* Modal galerii */
.gallery-modal{display:none;position:fixed;inset:0;z-index:1100;background:rgba(0,0,0,.96);}
.gallery-modal.open{display:flex;flex-direction:column;}
.gallery-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);flex-shrink:0;}
.gallery-modal-title{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:3px;color:var(--white);}
.gallery-modal-close{background:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;height:40px;padding:0 16px;display:flex;align-items:center;gap:10px;font-size:18px;transition:all .2s;white-space:nowrap;}

.gallery-modal-close:hover{border-color:var(--accent);color:var(--white);}
.gallery-modal-close:hover .modal-close-label{color:var(--accent);}
.modal-close-label{font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);transition:color .2s;}
/* PhotoSwipe — napis Zamknij przy X */
.pswp-close-label{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.7);margin-right:8px;vertical-align:middle;}
.gallery-modal-body{flex:1;overflow-y:auto;padding:0;min-height:0;}

.gallery-modal-grid{
  display:grid;
  gap:3px;
  width:100%;
}
.gallery-modal-img{
  overflow:hidden;cursor:pointer;background:var(--card);
  min-height:0;min-width:0;
  position:relative;
}
.gallery-modal-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s;display:block;}
.gallery-modal-img:hover img{transform:scale(1.04);}
.gallery-modal-img::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(0,0,0,.35);
  opacity:0;transition:opacity .25s;
  pointer-events:none;
}
.gallery-modal-img:hover::after{opacity:1;}
.gallery-modal-img .gm-icon{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.7);
  opacity:0;transition:opacity .25s, transform .25s;
  pointer-events:none;z-index:1;
}
.gallery-modal-img:hover .gm-icon{opacity:1;transform:translate(-50%,-50%) scale(1);}

@media(max-width:768px){
  .gallery-modal-grid{gap:2px;}
  .gallery-modal-img img{transition:none;} /* wyłącz hover efekt na dotyku */
}
@media(max-width:480px){
  .gallery-modal-grid{gap:2px;}
}
/* Separator między grupami */
.gallery-modal-spacer{
  flex-shrink:0;
  height:32px;
  background:var(--black);
  display:flex;align-items:center;
  font-family:'Bebas Neue',sans-serif;
  font-size:13px;letter-spacing:3px;color:var(--accent);
  padding:0 8px;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.gallery-modal-empty,.gallery-modal-loading{color:var(--muted);font-size:14px;padding:48px;text-align:center;}

/* ── MOBILE GALLERY MODAL ── */
@media(max-width:768px){
  .gallery-modal-header{padding:10px 14px;gap:8px;}
  .gallery-modal-title{font-size:18px;letter-spacing:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw;}
  .gallery-modal-close{height:36px;padding:0 12px;gap:6px;}
  .modal-close-label{font-size:10px;letter-spacing:1px;}
  .gallery-modal-spacer{height:24px;font-size:11px;letter-spacing:2px;padding:0 6px;}
  .gallery-modal-grid{gap:2px;}
  .gallery-modal-img img{transition:none;}
}
@media(max-width:480px){
  .gallery-modal-header{padding:8px 12px;}
  .gallery-modal-title{font-size:16px;max-width:55vw;}
  .gallery-modal-grid{gap:2px;}
  .gallery-modal-close{min-width:44px;min-height:44px;}
}

html.no-scroll{overflow:hidden;}

.oferta-head{text-align:center;max-width:580px;margin:0 auto 64px;}
.oferta-head .sec-tag{justify-content:center;}
.oferta-head .sec-tag::before{display:none;}
.oferta-head .sec-rule{margin:14px auto 20px;}
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);}
.svc{background:var(--dark);padding:44px 36px;position:relative;overflow:hidden;transition:background .3s;}
.svc:hover{background:#1e1e1e;}
.svc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .3s;}
.svc:hover::after{transform:scaleX(1);}
.svc-num{display:none;}
.svc-icon{width:50px;height:50px;border:1px solid rgba(200,147,42,.3);display:flex;align-items:center;justify-content:center;margin-bottom:26px;}
.svc-icon svg{width:22px;height:22px;fill:var(--accent);}
.svc-title{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:3px;color:var(--white);margin-bottom:25px;}
.svc-list{list-style:none;display:flex;flex-direction:column;gap:10px;}
.svc-list li{font-size:14px;color:var(--muted);font-weight:300;display:flex;align-items:flex-start;gap:10px;line-height:1.5;}
.svc-list li::before{content:'';width:4px;height:4px;background:var(--accent);border-radius:50%;margin-top:7px;flex-shrink:0;}

/* ══ CTA ══ */
.cta-bar{background:var(--accent);padding:64px 56px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.cta-bar h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(34px,4vw,58px);letter-spacing:2px;color:var(--black);line-height:1.1;}
.cta-bar p{font-size:17px;color:rgba(0,0,0,.65);margin-top:8px;}
.cta-bar .btn-dark{padding:20px 48px;font-size:15px;letter-spacing:2.5px;}

/* ══ LOKALIZACJA ══ */
.lokalizacja-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:stretch;}
.lokalizacja-grid > div:first-child{display:flex;flex-direction:column;}
.loc-detail-rows{display:flex;flex-direction:column;margin-top:32px;flex:1;}
.loc-row{display:flex;gap:16px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--border);}
.loc-row:last-child{border-bottom:none;}
.loc-icon{width:38px;height:38px;flex-shrink:0;background:rgba(200,147,42,.1);border:1px solid rgba(200,147,42,.2);display:flex;align-items:center;justify-content:center;}
.loc-icon svg{width:16px;height:16px;fill:var(--accent);}
.loc-label{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-weight:600;}
.loc-val{font-size:15px;color:var(--off);line-height:1.5;}
.loc-val a{color:var(--off);text-decoration:none;}
.loc-val a:hover{color:var(--accent);}
.loc-nip{margin-top:24px;padding:14px 18px;background:var(--card);border:1px solid var(--border);display:flex;gap:24px;flex-wrap:wrap;}
.loc-nip span{font-size:12px;color:#808080;}
/* Mapa — wysokość dopasowana do lewej kolumny */
.lokalizacja-grid > div:last-child{display:flex;flex-direction:column;}
.map-wrap{width:100%;height:100%;min-height:420px;background:var(--card);border:1px solid var(--border);overflow:hidden;}
.map-wrap iframe{width:100%;height:100%;min-height:420px;border:none;display:block;}
.map-placeholder{width:100%;height:100%;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;position:relative;}
.map-placeholder::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 28px,rgba(255,255,255,.03) 28px,rgba(255,255,255,.03) 29px),repeating-linear-gradient(90deg,transparent,transparent 28px,rgba(255,255,255,.03) 28px,rgba(255,255,255,.03) 29px);}
.map-open-btn{position:relative;background:var(--accent);color:var(--black);padding:12px 24px;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;transition:background .2s;}
.map-open-btn:hover{background:var(--accent2);color:var(--black);}

/* ══ EU BANNER ══ */
.eu-banner{background:#fff;padding:28px 56px;}
.eu-inner{display:flex;align-items:center;justify-content:center;gap:40px;max-width:1100px;margin:0 auto;}
.eu-img{flex-shrink:0;display:flex;align-items:center;}
.eu-img img{max-height:110px;width:auto;display:block;}
.eu-text{flex:1;text-align:center;}
.eu-text p{font-size:12px;line-height:1.3;color:#222;font-weight:700;margin:0 0 4px;}
.eu-text p:last-child{margin-bottom:0;}

/* ══ FOOTER ══ */
footer.site-footer{background:#0a0a0a;border-top:1px solid var(--border);}
.footer-inner{padding:60px 56px 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;border-bottom:1px solid var(--border);}
.f-brand{display:flex;flex-direction:column;justify-content:center;}

.f-desc{font-size:13px;line-height:1.75;color:#555;font-weight:300;max-width:400px;}
.f-col-head{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:25px;}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.f-col li{font-size:13px;color:#555;}
.f-col a{font-size:13px;color:#555;text-decoration:none;font-weight:300;transition:color .2s;}
.f-col a:hover{color:var(--off);}
.footer-bottom{padding:18px 56px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.f-copy{font-size:12px;color:#555;}
.f-legal{display:flex;gap:20px;list-style:none;}
.f-legal a{font-size:12px;color:#555;text-decoration:none;}
.f-legal a:hover{color:var(--muted);}

/* ── Widgety w stopce ── */
.f-widget .textwidget,
.f-widget p,
.f-widget ul,
.f-widget ol{
  font-size:13px;
  line-height:1.9;
  color:#555;
  font-weight:300;
}
.f-widget a{
  font-size:13px;
  color:#555;
  text-decoration:none;
  font-weight:300;
  transition:color .2s;
}
.f-widget a:hover{color:var(--off);}
.f-widget ul{list-style:none;display:flex;flex-direction:column;gap:5px;}
.f-widget strong,.f-widget b{color:var(--off);font-weight:600;}
.f-widget p{margin:0 0 6px;}
.f-widget p:last-child{margin-bottom:0;}
/* Tytuł widgetu — identyczny styl jak .f-col-head */
.f-widget .widget-title,
.f-widget .widgettitle{
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:600;
  margin:0 0 20px;
  font-family:'Inter',sans-serif;
}
/* Kontener widgetu w stopce */
.f-col .f-widget,
.f-col > div{overflow:hidden;}

/* Iframe FB — filtr ciemności + monochromatyczność */
.f-col iframe[src*="facebook"],
.f-col iframe[src*="fb.com"],
.widget_facebook_likebox iframe,
.widget_facebook_page iframe{
  filter:invert(1) hue-rotate(180deg) brightness(0.85) contrast(0.9) !important;
  border-radius:2px !important;
  max-width:100% !important;
}

/* Odwróć ponownie zdjęcia/awatary żeby były normalne */
.f-col iframe[src*="facebook"] img,
.widget_facebook_likebox img,
.widget_facebook_page img{
  filter:invert(1) hue-rotate(180deg) !important;
}

/* Ramka wokół całego widgetu FB */
.f-col .fb_iframe_widget,
.f-col .fb-page,
.f-col .fb-like-box{
  border:1px solid var(--border) !important;
  display:block !important;
  max-width:100% !important;
}
.f-col .fb_iframe_widget span,
.f-col .fb-page > span,
.f-col .fb-like-box > span{
  max-width:100% !important;
  width:100% !important;
}

/* ══ BACK TO TOP ══ */
.back-to-top{position:fixed;bottom:80px;right:32px;z-index:300;width:48px;height:48px;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s,visibility .3s,transform .3s,background .2s;box-shadow:0 4px 20px rgba(200,147,42,.4);}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0);}
.back-to-top:hover{background:var(--accent2);}
.back-to-top svg{width:22px;height:22px;fill:var(--black);}

/* ══ SCROLL REVEAL ══ */
.rv{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease;}
.rv.in{opacity:1;transform:translateY(0);}
.rv.d1{transition-delay:.15s;}.rv.d2{transition-delay:.3s;}.rv.d3{transition-delay:.45s;}

/* ══ SZABLON STRON (page.php) ══ */
.page-hero{
  background:var(--dark);
  padding:calc(var(--nav-h) + 56px) 56px 56px;
  border-bottom:1px solid var(--border);
}
.page-hero-inner{max-width:860px;}
.page-hero-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(42px,6vw,72px);
  letter-spacing:3px;
  color:var(--white);
  line-height:1.05;
  margin-bottom:0;
}
.page-main{background:var(--black);min-height:60vh;}
.page-content-inner{max-width:860px;margin:0 auto;padding:64px 56px;}
.page-featured-img{margin-bottom:40px;border-radius:2px;overflow:hidden;}
.page-featured-img img{width:100%;height:auto;display:block;}

/* Stylizacja treści WP */
.wp-content{color:var(--off);font-size:16px;line-height:1.85;}
.wp-content h1,.wp-content h2,.wp-content h3,.wp-content h4{
  font-family:'Bebas Neue',sans-serif;
  color:var(--white);
  letter-spacing:2px;
  margin:40px 0 16px;
  line-height:1.1;
}
.wp-content h1{font-size:clamp(32px,4vw,48px);}
.wp-content h2{font-size:clamp(26px,3vw,38px);}
.wp-content h3{font-size:clamp(22px,2.5vw,30px);}
.wp-content h4{font-size:20px;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:0;}
.wp-content p{margin-bottom:25px;}
.wp-content p:last-child{margin-bottom:0;}
.wp-content strong{color:var(--white);font-weight:600;}
.wp-content a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(200,147,42,.3);transition:border-color .2s;}
.wp-content a:hover{border-color:var(--accent);}
.wp-content ul,.wp-content ol{margin:0 0 20px 24px;}
.wp-content li{margin-bottom:8px;}
.wp-content blockquote{
  border-left:3px solid var(--accent);
  margin:32px 0;
  padding:20px 28px;
  background:var(--card);
  color:var(--muted);
  font-style:italic;
}
.wp-content blockquote p{margin:0;}
.wp-content img{max-width:100%;height:auto;border-radius:2px;margin:24px 0;}
.wp-content figure{margin:32px 0;}
.wp-content figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:8px;}
.wp-content hr{border:none;border-top:1px solid var(--border);margin:40px 0;}
.wp-content table{width:100%;border-collapse:collapse;margin:24px 0;}
.wp-content th{background:var(--card);color:var(--white);padding:12px 16px;text-align:left;font-size:12px;letter-spacing:1px;text-transform:uppercase;}
.wp-content td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--off);}
.wp-content tr:last-child td{border-bottom:none;}
.wp-content .wp-block-image img{border-radius:2px;}
.page-links{margin-top:40px;display:flex;gap:8px;flex-wrap:wrap;}
.page-links span{font-size:13px;color:var(--muted);}
.page-links a,.page-links span span{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  border:1px solid var(--border);
  font-size:13px;color:var(--muted);
  text-decoration:none;transition:all .2s;
}
.page-links a:hover{border-color:var(--accent);color:var(--accent);}
.page-links span span{background:var(--accent);border-color:var(--accent);color:var(--black);}

/* ── Szeroki szablon ── */
.page-hero--wide{padding-left:56px;padding-right:56px;}
.page-hero-inner--wide{max-width:1200px;}
.page-content-inner--wide{max-width:1200px;padding-left:56px;padding-right:56px;}
.wp-content--wide{font-size:17px;}
.wp-content--wide h2{font-size:clamp(28px,3.2vw,42px);}
.wp-content--wide h3{font-size:clamp(22px,2.5vw,32px);}

/* ══ STRONA 404 ══ */
.error404-wrap{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:var(--black);
  padding:calc(var(--nav-h) + 40px) 40px 80px;
  text-align:center;
}
.error404-inner{max-width:600px;width:100%;}
.error404-code{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(120px,20vw,200px);
  line-height:.9;
  color:transparent;
  -webkit-text-stroke:2px var(--border);
  letter-spacing:8px;
  margin-bottom:24px;
  user-select:none;
}
.error404-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(28px,4vw,46px);
  letter-spacing:3px;
  color:var(--white);
  margin-bottom:0;
}
.error404-inner .sec-rule{margin:16px auto 0;}
.error404-inner .sec-tag{justify-content:center;}
.error404-inner .sec-tag::before{display:none;}
.error404-msg{
  font-size:16px;line-height:1.8;color:var(--muted);
  margin:28px 0 36px;
}
.error404-msg strong{color:var(--accent);font-size:18px;font-variant-numeric:tabular-nums;}
.error404-btn{margin-bottom:40px;display:inline-block;}
.error404-progress{
  width:100%;height:3px;
  background:var(--border);
  border-radius:2px;
  overflow:hidden;
}
.error404-progress-bar{
  height:100%;width:0%;
  background:var(--accent);
  transition:width 1s linear;
  border-radius:2px;
}

/* ══ RESPONSIVE ══ */
@media(max-width:1200px){
  nav.site-nav{padding:0 28px;}
  .nav-links a{padding:0 12px;font-size:11px;}
  .hero-section{grid-template-columns:1fr 520px;}
}
@media(max-width:960px){
  :root{--nav-h:72px;}
  .nav-links{display:none;}
  .nav-tel{display:none!important;}
  .nav-hamburger{display:flex;margin-left:16px;}
  .hero-section{grid-template-columns:1fr;min-height:auto;}
  .hero-left{padding:48px 24px 0;}
  .hero-right{padding:32px 24px 48px;}
  .slider-dots{left:24px;bottom:16px;}
  .about-grid{grid-template-columns:1fr;gap:40px;}
  .about-gallery[data-count="8"]{grid-template-columns:repeat(3,1fr);}
  .about-gallery[data-count="9"]{grid-template-columns:repeat(3,1fr);}
  .cats-3,.cats-5,.cats-6{grid-template-columns:1fr 1fr;}
  .services{grid-template-columns:1fr;}
  .cta-bar{padding:40px 24px;}
  .lokalizacja-grid{grid-template-columns:1fr;gap:32px;}
  .footer-inner{grid-template-columns:1fr 1fr;padding:48px 24px;}
  .footer-bottom{padding:16px 24px;}
  .section{padding:64px 24px;}
  .eu-banner{padding:20px 24px;}
  .eu-inner{gap:24px;}
  .eu-img img{max-height:80px;}
  .page-hero{padding:calc(var(--nav-h) + 32px) 28px 40px;}
  .page-content-inner{padding:40px 28px;}
  .page-hero--wide{padding-left:28px;padding-right:28px;}
  .page-content-inner--wide{padding-left:28px;padding-right:28px;}
  .back-to-top{bottom:20px;right:20px;width:42px;height:42px;}
}
@media(max-width:600px){
  .cats-2,.cats-3,.cats-4,.cats-5,.cats-6{grid-template-columns:1fr;}
  .proj-cat,.cats-1 .proj-cat,.cats-2 .proj-cat{aspect-ratio:16/9;}
  .about-gallery{--cols:2!important;--row-h:140px!important;}
  .about-gallery[data-count="1"]{--cols:1!important;--row-h:280px!important;}
  .about-gallery[data-count="2"]{--cols:2!important;--row-h:200px!important;}
  .about-stats{grid-template-columns:1fr;}
  .stat-box{border-right:none;border-bottom:1px solid var(--border);}
  .stat-box:last-child{border-bottom:none;}
  .footer-inner{grid-template-columns:1fr;}
  .hero-right{padding:24px 16px 40px;}
  .contact-card{padding:32px 24px;}
  .back-to-top{bottom:20px;right:20px;}
  .eu-inner{flex-direction:column;gap:16px;}
  .eu-img img{max-height:70px;}
  .page-hero{padding:calc(var(--nav-h) + 24px) 20px 32px;}
  .page-content-inner{padding:32px 20px;}
  .page-hero--wide{padding-left:20px;padding-right:20px;}
  .page-content-inner--wide{padding-left:20px;padding-right:20px;}
  .wp-content--wide{font-size:15px;}
  .wp-content{font-size:15px;}
}
