.popover {
  position: absolute;
  top: 0;
  left: 0;
  z-index: $zindex-popover;
  display: block;
  max-width: $popover-max-width;
  font-size: $font-size-sm;
  word-wrap: break-word;
  background-color: $popover-bg;
  background-clip: padding-box;
  border: $popover-border-width solid $popover-border-color;
  border-radius: $border-radius-lg;
  box-shadow: $popover-box-shadow;
  animation: popoverFadeIn 0.6s ease;

  // Popover directions
  &[x-placement^='top'] {
    margin-bottom: $popover-margin + $popover-arrow-width;

    .popover-arrow {
      bottom: -$popover-arrow-outer-width;
      left: 50%;
      margin-left: -$popover-arrow-outer-width;
      border-top-color: $popover-arrow-outer-color;
      border-bottom-width: 0;

      &::after {
        bottom: 1px;
        margin-left: -$popover-arrow-width;
        content: '';
        border-top-color: $popover-arrow-color;
        border-bottom-width: 0;
      }
    }
  }

  &[x-placement^='right'] {
    margin-left: $popover-margin + $popover-arrow-width;

    .popover-arrow {
      top: 50%;
      left: -$popover-arrow-outer-width;
      margin-top: -$popover-arrow-outer-width;
      border-right-color: $popover-arrow-outer-color;
      border-left-width: 0;

      &::after {
        bottom: -$popover-arrow-width;
        left: 1px;
        content: '';
        border-right-color: $popover-arrow-color;
        border-left-width: 0;
      }
    }
  }

  &[x-placement^='bottom'] {
    margin-top: $popover-margin + $popover-arrow-width;

    .popover-arrow {
      top: -$popover-arrow-outer-width;
      left: 50%;
      margin-left: -$popover-arrow-outer-width;
      border-top-width: 0;
      border-bottom-color: $popover-arrow-outer-color;

      &::after {
        top: 1px;
        margin-left: -$popover-arrow-width;
        content: '';
        border-top-width: 0;
        border-bottom-color: $popover-arrow-color;
      }
    }
  }

  &[x-placement^='left'] {
    margin-right: $popover-margin + $popover-arrow-width;

    .popover-arrow {
      top: 50%;
      right: -$popover-arrow-outer-width;
      margin-top: -$popover-arrow-outer-width;
      border-right-width: 0;
      border-left-color: $popover-arrow-outer-color;

      &::after {
        right: 1px;
        bottom: -$popover-arrow-width;
        content: '';
        border-right-width: 0;
        border-left-color: $popover-arrow-color;
      }
    }
  }
}

// Offset the popover to account for the popover arrow
.popover-title {
  color: $popover-title-color;
  padding: $popover-title-padding-y $popover-title-padding-x;
  margin: 0; // reset heading margin
  font-size: $popover-title-font-size;
  background-color: $popover-title-bg;
  $offset-border-width: ($border-width / $font-size-root);
  border-radius: ($border-radius-lg - $offset-border-width)
    ($border-radius-lg - $offset-border-width) 0 0;
}

.popover-content {
  padding: $popover-content-padding-y $popover-content-padding-x;
}

// Arrows
// .popover-arrow is outer, .popover-arrow::after is inner
.popover-arrow {
  &,
  &::after {
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
  }

  border-width: $popover-arrow-outer-width;
}

.popover-arrow::after {
  content: '';
  border-width: $popover-arrow-width;
}

//Animation
@keyframes popoverFadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}
