.mh-button {
  -webkit-appearance: none;
  background-color: transparent;
  border: var(--mh-border-color) solid transparent;
  border-radius: var(--button-border-radius);
  color: inherit;
  cursor: pointer;
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1;
  outline: 0;
  padding: 0.65em 0.9rem;
  text-decoration: none;
  text-transform: none;
  transition: all 0.2s ease-in-out;
}

.mh-button:hover {
  text-decoration: none;
  transition: all 0.1s ease-in-out;
}

.mh-button:focus {
  box-shadow: 0 0 0 3px rgba(var(--mh-color-primary, 0, 0, 0), 0.4);
  text-decoration: none;
}

.mh-button--unstyled {
  background: transparent !important;
  border-radius: 0;
  padding: 0;
}

.mh-button--medium {
  font-size: .95rem;
  padding: 1em 1.5rem;
}

.mh-button--large {
  font-size: 1rem;
  padding: 1.2em 2rem;
}

.mh-button--larger {
  font-size: 1rem;
  padding: 1.5em 2.5rem;
}

.mh-button--primary {
  background: var(--color-primary, #000);
  color: var(--color-primary-contrast, #fff);
}

.mh-button--primary.mh-button--unstyled {
  color: var(--color-primary);
}

.mh-button--secondary {
  background: var(--color-secondary, #444);
  color: var(--color-secondary-contrast, #fff);
}

.mh-button--secondary.mh-button--unstyled {
  color: var(--color-secondary);
}

.mh-button--tertiary {
  background: var(--color-tertiary, #c4c4c4);
  color: var(--color-tertiary-contrast, #000);
}

.mh-button--tertiary.mh-button--unstyled {
  color: var(--color-tertiary);
}

.mh-button--dark {
  background: var(--color-bg-dark, #c4c4c4);
  color: var(--color-bg-dark-contrast, #000);
}

.mh-button--dark.mh-button--unstyled {
  color: var(--color-bg-dark);
}

.mh-button--dark-alt {
  background: var(--color-bg-dark-alt, #c4c4c4);
  color: var(--color-bg-dark-contrast, #000);
}

.mh-button--dark-alt.mh-button--unstyled {
  color: var(--color-bg-dark-alt);
}

.mh-button--arrow {
  position: relative;
  padding-right: 4.5rem;
}

.mh-button--arrow.mh-button--unstyled {
  padding-left: 0;
}

.mh-button--arrow:before, .mh-button--arrow:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  transition: .2s transform ease-in-out;
}

.mh-button--arrow:before {
  background-color: currentColor;
  height: 2px;
  right: 1.8em;
  transform: translateY(-50%);
  transform-origin: right center;
  width: 1.3em;
}

.mh-button--arrow:after {
  border: solid currentColor;
  border-width: 2px 2px 0px 0;
  height: 8px;
  right: 2.3em;
  transform: translate(110%, -50%) rotate(45deg);
  transform-origin: center;
  width: 8px;
}

.mh-button--arrow .mh-button__text {
  display: inline-block;
  position: relative;
  transition: .2s transform ease-in-out;
}

.mh-button--arrow:hover .mh-button__text {
  transform: translateX(10px) !important;
}

.mh-button--arrow:hover::before {
  transform: translate(0, -50%) scaleX(0.8);
}

/*/////////////////////////////////////
buttons arrows markup should be:

<a href="#" data-lity
   class="mh-play-pulser">
  <span class="mh-play-pulser__circles" aria-hidden="true">
    <span class="mh-play-pulser__icon-wrap">
      <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 600 800"><path class="mh-play-pulser__play" d="M0-1.79v800L600 395 0-1.79z"/></svg>
    </span>
  </span>
  <span class="mh-play-pulser__text"></span>
</a>
/////////////////////////////////////*/
:root {
  --mh-play-pulser-size: 42px;
  --mh-play-pulser-ring-size: 2px;
  --mh-play-pulser-outline-size: 2px;
  --mh-play-pulser-icon-size: calc(var(--mh-play-pulser-size) * .25);
}

@media (min-width: 1024px) {
  :root {
    --mh-play-pulser-size: 52px;
  }
}

/* pulsator animations */
@keyframes pulse-1 {
  0% {
    transform: translate3d(-50%, -50%, 0) scale(1);
    opacity: 1;
  }
  100% {
    transform: translate3d(-50%, -50%, 0) scale(1.7);
    opacity: 0;
  }
}

@keyframes pulse-2 {
  0% {
    transform: translate3d(-50%, -50%, 0) scale(1);
    opacity: .5;
  }
  100% {
    transform: translate3d(-50%, -50%, 0) scale(1.7);
    opacity: 0;
  }
}

/* play pulser parent el */
.mh-play-pulser {
  border-radius: 5em;
  box-shadow: none;
  padding: 2px;
  text-decoration: none;
}

@media (min-width: 1024px) {
  .mh-play-pulser {
    background: transparent;
    border: none;
    padding: 0;
  }
}

.mh-play-pulser--outlined:hover .mh-play-pulser__text {
  color: #fff;
}

/* pulsating circles */
.mh-play-pulser__circles {
  display: inline-block;
  height: var(--mh-play-pulser-size, 42px);
  position: relative;
  transition: all 0.4s cubic-bezier(0.19, 1, 0.22, 1) 0s;
  vertical-align: middle;
  width: var(--mh-play-pulser-size, 42px);
}

@media (min-width: 1024px) {
  .mh-play-pulser__circles {
    height: var(--mh-play-pulser-size, 52px);
    width: var(--mh-play-pulser-size, 52px);
  }
}

.mh-play-pulser__circles:before {
  backface-visibility: hidden;
}

.mh-play-pulser__circles:before, .mh-play-pulser__circles:after {
  animation: pulse-1 2.6s cubic-bezier(0.25, 0.9, 0.2, 1) 0.4s infinite;
  animation: pulse-2 2.6s cubic-bezier(0.25, 0.9, 0.2, 1) 0.4s infinite;
  border: var(--mh-play-pulser-ring-size, 2px) solid;
  border-radius: 50%;
  content: '';
  display: block;
  height: var(--mh-play-pulser-size, 52px);
  left: 50%;
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: scale(0.35) translateY(-50%) translateX(-50%);
  width: var(--mh-play-pulser-size, 52px);
}

@media (prefers-reduced-motion) {
  .mh-play-pulser__circles:before, .mh-play-pulser__circles:after {
    animation: none !important;
  }
}

.mh-play-pulser__circles:after {
  animation: pulse-2 2.6s cubic-bezier(0.25, 0.9, 0.2, 1) 0s infinite;
}

.mh-play-pulser:hover .mh-play-pulser__circles {
  transform: scale(1.15);
}

.mh-play-pulser:hover .mh-play-pulser__icon-wrap {
  transform: scale(0.99);
}

/* the play (triangle) icon */
.mh-play-pulser svg {
  display: block;
  fill: currentColor;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-40%, -50%);
  width: var(--mh-play-pulser-icon-size, 20px);
}

/* play icon circle wrap */
.mh-play-pulser__icon-wrap {
  background-color: #000;
  border-radius: 50%;
  border: var(--mh-play-pulser-outline-size, 2px) solid rgba(255, 255, 255, 0.5);
  display: block;
  height: 100%;
  position: relative;
  width: 100%;
  z-index: 1;
}

@media (min-width: 1024px) {
  .mh-play-pulser__icon-wrap {
    border: none;
  }
  .mh-play-pulser__icon-wrap--outlined {
    background: transparent !important;
    border: var(--mh-play-pulser-outline-size, 2px) solid currentColor !important;
  }
  .mh-play-pulser__icon-wrap--outlined svg {
    fill: currentColor !important;
  }
}

.mh-play-pulser--outlined.mh-play-pulser--white:hover .mh-play-pulser__text {
  color: var(--color-text-dark);
}

/* play button inlined text */
.mh-play-pulser__text {
  display: inline-block;
  margin: 0 calc(var(--mh-play-pulser-size, 52px) * .25);
  vertical-align: middle;
}

@media (min-width: 1024px) {
  .mh-play-pulser--primary .mh-play-pulser__text {
    color: var(--color-primary);
  }
  .mh-play-pulser--secondary .mh-play-pulser__text {
    color: var(--color-secondary);
  }
  .mh-play-pulser--tertiary .mh-play-pulser__text {
    color: var(--color-tertiary);
  }
  .mh-play-pulser--dark .mh-play-pulser__text {
    color: var(--color-text-dark);
  }
  .mh-play-pulser--white .mh-play-pulser__text {
    color: #fff;
  }
}

/* color themes */
.mh-play-pulser--secondary .mh-play-pulser__icon-wrap {
  background: var(--color-secondary);
}

.mh-play-pulser--secondary .mh-play-pulser__icon-wrap svg {
  fill: var(--color-secondary-contrast, #fff);
}

.mh-play-pulser--secondary .mh-play-pulser__circles:before,
.mh-play-pulser--secondary .mh-play-pulser__circles:after {
  background: rgba(var(--rgb-secondary), 0.2);
  border-color: var(--color-secondary);
}

.mh-play-pulser--primary .mh-play-pulser__icon-wrap {
  background: var(--color-primary);
}

.mh-play-pulser--primary .mh-play-pulser__icon-wrap svg {
  fill: var(--color-secondary-contrast, #fff);
}

.mh-play-pulser--primary .mh-play-pulser__circles:before,
.mh-play-pulser--primary .mh-play-pulser__circles:after {
  background: rgba(var(--rgb-primary), 0.2);
  border-color: var(--color-primary);
}

.mh-play-pulser--dark .mh-play-pulser__icon-wrap {
  background: var(--color-bg-dark);
}

.mh-play-pulser--dark .mh-play-pulser__icon-wrap svg {
  fill: #fff;
}

.mh-play-pulser--dark .mh-play-pulser__circles:before,
.mh-play-pulser--dark .mh-play-pulser__circles:after {
  background: rgba(var(--rgb-bg-dark), 0.2);
  border-color: var(--color-bg-dark);
}

.mh-play-pulser--white .mh-play-pulser__icon-wrap {
  background: #fff;
}

.mh-play-pulser--white .mh-play-pulser__icon-wrap svg {
  fill: var(--color-text-dark);
}

.mh-play-pulser--white .mh-play-pulser__icon-wrap svg {
  fill: var(--color-text-dark);
}

.mh-play-pulser--white .mh-play-pulser__circles:before,
.mh-play-pulser--white .mh-play-pulser__circles:after {
  background: rgba(255, 255, 255, 0.2);
  border-color: #fff;
}
