.wrapper {
  display: flex;  
  flex-flow: row wrap;
  font-weight: bold;
  text-align: center;
  margin: auto;
  max-width: 80%;
}

.wrapper > * {
  flex: 1 100%;
}

.header {
  background: white;
  padding: 5px;
}

.topnav {
  text-align: center;
}

.footer {
  background: rgb(247,247,247);
  padding: 0px 10px 10px 10px;
}

.main {
  text-align: left;
  /*background: rgb(198,34,50);*/
  padding: 10px;
}

.main img{
 width: 100%;
 border: 2px solid red;
}

.aside-1 {
  background: white;
  padding: 10px;
}

h2 { 
 font-family: 'Playfair Display', serif;
 font-size: 18pt;
 text-transform: uppercase;
}

ul {
 padding: 0;
}

.aside-1 ul {
 list-style: none;
 margin: 0;
 }

.aside-1 a{
 text-decoration: none;
 font-family: 'Cormorant Garamond', serif;
 text-align: center;
 color: black;
}

.aside-1 a:hover{
 color: rgb(198, 34, 50);
}

.aside-2 {
  background: white;
  padding: 10px;
}

h3 {
font-family: 'Cormorant Garamond', serif;
 font-size: 15pt;
}

p{
 text-decoration: none;
 color: black;
font-family: 'Cormorant Garamond', serif;
}

@media all and (min-width: 600px) {
  .aside { flex: 1 0 0; }
}

@media all and (min-width: 800px) {
  .main    { flex: 3 0px; }
  .aside-1 { order: 1; } 
  .main    { order: 2; }
  .aside-2 { order: 3; }
  .footer  { order: 4; }
}

body {
  padding: 2em; 
}

/*Nav stuff*/

.navigation {
  list-style: none;
  margin: 0;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-end;
}

.navigation a {
  text-decoration: none;
  font-family: 'Cormorant Garamond', serif;
  text-transform: uppercase;
  display: block;
  padding: 1.5em;
  color: black;
}

.navigation a:hover {
  background: rgba(198, 34, 50, 0.8);
}

.header img {
	width: 250px;
}

@media all and (max-width: 800px) {
  .navigation {
    justify-content: space-around;
  }
}

@media all and (max-width: 600px) {
  .navigation {
    flex-flow: column wrap;
    padding: 0;
  }
  
  .navigation a { 
    text-align: center; 
    padding: 10px;
    border-top: 1px solid rgba(255,255,255,0.3); 
    border-bottom: 1px solid rgba(0,0,0,0.1); 
  }

  
  .navigation li:last-of-type a {
    border-bottom: none;
  }
}

/*Footer stuff*/

.flex-container {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-around;
}

.flex-item {
  /*background: rgb(198,34,50);*/
  padding: 5px;
  width: 200px;
  height: 250px;
  margin-top: 10px;
  
  line-height: 150px;
  color: white;
  font-weight: bold;
  font-size: 3em;
  text-align: center;
}

.flex-item img{
 height: 100%;
 width: 100%;
 border: 2px solid red;
}