.button {
    overflow: hidden;
}

.button .elementor-button {
  padding: 12px 44px 12px 20px;
  font-family: var(--font-stack-heading);
  font-size: 0.888rem;
  font-weight: 700;
  line-height: 1.2em;
  text-decoration: none;
  border-radius: 8px;
  transition: all 0.2s ease;
  cursor: pointer;
}

.button::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 16px;
    height: 16px;
    transform: translateY(-50%);
	pointer-events: none;

    /* Mask */
    -webkit-mask-image: url('/wp-content/uploads/2025/11/arrow-combined2.svg');
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: 200% 200%;
    -webkit-mask-position: 0% 100%;

    mask-image: url('/wp-content/uploads/2025/11/arrow-combined2.svg');
    mask-repeat: no-repeat;
    mask-size: 200% 200%;
    mask-position: 100% 0%;

    background-color: var(--joincast-black-bg);
}

.button-yellow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 24px;
  width: 12px;
  height: 12px;
  transform: translateY(-50%);

  /* Mask */
  -webkit-mask-image: url("/wp-content/uploads/2025/12/icon-star-.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  -webkit-mask-position: center;

  mask-image: url("/wp-content/uploads/2025/12/icon-star-.svg");
  mask-repeat: no-repeat;
  mask-size: contain;
  mask-position: center;

  background: linear-gradient(180deg, #9500ff 0%, #ff8000 100%);
}

.button:hover::after,
.home-prodution-text:hover .button::after {
    -webkit-animation: arrow-move .5s forwards;
    animation: arrow-move .5s forwards;
}

@-webkit-keyframes arrow-move {
    0% { -webkit-mask-position: 100% 0%; }
    100% { -webkit-mask-position: 0 100%; }
}

@keyframes arrow-move {
    0% { mask-position: 100% 0%; }
    100% { mask-position: 0 100%; }
}

.button.button-white .elementor-button {
  background-color: #ffffff;
  color: #000000;
  border: 1px solid #ffffff;
}

.button.button-black .elementor-button {
  background-color: var(--joincast-black-bg);
  color: #ffffff;
  border: 1px solid var(--joincast-black-bg);
}

.button.button-transparent .elementor-button {
  background-color: transparent;
  color: #ffffff;
  border: 1px solid white;
}

.button.button-header .elementor-button {
  height: 60px;
  display: flex;
  align-items: center;
  background-color: var(--e-global-color-primary);
}

.button.button-yellow .elementor-button {
  padding: 12px 44px;
  background: linear-gradient(93deg, #f8b500 0%, #fac800 100%);
  color: #000000;
  border: none;
}

.button.button-black::after,
.button.button-transparent::after,
.button.button-header::after {
  background-color: white;
}

.button.button-transparent:hover .elementor-button {
  background-color: rgba(255, 255, 255, 0.15);
}

.button.button-white:hover .elementor-button {
  background-color: rgba(255, 255, 255, 0.75);
}

.button.button-black:hover .elementor-button {
  background-color: rgba(var(--joincast-black-bg-rgb), 0.85);
}

.button.button-header:hover .elementor-button {
  background-color: rgb(0 95 175);
}

.button.button-yellow:hover .elementor-button {
  background: linear-gradient(93deg, #f8b500 0%, #fad000 20%);
}

@media screen and (max-width: 767px) {
  .button .elementor-button {
    padding: 10px 40px 10px 16px;
    border-radius: 4px;
  }

  .button::after {
    right: 24px;
    width: 10px;
    height: 10px;
  }
}