.card.card--icon {
  --image-active: #00000080;
  --image-hover: #00000040;
  display: grid;
  align-items: flex-start;
  text-decoration: none;
  gap: 0.875rem;
}

  .card.card--icon:hover .image-wrapper::after {
      background: var(--image-hover);
    }

  .card.card--icon:active .image-wrapper::after {
      background: var(--image-active);
    }

  .card.card--icon .card--content h3 {
      font-size: 1.5rem;
      margin: 0;
      padding: 0;
    }

  .card.card--icon .image-wrapper {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1;
    height: 100%;
  }

  .card.card--icon .image-wrapper img {
      margin: 0;
    }

  .card.card--icon .image-wrapper::after {
      content: "";
      position: absolute;
      height: 100%;
      width: 100%;
      top: 0;
      left: 0;
      background: transparent;
      transition: background 300ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
    }
