/* =========================================================
   WR Gallery Thumbs – CSS (zgodne z aktualnym HTML)
   Strzałki poza obrazem dzięki paddingowi w stage (65px).
   ========================================================= */

.wr-gal{
  width: 100%;
  display: block;
}

/* ====== STAGE (duże zdjęcie) ====== */
.wr-gal__stage{
  --wr-gal-arrow-size: 52px;
  --wr-gal-arrow-offset: 22px;
  --wr-gal-arrow-gap: 14px;
  position: relative;
  width: 100%;
  height: 675px;                 /* desktop */
  background: #fff;
  overflow: hidden;

  padding-left: 0;
  padding-right: 0;

  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

/* Obrazek zajmuje tylko "content box" (bez paddingów), więc nie nachodzi na strzałki */
.wr-gal__img{
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  display: block;
  object-fit: contain;
  transform: translateZ(0);
}

/* ====== STRZAŁKI (w paddingu, czyli poza obrazem) ====== */
.wr-gal__arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);

  border: 0;
  padding: 0;
  width: var(--wr-gal-arrow-size);
  height: var(--wr-gal-arrow-size);

  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;

  background: #2f2f2f;
  z-index: 2;

  transition: transform .15s ease, opacity .15s ease;
}

.wr-gal__arrow svg{
  stroke: #ffffff;
}

.wr-gal__arrow:hover{
  transform: translateY(calc(-50% - 1px));
}

.wr-gal__arrow:active{
  opacity: .9;
  transform: translateY(-50%);
}

.wr-gal__arrow:focus{
  outline: 2px solid rgba(255,45,122,.55);
  outline-offset: 2px;
}

.wr-gal__arrow--prev{ left: var(--wr-gal-arrow-offset); }
.wr-gal__arrow--next{ right: var(--wr-gal-arrow-offset); }

/* ====== MINIATURY ====== */
.wr-gal__thumbs{
  margin-top: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px !important;
  flex-wrap: wrap;
}

.wr-gal__thumb{
  width: 100px;
  height: 100px;
  border: 1px solid transparent;

  background: #FFF;
  cursor: pointer;
  padding: 0;
  overflow: hidden;

  display: flex;
  align-items: center;
  justify-content: center;

  transition: border-color .15s ease, transform .15s ease;
  box-sizing: border-box;
}

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

.wr-gal__thumb:hover{
  transform: translateY(-1px);
}

.wr-gal__thumb.is-active{
  border-style: solid !important;
  border-width: 1px !important;
  border-color: #ff2d7a;
}

.wr-gal__thumb:not(.is-active){
  border: 0 !important;
}

/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 1200px){
  .wr-gal__stage{
    height: 600px;
    --wr-gal-arrow-gap: 12px;
  }
  .wr-gal__thumbs{ gap: 16px !important; }
  .wr-gal__thumb{ width: 76px; height: 76px; }
}

@media (max-width: 1024px){
  .wr-gal__stage{
    --wr-gal-arrow-size: min(var(--wr-gal-arrow-size), 44px);
    --wr-gal-arrow-offset: min(var(--wr-gal-arrow-offset), 14px);
    height: 520px;
    --wr-gal-arrow-gap: 10px;
  }
  .wr-gal__thumbs{
    margin-top: 18px;
    gap: 16px !important;
  }
  .wr-gal__thumb{ width: 70px; height: 70px; }
}

@media (max-width: 768px){
  .wr-gal__stage{
    --wr-gal-arrow-size: min(var(--wr-gal-arrow-size), 38px);
    --wr-gal-arrow-offset: min(var(--wr-gal-arrow-offset), 10px);
    height: 420px;
    --wr-gal-arrow-gap: 8px;
  }
  .wr-gal__thumbs{
    margin-top: 16px;
    gap: 16px !important;
  }
  .wr-gal__thumb{ width: 62px; height: 62px; }
}

@media (max-width: 480px){
  .wr-gal__stage{
    --wr-gal-arrow-size: min(var(--wr-gal-arrow-size), 34px);
    --wr-gal-arrow-offset: min(var(--wr-gal-arrow-offset), 8px);
    height: 360px;
    --wr-gal-arrow-gap: 6px;
  }
  .wr-gal__thumb{ width: 56px; height: 56px; }
}
