body {
  margin: 0;
  overflow-wrap: break-word;
  -webkit-font-smoothing: antialiased;
}


h1 { font-size: 2.222rem; }
h2 { font-size: 1.667rem; }
h3 { font-size: 1.333rem; }
h4 { font-size: 1.167rem; }
h5 { font-size: 1.0rem; } 
h6 { font-size: 0.889rem; }

p, li {
  text-wrap: pretty;
}

h1, h2, h3, h4, h5, h6 {
  text-wrap: balance;
}

body {
  font-family: system-ui, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
  font-family: system-ui, sans-serif;
  font-weight: bold;
}

main article {
  font-family: Charter, 'Bitstream Charter', 'Sitka Text', Cambria, serif;
}


input, button, textarea, select {
  font: inherit;
}

input, select, textarea, img, picture, video, canvas, svg, table, pre {
  vertical-align: baseline;
}

label:has(+ textarea) {
  vertical-align: top;
}

select {
  padding: 0.25em;
  line-height: 1.2;
  vertical-align: baseline;
}

input, textarea, select, button {
  border: 1px solid #ccc;
  color: inherit;
}

input[type="range"] {
  background-color: transparent;
}        


:where(code, pre) {
  border: 1px solid #ccc;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: 0.9em;
}

code {
  padding: 0.1em 0.3em;
  white-space: nowrap;
}

pre > code {
  all: unset;
}

pre {
  padding: 1em;
  overflow-x: auto;
  line-height: 1.4;
} 

/* Horizontal Rule */

hr {
  border: 0;
  border-bottom: 1px solid currentColor;
  height: 0;
  margin: 1rem 0;
}


hr {
  border: 0;
  border-bottom: 1px solid currentColor;
  height: 0;
  margin: 1rem 0;
}


.horizontal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem;
  padding: 0;
  list-style: none;
  align-items: center;
}

.horizontal-links li {
  margin: 0;
  line-height: 1;
}

.horizontal-links a {
  white-space: nowrap;
}            


.visually-hidden {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
  padding: 0;
  margin: 0;
  clip: rect(1px,1px,1px,1px);
}


#menu-toggle {
  float: right;
  min-width: 2em;
  text-align: center;
  cursor: pointer;
}

#menu-toggle .icon-close {
  display:none;
}

#menu-toggle[aria-expanded="true"] .icon-open {
  display:none;
}

#menu-toggle[aria-expanded="true"] .icon-close {
  display:inline;
}            

.masthead::after {
  content: "";
  display: table;
  clear: both;
}


html, body {
  height: 100%
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh
}

main {
  flex: 1 0 auto
}

footer {
  flex-shrink: 0;
  position: relative;
}


.bump-mt-0 { margin-top: 0; }
.bump-mt-1 { margin-top: 1rem; }
.bump-mt-2 { margin-top: 2rem; }
.bump-mt-3 { margin-top: 3rem; }

.bump-mb-0 { margin-bottom: 0; }
.bump-mb-1 { margin-bottom: 1rem; }
.bump-mb-2 { margin-bottom: 2rem; }
.bump-mb-3 { margin-bottom: 3rem; }


a[href^="http://"]:after,
a[href^="https://"]:after {
  content: '';
  display: inline-block;
  vertical-align: -0.11111em;
  margin-left: 0.25em;
  width: 0.8333em;
  height: 0.8333em;
  background: currentColor;
  mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path fill="white" d="M10.5 1a.5.5 0 0 0 0 1h2.793L7.146 8.146a.5.5 0 1 0 .708.708L14 2.707V5.5a.5.5 0 0 0 1 0v-4a.5.5 0 0 0-.5-.5h-4z"/><path fill="white" d="M13 8a.5.5 0 0 1 .5.5v4A2.5 2.5 0 0 1 11 15H4A2.5 2.5 0 0 1 1.5 12.5V5A2.5 2.5 0 0 1 4 2.5h4a.5.5 0 0 1 0 1H4A1.5 1.5 0 0 0 2.5 5v7.5A1.5 1.5 0 0 0 4 14h7a1.5 1.5 0 0 0 1.5-1.5v-4a.5.5 0 0 1 .5-.5z"/></svg>');
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}            

/* DARK THEME */
body {
  color: #f7f8f3;
  background-color: #2a2d29;
}


body {
    background-position: center center;
    background-repeat: no-repeat;
    background-image: url("/-/images/logo-opengraph.png");
}

/* Modified */