body {
 margin: 0;
 padding: 0;
 background: #2a2543;
 line-height: 133%;
 font-size: 0.98em;
 font-family: "Open Sans", "Droid Sans", "Calibri", sans-serif;
 }
 
 
/*Miscellanous custom styling for various elements.*/
h1, h2, h3 {
 font-family: "Calibri";
 }
 
a {
 color: #2F4F4F;
 }

a:hover, a:focus {
 color: #2a2543;
 transition: ease-in 0.1s, ease-out 0.1s;
 }
 
blockquote {
 border-left: #4d4385 3px solid;
 background: #d8d4ec;
 padding: 0.1px 0.75rem;
 margin: 0 1.5rem;
 }

hr {
 width: 75%;
 margin-top: 1.5rem;
 margin-bottom: 1.5rem;
 }
 
/*Sticky navigation links at the top of the page.*/
.quick-nav {
 position:fixed;
 z-index: 999;
 width: 100%;
 background: #0a000a;
 background: rgba(10,0,10,1);
 text-align: right;
 color: #fff; 
 font-size: 0.875em;
 }
 
.navbar {
 padding: 1px 25px;
 }
 
.navbar a {
 display: inline-block;
 text-decoration: none;
 color: #fff;
 padding: 5px 4px;
 margin: 0 2px;
 }
 
.navbar a:hover, .footer a:hover, .navbar a:focus, .footer a:focus {
 color: #edeef3;
 transition: ease-in 0.1s, ease-out 0.1s;
 }
 
 
/*Header image.*/
.header {
 height: 350px;
 background: linear-gradient(rgba(10,0,10,0.5), rgba(10,0,10,0.4)), url(/img/pexels-4254548-crop2.jpg);
 }

/*Title bar with icon and title/tagline.*/
.title {
 background: #52587c;
 min-height: 60px;
 margin-bottom: -25px;
 text-align: right;
 }
 
.title-text, .title-pic {
 padding:0;
 margin: 0;
 display: inline-block;
 vertical-align: top;
 }
 
/*Contains the text tagline.*/
.title-text {
 padding-right: 1em;
 width: calc(85vw - 110px);
 line-height: 167%;
 margin-top: -3px;
 padding-bottom: 15px;
 }
 
.title-text h1 {
 padding:0;
 font-size: 32px;
 }
 
/*Contains the profile pic. This can be left out and should still look okay.*/
.title-pic {
 height: 100px;
 margin-right: 100px;
 margin-top: -25px;
 border: 5px solid #52587c;
 border-radius: 10px;
 }
 
.title-pic img {
 height: 100%;
 overflow: hidden;
 }
 
/*Contains the main content and sidebar.*/
.page-wrapper {
 padding: 0 100px;
 margin: 0 auto;
 background: #ddd;
 background: linear-gradient(rgba(52,37,77,1), rgba(42,30,67,0.25)), url(/img/fancy1.png); /*Gradient makes tiles "fade in".*/
 }

/*Contains the sidebar boxes.*/
.sidebar {
 width: 320px;
 margin: 50px 0;
 position: absolute;
 }
 
.sidebar h1 {
 font-size: 1.2rem;
 background: #696f92;
 color: #fff;
 padding: 12px 10px 10px 10px;
 margin: auto;
 }
 
.sidebar a {
 display: block;
 border-left: 3px solid #52587c;
 background: #bcb9d6;
 padding: 5px;
 margin: 10px 0;
 color: #0e0718;
 text-decoration: none;
 }
 
.sidebar a:hover, .sidebar a:focus {
 background: #99a1c7;
 transition: ease-in 0.1s, ease-out 0.1s;
 }
 
.sidebar, .main {
 display: inline-block;
 }

/*Contains main content boxes.*/
.main {
 margin: 50px 100px 50px 350px;
 width: auto;
 width: calc(100vw - 550px);
 }
 
 
/*Basic container type for subsections of main and sidebar divs*/
.box {
 margin-bottom: 15px;
 }
 
/*Inner content div for boxes. Padding goes here so sidebar headers etc can keep their no-margin look.*/
.inner {
 background: #edeef3;
 padding: 10px 25px;
 }

.inner img {
 max-width: 100%; /*Prevent image overflow.*/
 height: auto;
 border-radius: 5px; /*Give images in content rounded corners.*/
 }
 
.box, .title-pic img {
 border-radius: 5px;
 overflow: hidden; /*Force inner divs to conform to rounded corners.*/
 }
 
 
/*Footer section.*/
.footer {
 background: #050005;
 color: #fff;
 padding: 5px 20px;
 font-size: 0.75em;
 padding-bottom: 10px;
 }
 
.footer a {
 color: #fff;
 }

/*Individual column of the footer. You can have 3 of these at the current given width.*/
.footer-column {
 width: 25%;
 margin: 5px 10px;
 display: inline-block;
 vertical-align: top;
 }


/*Adapt to narrower screens.*/
@media(max-width: 900px) {
 .page-wrapper {
 padding: 0 50px;
 }
 
 .sidebar {
 width: 25vw;
 }
 
 .main {
 margin: 50px 0 50px calc(25vw + 30px);
 width: calc(75vw - 150px);
 }
 
 .title-pic {
 margin-right: 7vw;
 }
 
 .title-text {
 padding-left: 1vw;
 padding-right: 2vw;
 }
 
 }
 
/*Mobile layout.*/
@media(orientation: portrait) { 
 .page-wrapper {
 padding-top: 0.1px;
 padding-bottom: 0.1px;
 }
 
 .sidebar, .main {
 display: block;
 margin: 0 auto;
 position: static;
 width: 100%; 
 }
 
 .sidebar {
 margin-top: 50px;
 }
 
 .main {
 margin-top: 30px;
 margin-bottom: 30px;
 }
 
 
 }
 
/***
For really narrow screens which cause the title text to wrap. 
You may need to adjust the width at which this kicks in to fit 
your own title.
***/
@media(max-width: 500px) {
 .header {
 height: 60vw;
 }
 
 .title {
 padding-right: 0;
 }
 
 .title-text {
 margin-top: -5px;
 }
 
 .title-text h1 {
 font-size: 6vw;
 line-height: 75%;
 }
 
 .title {
 height: calc(auto - 25px);
 }
 
 .page-wrapper {
 padding: 0.1px 7vw;
 }
 
 /*For extra narrow screens where the columns would get too skinny.*/
 .footer-column {
 display: block;
 width: 100%;
 margin: 0 auto;
 }
 }