@font-face {
  font-family: Liberation;
  font-weight: normal;
  src: url('LiberationSerif-Regular.ttf') format('truetype');
}

@font-face {
  font-family: Liberation;
  font-weight: bold;
  src: url('LiberationSerif-Bold.ttf') format('truetype');
}

html {
  font-family: Liberation, serif;
  font-size: 18px;
  line-height: 1.5;
  background-color: #FEF7F6; /* #F0EEFE */
  color: #090201;
}

body {
  max-width: 39rem;
  margin: auto;
  padding: 1rem;
}
body.wide {
  max-width: 55rem;
}

h1 {
  font-weight: bold;
  font-size: 140%;
  text-align: center;
}

h2 {
  font-weight: bold;
  font-size: 120%;
}

h3 {
  font-weight: bold;
  font-size: 100%;
}

small {
  font-size: 80%;
}

a {
  text-decoration: none;
  color: #150699;
}
a:hover {
  text-decoration: underline;
}

blockquote {
  margin: 1rem;
  padding-left: 1rem;
  border-left: 2px solid;
}

pre {
  font-family: monospace;
  font-size: 14px;
  overflow: auto;
}

hr {
  border: none;
}
hr::after {
  display: block;
  text-align: center;
  content: '***';
}

table {
  table-layout: fixed;
  width: 100%;
}
td[colspan] {
  text-align: center;
}
