<div class="parent">
  <div class="child"></div>
  <div class="child"></div>
  <div class="child"></div>
  <div class="child"></div>
</div>
.parent {
  width: 100%;
  display: flex;
}

.child {
  margin: 5px;
  width: 25%;
  border: 2px solid red;
  background: silver;
/*   14px = margin*2 +  border*2 */
  padding-bottom: calc(25% - 14px);
}

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.