@font-face {
  font-family: 'Linux Libertine';
  /* normal */
  src: url("/fonts/LinLibertine_R.woff") format("woff");
  font-weight: normal;
  font-style: normal; }
@font-face {
  font-family: 'Linux Libertine';
  /* italic */
  src: url("/fonts/LinLibertine_RI.woff") format("woff");
  font-weight: normal;
  font-style: italic; }
@font-face {
  font-family: 'Linux Libertine';
  /* bold */
  src: url("/fonts/LinLibertine_RB.woff") format("woff");
  font-weight: bold;
  font-style: normal; }
@font-face {
  font-family: 'Linux Libertine';
  /* bold */
  src: url("/fonts/LinLibertine_RBI.woff") format("woff");
  font-weight: bold;
  font-style: italic; }
*,
*::before,
*::after {
  box-sizing: border-box; }

html {
  background-color: #fbfbfb;
  color: #303030;
  font-family: "Linux Libertine", serif;
  font-size: 1rem; }
  @media screen and (min-width: 800px) {
    html {
      font-size: 1.125rem; } }

body {
  line-height: 1.6; }

html,
body {
  margin: 0; }

h1,
p,
figure,
pre,
blockquote {
  margin: 0 0 1rem; }

hr {
  display: block;
  width: 100%;
  height: 0;
  margin: 2rem 0;
  border: 0;
  border-top: 1px solid #686868; }

figure .representation {
  display: block;
  margin: 0 0 .5rem; }

figcaption {
  padding: 0 .5rem .5rem;
  font-size: .8125rem;
  text-align: right; }
  figcaption .original::before {
    content: ' ';
    display: block; }
  figcaption h4 {
    font-weight: normal;
    font-size: .9rem;
    font-style: italic; }

img {
  max-width: 100%; }

blockquote {
  padding: 1rem;
  border-left: 5px solid #e5e5e5;
  color: #686868;
  font-style: italic; }
  blockquote p {
    margin: 0; }
  blockquote cite {
    display: block;
    margin: 1rem 0 0;
    font-size: .875rem;
    text-align: right; }

a {
  border-bottom: 1px solid currentColor;
  color: currentColor;
  text-decoration: none; }
  a:hover {
    border-bottom-color: currentColor;
    color: #686868; }

ol,
ul {
  margin: 0 0 1rem 1.25rem;
  padding: 0;
  list-style-position: outside; }
  ol ol,
  ol ul,
  ul ol,
  ul ul {
    margin-bottom: 0; }

li {
  margin: 0; }
  li:not(last-of-type) {
    margin-bottom: .4rem; }

abbr {
  border-bottom: 1px dashed currentColor;
  text-decoration: none;
  cursor: help; }

kbd,
code,
pre {
  font-family: '"Source Code Pro"', monospace; }

pre {
  max-width: 100%; }

kbd,
code {
  margin: 0;
  padding: .125rem .25rem 0;
  background-color: #e5e5e5; }

article,
section {
  display: block;
  margin-bottom: 1rem; }

h1 {
  font-size: 1.875rem; }

h2,
h3,
h4,
h5,
h6 {
  margin: 0 0 .5rem; }

h2 {
  font-size: 2rem; }

h3 {
  font-size: 1.75rem; }

h4 {
  font-size: 1.5rem; }

h5 {
  font-size: 1.25rem; }

h6 {
  font-size: 1rem; }

.container {
  width: 100%;
  max-width: 38rem;
  margin: 0 auto;
  padding: .5rem; }
  @media screen and (min-width: 800px) {
    .container {
      padding: 1rem 0; } }

.site-header,
.site-nav {
  margin-bottom: 2rem; }
  .site-header h1,
  .site-nav h1 {
    margin-bottom: .5rem; }

.site-nav a::before {
  content: '\2190';
  margin-right: .25rem; }

.site-footer,
.tags {
  margin: 3rem 0 0;
  font-size: .8125rem; }
  .site-footer [itemprop="sameAs"] + [itemprop="sameAs"],
  .tags [itemprop="sameAs"] + [itemprop="sameAs"] {
    margin-left: .4rem; }
  @media screen and (min-width: 800px) {
    .site-footer,
    .tags {
      margin-bottom: .5rem; } }

.post-title {
  margin-bottom: 0; }

.posts ol {
  margin-left: 0;
  list-style: none; }
.posts li {
  margin-bottom: .5rem; }
  @media screen and (min-width: 800px) {
    .posts li {
      display: flex;
      flex-direction: row; } }
.posts time {
  display: block; }
  @media screen and (min-width: 800px) {
    .posts time {
      flex: 0 0 5rem; } }
  .posts time + a {
    margin-left: 1rem; }
    @media screen and (min-width: 800px) {
      .posts time + a {
        margin-left: 2rem; } }

.post .post-header {
  margin-bottom: 3rem; }
.post .post-date {
  display: block;
  margin: 0 0 1rem;
  text-align: right; }

.hljs {
  font-size: .875rem; }

table, th, td {
  border: 1px solid #686868;
  border-collapse: collapse;
  padding: 8px;
  margin-bottom: 2em; }
  table code, th code, td code {
    background: none; }

th {
  background-color: #eee; }
