div.menu {
    max-width: 100%;
    display: flex;
    flex-flow: row wrap;
}

div.menu > div.sub-menu {
    flex: 1;
    margin-top: 1.0em;
}

div.menu > div.sub-menu > h3 {
    margin-top: 0;
}

div.menu > div.sub-menu > ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

div.menu > div.sub-menu > ul > li {
    border: 2px solid #c3c3c3;
    background-color: #e5e5e5;
    display: block;
    margin: 0.4em;
}

div.menu > div.sub-menu > ul > li > a {
    width: 100%;
    color: #000;
    display: inline-block;
    padding: 0.4em;
}

div.menu > div.sub-menu > ul > li > a:link,
div.menu > div.sub-menu > ul > li > a:visited {
    text-decoration: none;
}

div.menu > div.sub-menu > ul > li > a:hover,
div.menu > div.sub-menu > ul > li > a:active {
    text-decoration: underline;
}

@media screen and (max-width: 768px) {
    div.menu > div.sub-menu {
        flex: 0 0 184px;
    }
}

@media screen and (max-width: 414px) {
    div.menu > div.sub-menu {
        flex: 0 0 140px;
    }
}
