@font-face {
  font-family: 'Triplicate';
  font-style: normal;
  font-weight: 300;
  src: local('Triplicate T3p'), url('font/triplicate_t3_poly_regular.woff');
}
@font-face {
  font-family: 'Triplicate';
  font-style: italic;
  font-weight: 300;
  font-
  src: local('Triplicate T3p'), url('font/triplicate_t3_poly_italic.woff');
}
@font-face {
  font-family: 'Triplicate';
  font-style: normal;
  font-weight: 900;
  src: local('Triplicate T3p'), url('font/triplicate_t3_poly_bold.woff');
}
@font-face {
  font-family: 'Triplicate';
  font-style: italic;
  font-weight: 900;
  src: local('Triplicate T3p'), url('font/triplicate_t3_poly_bold_italic.woff');
}

@font-face {
    font-family: 'Sansita';
    src: url('font/sansita-extrabold-webfont.woff2') format('woff2'),
         url('font/sansita-extrabold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

/* TODO: dark/light mode styles */
body {
  font-family: 'Triplicate', 'American Typewriter', 'Courier New', monospace;
  background: #4b4f3f;
  color: #cace9c;
  max-width: 44em;
  margin: 0 auto;
}

a {
  color: #cace9c;
}

a[href^="https://docs.factorcode.org"] {
  font-family: sans-serif;
}

header, footer {
  margin-left: 0em;
}

header {
  display: flex;
  flex-direction: row;
  border-bottom: 4px double #cace9c;
}

header a:first-child {
  flex-grow: 2;
  border-left: none;
}

header a {
/*  border-left: 1px solid #cace9c;*/
  padding: 0px 8px;
  margin: 0 3rem;
}

footer {
  margin-top: 4rem;
}


article {
  margin: 0 2rem;
}

article img {
  max-width: 100%;
}

hr {
 border: 0;
 border-top: 1px solid #cace9c;
}

article {
  min-height: 640px;
}

footer {
  flex-grow: 1;
}

article p {
  font-size: calc(16px + 0.25vw);
  line-height: 1.6;
}

article > p:first-child:first-letter {
  font-size: calc(60px + 0.75vw);
  line-height: 40px;
  color: indianred;
  float: left;
  padding-top: 10px;
  padding-right: 10px;
  padding-left: 5px;
  font-family: 'Sansita';
}

h1,h2,h3 {
  font-family: 'Sansita';
  color: indianred;
  margin: 0;
  font-size: 1.81rem;
}
h2,h3 {
  font-size: 1.6rem;
}

ol li + li {
  margin-top: 2em;
}

/* a little breathing room at the end of a section */
p + h2 {
  margin-top: 2em;
}

@media(max-width: 640px) {
  article {
    margin: 0 0.5em;
  }
  footer {
    text-align: center;
  }
  blockquote {
    margin: 0em;
    border-left: 3px solid orangered;
    padding: 0.5em
  }
}

[data-type="ftime"] {
  font-style: monospace;
  text-decoration: underline;
  font-size: 1.1em;
}

.highlight, .code-sample {
  background-color: #333;
  padding: 1em;
  font-size: calc(16px + 0.25vw);
  line-height: 1.6em;
}

code {
  white-space: pre;
}

.article-page article {
  display: grid;
  grid-template-columns: 90% 10%;
}
