.etafe-button {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 25px;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.2;
  transition: 0.3s;
  border-radius: 30px;
  overflow: hidden;
  --text-color: var(--etafePrimaryFgColor);
}
.etafe-button.style-default {
  color: var(--text-color);
  background-color: var(--etafePrimaryColor);
}
.etafe-button.style-default:hover {
  background-color: var(--etafeSecondaryColor);
  --text-color: var(--etafeSecondaryFgColor);
}
.etafe-button.style-gradient {
  color: var(--text-color);
}
.etafe-button.style-gradient::before, .etafe-button.style-gradient::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  transition: 0.3s;
}
.etafe-button.style-gradient::before {
  background: linear-gradient(45deg, var(--etafeSecondaryColor) 0%, var(--etafePrimaryColor) 100%);
  opacity: 1;
  visibility: visible;
}
.etafe-button.style-gradient::after {
  background: linear-gradient(90deg, var(--etafePrimaryColor) 0%, var(--etafeSecondaryColor) 100%);
  opacity: 0;
  visibility: hidden;
}
.etafe-button.style-gradient:hover::before {
  opacity: 0;
  visibility: hidden;
}
.etafe-button.style-gradient:hover::after {
  opacity: 1;
  visibility: visible;
}
.etafe-button .button-text,
.etafe-button .button-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.etafe-button .button-icon {
  transition: 0.3s;
}
.etafe-button.icon-anim-flip-top .button-icon, .etafe-button.icon-anim-flip-right .button-icon, .etafe-button.icon-anim-flip-bottom .button-icon, .etafe-button.icon-anim-flip-left .button-icon, .etafe-button.icon-anim-flip-top-right .button-icon, .etafe-button.icon-anim-flip-top-left .button-icon {
  position: relative;
  width: 1em;
  height: 1em;
  overflow: hidden;
}
.etafe-button.icon-anim-flip-top .button-icon > *, .etafe-button.icon-anim-flip-right .button-icon > *, .etafe-button.icon-anim-flip-bottom .button-icon > *, .etafe-button.icon-anim-flip-left .button-icon > *, .etafe-button.icon-anim-flip-top-right .button-icon > *, .etafe-button.icon-anim-flip-top-left .button-icon > * {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s;
}
.etafe-button.icon-anim-flip-top .button-icon > *:last-child {
  transform: translateY(150%);
}
.etafe-button.icon-anim-flip-top:hover .button-icon > * {
  transform: translateY(-150%);
}
.etafe-button.icon-anim-flip-top:hover .button-icon > *:last-child {
  transform: translateY(0);
}
.etafe-button.icon-anim-flip-right .button-icon > *:last-child {
  transform: translateX(-150%);
}
.etafe-button.icon-anim-flip-right:hover .button-icon > * {
  transform: translateX(150%);
}
.etafe-button.icon-anim-flip-right:hover .button-icon > *:last-child {
  transform: translateX(0);
}
.etafe-button.icon-anim-flip-bottom .button-icon > *:last-child {
  transform: translateY(-150%);
}
.etafe-button.icon-anim-flip-bottom:hover .button-icon > * {
  transform: translateY(150%);
}
.etafe-button.icon-anim-flip-bottom:hover .button-icon > *:last-child {
  transform: translateY(0);
}
.etafe-button.icon-anim-flip-left .button-icon > *:last-child {
  transform: translateX(150%);
}
.etafe-button.icon-anim-flip-left:hover .button-icon > * {
  transform: translateX(-150%);
}
.etafe-button.icon-anim-flip-left:hover .button-icon > *:last-child {
  transform: translateX(0);
}
.etafe-button.icon-anim-flip-top-right .button-icon > *:last-child {
  transform: translate(-150%, 150%);
}
.etafe-button.icon-anim-flip-top-right:hover .button-icon > * {
  transform: translate(150%, -150%);
}
.etafe-button.icon-anim-flip-top-right:hover .button-icon > *:last-child {
  transform: translate(0);
}
.etafe-button.icon-anim-flip-top-left .button-icon > *:last-child {
  transform: translate(-150%, -150%);
}
.etafe-button.icon-anim-flip-top-left:hover .button-icon > * {
  transform: translate(150%, 150%);
}
.etafe-button.icon-anim-flip-top-left:hover .button-icon > *:last-child {
  transform: translate(0);
}
.etafe-button.icon-anim-rotate-90 .button-icon > * {
  transition: 0.3s;
}
.etafe-button.icon-anim-rotate-90:hover .button-icon > * {
  transform: rotate(90deg);
}
.etafe-button.text-anim-flip-top .button-text, .etafe-button.text-anim-flip-bottom .button-text {
  overflow: hidden;
  color: transparent;
}
.etafe-button.text-anim-flip-top .button-text::before, .etafe-button.text-anim-flip-top .button-text::after, .etafe-button.text-anim-flip-bottom .button-text::before, .etafe-button.text-anim-flip-bottom .button-text::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  transition: 0.3s;
  color: var(--text-color);
}
.etafe-button.text-anim-flip-top .button-text::before {
  transform: translateY(150%);
}
.etafe-button.text-anim-flip-top .button-text::after {
  transform: translateY(0);
}
.etafe-button.text-anim-flip-top:hover .button-text::before {
  transform: translateY(0);
}
.etafe-button.text-anim-flip-top:hover .button-text::after {
  transform: translateY(-150%);
}
.etafe-button.text-anim-flip-bottom .button-text::before {
  transform: translateY(-150%);
}
.etafe-button.text-anim-flip-bottom .button-text::after {
  transform: translateY(0);
}
.etafe-button.text-anim-flip-bottom:hover .button-text::before {
  transform: translateY(0);
}
.etafe-button.text-anim-flip-bottom:hover .button-text::after {
  transform: translateY(150%);
}