/* ACTUAL CODE */

.button,
.button:any-link,
a.button {
  text-decoration: none;
  appearance: none;
  border: none;
  color: var(--_label-color);
}

.button {
  --_button-size: var(--control-button-size-m-height);
  --_icon-size: 1.5rem;
  --_padding-inline: .75rem;
  --_background-color: var(--button-grey-background-color);
  --_label-color: var(--button-grey-label-color);
  height: var(--_button-size);
  min-width: var(--_button-size);
  padding-inline: var(--_padding-inline);
  gap: calc(var(--_button-size) / 2 - var(--_icon-size) / 2);
  font-size: var(--typo-text-ui-font-size);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  white-space: nowrap;
  cursor: pointer;
  vertical-align: middle;
  user-select: none;
  -webkit-user-select: none;
  user-select: none;
  isolation: isolate;
  font-family: inherit;
  position: relative;
  background-color: var(--_background-color);
  color: var(--_label-color);
}

.button:hover {
  background-color: color-mix(in lch, var(--_background-color) var(--control_hover-mix), var(--_label-color));
}

.button:active {
  background-color: color-mix(in lch, var(--_background-color) var(--control_active-mix), var(--_label-color));
}

.button_shape_round {
  border-radius: 100vmax;
}

.button_style_grey {
  --_background-color: var(--button-grey-background-color);
  --_label-color: var(--text-bright-color);
}


.button_style_map {
  --_background-color: var(--button-grey-background-color);
  --_label-color: var(--text-bright-color);
  background-image: var(--button-map-background-image);
  background-size: cover;
  background-position: center;
}

.button_style_accent {
  --_background-color: var(--button-accent-background-color);
  --_label-color: var(--button-accent-label-color);
}


.button_style_telegram {
  --_background-color: var(--button-telegram-background-color);
  --_label-color: var(--button-telegram-label-color);
}


.button_style_vk {
  --_background-color: var(--button-vk-background-color);
  --_label-color: var(--button-vk-label-color);
}



.button_style_contrast {
  --_background-color: var(--button-contrast-background-color);
  --_label-color: var(--button-contrast-label-color);
}




.button_size_m {
  --_button-size: var(--control-button-size-m-height);
  --_icon-size: 1.25rem;
  --_padding-inline: .75rem;
}

.button_size_l {
  --_button-size: var(--control-button-size-l-height);
  --_icon-size: 1.25rem;
  --_padding-inline: .75rem;
}

.button_small,
.button_size_s {
  --_button-size: var(--control-button-size-s-height);
  --_icon-size: 1.15rem;
  --_padding-inline: .5rem;

}


.button_fullwidth {
  display: flex;
  width: 100%;
}





.button_ghost:not(:hover):not(:focus-visible),
.button_ghost[disabled] {
  background-color: transparent;
  box-shadow: none;
}

*:has([data-button_ghost-trigger]:hover)>.button_ghost,
[data-button_ghost-trigger]:hover>.button_ghost {
  background-color: var(--_background-color);
}

.button_with-icon::before {
  content: '';
  display: block;
  width: var(--_icon-size);
  height: var(--_icon-size);
  background-color: currentColor;
  mask-image: var(--icon);
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  margin-inline: calc(var(--_button-size) / 2 - var(--_icon-size) / 2 - var(--_padding-inline));
}


.button[disabled] {
  filter: saturate(0);
  opacity: .5;
  pointer-events: none;
}


.button_load {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 8 8' fill='none'><path d='M0 0H4L0 4V0Z' fill='black' fill-opacity='0.15'/><path d='M0 8L8 0V4L4 8H0Z' fill='black' fill-opacity='0.15'/></svg>");
  animation: linear .5s infinite buttonLoad;
  pointer-events: none;
}


.button__check-wrapper {
  display: inline-flex;
}

.button_link {
  padding: 0;
  border-radius: 0;
  background-color: transparent;
}

.button_link:hover {
  background-color: transparent;
  text-decoration: underline;
  text-underline-offset: .4em;
  text-decoration-thickness: 1px;
}

@keyframes buttonLoad {
  from {
    background-position: 0 0;
  }

  to {
    background-position: 1rem 0;
  }
}


.button__content {
  z-index: 1;
  pointer-events: none;
  display: flex;
  align-items: center;
}

.button__content:empty {
  display: none;
}

.button_shape_round .button__checkbox {
  border-radius: 100vmax;
}


/* LEGACY CODE */

.button_whitelabel {
  color: #fff;
}