/* ==========================================================================
   Generic Carousel
   ========================================================================== */
.carousel {
  position: relative;
  box-sizing: border-box;
  margin: 0 auto;
}
.carousel .carousel-root {
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.carousel .carousel-root .carousel-list {
  width: 20000em;
  margin: 0;
  padding: 0;
  position: relative;
}
.carousel .carousel-root .carousel-list .carousel-item {
  float: left;
  margin: 0;
  position: relative;
}

/* by default, hide the pagination and the controls */
.carousel.disabled .controls span,
.carousel.disabled .pagination {
  display: none;
}

/* carousel controls (left / right arrows) */
.carousel.with-controls {
  /*padding: 0 6px;*/
}
.carousel .controls span {
	position: absolute;
	top: 50%;
	margin-top: -21px;
	outline: 0;
	text-indent: -9999px;
  width: 0;
  height: 0;
  border-style: solid;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -khtml-user-select: none;
  -ms-user-select: none;
  opacity: 1;
  -webkit-transition: opacity .5s;
  -moz-transition: opacity .5s;
  -o-transition: opacity .5s;
  transition: opacity .5s;
}
.carousel .controls span.disabled {
  opacity: 0;
  cursor: default;
}
.carousel .controls span.previous {
  border-width: 21px 21px 21px 0;
  border-color: transparent #ffce41 transparent transparent;
  left: -20px;
  -webkit-filter: drop-shadow(-4px 6px 3px rgba(0,0,0,0.5)); 
  filter: drop-shadow(-4px 6px 3px rgba(0,0,0,0.5));
  filter: "progid:DXImageTransform.Microsoft.Dropshadow(OffX=0, OffY=4, Color='#444')";
  transition: transform .5s;
  -moz-transition: -moz-transform .5s;
  -webkit-transition: -webkit-transform .5s;
}
.carousel .controls span.next {
  border-width: 21px 0 21px 21px;
  border-color: transparent transparent transparent #ffce41;
  right: -20px;
  -webkit-filter: drop-shadow(4px 6px 3px rgba(0,0,0,0.5)); 
  filter: drop-shadow(4px 6px 3px rgba(0,0,0,0.5));
  filter: "progid:DXImageTransform.Microsoft.Dropshadow(OffX=0, OffY=4, Color='#444')";
  transition: transform .5s;
  -moz-transition: -moz-transform .5s;
  -webkit-transition: -webkit-transform .5s;
}
.carousel .controls span.previous:hover{
  transform: scale(1.2);
  -moz-transform: scale(1.2);
  -webkit-transform: scale(1.2);
}
.carousel .controls span.next:hover{
  transform: scale(1.2);
  -moz-transform: scale(1.2);
  -webkit-transform: scale(1.2);
}
/* create a larger, empty element for easier clicking / tapping*/
.carousel .controls span:after {
  content: '';
  display: block;
  position: absolute;
  z-index: 1;
  top: -40px;
  width: 50px;
  height: 80px;
}

/* carousel pagination */
.carousel .pagination {
  bottom: 16px;
  position: absolute;
  width: 100%;
  text-align: center;
}
.carousel .pagination span {
  display: inline-block;
  position: relative;
  height: 20px;
  width: calc(20px * 0.57735);
/*  
  border: 5px solid #fff; 
  border-radius: 16px;
*/
  background-color: #fff;
  margin: 0 20px;
  outline: 0 none;
  text-indent: -9999px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -khtml-user-select: none;
  -ms-user-select: none;
}
.carousel .pagination span:before,
.carousel .pagination span:after{
  content: "";
  position: absolute;
  height: inherit;
  width: inherit;
  background-color: inherit;
  right: calc((100%/2) - ((100% * 1)/2));
}
.carousel .pagination span:before{
  transform: rotateZ(60deg);
  -webkit-transform: rotateZ(60deg);
  -o-transform: rotateZ(60deg);
}
.carousel .pagination span:after{
  transform: rotateZ(-60deg);
  -webkit-transform: rotateZ(-60deg);
  -o-transform: rotateZ(-60deg);
}
.carousel .pagination span:hover {
	border-color: #ffd204;
}
.carousel .pagination span.active:hover {
	border-color: #fff;
}
.carousel .pagination span.active {
  background: #feca16;
}
.carousel.with-pagination.pagination-right .pagination,
.carousel.with-pagination.pagination-left .pagination {
  width: auto;
  bottom: 25px;
}
.carousel.with-pagination.pagination-small .pagination span {
  border: none;
  background: #fefefe;
}
.carousel.with-pagination.pagination-blue .pagination span {
  background: #005696;
}
.carousel.with-pagination.pagination-blue .pagination span.active, .carousel.with-pagination.pagination-blue .pagination span.active:hover {
  background: #009ddc;
}

.carousel.with-pagination.pagination-green .pagination span {
  background: #107c42;
}
.carousel.with-pagination.pagination-green .pagination span.active, .carousel.with-pagination.pagination-green .pagination span.active:hover {
  background: #1dbe7e;
}
.carousel.with-pagination.pagination-blue .pagination span:hover,
.carousel.with-pagination.pagination-green .pagination span:hover {
	background: #ffd204;
}

/* carousel items separator */
.carousel.with-separator .carousel-item:after {
  content: '';
  display: block;
  position: absolute;
  right: -3px;
  width: 1px;
  background: #c1c1c1;
  border-left: 1px solid #c8c8c8;
  border-right: 1px solid #ccc;
  border-radius: 3px;
  top: 0;
  bottom: 0;
  z-index: 1;
}
.carousel.finite.with-separator .carousel-item:last-child:after {
  display: none;
}

/* carousel items border */
.carousel.with-border .carousel-item a {
  position: relative;
}
.carousel.with-border .carousel-item a em.border {
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  overflow: hidden;
  border: 4px solid #013573;
  -webkit-transition: all .3s;
  -moz-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  border-radius: 11px;
}
.carousel.with-border .carousel-item a:hover em.border {
  border-color: #ffd204;
  -webkit-transform: scale(0.99);
  -moz-transform: scale(0.99);
  -o-transform: scale(0.99);
  transform: scale(0.99);
}

/* ==========================================================================
   Mobile
   ========================================================================== */
@media only  screen and (max-width: 767px) {
  .carousel .pagination {
    bottom: 12px;
  }
  .carousel.with-pagination.pagination-right .pagination,
  .carousel.with-pagination.pagination-left .pagination {
    bottom: 18px;
  }
  .carousel.with-pagination.pagination-right .pagination {
    padding-right: 20px;
  }
  .carousel.with-pagination.pagination-left .pagination {
    padding-left: 20px;
  }
  .carousel .pagination span {
    border-width: 3px;
    width: 8px;
    height: 8px;
    border-radius: 8px;
    margin: 0 6px;
  }
  .carousel.with-pagination.pagination-small .pagination span {
    width: 11px;
    height: 11px;
    border-radius: 11px;
    margin: 0 3px;
  }
  .carousel.with-controls {
    padding: 0 25px;
  }
  .carousel .controls span {
    margin-top: -13px;
  }
  .carousel .controls span.previous {
    border-width: 13px 13px 13px 0;
  }
  .carousel .controls span.next {
    border-width: 13px 0 13px 13px;
  }
  .carousel .controls span:after {
    top: -30px;
    width: 40px;
    height: 60px;
  }
  .carousel .controls span.previous:after {
    left: -15px;
  }
  .carousel .controls span.next:after {
    left: -25px;
  }
}