Вот мой вариант:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div class="block1">
<div class="inner-block1"></div>
</div>
<div class="block2">
<div class="inner-block2"></div>
</div>
<div class="block3">
<div class="inner-block3"></div>
</div>
</body>
<style>
.block1{
width: 200px;
height: 300px;
overflow: hidden;
}
.inner-block1{
width: 300px;
border-radius: 50%;
height: 400px;
background-color: brown;
}
.block2{
width: 800px;
height: 80px;
overflow: hidden;
border-radius: 50px;
border-top-left-radius: 2px;
/*Отступы для читабельности*/margin-top: 30px;
}
.inner-block2{
width: 800px;
height: 80px;
background-color: rgb(42, 165, 54);
}
.block3{
width: 400px;
height: 200px;
overflow: hidden;
/*Отступы для читабельности*/margin-top: 30px;
}
.inner-block3{
width: 400px;
border-radius: 50%;
height: 400px;
background-color: rgb(42, 108, 165);
}
</style>
</html>
Все просто. Делаем простые фигуры и обрезаем их с помощью оверфлова(Или же просто делаем скругление в определенных местах)