.wc-sidebar-filter li {
  margin: 5px 0;
}
.wc-sidebar-filter li a {
  display: inline-block;
  max-width: 100%;
  text-overflow: ellipsis;
}

.wc-shop-category-tiles {
  grid-template-columns: repeat(var(--bs-columns, 12), minmax(0, 1fr));
}
@media (max-width: 575.98px) {
  .wc-shop-category-tiles {
    grid-template: 100%/repeat(var(--wc-category-count), min(90%, 330px));
    overflow-x: auto;
    scroll-snap-type: x mandatory;
  }
  .wc-shop-category-tiles > * {
    scroll-snap-align: center;
  }
}
.wc-shop-category-tiles .wc-course-category-tile {
  height: 375px;
  overflow: hidden;
}
.wc-shop-category-tiles .wc-course-category-tile .wc-category-label {
  padding: 8px 16px;
  font-size: 12px;
  line-height: 1;
  background-color: #CC0000;
  color: white;
}
.wc-shop-category-tiles .wc-course-category-tile .wc-image {
  height: 160px;
  width: 100%;
  object-fit: cover;
}
.wc-shop-category-tiles .wc-course-category-tile .wc-tile-content-wrapper {
  height: 215px;
  position: relative;
}
.wc-shop-category-tiles .wc-course-category-tile .wc-tile-content-wrapper .wc-tile-inner-container > h3 {
  margin-bottom: 4px;
}
.wc-shop-category-tiles .wc-course-category-tile .wc-icon-button:hover {
  color: #990000;
}

.wc-course-list-item {
  background-color: var(--wc-campuswhite);
}
.wc-course-list-item img {
  min-height: 312px;
  max-height: 312px;
  min-width: 230px;
  max-width: 230px;
  object-fit: cover;
}
.wc-course-list-item .wc-fallback-image {
  min-height: 312px;
  max-height: 312px;
  min-width: 230px;
  max-width: 230px;
  background-position: center center;
}
.wc-course-list-item .wc-grid {
  display: grid;
  width: 100%;
  min-height: 312px;
  max-height: 312px;
  grid-template: "heading         heading         icons" "heading         heading         price" "presence-select presence-select price" "presence-info   presence-info   price" "description     description     price" 1fr "booking-status  buttons         buttons"/1fr auto auto;
}
@media (max-width: 575.98px) {
  .wc-course-list-item .wc-grid {
    min-height: 400px;
    max-height: 500px;
    grid-template: "heading         icons" "presence-select presence-select" "presence-info   presence-info" "description     description" 1fr "price           price" "booking-status  booking-status" "buttons         buttons"/1fr min-content;
  }
}
.wc-course-list-item .wc-grid .wc-heading {
  grid-area: heading;
}
.wc-course-list-item .wc-grid .wc-description {
  grid-area: description;
}
.wc-course-list-item .wc-grid .wc-icon-flag {
  grid-area: icons;
}
.wc-course-list-item .wc-grid .wc-icon-flag:before {
  float: right;
}
.wc-course-list-item .wc-grid .wc-icon-container {
  grid-area: icons;
}
.wc-course-list-item .wc-grid .wc-icon-container .wc-icon-button.wc-portfolio-favorite {
  font-size: 20px;
}
.wc-course-list-item .wc-grid .wc-icon-container .wc-icon-button.wc-portfolio-favorite:focus {
  color: #262626;
}
.wc-course-list-item .wc-grid .wc-price-container {
  grid-area: price;
}
.wc-course-list-item .wc-grid .wc-button-container {
  grid-area: buttons;
}
.wc-course-list-item .wc-grid .wc-presence-select {
  grid-area: presence-select;
}
.wc-course-list-item .wc-grid .wc-presence-info {
  grid-area: presence-info;
}
.wc-course-list-item .wc-grid .wc-booking-status {
  grid-area: booking-status;
}
.wc-course-list-item .wc-button-container {
  overflow: hidden;
}
.wc-course-list-item .wc-button-container .btn.wc-optional {
  margin-right: 16px;
}
@media (max-width: 575.98px) {
  .wc-course-list-item .wc-button-container {
    flex-direction: column-reverse;
    flex-wrap: wrap;
  }
  .wc-course-list-item .wc-button-container .btn {
    width: 100%;
    padding: 12px;
  }
  .wc-course-list-item .wc-button-container .btn.wc-optional {
    margin-right: 0;
    margin-top: 8px;
  }
}
.wc-course-list-item .wc-booking-status {
  overflow: hidden;
}
.wc-course-list-item .wc-booking-status p {
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0;
  color: #CC0000;
  font-style: italic;
  font-size: 15px;
  padding-right: 4px;
}
@media (max-width: 575.98px) {
  .wc-course-list-item .wc-booking-status {
    justify-content: center;
  }
  .wc-course-list-item .wc-booking-status p {
    margin-bottom: 16px;
  }
}
@media (min-width: 576px) {
  .wc-course-list-item .wc-presence-select {
    margin-top: 6px;
  }
}
.wc-course-list-item .wc-presence-info span {
  vertical-align: middle;
}
.wc-course-list-item .wc-presence-info .material-icons {
  margin-right: 4px;
}

/*
  The paginator automatically adjusts to the available width.
  This is possible because all items have the same width and height.
  Child elements which should be hidden are nested in flex-boxes with wrapping enabled.
  The wrapped elements become invisible because of the parents overflow and max-height.
  Each nested container has a special empty element as the first item, so that the real
  first item can be wrapped.
 */
.wc-paginator {
  display: flex;
  overflow: hidden;
  max-height: 53px;
  margin-left: -2px;
}
.wc-paginator .btn {
  color: #262626;
  background: #ffffff;
  font-size: 15px;
  width: 53px;
  min-width: 53px;
  height: 53px;
  padding: 14px 0;
  margin-left: 2px;
}
.wc-paginator .btn.wc-current {
  color: #ffffff;
  background: #262626;
}
.wc-paginator .wc-empty-wrapper {
  display: flex;
  flex-wrap: wrap;
  min-width: 0;
}
.wc-paginator .wc-empty {
  width: 0;
  min-height: 53px;
}
.wc-paginator .wc-show-small {
  display: none;
}
@media (max-width: 628px) {
  .wc-paginator .wc-hide-small {
    display: none;
  }
  .wc-paginator .wc-show-small {
    display: block;
  }
}

.wc-shop-content {
  max-width: min(1000px, 100%);
}

@media (max-width: 575.98px) {
  .wc-shop-header h1 {
    font-size: 24px;
    letter-spacing: -1.2px;
  }
}
