html * { font-size: 16px; }
header { margin: 0 0 10px 0; }
.logo { line-height: 26px; display: inline-block; padding: 0 0 0 30px; font-size: 22px; background-size: contain; background-position: 0; }
nav { background-color: #468; position: fixed; left: 0; width: 100vw; }
nav div { font-size: 20px; text-align: left; line-height: 35px; padding: 0 30px 0 10px; background-size: auto 25px; background-position: top 5px right 10px; }
nav form { display: block; float: right; height: 25px; margin: 5px; padding: 0; }
nav form input[type="image"] { height: 100%; }
nav.guest div { background-image: none; text-align: right; padding: 0 10px; }
nav a { font-size: 20px; line-height: 1.5; }
footer { display: block; text-align: center; }
footer * { font-size: 12px; }
.copyright span { display: block; font-size: 0; }
.footermenu p { padding: 5px 0; }
.mobilebreak { font-size: 0; display: block; }
.desktoponly { display: none!important; }
form.leftalign, form.rightalign { display: block; }
input:not([type="checkbox"], [type="radio"], [type="submit"]), textarea, select { width: 100%; }
.calendar p { font-size: 10px; padding: 5px 0 0 5px; }
.calendar span { font-size: 11px; margin: 2px; text-align: center; }