Есть два сту^W столбца таблицы, им назначена равная ширина (width: 50%). Но когда одному из них поставить ещё display:flex, он скукоживается до одной четвёртой общей ширины таблицы. Почему так? Это баг или фича?
Код:
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <style>
    td { width: 50%; }
    .d0 {
      display: flex;
      flex-direction: column;
      background-color: lightgray;
    }
    .d1 {
      display: flex;
      flex-grow: 1;
      border: 1px dotted gray;
    }
    .d2 {
      flex-grow: 1;
      background-color: yellow;
    }
    .d3 {
      width: 64px;
      flex-grow: 0;
      flex-shrink: 0;
      background-color: blue;
    }
  </style>
</head>
<body>
  <table width="100%">
    <tr>
      <td>what</td>
      <td class="d0">
        <div class="d1">
          <div class="d2">the</div>
          <div class="d3">fuck?</div>
        </div>
      </td>
    </tr>
  <table>
</body>
</html>


