/* reset */
html, body { margin: 0; padding: 0; font-family: 'Inter', sans-serif; }
* { box-sizing: border-box; }

:root {
  --header-h: 60px;
  --pad-x: 16px;
}

/* Pasek nawigacji */
.topbar {
  position: fixed;
  inset: 0 0 auto 0;
  height: var(--header-h);
  display: flex;
  gap: 16px;
  justify-content: space-between;
  align-items: center;
  background: #000;
  color: #fff;
  z-index: 1000;
  padding: max(0px, env(safe-area-inset-top)) var(--pad-x) 0 var(--pad-x);
}

/* Logo */
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #fff;
  text-decoration: none;
}
.brand img { width: 40px; height: 40px; }
.brand span { font-size: clamp(12px, 1.8vw, 16px); font-weight: 700; }

/* Nawigacja */
.mainnav { display: flex; gap: 20px; align-items: center; }
.mainnav a {
  color: orange;
  text-decoration: none;
  font-size: clamp(12px, 1.6vw, 15px);
}


/* Akcje (linki, nie buttony) */
.actions { display: flex; gap: 12px; align-items: center; }
.actions a {
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  line-height: 1;
}
.actions a:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Burger */
.menu-toggle {
  display: none;
  background: none;
  border: 1px solid transparent;
  color: #fff;
  font-size: 24px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
}
.menu-toggle:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Mobile menu */
@media (max-width: 1160px) {
  .mainnav {
    display: none;
    position: absolute;
    top: var(--header-h);
    left: 0; right: 0;
    flex-direction: column;
    gap: 0;
    background: #000;
    border-top: 1px solid rgba(255,255,255,.1);
    padding: 10px var(--pad-x) 16px;
  }
  .mainnav a { padding: 10px 0; }
  .menu-toggle { display: inline-block; }
  body.menu-open .mainnav { display: flex; }
}

/* Zapas: main nie potrzebuje padding-top, bo .hero kompensuje */
main { padding-top: 0; }

/* Redukcja animacji dla preferujących mniej ruchu */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}


/* Podstawowy wygląd „okrągłych” ikonek w .actions--icons */
.actions.actions--icons a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;               /* możesz dać 40px, jeśli chcesz większe */
  height: 36px;
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  border: 1px solid rgba(255,255,255,.15);
}
.actions.actions--icons a:hover { transform: translateY(-1px); }
.actions.actions--icons a:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Kolory brandowe — dopasowane do aria-label z Twojego HTMLa */
.actions.actions--icons a[aria-label="Facebook"]:hover,
.actions.actions--icons a[aria-label="Facebook"]:focus-visible {
  background: #1877f2;
  color: #fff;
  border-color: #1877f2;
}

.actions.actions--icons a[aria-label="Instagram"]:hover,
.actions.actions--icons a[aria-label="Instagram"]:focus-visible {
  background: #e1306c;
  color: #fff;
  border-color: #e1306c;
}

.actions.actions--icons a[aria-label="LinkedIn"]:hover,
.actions.actions--icons a[aria-label="LinkedIn"]:focus-visible {
  background: #0a66c2;
  color: #fff;
  border-color: #0a66c2;
}

.actions.actions--icons a[aria-label="Email"]:hover,
.actions.actions--icons a[aria-label="Email"]:focus-visible {
  background: #d93025; /* Gmail-owy czerwony */
  color: #fff;
  border-color: #d93025;
}

/* (opcjonalnie) niech ikona wewnątrz nie przechwytuje kliknięć */
.actions.actions--icons a > i { pointer-events: none; }



/*Opóźnienie dla tapnięcia w ikonki z linkami*/

.actions.actions--icons a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 300ms ease, transform 150ms ease;
  /* jeśli używasz Font Awesome – kolor ikony dziedziczy z <a> */
  color: inherit;
}

.actions.actions--icons a.is-pressed {
  color: #1877f2; /* fb/kontrast – podmień jak chcesz */
  transform: scale(0.94);
}

/* Szanuj preferencje dostępności */
@media (prefers-reduced-motion: reduce) {
  .actions.actions--icons a {
    transition: none;
  }
}


/* ====== PRO wygląd rozwiniętego hamburgera (mobile) ====== */
@media (max-width: 1160px) {
  /* panel menu */
  .mainnav {
    /* pozycjonowanie: już masz top: var(--header-h); left/right:0; */
    margin: 10px var(--pad-x) 16px;        /* odsunięte od krawędzi */
    padding: 8px;                          /* wewnętrzny margines panelu */
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,.12);
    background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
    box-shadow:
      0 10px 28px rgba(0,0,0,.45),
      inset 0 1px 0 rgba(255,255,255,.06);
    backdrop-filter: blur(10px);
    transform: translateY(-10px);
    opacity: 0;
    visibility: hidden;

    /* animacja wejścia/wyjścia */
    transition:
      transform .24s cubic-bezier(.2,.8,.2,1),
      opacity .24s ease,
      visibility 0s linear .24s; /* ukryj po zaniknięciu */
  }

  /* stan otwarty – gładkie show */
  body.menu-open .mainnav {
    display: flex;               /* już masz – tu tylko precyzujemy */
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    transition-delay: 0s;        /* widoczne od razu */
  }

  /* linki – większe hit‑area, nowa typografia, separator */
  .mainnav a {
    display: block;
    width: 100%;
    padding: 12px 14px;
    font-size: 16px;
    line-height: 1.35;
    color: #f3f3f3;
    text-decoration: none;
    border-radius: 10px;
    position: relative;
    transition: background .18s ease, color .18s ease, transform .12s ease;
  }

  /* cienki separator tylko pomiędzy pozycjami */
  .mainnav a + a {
    margin-top: 4px;
  }
  .mainnav a + a::before {
    content: "";
    position: absolute;
    top: -2px; left: 8px; right: 8px;
    height: 1px;
    background: linear-gradient(90deg, rgba(255,255,255,.05), rgba(255,255,255,.12), rgba(255,255,255,.05));
    pointer-events: none;
  }

  /* hover/focus – delikatne podświetlenie */
  .mainnav a:hover,
  .mainnav a:focus-visible {
    background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.06));
    color: #fff;
    outline: none;
    transform: translateY(-1px);
  }

  /* stan „aktywny” (np. hash w URL) – podkreśl bieżącą sekcję */
  .mainnav a[href*="#"]:where([aria-current="page"], [data-active="true"]) {
    background: linear-gradient(180deg, rgba(255,163,26,.22), rgba(255,163,26,.12));
    color: #fff;
    box-shadow: 0 0 0 1px rgba(255,163,26,.25) inset;
  }

}


/* Naprawa wyrównania hamburgera w przycisku */
@media (max-width: 1160px){
  .menu-toggle{
    display: inline-flex;              /* zamiast inline + line-height */
    align-items: center;               /* wyśrodkuj pionowo */
    justify-content: center;           /* wyśrodkuj poziomo */
    width: 44px;                       /* kwadratowy hit-area */
    height: 40px;
    padding: 0;                        /* usuń wewnętrzny odstęp */
    line-height: 1;                    /* bez baseline’u tekstu */
    font-size: 22px;                   /* wielkość “☰” */
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 10px;
    background: #000;                  /* spójne z topbarem */
    vertical-align: middle;            /* lepsze wyrównanie w linii */
  }
  .menu-toggle:hover { transform: translateY(-1px); }
  .menu-toggle:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }

  /* gdy menu otwarte – “X” zamiast ☰ (opcjonalnie) */
  body.menu-open .menu-toggle { color: transparent; background: rgba(255,255,255,.08); }
  body.menu-open .menu-toggle::after{
    content: "✕"; font-size: 20px; line-height: 1; position: relative;
  }
}

@media (max-width: 1160px) {
  .mainnav {
    align-items: flex-end;   /* menu przy prawej stronie */
  }
  .mainnav a {
    display: inline-block;
    min-width: 160px;        /* wszystkie linki mają tę samą szerokość */
    text-align: center;       /* tekst wyrównany do prawej */
    padding: 10px 0;
  }
}

/* ===== Animacja linków w nawigacji ===== */
/* === NAV HOVER: pro powiększenie + eleganckie podkreślenie === */
.topbar .mainnav a{
  position: relative;
  display: inline-block;              /* pewne skalowanie na desktopie */
  transition: color .25s ease, transform .25s ease;
  transform-origin: center;
  will-change: transform;
}

/* nadpisujemy wcześniejsze :hover które dawało zielony + underline */
.topbar .mainnav a:hover,
.topbar .mainnav a:focus-visible{
  color: #ffcc66;                     /* premium pomarańcz */
  transform: scale(1.12);
  text-decoration: none;              /* wyłącz stare underline */
  outline: none;
}

/* subtelna kreska „od dołu” */
.topbar .mainnav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-4px;
  width:0;
  height:2px;
  background:#ffcc66;
  transition: width .3s ease;
}
.topbar .mainnav a:hover::after,
.topbar .mainnav a:focus-visible::after{ width:100%; }

/* Mobile menu – trzymaj zachowanie z Twoich styli, ale bez konfliktu */
@media (max-width: 1160px){
  .topbar .mainnav a{
    display:block;                    /* pełna szerokość w panelu */
    transform: none;                  /* bez skalowania w wąskim panelu */
  }
  .topbar .mainnav a:hover,
  .topbar .mainnav a:focus-visible{
    transform: translateY(-1px);      /* zostaw lekkie uniesienie na mobile */
  }
  .topbar .mainnav a::after{ display:none; } /* bez kreski w panelu mobilnym */
}

@media (max-width: 409px) {
  .actions.actions--icons a[aria-label="LinkedIn"] {
    display: none !important;
  }
}
/* Ukryj GitHub przy wąskich ekranach */
@media (max-width: 470px) {
  .actions.actions--icons a[aria-label="GitHub"] {
    display: none !important;
  }
}
