.navicon-button {
    display: inline-block;
    position: relative;
    padding: 33px 24px;
    transition: 0.25s;
    cursor: pointer;
    user-select: none;
    opacity: .8;
}

.navicon-button .navicon:before,
.navicon-button .navicon:after {
    transition: 0.25s;
}

.navicon-button:hover {
    transition: 0.5s;
    opacity: 1;
}

.navicon-button:hover .navicon:before,
.navicon-button:hover .navicon:after {
    transition: 0.25s;
}

.navicon-button:hover .navicon:before {
    top: 13px;
}

.navicon-button:hover .navicon:after {
    top: -13px;
}

.navicon-button .navicon {
    position: relative;
    width: 40px;
    height: 5px;
    background: #fff;
    transition: 0.5s;
    border-radius: 40px;
}

.navicon:before, .navicon:after {
    display: block;
    content: "";
    height: 5px;
    width: 40px;
    background: #fff;
    position: absolute;
    z-index: -1;
    transition: 0.5s 0.25s;
    border-radius: 40px;
}

.navicon:before {
    top: 10px;
}

.navicon:after {
    top: -10px;
}

.navicon-button.open:not(.steps) .navicon:before,
.navicon-button.open:not(.steps) .navicon:after {
    top: 0 !important;
}

.navicon-button.open .navicon:before,
.navicon-button.open .navicon:after {
    transition: 0.5s;
    background: #000;
}

/* Minus */
.navicon .open {
    transform: scale(0.75);
}

/* Arrows */
.navicon-button.open.larr .navicon:before,
.navicon-button.open.larr .navicon:after,
.navicon-button.open.rarr .navicon:before,
.navicon-button.open.rarr .navicon:after,
.navicon-button.open.uarr .navicon:before,
.navicon-button.open.uarr .navicon:after {
    width: 23px;
}

.navicon-button.open.larr .navicon:before,
.navicon-button.open.rarr .navicon:before,
.navicon-button.open.uarr .navicon:before {
    transform: rotate(35deg);
    transform-origin: left top;
}

.navicon-button.open.larr .navicon:after,
.navicon-button.open.rarr .navicon:after,
.navicon-button.open.uarr .navicon:after {
    transform: rotate(-35deg);
    transform-origin: left bottom;
}

.navicon-button.open.uarr {
    transform: scale(0.75) rotate(90deg);
}

/* Arrows */
.navicon-button.open.rarr .navicon:before {
    transform: translate3d(1em, 0, 0) rotate(-35deg);
    transform-origin: right top;
}

.navicon-button.open.rarr .navicon:after {
    transform: translate3d(1em, 0, 0) rotate(35deg);
    transform-origin: right bottom;
}

/* × and + */
.navicon-button.open.plus .navicon,
.navicon-button.open.x .navicon {
    background: transparent;
}

.navicon-button.open.plus .navicon:before,
.navicon-button.open.x .navicon:before {
    transform: rotate(-45deg);
}

.navicon-button.open.plus .navicon:after,
.navicon-button.open.x .navicon:after {
    transform: rotate(45deg);
}

.navicon-button.open.plus {
    transform: scale(0.75) rotate(45deg);
}