/* Animation keyframes */
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes float {
  0% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0px);
  }
}

@keyframes bounce {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}

@keyframes rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes sway {
  0%,
  100% {
    transform: rotate(-5deg);
  }
  50% {
    transform: rotate(5deg);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes draw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes bottleWobble {
  0%,
  100% {
    transform: rotateZ(0deg);
  }
  25% {
    transform: rotateZ(5deg);
  }
  75% {
    transform: rotateZ(-5deg);
  }
}

@keyframes fillGlass {
  from {
    height: 0%;
  }
  to {
    height: 40%;
  }
}

@keyframes armWaveLeft {
  0%,
  100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(45deg);
  }
}

@keyframes armWaveRight {
  0%,
  100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-45deg);
  }
}

@keyframes legKickLeft {
  0%,
  100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-20deg);
  }
}

@keyframes legKickRight {
  0%,
  100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(20deg);
  }
}

@keyframes dancerJump {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

@keyframes dancerSpin {
  0%,
  100% {
    transform: rotateY(0deg);
  }
  50% {
    transform: rotateY(180deg);
  }
}

@keyframes pinBounce {
  0%,
  100% {
    transform: translate(-50%, -100%) rotate(-45deg);
  }
  50% {
    transform: translate(-50%, -120%) rotate(-45deg);
  }
}

/* Georgian Cartoon Animation Keyframes */
@keyframes dancerMove1 {
  0% {
    transform: translateX(0) translateY(0);
  }
  25% {
    transform: translateX(-20px) translateY(-5px);
  }
  50% {
    transform: translateX(-40px) translateY(0);
  }
  75% {
    transform: translateX(-20px) translateY(-5px);
  }
  100% {
    transform: translateX(0) translateY(0);
  }
}

@keyframes dancerMove2 {
  0% {
    transform: translateX(0) translateY(0);
  }
  25% {
    transform: translateX(10px) translateY(-10px);
  }
  50% {
    transform: translateX(20px) translateY(0);
  }
  75% {
    transform: translateX(10px) translateY(-10px);
  }
  100% {
    transform: translateX(0) translateY(0);
  }
}

@keyframes dancerMove3 {
  0% {
    transform: translateX(0) translateY(0) rotate(0deg);
  }
  25% {
    transform: translateX(15px) translateY(-5px) rotate(5deg);
  }
  50% {
    transform: translateX(30px) translateY(0) rotate(0deg);
  }
  75% {
    transform: translateX(15px) translateY(-5px) rotate(-5deg);
  }
  100% {
    transform: translateX(0) translateY(0) rotate(0deg);
  }
}

@keyframes characterFloat {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
}

@keyframes characterDance {
  0%, 100% {
    transform: rotate(-5deg);
  }
  25% {
    transform: translateY(-10px) rotate(0deg);
  }
  50% {
    transform: rotate(5deg);
  }
  75% {
    transform: translateY(-5px) rotate(0deg);
  }
}

@keyframes characterPlay {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  25% {
    transform: translateY(-5px) rotate(-3deg);
  }
  50% {
    transform: translateY(0) rotate(0deg);
  }
  75% {
    transform: translateY(-5px) rotate(3deg);
  }
}

@keyframes chefHatBob {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(-5px);
  }
}

@keyframes chefArmLeft {
  0%, 100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-30deg);
  }
}

@keyframes chefArmRight {
  0%, 100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(30deg);
  }
}

/* Steam animation */
.steam {
  position: absolute;
  height: 50px;
  width: 10px;
  border-radius: 50%;
  background-color: #fff;
  opacity: 0;
  filter: blur(8px);
  animation: steam 4s linear infinite;
}

.steam-one {
  top: 0px;
  left: 40%;
  animation-delay: 0.5s;
}

.steam-two {
  top: 0px;
  left: 50%;
  animation-delay: 1s;
}

.steam-three {
  top: 0px;
  left: 60%;
  animation-delay: 1.5s;
}

.steam-four {
  top: 0px;
  left: 45%;
  animation-delay: 2s;
}

@keyframes steam {
  0% {
    transform: translateY(0) scale(1);
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  50% {
    transform: translateY(-50px) scale(1.5);
  }
  95% {
    opacity: 0;
  }
  100% {
    transform: translateY(-80px) scale(2);
    opacity: 0;
  }
}

/* Animated text */
.animated-text {
  position: relative;
  display: inline-block;
  overflow: hidden;
}

.animated-text::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 10px;
  background-color: rgba(230, 183, 108, 0.4);
  bottom: 5px;
  left: 0;
  z-index: -1;
  transform: skew(-12deg);
}

.animated-text::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: var(--background-color);
  animation: revealText 1.5s cubic-bezier(0.77, 0, 0.18, 1) forwards;
}

@keyframes revealText {
  0% {
    width: 100%;
  }
  100% {
    width: 0;
  }
}

/* Animated button */
.animated-button {
  opacity: 0;
  animation: fadeInUp 1s ease 0.5s forwards;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Hero subtitle animation */
.hero-subtitle {
  opacity: 0;
  animation: fadeInUp 1s ease 0.3s forwards;
}