:root{
  --bg:#f4f2ee;
  --beige:#ece4d8;
  --card:#ffffff;
  --line:#e5dacc;
  --text:#2d2017;
  --muted:#8a7b6c;
  --accent:#cf7726;
  --accent-dark:#b86519;
  --accent-soft:#f1dfcc;
  --footer:#452917;
  --shadow:0 16px 40px rgba(38,26,15,.08);
  --shadow-soft:0 10px 24px rgba(38,26,15,.05);
  --radius:26px;
  --wrap: 820px;
  --trans:240ms cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  text-rendering:optimizeLegibility;
}
body.has-modal{overflow:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font:inherit}
.wrap{width:min(var(--wrap),calc(100% - 32px));margin:0 auto}
h1,h2,h3,h4,.serif{font-family:Georgia,"Times New Roman",serif}
p{margin:0}
section{position:relative}

/* reveal */
.will-reveal{
  opacity:0;
  transform:translate3d(0,28px,0);
  transition:opacity 720ms ease, transform 720ms cubic-bezier(.16,1,.3,1);
}
.will-reveal.is-visible{opacity:1;transform:none}

/* header */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:#ffffff;
  border-bottom:1px solid #ece6de;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:box-shadow var(--trans), background-color var(--trans), border-color var(--trans);
}
.topbar.scrolled{
  background:#ffffff;
  box-shadow:0 8px 22px rgba(30,22,14,.05);
  border-color:rgba(228,220,209,.95);
}
.topbar-inner{
  min-height:56px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand-logo{
  width:32px;height:32px;border-radius:50%;object-fit:cover;
  box-shadow:none;
}
.brand-copy{display:flex;flex-direction:column;line-height:1;min-width:0}
.brand-copy strong{font-size:15px;font-weight:700;white-space:nowrap}
.brand-copy small{font-size:9px;letter-spacing:.12em;color:#a09284;margin-top:4px;white-space:nowrap}
.main-nav{display:flex;justify-content:center;gap:4px;flex-wrap:wrap}
.main-nav a{
  position:relative;
  font-size:12px;
  color:#6f665d;
  padding:8px 12px;
  border-radius:14px;
  font-weight:500;
  transition:color var(--trans), background-color var(--trans), transform var(--trans);
}
.main-nav a:hover{color:var(--accent);background:#f7efe4}
.main-nav a.active{background:#f1e3d3;color:var(--accent);font-weight:700}
.phone-pill{
  background:var(--accent);color:#fff;height:32px;padding:0 14px;border-radius:16px;
  display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;
  box-shadow:0 8px 18px rgba(207,119,38,.18);
  transition:transform var(--trans), box-shadow var(--trans), background-color var(--trans);
}
.phone-pill:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(207,119,38,.26);background:var(--accent-dark)}
.phone-pill span{font-size:10px;opacity:.9}

/* buttons */
.white-btn,.ghost-btn,.outline-btn,.solid-btn{
  position:relative;
  overflow:hidden;
  height:48px;
  padding:0 22px;
  border-radius:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:700;
  font-size:14px;
  transition:transform var(--trans), box-shadow var(--trans), background-color var(--trans), border-color var(--trans), color var(--trans);
}
.white-btn::after,.ghost-btn::after,.outline-btn::after,.solid-btn::after{
  content:"";
  position:absolute;
  inset:-40% auto -40% -120%;
  width:60%;
  transform:skewX(-24deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  transition:transform 650ms ease;
}
.white-btn:hover::after,.ghost-btn:hover::after,.outline-btn:hover::after,.solid-btn:hover::after{transform:translateX(250%) skewX(-24deg)}
.white-btn:hover,.ghost-btn:hover,.outline-btn:hover,.solid-btn:hover{transform:translateY(-2px)}
.white-btn{background:#fff;color:var(--text);box-shadow:0 10px 18px rgba(0,0,0,.08)}
.ghost-btn{border:1px solid rgba(255,255,255,.6);color:#fff;background:rgba(255,255,255,.08)}
.outline-btn{background:transparent;border:1px solid #e1c1a0;color:var(--accent)}
.outline-btn.small-btn{height:40px;border-radius:13px;font-size:13px;width:100%;justify-content:center}
.solid-btn{background:var(--accent);color:#fff;box-shadow:0 10px 18px rgba(207,119,38,.18)}
.outline-btn:hover{background:#fff7ef;border-color:#d89a5b}
.ghost-btn:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.85)}
.solid-btn:hover{background:var(--accent-dark);box-shadow:0 14px 28px rgba(207,119,38,.24)}

/* hero */
.hero-card{
  margin-top: 8px;
  margin:40px auto 56px;
  min-height:410px;
  border-radius:26px;
  overflow:hidden;
  position:relative;
  background-size:cover;
  background-position:center;
  box-shadow:var(--shadow);
  isolation:isolate;
}
.hero-card::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:inherit;
  background-size:inherit;
  background-position:inherit;
  transform:scale(1.035) translate3d(var(--hero-x,0),var(--hero-y,0),0);
  transition:transform 420ms cubic-bezier(.2,.8,.2,1);
  will-change:transform;
  z-index:-2;
}
.hero-card::after{
  content:"";
  position:absolute;
  inset:auto -10% -22% 20%;
  height:180px;
  background:radial-gradient(circle at center, rgba(207,119,38,.25), transparent 70%);
  filter:blur(14px);
  opacity:.8;
  pointer-events:none;
  z-index:-1;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(28,20,13,.72) 0%, rgba(28,20,13,.52) 28%, rgba(28,20,13,.14) 62%, rgba(28,20,13,.08) 100%);
  display:flex;align-items:flex-end;
}
.hero-copy{
  max-width: 440px;padding:0 36px 34px;max-width:430px;color:#fff}
.hero-copy h1{font-size:58px;line-height: 1.01;margin:0 0 18px;font-weight:700;letter-spacing:-.045em}
.hero-copy p{font-size:14px;line-height:1.6;color:rgba(255,255,255,.92);max-width:360px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}

.beige-band{background:var(--beige);padding:44px 0;margin:0 0 44px}
.center-head{text-align:center;max-width:650px;margin:0 auto}
.center-head h1{font-size:44px;margin:0 0 10px;letter-spacing:-.04em}
.center-head p{color:var(--muted);font-size:13px;line-height:1.7}
.center-head.small p{font-size:12px}

.section-title{font-size:28px;margin:0 0 10px;letter-spacing:-.03em}
.section-subtitle{font-size:14px;color:#8b7a6b;margin-bottom:26px}

/* home models */
.home-models{padding-bottom:72px}
.home-model-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.home-model-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius: 20px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.03);
  transition:transform var(--trans), box-shadow var(--trans), border-color var(--trans);
}
.home-model-card:hover{transform:translateY(-6px);box-shadow:0 20px 38px rgba(38,26,15,.09);border-color:#dfcdb8}
.home-model-image{display:block;aspect-ratio:1.22/1;overflow:hidden}
.home-model-image img{width:100%;height:100%;object-fit:cover;transition:transform 520ms cubic-bezier(.2,.8,.2,1), filter var(--trans)}
.home-model-card:hover .home-model-image img{transform:scale(1.05);filter:saturate(1.04)}
.home-model-body{padding: 14px 16px 16px}
.home-model-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}
.home-model-head h3{font-size:15px;margin:0;letter-spacing:-.03em}
.home-model-head strong{color:var(--accent);font-size:14px}
.home-model-body p{font-size:12px;color:#7b7067;line-height:1.55;min-height: 42px;margin-bottom:14px}

/* gallery */
.gallery-section{padding: 6px 0 86px}
.gallery-top{display:flex;justify-content:space-between;gap:20px;align-items:flex-end;margin-bottom:22px}
.gallery-top .left p{font-size:14px;color:#8a7b6c;margin-top:8px}
.inline-link{font-size:12px;color:var(--accent);font-weight:700;transition:transform var(--trans), color var(--trans)}
.inline-link:hover{transform:translateX(2px);color:var(--accent-dark)}
.home-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.home-gallery-grid .gallery-tile,
.masonry-item{
  border-radius:20px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(227,218,207,.6);
  transition:transform var(--trans), box-shadow var(--trans), filter var(--trans);
}
.home-gallery-grid .gallery-tile{
  aspect-ratio:1/1;border:none;padding:0;background:none;cursor:pointer;
}
.gallery-tile img,.masonry-item img{width:100%;height:100%;object-fit:cover;transition:transform 560ms cubic-bezier(.2,.8,.2,1), filter var(--trans)}
.gallery-tile:hover,.masonry-item:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(38,26,15,.1)}
.gallery-tile:hover img,.masonry-item:hover img{transform:scale(1.04);filter:saturate(1.04)}
.center-btn{display:flex;justify-content:center;margin-top:22px}
.center-btn .outline-btn{width:auto;min-width:220px;height:40px;font-size:13px;border-color:#e8c9a4}

/* models page */
.models-page .beige-band{margin-bottom:38px}
.model-nav-pills{
  position:sticky;
  top:68px;
  z-index:12;
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin:-6px auto 22px;
  padding:10px 14px;
  background:rgba(246,243,238,.88);
  border:1px solid rgba(228,221,210,.75);
  border-radius:999px;
  width:max-content;
  max-width:100%;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.model-nav-pills a{
  background:#efe8dc;border:1px solid #e1d8ca;color:#60564d;
  font-size:13px;font-weight:700;padding:10px 14px;border-radius: 20px;
  transition:transform var(--trans), box-shadow var(--trans), background-color var(--trans), color var(--trans);
}
.model-nav-pills a:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(38,26,15,.07)}
.model-nav-pills a.is-current{background:#f1e3d3;color:var(--accent);border-color:#e4c7a4}
.model-stack{display:flex;flex-direction:column;gap:54px;padding-bottom:84px}
.model-detail-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius: 28px;
  box-shadow:var(--shadow);
  padding: 26px;
  display:grid;
  grid-template-columns: 274px 1fr;
  gap:24px;
  scroll-margin-top:132px;
  transition:transform var(--trans), box-shadow var(--trans), border-color var(--trans);
}
.model-detail-card:hover{transform:translateY(-3px);box-shadow:0 24px 50px rgba(38,26,15,.1);border-color:#e1d2bf}
.model-gallery-main{
  position:relative;aspect-ratio:1.16/1;border-radius:20px;overflow:hidden;cursor:pointer;margin-bottom: 8px;
  box-shadow:0 8px 20px rgba(38,26,15,.08);
}
.model-gallery-main img{width:100%;height:100%;object-fit:cover;transition:transform 520ms ease, opacity 220ms ease}
.model-gallery-main:hover img{transform:scale(1.02)}
.model-gallery-main img.is-swapping{opacity:.45}
.gallery-count{position:absolute;right:12px;bottom:10px;color:#fff;font-size:12px;background:rgba(0,0,0,.28);padding:4px 6px;border-radius:10px}
.model-thumb-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.model-thumb{
  border:none;padding:0;background:none;border-radius:10px;overflow:hidden;aspect-ratio:1/1;cursor:pointer;
  opacity:.5;box-shadow:0 0 0 1px #ddd4c7 inset;transform:translateY(0);transition:opacity var(--trans), transform var(--trans), box-shadow var(--trans)
}
.model-thumb.active{opacity:1;box-shadow:0 0 0 2px var(--accent) inset}
.model-thumb:hover{opacity:.9;transform:translateY(-1px)}
.model-thumb img{width:100%;height:100%;object-fit:cover}
.model-copy h2{font-size:26px;margin:6px 0 0}
.model-copy .price{font-size:16px;color:var(--accent);font-weight:800;margin-left:10px}
.model-copy .topline{display:flex;align-items:baseline;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.model-copy p{font-size:14px;line-height:1.7;color:#766a60}
.model-copy h4{font-size:12px;margin:22px 0 12px;letter-spacing:.05em;text-transform:uppercase;font-family:Inter,sans-serif}
.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.spec-pill{
  background:#f4efe7;color:#5f564d;border-radius:12px;padding:11px 14px;font-size:12px;min-height:38px;display:flex;align-items:center;
  transition:transform var(--trans), background-color var(--trans), box-shadow var(--trans);
}
.spec-pill:hover{transform:translateY(-1px);background:#f7f1ea;box-shadow:0 8px 16px rgba(38,26,15,.04)}
.model-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.model-actions .solid-btn,.model-actions .outline-btn{height:44px;border-radius: 20px;padding:0 24px;font-size:14px}
.model-actions .outline-btn{background:#f4efe7;border-color:#eadfce;color:#5f564d}

/* masonry */
.real-gallery{padding:28px 0 86px}
.masonry{columns:4 220px;column-gap:14px}
.masonry-item{break-inside:avoid;margin:0 0 14px;border:none;background:none;padding:0;width:100%;cursor:pointer}
.masonry-item img{width:100%;height:auto;display:block}

/* contact */
.contact-page .contact-wrap{padding:38px 0 86px}
.contact-card-main{
  width: min(540px,100%);
  background:#cb7524;color:#fff;border-radius: 26px;padding:30px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);max-width:540px;margin:0 auto 22px;
}
.contact-card-main::after{content:"";position:absolute;right:-40px;top:-40px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.08)}
.contact-card-main small{display:block;font-size:12px;letter-spacing:.06em;opacity:.78;text-transform:uppercase;margin-bottom:8px}
.contact-card-main h2{font-size:22px;margin:0 0 18px}
.phone-row{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.phone-icon{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;font-size:18px}
.phone-copy strong{display:block;font-size:11px;opacity:.74;letter-spacing:.06em;text-transform:uppercase}
.phone-copy a{font-size:25px;font-weight:800}
.contact-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.contact-actions .white-btn,.contact-actions .ghost-light{height:46px;border-radius:16px;font-size:14px;font-weight:700}
.ghost-light{background:rgba(255,255,255,.14);color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:540px;margin:0 auto}
.info-box{
  background:#fff;border:1px solid var(--line);border-radius: 20px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.02);
  transition:transform var(--trans), box-shadow var(--trans), border-color var(--trans);
}
.info-box:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(38,26,15,.08);border-color:#e1d2bf}
.info-box h3{font-size:16px;margin:0 0 10px}
.info-box p{font-size:14px;color:#7a6f64;line-height:1.7}
.social-box{grid-column:1/-1}
.social-row{display:flex;gap:12px;margin-top:14px}
.social-chip{height:34px;padding:0 14px;border-radius:12px;border:1px solid var(--line);display:inline-flex;align-items:center;gap:10px;font-size:13px;color:#5f564d;transition:transform var(--trans), box-shadow var(--trans), background-color var(--trans)}
.social-chip:hover{transform:translateY(-2px);box-shadow:0 10px 18px rgba(38,26,15,.06);background:#fff8ef}

/* wykonanie */
.exec-section{padding:30px 0 72px}
.exec-intro{display:grid;grid-template-columns:1.08fr 1fr;gap:28px;align-items:center;margin-bottom:52px}
.exec-collage{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.exec-collage .small{aspect-ratio:1/1;border-radius: 20px;overflow:hidden;box-shadow:var(--shadow)}
.exec-collage .wide{grid-column:1/-1;aspect-ratio:1.55/1;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.exec-collage img,.exec-photo img{width:100%;height:100%;object-fit:cover;transition:transform 520ms ease}
.exec-collage .small:hover img,.exec-collage .wide:hover img,.exec-photo:hover img{transform:scale(1.035)}
.exec-copy h2{font-size:30px;margin:0 0 14px}
.exec-copy p{font-size:14px;color:#72675d;line-height:1.8}
.exec-copy ul{margin:18px 0 0;padding-left:0;list-style:none}
.exec-copy li{font-size:13px;color:#6a6057;margin:0 0 10px;position:relative;padding-left:16px}
.exec-copy li::before{content:"•";position:absolute;left:0;color:var(--accent)}
.exec-band{background:var(--beige);padding:42px 0}
.exec-band-grid{display:grid;grid-template-columns:1fr 1.08fr;gap:30px;align-items:center}
.exec-band-grid.reverse{grid-template-columns:1.08fr 1fr}
.exec-photo{aspect-ratio:1.33/1;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.spec-section{padding:48px 0 88px}
.spec-head{text-align:center;margin-bottom:18px}
.spec-head h2{font-size:24px;margin:0 0 10px}
.spec-table{width:min(460px,100%);margin:0 auto;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius: 20px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.02)}
.spec-table td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--line)}
.spec-table tr:last-child td{border-bottom:none}
.spec-table td:first-child{font-weight:700;width:46%}
.spec-note{text-align:center;color:#84786d;font-size:13px;margin-top:22px}

/* footer */
.site-footer{background:var(--footer);color:#fff;margin-top:0;padding-top:26px}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:24px;padding-bottom:22px}
.footer-col h4{font-size:13px;letter-spacing:.08em;margin:0 0 14px;opacity:.85}
.footer-col p,.footer-col a{font-size:14px;color:rgba(255,255,255,.86);line-height:1.7}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.footer-brand img{width:28px;height:28px;border-radius:50%}
.footer-brand strong{font-family:Georgia,"Times New Roman",serif;font-size:24px}
.footer-phone{display:block;font-size:30px!important;font-weight:800;line-height:1.2!important;margin-top:8px}
.footer-socials{display:flex;gap:10px}
.footer-socials a{width:36px;height:36px;border-radius:12px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-weight:800;transition:transform var(--trans), background-color var(--trans)}
.footer-socials a:hover{transform:translateY(-2px);background:rgba(255,255,255,.14)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0 24px;text-align:center;color:rgba(255,255,255,.55);font-size:12px}

/* lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(13,9,6,.88);display:none;align-items:center;justify-content:center;z-index:100;
  opacity:0;transition:opacity 220ms ease;
}
.lightbox.open{display:flex;opacity:1}
.lightbox-figure{width:min(1080px,calc(100% - 120px));max-height:calc(100vh - 80px);transform:translateY(16px) scale(.98);transition:transform 300ms cubic-bezier(.16,1,.3,1)}
.lightbox.open .lightbox-figure{transform:translateY(0) scale(1)}
.lightbox-image{max-width:100%;max-height:calc(100vh - 80px);margin:auto;border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.lightbox-close,.lightbox-nav{position:absolute;border:none;background:rgba(255,255,255,.12);color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:28px;transition:transform var(--trans), background-color var(--trans)}
.lightbox-close:hover,.lightbox-nav:hover{transform:scale(1.05);background:rgba(255,255,255,.18)}
.lightbox-close{top:20px;right:20px}
.lightbox-nav.prev{left:24px}
.lightbox-nav.next{right:24px}

@media (max-width: 940px){
  :root{ --wrap: 92vw; }
  .topbar-inner{grid-template-columns:1fr auto;padding:10px 0}
  .main-nav{grid-column:1/-1;justify-content:flex-start;overflow:auto;white-space:nowrap;padding-bottom:8px}
  .hero-copy h1{font-size:44px}
  .home-model-grid,.exec-intro,.exec-band-grid,.exec-band-grid.reverse{grid-template-columns:1fr}
  .gallery-top{flex-direction:column;align-items:flex-start}
  .home-gallery-grid{grid-template-columns:1fr 1fr}
  .model-detail-card{grid-template-columns:1fr}
  .spec-grid{grid-template-columns:1fr}
  .footer-grid,.contact-grid{grid-template-columns:1fr}
  .social-box{grid-column:auto}
  .masonry{columns:2 180px}
}

@media (max-width: 640px){
  .hero-card{
  margin-top: 8px;min-height:360px;margin-top:24px}
  .hero-copy{
  max-width: 440px;padding:0 22px 24px}
  .hero-copy h1{font-size:38px}
  .white-btn,.ghost-btn,.solid-btn,.outline-btn{width:100%}
  .hero-actions,.contact-actions{display:grid;grid-template-columns:1fr}
  .home-model-grid,.home-gallery-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .model-thumb-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{padding-bottom:12px}
  .model-nav-pills{border-radius: 20px;justify-content:flex-start;overflow:auto;white-space:nowrap;padding:10px;top:60px}
  .lightbox-figure{width:min(100%,calc(100% - 34px))}
  .lightbox-close{top:14px;right:14px}
  .lightbox-nav.prev{left:8px}
  .lightbox-nav.next{right:8px}
}


/* v20 exact match refinements */

body{font-size:16px}
.topbar-inner{padding:0}
.brand-copy strong{font-size:15px}
.brand-copy small{font-size:9px;letter-spacing:.14em}
.main-nav a{font-size:12px;padding:8px 12px;border-radius:14px}
.main-nav a.active{background:#f1e2d1;color:var(--accent)}
.phone-pill{height:34px;padding:0 14px;border-radius:14px;font-size:12px}
.beige-band{background:var(--beige);padding:50px 0 54px;margin-bottom:34px}
.center-head{max-width:720px;text-align:center}
.center-head h1{font-size:54px;line-height:1.02;margin:0 0 12px;letter-spacing:-.04em}
.center-head p{font-size:16px;color:#8d7e70;line-height:1.6}
.hero-card{box-shadow:none;border:1px solid rgba(226,215,203,.7)}
.hero-overlay{background:linear-gradient(90deg, rgba(20,15,11,.60) 0%, rgba(20,15,11,.20) 44%, rgba(20,15,11,.08) 100%)}
.hero-copy h1{font-size:66px;line-height:1.02;letter-spacing:-.05em;text-shadow:0 1px 2px rgba(0,0,0,.22)}
.hero-copy p{font-size:16px;line-height:1.55;max-width:430px}
.home-models{padding:58px 0 72px}
.section-title{font-size:34px;line-height:1.08;letter-spacing:-.03em}
.section-subtitle{font-size:16px;color:#8a7b6c;margin-top:6px;margin-bottom:22px}
.home-model-card{border-radius:22px;box-shadow:0 8px 22px rgba(38,26,15,.045);border:1px solid rgba(227,218,207,.82)}
.home-model-image{aspect-ratio:1.18/1}
.home-model-body{padding:14px 16px 16px}
.home-model-head h3{font-size:15px;font-weight:700}
.home-model-head strong{font-size:14px;color:var(--accent)}
.home-model-body p{font-size:12px;line-height:1.55;color:#7b7067}
.small-btn{width:100%;height:38px;border-radius:14px;font-size:12px}
.outline-btn.small-btn{background:#fff;border:1px solid #e4c7a5;color:var(--accent)}
.gallery-top{margin-bottom:18px}
.inline-link{font-size:12px}
.home-gallery-grid{gap:14px}
.home-gallery-grid .gallery-tile{border-radius:20px}
.center-btn .outline-btn{height:40px;border-radius:999px}
.model-nav-pills{top:66px;gap:8px;padding:8px 10px;background:rgba(244,242,238,.92)}
.model-nav-pills a{font-size:13px;border-radius:16px;padding:10px 14px;background:#efe8dc}
.model-detail-card{border-radius:28px;box-shadow:0 10px 30px rgba(38,26,15,.05);padding:26px}
.model-copy h2{font-size:24px}
.model-copy p{font-size:14px;line-height:1.65}
.spec-pill{font-size:12px;border-radius:12px;background:#f2ece4}
.model-actions .solid-btn,.model-actions .outline-btn{height:44px;border-radius:18px}
.real-gallery .beige-band,.contact-page .beige-band,.wykonanie-page .beige-band{margin-bottom:32px}
.masonry{columns:4 180px;column-gap:14px}
.contact-card-main{padding:30px 30px 30px;border-radius:28px;box-shadow:none}
.contact-card-main h2{font-size:22px}
.contact-grid{gap:14px;max-width:540px}
.info-box{box-shadow:none}
.social-chip{height:34px;border-radius:12px}
.exec-section{padding:30px 0 60px}
.exec-copy h2{font-size:26px;line-height:1.1}
.exec-copy p{font-size:14px;line-height:1.75}
.exec-band{padding:48px 0}
.spec-head h2{font-size:26px}
.spec-table{width:min(460px,100%);box-shadow:none}
.site-footer{padding-top:28px}
.footer-grid{padding-bottom:22px}
.footer-brand strong{font-size:22px}
.footer-phone{font-size:26px!important}
@media (max-width: 940px){
  .center-head h1{font-size:42px}
  .hero-copy h1{font-size:52px}
}
@media (max-width: 640px){
  .wrap{width:min(100% - 24px, var(--wrap))}
  .hero-card{min-height:350px}
  .hero-copy h1{font-size:42px}
  .center-head h1{font-size:34px}
  .section-title{font-size:30px}
  .model-detail-card{padding:18px}
}


/* visual refresh + gallery fixes */
body{
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.8), transparent 28%),
    linear-gradient(180deg,#f7f4ef 0%, #f3efe9 100%);
  color:#2f241a;
}
img{height:auto}
.brand-copy strong{font-size:16px}
.brand-copy small{font-size:10px}
.main-nav a{font-size:13px;padding:9px 13px}
.phone-pill{height:36px;font-size:13px}
.hero-copy h1{font-size:clamp(2.8rem, 6vw, 4.5rem)}
.center-head h1{font-size:clamp(2.2rem, 5vw, 3.4rem)}
.section-title{font-size:clamp(1.95rem, 3.8vw, 2.4rem)}
.section-subtitle,
.center-head p,
.hero-copy p,
.model-copy p,
.exec-copy p,
.info-box p{font-size:clamp(.98rem, 1.8vw, 1.05rem)}
.hero-card,
.home-model-card,
.model-detail-card,
.contact-card-main,
.info-box{backface-visibility:hidden}
.gallery-tile,
.masonry-item,
.model-thumb,
.model-gallery-main,
.home-model-image{
  position:relative;
  background:linear-gradient(135deg, rgba(255,255,255,.8), rgba(237,229,218,.85));
}
.gallery-tile::before,
.masonry-item::before,
.model-thumb::before,
.model-gallery-main::before,
.home-model-image::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(110deg, transparent 20%, rgba(255,255,255,.38) 40%, transparent 60%);
  transform:translateX(-120%);
  transition:transform .9s ease;
  z-index:1;
  pointer-events:none;
}
.gallery-tile.is-loaded::before,
.masonry-item.is-loaded::before,
.model-thumb.is-loaded::before,
.model-gallery-main.is-loaded::before,
.home-model-image.is-loaded::before{
  transform:translateX(120%);
}
.gallery-tile img,
.masonry-item img,
.model-thumb img,
.model-gallery-main img,
.home-model-image img{
  position:relative;
  z-index:0;
}
.gallery-section{padding-bottom:96px}
.real-gallery{padding-top:8px}
.masonry{
  columns:4 250px;
  column-gap:18px;
}
.masonry-item{
  margin:0 0 18px;
  border-radius:24px;
  box-shadow:0 14px 28px rgba(33,23,15,.06);
}
.masonry-item img{
  border-radius:24px;
}
.masonry-item:hover{transform:translateY(-6px)}
.masonry-item:hover img{transform:scale(1.03)}
/* lightbox */
.lightbox{
  background:rgba(12,8,5,.94);
  padding:24px;
}
.lightbox-figure{
  width:min(1180px, calc(100% - 112px));
  max-height:calc(100vh - 48px);
  margin:0;
}
.lightbox-media-shell{
  border-radius:24px;
  overflow:hidden;
  background:rgba(255,255,255,.05);
  box-shadow:0 28px 80px rgba(0,0,0,.42);
}
.lightbox-image{
  display:block;
  width:auto;
  max-width:100%;
  max-height:calc(100vh - 190px);
  margin:auto;
  border-radius:0;
  transition:opacity .2s ease, transform .24s ease;
}
.lightbox-image.is-changing{
  opacity:.25;
  transform:scale(.985);
}
.lightbox-meta{
  margin-top:14px;
  color:#fff;
}
.lightbox-meta-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:12px;
}
.lightbox-counter{
  font-size:13px;
  font-weight:700;
  color:rgba(255,255,255,.78);
  background:rgba(255,255,255,.08);
  padding:8px 12px;
  border-radius:999px;
}
.lightbox-caption{
  font-size:14px;
  color:rgba(255,255,255,.78);
  min-height:1em;
}
.lightbox-thumbs{
  display:flex;
  gap:10px;
  overflow:auto;
  padding-bottom:6px;
  scrollbar-width:thin;
}
.lightbox-thumb{
  flex:0 0 62px;
  width:62px;
  height:62px;
  border:none;
  padding:0;
  border-radius:14px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  box-shadow:0 0 0 1px rgba(255,255,255,.08) inset;
  cursor:pointer;
  opacity:.6;
  transition:opacity var(--trans), transform var(--trans), box-shadow var(--trans);
}
.lightbox-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.lightbox-thumb:hover{
  opacity:.9;
  transform:translateY(-1px);
}
.lightbox-thumb.is-active{
  opacity:1;
  box-shadow:0 0 0 2px rgba(255,255,255,.88) inset;
}
.lightbox-close,
.lightbox-nav{
  width:54px;
  height:54px;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.lightbox-nav.prev{left:28px}
.lightbox-nav.next{right:28px}
.lightbox-close{top:24px;right:24px}
.footer-col p,.footer-col a{font-size:15px}
.footer-phone{font-size:28px!important}
@media (max-width: 940px){
  .masonry{columns:2 220px}
  .lightbox-figure{width:min(100%, calc(100% - 48px))}
  .lightbox-image{max-height:calc(100vh - 220px)}
}
@media (max-width: 640px){
  .main-nav a{font-size:12px}
  .phone-pill{font-size:12px}
  .hero-copy p,
  .center-head p,
  .model-copy p,
  .info-box p{font-size:15px}
  .masonry{columns:1}
  .masonry-item{margin-bottom:14px;border-radius:20px}
  .masonry-item img{border-radius:20px}
  .lightbox{
    padding:14px;
  }
  .lightbox-figure{
    width:100%;
    max-height:calc(100vh - 28px);
  }
  .lightbox-media-shell{
    border-radius:18px;
  }
  .lightbox-image{
    max-height:calc(100vh - 260px);
  }
  .lightbox-meta-top{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
  .lightbox-thumb{
    flex-basis:54px;
    width:54px;
    height:54px;
  }
  .lightbox-close,
  .lightbox-nav{
    width:46px;
    height:46px;
    font-size:24px;
  }
  .lightbox-nav.prev{left:10px}
  .lightbox-nav.next{right:10px}
  .lightbox-close{top:10px;right:10px}
}


/* top menu fix */
.topbar{
  overflow:visible;
}
.topbar-inner{
  position:relative;
  min-height:72px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px;
  padding:12px 0;
}
.brand{
  position:relative;
  z-index:3;
}
.brand-logo{
  width:42px;
  height:42px;
  border-radius:14px;
}
.brand-copy strong{
  font-size:17px;
}
.brand-copy small{
  font-size:10px;
  letter-spacing:.16em;
}
.menu-toggle{
  display:none;
  position:relative;
  z-index:3;
  width:48px;
  height:48px;
  border:1px solid rgba(210,193,173,.9);
  background:#fff;
  border-radius:16px;
  align-items:center;
  justify-content:center;
  padding:0;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(38,26,15,.08);
  transition:transform var(--trans), box-shadow var(--trans), border-color var(--trans);
}
.menu-toggle:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 28px rgba(38,26,15,.11);
  border-color:#d79b60;
}
.menu-toggle span{
  position:absolute;
  width:20px;
  height:2px;
  border-radius:999px;
  background:#4e3a27;
  transition:transform var(--trans), opacity var(--trans), top var(--trans);
}
.menu-toggle span:nth-child(1){top:16px;}
.menu-toggle span:nth-child(2){top:23px;}
.menu-toggle span:nth-child(3){top:30px;}
.menu-toggle[aria-expanded="true"] span:nth-child(1){top:23px;transform:rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){top:23px;transform:rotate(-45deg);}
.nav-shell{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  min-width:0;
}
.main-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  flex-wrap:wrap;
}
.main-nav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 15px;
  border-radius:16px;
  font-size:13px;
  font-weight:600;
}
.main-nav a.active{
  box-shadow:inset 0 0 0 1px rgba(214,161,108,.36);
}
.phone-pill-desktop{
  position:relative;
  z-index:2;
}
.nav-phone{
  display:none;
}
@media (max-width: 900px){
  .topbar-inner{
    grid-template-columns:1fr auto;
    gap:12px;
    min-height:68px;
    padding:10px 0;
  }
  .menu-toggle{
    display:inline-flex;
  }
  .phone-pill-desktop{
    display:none;
  }
  .nav-shell{
    position:absolute;
    left:0;
    right:0;
    top:calc(100% + 8px);
    display:grid;
    gap:10px;
    padding:14px;
    background:rgba(255,255,255,.97);
    border:1px solid rgba(224,211,196,.92);
    border-radius:24px;
    box-shadow:0 24px 50px rgba(26,18,11,.12);
    opacity:0;
    visibility:hidden;
    transform:translateY(-10px);
    pointer-events:none;
    transition:opacity var(--trans), transform var(--trans), visibility var(--trans);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
  }
  .topbar.menu-open .nav-shell{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
    pointer-events:auto;
  }
  .main-nav{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }
  .main-nav a{
    justify-content:flex-start;
    width:100%;
    min-height:48px;
    padding:12px 14px;
    border-radius:16px;
    background:#f8f4ef;
    border:1px solid rgba(228,216,201,.85);
  }
  .main-nav a.active{
    background:#f3e2cf;
  }
  .nav-phone{
    display:inline-flex;
    width:100%;
    justify-content:center;
    min-height:46px;
    border-radius:16px;
  }
}
@media (max-width: 640px){
  .topbar-inner{
    min-height:64px;
  }
  .brand-logo{
    width:40px;
    height:40px;
  }
  .brand-copy strong{
    font-size:15px;
  }
  .brand-copy small{
    font-size:9px;
  }
  .menu-toggle{
    width:46px;
    height:46px;
    border-radius:15px;
  }
}

/* final header + hero sizing adjustments */
.topbar .wrap{
  width:min(1180px, calc(100% - 32px));
}
.topbar-inner{
  grid-template-columns:auto minmax(0,1fr) auto;
}
.nav-shell{
  width:100%;
  justify-content:center;
}
.main-nav{
  flex-wrap:nowrap;
}
.main-nav a{
  white-space:nowrap;
  font-size:12px;
  padding:9px 11px;
}
.phone-pill-desktop{
  white-space:nowrap;
  font-size:12px;
  padding:0 12px;
}
.home-page .hero-copy h1{
  font-size:clamp(1.95rem, 4.1vw, 3.15rem);
  line-height:1.06;
}

@media (max-width: 1100px){
  .topbar .wrap{
    width:min(1040px, calc(100% - 28px));
  }
  .main-nav a{
    font-size:11px;
    padding:8px 9px;
  }
  .phone-pill-desktop{
    font-size:11px;
    padding:0 10px;
  }
}

@media (max-width: 900px){
  .topbar .wrap{
    width:min(100%, calc(100% - 24px));
  }
  .main-nav{
    flex-wrap:wrap;
  }
}


/* subtle premium animations */
@keyframes hero-breathe {
  0%,100% {
    transform: scale(1.035) translate3d(var(--hero-x,0px), var(--hero-y,0px), 0);
  }
  50% {
    transform: scale(1.055) translate3d(calc(var(--hero-x,0px) * .65), calc(var(--hero-y,0px) * .65 - 4px), 0);
  }
}
@keyframes hero-glow-drift {
  0%,100% {
    transform: translate3d(0,0,0) scale(1);
    opacity: .72;
  }
  50% {
    transform: translate3d(-18px,-8px,0) scale(1.08);
    opacity: .92;
  }
}
@keyframes soft-float {
  0%,100% { transform: translate3d(0,0,0); }
  50% { transform: translate3d(0,-4px,0); }
}
@keyframes premium-sheen {
  0% { transform: translateX(-160%) skewX(-24deg); }
  100% { transform: translateX(280%) skewX(-24deg); }
}

.topbar{
  box-shadow: 0 8px 24px rgba(34,24,14,.04);
}
.topbar::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, rgba(207,119,38,0), rgba(207,119,38,.24), rgba(207,119,38,0));
  opacity: 0;
  transform: scaleX(.6);
  transition: opacity var(--trans), transform var(--trans);
}
.topbar.scrolled::after{
  opacity: 1;
  transform: scaleX(1);
}

.main-nav a{
  overflow: hidden;
}
.main-nav a::after{
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 7px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(207,119,38,0), rgba(207,119,38,.92), rgba(207,119,38,0));
  transform: scaleX(0);
  transform-origin: center;
  opacity: 0;
  transition: transform 260ms ease, opacity 260ms ease;
}
.main-nav a:hover::after,
.main-nav a.active::after{
  transform: scaleX(1);
  opacity: 1;
}

.hero-card{
  transform: translate3d(0,0,0);
}
.hero-card::before{
  animation: hero-breathe 11s ease-in-out infinite;
}
.hero-card::after{
  animation: hero-glow-drift 10s ease-in-out infinite;
}
.hero-copy{
  animation: soft-float 8s ease-in-out infinite;
}
.hero-actions a{
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.white-btn,
.ghost-btn,
.outline-btn,
.solid-btn,
.phone-pill,
.social-chip,
.footer-socials a{
  will-change: transform;
}

.white-btn::before,
.ghost-btn::before,
.outline-btn::before,
.solid-btn::before,
.phone-pill::before{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
  opacity: .9;
}

.phone-pill,
.footer-socials a,
.social-chip,
.white-btn,
.ghost-btn,
.outline-btn,
.solid-btn,
.home-model-card,
.model-detail-card,
.info-box,
.contact-card-main,
.gallery-tile,
.masonry-item,
.exec-photo,
.exec-collage .small,
.exec-collage .wide{
  transform:
    translate3d(0, var(--hover-lift, 0px), 0)
    perspective(1200px)
    rotateX(var(--tilt-x, 0deg))
    rotateY(var(--tilt-y, 0deg));
  transform-style: preserve-3d;
  will-change: transform;
}

.phone-pill:hover,
.footer-socials a:hover,
.social-chip:hover,
.white-btn:hover,
.ghost-btn:hover,
.outline-btn:hover,
.solid-btn:hover,
.home-model-card:hover,
.model-detail-card:hover,
.info-box:hover,
.contact-card-main:hover,
.gallery-tile:hover,
.masonry-item:hover,
.exec-photo:hover,
.exec-collage .small:hover,
.exec-collage .wide:hover{
  --hover-lift: -4px;
}

.home-model-card,
.model-detail-card,
.info-box,
.contact-card-main,
.gallery-tile,
.masonry-item,
.exec-photo,
.exec-collage .small,
.exec-collage .wide{
  position: relative;
  transition: transform 420ms cubic-bezier(.16,1,.3,1), box-shadow var(--trans), border-color var(--trans), filter var(--trans), background-color var(--trans);
}

.home-model-card::before,
.model-detail-card::before,
.info-box::before,
.gallery-tile::after,
.masonry-item::after,
.exec-photo::after,
.exec-collage .small::after,
.exec-collage .wide::after{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: radial-gradient(circle at var(--glow-x, 50%) var(--glow-y, 50%), rgba(255,255,255,.22), transparent 34%);
  opacity: 0;
  transition: opacity 340ms ease;
  z-index: 2;
}
.home-model-card:hover::before,
.model-detail-card:hover::before,
.info-box:hover::before,
.gallery-tile:hover::after,
.masonry-item:hover::after,
.exec-photo:hover::after,
.exec-collage .small:hover::after,
.exec-collage .wide:hover::after{
  opacity: 1;
}

.gallery-tile,
.masonry-item,
.exec-photo,
.exec-collage .small,
.exec-collage .wide{
  overflow: hidden;
}

.footer-socials a{
  transition: transform var(--trans), background-color var(--trans), box-shadow var(--trans), color var(--trans);
}
.footer-socials a:hover{
  box-shadow: 0 14px 28px rgba(0,0,0,.18);
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .will-reveal{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .hero-card::before,
  .hero-card::after,
  .hero-copy,
  .white-btn::after,
  .ghost-btn::after,
  .outline-btn::after,
  .solid-btn::after{
    animation: none !important;
    transition: none !important;
  }
  .phone-pill,
  .footer-socials a,
  .social-chip,
  .white-btn,
  .ghost-btn,
  .outline-btn,
  .solid-btn,
  .home-model-card,
  .model-detail-card,
  .info-box,
  .contact-card-main,
  .gallery-tile,
  .masonry-item,
  .exec-photo,
  .exec-collage .small,
  .exec-collage .wide{
    transform: none !important;
    transition: none !important;
  }
}
