.-bs-befored::before {
  font-family: 'bootstrap-icons';
}

/* School badges */

.school-badge {
  line-height: 1;
  display: inline-block;
  font-size: 0.875rem;
}

/*----------------------------*\
	School index search results
\*----------------------------*/

#filters_wrapper {
  height: 100svh;
  position: sticky;
  top: 5px;
  overflow-y: auto;
  scrollbar-width: thin;
}

#filters_form .blocset-legend {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  margin-bottom: .5rem !important;
}

#filters_form .bloc-legend {
  font-size: 0.875rem !important;
  font-weight: 700 !important;
}

/* Select2 */
#filters_form .select2-search{
  display: none !important;
}

#filters_form .select2-selection {
  position: relative;
}

#filters_form .select2-selection__rendered {
  position: absolute;
  top: 3px;
}
/* end Select2 */

#filters_form .entry-legend {
  font-size: 0.875rem !important;
  /* min-width: 100px; */
}

#filters_form .entry-value {
  font-size: 0.875rem !important;
  min-width: 30px;
  text-align: end;
}

#filters_form .entry-value.filter-count .count-value {
  color: var(--bs-primary);
}

#filters_form .dots {
  height: 1px;
  flex: 1;
  align-self: center !important;
  border-top: 1px dotted #c1c1c1;
}

#filters_form #filter_fees .controlset {
  margin-top: 0.1rem !important;
  margin-bottom: 0.1rem !important;
  padding-top: .5rem !important;
  padding-bottom: .5rem !important;
}

#filters_form #filter_fees .controlset:not(:last-of-type) {
  border-bottom: 1px solid #ccc;
}

#filters_form #filter_fees .controlset:has(+ .collapsable.collapsed) {
  border-bottom: none;
}

#filters_form #filter_fees .entry-legend {
  position: relative;
  top: -3px;
}

#filters_form #filter_fees .range-container {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 0px 1px;
  max-width: 70%;
}

#filters_form .badge-stars::before {
  --star-size: 0.8rem;
  position: relative;
  bottom: -2px;
}

#filters_form .collapsable {
  display: none;
}

#filters_form .bloc-cmd {
 color: var(--bs-primary);
 cursor: pointer;
}

#filters_form .bloc-cmd:hover {
  background: #e1e1e1;
}

.filters_form_action {
  width: 104px;
  height: 28px;
  display: flex !important;
  justify-content: center;
  align-items: center;
}

/* .filters_form_reset.hidden {
  display : none !important;
} */

#show_filters_modal_btn {
  float: right;
  color: white;
  background-color: #f56700;
  font-weight: bold;
}

/* School search summary */

#school_search_result #summary {
  background-color: #fef3ec;
  border: 1px solid #f56700;
  position: sticky;
  top: 5px;
  z-index: 100;
  box-shadow: rgba(0, 0, 0, 0.25) 0px 5px 5px;
  transition: all cubic-bezier();
}

#school_search_result #summary .collapsable {
  overflow: hidden;
}

#school_search_result #summary #filters_summary tr {
  vertical-align: baseline;
}

#school_search_result #summary #filters_summary tr::before {
  content: '\2022';
  width: 0.6rem;
  display: inline-block;
  font-weight: 900;
}

#school_search_result #summary #filters_summary .filter-label {
  min-width: 4rem;
  white-space: nowrap;
}

#school_search_result #summary #filters_summary .filter-separator {
  width: 0.6rem;
}

#school_search_result #summary #filters_summary .filter-value {
  font-weight: bold;
}

#school_search_result #summary #filters_summary #fees_summary {
  font-weight: initial;
}

#school_search_result #summary #filters_summary #fees_summary tr::before {
  content: '\00B7';
  width: 0.6rem;
  display: inline-block;
  font-weight: 900;
}

#school_search_result #summary #filters_summary .fee-level-range {
  text-align: end;
  font-weight: bold;
  white-space: nowrap;
}

#school_search_result #summary #filters_summary .fee-level-postlabel {
  font-style: italic;
  font-size: smaller;
}

#school_search_result #summary .schools-loader-backdrop {
  background-color: #000000bd;
}

#school_search_result #summary #summary_expand_cmd {
  position: absolute;
  top: -8px;
  color: #f56700;
  cursor: pointer;
}

/* School cards */

.school-card {
  box-shadow: rgba(0, 0, 0, 0.25) 0px 5px 5px;
}

.school-card:hover {
  box-shadow: rgba(0, 0, 0, 0.25) 0px 8px 8px, rgba(0, 0, 0, 0.25) 0px 5px 5px;
}

.school-card:hover .school_thumbnail_wrapper {
  /* overflow: hidden; */
  transform: translate(0px, -3px);
}

.school-card:hover .school_thumbnail {
  /* transform: scale(1.1); */
  box-shadow: rgba(0, 0, 0, 0.25) 0px 8px 8px, rgba(0, 0, 0, 0.25) 0px 5px 5px;
}

.school-card .school_thumbnail {
  width: 150px;
  max-width: 100%;
  height: auto;
  /* transition: transform 0.5s; */
}

.school-card .badge-stars::before {
  --star-size: 0.8rem;
  vertical-align: middle;
}

.school-card .badge-likes::before,
.school-card .badge-dislikes::before {
  font-size: 0.8rem;
  margin-right: 0.3rem;
}

.school-card .school-level {
  padding-top: 5px;
  padding-bottom: 5px;
}

/*----------------------------*\
	School page
\*----------------------------*/

/* school header */

[data-theme="gold"] .school-data .school-header .badge-stars {
  --star-background: #ffffffb0 !important;
  --star-color: #138a36 !important;
}

.school-data {
  position: relative;
}

.school-data .school-header {
  color: var(--header-text-color);
}

.school-data .btn-show-reviews:hover {
  background-color: #f5f5f5;
}

/* School badges */

.school-data .badge-stars {
  margin-right: 3rem;
}

.school-data .badge-stars::before {
  --star-size: 1.3rem;
}

.school-data .badge-likes,
.school-data .badge-dislikes {
  margin-right: 0.75rem;
}

.school-data .badge-likes::before,
.school-data .badge-dislikes::before {
  font-size: 1.1rem;
  margin-right: 0.3rem;
}

/* ------------ */

.school-data td {
  vertical-align: baseline;
  text-wrap: balance;
}

.school-data .school-status .-bs-befored::before {
  font-size: 0.75rem;
  color: var(--primary-color);
  vertical-align: text-bottom;
}

.school-data .school-status .data-label {
  width: 5rem;
  font-weight: 100;
}

.school-data .school-status .non_renseigne,
.school-data .school-description .non_renseigne,
.school-data .school-infos .non_renseigne {
  color: #bbbbbb;
  font-style: italic;
}

.school-data .school-status .location-data {
  display: flex;
}

.school-data .school-status .location-data::before {
  content: '\F3E7';
  margin: 2px 0.5rem 0 0;
}

.school-data .school-status .social-data .-bs-befored::before,
.school-data .school-status .contact-data .-bs-befored::before,
.school-data .school-status .social-data .-bs-befored::before {
  margin-right: 0.5rem;
}

.school-data .school-status .contact-data .phone-mobile::before {
  content: '\F4E2';
}

.school-data .school-status .contact-data .phone-office::before {
  content: '\F5B4';
}

.school-data .school-status .contact-data .email::before {
  content: '\F84B';
}

.school-data .school-status .contact-data .website::before {
  content: '\F3EE';
}

/* !!! Il y'a deux autres classes .social-facebook et .social-instagram dans core.css avec des background qui produisent un effet de bord*/
.school-data .school-status .social-data .social-facebook,
.school-data .school-status .social-data .social-instagram {
  background: transparent !important;
}

.school-data .school-status .social-data .social-linkedin::before {
  content: '\F472';
}

.school-data .school-status .social-data .social-x::before {
  content: '\F8DB';
}

.school-data .school-status .social-data .social-facebook::before {
  content: '\F344';
}

.school-data .school-status .social-data .social-instagram::before {
  content: '\F437';
}

/* ------------ */

.school-gallery #static_gallery img {
  width: 100%;
  min-height: 100%;
  object-fit: contain;
  background-color: #e6e6e6;
  transition: transform 0.5s;
}

.school-gallery #static_gallery img:hover {
  transform: scale(1.15);
}

.school-gallery #static_gallery .gallery-thumbnail img {
  max-height: 350px;
}

.school-gallery #static_gallery .gallery-side img {
  max-height: 175px;
}

.school-gallery #static_gallery .gallery-footer img {
  max-height: 150px;
}

.school-gallery #static_gallery .gallery-footer .more_images {
  width: 100%;
  height: 100%;
  background-color: #00000099;
  color: #ffffff;
  font-weight: bold;
  text-decoration: underline;
  text-align: center;
}

/* ------------ */

.school-data .school-infos .data-label {
  width: 12rem;
  font-weight: 100;
}

.school-data .school-infos .data-content {
  text-align: end;
  margin-left: 2rem;
}

/* ------------ */

.school-data .school-reviews #btn_about_reviews:hover {
  background-color: #f5f5f5;
}

.school-data .school-reviews .rating-wrapper .rating-data,
.school-data .school-reviews .rating-stats-wrapper .rating-stats-data {
  background-color: #f5f5f5;
}

.school-data .school-reviews .rating-stats-wrapper .rating-stats-data .badge-stars {
  margin-right: 0px;
  font-size: 0rem;
}

.school-data .school-reviews .rating-stats-wrapper .rating-stats-data .badge-stars::before {
  font-size: 0.75rem;
}

.school-data .school-reviews .rating-stats-wrapper .rating-stats-data .rating-bar {
  max-height: 3px;
  flex-grow: 1;
  background-color: #c2c2c2;
}

.school-data .school-reviews .rating-stats-wrapper .rating-stats-data .rating-mark {
  display: flex;
}

.school-data .school-reviews .rating-stats-wrapper .rating-stats-data .rating-mark .rating-indicator {
  background-color: var(--primary-color);
  height: 100%;
}

.school-data .school-reviews .rating-stats-wrapper .rating-stats-data .rating-mark .rating-mark-count {
  width: 3rem;
  text-align: end;
}

/* --------------- */

.school-data .school-reviews .review:last-of-type {
  border-bottom: none !important;
}

.school-data .school-reviews .review.current-user {
  background-color: #ffeebd !important;
}

.school-data .school-reviews .review .review-header .review-actions .btn-dropdown-actions:hover {
  background-color: #f5f5f5 !important;
}

.school-data .school-reviews .review .review-header .review-actions .btn-dropdown-actions::after {
  content: none;
}

.school-data .school-reviews .review .review-header .user-infos .user-thumbnail img {
  border-radius: 50%;
  width: 32px;
  height: 32px;
  overflow: hidden;
  background-size: cover;
}

.school-data .school-reviews .review .badge-stars {
  margin-right: 0px;
}

.school-data .school-reviews .review .badge-stars::before {
  --star-size: 0.75rem;
}

.school-data .school-reviews .review .btn-useful-yes,
.school-data .school-reviews .review .btn-useful-no {
  padding: 2px 6px;
  margin-left: 5px;
  color: var(--bs-secondary);
  background-color: #ffffff;
}

.school-data .school-reviews .review .btn-useful-yes:hover,
.school-data .school-reviews .review .btn-useful-no:hover {
  background-color: #f5f5f5;
}

.school-data .school-reviews .review .btn-useful-yes.clicked {
  background-color: #ffeebd;
}

.school-data .school-reviews .review .btn-useful-yes.clicked::before {
  content: '\F272';
  vertical-align: bottom;
  margin-right: 3px;
}

.school-data .school-reviews .review .btn-useful-no:disabled {
  background-color: transparent;
}

/* --------------- */

.school-data .school-reviews .review-form-wrapper {
  background-color: #f5f5f5;
}

.school-data .school-reviews #review_form .stars {
  color: var(--star-background);
}

.school-data .school-reviews #review_form .stars .marked {
  color: var(--star-color) !important;
}

/*----------------------------*\
	Responsive
\*----------------------------*/

@media screen and (width <=576px) {
  .school-card .school_thumbnail {
    width: 100%;
  }

  #filters_form_container {
    display: none;
  }
}