// Wrapper for the slide container and indicators
.#{$carousel-prefix-cls} {
  position: relative;
}

.#{$carousel-prefix-cls}-inner {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.#{$carousel-prefix-cls}-item {
  position: relative;
  display: none;
  width: 100%;
}

.#{$carousel-prefix-cls}-item.active,
.#{$carousel-prefix-cls}-item-next,
.#{$carousel-prefix-cls}-item-prev {
  display: flex;
}

.#{$carousel-prefix-cls}-item-next,
.#{$carousel-prefix-cls}-item-prev {
  position: absolute;
  top: 0;
}

// CSS3 transforms when supported by the browser
@include if-supports-3d-transforms() {
  .#{$carousel-prefix-cls}-item-next.#{$carousel-prefix-cls}-item-left,
  .#{$carousel-prefix-cls}-item-prev.#{$carousel-prefix-cls}-item-right {
    transform: translate3d(0, 0, 0);
  }

  .#{$carousel-prefix-cls}-item-next,
  .active.#{$carousel-prefix-cls}-item-right {
    transform: translate3d(100%, 0, 0);
  }

  .#{$carousel-prefix-cls}-item-prev,
  .active.#{$carousel-prefix-cls}-item-left {
    transform: translate3d(-100%, 0, 0);
  }
}

//
// Left/right controls for nav
//

.#{$carousel-prefix-cls}-control-prev,
.#{$carousel-prefix-cls}-control-next {
  // We can't have a transition here because WebKit cancels the carousel
  // animation if you trip this while in the middle of another animation.

  // Hover/focus state
  @include hover-focus {
    color: $carousel-control-color;
    text-decoration: none;
    outline: 0;
    opacity: .9;
  }
  position: absolute;
  top: 0;
  bottom: 0;
  // Use flex for alignment (1-3)
  display: flex; // 1. allow flex styles
  align-items: center; // 2. vertically center contents
  justify-content: center; // 3. horizontally center contents
  width: $carousel-control-width;
  color: $carousel-control-color;
  text-align: center;
  opacity: $carousel-control-opacity;
}

.#{$carousel-prefix-cls}-control-prev {
  left: 0;
}

.#{$carousel-prefix-cls}-control-next {
  right: 0;
}

// Icons for within
.#{$carousel-prefix-cls}-control-prev-icon,
.#{$carousel-prefix-cls}-control-next-icon {
  display: inline-block;
  width: $carousel-control-icon-width;
  height: $carousel-control-icon-width;
  font-size: 48px;
  /*background: transparent no-repeat center center;
  background-size: 100% 100%;*/
}
/*.#{$carousel-prefix-cls}-control-prev-icon {
  background-image: $carousel-control-prev-icon-bg;
}
.#{$carousel-prefix-cls}-control-next-icon {
  background-image: $carousel-control-next-icon-bg;
}*/


// Optional indicator pips
//
// Add an ordered list with the following class and add a list item for each
// slide your carousel holds.

.#{$carousel-prefix-cls}-indicators {
  position: absolute;
  right: 0;
  bottom: 10px;
  left: 0;
  z-index: 15;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 0; // override <ol> default
  // Use the .#{$carousel-prefix-cls}-control's width as margin so we don't overlay those
  margin: 0;
  margin-right: $carousel-control-width;
  margin-left: $carousel-control-width;
  list-style: none;

  li {
    position: relative;
    //flex: 1 0 auto;
    padding-right: $carousel-indicator-spacer;
    padding-left: $carousel-indicator-spacer;
    &>span{
      cursor: pointer;
      display: block;
      width: $carousel-indicator-width;
      height: $carousel-indicator-height;
      //text-indent: -999px;
      background-color: rgba($carousel-indicator-active-bg, .65);
      background-clip: content-box;
      border-radius: $carousel-indicator-border-radius;
    }
    // border-radius: 50%;
    // Use pseudo classes to increase the hit area by 10px on top and bottom.
    // &::before {
    //   position: absolute;
    //   top: -10px;
    //   left: 0;
    //   display: inline-block;
    //   width: 100%;
    //   height: 10px;
    //   content: "";
    // }

    // &::after {
    //   position: absolute;
    //   bottom: -10px;
    //   left: 0;
    //   display: inline-block;
    //   width: 100%;
    //   height: 10px;
    //   content: "";
    // }

    // &:hover {
    //   &>span{
    //     height: $carousel-indicator-active-width;
    //     width: $carousel-indicator-active-height;
    //     background-color: $carousel-indicator-active-bg;
    //     border-color: $carousel-indicator-active-bg;
    //   }
    // }
  }

  .active {
    &>span{
      width: $carousel-indicator-active-width;
      height: $carousel-indicator-active-height;
      background-color: $carousel-indicator-active-bg;
      border-color: $carousel-indicator-active-bg;
    }
  }
}


// Optional captions
//
//

.#{$carousel-prefix-cls}-caption {
  position: absolute;
  right: ((100% - $carousel-caption-width) / 2);
  bottom: 20px;
  left: ((100% - $carousel-caption-width) / 2);
  z-index: 10;
  padding-top: 20px;
  padding-bottom: 20px;
  color: $carousel-caption-color;
  text-align: center;

  .#{$carousel-prefix-cls}-title {
    margin-bottom: $carousel-caption-spacer-y;
    font-size: $carousel-title-font-size;
  }

  .#{$carousel-prefix-cls}-description {
    font-size: $carousel-description-font-size;
  }
}

.#{$carousel-prefix-cls}--vertical{
  .#{$carousel-prefix-cls}-control-prev,
  .#{$carousel-prefix-cls}-control-next{
    left: 0;
    right: 0;
    top: auto;
    bottom: auto;
    height: $carousel-control-width * 1.5;
    width: 100%;
  }
  .#{$carousel-prefix-cls}-control-prev{
    top: 0;
  }
  .#{$carousel-prefix-cls}-control-next{
    bottom: 0;
  }
  .#{$carousel-prefix-cls}-control-prev-icon,
  .#{$carousel-prefix-cls}-control-next-icon {
    width: $carousel-control-icon-width / 2;
    height: $carousel-control-icon-width / 2;
    line-height: $carousel-control-icon-width / 2;
    font-size: 24px;
  }
  .#{$carousel-prefix-cls}-indicators {
    right: 10px;
    top: 0;
    bottom: 0;
    left: auto;
    margin: 0;
    margin-top: 10%;
    margin-bottom: 10%;
    flex-direction: column;
    li{
      &>span{
        height: $carousel-indicator-width;
        width: $carousel-indicator-height;
      }
      padding-bottom: $carousel-indicator-spacer;
      padding-top: $carousel-indicator-spacer;
    }
    li:hover{
      &>span{
        height: $carousel-indicator-active-width;
        width: $carousel-indicator-active-height;
      }
    }
    .active{
      &>span{
        height: $carousel-indicator-active-width;
        width: $carousel-indicator-active-height;
      }
    }
  }
}

.#{$carousel-prefix-cls}--slide,
.#{$carousel-prefix-cls}--fade {
  overflow: hidden;
  .#{$carousel-prefix-cls}-inner {
    width: auto;
    display: flex;
    overflow: visible;
  }
  .#{$carousel-prefix-cls}-item {
    display: flex;
    flex-shrink: 0;
  }
  &.#{$carousel-prefix-cls}--vertical {
    .#{$carousel-prefix-cls}-inner {
      flex-direction: column;
    }
  }
}

.#{$carousel-prefix-cls}--slide.animate {
  .#{$carousel-prefix-cls}-inner {
    transition: transform .3s ease-in-out;
  }
}

.#{$carousel-prefix-cls}--fade {
  .#{$carousel-prefix-cls}-item {
    position: relative;
    visibility: hidden;
    opacity: 0;
    transition: all .3s;
    &.active {
      visibility: visible;
      opacity: 1;
    }
  }
}