.hamburger-menu
container div
which contains the top, bottom, and middle bars.display: flex
with flex-flow: column wrap
.justify-content: space-between
.transform: rotate()
to rotate the top and bottom bars by 45 degrees and opacity: 0
to fade the middle bar on hover.transform-origin: left
so that the bars rotate around the left point.<div class="hamburger-menu"> <div class="bar top"></div> <div class="bar middle"></div> <div class="bar bottom"></div> </div>
.hamburger-menu {
display: flex;
flex-flow: column wrap;
justify-content: space-between;
height: 2.5rem;
width: 2.5rem;
cursor: pointer;
}
.hamburger-menu .bar {
height: 5px;
background: black;
border-radius: 5px;
margin: 3px 0px;
transform-origin: left;
transition: all 0.5s;
}
.hamburger-menu:hover .top {
transform: rotate(45deg);
}
.hamburger-menu:hover .middle {
opacity: 0;
}
.hamburger-menu:hover .bottom {
transform: rotate(-45deg);
}
Subscribe to get resources directly to your inbox. You won't receive any spam! ✌️