<div class="container">
<div class="section">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p>
</div>
<div class="section collapsible">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</p>
</div>
<div class="section">
<p>Ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p>
</div>
</div>
<button id="toggle-button">Toggle collapse</button>
.container {
border: 3px solid #ffeb3b;
margin:0 auto;
max-width: 300px;
border-radius:3px;
display:flex;
flex-direction:column;
justify-items: flex-start;
height:600px;
.section{
overflow: hidden;
height:auto;
border:2px solid #ffeb3b;
transition:flex 0.3s ease-out;
flex:1;
}
}
.section.collapsible.collapsed{
flex:0;
}
View Compiled
// Look ma, [very little] Javascript!
document.querySelector('#toggle-button').addEventListener('click', function() {
document.querySelector('.section.collapsible').classList.toggle('collapsed');
});
This Pen doesn't use any external CSS resources.