Позиционирование дочерних строк bootstrap

Позиционирование дочерних строк bootstrap.
Допустим имеется три строки вложенные в родительский div: Строка-1,
Строка-2, Строка-3.

Решение-1.

  • Строка-1 - заполняет свободное пространство (Строка-2, Строка-3 - 50/50 );
  • Строка-2 - заполняет свободное пространство (Строка-2, Строка-3 - 50/50 );
  • Строка-3 - прижата к нижней точке родителя. Высота строки задаётся.

Решение-2.

  • Строка-1 - прижата к верхней точке родителя. Высота строки задаётся.
  • Строка-2 - заполняет свободное пространство (Строка-2, Строка-3 - 50/50 );
  • Строка-3 - заполняет свободное пространство (Строка-2, Строка-3 - 50/50 );

Как реализовать эти два решения?

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Bootstrap 5 CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-+0n0xVW2eSR5OomGNYDnhzAbDsOXxcvSN1TPprVMTNDbiYZCxYbOOl7+AMvyTG2x" crossorigin="anonymous">
</head>
 
 
<!-- === === ===     BODY  === === === === === === === === === === === -->
<body>
  <div class="container vh-100 w-100 bg-info">
    <div class="row vh-100 w-100 border border-white">
      <div class="col-4 border  border-danger" >
      col-1
        <div class="row border border-danger" >
          row-1
        </div>
        <div class="row border border-danger" >
          row-2
        </div>
        <div class="row border border-danger" >
          row-3
        </div>
      </div>
      <div class="col-5 border border-danger" >
      col-2
      </div>
      <div class="col-3 border border-danger" >
      col-3
      </div>
    </div>
  </div>
  <!-- Bootstrap 5 Scripts -->
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.1/dist/js/bootstrap.bundle.min.js" integrity="sha384-gtEjrD/SeCtmISkJkNUaaKMoLD0//ElJ19smozuHV6z3Iehds+3Ulb9Bn9Plx0x4" crossorigin="anonymous"></script>
</body>
</html>

Такие задачи решаются через flexbox A Complete Guide to Flexbox | CSS-Tricks - CSS-Tricks. Еще возожно решить через разметку таблицами что нежелательно по ряду факторов (сложнее адаптировать для мобильников, хуже индексация, нюансы с “прыганьем” контента при загрузке страницы), и через grid (что концептуально сложнее уловить чем flexbox).

Вот решения через flexbox. Первая колонка - решение-1, вторая колонка решение-2.

UPD добавил в демку фиксированные по высоте строки. Для наглядности подсветил их красным

А как менять высоту строки?
Это цифрой?

.flex-restricted {
  flex-grow: 5;
}

По классике: “height: 100px;”.

Это делает совсем другое

Так?

.flex-restricted {
  flex-grow: 0;
  height: 100px;
}```

Да. Возможно высота не будет задаваться без дополнительной строки position: relative (сам до сих пор не имеют концепции в голове когда без этого свойства высота не задается)