:root{
  --bg: #000;
  --card: #f3f0f1;
  --pink: #d61fb6;
  --white: #fff;
  --muted: #cfcfcf;
  --container: 1100px;
  --radius: 20px;
  --nav-gap: clamp(40px, 10vw, 300px);
}

/* reset / podstawowe */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background:var(--bg);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.wrap{width:92%;max-width:var(--container);margin:0 auto}

/* HEADER / NAV */
.site-header{
  position:sticky;
  top:0;
  z-index:60;
  padding:18px 0;
  background:transparent;
  transition: background-color 220ms ease, box-shadow 220ms ease, backdrop-filter 220ms ease;
  will-change: background-color, box-shadow;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative; /* potrzebne dla pozycji indikator */
}

/* gdy przewinięte lub menu otwarte */
.site-header.scrolled{
  background-color: rgba(0,0,0,0.98); /* mocniej przyciemnione */
  box-shadow: 0 8px 30px rgba(0,0,0,0.65);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

/* lista nav (wyśrodkowana) */
.nav-list{
  display:flex;
  gap:var(--nav-gap);
  align-items:center;
  list-style:none;
  padding:0;
  margin:0;
  position:relative; /* dla prawidłowego obliczania pozycji indikator */
}
.nav-list li{ position: relative; } /* ułatwia targetowanie pozycji linku */
.nav-link{color:var(--muted);text-decoration:none;font-weight:600;font-size:15px;letter-spacing:0.06em;padding:6px 2px;display:inline-block}
.nav-link:hover,.nav-link:focus{color:var(--white);outline:none}
/* active link (fallback color) */
.nav-link.active{ color: var(--white); }

/* INDICATOR: zaokrąglona kreska pod aktywnym itemem */
.nav-indicator{
  position:absolute;
  height:8px;                     /* grubość kreski */
  background:var(--pink);
  border-radius:999px;
  bottom: -8px;                   /* jak daleko od dolnej krawędzi nav-list (dostosuj) */
  left: 0;
  width: 0;
  transform: translateX(0);
  transition: transform 320ms cubic-bezier(.2,.9,.2,1), width 320ms cubic-bezier(.2,.9,.2,1), opacity 200ms ease;
  box-shadow: 0 6px 18px rgba(214,31,182,0.12);
  pointer-events: none;
  z-index: 10;
  opacity: 1;
}

/* ukryj indicator jeśli brak pozycji aktywnej (opcjonalne) */
.nav-indicator.hidden{ opacity: 0; width: 0; }

/* kontakt jako pigułka */
.nav-contact{
  display:inline-block;
  background:var(--pink);
  color:var(--white);
  padding:8px 18px;
  border-radius:24px;
  text-decoration:none;
  font-weight:700;
  font-size:15px;
}
.site-header.scrolled .nav-contact{ background:var(--pink); color:var(--white); }

/* burger (mobile) - zawsze nad overlay */
.burger{
  position:absolute;
  right:18px;
  top:16px;
  background:transparent;
  border:0;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:6px;
  cursor:pointer;
  z-index:220; /* WYŻEJ niż overlay aby był zawsze widoczny */
}
.burger-line{width:22px;height:2px;background:var(--white);display:block}

/* overlay (mobile menu) — START OD GÓRY */
.nav-overlay{
  display:none;
  position:fixed;
  top:0;
  left:18px;
  right:18px;
  bottom:auto;
  background:rgba(0,0,0,0.95);
  padding:18px;
  border-radius:0 0 12px 12px;
  flex-direction:column;
  gap:12px;
  z-index:180;
  transform-origin: top center;
  pointer-events: none; /* pozwala scrollować tło */
}
@keyframes slideDown { from { transform: translateY(-8px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.nav-overlay.show{ display:flex; animation: slideDown 220ms cubic-bezier(.2,.9,.2,1); }
.nav-overlay a{ color:var(--muted); text-decoration:none; padding:10px; border-radius:8px; pointer-events:auto; }
.nav-overlay a.nav-contact{ background:var(--pink); color:var(--white); padding:10px 14px; border-radius:20px; pointer-events:auto; }
/* ================= Header - scrolled (widoczny, ciemne tło) ================= */
.site-header {
  transition: background-color 200ms ease, box-shadow 200ms ease, backdrop-filter 200ms ease;
}

/* when scrolled or overlay open */
.site-header.scrolled {
  background-color: rgba(0, 0, 0, 0.466); /* mocne ciemne tło */
  box-shadow: 0 10px 30px rgba(0,0,0,0.6);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}

/* opcjonalnie delikatnie rozjaśnij linki gdy header scrolled (większy kontrast) */
.site-header.scrolled .nav-link { color: #e8e8e8; }
.site-header.scrolled .nav-contact { background: var(--pink); color: var(--white); }

/* jeśli overlay jest otwarty - zapewniamy, że header wygląda tak samo */
.nav-overlay.show ~ .site-header,
.site-header.overlay-open { background-color: rgba(0, 0, 0, 0.466); }

/* HERO */
.hero{padding:36px 0 20px}
.hero-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:center}
.hero-left{z-index:2}
.hero-right{display:flex;align-items:center;justify-content:center}
.hero-right img{
  width:100%;
  height:auto;
  display:block;
  max-width:420px;
  border-radius:16px;
  object-fit:cover;
  box-shadow:0 18px 40px rgba(0,0,0,0.6);
  border:none;
  background:transparent;
}
.hero-title{font-family:"Montserrat",sans-serif;font-size:34px;line-height:1.02;margin:0}
.accent{color:var(--pink)}

/* SEKCJE */
.section{padding:48px 0}
.section-title{font-family:"Montserrat",sans-serif;font-size:30px;margin:0;text-align:left}

/* USŁUGI */
#uslugi .section-title {
  margin-bottom: 48px; /* większy odstęp pod tytułem usług */
}
.service-icon{ width:72px; height:72px; display:flex; align-items:center; justify-content:center; margin:15px auto 6px; border-radius:999px; background:var(--card); box-shadow:0 6px 18px rgba(2,6,23,0.12); padding:12px; }
.service-icon img{ width:36px; height:36px; display:block; object-fit:contain; }
.services-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:20px}
.service-card{ background:var(--card); color:#111; border-radius:28px; padding:28px 20px; min-height:160px; text-align:center; box-shadow:0 12px 30px rgba(0,0,0,0.45); padding-top:12px; }
.service-title{ margin-top:16px; color:var(--pink); font-weight:800; font-size:20px; letter-spacing:0.06em; font-family:"Montserrat"; }
.service-desc{ text-align:left; font-family:"Montserrat",sans-serif; font-size:14px; line-height:1.5; color:#111; margin:20px 0 0; }

/* =================== PROJEKTY — single visible card, większe kafle =================== */
/* wrapper + nawigacja */
.projects-wrap{display:flex;align-items:center;gap:18px;position:relative;margin-top:28px}
.proj-nav{width:48px;height:48px;border-radius:50%;background:var(--pink);color:var(--white);border:0;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;flex:0 0 auto;box-shadow:0 6px 18px rgba(0,0,0,0.35)}

/* slider container - centrowany i ograniczony szerokością */
.projects-slider{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  overflow:hidden;
  position:relative;
  padding:0;
}

/* track: gap określa odstęp między kartami; krok przesuwania = szerokość karty + gap */
.projects-track{
  display:flex;
  gap:48px;
  align-items:center;
  transition:transform .65s cubic-bezier(.22,.9,.26,1);
  will-change:transform;
  padding:8px 0;
}

/* pojedyncza karta zajmuje cały widoczny obszar tracka */
.projects-track .proj-card,
.projects-slider > .proj-card{ flex:0 0 100%; max-width:100%; box-sizing:border-box }

/* karta - duża, panoramiczna (szerokość steruje layoutem) */
.proj-card{
  height:720px;            /* główna wysokość desktop */
  border-radius:20px;
  background:transparent;
  padding:0;
  position:relative;
  box-shadow:0 40px 80px rgba(0,0,0,0.45);
  overflow:visible;
  display:block;
  cursor:pointer;
  outline:none;
}

/* miniatura wypełnia całą kartę */
.proj-thumb{
  width:100%;
  height:100%;
  border-radius:20px;
  overflow:hidden;
  display:block;
  background:#f3f0f1;
  position:relative;
}

/* img: cover, centrowane, lekko przyszarzone domyślnie */
.proj-thumb img {
  width: 100%;           /* zmniejsza obrazek do 70% szerokości kontenera */
  height: 100%;          /* zmniejsza obrazek do 70% wysokości kontenera */
  object-fit: contain;  /* zachowuje proporcje, nie rozciąga */
  margin: auto;
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  /* wyśrodkowanie */
  display: block;
  transition: filter .36s ease, transform .36s ease;
}

/* hover/focus: obraz odzyskuje kolory i delikatnie się powiększa */
.proj-card:hover .proj-thumb img,
.proj-card:focus .proj-thumb img{
  filter:none;
  transform:scale(1.03);
}
.proj-card:hover .proj-pill,
.proj-card:focus .proj-pill {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

/* proj-pill (przycisk) - domyślnie ukryty, pojawia się na hover/focus karty */
.proj-pill{
  position:absolute;
  left:50%;
  transform:translateX(-50%) translateY(8px);
  bottom:20px;
  z-index:60;
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s cubic-bezier(.2,.9,.3,1);
}

/* przycisk wewnątrz pill */
.proj-pill .proj-btn{
  pointer-events:auto;
  display:inline-block;
  background:var(--pink);
  color:var(--white);
  padding:12px 26px;
  border-radius:14px;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 28px 48px rgba(214,31,182,0.18);
  transition:transform .18s ease, box-shadow .18s ease;
}

/* opcjonalne małe kropki/paginacja (jeśli chcesz użyć) */
.proj-indicators{position:absolute;left:50%;transform:translateX(-50%);bottom:12px;display:flex;gap:8px;z-index:55}
.proj-indicators button{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.35);border:0}

/* hide scrollbars for aesthetic */
.projects-track::-webkit-scrollbar{display:none}
.projects-track{ -ms-overflow-style:none; scrollbar-width:none; }
.proj-nav {
  background: none;
  border: none;
  color: var(--pink);
  font-size: 2.2rem;        /* trochę mniejszy znak */
  font-weight: 600;         /* mniej pogrubiony */
  cursor: pointer;
  padding: 0 8px;
  transition: color .18s, box-shadow .18s, transform .38s;
  line-height: 1;
  outline: none;
}
.proj-nav:hover,
.proj-nav:focus {
  transform: scale(1.18); /* delikatne powiększenie */
}
/* STOPKA */
.site-footer{padding:28px 0;text-align:center;color:var(--muted);font-size:14px}

/* RESPONSYWNOŚĆ */
@media (max-width:767px){
  .nav-list{display:none}
  .burger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:18px}
  .hero-right img{max-width:100%;height:auto;border-radius:12px}
  .hero-title{font-size:26px}
  .services-grid{grid-template-columns:1fr}
  .proj-card{min-width:200px;height:220px}
}
@media (min-width:768px){
  .nav-list{display:flex}
  .burger{display:none}
  .hero-grid{grid-template-columns:1fr 420px;align-items:center}
  .hero-right img{max-width:420px}
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .hero-title{font-size:40px}
  .proj-card{min-width:260px;height:260px}
}
@media (min-width:1400px){
  .hero-grid{grid-template-columns:1fr 520px}
  .hero-right img{max-width:520px}
}
/* NAV INDICATOR (rounded underline) */
.nav-list { position: relative; }

/* kreska pod aktywną pozycją */
.nav-indicator {
  position: absolute;
  left: 0;
  bottom: -10px;                        /* dopasuj odległość od linków */
  height: 8px;                          /* grubość kreski */
  width: 0;
  background: var(--pink);
  border-radius: 999px;                 /* zaokrąglone końce */
  box-shadow: 0 8px 22px rgba(214,31,182,0.12);
  transform: translateX(0);
  transition:
    transform 320ms cubic-bezier(.2,.9,.2,1),
    width 320ms cubic-bezier(.2,.9,.2,1),
    opacity 200ms ease;
  pointer-events: none;
  z-index: 5;
  will-change: transform, width;
}

/* gdy chcemy ukryć indicator */
.nav-indicator.hidden {
  opacity: 0;
  width: 0;
}

/* mała adaptacja gdy nav ma padding: usuwamy kolizję */
.header-inner .nav-list { padding-bottom: 18px; }

/* Przy mniejszych ekranach można zmniejszyć grubość */
@media (max-width:767px){
  .nav-indicator { height:6px; bottom:-8px; }
}
.site-logo.mobile-only {
  display: none;
}

@media (max-width: 900px) {
  .site-logo.mobile-only {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 64px;
    margin-right: 16px;
  }
  .site-logo.mobile-only img {
    height: 40px;
    width: auto;
    display: block;
    border-radius: 12px;
  }
  .header-inner {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    height: 64px;
    min-height: 64px;
  }
}

.projects-slider { touch-action: pan-y; }
.projects-track { will-change: transform; }