/* =========================================================
   ASfoto — Studio Fotografii (Jarosław)
   Kierunek: editorial minimal, foto-first, ciepłe neutralne.
   Fonty self-host: Marcellus (display) + Spectral (body).
   ========================================================= */

/* ---------- @font-face (self-host woff2, latin + latin-ext PL) ---------- */
@font-face{font-family:"Marcellus";font-style:normal;font-weight:400;font-display:swap;
  src:url(assets/fonts/marcellus-400-latin.woff2) format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Marcellus";font-style:normal;font-weight:400;font-display:swap;
  src:url(assets/fonts/marcellus-400-latin-ext.woff2) format("woff2");
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}

@font-face{font-family:"Spectral";font-style:normal;font-weight:300;font-display:swap;
  src:url(assets/fonts/spectral-300-latin.woff2) format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:300;font-display:swap;
  src:url(assets/fonts/spectral-300-latin-ext.woff2) format("woff2");
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:400;font-display:swap;
  src:url(assets/fonts/spectral-400-latin.woff2) format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:400;font-display:swap;
  src:url(assets/fonts/spectral-400-latin-ext.woff2) format("woff2");
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Spectral";font-style:italic;font-weight:400;font-display:swap;
  src:url(assets/fonts/spectral-400-italic-latin.woff2) format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Spectral";font-style:italic;font-weight:400;font-display:swap;
  src:url(assets/fonts/spectral-400-italic-latin-ext.woff2) format("woff2");
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:500;font-display:swap;
  src:url(assets/fonts/spectral-500-latin.woff2) format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:500;font-display:swap;
  src:url(assets/fonts/spectral-500-latin-ext.woff2) format("woff2");
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:600;font-display:swap;
  src:url(assets/fonts/spectral-600-latin.woff2) format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Spectral";font-style:normal;font-weight:600;font-display:swap;
  src:url(assets/fonts/spectral-600-latin-ext.woff2) format("woff2");
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* ---------- tokeny ---------- */
:root{
  --porcelain:#F6F0E7;   /* tło główne, ciepła porcelana */
  --oat:#EFE6D8;         /* tło sekcji alt */
  --linen:#FBF7F0;       /* karty / jaśniejsze pola */
  --ink:#2A2622;         /* tekst główny, ciepły grafit */
  --ink-soft:#5A5048;    /* tekst drugorzędny */
  --muted:#6F6457;       /* podpisy, meta (AA na porcelana/oat/linen) */
  --clay:#B26A48;        /* akcent — terakota/glina (kontrast AA na jasnym) */
  --clay-deep:#9A5638;   /* akcent ciemniejszy do hover/tekstu na jasnym */
  --rose:#C98A6B;        /* ciepły róż-glina, dekoracje */
  --line:#E2D6C4;        /* delikatne linie na jasnym */
  --line-soft:#EAE0D2;
  --ink-on-dark:#F3ECE3; /* tekst na ciemnym */
  --shadow:0 18px 50px -28px rgba(42,38,34,.45);
  --shadow-sm:0 8px 24px -16px rgba(42,38,34,.4);
  --maxw:1200px;
  --gap:clamp(1.1rem,3vw,2rem);
  --r:14px;
  --r-lg:22px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--porcelain);color:var(--ink);
  font-family:"Spectral",Georgia,"Times New Roman",serif;font-weight:400;
  font-size:clamp(1rem,.96rem + .25vw,1.075rem);line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}
h1,h2,h3,h4{font-family:"Marcellus",Georgia,serif;font-weight:400;line-height:1.12;
  letter-spacing:.005em;color:var(--ink);margin:0 0 .5em}
p{margin:0 0 1rem}
ul{margin:0;padding:0}

/* bazowy rozmiar ikon (siatka bezpieczeństwa) */
.ico{width:1.3em;height:1.3em;flex:none;display:inline-block;vertical-align:middle}

/* ---------- utilities ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.4rem)}
.eyebrow{font-family:"Spectral",serif;font-weight:500;font-size:.78rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--clay-deep);margin:0 0 1rem;display:inline-block}
.lead{font-size:clamp(1.08rem,1rem + .5vw,1.32rem);color:var(--ink-soft);line-height:1.6;font-weight:300}
.tnum{font-variant-numeric:tabular-nums}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--ink-on-dark);
  padding:.7rem 1.1rem;border-radius:0 0 10px 0;z-index:1000}
.skip:focus{left:0}
:focus-visible{outline:2.5px solid var(--clay-deep);outline-offset:3px;border-radius:4px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.92rem 1.7rem;border-radius:999px;font-family:"Spectral",serif;font-weight:500;
  font-size:.97rem;letter-spacing:.02em;white-space:nowrap;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s var(--ease),background-color .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);
  min-height:48px}
.btn--primary{background:var(--ink);color:var(--ink-on-dark)}
.btn--primary:hover{background:var(--clay-deep);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--ink-on-dark);transform:translateY(-2px)}
.btn--light{background:var(--linen);color:var(--ink);border-color:var(--line)}
.btn--light:hover{background:#fff;border-color:var(--clay);transform:translateY(-2px)}
.btn:active{transform:translateY(0)}

/* ===================== HEADER ===================== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(246,240,231,.86);
  backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background-color .3s}
.site-header.is-stuck{border-bottom-color:var(--line);box-shadow:0 10px 30px -24px rgba(42,38,34,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px}
.brand{display:flex;align-items:center;gap:.7rem;flex:none}
.brand__mark{width:40px;height:40px;flex:none}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:"Marcellus",serif;font-size:1.32rem;letter-spacing:.06em;color:var(--ink)}
.brand__sub{font-family:"Spectral",serif;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-top:.32rem}

.nav__links{display:none;list-style:none;align-items:center;gap:clamp(1rem,2.2vw,2rem)}
.nav__links a{font-family:"Spectral",serif;font-size:.93rem;letter-spacing:.04em;color:var(--ink-soft);
  white-space:nowrap;position:relative;padding:.3rem 0;transition:color .2s}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;
  background:var(--clay);transition:right .28s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{right:0}
.nav__links a[aria-current="page"]{color:var(--ink)}
.nav__links a[aria-current="page"]::after{right:0}

.nav__cta{display:flex;align-items:center;gap:.85rem;flex:none}
.nav__tel{display:none;align-items:center;gap:.45rem;font-family:"Spectral",serif;font-weight:500;
  font-size:.95rem;color:var(--ink);white-space:nowrap}
.nav__tel .ico{color:var(--clay-deep);width:1.1em;height:1.1em}
.nav__tel:hover{color:var(--clay-deep)}
.nav .btn{display:none}
.nav__toggle{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;
  background:transparent;border:1px solid var(--line);border-radius:12px;color:var(--ink);cursor:pointer;transition:background-color .2s,border-color .2s}
.nav__toggle:hover{background:var(--linen);border-color:var(--clay)}
.nav__toggle .ico{width:1.4em;height:1.4em}
.nav__toggle .ico-close{display:none}
.nav__toggle[aria-expanded="true"] .ico-open{display:none}
.nav__toggle[aria-expanded="true"] .ico-close{display:inline-block}

/* menu mobilne */
.mobile-menu{position:fixed;inset:74px 0 0;background:var(--porcelain);z-index:99;
  transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
  display:flex;flex-direction:column;padding:2rem clamp(1.2rem,6vw,2.4rem) 2.5rem;overflow-y:auto}
.mobile-menu.is-open{opacity:1;visibility:visible;transform:none;pointer-events:auto}
.mobile-menu ul{list-style:none}
.mobile-menu li{border-bottom:1px solid var(--line)}
.mobile-menu li a{display:block;padding:1.05rem .2rem;font-family:"Marcellus",serif;font-size:1.5rem;color:var(--ink)}
.mobile-menu li a[aria-current="page"]{color:var(--clay-deep)}
.mm-actions{display:flex;flex-direction:column;gap:.8rem;margin-top:1.8rem}
.mm-actions .btn{width:100%}

/* ===================== HERO ===================== */
.hero{position:relative;padding:clamp(3rem,8vw,6rem) 0 clamp(2.5rem,6vw,4.5rem)}
.hero__grid{display:grid;gap:clamp(1.8rem,4vw,3rem)}
.hero__eyebrow{display:flex;align-items:center;gap:.8rem}
.hero__eyebrow .rule{width:46px;height:1px;background:var(--clay);display:inline-block}
.hero h1{font-size:clamp(2.6rem,2rem + 6vw,5.4rem);letter-spacing:-.01em;margin:.4rem 0 0}
.hero h1 em{font-style:italic;font-family:"Spectral",serif;font-weight:300;color:var(--clay-deep)}
.hero__lead{max-width:46ch;margin-top:1.4rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem;margin-top:2.6rem;padding-top:1.8rem;border-top:1px solid var(--line)}
.hero__meta .mi{display:flex;flex-direction:column;gap:.15rem}
.hero__meta .mi strong{font-family:"Marcellus",serif;font-size:1.6rem;color:var(--ink);line-height:1}
.hero__meta .mi span{font-size:.82rem;color:var(--muted);letter-spacing:.04em}

/* hero — kolumna obrazu (kolaż kadrów) */
.hero__gallery{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.7rem}
.hero__gallery .frame{position:relative;overflow:hidden;border-radius:var(--r);background:var(--oat);border:1px solid var(--line-soft)}
.hero__gallery .frame--tall{grid-row:span 2;aspect-ratio:3/5}
.hero__gallery .frame--sm{aspect-ratio:4/5}
.hero__gallery .frame--wide{aspect-ratio:4/5}

/* placeholder zdjęcia (elegancki, NIE stock/fake) */
.ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;
  background:
    repeating-linear-gradient(135deg,rgba(178,106,72,.05) 0 14px,transparent 14px 28px),
    linear-gradient(160deg,var(--oat),var(--linen));
  color:var(--muted);text-align:center;padding:1.1rem}
.ph__inner{display:flex;flex-direction:column;align-items:center;gap:.55rem}
.ph__inner .ico{width:1.9rem;height:1.9rem;color:var(--clay);opacity:.85}
.ph__inner span{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);max-width:18ch;line-height:1.4}

/* ===================== SECTIONS ===================== */
.section{padding:clamp(3.2rem,8vw,6rem) 0}
.section--alt{background:var(--oat)}
.section--ink{background:var(--ink);color:var(--ink-on-dark)}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--ink-on-dark)}
.section--ink .eyebrow{color:var(--rose)}
.section--ink .lead{color:#D8CdbF}
.section__head{max-width:62ch}
.section__head.center{margin-inline:auto;text-align:center}
.section__title{font-size:clamp(2rem,1.5rem + 2.6vw,3.2rem)}
.section__intro{margin-top:.6rem}

/* ---------- two-col editorial ---------- */
.split{display:grid;gap:clamp(1.8rem,5vw,4rem);align-items:center}

/* ---------- offer / service cards ---------- */
.cards{display:grid;gap:clamp(1.1rem,2.5vw,1.6rem)}
.card{background:var(--linen);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.5rem,3vw,2.1rem);display:flex;flex-direction:column;gap:.9rem;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--clay)}
.card__ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--oat);color:var(--clay-deep);border:1px solid var(--line)}
.card__ico .ico{width:1.5rem;height:1.5rem}
.card h3{font-size:1.5rem;margin:.2rem 0 0}
.card p{color:var(--ink-soft);margin:0;font-weight:300}
.card__meta{margin-top:auto;padding-top:.6rem;font-size:.85rem;color:var(--muted);letter-spacing:.03em;
  display:flex;align-items:center;gap:.5rem}
.card__meta .ico{width:1.05em;height:1.05em;color:var(--clay)}

/* ---------- numbered process ---------- */
.steps{display:grid;gap:clamp(1.2rem,3vw,2rem);counter-reset:step}
.step{position:relative;padding:1.6rem 0 1.6rem 4.4rem;border-top:1px solid var(--line)}
.step:last-child{border-bottom:1px solid var(--line)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);
  position:absolute;left:0;top:1.55rem;font-family:"Marcellus",serif;font-size:1.5rem;color:var(--clay-deep)}
.step h3{font-size:1.35rem;margin:0 0 .35rem}
.step p{margin:0;color:var(--ink-soft);font-weight:300}

/* ---------- gallery grid (równa siatka 4:5, anty-orphan) ---------- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.gallery .shot{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--r);
  background:var(--oat);border:1px solid var(--line-soft)}
.gallery .shot .ph__inner span{font-size:.66rem}
.shot__cap{position:absolute;left:0;right:0;bottom:0;padding:.7rem .8rem;
  background:linear-gradient(to top,rgba(42,38,34,.62),transparent);
  color:#F6EFE5;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.gallery .shot:hover .shot__cap,.gallery .shot:focus-within .shot__cap{opacity:1;transform:none}

/* ---------- pricing ---------- */
.tiers{display:grid;gap:clamp(1.1rem,2.5vw,1.5rem)}
.tier{background:var(--linen);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.6rem,3vw,2.2rem);display:flex;flex-direction:column;gap:1rem;position:relative}
.tier--feature{border-color:var(--clay);box-shadow:var(--shadow)}
.tier__tag{position:absolute;top:-.8rem;left:clamp(1.6rem,3vw,2.2rem);background:var(--clay-deep);
  color:var(--ink-on-dark);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.32rem .8rem;border-radius:999px}
.tier h3{font-size:1.7rem;margin:0}
.tier__price{font-family:"Marcellus",serif;font-size:2.1rem;color:var(--ink);line-height:1}
.tier__price small{font-family:"Spectral",serif;font-size:.85rem;color:var(--muted);letter-spacing:.04em;display:block;margin-top:.35rem;font-weight:400}
.tier__list{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin:.4rem 0;font-weight:300}
.tier__list li{display:flex;align-items:flex-start;gap:.6rem;color:var(--ink-soft)}
.tier__list .ico{width:1.15em;height:1.15em;color:var(--clay-deep);margin-top:.28em;flex:none}
.tier .btn{margin-top:auto}
.price-note{margin-top:1.6rem;font-size:.86rem;color:var(--muted);text-align:center}

/* ---------- reviews / slider ---------- */
.reviews{position:relative}
.reviews__track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:.4rem}
.reviews__track::-webkit-scrollbar{display:none}
.review{scroll-snap-align:start;flex:0 0 86%;background:var(--linen);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.1rem);display:flex;flex-direction:column;gap:1rem}
.review__stars{display:inline-flex;gap:.18rem;color:var(--clay)}
.review__stars .ico{width:1.05rem;height:1.05rem}
.review p{font-family:"Spectral",serif;font-style:italic;font-size:1.08rem;color:var(--ink);margin:0;font-weight:400}
.review__by{display:flex;flex-direction:column;gap:.1rem;margin-top:auto}
.review__by strong{font-family:"Marcellus",serif;font-weight:400;font-size:1.05rem}
.review__by span{font-size:.8rem;color:var(--muted);letter-spacing:.04em}
.slider-controls{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin-top:1.6rem}
.slider-controls .arrow{width:46px;height:46px;border-radius:999px;border:1px solid var(--line);
  background:var(--linen);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s}
.slider-controls .arrow:hover{background:var(--ink);color:var(--ink-on-dark);border-color:var(--ink)}
.slider-controls .arrow:disabled{opacity:.35;cursor:default}
.slider-controls .arrow:disabled:hover{background:var(--linen);color:var(--ink);border-color:var(--line)}
.dots{display:flex;align-items:center;gap:.35rem}
.dots button{width:24px;height:24px;padding:0;border:none;background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center}
.dots button::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--line);transition:background-color .2s,transform .2s}
.dots button[aria-current="true"]::before{background:var(--clay-deep);transform:scale(1.3)}

/* ---------- callout (notatka demo / banner) ---------- */
.note{background:var(--oat);border:1px dashed var(--clay);border-radius:var(--r);
  padding:1rem 1.2rem;font-size:.9rem;color:var(--ink-soft);display:flex;gap:.7rem;align-items:flex-start}
.note .ico{color:var(--clay-deep);width:1.3rem;height:1.3rem;flex:none;margin-top:.1rem}
.todo{color:var(--clay-deep);font-style:italic;font-weight:500}

/* ---------- contact / form ---------- */
.contact-grid{display:grid;gap:clamp(1.8rem,4vw,3rem)}
.contact-info{display:flex;flex-direction:column;gap:1.4rem}
.contact-item{display:flex;gap:.9rem;align-items:flex-start}
.contact-item .ci-ico{width:44px;height:44px;border-radius:12px;background:var(--oat);border:1px solid var(--line);
  color:var(--clay-deep);display:flex;align-items:center;justify-content:center;flex:none}
.contact-item .ci-ico .ico{width:1.35rem;height:1.35rem}
.contact-item h3{font-size:1.05rem;margin:0 0 .2rem;font-family:"Spectral",serif;font-weight:600;letter-spacing:.02em}
.contact-item a,.contact-item p{margin:0;color:var(--ink-soft)}
.contact-item a:hover{color:var(--clay-deep)}

.form{background:var(--linen);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.5rem,3.5vw,2.4rem)}
.field{margin-bottom:1.15rem}
.field label{display:block;font-family:"Spectral",serif;font-weight:500;font-size:.9rem;margin-bottom:.45rem;color:var(--ink)}
.field .req{color:var(--clay-deep)}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border:1px solid var(--line);
  border-radius:10px;background:var(--porcelain);color:var(--ink);font:inherit;font-size:1rem;
  transition:border-color .2s,box-shadow .2s;min-height:48px}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--clay-deep);box-shadow:0 0 0 3px rgba(178,106,72,.16)}
.field .err{display:none;color:#A33B26;font-size:.82rem;margin-top:.4rem}
.field.has-error input,.field.has-error textarea,.field.has-error select{border-color:#A33B26}
.field.has-error .err{display:block}
.form-row{display:grid;gap:1.15rem}
.check{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--muted);margin-bottom:1.2rem;line-height:1.5}
.check input{width:18px;height:18px;margin-top:.2rem;flex:none;accent-color:var(--clay-deep)}
.check a{color:var(--clay-deep);text-decoration:underline}
.form .btn{width:100%}
.form-status{display:none;margin-top:1rem;padding:.85rem 1rem;border-radius:10px;font-size:.92rem;align-items:center;gap:.5rem}
.form-status.ok{display:flex;background:#EAF1E6;color:#3C5A2E;border:1px solid #CBDCBF}
.form-status .ico{color:#3C5A2E;width:1.2rem;height:1.2rem}

/* ---------- mapa (własny kontener — NIGDY full-bleed) ---------- */
.map-frame{margin-top:1.6rem;max-width:100%;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);background:var(--oat)}
.map-frame iframe{display:block;width:100%;height:340px;border:0;filter:grayscale(.2) sepia(.06)}

/* ---------- breadcrumb ---------- */
.breadcrumb{padding:1.1rem 0 0}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;font-size:.82rem;color:var(--muted)}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--clay-deep)}
.breadcrumb li+li::before{content:"/";margin-right:.5rem;color:var(--line);}
.breadcrumb [aria-current="page"]{color:var(--ink-soft)}

/* ---------- CTA band ---------- */
.cta-band{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.4rem}
.cta-band h2{font-size:clamp(2rem,1.5rem + 3vw,3.4rem);max-width:18ch}
.cta-band .lead{max-width:48ch}
.cta-band__actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center}

/* ---------- about portrait ---------- */
.about-portrait{aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-soft);background:var(--oat)}
.signature{font-family:"Spectral",serif;font-style:italic;font-size:1.4rem;color:var(--clay-deep);margin-top:1rem}

/* ---------- faq ---------- */
.faq{display:flex;flex-direction:column;gap:.2rem;max-width:74ch;margin-inline:auto}
.faq details{border-bottom:1px solid var(--line);padding:.3rem 0}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 2.4rem 1.1rem 0;position:relative;
  font-family:"Marcellus",serif;font-size:1.22rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";position:absolute;right:.4rem;top:1.5rem;width:12px;height:12px;
  border-right:1.5px solid var(--clay-deep);border-bottom:1.5px solid var(--clay-deep);
  transform:rotate(45deg);transition:transform .25s var(--ease)}
.faq details[open] summary::after{transform:rotate(225deg)}
.faq details p{margin:0 0 1.1rem;color:var(--ink-soft);font-weight:300;max-width:64ch}

/* ===================== FOOTER ===================== */
.site-footer{background:var(--ink);color:var(--ink-on-dark);padding:clamp(3rem,6vw,4.5rem) 0 1.8rem}
.footer-grid{display:grid;gap:2.2rem}
.footer-brand .brand__name{color:var(--ink-on-dark)}
.footer-brand .brand__sub{color:#B7AC9D}
.footer-brand p{color:#C8BCAC;font-weight:300;margin-top:1rem;max-width:36ch}
.footer-col h4{font-family:"Spectral",serif;font-weight:600;font-size:.82rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--rose);margin:0 0 1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col a,.footer-col p{color:#D6CABA;font-weight:300}
.footer-col a:hover{color:var(--ink-on-dark)}
.footer-contact a{display:flex;align-items:center;gap:.55rem}
.footer-contact .ico{color:var(--rose);width:1.05em;height:1.05em}
.footer-bottom{margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid rgba(243,236,227,.14);
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;align-items:center;
  font-size:.82rem;color:#A99E8F}
.footer-bottom a{color:#A99E8F}
.footer-bottom a:hover{color:var(--ink-on-dark)}

/* ===================== REVEAL (enhancement; nigdy nie ukrywaj treści) ===================== */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.is-visible{opacity:1;transform:none}
.js .reveal[data-d="1"]{transition-delay:.08s}
.js .reveal[data-d="2"]{transition-delay:.16s}
.js .reveal[data-d="3"]{transition-delay:.24s}
.js .reveal[data-d="4"]{transition-delay:.32s}
html.reveal-instant .reveal{opacity:1!important;transform:none!important}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .btn,.card,.shot__cap{transition:none!important}
}

/* ===================== RESPONSIVE ===================== */
@media (min-width:560px){
  .gallery{grid-template-columns:repeat(3,1fr)}
  .form-row{grid-template-columns:1fr 1fr}
}
@media (min-width:768px){
  .hero__grid{grid-template-columns:1.05fr .95fr;align-items:center}
  .cards{grid-template-columns:repeat(2,1fr)}
  .tiers{grid-template-columns:repeat(3,1fr);align-items:stretch}
  .split{grid-template-columns:1fr 1fr}
  .split--portrait{grid-template-columns:.9fr 1.1fr}
  .contact-grid{grid-template-columns:.85fr 1.15fr}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1.2fr}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .review{flex-basis:calc(50% - .5rem)}
}
@media (min-width:1024px){
  .nav__links{display:flex}
  .nav__tel{display:flex}
  .nav .btn{display:inline-flex}
  .nav__toggle{display:none}
  .mobile-menu{display:none}
  .cards--3{grid-template-columns:repeat(3,1fr)}
  /* slider -> równa siatka na desktopie (wszystko widoczne) */
  .reviews__track{overflow:visible;flex-wrap:wrap}
  .review{flex-basis:calc(33.333% - .667rem)}
  .slider-controls{display:none}
}
@media (min-width:1024px) and (max-width:1180px){
  .nav__links{gap:1rem}
  .nav__links a{font-size:.86rem}
}

/* desktopowy hero gallery: bardziej okazały kolaż */
@media (min-width:768px){
  .hero__gallery{grid-template-columns:1.2fr .8fr;gap:.8rem}
  .hero__gallery .frame--tall{aspect-ratio:3/4.6}
}
