
html {
    background: #222;
}

body {
    display: flex;
    flex-direction: column;
    font-family: Helvetica, Arial, sans-serif; font-size: 16px; font-weight: 400;
    line-height: 1.45em;
    background: #222;
    color: #ddd;
    margin: 0;
    padding: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block; margin: 0;
}

h1 { font-size: 2.2em; margin: 10px 0px; line-height: 1.2em; font-weight: 400; }
h2 { font-size: 1.3em; margin: 40px 0 10px 0; line-height: 1.1em; font-weight: 700; }
h3 { font-size: 1.1em; margin: 30px 0 10px 0; line-height: 1.1em; font-weight: 700; }
a { color: #1099f0; text-decoration: none; }
a:hover { color: #1099f0; text-decoration: underline; }
a img { border: none; }
p { margin: 10px 0px 5px 0px; }
hr { background: url("hr-soft.png") no-repeat center center; height: 20px; border: 0 none;
    -webkit-background-size: 100% 1px; -moz-background-size: 100% 1px;
    -o-background-size: 100% 1px; -ms-background-size: 100% 1px; background-size: 100% 1px;
}
ul { padding-left: 1.8em; }
ul.no-bullets {
    margin: 0; padding: 0;
}
ul.no-bullets li {
    display: block; margin: 0; padding: 0; list-style: none;
}
textarea { font-size: 1.0em; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; }
sup { vertical-align: top; position: relative; top: -0.5em; }

.silver { color: #a0a0a0; }
.center { text-align: center; }
.right { text-align: right; }
.nowrap { white-space: nowrap; }

main {
    margin: 0 auto;
    width: 100%;
    max-width: 1000px;
    min-height: calc(100vh - 120px);
}
main .padding {
    padding: 20px;
}

header {
    display: flex; flex-direction: column;
    background: #333;
    margin: 0; padding: 0;
}
.nav-menu { display: block; width: 100%; max-width: 1000px; margin: 0 auto; padding: 10px 0 5px 0; white-space: nowrap; text-align: center; font-size: 0.8em; }
.nav-menu > li { display: inline-block; width: 70px; margin: 0; padding: 0; list-style: none; }
.nav-menu > li > a { color: #aaa; display: inline-block; padding-top: 5px; min-width: 70px; height: 32px; }
.nav-menu > li > a:hover { color: #ccc; }
/*.nav-menu > .home { background: url("../images/logo-32.png") no-repeat 50% 0%; }
.nav-menu > .home > a { opacity: 0; }*/

footer {
    margin: 0; padding: 0;
    background: #333;
    font-size: 0.8em; text-align: center;
    height: 68px;
    display: flex;
    align-items: center;
}
footer .row {
    margin: 0 auto; padding: 0 20px;
    max-width: 1000px;
}
footer h4 { font-size: 1em; margin: 10px 5px 2px 5px; line-height: 1em; font-weight: bold; }
footer.copyright p { color: #aaa;}
footer.copyright p a { color: #aaa; margin-left: 20px; }
footer.copyright p a:hover { color: #ccc; }

