/* =========================================================
   SZYBKA KONFIGURACJA (zmień tu pod swoją stronę)
   ========================================================= */
:root{
  --ag-gap: 12px;                 /* odstępy między miniaturami */
  --ag-thumb-aspect: 4/3;         /* proporcje miniatur (np. 1/1, 16/9, 4/5) */
  --ag-overlay-bg: rgba(0,0,0,.35);
  --ag-plus-size: 64px;           /* rozmiar plusa */
  --ag-hover-zoom: 1.04;          /* powiększenie miniatury na hover */
  --ag-lb-max-w: 85vw;            /* max szerokość zdjęcia w lightbox */
  --ag-lb-max-h: 85vh;            /* max wysokość zdjęcia w lightbox */
  --ag-lb-bg: rgba(0,0,0,.78);    /* tło lightboxa */
  --ag-btn-color: #39a1f1;        /* kolor przycisków */
}

/* =========================================================
   GALERIA - GRID
   ========================================================= */
.ag-gallery .ag-grid{
  display: grid;
  grid-template-columns: repeat(var(--ag-cols, 4), minmax(0, 1fr));
  gap: var(--ag-gap);
}

.ag-gallery .ag-item{
  position: relative;
  display: block;
  overflow: hidden;
  cursor: zoom-in;
  border-radius: 0;
  border: 1px solid #e6e6e6;
  box-sizing: border-box;
}

/* miniatura (img) */
.ag-gallery .ag-thumb{
  width: 100%;
  aspect-ratio: var(--ag-thumb-aspect);
  object-fit: cover;
  display: block;
  border-radius: 0;
  transition: transform .18s ease;
  border: 1px solid #e6e6e6;
  box-sizing: border-box;
}

/* hover overlay + plus */
.ag-gallery .ag-item::after{
  content: "+";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: var(--ag-plus-size);
  font-weight: 700;
  opacity: 0;
  transform: scale(.98);
  transition: opacity .18s ease, transform .18s ease;
  pointer-events: none;
  color: #fff;
  background: var(--ag-overlay-bg);
}

.ag-gallery .ag-item:hover .ag-thumb{
  transform: scale(var(--ag-hover-zoom));
}
.ag-gallery .ag-item:hover::after{
  opacity: 1;
  transform: scale(1);
}

/* =========================================================
   PORTRET – ręcznie oznaczasz kafel klasą ag-item-portrait
   ========================================================= */
/* Użycie w HTML: <a class="ag-item ag-item-portrait"> ... */
.ag-gallery .ag-item-portrait{
  --ag-thumb-aspect: 4/5; /* możesz zmienić np. 3/4 albo 2/3 */
}

/* opcjonalnie: lepszy kadr dla portretów (twarz u góry) */
.ag-gallery .ag-item-portrait .ag-thumb{
  object-position: center top;
}

/* =========================================================
   RESPONSYWNOŚĆ SIATKI
   ========================================================= */
@media (max-width: 700px){
  .ag-gallery .ag-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.ag-lightbox{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 99999;
}
.ag-lightbox.is-open{ display: block; }

.ag-lightbox .ag-lb-backdrop{
  position: absolute;
  inset: 0;
  background: var(--ag-lb-bg);
}

/* panel */
.ag-lightbox .ag-lb-panel{
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: 1fr auto;
  align-items: center;
  justify-items: center;
  padding: 24px;
  box-sizing: border-box;
}

/* stage – centrowanie obrazka i tytułu */
.ag-lightbox .ag-lb-stage{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  text-align: center;
  touch-action: none;      /* jeśli masz swipe w JS */
  user-select: none;
  -webkit-user-select: none;
}

.ag-lightbox .ag-lb-img{
  max-width: var(--ag-lb-max-w);
  max-height: var(--ag-lb-max-h);
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 0;
  background: rgba(255,255,255,.06);
  display: block;
  margin: 0 auto;
}

.ag-lightbox .ag-lb-title{
  margin-top: 14px;
  max-width: var(--ag-lb-max-w);
  color: #fff;
  font-size: 16px;
  line-height: 1.35;
  text-align: center;
  opacity: .95;
  word-break: break-word;
  margin-left: auto;
  margin-right: auto;
}

/* =========================================================
   PRZYCISKI LIGHTBOX
   ========================================================= */
.ag-lightbox .ag-lb-btn{
  position: absolute;
  border: 0;
  border-radius: 0;
  width: 44px;
  height: 44px;
  cursor: pointer;
  background: var(--ag-btn-color);
  color: #fff;
  font-size: 22px;
  display: grid;
  place-items: center;
  z-index: 5;
}

/* Desktop: strzałki na środku */
.ag-lightbox .ag-lb-prev,
.ag-lightbox .ag-lb-next{
  top: 50%;
  transform: translateY(-50%);
}

.ag-lightbox .ag-lb-prev{ left: 18px; }
.ag-lightbox .ag-lb-next{ right: 18px; }

/* X zawsze u góry */
.ag-lightbox .ag-lb-close{
  top: 18px;
  right: 18px;
  transform: none;
  font-size: 20px;
}

/* =========================================================
   MOBILE – przyciski na górze
   ========================================================= */
@media (max-width: 700px){
  .ag-lightbox .ag-lb-panel{
    padding-top: 70px; /* miejsce na przyciski */
  }

  .ag-lightbox .ag-lb-btn{
    top: 12px;
    transform: none;
  }

  .ag-lightbox .ag-lb-prev{ left: 12px; }
  .ag-lightbox .ag-lb-next{ right: 64px; } /* zostawia miejsce na X */
  .ag-lightbox .ag-lb-close{ right: 12px; top: 12px; }
}

.ag-subsection {
	padding-top: 50px;
}
.ag-subtext {
	padding-bottom: 30px;
	text-align: justify;
}
.ag-gallery {
	text-align: justify;
}