/* Self-hosted IBM Plex Mono (latin subset). OFL 1.1.
   Mirrored here so blog pages don't depend on /style.css and Browsers
   cache the font file across the home page and the blog. */
@font-face {
  font-family: "IBM Plex Mono";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/fonts/IBMPlexMono-Regular.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "IBM Plex Mono";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/fonts/IBMPlexMono-Bold.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
body {
  background: #000; color: #c8d3c8;
  font-family: "IBM Plex Mono", "Courier New", Courier, monospace;
  font-size: 16px; line-height: 1.65;
  padding: 2rem 1rem 4rem; min-height: 100vh;
}
main { max-width: 740px; margin: 0 auto; }
header.site {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 3rem; padding-bottom: 1rem;
  border-bottom: 1px solid #1f3a1f;
}
header.site a { color: #00ff00; text-decoration: none; font-weight: 700; }
header.site nav a { color: #7f9f7f; margin-left: 1rem; }
article h1 { color: #00ff00; font-size: 1.6rem; line-height: 1.3; margin: 0 0 0.5rem; }
article h2 { color: #00ff00; font-size: 1.15rem; margin: 2rem 0 0.75rem; }
article h3 { color: #9ec99e; font-size: 1rem; margin: 1.5rem 0 0.5rem; }
article p, article li { margin-bottom: 0.9rem; }
article ul, article ol { padding-left: 1.4rem; }
a { color: #7fb4ca; }
a:hover { color: #a8d4ea; }
code {
  background: #101810; color: #9ec99e;
  padding: 0.1em 0.35em; border-radius: 3px; font-size: 0.92em;
}
pre {
  background: #0a0f0a; border: 1px solid #1f3a1f;
  padding: 1rem; overflow-x: auto; margin: 1rem 0 1.4rem;
  border-radius: 4px; font-size: 0.85rem; line-height: 1.5;
}
pre code { background: transparent; padding: 0; color: #c8d3c8; }
time.posted { color: #7f9f7f; font-size: 0.85rem; display: block; margin-bottom: 2rem; }
footer { margin-top: 3rem; padding-top: 1rem; border-top: 1px solid #1f3a1f; color: #7f9f7f; font-size: 0.85rem; }
