<div class="wrap">
  <div class="card">
    <div class="card_img">
      <img src="https://katsu-dev.netlify.app/static/default_ogpimage-62d4a2892ca742cbdcb2a1523b97bef3.jpg" alt="カードイメージ">
    </div>
    <div class="card_text">
      <h2 class="card_title">吾輩は猫である</h2>
      <p class="card_desc">吾輩は猫である。名前はまだ無い。
         どこで生れたかとんと見当がつかぬ。何でも薄暗いじめじめした所でニャーニャー泣いていた事だけは記憶している。吾輩はここで始めて人間というものを見た。</p>
      <p class="card_date">2023年1月1日</p>
    </div>
  </div>
  <div class="card">
    <div class="card_img">
      <img src="https://katsu-dev.netlify.app/static/default_ogpimage-62d4a2892ca742cbdcb2a1523b97bef3.jpg" alt="カードイメージ">
    </div>
    <div class="card_text">
      <h2 class="card_title">記事タイトル</h2>
      <p class="card_desc">記事の本文</p>
      <p class="card_date">2023年1月1日</p>
    </div>
  </div>
  <div class="card">
    <div class="card_img">
      <img src="https://katsu-dev.netlify.app/static/default_ogpimage-62d4a2892ca742cbdcb2a1523b97bef3.jpg" alt="カードイメージ">
    </div>
    <div class="card_text">
      <h2 class="card_title">記事タイトル</h2>
      <p class="card_desc">記事の本文</p>
      <p class="card_date">2023年1月1日</p>
    </div>
  </div>
</div>
.card {
  width: 300px;
  height: auto;
  margin-bottom: 16px;
  margin-right: 16px;
  background-color: #fff;
  border-radius: 5px;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.16);
  transition: all 0.5s;
  position: relative;
  overflow: hidden;
}
/* 横並べで3個で折り返す場合は下記を入れると収まりがいい */
/* .card:nth-of-type(3n){
  margin-right: 0;
} */
.card:hover {
  transform: translateY(-3px);
  box-shadow: 0 7px 14px rgba(50, 50, 93, 0.1), 0 3px 6px rgba(0, 0, 0, 0.08);
}
.card .card_img img {
  width: 100%;
  height: auto;
  vertical-align: top;
}
.card .card_text {
  margin: 0;
  padding: 20px 16px 32px;
  font-family: sans-serif;
}
.card .card_text .card_title {
  margin: 0 0 20px;
  border-bottom: 1px solid #ddd;
  font-size: 20px;
}
.card .card_text .card_desc {
  margin: 0 0 16px;
  font-size: 14px;
  line-height: 1.7;
}
.card .card_text .card_date {
  margin: 0;
  padding: 12px 16px;
  font-size: 12px;
  color: #888;
  position: absolute;
  bottom: 0;
  right: 0;
}
.wrap {
  display: flex;
  flex-wrap: wrap;
  min-width: min-content;
  margin: 0;
  padding: 10px;
  border: 1px solid gray;
  background-color: #eee;
}
Run Pen

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.