
.card {
  position: relative;
  border: 0;
  background: transparent;
}
.card h3 {
  display: none;
}

.card-image {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
  overflow: hidden;
  border-radius: 8px;
}

.card-image::after {
  content: "";

  position: absolute;
  top: 0;
  left: -120%;

  width: 60%;
  height: 100%;

  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.28) 50%,
    rgba(255,255,255,0) 100%
  );

  transform: skewX(-20deg);

  transition: left .7s ease;
}
.card {
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}



.card-image img {
  width: 100%;
  height: 100%;

  object-fit: cover;
  display: block;
}

.card-body {
  padding: 12px 4px 0;
}
.card.unmatched {
  opacity: .25;
  filter: grayscale(.3);

  transition:
    opacity .3s,
    filter .3s,
    transform .3s;
}
.card.unmatched:hover {
  opacity: .75;
  filter: grayscale(0);
}

.card:not(.unmatched) .card-image {
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease,
    filter 0.28s ease;

  box-shadow:
    0 0 0 rgba(0,0,0,0);
}
.card:not(.unmatched):hover .card-image {
  transform: translateY(-2px);

  box-shadow:
    0 16px 40px rgba(0,0,0,0.45),
    0 0 18px rgba(120,180,255,0.25);
}
.card:not(.unmatched):hover .card-image::after {
  left: 160%;
}