/* =========================================================================
   MS Projektownia — Biuro Architektoniczne (Bochnia)
   Styl: Exaggerated Minimalism / Portfolio Grid · concrete minimal
   Fonty: Archivo (display) + Space Grotesk (body) — self-host woff2
   ========================================================================= */

/* ---- Self-hosted fonts ---- */
@font-face{font-family:'Archivo';font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/archivo-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+0304,U+0308,U+0329,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:'Archivo';font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/archivo-400-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;
  src:url('assets/fonts/archivo-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;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;
  src:url('assets/fonts/archivo-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/archivo-700-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;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/archivo-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;
  src:url('assets/fonts/archivo-800-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;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;
  src:url('assets/fonts/archivo-800-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}

@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/space-grotesk-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;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/space-grotesk-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;
  src:url('assets/fonts/space-grotesk-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;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;
  src:url('assets/fonts/space-grotesk-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;
  src:url('assets/fonts/space-grotesk-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;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;
  src:url('assets/fonts/space-grotesk-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/space-grotesk-700-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;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/space-grotesk-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1E00-1E9F,U+1EF2-1EFF,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* ---- Tokens ---- */
:root{
  --ink:#16161A;          /* tekst / marka */
  --paper:#F4F2EE;        /* warm off-white tło */
  --white:#FFFFFF;
  --concrete:#E4E0D8;     /* sekcje "beton" */
  --concrete-2:#EDEAE3;
  --graphite:#3A3A40;     /* secondary text */
  --muted:#6A6862;        /* muted text (AA na paper i white) */
  --line:#D9D5CC;         /* cienkie linie */
  --terra:#9C5B3B;        /* akcent terakota */
  --terra-700:#824630;    /* hover ciemniejszy */
  --terra-soft:#F0E4DC;   /* tło akcentowe jasne */

  --maxw:1240px;
  --gutter:clamp(20px,5vw,64px);
  --r:2px;                /* minimalny radius — architektoniczny */
  --r-lg:4px;
  --ease:cubic-bezier(.2,.7,.2,1);

  --f-display:'Archivo','Arial Narrow','Helvetica Neue',Arial,sans-serif;
  --f-body:'Space Grotesk','Segoe UI',Helvetica,Arial,sans-serif;
}

/* ---- 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(--paper);color:var(--ink);
  font-family:var(--f-body);font-size:17px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;}
img,svg,picture{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{margin:0;font-family:var(--f-display);font-weight:800;line-height:1.02;letter-spacing:-.02em}

/* base icon size (safety net — patrz lekcja v5.2) */
.ico{width:1.2em;height:1.2em;flex:none;stroke:currentColor;fill:none}

/* ---- Skip link ---- */
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink);color:var(--paper);
  padding:12px 18px;font-weight:600}
.skip:focus{left:12px;top:12px}

/* ---- Focus ---- */
:focus-visible{outline:3px solid var(--terra);outline-offset:3px}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(56px,9vw,120px)}
.section--paper{background:var(--paper)}
.section--white{background:var(--white)}
.section--concrete{background:var(--concrete)}
.section--ink{background:var(--ink);color:var(--paper)}

.eyebrow{font-family:var(--f-body);font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--terra);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--terra);display:inline-block}
.section--ink .eyebrow{color:#D98E66}
.section--ink .eyebrow::before{background:#D98E66}

.s-index{font-family:var(--f-body);font-weight:500;font-size:.78rem;letter-spacing:.18em;
  color:var(--muted);font-variant-numeric:tabular-nums}
.section--ink .s-index{color:#A8A49B}

.lead{font-size:clamp(1.06rem,2vw,1.28rem);color:var(--graphite);max-width:62ch;line-height:1.6}
.section--ink .lead{color:#D7D3CA}

.muted{color:var(--muted)}

/* ============================ HEADER / NAV ============================ */
.site-head{position:sticky;top:0;z-index:100;background:rgba(244,242,238,.86);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.head-inner{max-width:var(--maxw);margin-inline:auto;
  padding:14px clamp(20px,4vw,40px);
  display:flex;align-items:center;justify-content:space-between;gap:16px}

.brand{display:flex;align-items:center;gap:12px;flex:none}
.brand__mark{width:40px;height:40px;border-radius:8px;flex:none}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--f-display);font-weight:800;font-size:1.06rem;letter-spacing:-.02em}
.brand__sub{font-family:var(--f-body);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin-top:4px;font-weight:600}

.nav{display:none}
.nav ul{display:flex;align-items:center;gap:2px}
.nav a{display:inline-block;padding:9px 11px;font-weight:500;font-size:.94rem;color:var(--graphite);
  white-space:nowrap;border-radius:var(--r);transition:color .18s var(--ease),background .18s var(--ease)}
.nav a:hover{color:var(--ink);background:var(--concrete-2)}
.nav a[aria-current="page"]{color:var(--ink);font-weight:600}
.nav a[aria-current="page"]::after{content:"";display:block;height:2px;background:var(--terra);
  margin-top:5px;border-radius:2px}

.head-cta{display:none;align-items:center;gap:12px;flex:none}
.head-tel{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);
  font-variant-numeric:tabular-nums;white-space:nowrap}
.head-tel:hover{color:var(--terra)}

.burger{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;
  border:1px solid var(--line);border-radius:var(--r);background:var(--white)}
.burger span{position:relative;width:20px;height:2px;background:var(--ink);display:block;transition:.25s var(--ease)}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);transition:.25s var(--ease)}
.burger span::before{top:-6px}.burger span::after{top:6px}
.burger[aria-expanded="true"] span{background:transparent}
.burger[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.burger[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* mobile drawer */
.mnav{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:var(--paper);
  border-left:1px solid var(--line);transform:translateX(100%);transition:transform .3s var(--ease);
  z-index:120;display:flex;flex-direction:column;padding:24px var(--gutter) 32px;
  box-shadow:-30px 0 60px rgba(22,22,26,.12);overflow-y:auto}
.mnav.open{transform:translateX(0)}
.mnav__top{display:flex;justify-content:flex-end;margin-bottom:8px}
.mnav__close{width:46px;height:46px;border:1px solid var(--line);border-radius:var(--r);
  display:inline-flex;align-items:center;justify-content:center;background:var(--white)}
.mnav a.mlink{display:block;padding:15px 4px;font-family:var(--f-display);font-weight:700;
  font-size:1.5rem;letter-spacing:-.02em;border-bottom:1px solid var(--line);color:var(--ink)}
.mnav a.mlink[aria-current="page"]{color:var(--terra)}
.mnav__foot{margin-top:auto;padding-top:24px;display:flex;flex-direction:column;gap:12px}
.scrim{position:fixed;inset:0;background:rgba(22,22,26,.5);opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease),visibility .3s;z-index:110}
.scrim.show{opacity:1;visibility:visible}

/* ============================ BUTTONS ============================ */
.btn{display:inline-flex;align-items:center;gap:.6em;padding:14px 24px;border-radius:var(--r);
  font-family:var(--f-body);font-weight:600;font-size:.96rem;line-height:1;white-space:nowrap;
  border:1px solid transparent;transition:transform .15s var(--ease),background .18s var(--ease),
  color .18s var(--ease),border-color .18s var(--ease);cursor:pointer}
.btn .ico{width:1.05em;height:1.05em}
.btn--primary{background:var(--terra);color:var(--white);border-color:var(--terra)}
.btn--primary:hover{background:var(--terra-700);border-color:var(--terra-700)}
.btn--ink{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--ink:hover{background:#000}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}
.section--ink .btn--ghost{color:var(--paper);border-color:rgba(244,242,238,.55)}
.section--ink .btn--ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn:active{transform:translateY(1px)}
.btn--block{width:100%;justify-content:center}

/* ============================ HERO ============================ */
.hero{position:relative;background:var(--paper);border-bottom:1px solid var(--line);overflow:hidden}
.hero__grid-bg{position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:clamp(48px,8vw,96px) clamp(48px,8vw,96px);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 18%,#000 75%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 18%,#000 75%,transparent)}
.hero__inner{position:relative;max-width:var(--maxw);margin-inline:auto;padding:clamp(48px,9vw,104px) var(--gutter) clamp(44px,7vw,80px)}
.hero__meta{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;margin-bottom:clamp(26px,5vw,44px)}
.hero h1{font-size:clamp(2.9rem,11vw,7.2rem);font-weight:800;letter-spacing:-.04em;line-height:.94;
  text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--terra)}
.hero__sub{margin-top:clamp(22px,4vw,34px);display:grid;gap:26px;
  grid-template-columns:1fr;align-items:end}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.hero__facts{display:flex;flex-wrap:wrap;gap:14px 30px;margin-top:clamp(30px,5vw,46px);
  padding-top:24px;border-top:1px solid var(--line)}
.fact{display:flex;flex-direction:column;gap:3px}
.fact b{font-family:var(--f-display);font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.fact span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}

/* ============================ SECTION HEAD ============================ */
.s-head{display:grid;gap:18px;margin-bottom:clamp(34px,6vw,60px)}
.s-head__top{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  border-bottom:1px solid var(--line);padding-bottom:14px}
.section--ink .s-head__top{border-color:rgba(244,242,238,.22)}
.s-head h2{font-size:clamp(2rem,5.4vw,3.4rem);font-weight:800;letter-spacing:-.03em;line-height:1.02;max-width:18ch}

/* ============================ SERVICES ============================ */
.svc-list{border-top:1px solid var(--line)}
.section--ink .svc-list{border-color:rgba(244,242,238,.22)}
.svc{display:grid;grid-template-columns:1fr;gap:10px;padding:clamp(26px,4vw,40px) 0;
  border-bottom:1px solid var(--line);position:relative}
.section--ink .svc{border-color:rgba(244,242,238,.22)}
.svc__n{font-family:var(--f-body);font-weight:600;font-size:.78rem;letter-spacing:.18em;color:var(--terra);
  font-variant-numeric:tabular-nums}
.svc h3{font-family:var(--f-display);font-weight:700;font-size:clamp(1.5rem,4vw,2.1rem);letter-spacing:-.02em}
.svc p{color:var(--graphite);margin:0;max-width:56ch}
.section--ink .svc p{color:#D7D3CA}
.svc__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.tag{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:5px 12px}
.section--ink .tag{color:#C9C5BC;border-color:rgba(244,242,238,.28)}
.svc__ico{width:40px;height:40px;color:var(--ink);stroke-width:1.5}
.section--ink .svc__ico{color:var(--paper)}

@media (min-width:760px){
  .svc{grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:28px}
  .svc__head{display:flex;flex-direction:column;gap:14px}
}

/* ============================ PORTFOLIO GRID ============================ */
.grid-proj{display:grid;gap:clamp(14px,2.2vw,24px);grid-template-columns:1fr}
.proj{position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  min-height:clamp(240px,52vw,360px);padding:24px;border:1px solid var(--line);border-radius:var(--r-lg);
  background:var(--concrete);overflow:hidden;color:var(--ink);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.proj::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(120% 90% at 80% 10%,#000,transparent 72%);
  mask-image:radial-gradient(120% 90% at 80% 10%,#000,transparent 72%)}
.proj--dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.proj--dark::before{opacity:.2;background-image:linear-gradient(rgba(244,242,238,.4) 1px,transparent 1px),linear-gradient(90deg,rgba(244,242,238,.4) 1px,transparent 1px)}
.proj--terra{background:var(--terra);color:var(--white);border-color:var(--terra)}
.proj--terra::before{opacity:.28;background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px)}
.proj:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(22,22,26,.14)}
.proj__cat{position:relative;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  opacity:.82;margin-bottom:8px}
.proj__line{position:absolute;top:24px;right:24px;width:34px;height:34px;color:currentColor;opacity:.8}
.proj h3{position:relative;font-family:var(--f-display);font-weight:700;font-size:clamp(1.4rem,3.4vw,1.9rem);
  letter-spacing:-.02em;line-height:1.05}
.proj p{position:relative;margin:.5em 0 0;font-size:.95rem;opacity:.92;max-width:34ch}
.proj__meta{position:relative;display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:14px;
  font-size:.74rem;letter-spacing:.04em;font-weight:500;opacity:.85;font-variant-numeric:tabular-nums}

@media (min-width:640px){.grid-proj{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.grid-proj{grid-template-columns:repeat(3,1fr)}
  .proj--wide{grid-column:span 2}}

/* note strip under portfolio */
.note-strip{display:flex;gap:14px;align-items:flex-start;margin-top:26px;padding:18px 20px;
  background:var(--concrete-2);border:1px solid var(--line);border-radius:var(--r-lg)}
.note-strip .ico{width:22px;height:22px;color:var(--terra);margin-top:2px;stroke-width:1.7}
.note-strip p{margin:0;font-size:.95rem;color:var(--graphite)}

/* ============================ PROCESS / STEPS ============================ */
.steps{display:grid;gap:0;border-top:1px solid var(--line)}
.section--ink .steps{border-color:rgba(244,242,238,.22)}
.step{display:grid;grid-template-columns:auto 1fr;gap:18px 24px;padding:clamp(24px,4vw,38px) 0;
  border-bottom:1px solid var(--line);align-items:start}
.section--ink .step{border-color:rgba(244,242,238,.22)}
.step__n{font-family:var(--f-display);font-weight:800;font-size:clamp(2rem,6vw,3rem);letter-spacing:-.03em;
  color:var(--line);line-height:1;font-variant-numeric:tabular-nums}
.section--ink .step__n{color:rgba(244,242,238,.32)}
.step h3{font-family:var(--f-display);font-weight:700;font-size:clamp(1.25rem,3vw,1.6rem);letter-spacing:-.02em;margin-bottom:8px}
.step p{margin:0;color:var(--graphite);max-width:60ch}
.section--ink .step p{color:#D7D3CA}

/* ============================ FEATURE / VALUES ============================ */
.feat-grid{display:grid;gap:clamp(16px,2.4vw,26px);grid-template-columns:1fr}
.feat{padding:clamp(22px,3vw,30px);background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg)}
.section--concrete .feat{background:var(--paper)}
.feat__ico{width:40px;height:40px;color:var(--terra);stroke-width:1.5;margin-bottom:16px}
.feat h3{font-family:var(--f-display);font-weight:700;font-size:1.22rem;letter-spacing:-.01em;margin-bottom:8px}
.feat p{margin:0;color:var(--graphite);font-size:.97rem}
@media (min-width:680px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.feat-grid--3{grid-template-columns:repeat(3,1fr)}}

/* ============================ SPLIT / ABOUT ============================ */
.split{display:grid;gap:clamp(28px,5vw,56px);grid-template-columns:1fr;align-items:start}
@media (min-width:920px){.split{grid-template-columns:1.05fr .95fr}.split--rev>*:first-child{order:2}}
.portrait{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  background:var(--concrete);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;padding:28px}
.portrait::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:36px 36px}
.portrait__inner{position:relative;text-align:center;max-width:30ch}
.portrait__mono{width:84px;height:84px;margin:0 auto 18px}
.portrait__name{font-family:var(--f-display);font-weight:800;font-size:1.5rem;letter-spacing:-.02em}
.portrait__role{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:8px}

/* prose */
.prose p{color:var(--graphite);max-width:62ch}
.prose p+p{margin-top:1.1em}
.prose h3{font-family:var(--f-display);font-weight:700;font-size:1.4rem;letter-spacing:-.02em;margin:1.6em 0 .5em}
.checklist{display:grid;gap:12px;margin-top:22px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--graphite)}
.checklist .ico{width:22px;height:22px;color:var(--terra);margin-top:3px;flex:none;stroke-width:2}

/* ============================ STAT BAR ============================ */
.statbar{display:grid;gap:24px;grid-template-columns:1fr;text-align:left}
.stat b{display:block;font-family:var(--f-display);font-weight:800;font-size:clamp(2.2rem,6vw,3.2rem);
  letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.stat span{display:block;margin-top:10px;font-size:.92rem;color:var(--graphite)}
.section--ink .stat span{color:#C9C5BC}
@media (min-width:640px){.statbar{grid-template-columns:repeat(3,1fr)}}

/* ============================ FAQ ============================ */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  gap:16px;padding:clamp(18px,3vw,26px) 0;font-family:var(--f-display);font-weight:700;
  font-size:clamp(1.1rem,2.6vw,1.4rem);letter-spacing:-.015em}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ico{width:24px;height:24px;color:var(--terra);flex:none;transition:transform .25s var(--ease)}
.faq details[open] summary .ico{transform:rotate(45deg)}
.faq__a{padding:0 0 24px;color:var(--graphite);max-width:70ch}
.faq__a p{margin:0 0 .8em}

/* ============================ CTA BANNER ============================ */
.cta-band{position:relative;overflow:hidden}
.cta-band__inner{display:grid;gap:24px;grid-template-columns:1fr;align-items:center}
.cta-band h2{font-size:clamp(2rem,6vw,3.4rem);font-weight:800;letter-spacing:-.03em;line-height:1.02;max-width:16ch}
.cta-band__actions{display:flex;flex-wrap:wrap;gap:12px}
@media (min-width:880px){.cta-band__inner{grid-template-columns:1.3fr auto;gap:40px}}

/* ============================ CONTACT ============================ */
.contact-grid{display:grid;gap:clamp(28px,5vw,48px);grid-template-columns:1fr}
@media (min-width:960px){.contact-grid{grid-template-columns:.85fr 1.15fr}}
.cinfo{display:grid;gap:18px}
.cinfo__item{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.cinfo__item .ico{width:26px;height:26px;color:var(--terra);flex:none;margin-top:2px;stroke-width:1.7}
.cinfo__item h3{font-family:var(--f-body);font-weight:600;font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.cinfo__item a,.cinfo__item p{font-family:var(--f-display);font-weight:700;font-size:1.18rem;letter-spacing:-.01em;
  color:var(--ink);font-variant-numeric:tabular-nums;margin:0}
.cinfo__item a:hover{color:var(--terra)}
.cinfo__item small{display:block;font-family:var(--f-body);font-weight:400;font-size:.9rem;
  letter-spacing:0;color:var(--muted);text-transform:none;margin-top:4px}

/* form */
.form{display:grid;gap:18px}
.field{display:grid;gap:7px}
.field label{font-weight:600;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--graphite)}
.field label .req{color:var(--terra)}
.field input,.field textarea,.field select{font:inherit;font-size:1rem;color:var(--ink);background:var(--white);
  border:1px solid var(--line);border-radius:var(--r);padding:13px 15px;width:100%;
  transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--terra);
  box-shadow:0 0 0 3px rgba(156,91,59,.18)}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#C23B22;
  box-shadow:0 0 0 3px rgba(194,59,34,.16)}
.field .err{color:#C23B22;font-size:.85rem;font-weight:500;min-height:0;letter-spacing:0;text-transform:none}
.form__row{display:grid;gap:18px}
@media (min-width:560px){.form__row{grid-template-columns:1fr 1fr}}
.form__consent{display:flex;gap:11px;align-items:flex-start;font-size:.88rem;color:var(--muted);letter-spacing:0;text-transform:none}
.form__consent input{width:20px;height:20px;flex:none;margin-top:2px;accent-color:var(--terra)}
.form__consent a{color:var(--terra);text-decoration:underline}
.form__status{font-weight:600;padding:14px 16px;border-radius:var(--r);display:none}
.form__status.ok{display:block;background:var(--terra-soft);color:var(--terra-700);border:1px solid #E2C9BC}
.form__status.bad{display:block;background:#FBEAE6;color:#9A2A18;border:1px solid #EFC9C0}

/* map in its OWN container */
.map-wrap{margin-top:clamp(34px,6vw,52px)}
.map-frame{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  max-width:var(--maxw);aspect-ratio:16/10;background:var(--concrete)}
@media (min-width:760px){.map-frame{aspect-ratio:21/9}}
.map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;filter:grayscale(.25) contrast(1.02)}
.map-cap{margin-top:12px;font-size:.86rem;color:var(--muted)}

/* ============================ FOOTER ============================ */
.site-foot{background:var(--ink);color:var(--paper);padding-block:clamp(48px,7vw,80px)}
.foot-grid{display:grid;gap:34px;grid-template-columns:1fr}
.foot-brand .brand__name{color:var(--paper)}
.foot-brand .brand__sub{color:#A8A49B}
.foot-brand p{color:#C9C5BC;margin:18px 0 0;max-width:42ch;font-size:.96rem}
.foot-col h4{font-family:var(--f-body);font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:#A8A49B;margin-bottom:16px}
.foot-col ul{display:grid;gap:11px}
.foot-col a{color:#D7D3CA;font-size:.97rem}
.foot-col a:hover{color:var(--paper)}
.foot-col a.tel{font-variant-numeric:tabular-nums}
.foot-bottom{margin-top:clamp(34px,6vw,54px);padding-top:24px;border-top:1px solid rgba(244,242,238,.18);
  display:flex;flex-wrap:wrap;gap:12px 24px;justify-content:space-between;align-items:center;
  font-size:.85rem;color:#A8A49B}
.foot-bottom a{color:#A8A49B}.foot-bottom a:hover{color:var(--paper)}
.foot-social{display:flex;gap:10px}
.foot-social a{width:42px;height:42px;border:1px solid rgba(244,242,238,.24);border-radius:var(--r);
  display:inline-flex;align-items:center;justify-content:center;color:#D7D3CA;transition:.18s var(--ease)}
.foot-social a:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.foot-social .ico{width:20px;height:20px}
@media (min-width:760px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr;gap:48px}}

/* ============================ PAGE HEAD (subpages) ============================ */
.page-head{background:var(--paper);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-head__grid{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:clamp(48px,8vw,90px) clamp(48px,8vw,90px);
  -webkit-mask-image:linear-gradient(180deg,#000,transparent);mask-image:linear-gradient(180deg,#000,transparent)}
.page-head__inner{position:relative;max-width:var(--maxw);margin-inline:auto;
  padding:clamp(40px,7vw,84px) var(--gutter) clamp(34px,5vw,56px)}
.crumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:.82rem;color:var(--muted);
  font-weight:500;margin-bottom:22px}
.crumb a:hover{color:var(--terra)}
.crumb li{display:flex;align-items:center;gap:8px}
.crumb li:not(:last-child)::after{content:"/";color:var(--line)}
.crumb [aria-current="page"]{color:var(--ink)}
.page-head h1{font-size:clamp(2.4rem,8vw,5rem);font-weight:800;letter-spacing:-.035em;line-height:.96;
  text-wrap:balance;margin-top:6px}
.page-head .lead{margin-top:22px}

/* ============================ REVEAL ANIMATIONS ============================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}
.reveal[data-d="2"]{transition-delay:.14s}
.reveal[data-d="3"]{transition-delay:.21s}
.reveal[data-d="4"]{transition-delay:.28s}
.reveal[data-d="5"]{transition-delay:.35s}
/* failsafe: jeśli JS nie wystartuje, nic nie zostaje ukryte */
.no-js-safe .reveal{opacity:1;transform:none}
html.reveal-instant .reveal{opacity:1!important;transform:none!important;transition:none!important}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .proj:hover{transform:none}
  .btn:active{transform:none}
}

/* big desktop nav — breakpoint set so 6 links + tel + CTA fit on one row */
@media (min-width:1180px){
  .nav{display:block}
  .head-cta{display:flex}
  .burger{display:none}
}
@media (min-width:1080px){
  .hero__sub{grid-template-columns:1.1fr .9fr;gap:40px}
}
