:root{
  --g-dark:#0b1b12;
  --g-emerald:#1a472a;
  --g-emerald-2:#2e7d32;
  --g-mint:#e8f5e9;
  --g-gold:#ffc107;
  --g-text:#20302a;
  --g-white:#fff;
}

/* ===== Gallery Section ===== */
/* .ug-gallery{
  padding: 70px 16px 90px;
} */

/* .ug-wrap{
  max-width: 1320px;
  margin: auto;
} */

/* ===== Grid ===== */
.ug-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

/* ===== Card ===== */
.ug-card{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  height: 280px;
  cursor: pointer;
  box-shadow: 0 16px 36px rgba(0,0,0,0.12);
  transform: translateY(18px);
  opacity: 0;
  transition: transform .6s ease, opacity .6s ease, box-shadow .25s ease;
  outline: none;
  isolation: isolate;
}

.ug-card.is-visible{
  transform: translateY(0);
  opacity: 1;
}

.ug-card img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .7s ease;
}

.ug-card::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to top, rgba(0,0,0,0.72), rgba(0,0,0,0.22), transparent);
  z-index: 1;
}

.ug-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(255,193,7,.35), rgba(46,125,50,.35), rgba(255,255,255,.12));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity .25s ease;
  z-index: 2;
  pointer-events: none;
}

.ug-meta{
  position:absolute;
  bottom: 14px;
  left: 14px;
  right: 14px;
  z-index: 3;
}

.ug-meta h3{
  margin:0;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 700;
  color: #add5ea;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.ug-card:hover{
  box-shadow: 0 22px 48px rgba(0,0,0,0.18);
}

.ug-card:hover img{
  transform: scale(1.10);
}

.ug-card:hover::before,
.ug-card:focus-visible::before{
  opacity: 1;
}

.ug-card:focus-visible{
  box-shadow: 0 24px 55px rgba(0,0,0,0.22);
}

/* ===== Lightbox ===== */
.ug-lightbox{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.72);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 16px;
  opacity: 0;
  visibility: hidden;
  transition: .25s ease;
  z-index: 9999;
}

.ug-lightbox.is-open{
  opacity: 1;
  visibility: visible;
}

.ug-preview{
  width: min(980px, 100%);
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  transform: scale(.98);
  opacity: 0;
  transition: .25s ease;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
  position: relative;
}

.ug-lightbox.is-open .ug-preview{
  transform: scale(1);
  opacity: 1;
}

.ug-preview img{
  width: 100%;
  max-height: 74vh;
  object-fit: contain;
  background: #0b0f0d;
}

.ug-preview figcaption{
  padding: 14px 16px 16px;
  border-top: 1px solid rgba(0,0,0,0.08);
}

.ug-preview figcaption h3{
  margin: 0;
  color: #0f2d1c;
  font-weight: 800;
  font-size: 16px;
}

.ug-close{
  position: fixed;
  top: 18px;
  right: 18px;
  background: rgba(255,255,255,0.92);
  border: none;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  font-size: 18px;
  cursor: pointer;
  box-shadow: 0 10px 25px rgba(0,0,0,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index: 10000;
}

.ug-nav{
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 10px 25px rgba(0,0,0,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 20px;
  z-index: 10000;
}

.ug-prev{ left: 18px; }
.ug-next{ right: 18px; }

/* ===== Responsive ===== */
@media (max-width: 1199px){
  .ug-grid{
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 991px){
  .ug-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }

  .ug-card{
    height: 240px;
  }

  .ug-wrap{
    padding: 0px 25px !important;
  }
}

@media (max-width: 575px){
  .ug-grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .ug-card{
    height: 230px;
    border-radius: 16px;
  }

  .ug-card::before{
    border-radius: 16px;
  }

  .ug-nav{
    display: none;
  }
}

.no-data-wrapper {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 300px;
    grid-column: 1 / -1;
}
.no-data-box {
    text-align: center;
}
.no-data-box i {
    font-size: 50px;
    color: #3062a5;
    margin-bottom: 15px;
}
.no-data-box h3 {
    font-size: 22px;
    font-weight: 600;
    color: #1e293b;
    margin-bottom: 6px;
}
.no-data-box p {
    font-size: 14px;
    color: #94a3b8;
    margin: 0;
}