https://codepen.io/mo4_9/pen/qzBamX
checkされたinputと隣接するテキストの高さを0にする。JSは不要。
@mixin accordion-menu($toggleClassName: '.content', $arrow-size: 3px, $color: $font-color-base) {
position: relative;
i{
position: absolute;
margin-top: 25px;
right: 20px;
&:before, &:after{
content: '';
position: absolute;
background-color: $color;
width: $arrow-size + 1px;
height: $arrow-size * 4 + 1px;
}
&:before{
transform: translate( -$arrow-size , 0 ) rotate( 45deg );
}
&:after{
transform: translate( $arrow-size + 1px , 0 ) rotate( -45deg );
}
}
input[type='checkbox']{
position: absolute;
cursor: pointer;
width: 100%;
height: 100%;
z-index: 1;
opacity: 0;
&:checked{
&~#{$toggleClassName}{
margin-top: 0;
max-height: 0;
opacity: 0;
transform: translate( 0 , 50% );
}
&~i{
&:before{
transform: translate( $arrow-size , 0 ) rotate( 45deg );
}
&:after{
transform: translate( -$arrow-size - 1px , 0 ) rotate( -45deg );
}
}
}
}
}