@font-face {
  font-family: 'Bodoni';
  src: url("/assets/bodoni.ttf") format("truetype"); }
@font-face {
  font-family: 'Baskerville Bold';
  src: url("/assets/baskerville-bold.ttf") format("truetype"); }
@font-face {
  font-family: 'Baskerville Italic';
  src: url("/assets/baskerville-italic.ttf") format("truetype"); }
@font-face {
  font-family: 'Lato';
  src: url("/assets/lato.ttf") format("truetype"); }
.non-scrollable {
  position: fixed; }

body {
  box-sizing: border-box;
  padding: 48px 15% 36px 15%;
  width: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

@media screen and (max-width: 995px) {
  body {
    padding: 48px 5% 48px 5%; } }
@media screen and (max-width: 690px) {
  body {
    padding: 28px 5% 28px 5%; } }
.navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: row;
  text-align: center;
  width: 100%; }

.title {
  font-family: "Bodoni", "Times Header", serif;
  font-size: 36px;
  line-height: 33px;
  padding: 0 24px;
  font-weight: bold;
  margin: 0;
  opacity: 0.94; }

.title-link {
  color: #000;
  text-decoration: none; }

.subtitle {
  display: block;
  font-family: "Baskerville Italic", "Times New Roman", serif;
  font-size: 13px;
  font-weight: normal;
  font-style: italic;
  margin-top: 4px;
  line-height: 12px;
  opacity: 0.7; }

.header-center {
  flex: 2; }

.header-right, .header-left {
  flex: 1;
  display: flex;
  justify-content: space-around; }

.navItem {
  font-family: "Baskerville Bold", serif;
  font-size: 10px;
  line-height: 12px;
  font-weight: bold;
  text-transform: uppercase;
  opacity: 0.8;
  color: #000;
  text-decoration: none; }

.menu-toggle {
  display: none; }

.menu-drawer {
  position: fixed;
  padding: 28px 5% 28px 5%;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #E4DDDE;
  z-index: 1;
  box-sizing: border-box;
  overflow: hidden;
  transition: transform .7s; }

.menu-drawer-hidden {
  transform: translateX(-100%); }

.drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between; }

.drawer-menu-items {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  margin-top: 72px;
  align-items: center; }

.drawer-item {
  text-decoration: none;
  color: #000;
  opacity: 0.8;
  font-size: 36px;
  font-family: "Baskerville Bold", serif;
  font-style: italic;
  margin-bottom: 36px;
  line-height: 41px;
  padding: 0 8px; }

.menu-close-button {
  margin-right: 12px; }

.footer {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  width: 100%; }

.copyleft {
  font-family: "Baskerville Italic", "Times New Roman", sans-serif;
  font-size: 14px;
  line-height: 16px;
  opacity: 0.6;
  font-style: italic; }

@media screen and (max-width: 995px) {
  .navbar {
    justify-content: space-between; }

  .menu-toggle {
    display: inline-block;
    font-size: 20px;
    padding: 0 12px; }

  .header-center {
    flex: none;
    justify-content: left; }

  .title {
    padding: 0; }

  .header-right, .header-left {
    display: none; }

  .drawer-menu-items {
    margin-top: 128px; }

  .drawer-item {
    font-size: 44px;
    line-height: 64px;
    margin-bottom: 48px; } }
@media screen and (max-width: 690px) {
  .navbar {
    justify-content: space-between; }

  .menu-toggle {
    display: inline-block;
    padding: 0 12px; }

  .title {
    font-size: 28px; }

  .subtitle {
    font-size: 10px;
    margin-top: 0px; }

  .header-center {
    flex: none;
    justify-content: left; }

  .title {
    padding: 0; }

  .header-right, .header-left {
    display: none; }

  .copyleft > * {
    display: block;
    text-align: center; } }
@media screen and (max-width: 690px) {
  .menu-toggle {
    font-size: 14px; }

  .drawer-menu-items {
    margin-top: 40px; }

  .drawer-item {
    font-size: 24px;
    line-height: 32px;
    margin-bottom: 24px; } }
.page-lead {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 20px 0 20px;
  padding: 32px 32px;
  border-top: 1px solid #E4DDDE;
  border-bottom: 1px solid #E4DDDE;
  font-family: "Lato", "Helvetica", sans-serif; }
  .page-lead a {
    color: #000;
    text-decoration: none;
    border-bottom: 2px solid #E4DDDE; }
    .page-lead a:hover {
      color: #888;
      border-bottom: 2px solid #EEE7E8; }
  .page-lead p {
    font-style: italic;
    opacity: 0.8;
    margin: 0; }

@media screen and (max-width: 690px) {
  .page-lead {
    padding: 16px 8px; } }
.blog {
  margin-top: 88px; }

.reveries {
  margin-top: 60px; }

.post-list {
  padding: 0; }
  .post-list li {
    list-style-type: none; }
  .post-list .post-item {
    margin-bottom: 48px; }
  .post-list .post-date {
    font-family: "Lato", "Helvetica", sans-serif;
    font-size: 12px;
    opacity: 0.8;
    line-height: 14px;
    margin: 0; }
  .post-list .post-title {
    margin: 0;
    opacity: 0.9;
    line-height: 41px;
    font-family: "Baskerville Bold", serif;
    font-size: 24px;
    font-width: bold; }
  .post-list .post-title:hover {
    opacity: 0.5; }
  .post-list .post-link {
    margin: 0;
    color: #000;
    text-decoration: none; }
  .post-list .post-author {
    font-family: "Lato", "Helvetica", sans-serif;
    font-size: 12px;
    line-height: 14px;
    font-style: italic;
    opacity: 0.5;
    border-bottom: 4px solid #E4DDDE; }
  .post-list .post-flag {
    margin: 0 4px;
    opacity: 1;
    vertical-align: middle; }
  @media screen and (max-width: 995px) {
    .post-list .post-list {
      padding: 0; } }
  @media screen and (max-width: 690px) {
    .post-list .blog {
      margin-top: 72px; }
    .post-list .post-title {
      margin: 6px 0;
      font-size: 24px;
      line-height: 27px; } }
  @media screen and (max-width: 320px) {
    .post-list .post-author, .post-list .post-flag {
      font-size: 11px; } }

.post {
  padding: 132px 0 72px 0;
  width: 50em;
  margin: 0 auto; }
  .post .post-headline {
    display: flex;
    align-items: baseline;
    justify-content: space-between; }
  .post .post-title {
    margin: 6px 0;
    opacity: 0.9;
    line-height: 41px;
    font-family: "Baskerville Bold", serif;
    font-size: 36px;
    font-style: italic;
    font-width: bold; }
  .post .post-meta {
    margin-top: 16px; }
  .post .post-flag {
    border-bottom: 0px;
    margin: 0 4px;
    opacity: 1;
    vertical-align: middle; }
  .post .post-date,
  .post .post-separator,
  .post .post-author {
    font-family: "Lato", "Helvetica", sans-serif;
    font-size: 12px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.6);
    font-style: italic;
    line-height: 14px;
    opacity: 0.6; }
  .post .post-separator {
    padding: 0 4px; }
  .post .post-content {
    overflow-wrap: break-word;
    word-wrap: break-word;
    margin: 72px auto 0 auto; }
  .post .share-buttons {
    display: flex;
    font-size: 8px;
    align-items: center;
    justify-content: flex-end; }
    .post .share-buttons a {
      display: flex;
      align-items: center;
      justify-content: center;
      text-decoration: none;
      color: #E4DDDE;
      margin: 0 0 0 8px;
      height: 24px;
      width: 24px;
      border: 2px solid #E4DDDE;
      border-radius: 2px; }
      .post .share-buttons a:hover {
        color: #EEE7E8;
        border-color: #EEE7E8; }
  .post .post-content {
    font-family: "Lato", "Helvetica", sans-serif;
    font-size: 16px;
    line-height: 29px;
    color: rgba(0, 0, 0, 0.8); }
    .post .post-content a:not(.image-link) {
      color: #000;
      text-decoration: none;
      border-bottom: 4px solid #E4DDDE; }
      .post .post-content a:not(.image-link):hover {
        color: #888;
        border-bottom: 4px solid #EEE7E8; }
    .post .post-content p > code {
      background-color: rgba(218, 218, 218, 0.3);
      padding: 2px 4px;
      border-radius: 3px; }
  .post img {
    max-width: 100%;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    margin: 32px 0; }
  .post div.highlight {
    background-color: rgba(218, 218, 218, 0.3);
    padding: 12px 24px;
    overflow-x: scroll; }
  .post .video {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden; }
  .post .video-post {
    margin: 36px 0; }
  .post .video iframe,
  .post .video object,
  .post .video embed {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0; }
  .post blockquote {
    margin: 0.2em auto;
    padding: 0.2em 1em;
    border-left: 5px solid #999;
    font-style: italic; }
    .post blockquote:before {
      display: none; }
    .post blockquote:not(:first-of-type) {
      margin-top: .5em; }
    .post blockquote p:first-of-type {
      color: #555;
      font-size: 12pt;
      line-height: 1.4;
      margin: 0; }
  .post table {
    margin: 1em auto;
    display: block;
    overflow: scroll;
    display: table; }
  .post td,
  .post th {
    padding: 1em 2em; }
  .post td {
    text-align: center; }
  @media screen and (max-width: 690px) {
    .post .post-content {
      margin-top: 36px; }
    .post .post-text {
      font-size: 32px;
      margin: 36px 0 0 0; }
    .post .post-separator {
      display: table-column; }
    .post .post-date,
    .post .post-author {
      margin-top: 8px;
      display: inline-table; }
    .post .post-headline {
      flex-direction: column; }
      .post .post-headline .share-buttons {
        width: 100%;
        margin-top: 32px;
        justify-content: center; }
    .post div.highlight {
      font-size: 14px; } }
  .post .post-callout {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin: 20px 0 20px;
    padding: 24px 24px;
    border: 1px solid #E4DDDE;
    font-family: "Lato", "Helvetica", sans-serif;
    background-color: rgba(228, 221, 222, 0.29); }
    .post .post-callout a {
      color: #000;
      text-decoration: none;
      border-bottom: 2px solid #E4DDDE; }
      .post .post-callout a:hover {
        color: #888;
        border-bottom: 2px solid #EEE7E8; }
    .post .post-callout p {
      font-style: italic;
      opacity: 0.8;
      margin: 0; }
    .post .post-callout p:not(:first-child) {
      margin-top: 1em; }

@media screen and (max-width: 690px) {
  .post {
    padding: 64px 0 72px 0;
    width: auto; } }
.about .profile-picture {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  margin: 92px auto auto 0;
  height: 256px;
  width: 256px;
  border-radius: 50%; }
.about .greeting-text {
  text-align: center;
  margin: 48px 0 0 0;
  font-size: 36px;
  font-family: "Baskerville Bold", serif;
  font-style: italic; }
.about .greeting-text > span {
  font-style: normal; }
.about .call-to-action {
  text-align: center;
  display: block;
  font-family: "Baskerville Italic", "Times New Roman", serif;
  font-size: 12px;
  font-weight: normal;
  font-style: italic;
  margin-top: 12px;
  line-height: 12px;
  opacity: 0.7; }
  .about .call-to-action a {
    color: #000;
    text-decoration: none;
    border-bottom: 4px solid #E4DDDE; }
    .about .call-to-action a:hover {
      color: #888;
      border-bottom: 4px solid #EEE7E8; }
.about .profile-content {
  max-width: 50em;
  margin: 0 auto;
  padding: 48px 10% 72px 10%;
  text-align: justify;
  font-family: "Lato", "Helvetica", sans-serif;
  font-size: 16px;
  line-height: 29px;
  opacity: 0.8; }
  .about .profile-content a {
    color: #000;
    text-decoration: none;
    border-bottom: 4px solid #E4DDDE; }
    .about .profile-content a:hover {
      color: #888;
      border-bottom: 4px solid #EEE7E8; }
@media screen and (max-width: 690px) {
  .about .profile-picture {
    margin: 64px auto auto 0; }
  .about .profile-content {
    padding: 24px 0 48px 0; }
  .about .greeting-text {
    font-size: 32px; } }
@media screen and (max-width: 320px) {
  .about .greeting-text {
    font-size: 24px;
    margin: 24px 0 0 0; } }

.disclaimer {
  text-align: center;
  margin: 48px 0 0 0;
  font-style: bold; }
  .disclaimer h1, .disclaimer h2 {
    font-family: "Baskerville Bold", serif; }
  .disclaimer .disclaimer-callout {
    margin: 20px 0 20px;
    padding: 24px 24px;
    border: 1px solid #E4DDDE;
    font-size: 16px;
    font-family: "Lato", "Helvetica", sans-serif;
    background-color: rgba(228, 221, 222, 0.29);
    text-align: left; }
    .disclaimer .disclaimer-callout a {
      color: #000;
      text-decoration: none;
      border-bottom: 2px solid #E4DDDE; }
      .disclaimer .disclaimer-callout a:hover {
        color: #888;
        border-bottom: 2px solid #EEE7E8; }
    .disclaimer .disclaimer-callout p {
      font-style: italic;
      opacity: 0.8;
      margin: 0; }
    .disclaimer .disclaimer-callout p:not(:first-child) {
      margin-top: 1em; }
