/* ===============================
   Duo Lens – White/Gold/Black
   =============================== */
:root{
  --white:#FFFFFF;
  --paper:#F8F8F6;
  --paper-2:#F2F1EE;
  --black:#0A0A0A;
  --graphite:#1C1C1C;
  --muted:#6F6F6F;

  --gold:#D4B483;         /* szampańskie złoto */
  --gold-light:#cbb27c;   /* jaśniejsze złoto do hoverów */

  --line:#E8E5DE;
  --radius:16px;
  --radius-lg:22px;
  --radius-pill:50px;
  --shadow:0 8px 24px rgba(0,0,0,.08);
  --shadow-soft:0 4px 14px rgba(0,0,0,.06);
  --maxw:1200px;
  --gap:clamp(16px,2vw,24px);

  --nav-h: 72px;                 /* bazowa wysokość paska */
  --safe-top: env(safe-area-inset-top);
  --safe-bottom: env(safe-area-inset-bottom);
}

/* ===== Reset/przygotowanie ===== */
html{ scroll-behavior:smooth }
html, body { overflow-x: clip; }  /* brak poziomego scrolla */
*{ box-sizing:border-box }
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--graphite);
  background:var(--white);
}

/* Kontener – stabilny, bez ułamków szerokości */
.container{
  width:100%;
  max-width: var(--maxw);
  margin-inline:auto;
  padding-inline:16px;
}

section{ 
  padding: clamp(48px, 8vh, 96px) 0; 
  scroll-margin-top: calc(var(--nav-h) + var(--safe-top) + 12px);
}

h1,h2,h3{ font-family:Poppins, Inter, sans-serif; line-height:1.2; margin:0 0 12px; color:var(--black) }
h2{ font-size:clamp(24px, 3.2vw, 36px) }
h3{ font-size:clamp(18px, 2.2vw, 22px) }
p{ margin:0 0 12px }
a{ color:inherit; text-decoration:none }
.muted{ color: var(--muted) }
.accent{ color: var(--gold) }

.section-light{ background: var(--white) }
.section-neutral{ background: var(--paper) }
.section-paper{ background: var(--paper-2) }

/* ===== NAVBAR ===== */
.navbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  height: calc(var(--nav-h) + var(--safe-top));
  padding-top: var(--safe-top);
  transform: translateY(-100%); opacity:0;
  transition: transform .25s ease, opacity .25s ease, box-shadow .25s ease;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(140%) blur(6px);
  border-bottom: 1px solid var(--line);
}
.navbar.visible{ transform: translateY(0); opacity:1; box-shadow: var(--shadow-soft) }

.nav-inner{ display:flex; align-items:center; justify-content:space-between; padding:10px 0 }
.nav-inner > .brand,
.nav-inner > .nav-links { min-width: 0; }  /* klucz: pozwól flexowi się ścisnąć */

.brand{ display:flex; align-items:center; gap:12px; min-width:170px; color:var(--black); font-weight:700; letter-spacing:.2px }
.brand .logo{ height: clamp(44px, 5vw, 56px); width:auto; display:block }

.nav-links{
  display:flex; align-items:center; gap: clamp(12px, 2vw, 22px);
  flex-wrap: nowrap;
  flex: 1 1 auto;
  justify-content:flex-end;
}
.nav-links a{ color: var(--black); opacity:.9; font-weight:500; font-size:15px }

/* ===== Zakładka „Więcej” ===== */
.nav-more{ position:relative; flex:0 0 auto; }
.more-btn{
  background:none; border:0; font:inherit; font-weight:500; cursor:pointer;
  color:var(--black); padding:8px 12px; white-space:nowrap;
}
.more-menu{
  display:none;
  position:absolute; top:100%; right:0; /* kotwiczymy do prawej */
  background: var(--white);
  border:1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  min-width: 180px;
  z-index: 999;
}
.nav-more.open .more-menu{ display:block; }
.more-menu a{
  display:block; padding:10px 14px; color:var(--black); text-decoration:none;
}
.more-menu a:hover{ background: var(--paper-2); }

/* CTA w pasku – responsywne dopasowanie */
.nav-links .nav-cta{
  display:inline-flex; align-items:center; justify-content:center;
  white-space:nowrap;
  font-size: clamp(13px, 2.5vw, 15px);
  padding: 0.6em 1.4em;            /* padding w em = skaluje się z fontem */
  line-height:1.2;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--gold-light), var(--gold));
  color:#111; box-shadow: var(--shadow-soft); border:1px solid rgba(0,0,0,.06);
  flex:0 0 auto; max-width:50vw; overflow:hidden; text-overflow:ellipsis;
}
.nav-links .nav-cta:hover{ background: linear-gradient(180deg, #EFD49B, var(--gold-light)); transform: translateY(1px); }

/* ===== HERO ===== */
.hero{
  position:relative;
  display:grid; place-items:center; text-align:center;
  padding: clamp(72px, 10vh, 120px) 0;
  min-height: 100vh;                 /* fallback */
  min-height: 100svh;
}
@supports (min-height: 100lvh){ .hero{ min-height: 100lvh; } }
@supports (min-height: 100dvh){ .hero{ min-height: 100dvh; } }

.hero-inner{ max-width: 980px; margin-inline:auto }
.hero-eyebrow{
  font-family: "Cormorant Garamond", serif; font-style: italic; color: #C9BAA6;
  margin-bottom: 8px;
}
.title{ font-size: clamp(36px, 6vw, 64px) }
.lead{ max-width:70ch; margin:8px auto 24px; letter-spacing:.02em }
.actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap }

/* ===== Karty / siatki ===== */
.card{
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: clamp(16px, 2.5vw, 24px);
  border: 1px solid var(--line);
}
.grid{ display:grid; gap: var(--gap) }
.grid.cols-2{ grid-template-columns: repeat(2, minmax(0,1fr)) }
.grid.cols-3{ grid-template-columns: repeat(3, minmax(0,1fr)) }

/* Oferta */
#oferta .item{
  display:flex; align-items:flex-start; gap:12px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow-soft);
}
#oferta .dot{ width:10px; height:10px; border-radius:50%; background: var(--gold); margin-top:8px; flex: 0 0 auto }

/* Dlaczego my */
#dlaczego-my .value{
  background: var(--white);
  border-left: 4px solid var(--gold);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow-soft);
}

/* ===== Portfolio ===== */
#portfolio .grid{ gap: var(--gap); }

#portfolio figure{
  margin:0;
  position:relative;
  cursor:zoom-in;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#f1f1f1;
  box-shadow: var(--shadow-soft);
  aspect-ratio: 4 / 3;
  width:100%; max-width:100%; box-sizing:border-box;
}
#portfolio figure > img,
#portfolio figure > video{
  width:100%; height:100%;
  object-fit: cover;
  display:block;
  border:0; border-radius:0;
}

.lightbox img, 
.lightbox video {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #f1f1f1;
  box-shadow: var(--shadow-soft);
}

/* (opcjonalnie) wyrównanie EXIF */
img{ image-orientation: from-image; }

/* ===== Cennik/FAQ/Form ===== */
.price{ font-size: 28px; font-weight: 700; color: var(--black) }
.note{ color: var(--muted); font-size: 14px }

.faq-item{
  background: var(--white);
  border-radius: var(--radius);
  padding: 14px 16px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}
.faq-item + .faq-item{ margin-top:10px }
.faq-item summary{ cursor: pointer; font-weight: 600; }

.form{ display:grid; gap:12px }
.form label{ font-size:14px; color:var(--black) }
.form input, .form select, .form textarea{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid #DDD7CF; background:#fff; color:var(--graphite);
}
.form input::placeholder, .form textarea::placeholder{ color:#9a9aaa }
.consent{ display:flex; gap:10px; align-items:center }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 12px 20px; border-radius: var(--radius-pill);
  border: 1px solid transparent; font-weight:700;
  transition: transform .06s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-gold{
  background: linear-gradient(180deg, var(--gold-light), var(--gold));
  color:#111; box-shadow: var(--shadow-soft); border-color: rgba(0,0,0,.06);
}
.btn-gold:hover{ background: linear-gradient(180deg, #EFD49B, var(--gold-light)); transform: translateY(1px); }
.btn-ghost-gold{ background:transparent; color:var(--gold); border:1.5px solid var(--gold) }
.btn-ghost-gold:hover{ background: linear-gradient(180deg, var(--gold-light), var(--gold)); color:#111; transform: translateY(1px); }

/* ===== Lightbox (dialog) – bez przycinania i z równym odstępem ===== */
.lightbox{ display:none; } /* default (dla innych wariantów) */

.lightbox[role="dialog"]{
  --lb-pad: clamp(12px, 3vw, 24px);
  display:none;
  position:fixed; inset:0;
  background: rgba(0,0,0,.92);
  z-index:100;
  padding: var(--lb-pad);
  align-items:center; justify-content:center; /* centrum + symetria */
}
.lightbox[role="dialog"].open{ display:flex; }

.lightbox[role="dialog"] img,
.lightbox[role="dialog"] video{
  box-sizing:border-box;
  max-width: calc(100dvw - (var(--lb-pad) * 2));
  max-height: calc(100dvh - (var(--lb-pad) * 2));
  width:auto !important; height:auto !important;
  object-fit: contain;
  border-radius:12px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  background:#000;
}
@supports not (width: 1dvw){
  .lightbox[role="dialog"] img,
  .lightbox[role="dialog"] video{
    max-width: calc(100vw - (var(--lb-pad) * 2));
    max-height: calc(100vh - (var(--lb-pad) * 2));
  }
}
.lightbox[role="dialog"] .close{
  position:absolute; top:16px; right:16px;
  font-size:28px; color:#fff; cursor:pointer;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 9999px; padding: 8px 14px;
}

/* Toast (status) – osobno, by nie łapał styli dialogu */
.lightbox.toast{
  position: fixed;
  inset: 0;
  display: none;
  background: rgba(0,0,0,.92);
  z-index: 90;
  padding: 24px;
}

/* ===== Kontakt ===== */
.contact-grid{
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: clamp(10px, 2vw, 14px);
}
.contact-pill{
  display:flex; align-items:center; gap:12px;
  padding: 14px 16px;
  border:1px solid var(--line);
  border-radius: var(--radius-pill);
  background: var(--white);
  box-shadow: var(--shadow-soft);
  text-decoration:none; color: var(--graphite); font-weight:600;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.contact-pill:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  border-color: color-mix(in srgb, var(--gold) 40%, var(--line));
}
.contact-pill--cta{
  background: linear-gradient(180deg, var(--gold), var(--gold-light));
  color:#0A1418; border-color: transparent;
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
}
.contact-pill--cta:hover{ filter: brightness(1.03); }
.contact-hint{ margin-top: 10px; color: var(--muted); }

/* ===== Ikony (inline SVG jako background) ===== */
.ico{ width:22px; height:22px; flex:0 0 22px; display:inline-block; }
.ico::before{ content:""; display:block; width:100%; height:100%; background-size:contain; background-repeat:no-repeat; }

.ico-web::before{
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="%23212121" viewBox="0 0 24 24"><path d="M12 2a10 10 0 1 0 0 20A10 10 0 0 0 12 2Zm6.32 6H15.9a15.1 15.1 0 0 0-1.2-3.5A8.03 8.03 0 0 1 18.32 8ZM12 4.06c.8 1.09 1.55 2.63 2.02 3.94H9.98c.47-1.31 1.22-2.85 2.02-3.94ZM5.68 8A8.03 8.03 0 0 1 9.3 4.5 15.1 15.1 0 0 0 8.1 8H5.68ZM4.06 12c0-.68.07-1.34.2-2h3.6c-.07.65-.11 1.32-.11 2s.04 1.35.11 2h-3.6c-.13.66-.2 1.32-.2 2Zm1.62 4h2.42c.3 1.07.73 2.2 1.2 3.5A8.03 8.03 0 0 1 5.68 16Zm2.42-8h-2.42A8.03 8.03 0 0 0 9.3 19.5 15.1 15.1 0 0 1 8.1 16Zm3.8 11.94c-.8-1.09-1.55-2.63-2.02-3.94h4.04c-.47 1.31-1.22 2.85-2.02 3.94ZM14.02 14H9.98c-.07-.65-.11-1.32-.11-2s.04-1.35.11-2h4.04c.07.65.11 1.32.11 2s-.04 1.35-.11 2Zm1.88 5.5c.47-1.3.9-2.43 1.2-3.5h2.42A8.03 8.03 0 0 1 15.9 19.5ZM19.94 12c0 .68-.07 1.34-.2 2h-3.6c.07-.65.11-1.32.11-2s-.04-1.35-.11-2h3.6c.13.66.2 1.32.2 2Zm-1.62-4h-2.42c-.3-1.07-.73-2.2-1.2-3.5A8.03 8.03 0 0 1 18.32 8Z"/></svg>');
}
.ico-ig::before{
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="%23212121" viewBox="0 0 24 24"><path d="M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5zm0 2a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3H7zm5 3.5a5.5 5.5 0 1 1 0 11 5.5 5.5 0 0 1 0-11zm0 2a3.5 3.5 0 1 0 0 7 3.5 3.5 0 0 0 0-7zm5.25-.75a1 1 0 1 1 0 2 1 1 0 0 1 0-2z"/></svg>');
}
.ico-phone::before{
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="%23212121" viewBox="0 0 24 24"><path d="M6.6 2h3a1 1 0 0 1 1 1v3.2a1 1 0 0 1-.74.97l-2.1.6a13 13 0 0 0 7.48 7.48l.6-2.1a1 1 0 0 1 .97-.74H20a1 1 0 0 1 1 1v3a2 2 0 0 1-2 2h-.5C9.72 18.31 5.69 14.28 4 7.5V7a2 2 0 0 1 2-2z"/></svg>');
}
.ico-mail::before{
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="%23212121" viewBox="0 0 24 24"><path d="M20 4H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2Zm0 4-8 5L4 8V6l8 5 8-5v2Z"/></svg>');
}
.ico-wa::before{
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="%23212121" viewBox="0 0 24 24"><path d="M20 3.5A10.5 10.5 0 0 0 3.44 17.9L3 22l4.2-1.1A10.47 10.47 0 1 0 20 3.5ZM7.6 19.6l-.26.07-2.44.64.33-2.37.05-.3-.2-.26A8.47 8.47 0 1 1 16.5 5.5a8.48 8.48 0 0 1-8.9 14.1ZM16.8 14c-.09-.14-.32-.23-.66-.4s-2.05-1.01-2.37-1.12-.55-.17-.78.17c-.23.33-.9 1.12-1.1 1.35-.2.23-.41.26-.75.09-.33-.17-1.41-.52-2.69-1.66a10 10 0 0 1-1.77-2.19c-.19-.33-.02-.5.15-.68.16-.16.33-.42.5-.63.17-.2.22-.35.33-.58.11-.23.06-.43-.03-.6-.09-.17-.78-1.85-1.07-2.53-.28-.67-.56-.58-.78-.58h-.66c-.23 0-.6.09-.92.43-.31.33-1.2 1.17-1.2 2.86s1.23 3.32 1.4 3.55c.17.23 2.43 3.72 5.9 5.06 3.47 1.35 3.47.9 4.09.84.63-.06 2.05-.83 2.34-1.64.29-.81.29-1.49.2-1.64Z"/></svg>');
}
.ico-fb::before{
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="%23212121" viewBox="0 0 24 24"><path d="M22 12a10 10 0 1 0-11.5 9.9v-7h-2.3V12h2.3V9.7c0-2.3 1.4-3.5 3.4-3.5.98 0 2 .17 2 .17v2.2h-1.1c-1.1 0-1.5.7-1.5 1.4V12h2.6l-.4 2.9h-2.2v7A10 10 0 0 0 22 12Z"/></svg>');
}

/* ===== Portfolio – przycisk "więcej" ===== */
.portfolio-more { text-align:center; margin-top:20px; }
.portfolio-more .btn { display:inline-block; }

/* ===== Stopka ===== */
.footer{ color: var(--muted); border-top: 1px solid var(--line); padding: 24px 0 40px; background: var(--paper-2) }
.footer-grid{ display:grid; gap:12px; grid-template-columns: 1fr auto; align-items:center }

/* ===== Responsive ===== */

/* 1024 ↓: 3→2 kolumny, mniejsze gapy */
@media (max-width: 1024px){
  .grid.cols-3{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  #portfolio .grid{ gap: clamp(12px, 1.4vw, 18px); }
}

/* 900 ↓: logo i linki ciaśniej */
@media (max-width: 900px){
  .brand .logo{ height: 40px; }
  .nav-links{ gap: 14px; }
}

/* 680 ↓: kontakt jedna kolumna */
@media (max-width: 680px){
  .contact-grid{ grid-template-columns: 1fr; }
}

/* 640 ↓: siatki na jedną kolumnę */
@media (max-width: 640px){
  .grid.cols-3, .grid.cols-2{ grid-template-columns: 1fr; }
}

/* 560 ↓: mniejsze logo/CTA */
@media (max-width: 560px){
  .brand .logo{ height: 34px; }
  .nav-links a{ font-size: 14px; }
  .nav-links .btn{ padding: 9px 16px; }
}

/* 420 ↓: hero przyciski pionowo, pełna szerokość */
@media (max-width: 420px){
  .actions{ flex-direction: column; gap:10px; }
  .actions .btn{ width:100%; }
  .faq-item summary{ font-size:15px; }
  .faq-item ol{ padding-left:1em; }
  .lightbox[role="dialog"]{ --lb-pad: clamp(8px, 3.5vw, 16px); }
  .lightbox[role="dialog"] .close{ top:10px; right:10px; font-size:22px; }
  .footer-grid{ grid-template-columns:1fr; gap:8px; }
  .footer .btn{ width:100%; }
}

/* 360 ↓: kompaktowe odstępy i typografia */
@media (max-width: 360px){
  .container{ padding-inline:12px; }
  section{ padding:36px 0; }
  .hero-eyebrow{ font-size:14px; }
  .title{ font-size: clamp(28px, 9vw, 34px); }
  .lead{ font-size: clamp(14px, 3.6vw, 15px); }
  h2{ font-size: clamp(20px, 5.8vw, 24px); }
  h3{ font-size: clamp(16px, 4.8vw, 18px); }
  p{ font-size:14px; line-height:1.55; }

  .brand .logo{ height:28px; }
  .more-btn{ font-size:13px; padding:6px 10px; }
  .nav-links .nav-cta{
    font-size: clamp(12px, 3.6vw, 13.5px);
    padding: 0.55em 1.05em;
  }

  #portfolio .grid{ gap:10px; }
  #portfolio figure{ border-radius:12px; }
}

/* MOBILE-SAFE „Więcej” — brak ucinania na 320 px */
@media (max-width: 360px){
  .nav-more .more-menu{
    position: fixed; /* zamiast absolute względem przycisku */
    top: calc(var(--safe-top) + var(--nav-h) - 1px); /* tuż pod paskiem */
    /* symetryczne marginesy od krawędzi ekranu + wsparcie dla notcha */
    left: max(8px, env(safe-area-inset-left, 0px));
    right: max(8px, env(safe-area-inset-right, 0px));
    min-width: 0;          /* żadnych sztywnych szerokości */
    width: auto;
    max-width: none;
    max-height: min(60vh, 420px);
    overflow: auto;        /* przewijany, gdy lista długa */
    border-radius: 14px;
    z-index: 999;          /* nad innymi elementami */
  }
  /* trochę większe „tap targety” na małych ekranach */
  .nav-more .more-menu a{ padding: 12px 14px; }
}

/* na wszelki wypadek: nic nie przycina w pasku */
.navbar{ overflow: visible; }

.faq-item p,
.faq-item ul {
  margin-top: 12px;   /* odstęp od pytania */
  margin-left: 20px;
  margin-bottom: 8px; /* dodatkowy luz pod odpowiedzią */
  line-height: 1.6;   /* większa czytelność */
}




/* ==== Lightbox – fixy warstw + stage + kursory ==== */
.lightbox[role="dialog"]{ z-index: 1000; }               /* nad wszystkim */
.lightbox[role="dialog"] .close{ 
  position:absolute; top:16px; right:16px;
  z-index: 5;                                            /* ponad mediami */
  pointer-events:auto;
}

.lightbox-nav{ z-index: 4; }                             /* strzałki ponad mediami */

.lb-stage{
  position: relative;
  overflow: hidden;                                      /* tniemy wychodzące media */
  border-radius: 12px;
  /* zachowujemy te same maksymalne rozmiary co media (patrz Twoje style) */
  max-width: calc(100dvw - (var(--lb-pad) * 2));
  max-height: calc(100dvh - (var(--lb-pad) * 2));
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  background: #000;
  border: 1px solid var(--line);
}
@supports not (width: 1dvw){
  .lb-stage{
    max-width: calc(100vw - (var(--lb-pad) * 2));
    max-height: calc(100vh - (var(--lb-pad) * 2));
  }
}

.lb-media{
  display:block;
  width:auto !important; 
  height:auto !important;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  transform-origin: center center;
  transition: transform .12s ease;                       /* lekko, bez opóźnień */
  will-change: transform;
  cursor: zoom-in;
}

.lb-media.is-zoomed{ cursor: grab; }
.lb-media.is-zoomed.grabbing{ cursor: grabbing; }



/* ===============================
   Lightbox PRO – warstwy + stage
   =============================== */
.lightbox[role="dialog"]{ z-index:1000; }
.lightbox[role="dialog"] .close{
  position:absolute; top:16px; right:16px;
  font-size:28px; color:#fff; cursor:pointer;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 9999px; padding: 8px 14px;
  z-index:5; pointer-events:auto;
}

.lb-stage{
  position:relative;
  overflow:hidden;
  border-radius:12px;
  max-width: calc(100dvw - (var(--lb-pad) * 2));
  max-height: calc(100dvh - (var(--lb-pad) * 2));
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  background:#000;
  border:1px solid var(--line);
}
@supports not (width: 1dvw){
  .lb-stage{
    max-width: calc(100vw - (var(--lb-pad) * 2));
    max-height: calc(100vh - (var(--lb-pad) * 2));
  }
}

.lb-media{
  display:block;
  width:auto !important; height:auto !important;
  max-width:100%; max-height:100%;
  object-fit:contain;
  transform-origin:center center;
  transition: transform .12s ease;
  will-change: transform;
  cursor: zoom-in;
}
.lb-media.is-zoomed{ cursor: grab; }
.lb-media.is-zoomed.grabbing{ cursor: grabbing; }

/* Strzałki nawigacyjne */
.lightbox-nav{
  position:absolute; top:50%; left:0; right:0;
  display:flex; justify-content:space-between;
  transform: translateY(-50%);
  pointer-events:none; z-index:4;
}
.lightbox-arrow{
  pointer-events:auto;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);
  color:#fff; width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:28px; font-weight:300; cursor:pointer;
  transition: background .2s, transform .1s;
  user-select:none;
}
.lightbox-arrow:hover{ background: rgba(255,255,255,.18); transform: scale(1.05); }
@media (max-width:640px){
  .lightbox-arrow{ width:42px; height:42px; font-size:22px; }
}

/* Blokowanie scrolla tła, gdy LB otwarty */
.lb-open{ overflow:hidden !important; }



/* Równe kafle w portfolio (bez rozjeżdżania) */
#portfolio .grid.cols-3 figure{
  position: relative;
  aspect-ratio: 4 / 3;      /* możesz zmienić np. na 3/2 lub 1/1 */
  border-radius: 14px;
  overflow: hidden;
  background: #f2f2f2;      /* placeholder gdy obraz się ładuje */
}

/* picture i img jako bloki, wypełniają cały kadr */
#portfolio .grid.cols-3 figure picture,
#portfolio .grid.cols-3 figure img{
  display: block;
  width: 100%;
  height: 100%;
}

/* przycinaj obraz do kadru, bez zniekształceń */
#portfolio .grid.cols-3 figure img{
  object-fit: cover;
}

/* na węższych ekranach możesz zmienić proporcje, jeśli chcesz wyższe kafle */
@media (max-width: 768px){
  #portfolio .grid.cols-3 figure{ aspect-ratio: 3 / 4; } /* opcjonalnie */
}

