// Base class
//
// Requires one of the contextual, color modifier classes for `color` and
// `background-color`.
@use "mixins/badge";
@use "mixins/border-radius";
@use "mixins/hover";
@use "mixins/transition";
@use "variables";
@use "vendor/rfs";

.badge {
  display: inline-block;
  padding: variables.$badge-padding-y variables.$badge-padding-x;
  @include rfs.font-size(variables.$badge-font-size);
  font-weight: variables.$badge-font-weight;
  line-height: 1rem;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  @include border-radius.border-radius(variables.$badge-border-radius);
  @include transition.transition(variables.$badge-transition);

  @at-root a#{&} {
    @include hover.hover-focus() {
      text-decoration: none;
    }
  }

  // Empty badges collapse automatically
  &:empty {
    display: none;
  }
}

// Quick fix for badges in buttons
.btn .badge {
  position: relative;
  top: -1px;
}

// Pill badges
//
// Make them extra rounded with a modifier to replace v3's badges.

.badge-pill {
  padding-right: variables.$badge-pill-padding-x;
  padding-left: variables.$badge-pill-padding-x;
  @include border-radius.border-radius(variables.$badge-pill-border-radius);
}

// Colors
//
// Contextual variations (linked badges get darker on :hover).

@each $color, $value in variables.$badge-bg-colors {
  .badge-#{$color} {
    @include badge.badge-variant($color);
  }
}
