@font-face {
  font-family: "Playfair";
  src: url(/assets/fonts/Playfair/Playfair144pt-Italic.woff2) format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
.titles {
  padding-top: clamp(16px, 2.6vw, 32px);
  margin-bottom: 36px;
}
.titles h1.title {
  font-size: clamp(2.25rem, 0.457rem + 5.978vw, 5rem);
  font-weight: 400;
  font-family: "Playfair", serif;
  font-style: italic;
  line-height: 1.37;
  text-align: center;
}
.titles h3.slogan {
  font-weight: 300;
  font-size: clamp(0.625rem, 0.299rem + 1.087vw, 1.125rem);
  text-align: center;
  letter-spacing: 2.5px;
}

main.buildings {
  margin-bottom: 48px;
}
main.buildings .building-wrap {
  display: flex;
  align-items: center;
  transition: opacity 0.8s ease-in-out;
}
main.buildings .building-wrap.is-fading {
  transition: opacity 0.3s ease-out;
  opacity: 0;
}
main.buildings .building-wrap.is-active {
  opacity: 1;
}
main.buildings article.building {
  display: grid;
  grid-template-columns: 1fr;
  gap: 11px;
  width: 100%;
}
main.buildings article.building .pic {
  margin-bottom: 9px;
}
main.buildings article.building .pic img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  object-fit: cover;
  aspect-ratio: 1/1;
}
main.buildings article.building h2.title {
  margin-bottom: 21px;
  padding: 0 10px;
  font-size: clamp(1.5rem, 0.44rem + 3.533vw, 3.125rem);
  font-weight: 500;
  line-height: 1;
}
main.buildings article.building .uzor IMG {
  width: auto;
  height: auto;
  margin: 0 auto;
}
main.buildings article.building .desc {
  margin-bottom: 24px;
  padding: 0 10px;
  font-size: clamp(0.875rem, 0.712rem + 0.543vw, 1.125rem);
  font-weight: 300;
  line-height: 1.28;
}

@media (min-width: 900px) {
  .titles {
    margin-bottom: 48px;
  }
  .titles h1.title {
    margin-bottom: 7px;
  }
  .titles h3.slogan {
    letter-spacing: 3.5px;
  }
  main.buildings {
    margin-bottom: 64px;
  }
  main.buildings .building-wrap {
    min-height: 100vh;
  }
  main.buildings article.building {
    grid-template-columns: 460fr 768fr;
    align-items: stretch;
    gap: 66px;
    padding: 0;
  }
  main.buildings article.building .pic {
    display: flex;
    margin-bottom: 0;
  }
  main.buildings article.building .pic IMG {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  main.buildings article.building .titleNdesc {
    align-self: center;
  }
  main.buildings article.building h2.title {
    align-self: flex-end;
    margin-bottom: 0;
    line-height: 1.2;
  }
  main.buildings article.building .desc {
    line-height: 1.45;
  }
  main.buildings article.building .uzor {
    display: none;
  }
  main.buildings article.building.rightPic {
    grid-template-columns: 768fr 460fr;
  }
  main.buildings article.building.rightPic .pic {
    grid-row: 1/2;
    grid-column: 2/3;
  }
  main.buildings article.building.rightPic .titleNdesc {
    grid-row: 1/2;
    grid-column: 1/2;
  }
}
@media (min-width: 1216px) {
  main.buildings article.building {
    grid-template-columns: 460fr 706fr 62px;
  }
  main.buildings article.building .uzor {
    display: block;
    align-self: center;
  }
  main.buildings article.building.rightPic {
    grid-template-columns: 62px 706fr 460fr;
  }
  main.buildings article.building.rightPic .pic {
    grid-row: 1/2;
    grid-column: 3/4;
  }
  main.buildings article.building.rightPic .titleNdesc {
    grid-row: 1/2;
    grid-column: 2/3;
  }
  main.buildings article.building.rightPic .uzor {
    grid-row: 1/2;
    grid-column: 1/2;
  }
}