:root {
  --button_color: #ffffff;
  --button_border_radius: 50px;
}

.button_container {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
  margin-top: 5px;
}

.button_container a {
  text-decoration: none;
}
.button_container .button.black {
  background-color: var(--black);
}
.button_container .button {
  position: relative;
  display: flex;
  align-items: center;
  background-color: var(--button_color);
  padding: 15px 19px;
  border-radius: var(--button_border_radius);
  transition: all 0.3s linear;
  z-index: 2;
  white-space: nowrap;
}

.button_container .button .text {
  color: var(--black);
}

.button_container .button .dot {
  width: 10px;
  height: 10px;
  background-color: var(--black);
  border-radius: 50%;
  margin-left: 20px;
}

.button_container .button__black {
  position: relative;
  display: flex;
  align-items: center;
  padding: 15px;
  border-radius: var(--button_border_radius);
  transition: all 0.3s linear;
  background-color: var(--black);
  z-index: 2;
}

.button_container .button__black .text {
  color: var(--button_color);
}

.button_container .button__black .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-left: 20px;
  background-color: var(--button_color);
}

.button_container .border {
  position: absolute;
  top: 5px;
  left: 5px;
  right: -5px;
  bottom: -5px;
  height: 100%;
  border: 1px solid var(--button_color);
  border-radius: var(--button_border_radius);
  z-index: 1;
}

.button_container .border__black {
  position: absolute;
  top: 5px;
  left: 5px;
  right: -5px;
  bottom: -5px;
  height: 100%;
  border-radius: var(--button_border_radius);
  z-index: 1;
  border: 1px solid var(--black);
}

.button_container:active {
  top: 5px;
  left: 5px;
}

.button_container:active > .border,
.button_container:active > .border__black {
  top: -1px;
  left: 0px;
  right: 0;
  bottom: 0;
}
