body {
  max-width: 800px;
  margin: auto;
  padding: 1em;
  line-height: 1.5;
  background-color: #121212;
  color: #e0e0e0;
}

/* header and footer areas */
.menu { padding: 0; }
.menu li { display: inline-block; }
.menu a, .article-meta {
  text-decoration: none;
  background: #1e1e1e;
  padding: 5px;
  border-radius: 5px;
  color: #d0a1ff;
}
.menu, .article-meta, footer { text-align: center; }
.title { font-size: 1.1em; }
footer a { text-decoration: none; color: #d0a1ff; }
a, a:visited, a:hover, a:active {
  color: #d0a1ff;
  text-decoration: none;
}
hr {
  border-style: dashed;
  border-color: #333;
}

/* code */
pre {
  border: 1px solid #333;
  box-shadow: 5px 5px 5px #1e1e1e;
  padding: 1em;
  overflow-x: auto;
  background: #1e1e1e;
  color: #e0e0e0;
}
code { background: #2e2e2e; color: #e0e0e0; }
pre code { background: none; }

/* misc elements */
img, iframe, video { max-width: 100%; }
main { hyphens: auto; }
blockquote {
  background: #1e1e1e;
  border-left: 5px solid #555;
  padding: 3px 1em 3px;
  color: #e0e0e0;
}

table {
  margin: auto;
  border-top: 1px solid #444;
  border-bottom: 1px solid #444;
  color: #e0e0e0;
}
table thead th { border-bottom: 1px solid #555; }
th, td { padding: 5px; }
thead, tfoot, tr:nth-child(even) { background: #1e1e1e; }
