.upcoming-workshops-bar {
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  align-items: flex-start;
  background: linear-gradient(to bottom, #38276C 0, #38276C 104px, transparent 104px, transparent 100%);
  padding: 24px 10px 0;
  max-width: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  right: 0;
  z-index: 999;
}

@media (min-width: 992px) {
  .upcoming-workshops-bar {
    padding: 35px 32px 0;
    background: linear-gradient(to bottom, #38276C 0, #38276C 115px, transparent 115px, transparent 100%);
  }
}

.upcoming-workshops-bar__label {
  font: normal bold 18px/22px 'Droid Sans', sans-serif !important;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: white;
  flex: 0 0 auto;
  display: none; /* hidden on mobile */
  flex-flow: column nowrap;
  justify-content: center;
  height: 80px;
  padding: 0 24px 0 0;
}
@media (min-width: 768px) {
  .upcoming-workshops-bar__label {
    display: flex;
  }
}

.upcoming-workshops-bar__next {
  position: relative;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  height: 80px;
  padding: 0 0 0 40px;
  transition: opacity 0.2s;
}

.upcoming-workshops-bar__next.done-scrolling-right {
  opacity: 0;
}

.upcoming-workshops-bar__next::after {
  content: '';
  position: absolute;
  right: 100%;
  top: 0;
  width: 56px;
  height: 80px;
  background: linear-gradient(to right, rgba(56, 39, 108, 0) 0, rgba(56, 39, 108, 1) 100%);
}

.upcoming-workshops-bar__next button {
  position: relative;
  cursor: pointer;
}

.upcoming-workshops-bar__next span {
  letter-spacing: -10px;
  font-size: 38px;
  font-weight: normal;
  position: absolute;
  top: 2px;
  left: 50%;
  margin-left: -10px;
  cursor: pointer;
}

.upcoming-workshops-bar__view-all {
  flex: 0 0 auto;
  display: none; /* hidden on mobile */
  flex-flow: column nowrap;
  justify-content: center;
  height: 80px;
  padding: 0 0 0 28px;
}

@media (min-width: 992px) {
  .upcoming-workshops-bar__view-all {
    display: flex;
  }
}

.upcoming-workshops-bar__workshops {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  flex: 1;
  padding: 11px 0 0;
  position: relative;
  overflow-x: scroll;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}
.upcoming-workshops-bar__workshops::-webkit-scrollbar {
  display: none;
}

.upcoming-workshops-bar__workshop {
  flex: 0 0 315px;
  width: 315px;
  max-width: 315px;
  position: relative;
  scroll-snap-align: start;
}

@media (min-width: 992px) {
  .upcoming-workshops-bar__workshop {
    max-width: none;
  }
}

.has-1-workshops .upcoming-workshops-bar__workshop {
  flex: 0 0 100%;
  width: 100%;
}

@media (min-width: 1800px) {
  .has-2-workshops .upcoming-workshops-bar__workshop {
    flex: 0 0 49%;
    width: 49%;
  }
  
  .has-3-workshops .upcoming-workshops-bar__workshop {
    flex: 0 0 33%;
    width: 33%;
  }

  .has-4-workshops .upcoming-workshops-bar__workshop {
    flex: 0 0 25%;
    width: 25%;
  }
}

.upcoming-workshops-bar__workshop__link {
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  padding: 10px 20px 10px 10px;
}

.upcoming-workshops-bar__workshop__date {
  display: flex;
  flex-flow: column nowrap;
  width: 38px;
  flex: 0 0 38px;
  text-align: center;
  text-transform: uppercase;
}

.upcoming-workshops-bar__workshop__date__month {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
  background: white;
  font: normal bold 13px/1 'Droid Sans', sans-serif;
  letter-spacing: 0.29px;
  color: #38276C;
  padding: 1px 0;
}

.upcoming-workshops-bar__workshop__date__day {
  border-bottom-left-radius: 4px;
  border-bottom-right-radius: 4px;
  border: 2px solid white;
  border-top-width: 0;
  font: normal bold 18px/1 'Droid Sans', sans-serif;
  letter-spacing: 1.1px;
  color: white;
  padding: 3px 0 1px;
  margin-top: -1px;
}

.upcoming-workshops-bar__workshop__body {
  padding-left: 12px;
  margin-top: -5px;
  overflow: hidden;
}

.upcoming-workshops-bar__workshop__title {
  font: normal bold 18px/24px 'Noto Sans', sans-serif !important;
  color: white;
  padding: 0;
  margin: 0;
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.upcoming-workshops-bar__workshop__location {
  font: italic normal 18px/24px 'Noto Sans', sans-serif !important;
  color: white;
  display: block;
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Hover effects */
.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:hover,
.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:focus {
  background-color: #4C3D7A;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:hover .upcoming-workshops-bar__workshop__title,
.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:focus .upcoming-workshops-bar__workshop__title {
  text-decoration: underline;
}

.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:hover .upcoming-workshops-bar__workshop__title,
.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:focus .upcoming-workshops-bar__workshop__title,
.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:hover .upcoming-workshops-bar__workshop__location,
.upcoming-workshops-bar__workshop.in-viewport .upcoming-workshops-bar__workshop__link:focus .upcoming-workshops-bar__workshop__location {
  white-space: normal;
  overflow: visible;
}

/* Spacer, to compensate for floating bar */
.upcoming-workshops-bar__spacer {
  height: 80px;
}