/* POLYMAINT Gallery - Frontend */

.pms-gallery{
  --pms-blue: var(--pms-blue, #0C253C);
  --pms-red: var(--pms-red, #DD343B);
  --pms-bg: var(--pms-card, rgba(255,255,255,0.06));
  --pms-bg2: var(--pms-card2, rgba(255,255,255,0.04));
  --pms-text: var(--pms-text, rgba(255,255,255,0.92));
  --pms-muted: var(--pms-muted, rgba(255,255,255,0.72));
  --pms-border: var(--pms-border, rgba(255,255,255,0.12));
  --pms-shadow: var(--pms-shadow, 0 14px 40px rgba(0,0,0,0.35));

  --cols-desktop: 3;
  --cols-mobile: 2;
  --gap: 14px;
  --radius: 18px;
}

.pms-gallery .pms-gallery__grid{
  display: grid;
  grid-template-columns: repeat(var(--cols-mobile), minmax(0, 1fr));
  gap: var(--gap);
}

@media (min-width: 782px){
  .pms-gallery .pms-gallery__grid{
    grid-template-columns: repeat(var(--cols-desktop), minmax(0, 1fr));
  }
}

.pms-gallery .pms-gallery__item{
  margin: 0;
}

.pms-gallery .pms-gallery__link,
.pms-gallery .pms-gallery__thumbwrap{
  display: block;
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  background: linear-gradient(180deg, var(--pms-bg), var(--pms-bg2));
  border: 1px solid var(--pms-border);
  box-shadow: var(--pms-shadow);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.pms-gallery .pms-gallery__thumbwrap{
  box-shadow: var(--pms-shadow);
}

.pms-gallery[data-aspect="1-1"] .pms-gallery__thumbwrap{ aspect-ratio: 1 / 1; }
.pms-gallery[data-aspect="4-3"] .pms-gallery__thumbwrap{ aspect-ratio: 4 / 3; }
.pms-gallery[data-aspect="16-9"] .pms-gallery__thumbwrap{ aspect-ratio: 16 / 9; }

.pms-gallery .pms-gallery__img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform 260ms ease, filter 260ms ease;
}

.pms-gallery[data-hoverzoom="1"] .pms-gallery__item:hover .pms-gallery__img{
  transform: scale(1.04);
  filter: saturate(1.05);
}

.pms-gallery .pms-gallery__openhint{
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: var(--pms-text);
  background: rgba(12, 37, 60, 0.55);
  border: 1px solid var(--pms-border);
  box-shadow: 0 8px 20px rgba(0,0,0,0.35);
  pointer-events: none;
}

.pms-gallery .pms-gallery__link:hover .pms-gallery__openhint{
  border-color: rgba(221, 52, 59, 0.55);
}

.pms-gallery .pms-gallery__caption{
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.35;
  color: var(--pms-muted);
  padding-left: 2px;
}



/* Layout: Masonry */
.pms-gallery[data-layout="masonry"] .pms-gallery__grid{
  display: block;
  column-count: var(--cols-mobile);
  column-gap: var(--gap);
}

@media (min-width: 782px){
  .pms-gallery[data-layout="masonry"] .pms-gallery__grid{
    column-count: var(--cols-desktop);
  }
}

.pms-gallery[data-layout="masonry"] .pms-gallery__item{
  display: inline-block;
  width: 100%;
  break-inside: avoid;
  margin: 0 0 var(--gap);
}

.pms-gallery[data-layout="masonry"] .pms-gallery__thumbwrap{
  aspect-ratio: auto !important;
}

.pms-gallery[data-layout="masonry"] .pms-gallery__img{
  height: auto;
  object-fit: cover;
}

/* Layout: Carousel */
.pms-gallery[data-layout="carousel"] .pms-carousel{
  position: relative;
  width: 100%;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__viewport{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: linear-gradient(180deg, var(--pms-bg), var(--pms-bg2));
  border: 1px solid var(--pms-border);
  box-shadow: var(--pms-shadow);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  height: var(--carousel-h, 420px);
}

.pms-gallery[data-layout="carousel"] .pms-carousel__track{
  display: flex;
  height: 100%;
  transform: translateX(0%);
  transition: transform 420ms ease;
  will-change: transform;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__slide{
  flex: 0 0 100%;
  height: 100%;
  margin: 0;
  position: relative;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__link{
  display: block;
  height: 100%;
  position: relative;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform 260ms ease, filter 260ms ease;
}

.pms-gallery[data-layout="carousel"][data-hoverzoom="1"] .pms-carousel__slide:hover .pms-carousel__img{
  transform: scale(1.03);
  filter: saturate(1.05);
}

.pms-gallery[data-layout="carousel"] .pms-carousel__btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.25);
  color: #fff;
  cursor: pointer;
  z-index: 2;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__btn:hover{
  transform: translateY(-50%) translateY(-1px);
  border-color: rgba(221,52,59,0.55);
  background: rgba(221,52,59,0.12);
}

.pms-gallery[data-layout="carousel"] .pms-carousel__btn:active{
  transform: translateY(-50%) translateY(0px);
}

.pms-gallery[data-layout="carousel"] .pms-carousel__btn--prev{ left: 14px; }
.pms-gallery[data-layout="carousel"] .pms-carousel__btn--next{ right: 14px; }

.pms-gallery[data-layout="carousel"][data-carousel-arrows="0"] .pms-carousel__btn{ display: none; }

.pms-gallery[data-layout="carousel"] .pms-carousel__dots{
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: 10px 0 0;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__dot{
  appearance: none;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.85);
  width: 28px;
  height: 28px;
  border-radius: 999px;
  cursor: pointer;
  line-height: 1;
  font-size: 18px;
  display: grid;
  place-items: center;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
}

.pms-gallery[data-layout="carousel"] .pms-carousel__dot:hover{
  transform: translateY(-1px);
  border-color: rgba(221,52,59,0.55);
  background: rgba(221,52,59,0.10);
}

.pms-gallery[data-layout="carousel"] .pms-carousel__dot.is-active{
  border-color: rgba(221,52,59,0.75);
  background: rgba(221,52,59,0.16);
}

.pms-gallery[data-layout="carousel"][data-carousel-dots="0"] .pms-carousel__dots{ display: none; }


/* Lightbox */
.pms-lightbox{
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(0,0,0,0.65);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.pms-lightbox.is-open{ display: flex; }

.pms-lightbox__panel{
  width: min(1100px, 100%);
  max-height: calc(100vh - 40px);
  background: linear-gradient(180deg, rgba(12,37,60,0.85), rgba(12,37,60,0.68));
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 22px;
  box-shadow: 0 22px 80px rgba(0,0,0,0.55);
  overflow: hidden;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

.pms-lightbox__top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 10px 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}

.pms-lightbox__title{
  color: var(--pms-text);
  font-size: 14px;
  opacity: 0.92;
  margin: 0;
}

.pms-lightbox__btn{
  appearance: none;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.06);
  color: var(--pms-text);
  border-radius: 999px;
  height: 36px;
  padding: 0 12px;
  cursor: pointer;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
}

.pms-lightbox__btn:hover{
  transform: translateY(-1px);
  border-color: rgba(221,52,59,0.55);
  background: rgba(221,52,59,0.10);
}

.pms-lightbox__btn:active{ transform: translateY(0px); }

.pms-lightbox__stage{
  position: relative;
  overflow: hidden;
  background: rgba(0,0,0,0.15);
  display: grid;
  place-items: center;
}

.pms-lightbox__img{
  max-width: 100%;
  max-height: calc(100vh - 210px);
  transform-origin: 50% 50%;
  will-change: transform;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

.pms-lightbox__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.25);
  color: #fff;
  cursor: pointer;
}

.pms-lightbox__nav:hover{ border-color: rgba(221,52,59,0.55); }

.pms-lightbox__nav--prev{ left: 14px; }
.pms-lightbox__nav--next{ right: 14px; }

.pms-lightbox__bottom{
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-top: 1px solid rgba(255,255,255,0.12);
}

.pms-lightbox__caption{
  color: rgba(255,255,255,0.82);
  font-size: 13px;
  margin: 0;
}

.pms-lightbox__tools{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .pms-gallery .pms-gallery__img{ transition: none; }
  .pms-lightbox__btn{ transition: none; }
}
