/************************************************************** button_hover.css (by Modx)*********************************************************/
.btn-animated {
  position: relative;
  display: inline-block;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  overflow: hidden;
}
.btn-animated:before, .btn-animated:after {
  content: "";
  position: absolute;
  display: block;
  box-sizing: border-box;
  top: 0;
  left: 0;
}

.rectangleOut {
  /*border: 0.1vw solid #306B34;*/
}
.rectangleOut:after {
  width: 100%;
  height: 100%;
  background: #82D173;
  mix-blend-mode: lighten;
  transition: all 0.5s ease;
  transform-origin: center;
  transform: scale(0);
}
.rectangleOut:hover:after {
  transform: scale(1);
}
.radialOut {
  /*border: 0.1vw solid #306B34;*/
}
.radialOut:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #82D173;
  mix-blend-mode: lighten;
  transition: all 0.5s ease;
  transform-origin: center;
  transform: scale(0);
}
.radialOut:hover:after {
  border-radius: 0;
  transform: scale(1);
}
.turnOut {
  /*border: 0.1vw solid #306B34;*/
}
.turnOut:after {
  width: 100%;
  height: 100%;
  background: #82D173;
  mix-blend-mode: lighten;
  transition: all 0.5s ease;
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.turnOut:hover:after {
  transform: scale(1) rotate(180deg);
}
.turnRoundOut {
  /*border: 0.1vw solid #306B34;*/
}
.turnRoundOut:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #82D173;
  mix-blend-mode: lighten;
  transition: all 0.5s ease;
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.turnRoundOut:hover:after {
  border-radius: 0;
  transform: scale(1) rotate(180deg);
}
.turnQuickOut {
  /*border: 0.1vw solid #306B34;*/
}
.turnQuickOut:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #82D173;
  mix-blend-mode: lighten;
  transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.turnQuickOut:hover:after {
  border-radius: 0;
  transform: scale(1) rotate(180deg);
}
.rectangleRoundOut {
  border: 0.2vw solid #82D173;
  border-radius: 0;
  line-height: 3.6vw;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
}
.rectangleRoundOut:hover {
  border-radius: 1vw;
}
.rectangleRoundOut:after {
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: #306B34;
  mix-blend-mode: lighten;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.rectangleRoundOut:hover:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.25vw;
}
.radialRoundOut {
  border: 0.2vw solid #82D173;
  border-radius: 0;
  line-height: 3.6vw;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
}
.radialRoundOut:hover {
  border-color: transparent;
}
.radialRoundOut:after {
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: #82D173;
  mix-blend-mode: lighten;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.radialRoundOut:hover:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 0.25vw;
}
.rectangleRadialOut {
  /*border: 0.1vw solid #306B34;*/
}
.rectangleRadialOut:before, .rectangleRadialOut:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #42113C;
  mix-blend-mode: lighten;
  transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.rectangleRadialOut:hover:before {
  border-radius: 0;
  transform: scale(1) rotate(-180deg);
}
.rectangleRadialOut:hover:after {
  border-radius: 0;
  transform: scale(1) rotate(180deg);
}
.rectangleTurnBiColorOut {
  /*border: 0.1vw solid #306B34;*/
}
.rectangleTurnBiColorOut:before, .rectangleTurnBiColorOut:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #4D243D;
  mix-blend-mode: lighten;
  transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.rectangleTurnBiColorOut:hover:before {
  border-radius: 0;
  transform: scale(1) rotate(-180deg);
}
.rectangleTurnBiColorOut:after {
  background: #42113C;
}
.rectangleTurnBiColorOut:hover:after {
  border-radius: 0;
  transform: scale(1) rotate(180deg);
}
.rectangleBiColorOut {
  /*border: 0.1vw solid #306B34;*/
}
.rectangleBiColorOut:before, .rectangleBiColorOut:after {
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: #4D243D;
  mix-blend-mode: lighten;
  transition: width 0.25s 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), height 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55), left 0.25s 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), top 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.rectangleBiColorOut:after {
  transition: width 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55), height 0.25s 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), left 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55), top 0.25s 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), transform 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  background: #42113C;
}
.rectangleBiColorOut:hover:before, .rectangleBiColorOut:hover:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.rectangleBiColorSlowOut {
  border: 0.1vw solid #306B34;
}
.rectangleBiColorSlowOut:before, .rectangleBiColorSlowOut:after {
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: #4D243D;
  mix-blend-mode: lighten;
  transition: width 0.5s 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55), height 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55), left 0.5s 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55), top 0.75s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.rectangleBiColorSlowOut:after {
  transition: width 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), height 0.25s 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), left 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55), top 0.25s 0.25s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  background: #42113C;
}
.rectangleBiColorSlowOut:hover:before, .rectangleBiColorSlowOut:hover:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.sweptToRight {
  /*border: 0.1vw solid #306B34;*/
}
.sweptToRight:before, .sweptToRight:after {
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: #4D243D;
  mix-blend-mode: lighten;
  transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform: rotate(0);
}
.sweptToRight:after {
  background: #42113C;
}
.sweptToRight:hover:before, .sweptToRight:hover:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: rotate(170deg);
}
.sweptToRight:hover:after {
  transform: rotate(-170deg);
}
.sweptToRight2 {
  background: #306B34;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.sweptToRight2:after {
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  mix-blend-mode: lighten;
  background: #82D173;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.sweptToRight2:hover {
  background: transparent;
}
.sweptToRight2:hover:after {
  width: 100%;
  height: 100%;
}
.sweptToRight22 {
  background: #306B34;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.sweptToRight22:after {
  top: 0;
  left: 100%;
  width: 0;
  height: 100%;
  mix-blend-mode: lighten;
  background: #82D173;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.sweptToRight22:hover {
  background: transparent;
}
.sweptToRight22:hover:after {
  width: 100%;
  height: 100%;
  left: 0;
}
.sweptToRight222 {
  background: #306B34;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.sweptToRight222:before, .sweptToRight222:after {
  top: 0;
  width: 0;
  height: 100%;
  mix-blend-mode: overlay;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
}
.sweptToRight222:before {
  left: 0;
  width: 0;
  background: #4D243D;
}
.sweptToRight222:after {
  left: 100%;
  width: 0;
  background: #42113C;
}
.sweptToRight222:hover:before {
  width: 100%;
}
.sweptToRight222:hover:after {
  width: 100%;
  left: 0;
}
.sweptToRight2222 {
  background: #306B34;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
  filter: hue-rotate(0);
}
.sweptToRight2222:hover {
  filter: hue-rotate(360deg);
}
.sweptToRight2222:before, .sweptToRight2222:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #4D243D;
  mix-blend-mode: overlay;
  transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.sweptToRight2222:hover:before {
  border-radius: 0;
  transform: scale(1) rotate(-180deg);
}
.sweptToRight2222:after {
  background: #42113C;
}
.sweptToRight2222:hover:after {
  border-radius: 0;
  transform: scale(1) rotate(180deg);
}
.sweptToRight22222 {
  background: #306B34;
  transition: all 0.5s cubic-bezier(0.42, 0, 0.58, 1);
  filter: hue-rotate(0);
}
.sweptToRight22222:hover {
  filter: hue-rotate(360deg);
}
.sweptToRight22222:before, .sweptToRight22222:after {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #4D243D;
  mix-blend-mode: overlay;
  transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-origin: center;
  transform: scale(0) rotate(0);
}
.sweptToRight22222:hover:before {
  transform: scale(1) rotate(-180deg);
}
.sweptToRight22222:after {
  background: #42113C;
}
.sweptToRight22222:hover:after {
  border-radius: 2vw;
  transform: scale(1) rotate(180deg);
}
