.modal.modal-left .modal-dialog,
.modal.modal-right .modal-dialog,
.modal.modal-top .modal-dialog,
.modal.modal-bottom .modal-dialog {
  -webkit-transform: translate3d(0%, 0, 0);
  -ms-transform: translate3d(0%, 0, 0);
  -o-transform: translate3d(0%, 0, 0);
  transform: translate3d(0%, 0, 0);
}

/* Left & Right */
.modal.modal-left .modal-dialog,
.modal.modal-right .modal-dialog {
  position: fixed;
  margin: auto;
  width: 500px;
  max-width: 100%;
  height: 100%;
}

.modal.modal-left .modal-content,
.modal.modal-right .modal-content {
  height: 100%;
  overflow-y: auto;
}

.modal.modal-left .modal-body,
.modal.modal-right .modal-body {
  padding: 15px 15px 80px;
}

.modal.modal-left.fade .modal-dialog {
  left: -500px;
  -webkit-transition: opacity 0.3s linear, left 0.3s ease-out;
  -moz-transition: opacity 0.3s linear, left 0.3s ease-out;
  -o-transition: opacity 0.3s linear, left 0.3s ease-out;
  transition: opacity 0.3s linear, left 0.3s ease-out;
}

.modal.modal-left.fade.show .modal-dialog {
  left: 0;
}

.modal.modal-right.fade .modal-dialog {
  right: -500px;
  -webkit-transition: opacity 0.3s linear, right 0.3s ease-out;
  -moz-transition: opacity 0.3s linear, right 0.3s ease-out;
  -o-transition: opacity 0.3s linear, right 0.3s ease-out;
  transition: opacity 0.3s linear, right 0.3s ease-out;
}

.modal.modal-right.fade.show .modal-dialog {
  right: 0;
}

.modal.modal-left .modal-content,
.modal.modal-right .modal-content,
.modal.modal-top .modal-content,
.modal.modal-bottom .modal-content,
.modal.modal-full .modal-content {
  border-radius: 0;
  border: none;
}

.modal.modal-left .modal-dialog.modal-sm,
.modal.modal-right .modal-dialog.modal-sm {
  width: 300px;
}

.modal.modal-left .modal-dialog.modal-lg,
.modal.modal-right .modal-dialog.modal-lg {
  width: 800px;
}

.modal.modal-left .modal-dialog.modal-xl,
.modal.modal-right .modal-dialog.modal-xl {
  width: 1140px;
}

/* Top and Bottom */
.modal.modal-top .modal-dialog,
.modal.modal-bottom .modal-dialog {
  position: fixed;
  margin: auto;
  width: 100%;
  max-width: 100%;
  height: auto;
}

.modal.modal-top .modal-content,
.modal.modal-bottom .modal-content {
  height: auto;
  overflow-y: auto;
}

.modal.modal-top .modal-body,
.modal.modal-bottom .modal-body {
  padding: 15px 15px;
}

/* Top */
.modal.modal-top.fade .modal-dialog {
  top: -100%;
  -webkit-transition: opacity 0.3s linear, top 0.3s ease-out;
  -moz-transition: opacity 0.3s linear, top 0.3s ease-out;
  -o-transition: opacity 0.3s linear, top 0.3s ease-out;
  transition: opacity 0.3s linear, top 0.3s ease-out;
}

.modal.modal-top.fade.show .modal-dialog {
  top: 0;
}

/* Bottom */
.modal.modal-bottom.fade .modal-dialog {
  bottom: -100%;
  -webkit-transition: opacity 0.3s linear, bottom 0.3s ease-out;
  -moz-transition: opacity 0.3s linear, bottom 0.3s ease-out;
  -o-transition: opacity 0.3s linear, bottom 0.3s ease-out;
  transition: opacity 0.3s linear, bottom 0.3s ease-out;
}

.modal.modal-bottom.fade.show .modal-dialog {
  bottom: 0;
}

.modal.modal-bottom.fade .modal-dialog {
  bottom: -100%;
}

/* Full Screen */
.modal.modal-full .modal-dialog {
  position: fixed;
  margin: auto;
  width: 100%;
  max-width: 100%;
  height: 100%;
}

.modal.modal-full .modal-content {
  height: 100%;
  overflow-y: auto;
}

.modal.modal-full .close-modal {
  position: fixed;
  top: 0;
  right: 3rem;
}

/* Footer */
.modal-footer-fixed {
  position: fixed;
  bottom: 0;
  width: 100%;
  background: #fff;
  border-radius: 0;
}

/* XS */
.modal.modal-left.xs .modal-body,
.modal.modal-right.xs .modal-body {
  padding: 15px;
}

/* Full screen modal menu indicators */
a.has-sub:after {
  font-family: "FontAwesome";
}

a.has-sub:after {
  content: "\f107";
  margin-left: 1rem;
}

a.has-sub[aria-expanded=true]:after {
  content: "\f106";
}

.modal.modal-right.cart-modal .modal-dialog {
  width: 90%;
  max-width: 750px;
}

#navbarResponsive.show ~ .shopping-nav-icon-container, #navbarResponsive.collapsing ~ .shopping-nav-icon-container {
  display: none;
}

.shopping-nav-icon-container {
  cursor: pointer;
  padding-left: 2px;
}
.shopping-nav-icon-container i {
  color: #e0e0e0;
}
.shopping-nav-icon-container .fa-shopping-cart {
  color: #343a40;
}
.shopping-nav-icon-container .cartItemCount {
  display: inline-block;
  color: #e0e0e0;
  background: #bd2130;
  border-radius: 50%;
  padding: 5px;
  font-size: 1.2ch;
  left: -19px;
  position: relative;
  bottom: -15px;
  transform: scale(0.9);
  width: 20px;
  text-align: center;
  height: 20px;
  font-weight: bold;
}

h5.shopping-panel-title {
  font-size: 2em;
}

.smallText {
  font-size: 0.8em;
}

.cart_item {
  font-size: 0.85em;
  padding-top: 1px;
  padding-bottom: 1px;
  background-color: white;
  transition: all ease 400ms;
  touch-action: none;
}
.cart_item .rental_schedule_label, .cart_item .giftcard_info_label {
  padding-left: 12px;
  font-size: 0.85em;
}

.row_contents {
  background-color: #FFF;
  transition: all ease-in-out 250ms;
}

.cart_item.actual_item {
  border-bottom: 1px solid #000;
}

.row_contents {
  position: relative;
  opacity: 1;
}

.cart_item.delete-pending {
  background-color: #bd2130;
}

.delete-pending .row_contents {
  opacity: 0.9;
}

.delete-pending .prod-linemgt.smallText {
  display: none;
}

.swipeGesture {
  display: none;
  color: #FFF;
  position: relative;
}

.swiping.cart_item.delete-pending .swipeGesture {
  display: inline-block;
}

.swiping.delete-pending .swipeGesture.trash {
  float: left;
  margin-top: 1px;
  margin-left: 4px;
}

.swiping .swipeGesture.edit {
  float: right;
  right: 9px;
  bottom: 42px;
}

.cart_item.swiping .row_contents {
  border: 1px solid #000;
  background-color: #e9e9e9;
  z-index: 5;
}

.addConfirmationContainer {
  max-width: 350px;
}

.prod-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}