
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Helvetica Neue',Arial,'Noto Sans',sans-serif;background:#0a0c14;color:#e9edf5}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(10,12,20,.9);backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid rgba(255,255,255,.04)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;color:#e9edf5;text-decoration:none}
.brand-logo{width:36px;height:36px;object-fit:contain}
.site-nav{display:flex;align-items:center;gap:24px}
.site-nav a{color:#c8cfe4;text-decoration:none;font-weight:700;letter-spacing:.3px}
.site-nav a.active{color:#ffd166}
.btn{display:inline-block;padding:10px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.16);text-decoration:none}
.btn-primary{background:#1b1f2e;color:#e9edf5;border-color:#394166}
.btn-ghost{background:transparent;color:#e9edf5}

.hero{position:relative;min-height:72vh;display:flex;align-items:center}
.bg-video{position:absolute;inset:0;z-index:0}
.bg-video iframe,.bg-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bg-video__overlay{position:absolute;inset:0;background:radial-gradient(100% 70% at 60% 40%,rgba(15,18,30,.4) 0%,rgba(10,12,20,.9) 100%)}
.hero__content{position:relative;z-index:2;color:#fff;padding:96px 0 72px}
.hero__content h1{font-size:48px;line-height:1.1;margin:0 0 16px}
.hero__content .accent{color:#ffd166}
.hero__content p{max-width:840px;opacity:.9}
.cta-row{display:flex;gap:12px;margin-top:16px}
.hero__badges{display:flex;gap:12px;margin-top:12px;list-style:none;padding:0}

.section{padding:72px 0}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:32px}
.list-check{list-style:none;padding:0;margin:16px 0}
.list-check li{position:relative;padding-left:28px;margin:8px 0}
.list-check li:before{content:'✓';position:absolute;left:0;color:#ffd166}
.about__card{background:#121524;border:1px solid #20253b;border-radius:16px;padding:24px}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pillar{padding:14px 16px;border-radius:12px;background:#0f1322;border:1px solid #242a45}
.pillar span{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:9px;background:#ffd166;color:#111;font-weight:800;margin-right:8px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{padding:20px;border-radius:16px;background:#101425;border:1px solid #222742}
.card h3{margin:0 0 8px}
.card p{margin:0 0 12px;opacity:.9}
.offer-photo{width:100%;height:180px;object-fit:cover;border-radius:12px;margin:0 0 14px;display:block}
@media (max-width:900px){.offer-photo{height:200px}}
.btn-link{color:#ffd166;text-decoration:none}

.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.t-item{padding:18px;border-radius:16px;background:#0f1322;border:1px solid #242a45}
blockquote{margin:0 0 8px;font-style:italic}
.site-footer{padding:36px 0;border-top:1px solid rgba(255,255,255,.06);background:#090b12;color:#aeb6cf;text-align:center}
@media (max-width:900px){.grid-2{grid-template-columns:1fr}.cards,.t-grid{grid-template-columns:1fr}}

/* Hero layout refinements */
.hero__content .container{max-width:1200px;margin:0 auto;padding:0 24px;display:grid;gap:16px}
.hero__content h1{font-size:56px;line-height:1.05;margin:0}
.hero__content p.hero-sub{font-size:18px;max-width:760px;opacity:.92}
.hero__content .cta-row{flex-wrap:wrap}

/* Map block */
.map-wrap{margin:16px 24px 72px;border-radius:16px;overflow:hidden;border:1px solid #242a45}
.map-wrap iframe{width:100%;aspect-ratio:16/9;border:0;display:block}

/* Mobile tweaks */
@media (max-width:900px){
  .hero{min-height:56vh}
  .hero__content{padding:72px 0 56px}
  .hero__content h1{font-size:42px}
  .hero__content p.hero-sub{font-size:16px}
  .site-nav{gap:12px}
}
@media (max-width:600px){
  .hero__content h1{font-size:34px}
  .cta-row{gap:8px}
  .btn{padding:10px 14px}
  .brand-text{font-size:16px}
  .map-wrap{margin:12px 16px 56px}
}

/* === Mobile responsiveness upgrades (video, map, typography) === */
.bg-video{overflow:hidden}
.bg-video iframe,.bg-video video{
  width:100%;
  height:100%;
  min-width:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center;
}

/* Hero dynamic height by breakpoints */
:root{--hero-min-h:72vh}
.hero{min-height:var(--hero-min-h)}
@media (max-width:900px){ :root{--hero-min-h:60vh} }
@media (max-width:600px){ :root{--hero-min-h:52vh} }

/* Stronger overlay on small screens for readability */
@media (max-width:600px){
  .bg-video__overlay{background:radial-gradient(100% 70% at 60% 40%,rgba(15,18,30,.55) 0%,rgba(10,12,20,.95) 100%)}
}

/* Map smaller on mobile */
@media (max-width:900px){
  .map-wrap{margin:12px 20px 56px}
  .map-wrap iframe{aspect-ratio:4/3}
}
@media (max-width:600px){
  .map-wrap{margin:10px 16px 48px}
  .map-wrap iframe{aspect-ratio:auto;height:220px}
}

/* Header/nav tweaks on mobile */
@media (max-width:760px){
  .site-nav{gap:10px}
  .site-header .btn.btn-primary{padding:8px 12px}
}

/* HERO text spacing mobile */
@media (max-width:600px){
  .hero__content h1{font-size:30px; line-height:1.15}
  .hero__content p.hero-sub{font-size:15px}
}

/* === PZ MOBILE FINAL === */
/* Video covers area at all sizes */
.bg-video{overflow:hidden}
.bg-video iframe,.bg-video video{
  position:absolute;inset:0;
  width:100%;height:100%;
  min-width:100%;min-height:100%;
  object-fit:cover;object-position:center;
}

/* Hero dynamic height */
:root{--hero-min-h:72vh}
.hero{min-height:var(--hero-min-h)}
@media (max-width:900px){ :root{--hero-min-h:60vh} }
@media (max-width:600px){ :root{--hero-min-h:52vh} }

/* Stronger overlay for readability on small screens */
@media (max-width:600px){
  .bg-video__overlay{background:radial-gradient(100% 70% at 60% 40%,rgba(15,18,30,.55) 0%,rgba(10,12,20,.95) 100%)}
}

/* Map smaller on mobile */
.map-wrap{margin:16px 24px 72px;border-radius:16px;overflow:hidden;border:1px solid #242a45}
.map-wrap iframe{width:100%;aspect-ratio:16/9;border:0;display:block}
@media (max-width:900px){ .map-wrap{margin:12px 20px 56px} .map-wrap iframe{aspect-ratio:4/3} }
@media (max-width:600px){ .map-wrap{margin:10px 16px 48px} .map-wrap iframe{aspect-ratio:auto;height:220px} }

/* Header/nav & hero text tweaks */
@media (max-width:760px){ .site-nav{gap:10px} .site-header .btn.btn-primary{padding:8px 12px} }
@media (max-width:600px){ .hero__content h1{font-size:30px;line-height:1.15} .hero__content p.hero-sub{font-size:15px} }


/* === PZ MAP DESKTOP SMALLER === */
:root{ --map-max-w: 900px; --map-h-desktop: 320px }

/* Kontener mapy mniejszy i wycentrowany na desktopie */
.map-wrap{ max-width: var(--map-max-w); margin: 16px auto 64px }
/* Stała, niższa wysokość na desktopie; na mobile nadpisujemy dalej */
.map-wrap iframe{ width:100%; height: var(--map-h-desktop); aspect-ratio: auto }

/* Delikatne powiększenie na bardzo szerokich ekranach */
@media (min-width:1200px){ :root{ --map-max-w: 1000px; --map-h-desktop: 340px } }

/* Tablety i telefony – zostawiamy wcześniejsze reguły mobilne */
@media (max-width:900px){ .map-wrap{ max-width: 720px } .map-wrap iframe{ height:auto; aspect-ratio: 4/3 } }
@media (max-width:600px){ .map-wrap{ max-width: 100% } .map-wrap iframe{ aspect-ratio:auto; height:220px } }

/* === PZ FULL-WIDTH VIDEO & NO H-SCROLL === */
html,body{overflow-x:hidden}
.hero{width:100%;position:relative}
.bg-video{position:absolute;inset:0;z-index:0;overflow:hidden}
.bg-video iframe,.bg-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}

/* === PZ MOBILE NAV === */
.nav-wrap{gap:12px}
.nav-toggle{display:none;appearance:none;background:#0f1322;border:1px solid #242a45;color:#e9edf5;border-radius:10px;padding:8px 10px;line-height:1}
.nav-toggle[aria-expanded="true"]{background:#151a2c}
@media (max-width:880px){
  .site-nav{position:fixed;top:72px;right:16px;left:16px;display:none;flex-direction:column;gap:12px;background:#0b0f1c;border:1px solid #1f2440;border-radius:14px;padding:16px;z-index:60}
  .site-nav.open{display:flex}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .site-header .btn.btn-primary{width:100%;text-align:center}
}

/* === PZ FADE-IN === */
@keyframes pzFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.fade-animate{animation:pzFadeIn .55s ease-out both}

/* === PZ VIDEO FULL WIDTH (DESKTOP + MOBILE) === */
html, body { overflow-x: hidden; }

.hero { width: 100%; position: relative; }

/* Kontener tła dopasowany do szerokości urządzenia */
.bg-video {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
  left: 50%; width: 100vw; transform: translateX(-50%);
}
@supports (width: 100svw) {
  .bg-video { width: 100svw; }
}

/* Wideo/iframe na pełną szerokość, wysokość domykana przez hero */
.bg-video video,
.bg-video iframe {
  position: absolute; top: 0; left: 50%;
  width: calc(var(--vw, 1vw) * 100);
  height: 100%; transform: translateX(-50%);
  object-fit: cover; object-position: center;
}

/* iOS „small viewport” – jeszcze dokładniej */
@supports (width: 100svw) {
  .bg-video video, .bg-video iframe { width: 100svw; }
}

/* HERO wysokość pozostaje elastyczna jak dotąd */
:root { --hero-min-h: 72vh; }
.hero { min-height: var(--hero-min-h); }
@media (max-width: 900px) { :root { --hero-min-h: 60vh; } }
@media (max-width: 600px) { :root { --hero-min-h: 52svh; } }


/* === PZ VIDEO FULL WIDTH FIX v2 === */
.hero, .bg-video { width: 100% !important; }
.bg-video { position: absolute; inset: 0; z-index: 0; overflow: hidden; left: 0 !important; transform: none !important; }
.bg-video iframe, .bg-video video {
  position: absolute; inset: 0;
  width: 100% !important; height: 100% !important;
  transform: none !important;
  object-fit: cover; object-position: center;
}

/* === PZ FINAL PATCH v5: hero margins/centering, video full bleed, map keep === */

/* 1) Hero text: more left margin on desktop; centered on mobile */
@media (min-width: 1200px){
  .hero__content .container{
    padding-left: clamp(96px, 12vw, 240px);
    padding-right: clamp(24px, 6vw, 96px);
  }
}
@media (max-width: 900px){
  .hero__content .container{ text-align: center; }
  .hero__content .cta-row{ justify-content: center; }
}

/* 2) Video full width without right gap (final override) */
html, body { overflow-x: hidden; }
#home.hero{ overflow: hidden; }
.bg-video{ position:absolute; inset:0; left:0; right:0; width:auto !important; transform:none !important; z-index:0; }
.bg-video iframe, .bg-video video{
  position:absolute; inset:0;
  width:100% !important; height:100% !important;
  object-fit:cover; object-position:center; transform:none !important;
}

/* 3) Map visible and sized (sits above video overlay) */
.map-wrap{ position:relative; z-index:1; }

/* === PZ FULLSCREEN HERO VIDEO v6 === */
html, body { overflow-x: hidden; }

:root{ --vh: 1vh; }

/* HERO = pełne okno przeglądarki */
.hero{
  position: relative;
  height: 100dvh;                      /* nowoczesne przeglądarki */
  min-height: calc(var(--vh) * 100);   /* fallback (iOS/Safari) */
  overflow: hidden;
}

/* Tło wideo na całą sekcję */
.bg-video{ position:absolute; inset:0; overflow:hidden; z-index:0; left:0; right:0; transform:none !important; }
.bg-video iframe,
.bg-video video{
  position:absolute; inset:0;
  width:100% !important; height:100% !important;
  object-fit:cover; object-position:center; transform:none !important;
}

/* Treść nad wideo (nie zmieniamy layoutu sekcji) */
.hero__content{ position:relative; z-index:1; }

/* === PZ MOBILE FULLSCREEN HERO (final) === */
@media (max-width: 900px){
  html, body { overflow-x: hidden; }
  :root{ --vh: 1vh; --header-h: 72px; } /* JS podmieni realną wysokość */
  .hero{
    position: relative;
    height: calc(100dvh - var(--header-h));
    min-height: calc((var(--vh) * 100) - var(--header-h));
    overflow: hidden;
  }
  .bg-video{ position:absolute; inset:0; z-index:0; overflow:hidden; }
  .bg-video video,
  .bg-video iframe{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover; object-position:center;
    transform:none;
  }
  .hero__content{ position:relative; z-index:1; text-align:center; }
  .hero__content .cta-row{ justify-content:center; }
}

/* === PZ MOBILE FULLSCREEN ENFORCE v7 === */
@media (max-width:900px){
  :root{ --vh: 1vh; }
  .hero{ height: 100svh !important; min-height: calc(var(--vh) * 100) !important; overflow:hidden; }
  .bg-video{ position:absolute; inset:0; }
  .bg-video iframe, .bg-video video{ width:100% !important; height:100% !important; object-fit:cover; object-position:center; }
}
@supports not (height: 100svh){
  @media (max-width:900px){
    .hero{ height: calc(var(--vh) * 100) !important; }
  }
}


/* === TRAINERS SECTION === */
.trainers-section { padding-top: 40px; }

.trainers-card {
  background:#121524;
  border:1px solid #20253b;
  border-radius:16px;
  padding:32px;
}

.trainers-card h3 {
  margin:0 0 24px;
  font-size:24px;
  font-weight:700;
}

.trainers-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}

.trainer-box {
  background:#0f1322;
  border:1px solid #242a45;
  border-radius:16px;
  padding:20px;
  text-align:center;
}

.trainer-photo {
  width:100%;
  height:240px;
  object-fit:cover;
  border-radius:12px;
  margin-bottom:16px;
}

.trainer-btn {
  display:block;
  margin-top:12px;
  background:#1b1f2e;
  border:1px solid #394166;
  width:100%;
  padding:12px 0;
  border-radius:12px;
}

@media (max-width:900px){
  .trainers-grid { grid-template-columns:1fr; }
  .trainer-photo { height:220px; }
}

/* PZ POPUP FORM */
.pz-popup { position: fixed; inset:0; background:rgba(0,0,0,.65); display:none; align-items:center; justify-content:center; z-index:9999;}
.pz-popup-box { background:#121524; padding:32px; border-radius:16px; width:100%; max-width:420px; border:1px solid #242a45; color:#fff; position:relative;}
.pz-popup-box input, .pz-popup-box textarea { width:100%; margin:8px 0 14px; padding:10px 12px; border-radius:10px; border:1px solid #222742; background:#0f1322; color:#e9edf5;}
.pz-close { position:absolute; right:16px; top:16px; background:none; border:0; font-size:28px; cursor:pointer; color:#fff;}



/* ==== Unified nav styling same as semi.html ==== */

.site-header {
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:linear-gradient(to bottom, rgba(2,6,23,0.96), rgba(2,6,23,0.7), transparent);
  border-bottom:1px solid rgba(31,41,55,0.7);
}

.nav-wrap {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0;
  gap:12px;
}

.brand {
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
  color:#9ca3af;
  text-decoration:none;
}

.brand-logo {
  width:34px;
  height:34px;
  border-radius:10px;
  object-fit:cover;
}

.brand-text b {
  color:#facc15;
  font-weight:800;
}

.site-nav {
  display:flex;
  align-items:center;
  gap:16px;
  font-size:14px;
}

.site-nav a {
  position:relative;
  padding:6px 2px;
  opacity:.92;
  color:#e5e7eb;
  text-decoration:none;
}

.site-nav a::after {
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  height:2px;
  width:0;
  background:linear-gradient(to right, #facc15, #eab308);
  transition:width .18s ease-out;
}

.site-nav a:hover::after {
  width:100%;
}

.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:9px 16px;
  font-size:13px;
  font-weight:600;
  border:none;
  cursor:pointer;
  white-space:nowrap;
}

.btn-primary {
  background:linear-gradient(135deg, #facc15, #eab308);
  color:#020617;
  box-shadow:0 10px 26px rgba(234,179,8,0.35);
}

.btn-primary:hover {
  filter:brightness(1.05);
  transform:translateY(-1px);
}

.btn-ghost {
  border:1px solid rgba(148,163,184,0.7);
  background:transparent;
  color:#e5e7eb;
}

.nav-toggle {
  display:none;
  background:transparent;
  border:1px solid rgba(148,163,184,0.7);
  border-radius:999px;
  padding:4px 10px;
  color:#e5e7eb;
  font-size:18px;
  cursor:pointer;
  align-items:center;
}

/* mobile nav behavior like semi */
@media (max-width: 900px) {
  .site-header {
    background:rgba(2,6,23,0.96);
  }

  .nav-toggle {
    display:inline-flex;
  }

  .site-nav {
    position:absolute;
    inset-inline:0;
    top:100%;
    background:#020617;
    border-bottom:1px solid #1f2937;
    flex-direction:column;
    padding:8px 16px 10px;
    display:none;
  }

  .site-nav.open {
    display:flex;
  }
}
