/* ============================================================
   - premium, architektoniczny B2B fit-out
   Jasna paleta, zero brązu. System wg premium-web-craft.
   Projekt strony: Krzysztof Brzeziński
   ============================================================ */

:root{
  /* PALETA - jasna, architektoniczna, chłodna */
  --paper:#F2F8FC;          /* główne tło */
  --paper-2:#E0EEF7;        /* sekcje alternatywne (chłodny jasny szary) */
  --paper-3:#E0EEF7;        /* delikatne wypełnienia */
  --ink:#021547;            /* tekst główny - chłodny grafit */
  --ink-soft:#0A2A66;       /* nagłówki drugorzędne */
  --muted:#3D4B5C;          /* tekst poboczny */
  --line:rgba(2,21,71,.12);/* hairline */
  --accent:#3A5C8F;         /* stonowany petrol-slate - jedyny akcent */
  --accent-d:#274369;
  --accent-soft:rgba(58,92,143,.12);
  --dark:#021547;           /* sekcje ciemne (stopka/CTA) */

  /* ODSTĘPY - skala 4/8 */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
  --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px; --space-10:128px;

  /* TYPOGRAFIA - fluid clamp() */
  --text-sm:clamp(.88rem,.84rem+.18vw,1rem);
  --text-base:clamp(1.06rem,1rem+.35vw,1.22rem);
  --text-lg:clamp(1.18rem,1.08rem+.4vw,1.4rem);
  --text-h3:clamp(1.2rem,1.1rem+.5vw,1.5rem);
  --text-h2:clamp(1.9rem,1.5rem+1.9vw,2.8rem);
  --text-h1:clamp(2.6rem,1.9rem+3.6vw,4.6rem);

  /* PROMIENIE - architektoniczne, raczej ostre */
  --r-sm:3px; --r-md:6px; --r-lg:10px;

  /* RUCH */
  --ease:cubic-bezier(.25,.46,.45,.94); --dur:.24s;

  /* CIENIE - miękkie, warstwowe */
  --sh-sm:0 1px 2px rgba(16,24,32,.04), 0 2px 8px rgba(16,24,32,.05);
  --sh-md:0 2px 6px rgba(16,24,32,.05), 0 12px 28px -8px rgba(16,24,32,.12);
  --sh-lg:0 6px 14px rgba(16,24,32,.07), 0 26px 56px -18px rgba(16,24,32,.22);

  --hairline:1px solid var(--line);

  --font-display:'Barlow Condensed','Hanken Grotesk',sans-serif;
  --font-body:'Hanken Grotesk',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:var(--text-base);
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{width:min(92%,1180px);margin-inline:auto}
section{padding-block:clamp(52px,6.5vw,96px)}

h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:var(--text-h1);letter-spacing:-.035em}
h2{font-size:var(--text-h2);letter-spacing:-.025em}
h3{font-size:var(--text-h3)}
p{max-width:65ch}

.eyebrow{
  font-family:var(--font-body);
  font-size:var(--text-sm);
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:var(--space-3);
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--accent);display:inline-block}

.muted{color:var(--muted)}
.lead{font-size:var(--text-lg);line-height:1.55;color:var(--ink-soft);max-width:50ch}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:var(--space-2);
  font-weight:600;font-size:var(--text-sm);letter-spacing:.02em;
  padding:var(--space-4) var(--space-6);
  border-radius:var(--r-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);
  cursor:pointer;border:1px solid transparent;
}
.btn-accent{background:var(--accent);color:#fff;box-shadow:var(--sh-sm)}
.btn-accent:hover{background:var(--accent-d);transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn-accent:active{transform:translateY(0);box-shadow:var(--sh-sm)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink);box-shadow:var(--sh-sm)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn .arr{transition:transform var(--dur) var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:var(--hairline);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--font-display);font-weight:800;font-size:1.35rem;letter-spacing:.04em}
.brand .sub{font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);margin-top:5px}
.nav-links{display:flex;align-items:center;gap:var(--space-6)}
.nav-links a{font-size:var(--text-sm);font-weight:500;color:var(--ink-soft);position:relative;padding-block:4px;transition:color var(--dur) var(--ease)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--accent);transition:width var(--dur) var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links .btn{padding:var(--space-2) var(--space-5)}
/* przyciski w nav: właściwy kolor (przebij .nav-links a) + bez podkreślenia */
.nav-links a.btn-accent{color:#fff}
.nav-links a.btn-ghost,.nav-links a.btn-light{color:var(--ink)}
.nav-links a.btn::after{display:none}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:var(--dur)}

/* ---------- HERO (split) ---------- */
.hero{position:relative;overflow:hidden;border-bottom:var(--hairline)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,60px);align-items:center;
  padding-block:clamp(36px,4.5vw,64px)}
.hero-copy .eyebrow{margin-bottom:var(--space-5)}
.hero-copy h1{margin-bottom:var(--space-5)}
.hero-copy .lead{margin-bottom:var(--space-7)}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4)}
.hero-art{position:relative;aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg)}
.hero-art img{width:100%;height:100%;object-fit:cover}
.hero-art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(18,24,28,.28))}
.hero-badge{position:absolute;left:var(--space-5);bottom:var(--space-5);z-index:2;
  background:rgba(252,252,251,.94);backdrop-filter:blur(4px);
  border-radius:var(--r-md);padding:var(--space-4) var(--space-5);box-shadow:var(--sh-md);max-width:78%}
.hero-badge strong{display:block;font-family:var(--font-display);font-size:1rem;letter-spacing:-.01em}
.hero-badge span{font-size:var(--text-sm);color:var(--muted)}

/* ---------- HERO duży / kinowy (strona główna) ---------- */
.hero-cine{position:relative;min-height:clamp(560px,82vh,840px);min-height:clamp(560px,82svh,840px);display:flex;align-items:center;overflow:hidden;border-bottom:var(--hairline)}
.hero-cine>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-cine::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(95deg,rgba(13,18,23,.86) 0%,rgba(13,18,23,.64) 32%,rgba(13,18,23,.24) 62%,rgba(13,18,23,.04) 100%)}
.hero-cine .wrap{position:relative;z-index:2;padding-block:var(--space-8)}
.hero-cine .hero-copy{max-width:660px}
.hero-cine .eyebrow{color:#fff;margin-bottom:var(--space-5)}
.hero-cine .eyebrow::before{background:#fff}
.hero-cine h1{color:#fff;margin-bottom:var(--space-5);font-size:clamp(2.9rem,2rem+4.4vw,5.2rem)}
.hero-cine .lead{color:rgba(255,255,255,.92);max-width:48ch;margin-bottom:var(--space-7)}
.hero-cine .hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4)}
@media(max-width:680px){
  .hero-cine{min-height:clamp(520px,76vh,640px);min-height:clamp(520px,76svh,640px);align-items:flex-end}
  .hero-cine::after{background:linear-gradient(0deg,rgba(13,18,23,.9) 6%,rgba(13,18,23,.45) 55%,rgba(13,18,23,.25) 100%)}
  .hero-cine .wrap{padding-bottom:var(--space-9)}
}

/* full-bleed hero variant (podstrony) */
.pagehead{position:relative;min-height:46vh;min-height:46svh;display:flex;align-items:flex-end;overflow:hidden;border-bottom:var(--hairline)}
.pagehead img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pagehead::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,24,28,.25),rgba(18,24,28,.62))}
.pagehead .wrap{position:relative;z-index:2;padding-block:var(--space-9);color:#fff}
.pagehead h1{color:#fff;max-width:18ch}
.pagehead .eyebrow{color:#fff}
.pagehead .eyebrow::before{background:#fff}
.pagehead p{color:rgba(255,255,255,.86);margin-top:var(--space-4);max-width:54ch}

/* ---------- STRIP (pasek skrótów / liczby) ---------- */
.strip{background:var(--dark);color:#fff}
.strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);padding-block:var(--space-8)}
.strip .item .k{font-family:var(--font-display);font-size:clamp(1.6rem,1.2rem+1.4vw,2.4rem);font-weight:800;letter-spacing:-.02em;color:#fff}
.strip .item .v{font-size:var(--text-sm);color:rgba(255,255,255,.66);margin-top:var(--space-2);line-height:1.45}
.strip .item{border-left:2px solid var(--accent);padding-left:var(--space-5)}

/* ---------- SECTION HEAD ---------- */
.head{max-width:48rem;margin-bottom:var(--space-8)}
.head.center{margin-inline:auto;text-align:center}
.head .eyebrow{margin-bottom:var(--space-4)}
.head h2{margin-bottom:var(--space-4)}
.head p{color:var(--muted);font-size:var(--text-lg);line-height:1.55}
.head.center p{margin-inline:auto}

/* ---------- INTRO SPLIT ---------- */
.split{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(28px,5vw,80px);align-items:center}
.split.rev{grid-template-columns:1.08fr .92fr}
.split.rev .split-art{order:-1}
.split-art{position:relative;aspect-ratio:5/4;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg)}
.split-art img{width:100%;height:100%;object-fit:cover}
.split-copy h2{margin-bottom:var(--space-5)}
.split-copy p+p{margin-top:var(--space-4)}
.split-copy .btn{margin-top:var(--space-6)}

/* ---------- SERVICES (zakres) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5)}
.svc{background:#fff;border:var(--hairline);border-radius:var(--r-md);padding:var(--space-7) var(--space-6);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
  position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;width:3px;height:0;background:var(--accent);transition:height var(--dur) var(--ease)}
.svc:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:transparent}
.svc:hover::before{height:100%}
.svc .ic{font-family:var(--font-display);font-size:.8rem;font-weight:700;letter-spacing:.12em;color:var(--accent);margin-bottom:var(--space-4)}
.svc h3{margin-bottom:var(--space-3);font-size:1.22rem}
.svc p{color:var(--muted);font-size:var(--text-base);line-height:1.6}

/* big detailed service rows */
.svc-row{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(20px,4vw,60px);align-items:center;padding-block:var(--space-8)}
.svc-row+.svc-row{border-top:var(--hairline)}
.svc-row.rev{grid-template-columns:1.2fr .8fr}
.svc-row.rev .svc-row-art{order:-1}
.svc-row-art{aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-md)}
.svc-row-art img{width:100%;height:100%;object-fit:cover}
.svc-row h3{font-size:1.5rem;margin-bottom:var(--space-4)}
.svc-row .num{font-family:var(--font-display);font-size:.85rem;font-weight:700;letter-spacing:.14em;color:var(--accent);display:block;margin-bottom:var(--space-3)}
.svc-row ul{list-style:none;margin-top:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}
.svc-row li{position:relative;padding-left:var(--space-5);color:var(--muted);font-size:var(--text-base)}
.svc-row li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:1px;background:var(--accent)}

/* ---------- GALLERY (realizacje) ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--space-4);grid-auto-rows:200px}
/* GALERIA MASONRY - pionowe zdjęcia (portrety beauty/wellness) bez przycinania: kolumny, height auto */
.gallery-masonry{column-count:3;column-gap:var(--space-4)}
@media(max-width:900px){.gallery-masonry{column-count:2}}
@media(max-width:560px){.gallery-masonry{column-count:1}}
.gallery-masonry .m-tile{break-inside:avoid;margin:0 0 var(--space-4);padding:0;position:relative;overflow:hidden;border-radius:var(--r-md);border:1px solid var(--line)}
.gallery-masonry .m-tile img{width:100%;height:auto;display:block}
.gallery-masonry .m-tile .cap{position:absolute;left:0;right:0;bottom:0;padding:var(--space-4);color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent);font-size:var(--text-sm)}
.tile{position:relative;overflow:hidden;border-radius:var(--r-md);box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.tile:hover{box-shadow:var(--sh-md)}
.tile:hover img{transform:scale(1.05)}
.tile .cap{position:absolute;left:0;right:0;bottom:0;padding:var(--space-5) var(--space-4) var(--space-4);
  background:linear-gradient(transparent,rgba(18,24,28,.78));color:#fff;
  font-size:var(--text-sm);font-weight:600;letter-spacing:.01em;
  opacity:0;transform:translateY(8px);transition:var(--dur) var(--ease)}
.tile:hover .cap{opacity:1;transform:translateY(0)}
.tile .cap small{display:block;font-weight:400;opacity:.78;letter-spacing:.04em;text-transform:uppercase;font-size:.66rem;margin-top:3px}
/* bento spans */
.t-wide{grid-column:span 6}
.t-tall{grid-column:span 6;grid-row:span 2}
.t-std{grid-column:span 6}
.t-third{grid-column:span 4}
.t-two3{grid-column:span 8}

/* ---------- TRUST / WIARYGODNOŚĆ ---------- */
.trust{background:var(--paper-2)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-5);margin-top:var(--space-7)}
.trust-card{background:#fff;border-radius:var(--r-md);padding:var(--space-7) var(--space-6);box-shadow:var(--sh-sm);border-top:3px solid var(--accent)}
.trust-card .big{font-family:var(--font-display);font-size:clamp(1.8rem,1.3rem+1.6vw,2.6rem);font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1}
.trust-card h3{font-size:1.12rem;margin:var(--space-3) 0 var(--space-2)}
.trust-card p{color:var(--muted);font-size:var(--text-base);line-height:1.55}

/* ---------- CTA band ---------- */
.cta{background:var(--dark);color:#fff;position:relative;overflow:hidden}
.cta .wrap{display:grid;grid-template-columns:1.4fr .6fr;gap:var(--space-7);align-items:center;position:relative;z-index:2}
.cta h2{color:#fff;max-width:20ch}
.cta p{color:rgba(255,255,255,.74);margin-top:var(--space-4)}
.cta-actions{display:flex;flex-direction:column;gap:var(--space-3);align-items:flex-start}
.cta::before{content:"";position:absolute;right:-80px;top:-80px;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,var(--accent-soft),transparent 70%)}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:start}
.info-list{display:flex;flex-direction:column;gap:var(--space-2)}
.info-row{display:flex;gap:var(--space-4);align-items:flex-start;padding-block:var(--space-4);border-bottom:var(--hairline)}
.info-row .ic{flex:none;width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  background:var(--accent-soft);color:var(--accent);font-size:1.05rem}
.info-row .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.info-row .val{font-weight:600;font-size:var(--text-base);margin-top:2px}
.info-row a.val:hover{color:var(--accent)}
.map{border:none;border-radius:var(--r-lg);box-shadow:var(--sh-md);width:100%;height:100%;min-height:380px;filter:grayscale(.2) contrast(1.02)}
.form{background:#fff;border:var(--hairline);border-radius:var(--r-lg);padding:clamp(24px,3vw,40px);box-shadow:var(--sh-sm)}
.form .fld{margin-bottom:var(--space-5)}
.form label{display:block;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2)}
.form input,.form textarea{width:100%;font-family:inherit;font-size:var(--text-base);color:var(--ink);
  padding:var(--space-4);border:var(--hairline);border-radius:var(--r-sm);background:var(--paper);transition:border-color var(--dur)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--accent);background:#fff}
.form textarea{resize:vertical;min-height:120px}
.form .note{font-size:var(--text-sm);color:var(--muted);margin-top:var(--space-3)}

/* ---------- FOOTER ---------- */
footer{background:var(--dark);color:#fff;padding-block:var(--space-9) var(--space-6)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--space-7);margin-bottom:var(--space-8)}
.foot-brand .name{font-family:var(--font-display);font-weight:800;font-size:1.4rem;letter-spacing:.04em}
.foot-brand p{color:rgba(255,255,255,.62);margin-top:var(--space-4);font-size:var(--text-base);max-width:38ch}
.foot-col h4{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:var(--space-4)}
.foot-col a,.foot-col p{display:block;color:rgba(255,255,255,.82);font-size:var(--text-base);margin-bottom:var(--space-3)}
.foot-col a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.12);padding-top:var(--space-5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);
  font-size:var(--text-sm);color:rgba(255,255,255,.55)}
.foot-bot a:hover{color:#fff}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:920px){
  .hero-grid,.split,.split.rev,.svc-row,.svc-row.rev,.cta .wrap,.contact-grid,.foot-grid{grid-template-columns:1fr}
  .split.rev .split-art,.svc-row.rev .svc-row-art{order:0}
  .hero-art{aspect-ratio:16/10;max-height:420px}
  .strip .wrap{grid-template-columns:repeat(2,1fr);gap:var(--space-7)}
  .gallery{grid-auto-rows:180px}
  .t-wide,.t-tall,.t-std,.t-third,.t-two3{grid-column:span 6}
  .t-tall{grid-row:span 1}
  .cta-actions{flex-direction:row;flex-wrap:wrap}
  .foot-grid{gap:var(--space-6)}
}
@media(max-width:680px){
  .nav-links{position:fixed;inset:72px 0 auto 0;background:var(--paper);flex-direction:column;align-items:stretch;
    gap:0;padding:var(--space-4) 6%;border-bottom:var(--hairline);box-shadow:var(--sh-md);
    transform:translateY(-120%);transition:transform var(--dur) var(--ease)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding-block:var(--space-4);border-bottom:var(--hairline)}
  .nav-links .btn{margin-top:var(--space-3);justify-content:center}
  .nav-toggle{display:flex}
  .strip .wrap{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(6,1fr)}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}

/* ============================================================
   PREMIUM LAYER - destylat deep-researchu branż (anty-AI, spokój).
   Zmienne (--accent/--ink/--paper/--line/--dark). Ruch ledwo
   zauważalny, krzywa cubic-bezier(.16,.84,.44,1); prefers-reduced-motion
   pokryte blanketem wyżej. Karty hairline zamiast cieni = #1 sygnał „nie-AI".
   ============================================================ */

/* więcej oddechu między sekcjami (liderzy: 110-130px) */
section{padding-block:clamp(64px,8vw,128px)}

/* 1) Aksamitny reveal - dłuższa, miękka krzywa zamiast „skoku" */
.reveal{transition:opacity .9s cubic-bezier(.16,.84,.44,1),transform .9s cubic-bezier(.16,.84,.44,1);will-change:opacity,transform}
/* stagger TYLKO w galerii (tam pozycja = porządek dzieci) */
.gallery .reveal:nth-child(2){transition-delay:.07s}
.gallery .reveal:nth-child(3){transition-delay:.14s}
.gallery .reveal:nth-child(4){transition-delay:.21s}
.gallery .reveal:nth-child(5){transition-delay:.28s}
.gallery .reveal:nth-child(6){transition-delay:.35s}

/* 2) Hero STATYCZNY na .hero-cine - Ken Burns CAŁKIEM WYŁĄCZONY 26.06 (3. zgłoszenie Szymona).
   GENEZA: animowanie scale na <img> hero z teksturami (cegły/framugi) re-samplinguje obraz
   klatka po klatce → na części ekranów drobne drganie/shimmer = „heroshot się trzęsie".
   translateY usunięto wcześniej, scale-only + will-change/GPU NIE wystarczyły do GWARANCJI gładkości.
   Krzysztof zażądał pewności („make sure, że błąd się nie pojawi") > efekt. Zero animacji = 0% drgania.
   Delikatny zoom zostaje TYLKO w pełnoekranowych hero gastro/studio (hg-bg/hs-bg - tło, inny
   mechanizm, chwalone, nigdy nie zgłaszane). NIE wracać do KB na .hero-cine bez realnego testu
   na sprzęcie klienta - to ryzyko regresji „trzęsienia”. */
/* BEZPIECZNY "wow" na hero = jednorazowy FADE-IN (opacity), nie zoom.
   opacity nie dotyka bitmapy → gładkie na KAŻDYM zdjęciu/ekranie/GPU, zero ryzyka migotania.
   Geometryczny ruch (scale/translate) na .hero-cine jest ZAKAZANY (bramka pilnuje). */
@keyframes heroFade{from{opacity:0}to{opacity:1}}
.hero-cine>img{transform:none;animation:heroFade 1.1s ease-out both}

/* 3) Akcentowy hairline pod nagłówkiem sekcji, który „rysuje się" przy wejściu */
.head h2{position:relative;padding-bottom:18px}
.head h2::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);transition:width 1s cubic-bezier(.16,.84,.44,1) .15s}
.head.center h2::after{left:50%;transform:translateX(-50%)}
.head.reveal.in h2::after,.head.center.reveal.in h2::after{width:54px}

/* 4) Karty HAIRLINE zamiast cieni/zaokrągleń (najmocniejszy anty-AI detal) */
.svc{background:transparent;border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:none}
.svc:hover{box-shadow:none;border-color:var(--accent);transform:translateY(-3px)}
.trust-card{background:transparent;box-shadow:none;border:1px solid var(--line);border-top:2px solid var(--accent);border-radius:var(--r-sm)}
.tile{box-shadow:none;border-radius:var(--r-sm)}
.tile:hover{box-shadow:none}

/* 5) Sticky-nav kondensuje się po przewinięciu (sygnał dopracowania) */
.nav{transition:box-shadow .4s ease,background .4s ease}
.nav.is-stuck{box-shadow:0 1px 0 var(--line),0 14px 30px -24px rgba(0,0,0,.45)}
.nav-inner{transition:height .35s var(--ease)}
.nav.is-stuck .nav-inner{height:70px}

/* 6) MANIFESTO - pełnoekranowy cytat-bohater (zastępuje generyczne „Dlaczego my") */
.manifesto{background:var(--paper-2);text-align:center}
.manifesto .wrap{max-width:60rem}
.manifesto p{font-family:var(--font-display);font-style:italic;font-size:clamp(1.6rem,1rem+2.4vw,2.8rem);line-height:1.32;color:var(--ink-soft);margin-inline:auto;max-width:26ch;position:relative;padding-top:var(--space-8)}
.manifesto p::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:54px;height:1px;background:var(--accent)}
.manifesto p span{color:var(--accent);font-style:italic}

/* 7) GATEWAYS - 3 duże bramy-zdjęcia (zamiast paska menu usług) */
.gateways{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.gateway{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:var(--r-sm);display:block}
.gateway img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .5s var(--ease)}
.gateway::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(18,24,28,.74))}
.gateway:hover img{transform:scale(1.05);filter:brightness(1.05)}
.gateway .g-ttl{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:var(--space-6) var(--space-5);color:#fff;font-family:var(--font-display);font-size:1.45rem;letter-spacing:-.01em;line-height:1.15}
.gateway .g-ttl small{display:block;font-family:var(--font-body);font-size:var(--text-sm);font-weight:400;opacity:.82;letter-spacing:.03em;margin-top:5px}
@media(max-width:760px){.gateways{grid-template-columns:1fr}.gateway{aspect-ratio:16/10}}

/* 8) LOGO klienta w nagłówku (gdy podane --logo) */
.brand-logo{height:64px;width:auto;max-width:300px;object-fit:contain;display:block;border-radius:10px;box-shadow:0 2px 10px rgba(2,21,71,.12)}
.nav.is-stuck .brand-logo{height:50px}
@media(max-width:680px){.brand-logo{height:32px}}

/* === rodzina: fachowcy === */
/* ============================================================
   RODZINA: FACHOWCY (hydraulik/elektryk/remont/brukarstwo/ogrodzenia)
   Doklejane NA WIERZCH base.css. Dziedziczy paletę/fonty skórki (trade/elektryk).
   Filozofia: telefon-bohater + zaufanie + „bezpłatna wycena". Spokój, nie krzyk.
   (count-up i podwójny iframe mapy świadomie pominięte - krytyka blueprintu.)
   ============================================================ */

/* --- PROCES - oś „jak pracujemy" (podpis rodziny, czego nie ma w meblach) --- */
.proces{background:var(--paper-2)}
.proces-line{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);position:relative;margin:0;padding:0}
.proces-line li{position:relative;padding-top:var(--space-7)}
.proces-line li::before{content:"";position:absolute;top:14px;left:0;right:0;height:1px;background:var(--line)}
.proces-line li:last-child::before{right:50%}
.proces-line li:first-child::before{left:50%}
.proces-line li::after{content:"";position:absolute;top:9px;left:calc(50% - 6px);width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--paper-2)}
.proces-line .pno{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--accent);letter-spacing:-.02em;display:block;margin-bottom:var(--space-3);text-align:center}
.proces-line h3{font-size:1.1rem;margin-bottom:var(--space-2);text-align:center}
.proces-line p{color:var(--muted);font-size:var(--text-sm);line-height:1.5;text-align:center;max-width:26ch;margin-inline:auto}
@media(max-width:820px){
  .proces-line{grid-template-columns:1fr;gap:0}
  .proces-line li{padding:var(--space-5) 0 var(--space-5) var(--space-7)}
  .proces-line li::before{left:5px;right:auto;top:0;bottom:0;width:1px;height:auto}
  .proces-line li:first-child::before,.proces-line li:last-child::before{left:5px;right:auto}
  .proces-line li::after{top:var(--space-6);left:0}
  .proces-line .pno,.proces-line h3,.proces-line p{text-align:left;margin-inline:0}
}

/* --- OBSZAR DZIAŁANIA - lokalność (chipy z REALNEGO miasta, bez drugiego iframe) --- */
.obszar .head{text-align:center;margin-inline:auto}
.obszar .head .eyebrow{justify-content:center}
.obszar-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-3);margin:0;padding:0;max-width:60rem;margin-inline:auto}
.obszar-list li{border:1px solid var(--line);border-radius:999px;padding:var(--space-2) var(--space-5);
  font-size:var(--text-sm);font-weight:600;color:var(--ink-soft);transition:border-color .24s var(--ease),color .24s var(--ease)}
.obszar-list li:hover{border-color:var(--accent);color:var(--accent)}
.obszar-list li.is-home{background:var(--accent);border-color:var(--accent);color:#fff}

/* --- STICKY-CALL - dolny pasek mobile (najważniejszy konwerter tej rodziny) --- */
.sticky-call{display:none}
@media(max-width:820px){
  .sticky-call{display:grid;grid-template-columns:1fr 1fr;gap:1px;position:fixed;left:0;right:0;bottom:0;z-index:90;
    background:var(--line);box-shadow:0 -6px 20px -10px rgba(0,0,0,.4)}
  .sticky-call a{padding:15px 8px;text-align:center;font-weight:700;font-size:.95rem;letter-spacing:.01em}
  .sc-call{background:var(--accent);color:#fff}
  .sc-quote{background:var(--paper);color:var(--ink)}
  body{padding-bottom:56px}
}

/* --- Blok „Awaria? Dzwoń” (opcjonalny, hydraulik/elektryk) --- */
.awaria{background:var(--dark);color:#fff}
.awaria .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-5);padding-block:var(--space-7)}
.awaria h3{color:#fff;font-size:clamp(1.3rem,1rem+1.2vw,1.8rem)}
.awaria p{color:rgba(255,255,255,.72);margin-top:var(--space-2)}
.awaria .btn-accent{white-space:nowrap}

/* === CERTYFIKATY / CZYM PRACUJEMY (gated: renderuje sie tylko gdy brief poda certy/marki/gwarancja) - mocny lever dla dekarzy === */
.auto-marki .marki-list{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(.8rem,2.5vw,1.6rem);list-style:none;margin:var(--space-7) 0 0;padding:0}
.auto-marki .marki-list li{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-weight:600;
  font-size:clamp(.82rem,1.5vw,1rem);color:var(--ink-soft);padding:.5rem 1rem;border:1px solid var(--line);border-radius:var(--r-sm)}
.marki-gwar{text-align:center;color:var(--muted);font-size:var(--text-sm);margin-top:var(--space-6)}

/* ============================================================
   FAZA 3 - OSOBNY UKŁAD FACHOWCY (research wf_e4ed63db + krytyka z policzonym WCAG). Doklejane na wierzch.
   Tożsamość: ZAUFANIE + DUŻY TELEFON + DOWÓD. Dwublok hero (zdjęcie | lity panel), bezpośrednio, solidnie.
   ============================================================ */

/* --- P0 KONTRAST: bursztyn jako TEKST na jasnym = 2.0 FAIL (policzone). Naprawy (bursztyn->ciemny tekst / ink). --- */
.btn-accent{color:#14171c}                                  /* bursztyn + ciemny tekst = 8.28 PASS */
.sticky-call .sc-call{color:#fff}                        /* sticky bursztyn + ciemny tekst */
.obszar-list li.is-home{background:var(--ink);border-color:var(--ink);color:#fff}  /* było bursztyn+biel 2.17 -> ink+biel 16.29 */
.proces-line .pno{color:var(--ink-soft)}                    /* numery procesu: było bursztyn 2.0 -> ink-soft (czytelne); kropka osi zostaje bursztyn (grafika) */

/* --- Ikona telefonu (uzywana w hero hf-phone-num; nav styluje silnik NAV NOBU) --- */
.ico-tel{vertical-align:-2px;margin-right:.3em}

/* === HERO FACHOWCY: dwublok (zdjęcie | lity panel ink). Zdjęcie = PIERWSZE dziecko (blur-guard + mobilny stack). STATYCZNE. === */
.hero-fach{display:grid;grid-template-columns:1fr minmax(0,46%);min-height:clamp(540px,76vh,740px);min-height:clamp(540px,76svh,740px)}
.hf-photo{width:100%;height:100%;object-fit:cover;display:block;background:var(--paper-2)}  /* img = PIERWSZE dziecko sekcji (blur-guard); EAGER, bez animacji (zero janku) */
.hf-panel{order:-1;background:var(--ink);color:#fff;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(2.2rem,5vw,4.5rem) clamp(1.6rem,4vw,3.6rem)}
.hf-kicker{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:clamp(.74rem,1.4vw,.9rem);color:var(--accent)}
.hf-title{color:#fff;font-family:var(--font-display);font-weight:800;line-height:1.05;letter-spacing:-.01em;
  font-size:clamp(1.9rem,1.4rem+2vw,3rem);margin:var(--space-3) 0 var(--space-5)}
.hf-phone{display:inline-flex;flex-direction:column;gap:.15rem;margin-bottom:var(--space-5);width:fit-content}
.hf-phone-lab{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.66)}
.hf-phone-num{font-family:var(--font-display);font-weight:800;color:#fff;font-variant-numeric:tabular-nums;white-space:nowrap;
  font-size:clamp(2rem,1.4rem+2.2vw,2.9rem);line-height:1;display:inline-flex;align-items:center}
.hf-phone-num .ico-tel{width:.7em;height:.7em;color:var(--accent);margin-right:.35em}   /* ikona bursztyn, cyfry białe */
.hf-phone:hover .hf-phone-num{color:var(--accent)}
.hf-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}
.hf-ghost{color:#fff;border-color:rgba(255,255,255,.45)}
.hf-trust{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.16);
  color:rgba(255,255,255,.82);font-weight:600;font-size:var(--text-sm);letter-spacing:.01em}
@media(max-width:820px){
  .hero-fach{grid-template-columns:1fr;min-height:0}
  .hf-photo{aspect-ratio:16/10}
  .hf-panel{order:0;padding-block:clamp(2rem,7vw,3rem)}     /* DOM-order: zdjęcie na górze, panel pod */
}

/* === PROMISE BAR: zawsze-obecna sygnatura usługowa (anty recon-collapse) === */
.fach-promise{background:var(--paper-2);border-bottom:var(--hairline);padding-block:0}
.fach-promise .wrap{padding-block:var(--space-4)}
.fp-row{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(.6rem,2.4vw,2rem)}
.fp-row li{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-size:clamp(.72rem,1.3vw,.85rem);color:var(--ink-soft);display:flex;align-items:center}
.fp-row li:not(:last-child)::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);margin-left:clamp(.6rem,2.4vw,2rem)}

/* === TRUST BAR (gated): jasne pasmo, cyfry INK (NIE bursztyn=2.0 FAIL), bursztyn jako kreska pod liczbą === */
.trust-bar{background:var(--paper);border-bottom:var(--hairline)}
.trust-bar .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(1rem,3vw,2.6rem);padding-block:var(--space-7)}
.tb-stats{display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,2.6rem)}
.tb-stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding-bottom:var(--space-2);border-bottom:3px solid var(--accent)}
.tb-num{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,3vw,2.8rem);line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}
.tb-lab{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-top:.3rem}
.tb-google{font-weight:700;color:var(--ink);font-size:var(--text-base);background:var(--paper-2);border:var(--hairline);border-radius:999px;padding:.5rem 1.1rem;font-variant-numeric:tabular-nums}
.tb-seal{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.85rem;
  color:var(--ink);border:1px solid var(--accent);border-radius:var(--r-sm);padding:.5rem 1rem}

/* === LISTA USŁUG (zamiast bram-nastrojowych): konkret "co + zakres + wycena" === */
.fach-uslugi .fu-list{list-style:none;margin:var(--space-8) 0 0;padding:0;display:flex;flex-direction:column}
.fu-row{display:grid;grid-template-columns:minmax(11rem,1fr) 2fr auto;gap:clamp(1rem,3vw,2.5rem);align-items:center;
  padding-block:var(--space-5);border-top:1px solid var(--line)}
.fu-row:last-child{border-bottom:1px solid var(--line)}
.fu-name{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--ink)}
.fu-desc{color:var(--muted);font-size:var(--text-sm);line-height:1.55}
.fu-cta{font-weight:700;font-size:var(--text-sm);color:var(--accent-d);white-space:nowrap}
.fu-cta:hover{color:var(--ink)}
@media(max-width:760px){.fu-row{grid-template-columns:1fr;gap:var(--space-2)}.fu-cta{justify-self:start}}

/* === OPINIE (gated): realne cytaty z reconu === */
.opinie-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));gap:var(--space-6);margin-top:var(--space-8)}
.op-card{margin:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}
.op-star{color:var(--accent-d);letter-spacing:.1em;font-size:.95rem}
.op-card blockquote{margin:0;color:var(--ink-soft);font-size:var(--text-base);line-height:1.6}
.op-autor{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:.95rem}

/* === SUWAK PRZED/PO (kopia z auto.css - CSS nie dziedziczy się między rodzinami; krytyka 5b) === */
.auto-ba .ba-slider{position:relative;--ba-pos:50%;max-width:62rem;margin:var(--space-8) auto 0;aspect-ratio:16/9;
  overflow:hidden;border-radius:var(--r-sm);border:1px solid var(--line);touch-action:none;user-select:none;cursor:ew-resize}
.ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ba-before-wrap{position:absolute;inset:0;clip-path:inset(0 calc(100% - var(--ba-pos)) 0 0)}
.ba-lab{position:absolute;top:var(--space-4);z-index:3;font-family:var(--font-display);text-transform:uppercase;
  letter-spacing:.1em;font-size:.7rem;color:#fff;background:rgba(10,12,15,.6);padding:.3rem .6rem;border-radius:2px}
.ba-lab-l{left:var(--space-4)}
.ba-lab-r{right:var(--space-4)}
.ba-handle{position:absolute;top:0;bottom:0;left:var(--ba-pos);width:2px;background:var(--accent);transform:translateX(-1px);z-index:4;pointer-events:none}
.ba-handle span{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;
  background:var(--accent);box-shadow:0 2px 12px rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center}
.ba-handle span::before,.ba-handle span::after{content:"";position:absolute;width:0;height:0;border-block:5px solid transparent}
.ba-handle span::before{left:9px;border-right:6px solid #14171c}
.ba-handle span::after{right:9px;border-left:6px solid #14171c}
.ba-podpis{text-align:center;color:var(--muted);font-size:var(--text-sm);margin-top:var(--space-5)}

/* === NAV NOBU (silnik): fachowcy === */
.nav{position:fixed;left:0;right:0;backdrop-filter:none;border-bottom:1px solid transparent;z-index:100;transition:transform .35s var(--ease),background .35s ease,box-shadow .35s ease}
.nav.nav-hidden{transform:translateY(-100%)}
.nav.is-stuck{background:transparent;box-shadow:none;border-bottom-color:transparent}
.nav.is-stuck .nav-inner{height:64px}
.nav .brand{flex-direction:row;align-items:baseline;gap:.6rem;line-height:1}
.nav .brand .name{font-family:var(--font-display);font-weight:600;font-size:1.5rem;text-transform:uppercase;letter-spacing:.14em}
.nav .brand .sub{margin-top:0;padding-left:.65rem;border-left:1px solid currentColor;font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase}
.nav .nav-links a{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding-block:6px}
.nav .nav-links a::after{height:1px}
.nav .nav-links a.btn-accent{font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;padding:.5rem 1.1rem;border-radius:4px;box-shadow:none}
.nav .nav-links a.btn-accent:hover{transform:none;box-shadow:none}
.nav .nav-links a.btn-accent{background:var(--accent);border:1px solid var(--accent);color:#14171c}
.nav .nav-links a.btn-accent:hover{background:var(--accent);border-color:var(--accent);color:#14171c;filter:brightness(1.07)}
.nav{background:transparent}
.nav::after{content:"";position:absolute;left:0;right:0;top:0;height:150px;z-index:-1;pointer-events:none;transition:opacity .35s ease;background:linear-gradient(180deg,rgba(8,6,4,.55) 0%,rgba(8,6,4,0) 100%)}
.nav.nav-solid::after{opacity:0}
.nav .brand .name{color:#f5f1ea}
.nav .brand .sub{color:rgba(245,241,234,.82)}
.nav .nav-links a:not(.btn-accent){color:rgba(245,241,234,.9)}
.nav .nav-links a:not(.btn-accent):hover,.nav .nav-links a.active:not(.btn-accent){color:#fff}
.nav .nav-links a:not(.btn-accent)::after{background:#fff}
.nav .nav-toggle span{background:#f5f1ea}
.nav.nav-solid{background:color-mix(in srgb,var(--paper) 94%,transparent);backdrop-filter:saturate(140%) blur(10px);border-bottom:var(--hairline)}
.nav.nav-solid .brand .name{color:var(--ink)}
.nav.nav-solid .brand .sub{color:var(--accent-d)}
.nav.nav-solid .nav-links a:not(.btn-accent){color:var(--ink-soft)}
.nav.nav-solid .nav-links a:not(.btn-accent):hover,.nav.nav-solid .nav-links a.active:not(.btn-accent){color:var(--ink)}
.nav.nav-solid .nav-links a:not(.btn-accent)::after{background:var(--accent-d)}
.nav.nav-solid .nav-toggle span{background:var(--ink)}
.nav.nav-solid.nav-hidden{background:transparent;box-shadow:none;border-bottom-color:transparent}
@media(min-width:681px){
.nav .nav-inner{position:relative;height:64px}
.nav .nav-links{flex:1;justify-content:center;gap:clamp(1rem,2.2vw,1.9rem);padding-right:12rem}
.nav .nav-links a.btn-accent{position:absolute;right:0;top:50%;transform:translateY(-50%);margin:0}
.nav:not(.nav-solid) .nav-links a.btn-accent{background:transparent;border-color:rgba(245,241,234,.55);color:#f5f1ea}
.nav:not(.nav-solid) .nav-links a.btn-accent:hover{background:var(--accent);border-color:var(--accent);color:#14171c;transform:translateY(-50%)}
}
@media(max-width:680px){
.nav .nav-links:not(.open){transform:translateY(-160%);visibility:hidden}
.nav .nav-links.open{visibility:visible}
.nav .brand .name{font-size:1.12rem;letter-spacing:.1em}
.nav .brand .sub{display:none}
.nav .brand{min-width:0;overflow:hidden}
.nav .nav-links{background:var(--paper)}
.nav .nav-links a:not(.btn-accent){color:var(--ink-soft)}
.nav .nav-links a:not(.btn-accent):hover,.nav .nav-links a.active:not(.btn-accent){color:var(--ink)}
}

.foot-legal a{text-decoration:underline;text-underline-offset:2px}

/* --- Formularz kontaktowy --- */
.contact-form .field{margin-bottom:var(--space-4)}
.contact-form label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.02em;color:var(--ink);margin-bottom:6px}
.contact-form input,.contact-form textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;border:1px solid rgba(2,21,71,.18);border-radius:10px;padding:.7rem .8rem;box-sizing:border-box}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.contact-form textarea{resize:vertical}
.hp-field{position:absolute !important;left:-9999px !important;width:1px;height:1px;opacity:0}
.form-rodo{font-size:.78rem;color:var(--muted);margin-top:var(--space-4);line-height:1.55}
.form-rodo a{color:var(--accent);text-decoration:underline}
/* --- Panel obszaru --- */
.area-panel{background:var(--espresso,#021547);color:#fff;border-radius:var(--r-lg,18px);padding:clamp(1.6rem,4vw,3rem)}
.area-panel .eyebrow{color:#9FB0C9}
.area-panel h2{color:#fff}
.area-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.area-chips span{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);border-radius:999px;padding:.42rem .9rem;font-size:.92rem}
/* --- Treść prawna --- */
.legal{max-width:800px;margin:0 auto}
.legal h2{margin:var(--space-7) 0 var(--space-3);font-size:1.4rem}
.legal h3{margin:var(--space-5) 0 var(--space-2);font-size:1.05rem}
.legal p,.legal li{color:var(--muted);line-height:1.7}
.legal ul{padding-left:1.2rem;margin:var(--space-3) 0}
.legal .ph{background:#fff6da;border:1px dashed #e0c060;border-radius:6px;padding:1px 6px;color:#6b5a1f;font-weight:600}
.legal .note{background:#fff6da;border:1px solid #f0d98a;border-radius:10px;padding:1rem 1.2rem;font-size:.9rem;color:#6b5a1f;margin:var(--space-5) 0}

/* feedback 27.06: czytelność + metaliczny akcent z logo */
.lead{color:var(--ink)}
.head p,.hero-copy p{font-size:var(--text-lg)}
body{line-height:1.6}

/* feedback 27.06: czytelność napisów na granatowym hero */
.hero-fach .eyebrow{color:#9FB0C9}
.hero-fach .eyebrow::before{background:#9FB0C9}
.hero-fach .hero-badge span{color:#AEB9CC}
.hero-fach .btn-accent{background:#3A5C8F;color:#fff}
.hero-fach .btn-accent:hover{background:#4a6ea6}

/* === FEEDBACK 27.06 v2: ciemny pasek nawigacji + lockup logo + większy tekst === */
:root{
  --text-sm:clamp(.94rem,.88rem+.2vw,1.08rem);
  --text-base:clamp(1.12rem,1.04rem+.45vw,1.32rem);
  --text-lg:clamp(1.22rem,1.1rem+.5vw,1.5rem);
}
.nav, .nav.nav-solid{background:#021547 !important;backdrop-filter:none !important;border-bottom:1px solid rgba(159,176,201,.16) !important}
.nav-inner{height:94px}
.nav.is-stuck .nav-inner{height:76px}
.nav-links a{color:#cfd8e8 !important}
.nav-links a:hover,.nav-links a.active{color:#fff !important}
.nav-links a::after{background:#9FB0C9}
.nav-toggle span{background:#fff}
.nav-links a.btn-accent{background:#3A5C8F;color:#fff !important;border-color:#3A5C8F}
.nav-links a.btn-ghost{color:#fff !important;border-color:rgba(255,255,255,.42)}
/* lockup logo (monogram + napis) */
.brand-lockup{display:flex;align-items:center;gap:14px}
.brand-lockup .brand-logo{height:64px;width:auto;border-radius:0 !important;box-shadow:none !important;filter:drop-shadow(0 1px 3px rgba(0,0,0,.35))}
.nav.is-stuck .brand-lockup .brand-logo{height:52px}
.brand-wm{display:flex;flex-direction:column;line-height:1.04}
.brand-wm small{font-family:var(--font-body);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:#9FB0C9}
.brand-wm b{font-family:var(--font-display);font-size:1.6rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:#fff;margin-top:3px}
@media(max-width:760px){
  .nav-links{background:#021547 !important;inset:94px 0 auto 0 !important}
  .nav-links a{color:#e7ecf5 !important}
  .brand-wm b{font-size:1.25rem}
  .brand-lockup .brand-logo{height:50px}
}
@media(max-width:430px){.brand-wm{display:none}}
/* większy, czytelny tekst */
body{font-size:var(--text-base);line-height:1.62}
.head p{font-size:var(--text-lg);color:var(--ink)}
.eyebrow{font-weight:700}

/* === FIX 27.06: nawigacja solidny granat, bez gradientu-cienia, lockup wyśrodkowany === */
.nav, .nav.nav-solid, .nav.is-stuck, .nav.nav-hidden{background:#021547 !important;backdrop-filter:none !important}
.nav::after{display:none !important}
.nav{border-bottom:1px solid rgba(159,176,201,.16) !important}
.nav .nav-inner{height:92px !important}
.nav.is-stuck .nav-inner{height:74px !important}
.nav .brand-lockup{flex-direction:row !important;align-items:center !important;gap:14px}
.nav .brand-lockup .brand-logo{height:58px}
.nav.is-stuck .brand-lockup .brand-logo{height:48px}
.nav .nav-links a:not(.btn-accent),.nav.nav-solid .nav-links a:not(.btn-accent){color:#cfd8e8 !important}
.nav .nav-links a:not(.btn-accent):hover,.nav .nav-links a.active:not(.btn-accent){color:#fff !important}
.nav .nav-toggle span,.nav.nav-solid .nav-toggle span{background:#fff !important}
.nav .nav-links a.btn-accent,.nav:not(.nav-solid) .nav-links a.btn-accent{background:transparent !important;border:1px solid rgba(255,255,255,.5) !important;color:#fff !important}
.nav .nav-links a.btn-accent:hover{background:#3A5C8F !important;border-color:#3A5C8F !important;color:#fff !important}

/* ===== AUDYT 27.06 - poprawki ===== */
.btn-accent{color:#fff !important}
.nav .nav-links a.btn-accent,.nav .nav-links a.btn-accent:hover{color:#fff !important}
.cta .eyebrow{color:#9FB0C9}
.cta .eyebrow::before{background:#9FB0C9}
.hero-fach .hf-kicker{color:#9FB0C9 !important}
.legal a{color:var(--accent);text-decoration:underline}
.pagehead::after{background:linear-gradient(180deg,rgba(18,24,28,.30),rgba(18,24,28,.78)) !important}
@media(min-width:821px){.nav.nav-hidden{transform:none !important}}
footer{border-top:1px solid rgba(159,176,201,.18)}
.skip{position:absolute;left:-9999px;top:auto;background:#021547;color:#fff;padding:10px 16px;border-radius:6px;z-index:300;font-weight:600}
.skip:focus{left:12px;top:12px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ===== AUDYT WIZUALNY 27.06 ===== */
/* przycisk-ghost na ciemnym panelu obszaru (był niewidoczny: granat na granacie) */
.area-panel .btn-ghost{color:#fff !important;border-color:rgba(255,255,255,.45) !important}
.area-panel .btn-ghost:hover{background:var(--accent) !important;border-color:var(--accent) !important;color:#fff !important}
/* zygzak wierszy usług - zdjęcie w parzystych po prawej */
@media(min-width:761px){.svc-row.rev .svc-row-art{order:2 !important}}
/* wąskie okno desktop (681-860): linki nie nachodzą na przycisk Zadzwoń */
@media(min-width:681px) and (max-width:860px){
  .nav .nav-links{gap:clamp(.5rem,1.2vw,1rem);padding-right:13.5rem}
  .nav .nav-links a:not(.btn-accent){font-size:.74rem;letter-spacing:.06em}
}

/* feedback: logo - świetlna poświata, by JB odcinało się od granatu */
.brand-lockup .brand-logo{filter:drop-shadow(0 0 5px rgba(175,198,235,.65)) drop-shadow(0 0 1px rgba(255,255,255,.5)) !important}
