/* GRID */
.upg-grid {
  display: grid;
  max-width: 1140px;
  margin: auto;
  gap: 100px;
  padding-bottom: 250px;
}

/* ===============================
   COLUNAS DESKTOP
================================ */
.upg-grid.cols-d-1 {
  grid-template-columns: 1fr;
  justify-items: center;
}

.upg-grid.cols-d-2 {
  grid-template-columns: repeat(2, 1fr);
}

.upg-grid.cols-d-3 {
  grid-template-columns: repeat(3, 1fr);
}

.upg-grid.cols-d-4 {
  grid-template-columns: repeat(4, 1fr);
}

/* ===============================
   CARD
================================ */
.upg-card {
  position: relative;
  will-change: transform;
  width: 100%;
  max-width: 330px;
}

/* ===============================
   MEDIA WRAPPER QUADRADO
================================ */
.upg-card-media {
  position: relative;
  width: 100%;
  padding-top: 100%;
  overflow: visible;
}

/* ===============================
   IMAGEM DESTACADA
================================ */
.upg-card-cover {
  position: absolute;
  inset: 0;
  z-index: 2;
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

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

/* ===============================
   IMAGEM OCULTA
================================ */
.upg-card-bg {
  position: absolute;
  top: 0;
  left: 7%;
  width: 100%;
  height: 100%;
  z-index: 1;
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

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

/* ===============================
   HOVER
================================ */
.upg-card:hover .upg-card-bg {
  transform: translateX(60px);
}

.upg-card:hover .upg-card-cover {
  transform: translateX(-30px);
}

/* ===============================
   TEXTO
================================ */
.upg-card-content {
  margin-top: 20px;
}

.upg-card-title {
  margin: 0;
  font-size: 18px;
}

.upg-card-stage {
  display: block;
  font-size: 12px;
  opacity: 0.6;
}

/* ===============================
   OFFSETS DESKTOP
================================ */
/* 1 COLUNA */
.upg-grid.cols-d-1 .upg-card {
  transform: none !important;
}

/* 2 COLUNAS */
.upg-grid.cols-d-2 .upg-card:nth-child(2n + 1) {
  transform: translateY(150px);
}

.upg-grid.cols-d-2 .upg-card:nth-child(2n + 2) {
  transform: translateY(300px);
}

/* 3 COLUNAS */
.upg-grid.cols-d-3 .upg-card:nth-child(3n + 1) {
  transform: translateY(150px);
}

.upg-grid.cols-d-3 .upg-card:nth-child(3n + 2) {
  transform: translateY(300px);
}

.upg-grid.cols-d-3 .upg-card:nth-child(3n + 3) {
  transform: translateY(100px);
}

/* 4 COLUNAS */
.upg-grid.cols-d-4 .upg-card:nth-child(4n + 1) {
  transform: translateY(150px);
}

.upg-grid.cols-d-4 .upg-card:nth-child(4n + 2) {
  transform: translateY(300px);
}

.upg-grid.cols-d-4 .upg-card:nth-child(4n + 3) {
  transform: translateY(100px);
}

.upg-grid.cols-d-4 .upg-card:nth-child(4n + 4) {
  transform: translateY(200px);
}

/* ===============================
   TABLET
================================ */
@media (max-width: 1024px) {
  .upg-grid.cols-t-1 {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .upg-grid.cols-t-2 {
    grid-template-columns: repeat(2, 1fr);
  }

  .upg-grid.cols-t-3 {
    grid-template-columns: repeat(3, 1fr);
  }

  .upg-grid.cols-t-4 {
    grid-template-columns: repeat(4, 1fr);
  }

  /* OFFSETS TABLET */
  .upg-grid.cols-t-1 .upg-card {
    transform: none !important;
  }

  .upg-grid.cols-t-2 .upg-card:nth-child(2n + 1) {
    transform: translateY(150px);
  }

  .upg-grid.cols-t-2 .upg-card:nth-child(2n + 2) {
    transform: translateY(300px);
  }
}

/* ===============================
   MOBILE
================================ */
@media (max-width: 640px) {
  .upg-grid.cols-m-1 {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .upg-grid.cols-m-2 {
    grid-template-columns: repeat(2, 1fr);
  }

  .upg-grid.cols-m-3 {
    grid-template-columns: repeat(3, 1fr);
  }

  .upg-grid.cols-m-4 {
    grid-template-columns: repeat(4, 1fr);
  }

  /* OFFSETS MOBILE */
  .upg-grid.cols-m-1 .upg-card {
    transform: none !important;
  }
}
