@charset "UTF-8";

#related-articles--container #related-articles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
  padding: 20px;
}

#related-articles--container #related-articles article {
  border: 1px solid #ddd;
  padding: 20px;
}

#related-articles--container #related-articles article a {
  display: contents;
}

#related-articles--container #related-articles article img {
  max-width: 100%;
  height: auto;
  display: block;
}

#related-articles--container #related-articles article .text-content {
  line-height: 1.6;
  margin-top: 20px;
}

#related-articles--container #related-articles article .text-content h3 {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 0;
  /* 2行目以上は省略 */
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

#related-articles--container #related-articles article .text-content p {
  font-size: 12px;
  margin: .2em 0 0;
  /* 2行目以上は省略 */
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

@media screen and (min-width: 768px) {
  #related-articles--container #related-articles {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media screen and (max-width: 600px) {
  #related-articles--container #related-articles {
    grid-template-columns: 1fr;
  }

  #related-articles--container #related-articles article {
    display: flex;
    align-items: flex-start;
  }

  #related-articles--container #related-articles article img {
    max-width: calc(100%/3);
    margin-right: 10px;
  }

  #related-articles--container #related-articles article .text-content {
    flex: 1;
    margin-top: 0px;
  }

  #related-articles--container #related-articles article .text-content p {
    margin-top: .2em;
  }

}
