/*
--------------------------------------------------------------------------------
Article List Page
--------------------------------------------------------------------------------
*/
.blog-list {
  position: relative;
  display: grid;
  margin-bottom: 30px;
  margin-left: 0;
  padding-left: 0;
  list-style: none;
  gap: 30px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* tablets */
@media (min-width: 576px) and (max-width: 768px) {
  .blog-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* desktops */
@media (min-width: 768px) {
  .blog-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

.blog-list-item {
  position: relative;
}

.blog-list-item-image {
  position: relative;
  display: flex;
  flex-direction: column;
  margin-bottom: 15px;
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.05);
  border-radius: 3px;
  box-shadow: inset 0 0 1px rgb(0, 0, 0, 0.5);
  aspect-ratio: 3 / 2;
}

.blog-list-item-image a {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.blog-list-item-image img {
  transition: all 150ms;
}

.blog-list-item:hover .blog-list-item-image img {
  transform: scale(1.025);
}

.blog-list-item-title {
  font-size: 120%;
}

.blog-list-item-title a {
  text-decoration: none;
}

.blog-list-item-date {
  margin-bottom: 15px;
  font-size: 14px;
  opacity: 0.6;
}

.blog-list-item-teaser {
  display: -webkit-box;
  /* "em" works better here than "px" */
  max-height: 4.5em;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.blog-list-item-categories {
  margin-bottom: 15px;
}

/*
--------------------------------------------------------------------------------
Article Details Page                                   BLOG.article_display.html
--------------------------------------------------------------------------------
*/

@media (min-width: 992px) {
  .blog-article {
    display: flex;
  }
}

.blog-article-image {
  margin-bottom: 30px;
}

/* desktops */
@media (min-width: 768px) {
  .blog-article-image {
    width: 300px;
    margin-right: 30px;
  }

  .blog-article-image img {
    position: sticky;
    top: 100px;
  }
}

.blog-article-image img {
  width: 100%;
}

.blog-article-content {
  flex: 1;
}

.blog-article-date {
  font-size: 14px;
  opacity: 0.6;
}

.blog-article-categories {
  margin-bottom: 15px;
}

.blog-article .row {
  margin-bottom: 30px;
}