.img-zoom, .propertycard__top .propertycard__slider a:hover img {
  transition: all 300ms ease-in 0s;
  transform: scale(1.1);
  filter: progid:DXImageTransform.Microsoft.Matrix(M11=1.5, M12=0, M21=0, M22=1.5, SizingMethod='auto expand'); }

.propertycard--ref {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 2px;
  font-size: 12px;
  font-size: 0.75em;
  font-size: 0.75rem;
  padding: 0 1.25em;
  background-color: rgba(0, 0, 0, 0.7);
  color: white;
  position: absolute;
  z-index: 1;
  height: 29px;
  top: 10px;
  left: 10px; }

.propertycard--fav {
  width: 31px;
  height: 29px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.7);
  top: 10px;
  right: 10px;
  border-radius: 2px;
  cursor: pointer; }
  .propertycard--fav svg {
    width: 20px;
    height: 18px;
    fill: #f0f0f0; }

.propertycard--title {
  font-size: 18px;
  font-size: 1.125em;
  font-size: 1.125rem;
  line-height: 1.4;
  margin: 0 0 1em;
  font-weight: 600;
  min-height: 3rem; }

.propertycard--price {
  font-size: 18px;
  font-size: 1.125em;
  font-size: 1.125rem;
  color: #c59653;
  font-weight: 400;
  margin: 0; }

.propertycard__top {
  position: relative; }
  .propertycard__top .propertycard__slider a img {
    transition: all 600ms ease-in-out 0s; }

.propertycard__body {
  padding: 22px 10px 0; }

.propertycard__flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 15px;
  border-bottom: 1px solid #e5e4e4; }
  .propertycard__flex span {
    font-size: 14px;
    font-size: 0.875em;
    font-size: 0.875rem; }

.propertycard__details {
  padding: 20px 0;
  border-bottom: 1px solid #e5e4e4;
  display: flex;
  align-items: center;
  justify-content: space-between; }
  .propertycard__details ul {
    display: flex;
    align-items: center; }
    .propertycard__details ul li {
      display: flex;
      align-items: center;
      font-size: 14px;
      font-size: 0.875em;
      font-size: 0.875rem;
      margin: 0 17px 0 0; }
      .propertycard__details ul li:last-child {
        margin-right: 0; }
      .propertycard__details ul li svg {
        fill: #fdcf2c;
        margin: 0 8px 0 0; }
        .propertycard__details ul li svg.bed {
          width: 19px;
          height: 15px; }
        .propertycard__details ul li svg.bath {
          width: 24px;
          height: 14px; }
        .propertycard__details ul li svg.home {
          width: 15px;
          height: 15px; }
        .propertycard__details ul li svg.garden {
          width: 22px;
          height: 15px; }
  .propertycard__details .property--link {
    width: 35px;
    height: 35px;
    display: flex;
    justify-content: center;
    align-items: center; }
    .propertycard__details .property--link svg {
      width: 24px;
      height: 24px;
      fill: #86979f; }

.listingpage__top {
  display: flex;
  align-items: center;
  justify-content: center; }
  .listingpage__top h1 {
    font-size: 40px;
    font-size: 2.5em;
    font-size: 2.5rem;
    text-transform: uppercase;
    font-weight: 300;
    margin: 85px 0; }

.listing__top {
  display: flex;
  justify-content: space-between;
  padding: 40px 45px; }
  .listing__top h2 {
    width: 100%;
    text-align: center; }
  .listing__top > p {
    font-size: 14px;
    font-size: 0.875em;
    font-size: 0.875rem;
    color: #121212;
    margin: 0; }
    .listing__top > p span {
      text-transform: uppercase;
      margin: 0 0.25em 0 0; }

.listing__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(480px, 1fr));
  gap: 66px 30px;
  padding: 0 45px;
  margin: 0 0 80px; }

.listing__bottom {
  margin: 0;
  padding: 0 45px;
  text-align: center; }

@media screen and (max-width: 37.4375em) {
  .propertycard {
    width: calc(100vw - 3em); }
  .listingpage__top h1 {
    margin: 50px 0; }
  .listing__top {
    padding: 40px 1em;
    flex-wrap: wrap;
    justify-content: center; }
    .listing__top p {
      width: 100%;
      text-align: center;
      margin: 0 0 1.5em; }
  .listing__grid {
    grid-template-columns: 1fr;
    padding: 0 1em; } }

@media screen and (min-width: 37.5em) and (max-width: 64em) {
  .propertycard {
    width: calc(50vw - 3em); }
  .listing__grid {
    grid-template-columns: repeat(2, 1fr);
    padding: 0 1em; }
    .listing__grid .propertycard__slider {
      height: 280px; }
      .listing__grid .propertycard__slider .slick-track {
        height: 280px; } }

@media screen and (min-width: 64.0625em) and (max-width: 90.625em) {
  .listing__grid {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); }
    .listing__grid .propertycard__slider {
      height: 280px; }
      .listing__grid .propertycard__slider .slick-track {
        height: 280px; } }
