/* =============================================================================
   Grupa Pomocni — arkusz stylów
   -----------------------------------------------------------------------------
   Strona wizytówka (one-page). Czysty CSS, bez frameworków i JavaScriptu.
   Układ oparty na Flexbox + CSS Grid. Menu mobilne działa wyłącznie na CSS
   (technika z ukrytym checkboxem — patrz sekcja "NAGŁÓWEK / NAWIGACJA").

   SPIS TREŚCI
     1. Zmienne motywu (design tokens)
     2. Reset i elementy bazowe
     3. Klasy pomocnicze (kontener, etykiety, przyciski)
     4. Nagłówek i nawigacja (+ menu mobilne)
     5. Hero
     6. Sekcja: Nasze serwisy (karty)
     7. Sekcja: Dlaczego my
     8. Stopka
     9. RWD — punkty łamania (1000 / 760 / 520 px)
   ========================================================================== */


/* 1. ZMIENNE MOTYWU ========================================================= */
/* Wszystkie kolory i odcienie w jednym miejscu — zmiana tu przebudowuje całość. */
:root{
  --bg:    #FFFFFF;   /* główne tło stron */
  --soft:  #FAF7F2;   /* delikatne tło (hover w menu) */
  --alt:   #F3EEE4;   /* tło sekcji hero i "Dlaczego my" */
  --ink:   #1B1A17;   /* główny kolor tekstu i ciemnej stopki */
  --muted: #6B6660;   /* tekst drugorzędny / opisy */
  --line:  #ECE7DF;   /* linie, obramowania, separatory */
  --clay:  #B5654A;   /* kolor akcentu (etykiety "eyebrow", wyróżnienia) */
}


/* 2. RESET I ELEMENTY BAZOWE =============================================== */
*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }            /* płynne przewijanie do kotwic (#serwisy itd.) */

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Plus Jakarta Sans', system-ui, sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

a{ color:inherit; }
img{ max-width:100%; }

/* Zerujemy domyślny margines akapitów — wszystkie odstępy ustawiają klasy niżej.
   Bez tego przeglądarka dodaje ~16px nad/pod każdym <p> i psuje odstępy w kartach. */
p{ margin:0; }


/* 3. KLASY POMOCNICZE ====================================================== */

/* Centralny kontener o stałej maksymalnej szerokości. */
.wrap{
  max-width:1120px;
  margin:0 auto;
  padding:0 60px;
}

/* Mała etykieta nad nagłówkami sekcji (wersaliki, rozstrzelone litery). */
.eyebrow{
  font-size:12px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--clay);
}

/* Odsuwa kotwicę od górnej krawędzi przy przewijaniu (żeby nie chowała się pod treścią). */
section[id]{ scroll-margin-top:24px; }

/* Treść widoczna tylko dla czytników ekranu i robotów (np. ukryte nagłówki <h3>).
   Element jest w kodzie (ważne dla SEO/dostępności), ale niewidoczny na ekranie. */
.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;
}

/* Przyciski (bazowy + warianty). */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  font-size:14.5px;
  border-radius:11px;
  padding:12px 22px;
  border:1.5px solid transparent;
  cursor:pointer;
  text-decoration:none;
  white-space:nowrap;
  transition:background .15s, color .15s, border-color .15s;
}
.btn-solid{ background:var(--ink); color:#fff; }
.btn-solid:hover{ background:#3a372f; }
.btn-sm{ padding:9px 16px; font-size:13.5px; border-radius:9px; }   /* mniejszy wariant */


/* 4. NAGŁÓWEK I NAWIGACJA ================================================== */

.hdr{
  position:relative;            /* kontekst pozycjonowania dla rozwijanego menu mobilnego */
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  max-width:1120px;
  margin:0 auto;
  padding:24px 60px;
}

/* Logo = znak (4 kolorowe kwadraty) + nazwa. */
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  font-size:19px;
  letter-spacing:-0.02em;
  color:var(--ink);
  white-space:nowrap;
  flex:0 0 auto;
  text-decoration:none;
}
.logo .mark{                    /* siatka 2x2 na cztery kwadraciki marki */
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2.5px;
  width:24px; height:24px;
  flex:0 0 auto;
}
.logo .mark i{ border-radius:3px; display:block; }

/* Nawigacja desktop. */
.nav{ display:flex; align-items:center; gap:32px; }
.nav a{ color:var(--muted); text-decoration:none; font-size:14.5px; font-weight:600; }
.nav a:hover{ color:var(--ink); }

/* --- Menu mobilne BEZ JavaScriptu ------------------------------------------
   Ukryty checkbox (.nav-checkbox) przechowuje stan "otwarte / zamknięte".
   Kliknięcie etykiety <label class="nav-toggle"> (hamburger) przełącza checkbox,
   a reguła ".nav-checkbox:checked ~ .nav-sheet" pokazuje rozwijane menu.
   Przycisk hamburgera jest ukryty na desktopie, pojawia się dopiero w RWD < 760px. */
.nav-toggle{
  display:none;                 /* domyślnie ukryty — widoczny dopiero na mobile */
  align-items:center;
  justify-content:center;
  width:40px; height:40px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  color:var(--ink);
  cursor:pointer;
  flex:0 0 auto;
  transition:border-color .12s, background .12s;
}
.nav-toggle:hover{ border-color:var(--ink); background:var(--soft); }

.nav-checkbox{                  /* sam przełącznik — niewidoczny, poza układem */
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:0; height:0;
}

.nav-sheet{                     /* rozwijany panel z linkami (mobile) */
  display:none;
  position:absolute;
  top:100%; left:0; right:0;
  z-index:30;
  background:#fff;
  border-bottom:1px solid var(--line);
  box-shadow:0 18px 34px -18px rgba(27,26,23,.3);
  flex-direction:column;
  padding:8px 16px 14px;
}
.nav-sheet a{ color:var(--ink); text-decoration:none; font-size:16px; font-weight:600; padding:14px 16px; border-radius:10px; }
.nav-sheet a:hover{ background:var(--soft); }

.nav-checkbox:checked ~ .nav-sheet{ display:flex; }   /* otwarcie menu po zaznaczeniu checkboxa */


/* 5. HERO =================================================================== */
.hero{ text-align:center; padding:86px 0 70px; background:var(--alt); }
.hero .eyebrow{ display:inline-block; }
.hero h1{
  font-size:60px;
  line-height:1.02;
  letter-spacing:-0.035em;
  font-weight:800;
  margin:22px auto 22px;
  max-width:15ch;               /* skraca linię nagłówka dla lepszego łamania */
}
.hero p{ font-size:18px; color:var(--muted); max-width:56ch; margin:0 auto 30px; }


/* 6. SEKCJA: NASZE SERWISY (KARTY) ========================================= */
.services{ padding-top:64px; padding-bottom:86px; }

/* Wspólny nagłówek sekcji (eyebrow + h2 + opis). */
.sec-head{ text-align:center; max-width:620px; margin:0 auto 48px; }
.sec-head h2{ font-size:40px; letter-spacing:-0.03em; font-weight:800; margin:12px 0 14px; }
.sec-head p{ color:var(--muted); font-size:17px; margin:0; }

/* Siatka kart 2 kolumny (na mobile przechodzi w 1 kolumnę — patrz RWD). */
.svc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }

/* Pojedyncza karta serwisu.
   Kolory marki przekazywane są inline w HTML przez zmienne --svc / --svc-deep
   (np. style="--svc:#D8557E;--svc-deep:#B43E64") i używane w pasku, kropkach i linku. */
.svc{
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  background:var(--bg);
  display:flex;
  flex-direction:column;
  transition:box-shadow .18s, transform .18s, border-color .18s;
}
.svc:hover{ box-shadow:0 22px 48px -30px rgba(27,26,23,.4); border-color:var(--svc); }

.svc-top{ height:5px; background:var(--svc); }          /* kolorowy pasek na górze karty */
.svc-body{ padding:30px 30px 32px; display:flex; flex-direction:column; flex:1; }

/* Strefa logo — stała min. wysokość, by logotypy różnych serwisów się wyrównały. */
.svc-head{ display:flex; align-items:center; min-height:48px; margin-bottom:16px; }
.svc-logoimg{ width:auto; max-width:100%; display:block; }   /* wysokość ustawiana inline per logo */

.svc-tag{ font-size:11.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--svc-deep); white-space:nowrap; display:block; margin-bottom:8px; }
.svc h3{ font-size:23px; font-weight:800; letter-spacing:-0.02em; margin:3px 0 0; }   /* używane tylko gdy nazwa jest widoczna */
.svc-desc{ color:var(--muted); font-size:15px; margin:0 0 20px; }

/* Dwie kolumny zalet ("Dla rodziców" / "Dla niań" itd.). */
.svc-cols{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-bottom:22px; }
.svc-col h4{ font-size:12px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--ink); margin:0 0 12px; }
.svc-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.svc-col li{ position:relative; padding-left:18px; font-size:14px; color:var(--muted); line-height:1.45; }
.svc-col li::before{                                    /* kolorowa kropka w kolorze marki */
  content:"";
  position:absolute;
  left:2px; top:8px;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--svc);
}

/* Stopka karty z linkiem "Przejdź do serwisu". */
.svc-foot{ margin-top:auto; padding-top:18px; border-top:1px solid var(--line); }
.svc-link{ display:inline-flex; align-items:center; gap:7px; color:var(--svc-deep); font-weight:700; font-size:14.5px; text-decoration:none; white-space:nowrap; transition:gap .15s; }
.svc-link:hover{ gap:11px; }                            /* strzałka odsuwa się na hover */


/* 7. SEKCJA: DLACZEGO MY ==================================================== */
.why{ background:var(--alt); }
.why .wrap{ padding:80px 60px; }
.why-lead{ font-size:19px; line-height:1.5; color:var(--muted); margin:14px auto 0; font-weight:500; }
.why-lead .hl{ color:var(--clay); font-weight:700; }    /* wyróżnienie fragmentu tekstu */

/* Siatka 4 kafelków z zaletami (na RWD: 2, potem 1 kolumna). */
.why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.why-card{ background:var(--bg); border:1px solid var(--line); border-radius:16px; padding:26px 24px; }
.why-ic{ width:40px; height:40px; border-radius:11px; background:var(--ink); color:#fff; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.why-card h3{ font-size:17px; font-weight:800; letter-spacing:-0.01em; margin:0 0 7px; }
.why-card h3 strong{ color:var(--clay); font-weight:800; }
.why-card p{ color:var(--muted); font-size:14px; margin:0; line-height:1.5; }


/* 8. STOPKA ================================================================= */
.ft{ background:var(--ink); color:#fff; }

/* Górna część stopki: lewa kolumna (marka + kontakt) i prawa (lista serwisów). */
.ft-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:40px; padding-top:64px; padding-bottom:50px; }
.ft .logo{ margin-bottom:13px; color:#fff; }
.ft-grid p{ color:rgba(255,255,255,.66); font-size:14.5px; max-width:32em; margin:0; }

/* Lista serwisów z ikonkami. */
.ft-services{ display:flex; flex-direction:column; gap:10px; }
.ft-services .d-label{ font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:4px; }
.ft-services a{ display:flex; align-items:center; gap:10px; color:#fff; text-decoration:none; font-size:14.5px; font-weight:600; }
.ft-services a:hover{ color:#E2A488; }

/* Jednolity kafelek-tło pod favicon serwisu (równa wielkość niezależnie od ikony). */
.ft-ico{ flex:0 0 auto; width:28px; height:28px; border-radius:7px; background:#fff; border:1px solid rgba(0,0,0,.06); display:flex; align-items:center; justify-content:center; padding:4px; }
.ft-ico img{ width:18px; height:18px; object-fit:contain; display:block; border-radius:4px; }

/* Kompaktowy blok "Kontakt" pod marką. */
.ft-contact{ margin-top:26px; }
.ft-contact .d-label{ font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:8px; }
.ft-contact p{ color:rgba(255,255,255,.66); margin:0 0 14px; font-size:14px; max-width:30ch; }
.ft-contact .btn{ background:#fff; color:var(--ink); height:28px; padding:0 14px; font-size:12.5px; border-radius:8px; }  /* przycisk dopasowany wysokością do kafelka faviconu */
.ft-contact .btn:hover{ background:var(--alt); }

/* Dolny pasek: copyright + polityka prywatności. */
.ft-base{ border-top:1px solid rgba(255,255,255,.12); }
.ft-base .wrap{ padding:22px 60px; display:flex; justify-content:space-between; font-size:13px; color:rgba(255,255,255,.55); }
.ft-base a{ color:rgba(255,255,255,.7); text-decoration:none; }
.ft-base a:hover{ color:#fff; }


/* 9. RWD — PUNKTY ŁAMANIA =================================================== */

/* Tablet / mały desktop. */
@media (max-width: 1000px){
  .hero h1{ font-size:50px; }
  .why-grid{ grid-template-columns:repeat(2,1fr); }
  .sec-head h2{ font-size:34px; }
}

/* Mobile poziomy / mały tablet — tu włącza się menu hamburger. */
@media (max-width: 760px){
  .wrap{ padding-left:34px; padding-right:34px; }
  .hdr{ padding:20px 34px; }
  .nav{ gap:18px; }
  .nav .nav-link{ display:none; }       /* chowamy linki desktopowe */
  .nav-toggle{ display:inline-flex; }    /* pokazujemy hamburger */
  .hero{ padding:58px 0 52px; }
  .hero h1{ font-size:40px; }
  .hero p{ font-size:16px; }
  .svc-grid{ grid-template-columns:1fr; }
  .why .wrap{ padding:64px 34px; }
  .ft-grid{ grid-template-columns:1fr; gap:30px; padding-top:40px; padding-bottom:40px; }
  .ft-base .wrap{ padding:18px 34px; }
  .sec-head h2{ font-size:30px; }
}

/* Telefon. */
@media (max-width: 520px){
  .wrap{ padding-left:20px; padding-right:20px; }
  .hdr{ padding:16px 20px; }
  .logo{ font-size:17px; }
  .logo .mark{ width:22px; height:22px; }
  .hero{ padding:44px 0 44px; }
  .hero h1{ font-size:32px; }
  .hero .eyebrow{ font-size:11px; }
  .svc-cols{ grid-template-columns:1fr; gap:18px; }
  .svc-body{ padding:26px 22px 28px; }
  .why-grid{ grid-template-columns:1fr; }
  .why .wrap{ padding:54px 20px; }
  .ft-base .wrap{ padding:16px 20px; }
}
