.mf-button {
  vertical-align: top;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  padding: 0 1.25rem;
  transition: var(--transition-ease);
  height: 2.75rem;
  cursor: pointer;
  background-color: var(--color-base);
  color: #fff;
  border-radius: var(--b-r-2);
  border-width: 0.125rem;
  border-style: solid;
  border-color: var(--color-base);
  font-family: var(--font-family-main);
}
.mf-button:hover {
  background-color: var(--color-base-s-40);
  border-color: var(--color-base-s-40);
}
.mf-button[class*=size-] {
  padding: 0 1.25em;
}
.mf-button.size-s {
  height: 2rem;
}
.mf-button.size-sm {
  height: 2.375rem;
}
.mf-button.size-m {
  height: 2.75rem;
}
.mf-button.size-l {
  height: 3rem;
}
.mf-button.size-xl {
  height: 3.25rem;
}
.mf-button.bg-base {
  border-color: var(--color-base);
  background-color: var(--color-base);
}
.mf-button.bg-accent {
  border-color: var(--color-accent);
  background-color: var(--color-accent);
}
.mf-button.bg-green {
  border-color: var(--color-approve);
  background-color: var(--color-approve);
}
.mf-button.bg-red {
  border-color: var(--color-decline);
  background-color: var(--color-decline);
}
.mf-button.bg-gray {
  border-color: var(--color-gray);
  background-color: var(--color-gray);
}
.mf-button.bg-text-color {
  border-color: var(--color-text);
  background-color: var(--color-text);
}
.mf-button.bg-white {
  border-color: #fff;
  background-color: #fff;
  color: var(--color-text) !important;
}
.mf-button.bg-base:hover {
  background-color: var(--color-base-s-20);
  border-color: var(--color-base-s-20);
}
.mf-button.bg-accent:hover {
  background-color: var(--color-accent-s-20);
  border-color: var(--color-accent-s-20);
}
.mf-button.bg-green:hover {
  background-color: var(--color-approve-s-20);
  border-color: var(--color-approve-s-20);
}
.mf-button.bg-red:hover {
  background-color: var(--color-decline-s-20);
  border-color: var(--color-decline-s-20);
}
.mf-button.bg-gray:hover {
  background-color: var(--color-gray-s-20);
  border-color: var(--color-gray-s-20);
}
.mf-button.bg-text-color:hover {
  background-color: var(--color-gray-s-70);
  border-color: var(--color-gray-s-70);
}
.mf-button.bg-white:hover {
  background-color: var(--color-gray);
  border-color: var(--color-gray);
}
.mf-button.color-base:hover {
  color: var(--color-base-s-40);
}
.mf-button.color-accent:hover {
  color: var(--color-accent-s-40);
}
.mf-button.color-green:hover {
  color: var(--color-approve-s-40);
}
.mf-button.color-red:hover {
  color: var(--color-decline-s-40);
}
.mf-button.color-gray:hover {
  color: var(--color-gray-s-40);
}
.mf-button.color-text:hover {
  color: var(--color-text-s-40);
}
.mf-button.simple, .mf-button.outline, .mf-button.underline, .mf-button.simple:is(a):not([class*=color-]), .mf-button.outline:is(a):not([class*=color-]), .mf-button.underline:is(a):not([class*=color-]) {
  background-color: transparent;
}
.mf-button.simple, .mf-button.outline:not([class*=color-]), .mf-button.underline, .mf-button.simple:is(a):not([class*=color-]), .mf-button.outline:is(a):not([class*=color-]), .mf-button.underline:is(a):not([class*=color-]) {
  color: var(--color-base);
}
.mf-button.simple, .mf-button.underline, .mf-button.simple:is(a):not([class*=color-]), .mf-button.underline:is(a):not([class*=color-]) {
  border-color: transparent !important;
}
.mf-button.simple:hover, .mf-button.underline:hover, .mf-button.simple:is(a):not([class*=color-]):hover, .mf-button.underline:is(a):not([class*=color-]):hover {
  background-color: transparent;
}
.mf-button.outline {
  border-style: solid;
  border-width: 0.125rem;
  border-color: initial;
}
.mf-button.outline.thin {
  border-width: 0.0625rem;
}
.mf-button.outline.color-base:hover {
  border-color: var(--color-base);
  background-color: var(--color-base);
  color: #fff;
}
.mf-button.outline.color-accent:hover {
  border-color: var(--color-accent);
  background-color: var(--color-accent);
  color: #fff;
}
.mf-button.outline.color-green:hover {
  border-color: var(--color-approve);
  background-color: var(--color-approve);
  color: #fff;
}
.mf-button.outline.color-red:hover {
  border-color: var(--color-decline);
  background-color: var(--color-decline);
  color: #fff;
}
.mf-button.outline.color-gray:hover {
  border-color: var(--color-gray-s-40);
  background-color: var(--color-gray-s-40);
  color: #fff;
}
.mf-button.outline.color-gray.on-hover-shadow:hover {
  border-color: var(--color-gray);
  background-color: transparent;
}
.mf-button.outline.color-text:hover {
  border-color: var(--color-text);
  background-color: var(--color-text);
  color: #fff;
}
.mf-button.outline:hover, .mf-button.outline:is(a):not([class*=color-]):hover {
  border-color: var(--color-base);
  background-color: var(--color-base);
  color: #fff;
}
.mf-button.underline {
  position: relative;
}
.mf-button.underline::after {
  content: "";
  position: absolute;
  top: 96%;
  left: 0;
  right: 0;
  margin: auto;
  width: 50%;
  height: 0.125rem;
  display: block;
  border-top: solid 2px;
  transition: var(--transition-ease);
}
.mf-button.underline:hover {
  border-color: transparent;
}
.mf-button.underline:hover::after {
  border-color: var(--color-base-t-40);
  width: 70%;
}
.mf-button.with-margin {
  margin-bottom: 1rem;
  margin-right: 1rem;
}
.mf-button.icon [class*=ico-]::before {
  font-size: 1.25em;
  line-height: 2px;
  display: inline-flex;
  transform: translateY(0.125em);
  margin-right: 0.125em;
  margin-left: -0.125em;
}
.mf-button.icon.icon-right [class*=ico-]::before {
  margin-left: 0.125em;
  margin-right: -0.125em;
}
.mf-button.icon.icon-on-hover [class*=ico-]::before {
  transition: var(--transition-ease);
}
.mf-button.icon.icon-on-hover span:not([class*=ico-]) {
  transition: var(--transition-ease);
  transform: translateX(-0.625rem);
}
.mf-button.icon.icon-on-hover.icon-right span:not([class*=ico-]) {
  transform: translateX(0.625rem);
}
.mf-button.icon.icon-on-hover [class*=ico-]::before {
  opacity: 0;
}
.mf-button.icon.icon-on-hover:hover [class*=ico-]::before {
  opacity: 1;
}
.mf-button.icon.icon-on-hover:hover span:not([class*=ico-]) {
  transform: translateX(0);
}
.mf-button.icon-only [class*=ico-]::before {
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mf-button.icon-only.square {
  height: 2.75rem;
  width: 2.75rem;
  padding: 0;
}
.mf-button.icon-only.square.size-s {
  height: 2rem;
  width: 2rem;
}
.mf-button.icon-only.square.size-m {
  height: 2.75rem;
  width: 2.75rem;
}
.mf-button.icon-only.square.size-l {
  height: 3rem;
  width: 3rem;
}
.mf-button.icon-only.square.size-xl {
  height: 3.25rem;
  width: 3.25rem;
}

a.mf-button:not([class*=color-]),
[data-href].mf-button:not([class*=color-]) {
  color: #fff;
}

.mf-button-square-style-1 {
  height: 2rem;
  width: 2rem;
  color: var(--color-text);
  border-color: var(--color-gray);
  border-width: 0.0625rem;
  border-style: solid;
  padding: 0;
  background-color: transparent;
  font-size: 1.25rem;
}
.mf-button-square-style-1:hover {
  box-shadow: 0 0.125rem 0.75rem rgba(0, 0, 0, 0.16);
  background-color: transparent;
  border-color: var(--color-gray);
}
@media (min-width: 768px) {
  .mf-button-square-style-1 {
    height: 2.25rem;
    width: 2.25rem;
  }
}

.mf-button-square-style-2 {
  height: 1.5rem;
  width: 1.5rem;
  color: var(--color-decline);
  border-color: var(--color-decline);
  border-width: 0.0625rem;
  border-style: solid;
  padding: 0;
  background-color: transparent;
  font-size: 1.25rem;
}
.mf-button-square-style-2:hover {
  background-color: var(--color-decline);
  border-color: var(--color-decline);
  color: #fff;
}
@media (min-width: 768px) {
  .mf-button-square-style-2 {
    height: 2.25rem;
    width: 2.25rem;
  }
}/*# sourceMappingURL=button.css.map */