/* =======================
   Reset & Variables
======================= */
:root{
  /* Light theme */
  --bg:#f7f9fc; --bg-soft:#f1f4f9; --card:#fff;
  --text:#1b1f24; --text-muted:#5b6472;
  --brand:#2160ff; --brand-2:#12b886; --accent:#ffd166;
  --border:#e5e7ef; --shadow:0 6px 18px rgba(0,0,0,.06);
  --radius:16px; --radius-sm:10px; --max:1200px;

  /* Header heights */
  --header-h-m:72px; --header-h-d:80px;

  /* Boczne „guttery” (global + header) – łatwe strojenie desktop/mobile */
  --edge: clamp(12px, 2vw, 32px);     /* ~24px na 1920px */
  --edge-h: clamp(8px, 1.2vw, -50px);  /* header: ~23px na 1920px */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%;height:auto;display:block}

/* =======================
   Typography
======================= */
@font-face{font-family:"Montserrat";src:local("Montserrat");font-display:swap}
html{scroll-behavior:smooth}
body{
  font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;
  color:var(--text); background:var(--bg); line-height:1.6;
  padding-top:var(--header-h-m);
}
@media (min-width:900px){ body{ padding-top:var(--header-h-d);} }

h1,h2,h3{line-height:1.2;margin:0 0 .6em}
h1{font-size:clamp(28px,4.0vw,44px);letter-spacing:.3px}
h2{font-size:clamp(22px,2.6vw,32px)}
h3{font-size:clamp(18px,2.0vw,22px)}
p{margin:0 0 1rem}
.lead{color:var(--text-muted);font-size:clamp(16px,1.8vw,18px)}

/* =======================
   Links & Buttons
======================= */
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.btn{
  display:inline-block;border:1px solid transparent;padding:.85rem 1.1rem;
  border-radius:999px;background:var(--brand);color:#fff;font-weight:700;
  box-shadow:var(--shadow);transition:transform .12s ease,opacity .12s ease
}
.btn:hover{transform:translateY(-1px);opacity:.95}
.btn.secondary{background:#fff;border:1px solid var(--border);color:var(--text)}
.cta-call{
  display:inline-flex;align-items:center;gap:.5rem;font-weight:700;
  background:var(--brand-2);color:#fff!important;padding:.55rem .9rem;
  border-radius:999px;box-shadow:var(--shadow)
}

/* =======================
   Layout helpers
======================= */
.container{width:100%;max-width:var(--max);margin:0 auto;padding-inline:var(--edge)}
.center-narrow{max-width:760px;margin-inline:auto}
.center-all{display:flex;min-height:100dvh;flex-direction:column}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{
  left:16px;top:16px;width:auto;height:auto;padding:.5rem .75rem;z-index:9999;
  background:var(--accent);color:#222;border-radius:8px
}

/* =======================
   Header (fixed)
======================= */
.header{
  position:fixed;inset:0 0 auto 0;z-index:1000;background:#fff;
  border-bottom:1px solid var(--border);box-shadow:var(--shadow)
}
/* Rozsunięcie: logo w lewo, menu w prawo – sterujesz zmienną --edge-h */
.header .container{
  display:flex;align-items:center;gap:12px;
  justify-content:space-between;min-height:var(--header-h-m);
  padding-inline:var(--edge-h);
}
@media (min-width:900px){ .header .container{ min-height:var(--header-h-d);} }

.logo{display:flex;align-items:center}
.logo img{height:52px;width:auto;display:block}

/* przytrzymaj menu przy prawej krawędzi headera */
.nav,.menu{margin-left:auto}
.nav ul,.menu ul{list-style:none;display:flex;gap:6px;padding:0;margin:0}
.nav a,.menu a{display:block;padding:.55rem .75rem;border-radius:10px;color:var(--text);font-weight:600}
.nav a:hover,.menu a:hover{background:#f1f4f9}

.menu-toggle{
  inline-size:44px;block-size:44px;border-radius:10px;display:grid;place-items:center;
  font-size:20px;border:1px solid var(--border);background:#fff;color:var(--text);
  cursor:pointer;box-shadow:var(--shadow)
}
.menu-toggle:focus{outline:2px solid var(--brand);outline-offset:2px}

/* Mobile dropdown under fixed header */
.nav,.menu{
  position:fixed;left:0;right:0;top:var(--header-h-m);background:#fff;border-top:1px solid var(--border);
  transform:translateY(-8px);opacity:0;pointer-events:none;transition:.15s ease;padding:10px var(--edge-h);box-shadow:var(--shadow)
}
.nav ul,.menu ul{flex-direction:column;gap:2px}
.nav .cta-call,.menu .cta-call{margin-top:6px}

/* ✅ OTWIERANIE MENU – JS ustawia klasę na body */
body.nav-open .nav,
body.nav-open .menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

/* Desktop reset */
@media (min-width:900px){
  .menu-toggle{display:none}
  .nav,.menu{position:static;background:transparent;border:0;transform:none;opacity:1;pointer-events:auto;padding:0;box-shadow:none}
  .nav ul,.menu ul{flex-direction:row;gap:4px}
  .nav .cta-call,.menu .cta-call{margin-left:6px}
}

/* =======================
   Hero
======================= */
.hero{
  padding:clamp(32px,5vw,72px) 0;
  background:
    radial-gradient(900px 400px at 85% 10%, rgba(33,96,255,.08), transparent 60%),
    radial-gradient(900px 400px at 10% 0%, rgba(18,184,134,.07), transparent 60%),
    linear-gradient(180deg,#fff 0%,var(--bg) 100%)
}
.hero .inner{display:grid;gap:28px;grid-template-columns:1fr;align-items:center}
.hero-visual{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border)}
.badge{display:inline-block;font-weight:700;color:#1b1f24;background:var(--accent);padding:.35rem .6rem;border-radius:999px;margin:.4rem 0 .8rem}
.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
@media (min-width:980px){ .hero .inner{grid-template-columns:1.05fr .95fr} }

/* =======================
   Sections & Cards
======================= */
.section{padding:clamp(28px,5vw,64px) 0}
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:clamp(16px,2.8vw,28px);box-shadow:var(--shadow);
  text-align:center
}

/* =======================
   Carousel (fade)
======================= */
.carousel{position:relative;margin:18px 0}
.car-track{
  position:relative;overflow:hidden;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:#fff;aspect-ratio:16/9
}
.car-slide{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;visibility:hidden;transition:opacity .35s ease
}
.car-slide.is-active{opacity:1;visibility:visible;z-index:1}
.car-btn{
  position:absolute;top:50%;transform:translateY(-50%);inline-size:40px;block-size:40px;border-radius:10px;
  border:1px solid var(--border);background:#fff;color:var(--text);display:grid;place-items:center;box-shadow:var(--shadow);z-index:2
}
.car-prev{left:10px} .car-next{right:10px}
.car-dots{display:flex;gap:8px;justify-content:center;margin-top:10px}
.car-dot{inline-size:10px;block-size:10px;border-radius:50%;border:1px solid var(--border);background:#e9edf5;cursor:pointer}
.car-dot.is-active{background:var(--brand);border-color:transparent}

/* =======================
   Footer
======================= */
.footer{background:#fff;border-top:1px solid var(--border);padding:28px 0}
.footer-grid{display:grid;gap:22px;grid-template-columns:1fr}
.footer-col{background:#fff;padding:18px;border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow)}
.footer-head{margin-bottom:.5rem}
.foot-links{list-style:none;padding:0;margin:0}
.foot-links li+li{margin-top:.35rem}
@media (min-width:820px){ .footer-grid{grid-template-columns:1fr 1fr} }
.copyright{text-align:center;margin-top:16px;color:var(--text-muted);font-size:14px}

/* =======================
   FAQ page
======================= */
main.section{
  display:flex;justify-content:center;align-items:flex-start;
  min-height:calc(100vh - 200px);padding:60px var(--edge) 40px
}
.faq-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:28px;max-width:900px;width:100%;text-align:center
}
.faq-card .lead{margin-bottom:28px;color:var(--text-muted)}
.faq{display:grid;gap:16px;justify-items:center}
.faq details{
  background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.03);
  max-width:600px;width:100%;padding:14px 16px;text-align:left
}
.faq summary{font-weight:600;cursor:pointer}
.faq .answer{margin-top:8px}
.faq-actions{margin-top:28px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.faq-actions .btn{min-width:200px}

/* =======================
   Offer page
======================= */
.page-bg h1,.page-bg .lead{ text-align:center }
.grid{ display:grid; gap:20px; justify-items:center }
.grid-2{ grid-template-columns:1fr }
.grid-2 .card{ max-width:380px; width:100% }
@media (min-width:768px){ .grid-2{ grid-template-columns:repeat(2,1fr) } }
.actions{ margin-top:32px; display:flex; justify-content:center; gap:12px; flex-wrap:wrap }

/* =======================
   A11y / Motion
======================= */
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* === LOGO PRZY SAMEJ KRAWĘDZI VIEWPORTU (bez zmian w HTML) === */
.header > .container{
  max-width: none !important;  /* zdejmujemy ograniczenie 1200px tylko w headerze */
  width: 100% !important;      /* 100% zamiast 100vw, by uniknąć poziomego scrolla */
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.header .logo img{
  height: 72px;   /* większe na desktop */
  width: auto;
}

@media (max-width: 899px){
  .header .logo img{ height: 52px; }
}
.header .logo img{ display:block } /* usuwa ewentualne szczeliny obrazka */

/* menu trzymaj po prawej z kontrolowanym „oddechem” */
.header .nav,
.header .menu{
  margin-left: auto !important;
  padding-right: clamp(8px, 1.2vw, 24px) !important;
}

/* mobile dropdown dalej liczy wysokość headera */
.nav, .menu{ padding-left: clamp(8px, 1.2vw, 24px) !important; }

/* Active link */
.nav a.active {
  color: var(--brand);
  font-weight: 700;
  border-bottom: 2px solid var(--brand);
}

@media (max-width: 899px){
  /* wyrównaj padding w dropdownie */
  .nav, .menu{
    padding-left: 12px !important;
    padding-right: 12px !important;
    left: 0; right: 0; margin: 0;
  }

  /* to z Twojej reguły .header .nav/.menu — dociągamy do tych samych 12px */
  .header .nav,
  .header .menu{
    padding-right: 12px !important;
  }
}

/* awaryjnie odetnij ewentualny poziomy scroll (gdyby obrazek/karuzela przesadziły) */
html, body{ overflow-x: hidden; }

