/* NS Zostań Partnerem (MVP) – neon Nightskating */
.nsbp{
  padding: 64px 0;
  /* Prevent any accidental horizontal scroll on mobile */
  overflow-x: clip;
}

.nsbp__wrap{
  width: min(1200px, calc(100% - 40px));
  margin: 0 auto;
  overflow-x: clip;
}


.nsbp__kicker{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(234, 246, 255, .8);
  margin: 18px 0 18px;
}

.nsbp__kicker:before,
.nsbp__kicker:after{
  content:"";
  width: 48px;
  height: 1px;
  background: rgba(30,167,255,.7);
  box-shadow: 0 0 14px rgba(30,167,255,.55);
}


.nsbp__hero{
  display: grid;
  grid-template-columns: 3fr 5fr;
  gap: 28px;
  align-items: stretch;
}

@media (max-width: 900px){
  .nsbp__hero{ grid-template-columns: 1fr; }
}

.nsbp__title{
  margin: 0 0 10px;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.08;
  color: #EAF6FF;
}

.nsbp__text{
  margin: 0 0 18px;
  color: rgba(234, 246, 255, .86);
  font-size: 16px;
  line-height: 1.6;
  max-width: 56ch;
}

.nsbp__ctaRow{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.nsbp__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 14px;
  background: rgba(30, 167, 255, .18);
  border: 1px solid rgba(30, 167, 255, .38);
  color: #EAF6FF;
  text-decoration:none;
  font-weight: 600;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  box-shadow: 0 0 18px rgba(30, 167, 255, .14);
}

.nsbp__btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 28px rgba(30, 167, 255, .22);
  background: rgba(30, 167, 255, .22);
  border-color: rgba(30, 167, 255, .55);
}

.nsbp__btn--ghost{
  background: rgba(7, 22, 38, .45);
  border-color: rgba(234, 246, 255, .22);
}

.nsbp__right{
  min-height: 420px;
}

.nsbp__frame{
  aspect-ratio: 16 / 9;
  aspect-ratio: 16 / 9;
  height: 100%;
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  background: rgba(7, 22, 38, .55);
  border: 1px solid rgba(30, 167, 255, .28);
  box-shadow:
    0 0 0 1px rgba(7, 22, 38, .35) inset,
    0 0 26px rgba(30, 167, 255, .10);
  max-width: 100%;
}

.nsbp__frame:before{
  content:"";
  position:absolute; inset:-1px;
  border-radius: 18px;
  pointer-events:none;
  background: radial-gradient(800px 200px at 30% 0%, rgba(30,167,255,.18), transparent 55%);
}

.nsbp__frame iframe{
  width: 100% !important;
  height: 100% !important;
  min-height: 0;
  border: 0 !important;
  display:block;
  position: relative;
  z-index: 1;
}

.nsbp__placeholder{
  position: relative;
  z-index: 1;
  height: 100%;
  min-height: 420px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding: 22px;
  text-align:center;
  color: rgba(234,246,255,.86);
}

.nsbp__placeholderTitle{
  font-weight: 700;
  margin-bottom: 6px;
}

.nsbp__placeholderText{
  color: rgba(234,246,255,.68);
  font-size: 14px;
}

.nsbp__contact{
  margin-top: 22px;
}

.nsbp__card{
  position: relative;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(30, 167, 255, .26);
  background: rgba(7, 22, 38, .55);
  box-shadow: 0 0 24px rgba(30,167,255,.10);
}

.nsbp__cardGlow{
  position:absolute; inset:-2px;
  background: radial-gradient(900px 260px at 20% 10%, rgba(30,167,255,.18), transparent 55%);
  pointer-events:none;
}

.nsbp__cardBody{
  position: relative;
  padding: 18px 18px;
}

.nsbp__cardTitle{
  margin: 0 0 10px;
  font-size: 18px;
  color: #EAF6FF;
}

.nsbp__personName{
  font-weight: 700;
  color: #EAF6FF;
}

.nsbp__personRole{
  color: rgba(234,246,255,.72);
  font-size: 14px;
  margin-top: 2px;
}

.nsbp__contactLinks{
  display:flex;
  gap: 10px 18px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.nsbp__link{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  color: #EAF6FF;
  text-decoration:none;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(234,246,255,.18);
  background: rgba(7, 22, 38, .35);
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.nsbp__link:hover{
  transform: translateY(-1px);
  border-color: rgba(30, 167, 255, .45);
  box-shadow: 0 0 18px rgba(30,167,255,.14);
}

.nsbp__dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(30, 167, 255, .92);
  box-shadow: 0 0 14px rgba(30,167,255,.55);
}

.nsbp__note{
  margin-top: 12px;
  color: rgba(234,246,255,.62);
  font-size: 13px;
  line-height: 1.55;
}


/* MVP tweaks */
.nsbp__title{ display: none; }


/* Zaufali nam */
.nsbp__trusted{
  margin-top: 26px;
  padding-top: 8px;
}

.nsbp__trustedHead{
  display:flex;
  align-items:center;
  gap: 14px;
  margin: 0 0 14px;
}

.nsbp__trustedTitle{
  margin: 0;
  font-size: 18px;
  color: #EAF6FF;
  white-space: nowrap;
}

.nsbp__trustedLine{
  height: 1px;
  flex: 1;
  background: rgba(30,167,255,.28);
  box-shadow: 0 0 16px rgba(30,167,255,.18);
}

.nsbp__logos{
  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 1100px){
  .nsbp__logos{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 700px){
  .nsbp__logos{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.nsbp__logo{
  border-radius: 16px;
  border: 1px solid rgba(234,246,255,.14);
  background: rgba(7,22,38,.35);
  overflow:hidden;
  padding: 14px 12px 12px;
  text-align:center;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.nsbp__logo:hover{
  transform: translateY(-1px);
  border-color: rgba(30,167,255,.42);
  box-shadow: 0 0 18px rgba(30,167,255,.14);
}

.nsbp__logoLink{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 62px;
  text-decoration:none;
}

.nsbp__logoImg{
  max-width: 100%;
  max-height: 56px;
  width: auto;
  height: auto;
  opacity: .85;
  filter: grayscale(100%) brightness(1.15);
  transition: opacity .15s ease, filter .15s ease;
}

.nsbp__logo:hover .nsbp__logoImg{
  opacity: 1;
  filter: grayscale(0%) brightness(1.1);
}

.nsbp__logoName{
  margin-top: 8px;
  font-size: 12px;
  color: rgba(234,246,255,.72);
}


/* Mobile tuning – Canva full width */
@media (max-width: 900px){
  .nsbp__hero{ gap: 16px; }
  /* IMPORTANT: full-bleed only the map/frame, not the whole right column.
     Otherwise it causes horizontal overflow and "ucięte" pola na mobile. */
  .nsbp__right{ margin-left: 0; margin-right: 0; }
  .nsbp__frame{
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  .nsbp__frame{
    border-radius: 0;
    border-left: 0;
    border-right: 0;
  }
  .nsbp__frame:before{
    border-radius: 0;
  }
}


/* Fullscreen button */
.nsbp__fsBtn{
  position:absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(234,246,255,.18);
  background: rgba(7,22,38,.55);
  color: #EAF6FF;
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
  box-shadow: 0 0 18px rgba(30,167,255,.10);
}
.nsbp__fsBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(30,167,255,.45);
  box-shadow: 0 0 22px rgba(30,167,255,.18);
}


/* Modal */
.nsbp__modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(0,0,0,.72);}
.nsbp__modalBackdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(8px);
}
.nsbp__modalPanel{position:relative;width:min(1200px,100%);max-height:calc(100vh - 48px);border-radius:18px;border:1px solid rgba(30,167,255,.28);background:rgba(7,22,38,.85);overflow:hidden;box-shadow:0 0 32px rgba(30,167,255,.16);}
.nsbp__modalInner{width:100%;aspect-ratio:16/9;}
.nsbp__modalInner iframe{width:100%;height:100%;border:0;display:block;}
.nsbp__modalClose{
  position:absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(234,246,255,.18);
  background: rgba(7,22,38,.55);
  color: #EAF6FF;
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  display:flex;
  align-items:center;
  justify-content:center;
}
@media (max-width: 600px){
  .nsbp__modalPanel{position:relative;width:min(1200px,100%);max-height:calc(100vh - 48px);border-radius:18px;border:1px solid rgba(30,167,255,.28);background:rgba(7,22,38,.85);overflow:hidden;box-shadow:0 0 32px rgba(30,167,255,.16);}
}

.nsbp__modal[hidden]{display:none !important;}

/* Contact/Trusted styles injected by hotfix */

.nsbp__contactCard{
  width: 100%;
margin-top:18px;display:grid;grid-template-columns:1fr 260px;gap:14px;padding:16px;border-radius:18px;border:1px solid rgba(234,246,255,.14);background:rgba(7,22,38,.35);overflow:hidden;position:relative;}
.nsbp__contactGlow{position:absolute;inset:-1px;border-radius:18px;background:radial-gradient(520px 220px at 20% 0%, rgba(30,167,255,.20), transparent 60%);pointer-events:none;}
.nsbp__contactCard > *{position:relative;z-index:1;}
@media (max-width: 900px){.nsbp__contactCard{grid-template-columns:1fr;}}
.nsbp__contactTitle{margin:0 0 10px;font-size:18px;color:#EAF6FF;}
.nsbp__field{border:1px solid rgba(234,246,255,.12);background:rgba(7,22,38,.26);border-radius:14px;padding:10px 12px;margin-bottom:10px;}
.nsbp__field:last-child{margin-bottom:0;}
.nsbp__fieldLabel{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(234,246,255,.55);margin-bottom:4px;}
.nsbp__fieldValue{color:#EAF6FF;font-weight:650;}
.nsbp__plainLink{color:#EAF6FF;text-decoration:none;}
.nsbp__plainLink:hover{text-decoration:underline;}
.nsbp__contactPhotoWrap{border-radius:16px;overflow:hidden;border:1px solid rgba(234,246,255,.12);background:rgba(7,22,38,.22);display:flex;align-items:stretch;}
.nsbp__contactPhoto{width:100%;height:100%;object-fit:cover;display:block;min-height:0;}
.nsbp__trusted{margin-top:26px;padding-top:8px;}
.nsbp__trustedHead{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 0 14px;}
.nsbp__trustedTitle{margin:0;font-size:18px;color:#EAF6FF;white-space:nowrap;}
.nsbp__trustedLine{height:1px;width:clamp(60px,18vw,220px);background:rgba(30,167,255,.28);box-shadow:0 0 16px rgba(30,167,255,.18);}
.nsbp__logos{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;}
@media (max-width: 1100px){.nsbp__logos{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 700px){.nsbp__logos{grid-template-columns:1fr;}}
.nsbp__logo{border-radius:18px;border:1px solid rgba(234,246,255,.14);background:rgba(7,22,38,.35);overflow:hidden;padding:18px 16px 16px;text-align:left;}
.nsbp__logoLink{display:flex;align-items:center;justify-content:flex-start;min-height:72px;text-decoration:none;}
.nsbp__logoImg{max-width:180px;max-height:62px;width:auto;height:auto;opacity:.95;}
.nsbp__logoName{margin-top:10px;font-size:14px;color:rgba(234,246,255,.86);font-weight:750;}
.nsbp__logoDesc{margin-top:8px;font-size:13px;line-height:1.55;color:rgba(234,246,255,.66);}

/* Ukryj stary blok kontaktu (v4) */
.nsbp__card{display:none !important;}


/* === FIX: photo truly 1:1 (square) === */
@media (max-width: 1024px){
  }
@media (max-width: 860px){
  }

/* === Dynamic contact photo sizing (photo drives column width) === */
@media (max-width: 860px){
  }



/* === FINAL: photo box equals height of 3 fields (no padding) === */
@media (max-width: 860px){
  }


  .nsbp__contactPhotoRect{
    width: 140px;
    height: 140px;
  }
}


  .nsbp__contactPhotoRect{
    width: 160px;
    height: 160px;
    flex-basis: 160px;
  }
}

/* === Kontakt: zdjęcie obok + pola w kartach (FINAL COMBO) === */
.nsbp__contactMedia{
  --nsbp-photo: 200px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
}

.nsbp__contactPhotoRect{
  flex: 0 0 var(--nsbp-photo);
  width: var(--nsbp-photo);
  height: var(--nsbp-photo);
  aspect-ratio: 1 / 1;
  padding: 0;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.02);
  box-shadow: 0 10px 30px rgba(0,0,0,.22);
}

.nsbp__contactPhotoRect img{
  width: 100%;
  height: 100%;
  object-fit: contain; /* działa i dla logo, i dla zdjęcia */
  display: block;
}

.nsbp__contactFields{
  flex: 1 1 auto;
  min-width: 360px; /* zapobiega zawijaniu, które psuje proporcje */
}

@media (max-width: 980px){
  .nsbp__contactFields{ min-width: 300px; }
}

@media (max-width: 860px){
  .nsbp__contactMedia{ flex-direction: column; }
  .nsbp__contactFields{ min-width: 0; width: 100%; }
  .nsbp__contactPhotoRect{
    width: 160px;
    height: 160px;
    flex-basis: 160px;
  }
}

/* =====================================================================


/* === Kontakt: FINAL układ (foto 1:1 = wysokość 3 boxów) === */
.nsbp__contactMedia{
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  gap: 16px !important;
  align-items: stretch !important;
}

.nsbp__contactPhotoRect{
  width: auto !important;
  height: 100% !important;
  aspect-ratio: 1 / 1;
  padding: 0 !important;
  flex: initial !important;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.02);
  box-shadow: 0 10px 30px rgba(0,0,0,.22);
}

.nsbp__contactPhotoRect img{
  width: 100%;
  height: 100%;
  object-fit: cover !important;
  display: block;
}

.nsbp__contactFields{
  display: grid !important;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 12px;
  min-width: 0 !important;
  width: auto !important;
}

.nsbp__contactRow{
  margin: 0 !important;
  border: 1px solid rgba(234,246,255,.12);
  background: rgba(7,22,38,.26);
  border-radius: 14px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.nsbp__contactLabel{
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(234,246,255,.55);
  margin-bottom: 4px;
}

.nsbp__contactValue{
  color: #EAF6FF;
  font-weight: 650;
}

@media (max-width: 860px){
  .nsbp__contactMedia{ grid-template-columns: 1fr !important; }
  .nsbp__contactPhotoRect{
    width: min(320px, 70vw) !important;
    height: auto !important;
    justify-self: start;
  }
}

/* === Zaufali nam: 3 boxy w poziomie === */
.nsbp__logos{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

@media (max-width: 1100px){
  .nsbp__logos{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

@media (max-width: 700px){
  .nsbp__logos{ grid-template-columns: 1fr !important; }
}


/* === v1.3.2 FIX: remove empty space in Kontakt + stable 1:1 next to 3 boxes === */
.nsbp__contactCard{
  display:block;
}

.nsbp__contactMedia{
  --nsbp-photo: 220px;
  display:grid;
  grid-template-columns: var(--nsbp-photo) 1fr;
  gap:16px;
  align-items:start;
}

.nsbp__contactPhotoRect{
  width: var(--nsbp-photo);
  aspect-ratio: 1 / 1;
  height: auto;
  align-self:start;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.02);
  box-shadow: 0 10px 30px rgba(0,0,0,.22);
}

.nsbp__contactPhotoRect img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.nsbp__contactFields{
  display:grid;
  grid-template-rows: repeat(3, auto);
  gap:12px;
  align-content:start;
}

@media (max-width: 900px){
  .nsbp__contactMedia{
    grid-template-columns: 1fr;
  }
  .nsbp__contactPhotoRect{
    width: 100%;
  }
}

/* === v1.3.2: "Zaufali nam" – 3 boxy w poziomie === */
.nsbp__logos{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 1100px){
  .nsbp__logos{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 700px){
  .nsbp__logos{ grid-template-columns: 1fr; }
}




/* === v1.3.3 HOTFIX: mobile overflow (Kontakt) === */
.nsbp, .nsbp *{ box-sizing: border-box; }
.nsbp{ overflow-x: hidden; }

@media (max-width: 900px){
  .nsbp__wrap{ width: calc(100% - 24px); }
}

/* On mobile stack photo + fields and prevent any horizontal spill */
@media (max-width: 860px){
  .nsbp__contactMedia{
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }
  .nsbp__contactPhotoRect{
    width: 100% !important;
    max-width: 100%;
    height: auto !important;
    flex: 0 0 auto !important;
    aspect-ratio: 1 / 1;
  }
  .nsbp__contactPhotoRect img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display:block;
  }
  .nsbp__contactFields{
    min-width: 0;
  }
}
