.like-icon {
  inline-size: 39px;
  block-size: 36px;
}

.like-icon .heart {
  transform-origin: center;
}

.like-icon .core,
.like-icon .main-body {
  fill: transparent;
}

.like-icon .contour {
  fill: var(--contour-color);
  transition: fill 0.1s linear;
}

.like-icon .core {
  transition: fill 0.3s linear 0.03s;
}

.like-icon .main-body {
  transition: fill 0.3s linear;
}

.like-icon .sparks {
  fill: var(--animation-fill-color);
  opacity: 0;
}

.card__icon-button:hover .like-icon .core {
  fill: var(--contour-color);
  transition-delay: 0s;
}

.card__icon-button:hover .like-icon .main-body {
  fill: var(--contour-color);
  transition-delay: 0.05s;
}

.card__icon-button:not(:hover) .like-icon .core {
  transition-delay: 0.03s;
}

.card__icon-button:not(:hover) .like-icon .main-body {
  transition-delay: 0s;
}

.card__icon-button:active .like-icon .core,
.card__icon-button:active .like-icon .main-body {
  fill: var(--animation-fill-color);
}

.like-icon.is-liked .core,
.like-icon.is-liked .main-body {
  fill: var(--animation-fill-color);
}

.like-icon.is-liked .main-body {
  transition-delay: 0.05s;
}

.like-icon.is-liked .contour {
  fill: var(--animation-fill-color);
  transition-delay: 0.06s;
  transition-duration: 0.3s;
}

.like-icon:not(.is-liked) .contour {
  transition-delay: 0s;
  transition-duration: 0.1s;
}

.like-icon.is-liked .heart {
  animation: scale-heart 0.3s ease-in 0.1s 1;
}

.like-icon.is-liked .sparks {
  animation: show-sparks 0.3s ease-in 0.3s 1;
}

@keyframes scale-heart {
  from {
    transform: scale(1);
  }

  50% {
    transform: scale(1.25);
  }

  to {
    transform: scale(1);
  }
}

@keyframes show-sparks {
  from {
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}
