// Base class
//
// Requires one of the contextual, color modifier classes for `color` and
// `background-color`.

.label {
  display: inline-block;
  padding: ($half-spacer/2) $half-spacer;
  font-size: 75%;
  font-weight: bold;
  line-height: 1;
  color: $label-color;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  @include border-radius();

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

  // Quick fix for labels in buttons
  .button & {
    position: relative;
    top: -1px;
  }
}

// Add hover effects, but only for links
a.label {
  @include hover-focus {
    color: $label-link-hover-color;
    text-decoration: none;
    cursor: pointer;
  }
}

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

.label--pill {
  padding-left: $half-spacer;
  padding-right: $half-spacer;
  border-radius: $spacer;

  & + .label--pill {
    margin-left: $half-spacer;
  }
}


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

.label--default {
  @include label-variant($label-default-bg);
}

.label--primary {
  @include label-variant($label-primary-bg);
}

.label--secondary {
  @include label-variant($label-secondary-bg);
}

.label--success {
  @include label-variant($label-success-bg);
}

.label--info {
  @include label-variant($label-info-bg);
}

.label--warning {
  @include label-variant($label-warning-bg);
}

.label--danger {
  @include label-variant($label-danger-bg);
}
