@import url("https://fonts.googleapis.com/css2?family=Bad+Script&display=swap");
body {
  background-color: black;
  margin: 0;
  font-family: "Bad Script", cursive;
}

.main {
  height: 100vh;
  width: 100vw;
  display: flex;
  justify-content: center;
  align-items: center;
}

.heart {
  position: relative;
  height: auto;
  max-width: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  -webkit-animation: beat 2s infinite linear;
          animation: beat 2s infinite linear;
  z-index: 1;
}
.heart h1 {
  position: absolute;
  font-size: 4em;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -100%);
  color: rgb(102, 34, 34);
  filter: drop-shadow(0 0 5px rgb(164, 0, 0));
  transition: color 1s, filter 1s;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.heart img {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  cursor: pointer;
  max-width: 100%;
  max-height: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

#flowers {
  height: 100vh;
  width: 100%;
  overflow: hidden;
  position: absolute;
  top: 0;
  background: linear-gradient(130deg, rgb(28, 46, 40) 0%, rgb(13, 0, 0) 100%);
}
#flowers img {
  cursor: pointer;
  max-width: 100px;
  max-height: 100px;
  position: absolute;
  transition: top 15s ease-out, transform 15s linear, filter 2s;
  opacity: 0.8;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -moz-user-select: none;
  -o-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border: 0;
  outline: none;
}

@-webkit-keyframes beat {
  from {
    transform: scale(1);
  }
  80% {
    transform: scale(0.95);
  }
  90% {
    transform: scale(1);
  }
  95% {
    transform: scale(0.99);
  }
  to {
    transform: scale(1);
  }
}

@keyframes beat {
  from {
    transform: scale(1);
  }
  80% {
    transform: scale(0.95);
  }
  90% {
    transform: scale(1);
  }
  95% {
    transform: scale(0.99);
  }
  to {
    transform: scale(1);
  }
}
@-webkit-keyframes clickOnHeart {
  from {
    transform: scale(1);
    filter: drop-shadow(0 0 5px red);
  }
  20% {
    transform: scale(0.9);
    filter: drop-shadow(0 0 30px red);
  }
  to {
    transform: scale(1);
  }
}
@keyframes clickOnHeart {
  from {
    transform: scale(1);
    filter: drop-shadow(0 0 5px red);
  }
  20% {
    transform: scale(0.9);
    filter: drop-shadow(0 0 30px red);
  }
  to {
    transform: scale(1);
  }
}