:root {
  /* --bg-color: #345DA1; */
}

.cards {
  display: flex;
}

.cards:hover > .card::after {
  opacity: 1;
}
.card {
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}

.card:hover::before {
  opacity: 1;
  pointer-events: none;
}

.card::before,
.card::after {
  border-radius: inherit;
  content: "";
  height: 100%;
  left: 0px;
  opacity: 0;
  position: absolute;
  top: 0px;
  transition: opacity 500ms;
  width: 100%;
}

.card::before {
  background: radial-gradient(
    800px circle at var(--mouse-x) var(--mouse-y),
    rgba(255, 255, 255, 0.15),
    transparent 40%
  );
  z-index: 3;
}

.card::after {
  background: radial-gradient(
    600px circle at var(--mouse-x) var(--mouse-y),
    rgba(255, 255, 255, 0.5),
    transparent 40%
  );
  z-index: 1;
}

.card > .card-content {
  background-color: var(--bg-color);
  border-radius: inherit;
  display: flex;
  flex-grow: 1;
  inset: 1.2px;
  /* padding: 10px; */
  position: absolute;
  z-index: 2;
}
