a,
input,
button {
  &:focus {
    outline: none;
  }

  &:focus-visible {
    outline: 1px dotted #212121;
    outline: 1px auto -webkit-focus-ring-color;
  }
}

.#{$n}-button {
  display: inline-flex;
  align-items: center;
  gap: $spacer * 0.5;
  margin: 0;
  padding: 0;
  border: 0;
  background: none;
  font-size: $fontsize-medium;
  text-align: left;
  cursor: pointer;
}

.#{$n}-button span {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
}

.#{$n}-button--primary {
  min-height: $buttonsize;
  padding: $spacer * 0.5 $spacer * 0.75;
  border-radius: $borderradius-small;
  background-color: $interaction;
  color: set-text-color($interaction);
  font-weight: $fontweight-bold;
}

.#{$n}-button--secondary {
  padding: $spacer * 0.5 $spacer * 0.75;
  color: $interaction;
  font-weight: $fontweight-bold;
}

.#{$n}-button--tertiary {
  padding: $spacer * 0.1 $spacer * 0.25;
  border-radius: $borderradius-small;
  background-color: initial;
  color: set-text-color($interaction);
  font-size: $fontsize-small;
  font-weight: $fontweight-bold;
}

.#{$n}-button[aria-disabled='true'] {
  color: $disabled;
  cursor: auto;
}

.#{$n}-button__state {
  display: inline-block;
  margin: 0;
  padding: $spacer * 0.1 $spacer * 0.5;
  border-radius: $borderradius-small;
  background-color: $grey-a;
  color: inherit;
}
