@import (reference) "colors";
@import (reference) "fonts";

.tooltip {
  @height: 7px;
  @width: 14px;
  @color: @color--black;
  @offset: @height / 2;

  font-family: @font-family--content;
  position: absolute;
  display: inline-block;
  background: @color--black;
  font-size: @font-size--body-sm;
  padding: @font-size--body-sm / 2;
  border-radius: 5px;
  color: @color--white;
  z-index: 100000;

  &--inner {
    display: inline-block;
  }

  &--arrow, &--arrow:after {
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
    z-index: -1;
  }

  &--arrow:after {
    content: " ";
    border-width: @width;
  }

  &.m-bottom {
    margin-top: @height;
    .tooltip--arrow {
      left: 50%;
      margin-left: -@height - @offset;
      border-top-width: 0;
      top: -@height;
      &:after {
        content: " ";
        top: 1px;
        margin-left: -@height;
        border-top-width: 0;
        border-bottom-color: @color;
      }
    }
  }

  &.m-top {
    margin-top: -@height;
    .tooltip--arrow {
      left: 50%;
      margin-left: -@height - @offset;
      border-bottom-width: 0;
      bottom: -@height;
      &:after {
        content: " ";
        bottom: 1px;
        margin-left: -@height;
        border-bottom-width: 0;
        border-top-color: @color;
      }
    }
  }

  &.m-left {
    margin-left: -@height;
    .tooltip--arrow {
      top: 50%;
      right: -@height;
      margin-top: @offset;
      border-right-width: 0;
      &:after {
        content: " ";
        right: 1px;
        border-right-width: 0;
        border-left-color: @color;
        bottom: -@height;
      }
    }
  }

  &.m-right {
    margin-left: @height;
    .tooltip--arrow {
      top: 50%;
      left: -@height;
      margin-top: @offset;
      border-left-width: 0;
      &:after {
        content: " ";
        left: 1px;
        bottom: -@height;
        border-left-width: 0;
        border-right-color: @color;
      }
    }
  }
}
