/* D&O Junk Bros – premium static website */
:root {
  --black:#090909;
  --black-soft:#0f0f0f;
  --charcoal:#171717;
  --charcoal-2:#202020;
  --panel:#1a1a1a;
  --orange:#f4771e;
  --orange-light:#ffa259;
  --orange-deep:#cc570d;
  --white:#f8f7f3;
  --muted:#b8b8b8;
  --muted-dark:#8b8b8b;
  --line:rgba(255,255,255,.12);
  --shadow:0 24px 68px rgba(0,0,0,.44);
  --container:1180px;
  --display:"Bebas Neue", Impact, sans-serif;
  --body:"Manrope", Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--black)}
body{margin:0;background:var(--black);color:var(--white);font-family:var(--body);line-height:1.6;overflow-x:hidden}
body.modal-open,body.nav-open{overflow:hidden}
a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}img{display:block;max-width:100%}
::selection{background:var(--orange);color:var(--black)}
.svg-sprite{position:absolute;width:0;height:0;overflow:hidden}.icon{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}
.container{width:min(calc(100% - 40px),var(--container));margin-inline:auto}.section{position:relative;padding:116px 0}.section-tight{padding:36px 0}
.skip-link{position:fixed;top:12px;left:12px;z-index:10000;padding:10px 15px;background:var(--orange);border-radius:8px;color:#111;font-weight:800;transform:translateY(-180%);transition:transform .2s}.skip-link:focus{transform:translateY(0)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;margin:0 0 16px;color:var(--orange-light);font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.eyebrow>span{width:28px;height:2px;background:var(--orange)}
.section-head{max-width:720px}.section-head h2,.why-intro h2,.quote-copy h2,.reviews-copy h2,.faq-copy h2,.contact-copy h2,.photo-estimate h2,.social h2{margin:0;font-family:var(--display);font-size:clamp(3.1rem,5.6vw,5.9rem);line-height:.91;font-weight:400;letter-spacing:.01em;text-transform:uppercase}.section-head>p:last-child,.why-intro>p,.quote-copy>p,.reviews-copy>p,.faq-copy>p,.contact-copy>p,.photo-estimate p,.social p{margin:21px 0 0;color:var(--muted);font-size:1rem}.center{margin-inline:auto;text-align:center}.center .eyebrow{justify-content:center}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.reveal.is-visible{opacity:1;transform:none}.reveal-delay{transition-delay:.13s}.reveal-delay-sm{transition-delay:.1s}.reveal-delay-md{transition-delay:.2s}.reveal-delay-lg{transition-delay:.28s}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:52px;padding:13px 20px;border:1px solid transparent;border-radius:11px;font-size:.85rem;font-weight:900;line-height:1.2;transition:transform .2s,background .2s,border-color .2s,box-shadow .2s}.btn:hover{transform:translateY(-3px)}.btn-orange{background:var(--orange);color:#101010;box-shadow:0 12px 26px rgba(244,119,30,.24)}.btn-orange:hover{background:var(--orange-light);box-shadow:0 16px 34px rgba(244,119,30,.34)}.btn-outline{border-color:rgba(255,255,255,.27);background:rgba(255,255,255,.03);color:var(--white)}.btn-outline:hover{border-color:var(--orange);background:rgba(244,119,30,.08)}.btn-full{width:100%}
.btn:focus-visible,.nav-link:focus-visible,.menu-toggle:focus-visible,.top-button:focus-visible,.detail-card:focus-visible,.ba-range:focus-visible{outline:3px solid var(--orange-light);outline-offset:4px}
/* NAV */
.site-header{position:sticky;top:0;z-index:100;height:79px;border-bottom:1px solid transparent;background:rgba(9,9,9,.72);backdrop-filter:blur(18px);transition:background .2s,border-color .2s,box-shadow .2s}.site-header.scrolled{background:rgba(9,9,9,.95);border-color:var(--line);box-shadow:0 10px 26px rgba(0,0,0,.18)}
.nav-wrap{min-height:79px;display:flex;align-items:center;justify-content:space-between;gap:23px}.brand{display:flex;align-items:flex-end;gap:9px;min-width:max-content;line-height:1}.brand-code{font-family:var(--display);font-size:2.22rem;letter-spacing:.02em;transform:skewX(-9deg)}.brand-amp{display:inline-block;margin:0 .06em;color:var(--orange);font-size:.34em;transform:translateY(-.42em) skewX(9deg);vertical-align:middle}.brand-title{padding-bottom:3px;font-size:.72rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.site-nav{display:flex;align-items:center;gap:5px}.nav-link{position:relative;padding:11px 10px;border-radius:8px;color:#c9c9c9;font-size:.74rem;font-weight:800;white-space:nowrap;transition:color .2s,background .2s}.nav-link::after{position:absolute;right:10px;bottom:4px;left:10px;height:2px;background:var(--orange);content:"";transform:scaleX(0);transform-origin:left;transition:transform .2s}.nav-link:hover,.nav-link.active{color:var(--white);background:rgba(255,255,255,.04)}.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}.nav-call{display:inline-flex;align-items:center;gap:8px;margin-left:9px;padding:10px 14px;border:1px solid rgba(244,119,30,.56);border-radius:9px;background:rgba(244,119,30,.12);color:var(--orange-light);font-size:.75rem;font-weight:900;transition:background .2s,color .2s}.nav-call:hover{background:var(--orange);color:#151515}.nav-call .icon{width:16px;height:16px}.menu-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:10px;background:var(--charcoal);color:var(--white)}.menu-close{display:none}.menu-toggle.open .menu-open{display:none}.menu-toggle.open .menu-close{display:block}
/* HERO */
.hero{display:flex;align-items:center;min-height:calc(100vh - 79px);padding-top:78px;padding-bottom:80px;overflow:hidden;background:radial-gradient(circle at 83% 37%,rgba(244,119,30,.19),transparent 0 24%),radial-gradient(circle at 24% 62%,rgba(244,119,30,.07),transparent 0 31%),var(--black)}.hero-grid{position:absolute;inset:0;opacity:.8;background-image:linear-gradient(rgba(255,255,255,.027) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.027) 1px,transparent 1px);background-size:54px 54px;mask-image:linear-gradient(#000,transparent 82%)}.hero-sweep{position:absolute;top:-90px;right:-220px;width:690px;height:690px;border:1px solid rgba(244,119,30,.18);border-radius:50%;box-shadow:0 0 0 66px rgba(244,119,30,.04),0 0 0 132px rgba(244,119,30,.02)}.hero-layout{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .92fr;gap:60px;align-items:center}.hero h1{max-width:780px;margin:0;font-family:var(--display);font-size:clamp(4.1rem,7.2vw,8rem);font-weight:400;letter-spacing:.01em;line-height:.84;text-transform:uppercase}.hero h1 strong{color:var(--orange);font-weight:400}.tagline{margin:25px 0 0;font-size:clamp(1.04rem,1.6vw,1.35rem);font-weight:900}.intro{max-width:650px;margin:18px 0 0;color:var(--muted);font-size:1rem}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.hero-proof{display:flex;flex-wrap:wrap;gap:11px 20px;margin-top:28px}.hero-proof span{display:inline-flex;align-items:center;gap:7px;color:#ddd;font-size:.76rem;font-weight:800}.hero-proof .icon{width:16px;height:16px;color:var(--orange)}.hero-copy small{display:block;margin-top:9px;color:var(--muted-dark);font-size:.7rem}.hero-media{position:relative;display:flex;align-items:center;justify-content:center;min-height:560px}.hero-ring{position:absolute;border:1px solid rgba(244,119,30,.38);border-radius:50%}.ring-one{width:min(100%,510px);aspect-ratio:1;background:radial-gradient(circle,rgba(244,119,30,.17),transparent 65%);animation:pulse 4.5s ease-in-out infinite}.ring-two{width:min(100%,620px);aspect-ratio:1;border-color:rgba(255,255,255,.09)}.hero-logo-card{position:relative;z-index:2;width:min(100%,548px);border:1px solid rgba(255,255,255,.18);border-radius:29px;overflow:hidden;background:#0b0b0b;box-shadow:var(--shadow);transform:rotate(1.6deg)}.hero-logo-card::after{position:absolute;inset:11px;border:1px solid rgba(244,119,30,.42);border-radius:19px;content:"";pointer-events:none}.hero-logo-card img{width:100%;aspect-ratio:1;object-fit:contain;transform:scale(1.03)}.float-card{position:absolute;z-index:3;display:flex;align-items:center;gap:9px;padding:11px 13px;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:rgba(19,19,19,.92);box-shadow:var(--shadow);font-size:.7rem;font-weight:900;backdrop-filter:blur(12px)}.float-card .icon{width:18px;height:18px;color:var(--orange)}.float-card-one{right:-2%;top:9%}.float-card-two{bottom:11%;left:-5%}
/* ESTIMATE */
.photo-estimate{border-top:1px solid rgba(244,119,30,.2);border-bottom:1px solid rgba(244,119,30,.2);background:linear-gradient(100deg,rgba(244,119,30,.13),rgba(244,119,30,.035) 55%,transparent)}.photo-estimate-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px;padding:24px 0}.estimate-icon{display:grid;width:58px;height:58px;place-items:center;border-radius:16px;background:var(--orange);color:#111}.estimate-icon .icon{width:30px;height:30px}.photo-estimate .eyebrow{margin-bottom:7px}.photo-estimate h2{font-size:clamp(2rem,3.3vw,3.4rem)}.photo-estimate p{max-width:700px;margin-top:8px;font-size:.83rem}.photo-estimate strong{color:var(--orange-light)}
/* SERVICES */
.services{background:var(--black-soft)}.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:43px}.service-card{min-height:244px;padding:26px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(145deg,#1c1c1c,#121212);transition:transform .23s,border-color .23s,box-shadow .23s}.service-card:hover{transform:translateY(-5px);border-color:rgba(244,119,30,.62);box-shadow:0 18px 40px rgba(0,0,0,.24)}.service-icon{display:grid;width:48px;height:48px;place-items:center;border:1px solid rgba(244,119,30,.45);border-radius:12px;background:rgba(244,119,30,.11);color:var(--orange)}.service-icon .icon{width:24px;height:24px}.service-card h3{margin:21px 0 10px;font-size:.99rem;line-height:1.35}.service-card p{margin:0;color:var(--muted);font-size:.82rem}
/* WHY */
.why{overflow:hidden;background:linear-gradient(90deg,rgba(244,119,30,.055),transparent 38%),var(--charcoal)}.why-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:74px;align-items:start}.why-intro{position:sticky;top:115px}.text-link{display:inline-flex;align-items:center;gap:9px;margin-top:26px;color:var(--orange-light);font-size:.85rem;font-weight:900}.text-link .icon{transition:transform .2s}.text-link:hover .icon{transform:translateX(4px)}.why-list{display:grid;gap:13px}.why-item{display:flex;gap:17px;padding:21px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.022);transition:transform .2s,border-color .2s}.why-item:hover{transform:translateX(5px);border-color:rgba(244,119,30,.5)}.why-icon{display:grid;width:48px;height:48px;place-items:center;border-radius:13px;background:rgba(244,119,30,.11);color:var(--orange)}.why-icon .icon{width:24px;height:24px}.why-item h3{margin:0 0 5px;font-size:.96rem}.why-item p{margin:0;color:var(--muted);font-size:.81rem}
/* PROCESS */
.process{background:var(--black-soft)}.process-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}.process-grid::before{position:absolute;top:77px;right:12%;left:12%;height:1px;background:linear-gradient(90deg,transparent,rgba(244,119,30,.7),transparent);content:""}.process-card{position:relative;z-index:1;min-height:280px;padding:21px 20px 24px;border:1px solid var(--line);border-radius:18px;background:var(--charcoal);text-align:center}.stage{display:inline-block;padding:5px 9px;border:1px solid rgba(244,119,30,.38);border-radius:100px;color:var(--orange-light);font-size:.68rem;font-weight:900;text-transform:uppercase}.process-icon{display:grid;width:78px;height:78px;place-items:center;margin:17px auto;border:1px solid rgba(244,119,30,.5);border-radius:50%;background:#171717;color:var(--orange);box-shadow:0 0 0 9px var(--black-soft)}.process-icon .icon{width:32px;height:32px}.process-card h3{margin:0 0 9px;font-size:.94rem;line-height:1.3}.process-card p{margin:0;color:var(--muted);font-size:.79rem}
/* REALISATIONS */
.realizacje{background:var(--black)}.realizacje-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px}.realization-badge{display:flex;align-items:center;gap:10px;max-width:280px;margin-bottom:43px;padding:12px 14px;border:1px solid rgba(244,119,30,.3);border-radius:12px;background:rgba(244,119,30,.08);color:#e6e6e6;font-size:.75rem;font-weight:800}.realization-badge .icon{width:19px;height:19px;color:var(--orange)}.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.ba-card{padding:15px;border:1px solid var(--line);border-radius:19px;background:var(--charcoal);box-shadow:0 12px 28px rgba(0,0,0,.16)}.ba-title{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:0 4px 12px}.ba-title span{color:var(--orange-light);font-size:.7rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.ba-title strong{font-size:.78rem}.ba-frame{position:relative;height:380px;border-radius:12px;overflow:hidden;background:#111;isolation:isolate}.ba-frame>img{width:100%;height:100%;object-fit:cover}.ba-after{position:absolute;inset:0}.ba-before{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;clip-path:inset(0 calc(100% - var(--split)) 0 0)}.ba-divider{position:absolute;top:0;bottom:0;left:var(--split);width:0;transform:translateX(-50%);pointer-events:none}.ba-divider span{position:absolute;top:50%;left:50%;width:42px;height:42px;border:2px solid var(--white);border-radius:50%;background:var(--orange);box-shadow:0 5px 18px rgba(0,0,0,.4);transform:translate(-50%,-50%)}.ba-divider span::before,.ba-divider span::after{position:absolute;top:50%;width:9px;height:2px;background:#111;content:""}.ba-divider span::before{left:8px;transform:rotate(35deg)}.ba-divider span::after{right:8px;transform:rotate(-35deg)}.ba-label{position:absolute;top:12px;z-index:2;padding:5px 8px;border-radius:6px;background:rgba(0,0,0,.66);font-size:.68rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.ba-label-before{left:12px}.ba-label-after{right:12px}.ba-control{display:flex;align-items:center;justify-content:space-between;gap:13px;padding:13px 4px 1px;color:var(--muted);font-size:.72rem;font-weight:800}.ba-range{width:46%;accent-color:var(--orange);cursor:ew-resize}.gallery-extra{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:18px}.detail-card{position:relative;min-height:315px;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--charcoal);cursor:pointer}.detail-card img{width:100%;height:315px;object-fit:cover;filter:saturate(.85) contrast(1.04);transition:transform .4s,filter .4s}.detail-card:hover img{transform:scale(1.06);filter:saturate(1) contrast(1.05)}.detail-card>div{position:absolute;right:0;bottom:0;left:0;padding:38px 20px 18px;background:linear-gradient(transparent,rgba(0,0,0,.94))}.detail-card span{color:var(--orange-light);font-size:.7rem;font-weight:900;text-transform:uppercase}.detail-card h3{margin:5px 0 4px;font-size:1rem}.detail-card p{margin:0;color:#d2d2d2;font-size:.78rem}.gallery-action{display:flex;justify-content:center;margin-top:30px}
/* QUOTE */
.quote-section{overflow:hidden;background:radial-gradient(circle at 13% 78%,rgba(244,119,30,.2),transparent 0 29%),#151515}.quote-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:58px;align-items:center}.quote-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}.quote-panel{padding:33px;border:1px solid rgba(244,119,30,.32);border-radius:25px;background:linear-gradient(145deg,rgba(244,119,30,.13),rgba(244,119,30,.02)),rgba(22,22,22,.82);box-shadow:var(--shadow)}.quote-panel-icon{display:grid;width:52px;height:52px;place-items:center;border-radius:50%;background:var(--orange);color:#111}.quote-panel-icon .icon{width:28px;height:28px}.quote-panel h3{margin:20px 0 16px;font-size:1.08rem}.quote-panel ul{display:grid;gap:10px;margin:0;padding:0;list-style:none}.quote-panel li{position:relative;padding-left:20px;color:#dedede;font-size:.82rem}.quote-panel li::before{position:absolute;top:.58em;left:0;width:7px;height:7px;border-radius:50%;background:var(--orange);content:""}
/* REVIEWS */
.reviews{background:var(--black-soft)}.reviews-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:70px;align-items:center}.review-shot{padding:17px;border:1px solid rgba(244,119,30,.35);border-radius:18px;background:linear-gradient(145deg,rgba(244,119,30,.08),transparent),var(--charcoal);box-shadow:var(--shadow)}.review-shot img{width:100%;border-radius:10px}.reviews-copy blockquote{margin:25px 0 0;padding-left:19px;border-left:3px solid var(--orange);font-size:clamp(1.08rem,2vw,1.45rem);font-weight:800;line-height:1.45}.review-note{display:inline-flex;align-items:center;gap:7px;margin-top:21px;color:var(--orange-light);font-size:.76rem;font-weight:900}.review-note .icon{width:16px;height:16px}
/* MAP */
.area{background:var(--charcoal)}.area-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px}.area-note{display:flex;align-items:center;gap:9px;max-width:290px;margin-bottom:42px;color:#ddd;font-size:.79rem;font-weight:800}.area-note .icon{width:19px;height:19px;color:var(--orange)}.map-shell{height:520px;border:1px solid var(--line);border-radius:23px;overflow:hidden;box-shadow:var(--shadow);background:#dedede}.town-list{display:flex;flex-wrap:wrap;gap:9px;margin-top:20px}.town-list span{padding:7px 11px;border:1px solid var(--line);border-radius:100px;background:rgba(255,255,255,.035);color:#ddd;font-size:.74rem;font-weight:800}.leaflet-container{font-family:var(--body)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#1a1a1a;color:#f8f7f3}.leaflet-popup-content{margin:12px 14px;font-size:.8rem;font-weight:800}.map-marker{display:grid;width:27px;height:27px;place-items:center;border:2px solid #fff;border-radius:50%;background:var(--orange);box-shadow:0 5px 14px rgba(0,0,0,.35)}.map-marker::after{width:7px;height:7px;border-radius:50%;background:#151515;content:""}
/* FAQ */
.faq{background:var(--black-soft)}.faq-layout{display:grid;grid-template-columns:.76fr 1.24fr;gap:70px;align-items:start}.faq-copy a{color:var(--orange-light);font-weight:900}.faq-list{border-top:1px solid var(--line)}details{border-bottom:1px solid var(--line)}summary{display:flex;align-items:center;justify-content:space-between;gap:17px;padding:21px 0;cursor:pointer;font-size:.92rem;font-weight:900;list-style:none}summary::-webkit-details-marker{display:none}summary .icon{color:var(--orange);transition:transform .2s}details[open] summary .icon{transform:rotate(180deg)}details p{max-width:720px;margin:0;padding:0 0 21px;color:var(--muted);font-size:.84rem}
/* SOCIAL */
.social{background:linear-gradient(110deg,rgba(244,119,30,.1),transparent 38%),var(--charcoal)}.social-inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px;align-items:center}.social-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.social-list>div{display:grid;min-height:155px;place-items:center;align-content:center;gap:7px;padding:16px;border:1px solid var(--line);border-radius:17px;background:rgba(255,255,255,.025);text-align:center}.social-list b{display:grid;width:44px;height:44px;place-items:center;border:1px solid rgba(244,119,30,.5);border-radius:50%;color:var(--orange);font-size:1.25rem}.social-list span{font-size:.82rem;font-weight:900}.social-list small{color:var(--muted-dark);font-size:.7rem}
/* CONTACT */
.contact{background:var(--black)}.contact-layout{display:grid;grid-template-columns:.88fr 1.12fr;gap:70px;align-items:start}.contact-list{display:grid;gap:11px;margin-top:30px}.contact-item{display:flex;align-items:center;gap:14px;min-height:74px;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.018);transition:transform .2s,border-color .2s,background .2s}.contact-item[href]:hover{transform:translateX(4px);border-color:rgba(244,119,30,.58);background:rgba(244,119,30,.06)}.contact-item>span{display:grid;width:42px;height:42px;place-items:center;border-radius:11px;background:rgba(244,119,30,.12);color:var(--orange)}.contact-item .icon{width:21px;height:21px}.contact-item div{display:grid;gap:1px}.contact-item b{font-size:.78rem}.contact-item small{color:var(--muted);font-size:.76rem}.form-card{padding:33px;border:1px solid rgba(244,119,30,.25);border-radius:24px;background:linear-gradient(145deg,rgba(244,119,30,.09),transparent 48%),var(--charcoal);box-shadow:var(--shadow)}.form-card h3{margin:0;font-size:1.2rem}.form-card>p{margin:8px 0 0;color:var(--muted);font-size:.8rem}form{display:grid;gap:16px;margin-top:25px}form label{display:grid;gap:7px;color:#eee;font-size:.77rem;font-weight:800}input,textarea{width:100%;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:rgba(0,0,0,.2);color:var(--white);outline:none;transition:border-color .2s,box-shadow .2s}input{height:50px;padding:0 14px}textarea{min-height:130px;padding:13px 14px;resize:vertical}input:focus,textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(244,119,30,.14)}input::placeholder,textarea::placeholder{color:#777}.form-status{min-height:17px;margin:0;color:var(--orange-light);font-size:.75rem;font-weight:800}
/* FOOTER */
.site-footer{border-top:1px solid var(--line);background:#070707}.footer-top{display:grid;grid-template-columns:1.35fr repeat(3,1fr);gap:34px;padding:60px 0 42px}.footer-brand img{width:176px;border-radius:13px}.footer-brand p{max-width:320px;margin:15px 0 0;color:var(--muted);font-size:.79rem}.footer-top h3{margin:0 0 14px;font-size:.86rem}.footer-top a,.footer-top p:not(.footer-brand p){display:block;margin:0 0 8px;color:var(--muted);font-size:.78rem}.footer-top a:hover{color:var(--orange-light)}.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 0;border-top:1px solid var(--line)}.footer-bottom p{margin:0;color:var(--muted-dark);font-size:.71rem}.top-button{display:inline-flex;align-items:center;gap:8px;border:0;background:transparent;color:#ddd;font-size:.74rem;font-weight:900}.top-button .icon{width:16px;height:16px;transform:rotate(-90deg)}.top-button:hover{color:var(--orange-light)}
.floating-call{position:fixed;right:20px;bottom:20px;z-index:80;display:inline-flex;align-items:center;gap:9px;min-height:53px;padding:0 18px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:var(--orange);color:#101010;box-shadow:0 18px 36px rgba(0,0,0,.38);font-size:.8rem;font-weight:900;transition:transform .2s,background .2s}.floating-call:hover{transform:translateY(-3px);background:var(--orange-light)}
/* MODAL */
.modal[hidden]{display:none}.modal{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:18px}.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(6px)}.modal-dialog,.lightbox-dialog{position:relative;z-index:1;width:min(100%,430px);border:1px solid rgba(244,119,30,.35);border-radius:20px;background:var(--charcoal);box-shadow:var(--shadow);animation:modalIn .22s ease both}.modal-dialog{padding:36px 30px 29px;text-align:center}.modal-close{position:absolute;top:12px;right:12px;display:grid;width:38px;height:38px;place-items:center;border:1px solid var(--line);border-radius:9px;background:rgba(255,255,255,.04);color:var(--white)}.modal-close:hover{border-color:var(--orange);background:rgba(244,119,30,.1)}.modal-icon{display:grid;width:61px;height:61px;place-items:center;margin:auto;border-radius:50%;background:rgba(244,119,30,.14);color:var(--orange)}.modal-icon .icon{width:31px;height:31px}.modal-dialog>p{margin:18px 0 3px;color:var(--orange-light);font-size:.72rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.modal-dialog h2{margin:0;font-family:var(--display);font-size:2.65rem;font-weight:400;text-transform:uppercase}.modal-number{display:block;margin:12px 0;color:var(--orange);font-family:var(--display);font-size:3rem;line-height:1}.modal-dialog small{display:block;margin:14px 0 22px;color:var(--muted);font-size:.78rem}.modal-dialog #copy-status{display:block;min-height:17px;margin-top:10px;color:var(--orange-light);font-size:.75rem;font-weight:800}.lightbox-dialog{width:min(100%,1000px);padding:10px}.lightbox-dialog img{width:100%;max-height:75vh;border-radius:13px;object-fit:contain;background:#090909}.lightbox-dialog p{margin:10px 7px 4px;text-align:center;font-size:.8rem;font-weight:800}
@keyframes pulse{0%,100%{transform:scale(.98);opacity:.72}50%{transform:scale(1.035);opacity:1}}@keyframes modalIn{from{opacity:0;transform:translateY(11px) scale(.97)}to{opacity:1;transform:none}}
/* RESPONSIVE */
@media(max-width:1100px){.nav-link{padding:10px 7px;font-size:.7rem}.site-nav{gap:2px}.hero-layout{gap:35px}.service-grid{grid-template-columns:repeat(2,1fr)}.footer-top{grid-template-columns:1.2fr repeat(3,1fr)}}
@media(max-width:900px){.site-header,.nav-wrap{height:72px;min-height:72px}.menu-toggle{display:grid;place-items:center}.site-nav{position:fixed;top:72px;right:0;left:0;display:grid;gap:0;padding:20px;border-bottom:1px solid var(--line);background:#121212;box-shadow:0 18px 40px rgba(0,0,0,.35);opacity:0;pointer-events:none;transform:translateY(-12px);transition:opacity .2s,transform .2s}.site-nav.open{opacity:1;pointer-events:auto;transform:none}.nav-link{padding:13px 3px;border-bottom:1px solid var(--line);font-size:.93rem}.nav-link::after{display:none}.nav-call{justify-self:start;margin:17px 0 0}.hero{min-height:auto;padding-top:62px}.hero-layout,.why-layout,.quote-layout,.reviews-layout,.faq-layout,.contact-layout,.social-inner{grid-template-columns:1fr;gap:42px}.hero-media{min-height:480px}.why-intro{position:static}.photo-estimate-inner{grid-template-columns:auto 1fr}.photo-estimate-inner .btn{grid-column:1/-1;justify-self:start}.realizacje-head,.area-head{align-items:flex-start;flex-direction:column}.realization-badge,.area-note{margin:-16px 0 0}.footer-top{grid-template-columns:repeat(2,1fr)}.footer-brand{grid-column:1/-1}}
@media(max-width:680px){.container{width:min(calc(100% - 30px),var(--container))}.section{padding:76px 0}.section-tight{padding:25px 0}.hero{padding-top:51px;padding-bottom:65px}.hero h1{font-size:clamp(3.5rem,15.4vw,5.2rem);line-height:.87}.intro{font-size:.91rem}.hero-actions{display:grid;grid-template-columns:1fr}.hero-actions .btn{width:100%}.hero-proof{display:grid;grid-template-columns:1fr 1fr;gap:9px}.hero-proof span{align-items:flex-start;font-size:.7rem}.hero-media{min-height:365px}.hero-logo-card{max-width:420px;border-radius:22px}.hero-logo-card::after{inset:8px;border-radius:14px}.float-card{max-width:155px;padding:8px 9px;font-size:.59rem}.float-card-one{top:3%;right:-1%}.float-card-two{bottom:2%;left:-1%}.photo-estimate-inner{grid-template-columns:1fr}.estimate-icon{width:50px;height:50px}.photo-estimate .btn{grid-column:auto;width:100%}.section-head h2,.why-intro h2,.quote-copy h2,.reviews-copy h2,.faq-copy h2,.contact-copy h2,.photo-estimate h2,.social h2{font-size:clamp(2.75rem,13.4vw,4.5rem)}.service-grid,.ba-grid,.gallery-extra,.testimonials-grid{grid-template-columns:1fr}.process-grid{grid-template-columns:1fr 1fr;gap:13px;margin-top:33px}.process-grid::before{display:none}.process-card{min-height:260px}.ba-frame{height:320px}.ba-before{width:100%}.ba-control{align-items:flex-start;flex-direction:column}.ba-range{width:100%}.detail-card,.detail-card img{min-height:270px;height:270px}.map-shell{height:420px}.social-list{grid-template-columns:1fr}.social-list>div{min-height:80px;grid-template-columns:auto 1fr auto;justify-items:start}.social-list b{grid-row:1/3}.social-list small{justify-self:end;grid-column:3;grid-row:1/3}.form-card{padding:25px 19px}.footer-top{grid-template-columns:1fr;padding-top:45px}.footer-brand{grid-column:auto}.footer-bottom{align-items:flex-start;flex-direction:column}.floating-call{right:15px;bottom:15px}.modal-dialog{padding:34px 20px 24px}.modal-number{font-size:2.62rem}}
@media(max-width:390px){.hero-proof{grid-template-columns:1fr}.process-grid{grid-template-columns:1fr}.hero-media{min-height:325px}.floating-call{width:52px;justify-content:center;padding:0}.floating-call span{display:none}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}}


/* =========================
   AKTUALIZACJA V3: MENU I KATEGORIE REALIZACJI
========================= */
/* Górne menu ma teraz bardziej „premium” wygląd: małe akcenty, zaokrąglone aktywne pole i czytelne stany. */
.site-nav{gap:7px}
.nav-link{display:inline-flex;align-items:center;gap:7px;border:1px solid transparent;padding:10px 11px;overflow:hidden}
.nav-link::before{width:5px;height:5px;border-radius:50%;background:var(--orange);content:"";opacity:0;transform:scale(0);transition:opacity .2s,transform .2s}
.nav-link::after{right:11px;left:11px;bottom:4px;height:1px;background:linear-gradient(90deg,var(--orange),var(--orange-light));}
.nav-link:hover,.nav-link.active{border-color:rgba(244,119,30,.26);background:linear-gradient(135deg,rgba(244,119,30,.16),rgba(244,119,30,.035));color:var(--white)}
.nav-link:hover::before,.nav-link.active::before{opacity:1;transform:scale(1)}

/* Sekcja realizacji różni się od pozostałych sekcji: ma własny nagłówek, panel kategorii i projekty do kliknięcia. */
.realizacje{background:radial-gradient(circle at 92% 5%,rgba(244,119,30,.16),transparent 0 23%),radial-gradient(circle at 10% 65%,rgba(244,119,30,.07),transparent 0 26%),var(--black)}
.realization-head-copy h2{max-width:820px;font-size:clamp(3.3rem,6vw,6.5rem);letter-spacing:.015em}
.realization-head-copy h2::first-letter{color:var(--orange)}
.work-categories{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:8px 0 30px}
.work-category{display:flex;min-height:112px;align-items:center;gap:11px;padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.025);color:var(--white);text-align:left;transition:transform .22s,border-color .22s,background .22s,box-shadow .22s}
.work-category:hover{border-color:rgba(244,119,30,.56);background:rgba(244,119,30,.08);transform:translateY(-3px)}
.work-category.active{border-color:rgba(244,119,30,.75);background:linear-gradient(145deg,rgba(244,119,30,.22),rgba(244,119,30,.065));box-shadow:0 16px 30px rgba(0,0,0,.2)}
.work-category:focus-visible{outline:3px solid var(--orange-light);outline-offset:3px}
.work-category-icon{display:grid;width:38px;height:38px;place-items:center;border:1px solid rgba(244,119,30,.45);border-radius:10px;background:rgba(244,119,30,.12);color:var(--orange);flex:0 0 auto}
.work-category-icon .icon{width:20px;height:20px}
.work-category>span:last-child{display:grid;gap:2px;min-width:0}
.work-category strong{font-size:.75rem;line-height:1.22}
.work-category small{color:var(--muted);font-size:.64rem;font-weight:700;line-height:1.25}
.work-panel{animation:workPanelIn .32s ease both}
.work-project-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;margin:0 0 20px;padding:24px 26px;border:1px solid rgba(244,119,30,.28);border-radius:18px;background:linear-gradient(135deg,rgba(244,119,30,.12),rgba(255,255,255,.025) 55%,rgba(255,255,255,.012))}
.project-kicker{display:inline-block;margin:0 0 7px;color:var(--orange-light);font-size:.69rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.work-project-bar h3{max-width:730px;margin:0;font-size:1.25rem;line-height:1.25}
.work-project-bar p{max-width:800px;margin:9px 0 0;color:var(--muted);font-size:.82rem}
.project-count{display:inline-flex;min-width:max-content;align-items:center;gap:8px;padding:8px 10px;border:1px solid rgba(255,255,255,.12);border-radius:9px;background:rgba(0,0,0,.14);color:#ececec;font-size:.71rem;font-weight:800}
.project-count .icon{width:16px;height:16px;color:var(--orange)}
.ba-card{background:linear-gradient(160deg,#1f1f1f,#151515)}
.ba-title{padding:3px 4px 14px}
.ba-title span{font-size:.65rem}
.ba-title strong{font-size:.82rem}
.ba-control{padding-top:15px}
.work-empty-panel{min-height:420px;display:grid;place-items:center;border:1px solid rgba(244,119,30,.22);border-radius:22px;background:linear-gradient(135deg,rgba(244,119,30,.07),transparent 46%),var(--charcoal)}
.empty-realization-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:21px;width:min(100%,930px);padding:32px}
.empty-realization-icon{display:grid;width:60px;height:60px;place-items:center;border-radius:15px;background:rgba(244,119,30,.13);color:var(--orange)}
.empty-realization-icon .icon{width:30px;height:30px}
.empty-realization-card h3{margin:0;font-size:1.2rem;line-height:1.25}
.empty-realization-card p{max-width:610px;margin:8px 0 0;color:var(--muted);font-size:.82rem}
@keyframes workPanelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

@media(max-width:1100px){
  .site-nav{gap:3px}
  .nav-link{gap:5px;padding:9px 8px}
  .work-categories{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .nav-link{display:block;border:0;padding:13px 3px}
  .nav-link::before{display:none}
  .nav-link:hover,.nav-link.active{border:0;background:transparent}
  .work-project-bar{align-items:flex-start;flex-direction:column;gap:14px}
  .empty-realization-card{grid-template-columns:auto 1fr}
  .empty-realization-card .btn{grid-column:1/-1;justify-self:start}
}
@media(max-width:680px){
  .realization-head-copy h2{font-size:clamp(3rem,14.2vw,4.7rem)}
  .work-categories{grid-template-columns:1fr 1fr;gap:9px;margin-bottom:20px}
  .work-category{min-height:92px;align-items:flex-start;gap:8px;padding:11px}
  .work-category-icon{width:32px;height:32px;border-radius:9px}
  .work-category-icon .icon{width:17px;height:17px}
  .work-category strong{font-size:.67rem}
  .work-category small{font-size:.58rem}
  .work-project-bar{padding:19px 17px}
  .work-project-bar h3{font-size:1.05rem}
  .project-count{min-width:0}
  .work-empty-panel{min-height:360px}
  .empty-realization-card{grid-template-columns:1fr;padding:25px 20px}
  .empty-realization-card .btn{width:100%;justify-self:stretch}
}
@media(max-width:390px){
  .work-categories{grid-template-columns:1fr}
}


/* =========================
   AKTUALIZACJA V4: SUWAKI, OPINIE, LOGO I MAPA
========================= */

/* Większy, czytelniejszy znak & w znaku D&O. */
.brand-amp {
  margin: 0 .05em;
  font-size: .68em;
  font-weight: 400;
  transform: translateY(-.17em) skewX(9deg);
}

/* Logo na hero ma tło dopasowane do strony, bez szarego panelu. */
.hero-logo-card {
  width: min(100%, 560px);
  border: 0;
  border-radius: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
  transform: rotate(1.6deg);
  animation: hero-logo-float 4.6s ease-in-out infinite;
}
.hero-logo-card::after {
  display: none;
}
.hero-logo-card img {
  aspect-ratio: 1;
  border-radius: 0;
  filter: drop-shadow(0 24px 34px rgba(0,0,0,.48));
  transform: scale(1.03);
}
@keyframes hero-logo-float {
  0%, 100% { transform: rotate(1.6deg) translateY(0); }
  50% { transform: rotate(1.6deg) translateY(-13px); }
}

/* Poprawiony porównywacz przed / po.
   Cała powierzchnia zdjęcia jest suwakiem, więc nie da się przypadkowo przeciągnąć lub skopiować zdjęcia. */
.ba-frame.before-after {
  position: relative;
  isolation: isolate;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
  cursor: ew-resize;
}
.ba-frame.before-after .ba-image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
  -webkit-touch-callout: none;
}
.ba-frame.before-after .ba-after {
  z-index: 1;
}
.ba-frame.before-after .ba-before {
  z-index: 2;
  width: 100%;
  height: 100%;
  clip-path: inset(0 calc(100% - var(--split)) 0 0);
  will-change: clip-path;
}
.ba-frame.before-after .ba-label {
  z-index: 4;
  pointer-events: none;
}
.ba-frame.before-after .ba-divider {
  z-index: 5;
  left: var(--split);
}
.ba-frame.before-after .ba-divider::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: rgba(255,255,255,.95);
  box-shadow: 0 0 0 1px rgba(0,0,0,.18);
  content: "";
  transform: translateX(-50%);
}
.ba-frame.before-after .ba-divider span {
  display: grid;
  place-items: center;
  border-color: rgba(255,255,255,.92);
}
.ba-frame.before-after .ba-divider span::before,
.ba-frame.before-after .ba-divider span::after {
  top: 50%;
  width: 8px;
  height: 8px;
  border-top: 2px solid #151515;
  border-right: 2px solid #151515;
  background: transparent;
}
.ba-frame.before-after .ba-divider span::before {
  left: 8px;
  transform: translateY(-50%) rotate(-135deg);
}
.ba-frame.before-after .ba-divider span::after {
  right: 8px;
  transform: translateY(-50%) rotate(45deg);
}
.ba-frame.before-after .ba-range {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  appearance: none;
  -webkit-appearance: none;
  opacity: 0;
  cursor: ew-resize;
  touch-action: pan-y;
}
.ba-frame.before-after .ba-range:focus-visible {
  opacity: .01;
  outline: 3px solid var(--orange-light);
  outline-offset: -5px;
}
.ba-control {
  justify-content: space-between;
}
.ba-control b {
  color: var(--orange-light);
  font-size: .67rem;
  letter-spacing: .08em;
  white-space: nowrap;
}

/* Minimalna, czytelna sekcja opinii: jedno prawdziwe zdjęcie bez udawanej opinii tekstowej. */
.reviews-simple {
  background:
    radial-gradient(circle at 82% 22%, rgba(244,119,30,.11), transparent 0 25%),
    var(--black-soft);
}
.reviews-simple-head {
  max-width: 640px;
  margin: 0 auto 30px;
  text-align: center;
}
.reviews-simple-head .eyebrow {
  justify-content: center;
}
.reviews-simple-head h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(3rem, 5.4vw, 5.8rem);
  line-height: .92;
  font-weight: 400;
  text-transform: uppercase;
}
.review-shot-single {
  width: min(100%, 760px);
  margin: 0 auto;
  padding: 15px;
  border: 1px solid rgba(244,119,30,.42);
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(244,119,30,.11), rgba(255,255,255,.02) 45%), var(--charcoal);
}
.review-shot-single img {
  width: 100%;
  min-height: 118px;
  border-radius: 11px;
  object-fit: contain;
  background: #252525;
}

/* Większy promień obejmuje dodatkowe miejscowości widoczne na mapie. */
.map-shell {
  background: #dce6c2;
}
@media (max-width: 1100px) {
  .site-nav { gap: 2px; }
  .nav-link { padding: 8px 7px; font-size: .68rem; }
}
@media (max-width: 680px) {
  .hero-logo-card {
    max-width: 430px;
  }
  .ba-control {
    gap: 7px;
    flex-direction: column;
    align-items: flex-start;
  }
  .reviews-simple-head h2 {
    font-size: clamp(2.78rem, 13.2vw, 4.5rem);
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero-logo-card {
    animation: none;
  }
}


/* =========================
   AKTUALIZACJA V5: odstępy, ukrywanie paneli i drugi suwak
========================= */
/* Ukryte panele muszą pozostać całkowicie niewidoczne.
   Ta reguła naprawia „Pokaż mniej” oraz kategorie ze zdjęciami do dodania później. */
[hidden],
.work-panel[hidden],
.gallery-extra[hidden] {
  display: none !important;
}

/* Więcej powietrza w sekcji realizacji – bez zlepiania kart i przycisków. */
.work-panels {
  margin-top: 8px;
}

.ba-grid {
  margin-top: 6px;
  row-gap: 24px;
}

.gallery-extra {
  margin-top: 28px;
  padding-top: 2px;
}

.gallery-action {
  margin-top: 34px;
}

/* Mały panel, który pojawia się dopiero po „Pokaż więcej”. */
.future-realizations-note {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 17px;
  padding: 24px;
  border: 1px dashed rgba(244, 119, 30, 0.48);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(244,119,30,.09), rgba(255,255,255,.02));
}

.future-realizations-icon {
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  border-radius: 12px;
  background: rgba(244,119,30,.12);
  color: var(--orange);
}

.future-realizations-icon .icon {
  width: 24px;
  height: 24px;
}

.future-realizations-note h3 {
  margin: 0;
  font-size: 1rem;
  line-height: 1.35;
}

.future-realizations-note p {
  max-width: 760px;
  margin: 7px 0 0;
  color: var(--muted);
  font-size: .81rem;
}

/* Drugi suwak – właściwe zdjęcia ceramiki i pustego miejsca po wyniesieniu. */
.ba-card-ceramika .ba-frame {
  min-height: 420px;
}

.ba-card-ceramika .ba-image {
  object-position: center center;
}

/* Suwak działa po całej powierzchni zdjęcia. Obrazków nie można zaznaczać ani przeciągać. */
.ba-frame.before-after {
  touch-action: pan-y;
  -webkit-user-select: none;
  user-select: none;
}

.ba-frame.before-after::selection,
.ba-frame.before-after *::selection {
  background: transparent;
}

.ba-frame.before-after .ba-range {
  pointer-events: none;
}

@media (max-width: 680px) {
  .ba-card-ceramika .ba-frame {
    min-height: 360px;
  }

  .future-realizations-note {
    grid-template-columns: 1fr;
    gap: 13px;
    padding: 20px;
  }
}


/* =========================
   AKTUALIZACJA V6: druga opinia klienta
========================= */
/* Dwie prawdziwe wiadomości zachowują właściwe proporcje zdjęć,
   a na telefonie układają się jedna pod drugą. */
.reviews-simple-head > p:last-child {
  margin: 14px auto 0;
  color: var(--muted);
  font-size: .88rem;
}

.review-shot-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  align-items: start;
  width: min(100%, 1120px);
  margin: 0 auto;
}

.review-shot-card {
  width: 100%;
  min-width: 0;
  margin: 0;
  padding: 13px;
  border: 1px solid rgba(244,119,30,.42);
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(244,119,30,.11), rgba(255,255,255,.02) 45%), var(--charcoal);
  box-shadow: 0 16px 36px rgba(0,0,0,.18);
}

.review-shot-card img {
  display: block;
  width: 100%;
  height: auto;
  min-height: 0;
  border-radius: 11px;
  background: #252525;
  object-fit: contain;
}

@media (max-width: 760px) {
  .review-shot-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    width: min(100%, 690px);
  }

  .review-shot-card {
    padding: 10px;
    border-radius: 16px;
  }
}


/* =========================
   AKTUALIZACJA V7: mocniejsze hover, dodatkowy suwak i ciaśniejsza mapa
========================= */
/* Karty usług dostają wyraźne podświetlenie dokładnie w miejscu najechania myszką. */
.service-card {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  will-change: transform;
}

.service-card::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(circle at 14% 12%, rgba(244,119,30,.24), transparent 42%);
  content: "";
  opacity: 0;
  transform: scale(.92);
  transition: opacity .26s ease, transform .32s ease;
}

.service-card::after {
  position: absolute;
  top: 18px;
  bottom: 18px;
  left: 0;
  width: 3px;
  border-radius: 0 6px 6px 0;
  background: var(--orange);
  box-shadow: 0 0 22px rgba(244,119,30,.82);
  content: "";
  opacity: 0;
  transform: scaleY(.35);
  transform-origin: center;
  transition: opacity .24s ease, transform .28s ease;
}

.service-card:hover,
.service-card:focus-within {
  border-color: rgba(244,119,30,.88);
  background: linear-gradient(145deg, #24201d, #161515);
  box-shadow: 0 22px 46px rgba(0,0,0,.34), 0 0 0 1px rgba(244,119,30,.1) inset;
  transform: translateY(-8px);
}

.service-card:hover::before,
.service-card:focus-within::before {
  opacity: 1;
  transform: scale(1);
}

.service-card:hover::after,
.service-card:focus-within::after {
  opacity: 1;
  transform: scaleY(1);
}

.service-card:hover .service-icon,
.service-card:focus-within .service-icon {
  border-color: var(--orange-light);
  background: rgba(244,119,30,.2);
  box-shadow: 0 8px 20px rgba(244,119,30,.18);
  transform: translateY(-2px) rotate(-4deg);
}

.service-card:hover h3,
.service-card:focus-within h3 {
  color: #fff7ef;
}

.service-icon {
  transition: transform .24s ease, background .24s ease, border-color .24s ease, box-shadow .24s ease;
}

/* Nagłówek „Usługi” i same karty wysuwają się od lewej strony. */
.services-heading .eyebrow {
  transition: opacity .55s ease, transform .65s cubic-bezier(.22,1,.36,1);
}

.services-heading.reveal:not(.is-visible) .eyebrow {
  opacity: 0;
  transform: translateX(-52px);
}

.services-heading.reveal.is-visible .eyebrow {
  opacity: 1;
  transform: translateX(0);
}

.services .service-reveal.reveal:not(.is-visible) {
  opacity: 0;
  transform: translateX(-42px);
}

.services .service-reveal.reveal.is-visible {
  opacity: 1;
  transform: translateX(0);
}

/* Dodatkowe porównanie jest niewidoczne aż do kliknięcia „Pokaż więcej”. */
.gallery-extra {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 30px;
  padding-top: 2px;
}

.gallery-extra[hidden] {
  display: none !important;
}

.extra-realization-heading {
  padding: 22px 24px;
  border: 1px solid rgba(244,119,30,.28);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(244,119,30,.1), rgba(255,255,255,.025) 58%, rgba(255,255,255,.01));
}

.extra-realization-heading h3 {
  margin: 6px 0 0;
  color: var(--white);
  font-size: 1.06rem;
  line-height: 1.35;
}

.extra-realization-heading p {
  max-width: 780px;
  margin: 8px 0 0;
  color: var(--muted);
  font-size: .82rem;
}

.ba-card-extra {
  max-width: 900px;
  margin: 0 auto;
}

.ba-card-extra .ba-frame {
  height: min(55vw, 520px);
  min-height: 380px;
}

/* Opinie też reagują na najechanie – pomarańczowa poświata, lekki ruch i lepsza ramka. */
.review-shot-card {
  position: relative;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease;
}

.review-shot-card::after {
  position: absolute;
  inset: 0;
  border: 1px solid transparent;
  border-radius: inherit;
  box-shadow: inset 0 0 42px rgba(244,119,30,0);
  content: "";
  pointer-events: none;
  transition: border-color .25s ease, box-shadow .25s ease;
}

.review-shot-card:hover,
.review-shot-card:focus-within {
  border-color: rgba(244,119,30,.88);
  background: linear-gradient(145deg, rgba(244,119,30,.18), rgba(255,255,255,.035) 46%), var(--charcoal);
  box-shadow: 0 24px 46px rgba(0,0,0,.34), 0 0 32px rgba(244,119,30,.1);
  transform: translateY(-7px);
}

.review-shot-card:hover::after,
.review-shot-card:focus-within::after {
  border-color: rgba(244,119,30,.34);
  box-shadow: inset 0 0 42px rgba(244,119,30,.09);
}

.review-shot-card:hover img {
  transform: scale(1.012);
}

.review-shot-card img {
  transition: transform .34s ease, filter .34s ease;
}

/* Kategorie realizacji dostają podobne, czytelne podświetlenie po najechaniu. */
.work-category {
  position: relative;
  overflow: hidden;
}

.work-category::after {
  position: absolute;
  right: 11px;
  bottom: 11px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 0 0 rgba(244,119,30,.28);
  content: "";
  opacity: 0;
  transition: opacity .22s ease, box-shadow .24s ease;
}

.work-category:hover::after,
.work-category.active::after {
  opacity: 1;
  box-shadow: 0 0 0 6px rgba(244,119,30,.1);
}

/* Obszar mapy kończy się bliżej skrajnych zaznaczonych miejscowości. */
.map-shell {
  height: 490px;
}

.area-tooltip {
  padding: 4px 7px;
  border: 1px solid rgba(244,119,30,.52);
  border-radius: 6px;
  background: rgba(18,18,18,.92);
  color: var(--white);
  font-family: var(--body);
  font-size: .7rem;
  font-weight: 800;
  box-shadow: 0 7px 16px rgba(0,0,0,.28);
}

.leaflet-tooltip-top:before {
  border-top-color: rgba(18,18,18,.92);
}

.map-marker {
  transition: transform .18s ease, box-shadow .18s ease;
}

.map-marker:hover {
  transform: scale(1.16);
  box-shadow: 0 8px 18px rgba(244,119,30,.44);
}

@media (max-width: 680px) {
  .extra-realization-heading {
    padding: 18px;
  }

  .ba-card-extra .ba-frame {
    height: 360px;
    min-height: 0;
  }

  .map-shell {
    height: 400px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .service-card,
  .service-card::before,
  .service-card::after,
  .service-icon,
  .review-shot-card,
  .review-shot-card::after,
  .review-shot-card img,
  .work-category,
  .work-category::after,
  .services-heading .eyebrow {
    transition: none !important;
  }
}


/* =========================
   AKTUALIZACJA V8: stabilna mapa i wyśrodkowany znak &
========================= */
/* Znak & jest mniejszy, ale siedzi dokładnie między D i O, zamiast uciekać do góry. */
.brand-code {
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.brand-amp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  margin: 0 .05em;
  color: var(--orange);
  font-size: .52em;
  line-height: 1;
  transform: translateY(-.01em) skewX(9deg);
  vertical-align: initial;
}

/* Przywrócony, czytelny rozmiar mapy — bez nadmiernego przybliżenia. */
.map-shell {
  min-height: 0;
  height: 510px;
  background: #dce6c2;
}

.map-fallback {
  display: grid;
  height: 100%;
  place-content: center;
  margin: 0;
  padding: 28px;
  color: #1b1b1b;
  font-weight: 800;
  text-align: center;
}

.map-fallback a {
  color: #9d4100;
  text-decoration: underline;
}

@media (max-width: 680px) {
  .brand-amp {
    font-size: .55em;
    margin: 0 .04em;
  }

  .map-shell {
    height: 420px;
  }
}
