.noscroll {
  overflow: hidden;
}

body {
  position: relative;
  z-index: 0;
  overflow-x: hidden;
  margin: 0; 
  padding: 0;
  min-height: 100vh;
}

#canvas
{
  width: 100%;
  height: 100%;
  background: #242424;
}

.potionLoader h1, .potionLoader h2, .potionLoader h3 {
  color: aliceblue;
}

.potionLoader h1 {
  position: absolute;
  top: 30px;
  color: aliceblue;
  font-size: 6rem;
}

.potionLoader h3 {
  position: absolute;
  color: aliceblue;
  font-size: 1.5rem;
  bottom: 30px;
}

.potionLoader {
  position: relative;
  top: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  background-color: #121212;
  box-sizing: border-box;
}

.potionBottle {
  position: relative;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 8px solid transparent;
  box-sizing: border-box;
  transform-origin: bottom center;
  animation: animateBottle linear 3s infinite;
}

@keyframes animateBottle {
 0% {
  transform: rotate(0deg);
  filter: hue-rotate(0deg);
 }
 25% {
  transform: rotate(15deg);
 }
 50% {
  transform: rotate(0deg);
  filter: hue-rotate(180deg);
 }
 75% {
  transform: rotate(-15deg);
 }
 100% {
  transform: rotate(0deg);
  filter: hue-rotate(0deg);
 }
}

@keyframes animateSpecular {
  0% {
   transform: translate(-50%, -50%) rotate(0deg);
  }
  25% {
   transform: translate(-50%, -50%) rotate(-15deg);
  }
  50% {
   transform: translate(-50%, -50%) rotate(0deg);
  }
  75% {
   transform: translate(-50%, -50%) rotate(15deg);
  }
  100% {
   transform: translate(-50%, -50%) rotate(0deg);
  }
 }

@keyframes animateLiquid {
  0% {
   transform: rotate(0deg);
  }
  25% {
   transform: rotate(-17deg);
  }
  50% {
   transform: rotate(0deg);
  }
  75% {
   transform: rotate(17deg);
  }
  100% {
   transform: rotate(0deg);
  }
 }

 @keyframes animateShadow {
  0% {
   transform: translateX(-50%) scale(0.95);
  }
  25% {
    transform: translateX(-40%) scale(1);
   }
  50%{
    transform: translateX(-50%) scale(0.95);
  }
  75% {
    transform: translateX(-60%) scale(1);
   }
  100% {
   transform: translateX(-50%) scale(0.95);
  }
 }


.potionBottle::before {
  content: '';
  position: absolute;
  left: 50%;
  top: -15px;
  transform: translateX(-50%);
  width: 50%;
  height: 60px;
  border: 15px solid #444;
  border-radius: 50%;
  box-sizing: border-box;
  box-shadow: 0 10px #222;
}

.potionBottle::after {
  content: '';
  position: absolute;
  width: 150px;
  height: 80px;
  top: 40%;
  left: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: rgba(255,255,255,0.05);
  transform-origin: top center;
  animation: animateSpecular linear 3s infinite;
}

.potionLiquid {
  position: absolute; 
  top: 50%;
  left: 5px;
  right: 5px;
  bottom: 5px;
  background-color: #41c1fb;
  border-bottom-left-radius: 150px;
  border-bottom-right-radius: 150px;
  filter: drop-shadow(0 0 80px #41c1fb);
  transform-origin: top center;
  animation: animateLiquid linear 3s infinite;
}

.potionLiquid::before {
  content: '';
  position: absolute;
  top: -10px;
  width: 100%;
  height: 20px;
  border-radius: 50%;
  background-color: #1fa4e0;
  filter: drop-shadow(0 0 80px #41c1fb);
}

.potionLiquidShadow {
  position: absolute;
  width: 300px;
  height: 30px;
  top: calc(50% + 150px);
  left: 50%;
  background: rgba(0,0,0,0.5);
  border-radius: 50%;
  transform: translate(-50%,-50%);
  animation: animateShadow linear 3s infinite;
}