.favourite-button {
  position: relative;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px;
  border-radius: 100%;
  overflow: hidden;
  z-index: 1;
}
.favourite-button.active .favourite-button__icon_default {
  opacity: 0;
  visibility: hidden;
}
.favourite-button.active .favourite-button__icon_active {
  opacity: 1;
  visibility: visible;
}
@media (min-width: 1024px) {
  .favourite-button:hover .favourite-button__icon_default {
    opacity: 0;
    visibility: hidden;
  }
  .favourite-button:hover .favourite-button__icon_active {
    opacity: 1;
    visibility: visible;
  }
}
.favourite-button::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: #fff;
  opacity: 0.6;
  z-index: 0;
}
.favourite-button span {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s cubic-bezier(0.3, 0.1, 0.26, 1), visibility 0.3s cubic-bezier(0.3, 0.1, 0.26, 1);
  pointer-events: none;
}
.favourite-button span svg {
  width: 20px;
  height: 20px;
}
.favourite-button__icon_default {
  position: relative;
  opacity: 1;
  visibility: visible;
}
.favourite-button__icon_active {
  position: absolute;
  opacity: 0;
  visibility: hidden;
}