body {
    background-color:  #faffff;
    font-size: large;
    font-family: arial;
    line-height: 1.5em;
    margin: 15px 0px 0px 0px;
}

div {
    width: 80%;
    height: 100%;
    margin: auto;
    margin-bottom: 15pt;
    padding-left: 20px;
    border-left: 5px solid #bbdddd;
    border-bottom: 5px solid #aacccc;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 15px;
    border-top-left-radius: 5px;

}

a {
    text-decoration: none;
    background-color: #b3ffb3;
    padding: 5pt;
    border-radius: 5pt;
    color: black;
    margin: 2px;
}

a:hover {
    background-color: #20ac58;
}

.list {
    margin: 10px;
}

section a img {
    width: 20px;
    position: relative;
    top: 4px;
    padding-right: 5pt;
}

section a {
    font-size: medium;
}

header {
    flex: 1 100%;
    text-align: left;
    
    padding-top: 10px;
}

h1 {
    flex:1 100%;
    background-color: #bbdddd;
    width: 420px;
    padding: 45px;
    margin: 0pt;
    margin-left: -18pt;
    margin-top: -8pt;
    border-bottom-right-radius: 10pt;
    border-top-right-radius: 10pt;
    border-top-left-radius: 5px;
    color: #006600;
}

aside {
}

.right {
    flex: 1 0px;
    margin-top: 55px;
    padding-left: 5pt;
    background: linear-gradient(#d3ffd3,#faffff);
    border-radius: 5px;
    margin-left: 5pt;
    min-width: 140px;
    max-width: 150px;
}

aside h2 {
    font-size: medium;
}

aside h3 {
    font-size: medium;
}

aside p {
    font-size: medium;
}

nav {
    flex: 2;
    height: 100%;
    position: relative;
    left: -40px;
    font-weight: bold;
    min-width: 280px;
    max-width: 300px;
}

section
{
    flex:5 0px;
    padding-top: 45px;
    height: 100%;
    padding-right: 10pt;
    /*margin: auto;*/
}

footer {
    flex: 1 100%;
    text-align: center;
    font-size: small;
    color: #006600;
}


nav a {
    display: list-item;
    list-style: none;
    text-decoration: none;
    position: relative;
    top: 50px;   
    margin: 10px 10px 10px 10px;
    padding: 20px 15px 20px 15px;
    text-align: center;
}

.menu {
    background-color: #20ac58 /*#b3ffb3*/;
    color: white/*#006600*/;
    border-radius: 5px;
    opacity: 0.9;
    transition: margin 0.5s;
}

.menu:hover {
    background-color:  #20ac58;
    margin-left: -5px;
}

#active {
    margin-left: -5px;
}

#active:hover{
    
}

.flex-container {
    display: -webkit-flex;
    display: flex;  
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
}


h2 {
    color: #006600;
}

@media screen and (max-width: 300px)
{
    body
    {
        font-size: 1em;
    }
    
    .flex-container > *
    {
        flex: 1 100%;
    }
    
    nav {
        flex: 2;
        height: 100%;
        position: relative;
        left: 0px;
        font-weight: bold;
    } 
    
}
