<div class="blocks">
<div class="block block_red"></div>
<div class="block block_blue"></div>
<div class="block block_blue"></div>
<div class="block block_red"></div>
</div>
.blocks {
display: flex;
flex-wrap: wrap;
}
.block {
background: black;
flex-basis: 50%;
}
.block_red {
background: red;
}
.block_blue {
background: blue;
}
.block:after {
content: "";
display: block;
padding-bottom: 100%;
}
<div class="blocks">
<div class="block block_red size25">1</div>
<div class="block block_blue size55">2</div>
<div class="block block_blue size45">3</div>
<div class="block block_red size35">4</div>
</div>
.blocks {
display: flex;
flex-wrap: wrap;
}
.block {
background: black;
flex-basis: 50%;
}
.block_red {
background: red;
}
.block_blue {
background: blue;
}
.block:after {
content: "";
display: block;
padding-bottom: 100%;
}
.size25 {
font-size: 25px;
color: green;
}
.size35 {
font-size: 35px;
color: orange;
}
.size45 {
font-size: 45px;
color: pink;
}
.size55 {
font-size: 55px;
color: lime;
}