// // Carousel // -------------------------------------------------- // Wrapper for the slide container and indicators .carousel { position: relative; } // Wrap all slides, but only show the active one .carousel-inner { position: relative; overflow: hidden; width: 100%; } // Immediate parent of all slides .carousel-inner { > .item { display: none; position: relative; .transition(.6s ease-in-out left); // Account for jankitude on images > img, > a > img { display: block; line-height: 1; } } > .active, > .next, > .prev { display: block; } > .active { left: 0; } > .next, > .prev { position: absolute; top: 0; width: 100%; } > .next { left: 100%; } > .prev { left: -100%; } > .next.left, > .prev.right { left: 0; } > .active.left { left: -100%; } > .active.right { left: 100%; } } // Left/right controls for nav // --------------------------- .carousel-control { position: absolute; top: 0; left: 0; bottom: 0; width: 15%; .opacity(.5); font-size: 20px; color: #fff; text-align: center; text-shadow: 0 1px 2px rgba(0,0,0,.6); // we can't have this transition here // because webkit cancels the carousel // animation if you trip this while // in the middle of another animation // ;_; // .transition(opacity .2s linear); // Set gradients for backgrounds &.left { #gradient > .horizontal(rgba(0,0,0,.5), rgba(0,0,0,.0001)); background-color: transparent; } &.right { left: auto; right: 0; #gradient > .horizontal(rgba(0,0,0,.0001), rgba(0,0,0,.5)); background-color: transparent; } // Hover/focus state &:hover, &:focus { color: #fff; text-decoration: none; .opacity(.9); } // Toggles .glyphicon { position: absolute; top: 50%; left: 50%; z-index: 5; display: inline-block; width: 20px; height: 20px; margin-top: -10px; margin-left: -10px; } } // Optional indicator pips // ----------------------------- .carousel-indicators { position: absolute; bottom: 20px; left: 50%; z-index: 5; width: 100px; margin: 0 0 0 -50px; list-style: none; text-align: center; li { display: inline-block; width: 8px; height: 8px; margin-left: 0; margin-right: 0; text-indent: -999px; border: 1px solid #fff; border-radius: 5px; cursor: pointer; } .active { background-color: #fff; } } // Optional captions // ----------------------------- // Hidden by default for smaller viewports .carousel-caption { position: absolute; left: 15%; right: 15%; bottom: 20px; z-index: 10; padding-top: 20px; padding-bottom: 20px; color: #fff; text-align: center; text-shadow: 0 1px 2px rgba(0,0,0,.6); & .btn { text-shadow: none; // No shadow for button elements in carousel-caption } } // Scale up controls for tablets and up @media screen and (min-width: @screen-tablet) { // Scale up the controls a smidge .carousel-control .glyphicon { width: 30px; height: 30px; margin-top: -15px; margin-left: -15px; font-size: 30px; } // Show and left align the captions .carousel-caption { left: 20%; right: 20%; padding-bottom: 30px; } }