Расстановка

Основная идея, продемонстрированная здесь, — это использование justify-content: space-between , которое размещает первый и последний дочерние элементы по краям их ограничивающего прямоугольника, а оставшееся пространство равномерно распределяется между элементами. Для этих карточек они помещаются в режим отображения flexbox, при этом направление столбца устанавливается с помощью flex-direction: column .

При этом заголовок, описание и блок изображения помещаются в вертикальный столбец внутри родительской карточки. Затем применение justify-content: space-between привязывает первый (заголовок) и последний (блок изображения) элементы к краям гибкого контейнера, а описательный текст между ними размещается с равным интервалом до каждой конечной точки.

.container {
  display
: flex;
  flex
-direction: column;
  justify
-content: space-between;
}
<div class="container">
 
<div class="card">
   
<h3>Title - Card 1</h3>
   
<p contenteditable>Medium length description with a few more words here.</p>
   
<div class="visual"></div>
 
</div>
 
<div class="card">
   
<h3>Title - Card 2</h3>
   
<p contenteditable>Long Description. Lorem ipsum dolor sit, amet consectetur adipisicing elit.</p>
   
<div class="visual"></div>
 
</div>
 
<div class="card">
   
<h3>Title - Card 3</h3>
   
<p contenteditable>Short Description.</p>
   
<div class="visual"></div>
 
</div>
</div>

       
.container {
 
display: grid;
 
grid-gap: 1rem;
 
grid-template-columns: repeat(3, 1fr);
}

.visual {
 
height: 100px;
 
width: 100%;
}

.card {
 
display: flex;
 
flex-direction: column;
 
padding: 1rem;
 
justify-content: space-between;
}

h3
{
 
margin: 0
}