Here is the playground :
.container {
width: 500px;
display: flex;
flex-flow: row wrap;
align-items: flex-start;
align-content: flex-start;
justify-content: flex-start;
justify-items: flex-start;
gap: 1rem;
padding: 1rem;
box-sizing: border-box;
border: 1px solid salmon;
}
.item {
flex: 1 1 auto;
min-width: 50px;
height: 6rem;
padding: 1rem;
box-sizing: border-box;
background-color: teal;
border-radius: 0.4rem;
display: grid;
place-items: center;
font-size: 1.25rem;
line-height: 1.5rem;
text-align: center;
cursor: pointer;
}
<div class="container">
<div class="item">Some content</div>
<div class="item">Some content</div>
<div class="item">Some content</div>
<div class="item">Some content in the item</div>
</div>
As you can see the last item is taking the remaning space, I would like it not to, and instead take the space required by the text. How should I proceed ?
I am aware I can use grid layout for this, but I would like to stay on flex layout.