﻿i.dynamic-filter-All:before {
  content: "\f732";
}

i.dynamic-filter-WalkingDistance:before {
  content: "\f554";
}

i.dynamic-filter-Ecological:before {
  content: "\f06c";
}

i.dynamic-filter-Luxury:before {
  content: "\f3a5";
}

i.dynamic-filter-Economic:before {
  content: "\f51e";
}

i.dynamic-filter-MostBooked:before {
  content: "\f7e4";
}

i.dynamic-filter-TravelerRating:before {
  content: "\f164";
}

i.dynamic-filter-Youth:before {
  content: "\f0f2";
}

.dynamic-filter-container {
  padding-left: 0;
  padding-right: 0;
  padding-top: 0;
  margin: 0;
}

.dynamic-filters.gallery {
  padding-bottom: 50px;
  display: flex;
  flex-flow: wrap;
  align-items: center;
  justify-content: center;
}

.dynamic-filters.gallery > * > .dynamic-filter {
  position: relative;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.6);
  padding: 0;
  margin-top: 10px;
  margin-bottom: 10px;
  height: auto;
  width: 100%;
  border-radius: 0px 0px 10px 10px;
  opacity: 0.8;
  min-width: 160px;
}

.dynamic-filters.gallery > * > .dynamic-filter:hover {
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.8);
  opacity: 1;
  transition-duration: 1s;
  animation-duration: 1s;
}

.dynamic-filters.gallery > * > .dynamic-filter:active:focus {
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6);
}

/*.dynamic-filters.gallery > * >*/
.dynamic-filter > .title {
  flex: 0;
  color: white;
  font-weight: bold;
  font-size: 15px;
  text-align: center;
  position: relative;
  margin-top: -5px;
  width: 100%;
  line-height: 35px;
  background-color: rgba(0, 0, 0, 0.8);
  pointer-events: none;
  border-radius: 0px 0px 10px 10px;
}

.dynamic-filters.gallery > * > .dynamic-filter > .image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (min-width: 768px) {
  .col-dynamic-filter {
    flex: 0 1 auto;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .dynamic-filter-container {
    padding-left: 0px !important;
    padding-right: 0px !important;
    padding-top: 60px !important;
  }
}
@media (max-width: 768px) {
  .col-dynamic-filter {
    flex-basis: 100%;
    flex-flow: row wrap;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .dynamic-filter-container {
    padding-left: 15px;
    padding-right: 15px;
  }
}
* {
  margin: 0;
}

html, body {
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

body {
  font-size: 11pt;
  color: #666666;
  margin: 0 0;
}

header, #header {
  background-color: var(--color1);
  position: sticky;
  top: 0;
  padding: 0;
  margin: 0;
  z-index: 3;
}

#header > div.offcanvas {
  z-index: 1041;
}

#header .btn:not(.mobile-filters),
#header button:not(.mobile-filters) {
  font-size: 0.8rem !important;
}

.right-buttons .select2-selection {
  font-size: 0.8rem !important;
  min-width: 200px !important;
}

main {
  scrollbar-width: thin;
  width: 100%;
  height: calc(100% - 60px);
}

footer {
  /*background-color: var(--color1);
  color:white;*/
  position: fixed;
  bottom: 0;
  padding: 0px;
  margin: 0px;
  width: 100%;
  z-index: 2;
}

footer > * {
  padding: 5px;
}

.bg-color1 {
  background-color: var(--color1);
}

.bg-color2 {
  background-color: var(--color2);
}

.text-color1 {
  color: var(--color1);
}

.text-color2 {
  color: var(--color2);
}

.mh-100 {
  max-height: 100% !important;
}

.mw-100 {
  max-width: 100% !important;
}

.btnRadius {
  border-radius: 8px !important;
}

.daterangepicker td.in-range {
  background-color: rgba(var(--bs-primary-rgb), 0.5);
  border-color: transparent;
  color: #000;
  border-radius: 0;
}

.daterangepicker td.active, .daterangepicker td.active:hover {
  background-color: var(--primary-color);
  border-color: transparent;
  color: #fff;
}

.map-container {
  min-height: 45px !important;
}

#hotels-list-items-container {
  overflow-y: auto;
  height: 100%;
  max-height: 92%;
}

.hotel-list-item > a {
  text-decoration: none;
  color: var(--color1);
}

.hotel-list-item > a:hover > div {
  background-color: #EEEEEE;
}

/* dynamic filters */
.btn-align {
  margin-left: 5px;
  margin-right: 5px;
}

tr.hotel {
  cursor: pointer;
}

tr.hotel:hover > td {
  background-color: var(--bs-primary);
  color: white;
}

@media (max-width: 991px) {
  .btn-align {
    width: 100%;
    margin: 5px;
    padding-bottom: 1px;
  }
  .btn-align > .dropdown-menu,
  .btn-align > .select2-container,
  .btn-align > * {
    width: 100%;
  }
  .filter-mobile .btn-mobile {
    width: 80vw !important;
    max-width: 300px !important;
  }
  .filter-mobile .dropdown-mobile {
    position: relative !important;
    transform: unset !important;
  }
  .smallscreen-nav {
    flex-direction: column;
  }
  .smallscreen-nav .left-buttons {
    align-items: center;
  }
  .filters-mobile-container {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .quick-filters {
    width: 90%;
    border-top: 1px solid #ccc;
    display: flex;
    flex-direction: column;
  }
  .quick-filters a {
    display: flex;
    align-items: center;
    padding: 10px;
    text-decoration: none;
    color: inherit;
    transition: background 0.2s;
    border: none;
    border-bottom: 1px solid #ccc;
  }
  .quick-filters a.active {
    background-color: var(--bs-link-hover-color-rgb);
    font-weight: bold;
  }
  .quick-filters i {
    margin-right: 8px;
  }
  .reset-mobile {
    align-self: flex-end;
    padding-top: 15px;
  }
  .mobile-filters {
    padding: 6px 30px;
    font-size: small !important;
    color: black;
  }
}
@media screen and (max-width: 0) {
  .btn-align {
    /*... */
  }
}
@media screen and (max-width: 576px) {
  .btn-align {
    /*... */
  }
}
@media screen and (max-width: 768px) {
  .btn-align {
    /*... */
  }
}
@media screen and (max-width: 992px) {
  .btn-align {
    /*... */
  }
}
@media screen and (max-width: 1200px) {
  .btn-align {
    /*... */
  }
}
@media screen and (max-width: 1400px) {
  .btn-align {
    /*... */
  }
}
@media (max-width: 767px) {
  .col-hotels.map-on {
    display: none;
  }
  .h-sm-100 {
    height: 100% !important;
  }
}
.imgHotels {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.divHotelImage, .divHotelSlide {
  overflow: hidden;
  height: 220px;
  margin-bottom: 5px;
  text-align: center;
  position: relative;
  background-color: #f3eded;
  position: relative;
}

/* Dynamic filters */
img.svg-filter {
  background-color: var(--color1);
  color: var(--color2);
  padding: 30px;
  object-fit: contain;
  object-position: center;
}

.fadeInDynamicFilter {
  opacity: 0;
  -webkit-animation: fadeIn 1s;
  -webkit-animation-delay: 0s;
  animation: fadeIn 1s;
  animation-delay: 0s;
}

@-webkit-keyframes fadeIn {
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  100% {
    opacity: 1;
  }
}
.fadeOut {
  opacity: 1;
  -webkit-animation: fadeOut 1s forwards;
  -webkit-animation-delay: 0s;
  animation: fadeOut 1s forwards;
  animation-delay: 0s;
}

@-webkit-keyframes fadeOut {
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  100% {
    opacity: 0;
  }
}
.slide-animation {
  opacity: 0;
  -webkit-animation: slide 3s forwards;
  -webkit-animation-delay: 0s;
  animation: slide 3s forwards;
  animation-delay: 0s;
}

@-webkit-keyframes slide {
  100% {
    opacity: 1;
  }
}
@keyframes slide {
  100% {
    opacity: 1;
  }
}
.dynamic-filters .divEcoSlide {
  border-radius: 10px 10px 10px 10px;
  overflow: hidden;
  background-color: var(--color1);
  color: white;
  padding: 6px 10px 3px 10px;
  text-align: center;
}

.dynamic-filters .divEcoSlide > img {
  padding: 0px;
  height: 30px;
  width: 30px;
}

.dynamic-filters .divHotelSlide {
  border-radius: 10px 10px 0px 0px;
  max-height: 160px;
  overflow: hidden;
  background-color: var(--color1);
}

.dynamic-filters div.secondary {
  position: absolute;
  right: 57px;
  top: 17px;
  color: white;
}

.dynamic-filters img.imgHotelsSmall {
  width: 85%;
  height: 85%;
  top: 25px;
  position: relative;
}

.dynamic-filters img.secondary {
  position: absolute;
  right: 5px;
  top: 2px;
  width: 50px;
  height: 50px;
}

.dynamic-filters .divHotelSlide > div > a > img:not(.secondary) {
  transition-duration: 1s;
  animation-duration: 1s;
  border-radius: 20px;
  -webkit-transition-duration: 1s;
  -webkit-transform: scale(0.8);
}

.dynamic-filters .divHotelSlide > div > a > img:hover {
  transform: scale(1.3);
  -ms-transform: scale(1.3); /* IE 9 */
  -moz-transform: scale(1.3); /* Firefox */
  -webkit-transform: scale(1); /* Safari and Chrome */
  -o-transform: scale(1.3); /* Opera */
}

@media (max-width: 768px) {
  .dynamic-filters .divHotelSlide {
    max-height: 100px;
  }
  img.svg-filter {
    padding: 10px;
  }
}
.sustainability-link {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(to right, #698b27, #86b72e);
  color: white;
  border-radius: 40px;
  padding: 2px 11px 0 4px;
  gap: 8px;
  text-decoration: none;
  height: 32px;
  font-size: 0.8rem !important;
}

.sustainability-image {
  height: 28px;
  width: 28px;
  border-radius: 50%;
  object-fit: cover;
}

.sustainability-text {
  white-space: nowrap;
}

.dropdown-card {
  padding: 10px;
  width: 80vw;
  max-width: 300px;
  top: unset;
  left: unset;
  transform: translateX(-25%);
}

.right-buttons {
  padding-top: 10px;
  display: flex;
  justify-content: flex-end;
  width: 100%;
  padding-right: 5px;
}

.mobile-padding-bottom {
  padding-bottom: 5rem;
}

.daterangepicker {
  left: auto !important;
}
