body {
  background-color: #FDFDFD;
  padding:50px;
  font: 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  color:#312855;
  font-weight:400;
}

.fa {
  color:#B9AA81;
  font-size: 20px;
}

.highlight-block {
  border-top: medium solid #A53E41;
  border-right: medium solid #A53E41;
  border-bottom: medium solid #A53E41;
}

h1, h2, h3, h4, h5, h6 {
  /*color:#6A4028;*/
  margin:0 0 20px;
}



p, ul, ol, table, pre, dl {
  margin:0 0 20px;
}

h1, h2, h3 {
  line-height:1.1;
}

h1 {
  font-size:28px;
  font-weight: 500;
}

h2 {
  /*color:#393939;*/
  font-weight: 500;
}

h3, h4, h5, h6 {
  color:#494949;
  font-weight: 500;
}

a {
  color:#781A3C;
  /*color: #B9AA81;*/
  text-decoration:none;
}

a:hover {
  color:#A53E41;
}

a small {
  font-size:11px;
  color:#777;
  margin-top:-0.3em;
  display:block;
}

a:hover small {
  color:#777;
}

.wrapper {
  /* width:860px; */
  margin:0 auto;
}

blockquote {
  border-left:1px solid #e5e5e5;
  margin:0;
  padding:0 0 0 20px;
  font-style:italic;
}

code, pre {
  font-family:Monaco, Bitstream Vera Sans Mono, Lucida Console, Terminal, Consolas, Liberation Mono, DejaVu Sans Mono, Courier New, monospace;
  color:#333;
}

pre {
  padding:8px 15px;
  background: #f8f8f8;
  border-radius:5px;
  border:1px solid #e5e5e5;
  overflow-x: auto;
}

table {
  width:100%;
  border-collapse:collapse;
}

th, td {
  text-align:left;
  padding:5px 10px;
  border-bottom:1px solid #e5e5e5;
}

dt {
  color:#444;
  font-weight:500;
}

th {
  color:#444;
}

img {
  max-width: 100%;
}
img.teaser-figure {
  max-width:300px;
  display: inline-block;
}

header {
  /* width:300px; */
  width: 25vw;
  float:right;
  /* position:fixed; */
  -webkit-font-smoothing:subpixel-antialiased;
  font-family: 'Optima', sans-serif;
}

header ul {
  list-style:none;
  height:40px;
  padding:0;
  background: #f4f4f4;
  border-radius:5px;
  border:1px solid #e0e0e0;
  width:270px;
}

header li {
  width:89px;
  float:left;
  border-right:1px solid #e0e0e0;
  height:40px;
}

header li:first-child a {
  border-radius:5px 0 0 5px;
}

header li:last-child a {
  border-radius:0 5px 5px 0;
}

header ul a {
  line-height:1;
  font-size:11px;
  color:#999;
  display:block;
  text-align:center;
  padding-top:6px;
  height:34px;
}

header ul a:hover {
  color:#999;
}

header ul a:active {
  background-color:#f0f0f0;
}

strong {
  color:#222;
  font-weight:600;
}

header ul li + li + li {
  border-right:none;
  width:89px;
}

header ul a strong {
  font-size:14px;
  display:block;
  color:#222;
}

#bio button{
  color: white!important;
  font-family: 'Optima', sans-serif;
  font-size: 14px;
}

section {
  /* width:500px; */
  width:65vw;
  /* float:right; */
  float:top;
  padding-bottom:50px;
  font-family: 'Optima', sans-serif;
}

section.fill {
  width: auto;
}

small {
  font-size:11px;
}

hr {
  border:0;
  background:#e5e5e5;
  height:1px;
  margin:0 0 20px;
}

footer {
  width:270px;
  float:left;
  position:fixed;
  bottom:50px;
  -webkit-font-smoothing:subpixel-antialiased;
}

.container {
  display: grid ;
  grid-template-columns: repeat(8, 1fr);
}
.paper-img {
  /* grid: 1/3; */
  grid-column-start: 1;
  grid-column-end: 3;
  padding: 5px 10px;
}
.paper-text {
  grid-column-start: 3;
  grid-column-end: 9;
}
.paper-text .title {
  font-size: 18px;
}
.paper-text .author::before {
  content: ", ";
}
.paper-text .author.no-before::before {
  content: "";
}
.paper-text .award {
  display: inline-block;
  padding: 5px 10px;
  margin: 0px 10px;
  background-color: #F9BF45;
  color: #FDFDFD;
  font-weight: bold;
  text-transform: uppercase;
  border-radius: 5px;
  font-size: 14px;
}
.paper-text .fa span {
  font-size: 16px;
}
.paper-text .link {
  padding: 5px 5px;
}

@media print, screen and (max-width: 960px) {

  div.wrapper {
    width:auto;
    margin:0;
  }

  header, section, footer {
    float:none;
    position:static;
    width:auto;
  }

  header {
    padding-right:320px;
  }

  section {
    border:1px solid #e5e5e5;
    border-width:1px 0;
    padding:20px 0;
    margin:0 0 20px;
  }

  header a small {
    display:inline;
  }

  header ul {
    position:absolute;
    right:50px;
    top:52px;
  }
}

@media print, screen and (max-width: 720px) {
  body {
    word-wrap:break-word;
  }

  header {
    padding:0;
  }

  header ul, header p.view {
    position:static;
  }

  pre, code {
    word-wrap:normal;
  }
}

@media print, screen and (max-width: 480px) {
  body {
    padding:15px;
  }

  header ul {
    width:99%;
  }

  header li, header ul li + li + li {
    width:33%;
  }
}

@media print {
  body {
    padding:0.4in;
    font-size:12pt;
    color:#444;
  }
}
