/* Опишите в этом файле все keyframes для проекта и стили анимаций иконки Like.

Будьте внимательны! Для корректной работы скриптов на этом сайте нужно, чтобы в HTML некоторые классы были названы особым образом:
✦ like-icon — для svg-иконки анимированного сердца
✦ card__like-button — для кнопки Like рядом с иконкой
✦ card__icon-button — для кнопки, оборачивающей иконку
✦ is-liked — для обозначения состояния лайкнутой иконки в виде сердца
✦ button__text — для обозначения текстового элемента внутри кнопки

*/

/* Базовые состояния и переходы для частей сердца */
.like-icon .contour {
  fill: var(--contour-color);
  transition: fill 0.1s linear;
}

.like-icon .main-body {
  fill: transparent;
  transition: fill 0.3s linear;
  /* без задержки */
}

.like-icon .core {
  fill: transparent;
  transition: fill 0.3s linear 0.03s;
  /* с небольшой задержкой */
}

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

/* Состояние :hover — проявление сердцевины и затем основного тела */
.card__icon-button:hover .like-icon .core {
  fill: var(--contour-color);
  /* Отменяем базовую задержку 0.03s для core на hover */
  transition: fill 0.3s linear 0s;
}

.card__icon-button:hover .like-icon .main-body {
  fill: var(--contour-color);
  /* Добавляем задержку 0.05s, чтобы тело появлялось вслед за core */
  transition: fill 0.3s linear 0.05s;
}

/* Состояние :active — при зажатии: те же задержки, цвет — акцентный */
.card__icon-button:active .like-icon .core {
  fill: var(--contour-color);
  transition: fill 0.3s linear 0s;
}

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

/* Клик (toggle класса .is-liked на svg.like-icon) */
/* 5 шагов: 1) покой 2) заполняется сердцевина 3) заполняется тело 4) вспышка искр 5) итог — красное сердце */
.like-icon.is-liked .core {
  animation: core-fill 0.8s linear forwards;
}

.like-icon.is-liked .main-body {
  animation: main-fill 0.8s linear forwards;
}

.like-icon.is-liked .contour {
  animation: contour-fill 0.8s linear forwards;
}

/* Анимации масштаба сердца и вспышки искр при клике */
.like-icon {
  transform-origin: center;
}

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

.like-icon.is-liked .heart {
  /* Лёгкий бамп параллельно заполнению */
  animation: heart-bump 0.3s ease-in 0.2s 1 normal none;
}

.like-icon.is-liked .sparks {
  /* Вспышка искр на 4 шаге последовательности */
  animation: sparks-sequence 0.8s linear forwards;
}

@keyframes heart-bump {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.25);
  }
}

/* 5-шаговые последовательности заполнения */
@keyframes core-fill {
  0%, 19% { fill: transparent; }
  20%, 100% { fill: var(--animation-fill-color); }
}

@keyframes main-fill {
  0%, 39% { fill: transparent; }
  40%, 100% { fill: var(--animation-fill-color); }
}

@keyframes contour-fill {
  0%, 59% { fill: var(--contour-color); }
  60%, 100% { fill: var(--animation-fill-color); }
}

/* Искры: появляются на 80–90%, исчезают к финалу */
@keyframes sparks-sequence {
  0%, 79% { opacity: 0; }
  80%, 90% { opacity: 1; }
  100% { opacity: 0; }
}