header, section, footer, aside, nav, main, article, figure {
    display: block; 
}
body {
    padding: 0;
    margin: 0;
    font-family: "Times New Roman", serif;
    background-color: #cbe2ef;
}
h2, ul {
    margin: 0;
}
a:hover {
    color: #5ba9d5;
}
#main_header {
    color: #fff;
    height: 210px;
    padding: 60px 0 40px 0;
    text-align: center;
    background: url(../images/background-ice.jpg) no-repeat #000;
    border-bottom: 5px solid #5ba9d5;
}
#nameline {
    display: inline-block;
    padding: 20px 5px 20px 5px;
    text-shadow: 0 0 6px #000;
}
#main_nav {
    background-color: rgba(203, 226, 239, 0.6);
    border-style: solid;
    border-color: #5ba9d5;
    border-width: 1px 0px 1px 0px;
    display: flex;
    flex-direction: row;
    justify-content: center;
}
nav ul{
    list-style-type: none;
}
#main_nav ul {
    padding: 0;
}
#main_nav ul li {
    display: inline-block;
}
#main_nav ul li a {
    padding: 0.5em 2em 0.5em 2em;
    display: inline-block;
}
#main_nav a:link, #main_nav a:visited {
    color: #fff;
    text-transform: uppercase;
    font-family: "DejaVu Sans", sans-serif;
    font-weight: bold;
    text-shadow: 0 0 3px #000;
}
#main_nav ul li:hover {
    background-color: #ffbe7e;
}
.undertext {
    font-family: "DejaVu Sans", sans-serif;
}
main {
    background-color: #fff;
    overflow: auto;
    font-size: 1.3em;
    padding: 2em 4em 2em 4em
}
#profile {
    width: 25%;
    min-width: 8em;
    max-width: 600px;
    margin: 0 1em 0 0;
    float: left;
}
#profile section, #profile nav {
    border: 0.1em groove #000;
    margin-bottom: 1em;
    width: 100%;
    min-width: 8em;   
    max-width: 600px;
}
#profile header {
    background-color: #ffbe7e;
    margin-bottom: 0.2em;
    padding: 0.2em;
    border-bottom: 1px solid #000;
}
#prof_img img {
    width: 100%;
    max-width: 600px;
    margin: 0;
    padding: 0;
    display: block;
}
#me_otherwhere {
    padding-bottom: 1em;
}
#me_otherwhere ul li {
    margin-top: 0.2em;
}
#me_otherwhere img {
    width: 16px;
    margin-right: 0.3em;
    vertical-align: bottom;
}
footer {
    padding: 1em 0 0 0;
    margin-top: 0;
    background-color: #cbe2ef;
    width: 100%;
    display: flex;
    justify-content: flex-end;
    flex-grow: 1;
    flex-basis: auto;
    overflow: auto;

}
footer > * {
    margin: 0 1em 0 1em;
}
@media screen and (max-width: 500px) {
    #profile {
        width: 100%;
        float: none;
    }
    #profile section, #profile nav {
        border-width: 0.1em 0 0.1em 0;
    }
    main {
        padding: 0;
    }
    main > section {
        padding: 0.4em;
    }
}