@mixin button-base {
  $min-height: control-height();
  $horizontal-padding: spacing(tight) * 1.5;
  $vertical-padding: ($min-height - line-height(body) - rem(2px)) / 2;

  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: $min-height;
  min-width: $min-height;
  margin: 0;
  padding: $vertical-padding $horizontal-padding;
  @include state(base);
  color: color('ink');
  @include recolor-icon(color('ink', 'lighter'));
  border: border(transparent);
  font-family: inherit;
  border-radius: border-radius();
  line-height: 1;
  text-align: center;
  cursor: pointer;
  user-select: none;
  text-decoration: none;
  transition-property: border, box-shadow;
  transition-duration: duration();
  transition-timing-function: easing();

  &:hover {
    @include state(hover);
    // background: color('sky', 'base');
    // background: linear-gradient(
    //   to bottom,
    //   color('sky', 'lighter'),
    //   color('sky', 'light')
    // );
    // border-color: color('sky', 'dark');
  }

  &:focus {
    @include state(hover);
    // border-color: color('indigo');
    outline: 0;
    // box-shadow: 0 0 0 1px color('indigo');
  }

  &:active {
    @include state(press);
    // Same color gradient is necessary for background transitions
    // background: linear-gradient(
    //   to bottom,
    //   color('sky', 'light'),
    //   color('sky', 'light')
    // );
    // border-color: color('sky', 'dark');
    // box-shadow: 0 0 0 0 transparent,
    //   inset 0 1px 1px 0 rgba(color('ink', 'lighter'), 0.1),
    //   inset 0 1px 4px 0 rgba(color('ink', 'lighter'), 0.2);
    // transform: scale(0.94);
  }
}

@mixin base-button-disabled {
  transition: none;
  @include state(hover);
  @include recolor-icon(color('ink', 'lightest'));
  color: color('ink', 'lightest');
}

@mixin button-filled($button-color, $focus-color, $outline-color: null) {
  $border-color: darken($button-color, 10%);
  $active-color: darken($button-color, 15%);
  background: $button-color;
  color: color('white');

  &:hover {
    background: lighten($button-color, 5%);
    color: color('white');
    text-decoration: none;
  }

  &:focus {
    background: lighten($button-color, 5%);
  }

  &:active {
  }
}

@mixin button-filled-disabled($button-color) {
  @include recolor-icon(color('white'));
  background: $button-color;
  color: color('white');
}

@mixin button-outline() {
  border-radius: border-radius();
  border: border(dark);
  background: none;

  &:hover {
    @include state(base);
  }

  &:focus {
    @include state(base);
  }

  &:active {
    @include state(hover);
  }
}

@mixin button-outline-disabled() {
  @include state(base);
  @include recolor-icon(color('ink', 'lightest'));
  color: color('ink', 'lightest');
}

@mixin button-minimal($minimal-color) {
  background: transparent;
  box-shadow: none;
  @include recolor-icon(color('ink', 'lightest'));
  color: color('ink', 'lightest');

  &:hover,
  &:focus {
    @include recolor-icon(color('ink', 'lighter'));
    color: color('ink', 'lighter');
    background: color('sky');
    @include state(hover);
  }

  &:active {
    @include state(press);
    box-shadow: none;
  }
}

@mixin button-minimal-disabled($minimal-color) {
  background: transparent;
  box-shadow: none;
  color: transparent;

  @include recolor-icon(color('ink', 'lightest'));
}

@mixin button-full-width {
  display: flex;
  width: 100%;
}

@function plain-button-background() {
  @return rgba(color('ink'), 0.1);
}

@mixin plain-button-backdrop() {
  position: absolute;
  top: -2px;
  bottom: -2px;
  left: -5px;
  right: -5px;
  display: block;
  background: plain-button-background();
  border-radius: border-radius();
  transition: opacity duration() easing();
}

@mixin unstyled-button() {
  appearance: none;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
  cursor: pointer;

  &:focus {
    outline: none;
  }
}
