/* ===========================
   SERWISCO — style.css (full)
   =========================== */

:root{
  --bg:#0b1020;
  --header-h: 96px;
  --white:#ffffff;
  --text:#0b1020;
  --muted:#6b7280;
  --brand:#19a44a;
  --brand-2:#0f8d3b;
  --card:#f7f9fb;
  --radius:16px;
  --shadow:0 10px 30px rgba(3,7,18,.08),0 2px 8px rgba(3,7,18,.04);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body {
  font-family: 'Urbanist', system-ui, sans-serif;
  font-weight: 400;
  color: var(--text);
  background: #fff;
  letter-spacing: 0.01em;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0}
.container{max-width:1120px;margin-inline:auto;padding:0 20px}
.green{color:var(--brand)}
/* === HEADINGS === */
h1, h2, h3, h4 {
  font-family: 'Exo 2', 'Urbanist', sans-serif;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: #0b1020;
  text-transform: none; /* zostawia oryginalny zapis */
}

h1 {
  font-weight: 800;
  line-height: 1.05;
}

h2 {
  font-weight: 700;
  line-height: 1.15;
}

h3, h4 {
  font-weight: 600;
  line-height: 1.2;
}

/* ================= NAV ================= */
.nav{
  position:sticky; top:0; z-index:50;
  background:#fff; border-bottom:1px solid #eef2f6;
  backdrop-filter:saturate(140%) blur(6px);
}
.nav.scrolled{ box-shadow:0 8px 30px rgba(2,6,23,.06); border-bottom-color:transparent }
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{
  height:72px;    /* było 56px — powiększamy o ok. 30% */
  width:auto;
  object-fit:contain;
}
@media (max-width:640px){
  .brand img{
    height:58px;  /* dopasowane do mniejszych ekranów */
  }
}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-weight:600;color:#0b1020;opacity:.9}
.nav-links a:hover{opacity:1}
.cta{
  background:var(--brand); color:#fff; font-weight:700;
  padding:10px 16px; border-radius:999px; box-shadow:0 8px 16px rgba(25,164,74,.25)
}
.burger{display:none;background:transparent;border:0;font-size:22px;cursor:pointer}

/* Mobile nav menu */
@media (max-width:920px){
  .nav-links{ display:none; }
  .burger{ display:block; }
  .nav-inner{ position: relative; } /* kotwica dla panelu */
  .nav.open .nav-links{
    position: absolute;
    top: calc(100% + 10px);  /* ZAWSZE tuż pod headerem */
    left: 0;
    right: 0;
    margin: 0 16px;
    background:#fff; border:1px solid #e5e7eb; border-radius:14px;
    box-shadow:var(--shadow);
    display:flex; flex-direction:column; padding:14px; gap:6px;
  }
  .nav.open .nav-links a{ padding:10px 12px; border-radius:10px; }
  .nav.open .nav-links a:hover{ background:#f3f4f6; }
}

/* ================= HERO ================= */
.hero{position:relative; overflow:hidden; padding:72px 0 28px}
.hero::before{
  content:""; position:absolute; inset:auto -15% -55% -15%; height:55%;
  background:radial-gradient(520px 520px at 50% 20%, rgba(25,164,74,.10), transparent 70%);
  pointer-events:none;
}
.kpis{display:flex;gap:22px;justify-content:center;color:#111827}
.kpi{display:flex;align-items:center;gap:8px;color:#3b4453;font-weight:600}
.dot{height:8px;width:8px;border-radius:999px;background:var(--brand)}
.hero h1{font-size:clamp(40px,5.2vw,80px);line-height:1.02;letter-spacing:-.03em;margin:12px 0}
.hero p{color:#5b6472;font-size:18px;max-width:760px;margin:0 auto 26px;text-align:center}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:13px 20px; border-radius:14px; font-weight:700; line-height:1;
  text-align:center;
  border:1px solid #e5e7eb; background:#fff; transition:.18s ease
}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 12px 28px rgba(25,164,74,.22)}
.btn.primary:hover{background:var(--brand-2);transform:translateY(-1px)}
.btn.outline{background:#fff;border-color:#e5e7eb;color:#0b1020}
.btn.full{width:100%;justify-content:center}

/* =============== VIDEO STRIP =============== */
.media-strip{padding:10px 0 0}
.videobox{
  position:relative; overflow:hidden; border-radius:18px;
  border:1px solid #e9eef4; background:#000;
  box-shadow:0 12px 26px rgba(2,6,23,.06), 0 2px 8px rgba(2,6,23,.04);
}
.video{display:block;width:100%;height:clamp(220px,42vw,520px);object-fit:cover}
.video-caption{
  position:absolute; left:16px; bottom:14px; font-size:14px;
  color:#e5e7eb; background:rgba(15,20,39,.72);
  padding:10px 14px; border-radius:12px; backdrop-filter:blur(6px) saturate(130%)
}

/* =============== GENERIC SECTIONS =============== */
.section{padding:64px 0}
.section h2{font-size:clamp(28px,3vw,54px);font-weight:900;line-height:1.1;margin-bottom:10px}
.lead{color:#64748b;margin-bottom:28px}

/* =============== SERVICES / CARDS =============== */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{
  background:#fff; border:1px solid #e9eef4; border-radius:var(--radius);
  padding:22px; box-shadow:0 10px 24px rgba(2,6,23,.05),0 2px 6px rgba(2,6,23,.04);
  transition:transform .18s ease, box-shadow .18s ease
}
.card:hover{transform:translateY(-2px); box-shadow:0 16px 36px rgba(2,6,23,.08),0 3px 10px rgba(2,6,23,.05)}
.card h3{font-size:21px;margin:0 0 6px}
.card p{color:#616a78;margin:0}
.hint{color:#5b6472;margin-top:10px;text-align:center}

/* =============== WHY & REACH =============== */
.why{background:#f8fbf9}
.facts{grid-template-columns:repeat(3,1fr)}
.reach .stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:14px 0 18px
}
.reach .s{border:1px solid #e9eef4;border-radius:14px;padding:16px;text-align:center;background:#fff}
.reach .n{display:block;font-weight:900;font-size:26px;color:#0b1020}
/* =============== CONTACT =============== */
.contact{background:#0e1323;color:#e5e7eb}
.contact h2{color:#fff}
.contact-grid .lead{color:#b8c1d1}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:8px}
.panel{
  border:1px solid rgba(255,255,255,.06); border-radius:16px; padding:18px;
  background:rgba(255,255,255,.03); backdrop-filter:saturate(130%) blur(2px)
}
.contact-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.quick-actions{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 14px}
.pill{
  display:inline-flex;align-items:center;gap:10px;border-radius:12px;padding:12px 16px;
  background:#10b981;color:#052e1b;font-weight:800;box-shadow:0 10px 20px rgba(16,185,129,.18)
}
.pill.sec{background:#fff;color:#0b1020;border:1px solid #e5e7eb}
/* Kontakt: biały nagłówek w lewym panelu */
.contact .grid-2 > :first-child h3{
  color:#fff;
}
/* form */
.form{margin-top:6px}
.field{margin-bottom:12px}
.field.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:block;font-size:12px;letter-spacing:.02em;color:#9aa3b2;margin-bottom:6px}
input,textarea{
  width:100%; padding:12px 14px; border-radius:12px;
  border:1px solid #2b3244; background:#12182a; color:#e5e7eb;
  outline:none; transition:border-color .15s ease, box-shadow .15s ease
}
input::placeholder,textarea::placeholder{color:#7b8394}
input:focus,textarea:focus{border-color:#3b82f6; box-shadow:0 0 0 4px rgba(59,130,246,.15)}
.form-note{
  margin-top:8px;
  font-size:14px;
  min-height:1.2em;   /* rezerwuje miejsce na komunikat, mniej skakania layoutu */
  opacity:.9;
}
.hours{opacity:.85;margin-top:12px}

/* =============== FOOTER =============== */
footer{background:#0e1323;color:#cbd5e1}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px;padding:32px 0 22px}
.footer-logo{
  height:100px;        /* było 84px */
  border:10px solid #fff;
  border-radius:14px;
  padding:12px 22px;
  object-fit:contain;
  background:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.1);
}

@media (max-width:640px){
  .footer-logo{
    height:78px;       /* było 68px */
  }
}

h4{color:#22c55e;margin:0 0 6px}
.copy{border-top:1px solid rgba(255,255,255,.08);padding:12px 0 24px;text-align:center;opacity:.8}

/* =============== REVEAL ANIMATIONS =============== */
.reveal{opacity:0; transform:translateY(14px); will-change:opacity,transform}
.reveal.show{opacity:1; transform:none; transition:opacity .55s ease, transform .55s ease}
.delay-1{transition-delay:.08s}
.delay-2{transition-delay:.16s}
.delay-3{transition-delay:.24s}
.delay-4{transition-delay:.32s}

/* =============== RESPONSIVE =============== */
@media (max-width:980px){
  .gallery-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .grid{grid-template-columns:1fr 1fr}
  .facts{grid-template-columns:1fr}
  .why{padding-top:56px}
  .grid-2{grid-template-columns:1fr}
}
@media (max-width:620px){
  .grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .video{height:clamp(220px,52vw,380px)}
}
/* Contact right extra air v2 */
.contact .grid-2 > :nth-child(2).panel{ padding:34px 30px 34px }
.contact .grid-2 > :nth-child(2) .quick-actions{ margin:20px 0 22px; gap:16px }
.contact .grid-2 > :nth-child(2) .field{ margin-bottom:18px }
.contact .grid-2 > :nth-child(2) .form .btn{ margin-top:10px }
.contact .grid-2 > :nth-child(2) .hours{ margin-top:22px }


/* === Centering rules === */
.hero .container{ text-align:center }
.section > .container > h2,
.section > .container > p.lead{ text-align:center; margin-left:auto; margin-right:auto }
.hint{ display:inline-block; margin:16px auto 0; text-align:center }
.reach .card{ text-align:center }
.reach .card .btn{ margin:0 auto }
.gallery .container{ text-align:center }

/* Contact map embed */
.map-embed{ margin-top:16px; border-radius:18px; overflow:hidden; box-shadow:0 12px 24px rgba(2,6,23,.06), 0 2px 8px rgba(2,6,23,.04) }
.map-embed iframe{ display:block; width:100%; height:320px }

/* Contact right extra air v3 */
.contact .grid-2 > :nth-child(2).panel{ padding:38px 34px 38px }
.contact .grid-2 > :nth-child(2) .quick-actions{ margin:24px 0 24px; gap:18px }
.contact .grid-2 > :nth-child(2) .field{ margin-bottom:20px }
.contact .grid-2 > :nth-child(2) .form .btn{ margin-top:12px }
.contact .grid-2 > :nth-child(2) .hours{ margin-top:26px }


/* Bigger, responsive gallery */
.gallery .container{ max-width:1400px }
.gallery-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(360px,1fr)); gap:40px }
.gl-item{ position:relative; border-radius:24px; overflow:hidden; background:#fff; box-shadow:0 30px 60px rgba(2,6,23,.06), 0 5px 14px rgba(2,6,23,.04) }
.gl-item img{ width:100%; height:100%; object-fit:cover }
.gl-item figcaption{ position:absolute; left:16px; right:16px; bottom:16px; background:rgba(255,255,255,.9); padding:10px 14px; border-radius:14px; font-weight:800; text-align:center }

.gallery .container{ text-align:center }

.section .hint{ display:inline-block; margin:20px auto 0; text-align:center }


/* Services grid: 3-up, bigger cards */
#services .grid{ grid-template-columns:repeat(3, 1fr); gap:26px }
#services .card{ padding:24px 22px; border-radius:22px }
#services .card h3{ font-size:22px }
#services .card p.sub{ color:#475569; margin-top:6px }
@media (max-width:900px){ #services .grid{ grid-template-columns:1fr 1fr } }
@media (max-width:620px){ #services .grid{ grid-template-columns:1fr } }

/* WHY section — media layout (distinct look) */
.section.why{ background:#f4fbf7 }
.why .why-media{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:8px }
.why .f{ display:flex; gap:14px; align-items:flex-start; background:#fff; border:1px solid #e9eef4; border-radius:22px; padding:20px 18px; box-shadow:0 18px 40px rgba(2,6,23,.06), 0 3px 10px rgba(2,6,23,.04) }
.why .ico{ flex:0 0 44px; height:44px; display:grid; place-items:center; border-radius:12px; background:#e8f7ee; font-size:22px }
.why h3{ margin:0 0 6px; font-size:20px }
@media (max-width:900px){ .why .why-media{ grid-template-columns:1fr 1fr } }
@media (max-width:620px){ .why .why-media{ grid-template-columns:1fr } }


/* ===== SERVICES: Large visual tiles ===== */
#services .container{ text-align:center }
.services-tiles{
  display:grid; grid-template-columns:repeat(3,1fr); gap:36px; margin-top:16px
}
.services-tiles .tile{
  position:relative; display:block; border-radius:28px; overflow:hidden;
  box-shadow:0 40px 80px rgba(2,6,23,.08), 0 8px 20px rgba(2,6,23,.05);
  transform:translateZ(0);  /* create new stacking context for smoother hover */
}
.services-tiles .tile img{
  width:100%; height:100%; aspect-ratio: 16/9; object-fit:cover; display:block;
  transition:transform .35s ease;
}
.services-tiles .tile .cap{
  position:absolute; left:18px; right:18px; bottom:18px;
  background:rgba(255,255,255,.96); border-radius:18px; padding:14px 16px;
  box-shadow:0 16px 34px rgba(2,6,23,.10), 0 4px 10px rgba(2,6,23,.06);
  text-align:left;
}
.services-tiles .tile .cap h3{ margin:0 0 6px; font-size:22px }
.services-tiles .tile .cap p{ margin:0; color:#475569 }
.services-tiles .tile:hover img{ transform:scale(1.04) }

/* Responsive */
@media (max-width:1100px){ .services-tiles{ grid-template-columns:1fr 1fr } }
@media (max-width:640px){ .services-tiles{ grid-template-columns:1fr } }

/* WHY icons as images */
.why .ico{ flex:0 0 52px; height:52px; display:grid; place-items:center; border-radius:14px; background:#e8f7ee }
.why .ico img{ width:30px; height:30px; object-fit:contain; display:block }

/* Gallery 2x2 layout */
.gallery .container{ max-width:1500px; text-align:center }
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(520px, 1fr));
  gap:52px;
  justify-content:center;
}
@media (max-width:1200px){
  .gallery-grid{ grid-template-columns:1fr 1fr; gap:36px }
}
@media (max-width:700px){
  .gallery-grid{ grid-template-columns:1fr; gap:26px }
}
.gl-item{ position:relative; border-radius:28px; overflow:hidden; background:#fff;
  box-shadow:0 36px 80px rgba(2,6,23,.08), 0 8px 20px rgba(2,6,23,.05) }
.gl-item img{ width:100%; aspect-ratio: 4/3; object-fit:cover; display:block }
.gl-item figcaption{ position:absolute; left:18px; right:18px; bottom:18px; background:rgba(255,255,255,.95);
  padding:14px 18px; border-radius:18px; font-weight:800; font-size:20px; text-align:center }


/* === MOBILE POLISH (final) === */
@media (max-width:640px){
  .section{ padding:56px 0 }
  .container{ padding:0 16px }
  .hero p{ margin-bottom:18px }
  .cta-row{ gap:10px }
  .services-tiles{ grid-template-columns:1fr; gap:18px }
  .why .why-media{ grid-template-columns:1fr; gap:16px }
  .grid-2{ grid-template-columns:1fr; gap:16px }
  .contact .grid-2 > :nth-child(2).panel{ padding:22px 18px }
  .gallery-grid{ grid-template-columns:1fr; gap:22px }
}
/* === MOBILE HERO CTA CENTER/NARROW === */
@media (max-width:640px){
  .cta-row{ flex-direction:column; align-items:center; gap:12px }
  .cta-row .btn{ width:min(360px, 88vw); }
}


/* === MOBILE NAV TOP SPACING === */
@media (max-width:640px){
  .nav{ padding-top:10px; padding-bottom:6px }
  .nav .brand img{ max-height:44px } /* było 34px */
}


/* === CONTACT: swap columns on mobile (Quick contact first) === */
@media (max-width:640px){
  .contact .grid-2{ display:flex; flex-direction:column; gap:18px }
  .contact .grid-2 > :nth-child(2){ order:-1 } /* 'Szybki kontakt' panel goes first */
}
/* === CONTACT MOBILE: hide duplicate contact details, keep map === */
@media (max-width:640px){
  /* Left panel (original DOM first-child) */
  .contact .grid-2 > :first-child h3{ display:none }
  .contact .grid-2 > :first-child .contact-list{ display:none }
  .contact .grid-2 > :first-child .map-embed{ margin-top:0 }
  .contact .grid-2 > :first-child.panel{ padding-top:12px }
}


/* === HERO MOBILE — final spacing (pod większe logo/header) === */
@media (max-width:640px){
  .hero{
    /* bezpieczny top względem sticky headera + notcha */
    padding-top: calc(88px + env(safe-area-inset-top));
    padding-bottom: 28px;
  }
  .hero .kpis{
    margin: 8px 0 14px !important;
  }
  .hero h1{
    margin: 6px 0 10px !important;
  }
  .hero p, .hero .lead{
    margin: 10px auto 18px !important;
    max-width: 32ch;          /* czytelniejsza długość wiersza */
    line-height: 1.5;
  }
  .cta-row{
    margin-top: 10px;
    gap: 12px;
  }
}
/* REACH stats — mobile: jedna pod drugą */
@media (max-width: 640px){
  .reach .stats{
    grid-template-columns: 1fr;   /* 1 kolumna */
    gap: 12px;
  }
  .reach .s{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 14px;
    min-height: 72px;             /* równa wysokość kart */
    white-space: normal;           /* pozwól zawijać tekst */
    word-break: break-word;        /* zabezpieczenie przed wyciekaniem */
  }
  .reach .n{
    font-size: 24px;               /* trochę mniejsze liczby na tel. */
    line-height: 1.1;
  }
}
/* === CONTACT — no overflow, 1 kolumna wcześniej === */
@media (max-width: 900px){
  .contact .grid-2{
    display: flex;                 /* zamiast grid — stabilniej dla zawijania */
    flex-direction: column;
    gap: 18px;
  }
  /* Szybki kontakt najpierw */
  .contact .grid-2 > :nth-child(2){ order:-1 }
}

/* pozwól dzieciom panelu się zawijać i nie wypychać layoutu */
.contact .panel{ min-width: 0 }     /* kluczowe w flex/grid! */
.contact .panel, 
.contact .panel *{
  word-break: break-word;           /* dzieli długie słowa/liczby */
  overflow-wrap: anywhere;          /* awaryjne łamanie np. emaili */
}

/* Pola formularza: na węższych ekranach 1 kolumna, żeby nic nie nachodziło */
@media (max-width: 900px){
  .field.two{ 
    grid-template-columns: 1fr; 
    gap: 12px;
  }
}

/* Drobne urealnienie rozmiarów na mobile/tablet */
@media (max-width: 640px){
  .contact h2{ font-size: clamp(22px, 6vw, 28px) }
  .contact .panel{ padding: 20px 16px }
}
/* === FOOTER: anty-wylewanie + responsywna siatka === */
.footer-grid > *{
  min-width: 0;                    /* klucz w grid/flex – pozwala się zawijać */
}
footer .footer-grid,
footer .footer-grid *{
  white-space: normal;             /* żadnego wymuszania jednej linii */
  overflow-wrap: anywhere;         /* łamie e-maile/ciągi cyfr w razie potrzeby */
  word-break: break-word;          /* dodatkowe zabezpieczenie */
}

/* Siatka: 3→2→1 kolumna, żeby nic się nie ściskało */
@media (max-width: 900px){
  .footer-grid{ grid-template-columns: 1fr 1fr; gap: 18px; }
}
@media (max-width: 640px){
  .footer-grid{ grid-template-columns: 1fr; gap: 14px; }
}

/* Delikatne dopasowanie typografii w stopce na mobile */
@media (max-width: 640px){
  footer h4{ font-size: 16px; margin-bottom: 4px; }
  footer p, footer li, footer address{ font-size: 15px; line-height: 1.45; }
}
.footer-grid > *{ min-width:0; }
footer .footer-grid, footer .footer-grid *{
  white-space:normal; overflow-wrap:anywhere; word-break:break-word;
}
/* === HERO: ukryj KPI na mobile === */
@media (max-width:640px){
  .hero .kpis{ display:none !important; }
}
/* === CONTACT: biały tekst w panelu "Szybki kontakt" === */
.contact .panel.reveal.delay-1 {
  color: #ffffff;
}

.contact .panel.reveal.delay-1 h3 {
  color: #ffffff;
}
/* Plakietka: białe tło + biała „ramka” wokół logo */
.footer-logo{
  height:84px;               /* większe logo */
  width:auto;
  display:block;
  background:#fff;           /* białe tło */
  border:10px solid #fff;    /* biała ramka */
  border-radius:14px;        /* lekko zaokrąglone rogi */
  padding:10px 18px;         /* oddech wewnątrz */
  object-fit:contain;
  box-shadow:0 10px 24px rgba(0,0,0,.10); /* separacja od ciemnego footera */
}
/* === FINAL OVERRIDE: większe logo w headerze i footerze (mobile + desktop) === */

/* HEADER */
.nav .brand img {
  height: 80px !important;   /* desktop */
  width: auto !important;
}

@media (max-width:640px){
  .nav .brand img {
    height: 68px !important;  /* mobile */
  }
}

/* FOOTER */
.footer-logo {
  height: 110px !important;   /* desktop */
  padding: 14px 24px !important;
  border: 10px solid #fff !important;
  background: #fff !important;
}

@media (max-width:640px){
  .footer-logo {
    height: 90px !important;   /* mobile */
    border-width: 10px !important;
    padding: 12px 20px !important;
  }
}
/* === SPACING OPTIMIZATION (2025-10 tuning) === */

/* Header — więcej powietrza pod logo */
.nav { padding-top: 14px; padding-bottom: 10px; }

/* Hero — lepszy rytm pionowy */
.hero {
  padding-top: 96px; /* było 72px */
  padding-bottom: 48px; /* było 28px */
}
.hero h1 {
  margin-bottom: 18px; /* było 12px */
}
.hero p {
  margin-bottom: 32px; /* więcej oddechu przed CTA */
}

/* Sections — wizualny rytm */
.section {
  padding: 80px 0; /* było 64px — lekko większe oddechy */
}
.section h2 {
  margin-bottom: 18px;
}
.section .lead {
  margin-bottom: 36px;
}

/* Cards (Services) — równy oddech na dole */
.card {
  padding: 26px 22px; /* +4px pionowo */
}

/* Contact — więcej światła między panelami i elementami */
.contact .grid-2 {
  gap: 28px; /* było 20px */
}
.contact .panel {
  padding: 28px 22px; /* było 18px */
}
.contact .quick-actions {
  margin: 14px 0 20px; /* większy bufor */
}

/* Footer — wizualny balans z dużym logo */
footer {
  padding-top: 48px;
  padding-bottom: 36px;
}
.footer-grid {
  gap: 28px;
}
.copy {
  padding-top: 18px; /* nieco większa przestrzeń nad linią */
}
@media (max-width:640px) {
  .hero {
    padding-top: calc(96px + env(safe-area-inset-top));
    padding-bottom: 42px;
  }
  .section {
    padding: 64px 0;
  }
  .contact .grid-2 {
    gap: 22px;
  }
  footer {
    padding-top: 38px;
    padding-bottom: 28px;
  }
}
/* === FIX: mniejszy odstęp między Galerią a sekcją Działamy w całej Polsce === */
.gallery {
  padding-bottom: 32px !important; /* było 64px, skracamy dolny margines */
}

.reach {
  padding-top: 32px !important; /* było 64px */
}

@media (max-width:640px){
  .gallery {
    padding-bottom: 24px !important;
  }
  .reach {
    padding-top: 28px !important;
  }
}
.cookie-consent{
  position:fixed; left:0; right:0; bottom:0;
  z-index:120;
  padding: 0 12px calc(10px + env(safe-area-inset-bottom));
  pointer-events:auto;
}
.cookie-consent .bar{
  max-width:1100px; margin:0 auto 10px; border-radius:12px;
  display:flex; gap:12px; align-items:center; justify-content:space-between;
  background:#0b1020; color:#e5e7eb; padding:12px 16px;
  box-shadow:0 10px 28px rgba(2,6,23,.24);
}
.cookie-consent .actions .btn{ min-height:44px; }
@media (max-width:640px){
  .cookie-consent .bar{ border-radius:10px; padding:12px 14px; }
  .cookie-consent .actions{ width:100%; }
  .cookie-consent .actions .btn{ width:100%; justify-content:center; }
}
/* płynne zjechanie paska po akceptacji */
.cookie-consent { transform: translateY(0); transition: transform .3s ease; }
.cookie-consent.hide { transform: translateY(110%); }
@media (prefers-reduced-motion: reduce){
  .cookie-consent { transition: none; }
}
.cookie-consent .actions .btn:focus-visible{
  outline: 2px solid #22c55e; outline-offset: 2px;
}
