@charset "UTF-8";
/*
 * 8-color neutral palette with a 16-color accent palette.
 */
@font-face {
  font-family: "Literata";
  src: url("https://www.codas.dev/vendor/kits/withcaer-brand/fonts/ttf/literata-variable.ttf");
  font-style: normal;
  font-display: swap;
  font-weight: 200 900;
}
@font-face {
  font-family: "Literata";
  src: url("https://www.codas.dev/vendor/kits/withcaer-brand/fonts/ttf/literata-italic-variable.ttf");
  font-style: italic;
  font-display: swap;
  font-weight: 200 900;
}
@font-face {
  font-family: "Inconsolata";
  src: url("https://www.codas.dev/vendor/kits/withcaer-brand/fonts/ttf/inconsolata-variable.ttf");
  font-style: normal;
  font-display: swap;
  font-weight: 200 900;
  size-adjust: 115%;
}
:root {
  --t-neutral-bg: #faf5e6;
  --t-neutral-bg-glass: rgba(250, 245, 230, 0.25);
  --t-neutral-bg-glaze: rgba(250, 245, 230, 0.5);
  --t-neutral-bg-glossy: rgba(250, 245, 230, 0.86);
  --t-neutral-bg-glassy: rgba(250, 245, 230, 0.96);
  --t-neutral-bg-more: #ebe4d3;
  --t-neutral-bg-more-glass: rgba(235, 228, 211, 0.25);
  --t-neutral-bg-more-glaze: rgba(235, 228, 211, 0.5);
  --t-neutral-bg-more-glossy: rgba(235, 228, 211, 0.86);
  --t-neutral-bg-more-glassy: rgba(235, 228, 211, 0.96);
  --t-neutral-fg-less: #7d7a70;
  --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
  --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
  --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
  --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
  --t-neutral-fg: #4d4b45;
  --t-neutral-fg-glass: rgba(77, 75, 69, 0.25);
  --t-neutral-fg-glaze: rgba(77, 75, 69, 0.5);
  --t-neutral-fg-glossy: rgba(77, 75, 69, 0.86);
  --t-neutral-fg-glassy: rgba(77, 75, 69, 0.96);
  --t-neutral-fg-more: #21201d;
  --t-neutral-fg-more-glass: rgba(33, 32, 29, 0.25);
  --t-neutral-fg-more-glaze: rgba(33, 32, 29, 0.5);
  --t-neutral-fg-more-glossy: rgba(33, 32, 29, 0.86);
  --t-neutral-fg-more-glassy: rgba(33, 32, 29, 0.96);
  --t-accent-1: #8fb657;
  --t-accent-1-glass: rgba(143, 182, 87, 0.25);
  --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
  --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
  --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
  --t-accent-1-secondary: #aac67b;
  --t-accent-1-tertiary: #d5dfb4;
  --t-accent-1-fade: #efefd8;
  --t-accent-2: #97abd4;
  --t-accent-2-glass: rgba(151, 171, 212, 0.25);
  --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
  --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
  --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
  --t-accent-2-secondary: #b0bed9;
  --t-accent-2-tertiary: #d7dbe0;
  --t-accent-2-fade: #f0eee4;
  --t-accent-3: #ef9275;
  --t-accent-3-glass: rgba(239, 146, 117, 0.25);
  --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
  --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
  --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
  --t-accent-3-secondary: #f2ab91;
  --t-accent-3-tertiary: #f6d2be;
  --t-accent-3-fade: #f9ebdb;
  --t-accent-4: #d2a74c;
  --t-accent-4-glass: rgba(210, 167, 76, 0.25);
  --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
  --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
  --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
  --t-accent-4-secondary: #dcbb73;
  --t-accent-4-tertiary: #ecdab0;
  --t-accent-4-fade: #f6edd7;
  --t-accent-5: #3bc0e0;
  --t-accent-5-glass: rgba(59, 192, 224, 0.25);
  --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
  --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
  --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
  --t-accent-5-secondary: #6bcde2;
  --t-accent-5-tertiary: #b7e2e4;
  --t-accent-5-fade: #e7f0e5;
  --t-accent-6: #e88db4;
  --t-accent-6-glass: rgba(232, 141, 180, 0.25);
  --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
  --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
  --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
  --t-accent-6-secondary: #eda7c1;
  --t-accent-6-tertiary: #f4d1d5;
  --t-accent-6-fade: #f8ebe1;
}

@media (prefers-color-scheme: dark) {
  :root {
    --t-neutral-bg: #161512;
    --t-neutral-bg-glass: rgba(22, 21, 18, 0.25);
    --t-neutral-bg-glaze: rgba(22, 21, 18, 0.5);
    --t-neutral-bg-glossy: rgba(22, 21, 18, 0.86);
    --t-neutral-bg-glassy: rgba(22, 21, 18, 0.96);
    --t-neutral-bg-more: #21201d;
    --t-neutral-bg-more-glass: rgba(33, 32, 29, 0.25);
    --t-neutral-bg-more-glaze: rgba(33, 32, 29, 0.5);
    --t-neutral-bg-more-glossy: rgba(33, 32, 29, 0.86);
    --t-neutral-bg-more-glassy: rgba(33, 32, 29, 0.96);
    --t-neutral-fg-less: #7d7a70;
    --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
    --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
    --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
    --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
    --t-neutral-fg: #b2aea0;
    --t-neutral-fg-glass: rgba(178, 174, 160, 0.25);
    --t-neutral-fg-glaze: rgba(178, 174, 160, 0.5);
    --t-neutral-fg-glossy: rgba(178, 174, 160, 0.86);
    --t-neutral-fg-glassy: rgba(178, 174, 160, 0.96);
    --t-neutral-fg-more: #ebe4d3;
    --t-neutral-fg-more-glass: rgba(235, 228, 211, 0.25);
    --t-neutral-fg-more-glaze: rgba(235, 228, 211, 0.5);
    --t-neutral-fg-more-glossy: rgba(235, 228, 211, 0.86);
    --t-neutral-fg-more-glassy: rgba(235, 228, 211, 0.96);
    --t-accent-1: #8fb657;
    --t-accent-1-glass: rgba(143, 182, 87, 0.25);
    --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
    --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
    --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
    --t-accent-1-secondary: #718e46;
    --t-accent-1-tertiary: #404d2a;
    --t-accent-1-fade: #222519;
    --t-accent-2: #97abd4;
    --t-accent-2-glass: rgba(151, 171, 212, 0.25);
    --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
    --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
    --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
    --t-accent-2-secondary: #7786a4;
    --t-accent-2-tertiary: #434a56;
    --t-accent-2-fade: #232425;
    --t-accent-3: #ef9275;
    --t-accent-3-glass: rgba(239, 146, 117, 0.25);
    --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
    --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
    --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
    --t-accent-3-secondary: #b9735c;
    --t-accent-3-tertiary: #624135;
    --t-accent-3-fade: #2c221c;
    --t-accent-4: #d2a74c;
    --t-accent-4-glass: rgba(210, 167, 76, 0.25);
    --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
    --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
    --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
    --t-accent-4-secondary: #a3833e;
    --t-accent-4-tertiary: #584826;
    --t-accent-4-fade: #292418;
    --t-accent-5: #3bc0e0;
    --t-accent-5-glass: rgba(59, 192, 224, 0.25);
    --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
    --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
    --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
    --t-accent-5-secondary: #3295ad;
    --t-accent-5-tertiary: #23515a;
    --t-accent-5-fade: #1a2627;
    --t-accent-6: #e88db4;
    --t-accent-6-glass: rgba(232, 141, 180, 0.25);
    --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
    --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
    --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
    --t-accent-6-secondary: #b46f8c;
    --t-accent-6-tertiary: #5f3f4b;
    --t-accent-6-fade: #2b2122;
  }
}
:root.light-theme {
  --t-neutral-bg: #faf5e6;
  --t-neutral-bg-glass: rgba(250, 245, 230, 0.25);
  --t-neutral-bg-glaze: rgba(250, 245, 230, 0.5);
  --t-neutral-bg-glossy: rgba(250, 245, 230, 0.86);
  --t-neutral-bg-glassy: rgba(250, 245, 230, 0.96);
  --t-neutral-bg-more: #ebe4d3;
  --t-neutral-bg-more-glass: rgba(235, 228, 211, 0.25);
  --t-neutral-bg-more-glaze: rgba(235, 228, 211, 0.5);
  --t-neutral-bg-more-glossy: rgba(235, 228, 211, 0.86);
  --t-neutral-bg-more-glassy: rgba(235, 228, 211, 0.96);
  --t-neutral-fg-less: #7d7a70;
  --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
  --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
  --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
  --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
  --t-neutral-fg: #4d4b45;
  --t-neutral-fg-glass: rgba(77, 75, 69, 0.25);
  --t-neutral-fg-glaze: rgba(77, 75, 69, 0.5);
  --t-neutral-fg-glossy: rgba(77, 75, 69, 0.86);
  --t-neutral-fg-glassy: rgba(77, 75, 69, 0.96);
  --t-neutral-fg-more: #21201d;
  --t-neutral-fg-more-glass: rgba(33, 32, 29, 0.25);
  --t-neutral-fg-more-glaze: rgba(33, 32, 29, 0.5);
  --t-neutral-fg-more-glossy: rgba(33, 32, 29, 0.86);
  --t-neutral-fg-more-glassy: rgba(33, 32, 29, 0.96);
  --t-accent-1: #8fb657;
  --t-accent-1-glass: rgba(143, 182, 87, 0.25);
  --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
  --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
  --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
  --t-accent-1-secondary: #aac67b;
  --t-accent-1-tertiary: #d5dfb4;
  --t-accent-1-fade: #efefd8;
  --t-accent-2: #97abd4;
  --t-accent-2-glass: rgba(151, 171, 212, 0.25);
  --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
  --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
  --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
  --t-accent-2-secondary: #b0bed9;
  --t-accent-2-tertiary: #d7dbe0;
  --t-accent-2-fade: #f0eee4;
  --t-accent-3: #ef9275;
  --t-accent-3-glass: rgba(239, 146, 117, 0.25);
  --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
  --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
  --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
  --t-accent-3-secondary: #f2ab91;
  --t-accent-3-tertiary: #f6d2be;
  --t-accent-3-fade: #f9ebdb;
  --t-accent-4: #d2a74c;
  --t-accent-4-glass: rgba(210, 167, 76, 0.25);
  --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
  --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
  --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
  --t-accent-4-secondary: #dcbb73;
  --t-accent-4-tertiary: #ecdab0;
  --t-accent-4-fade: #f6edd7;
  --t-accent-5: #3bc0e0;
  --t-accent-5-glass: rgba(59, 192, 224, 0.25);
  --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
  --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
  --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
  --t-accent-5-secondary: #6bcde2;
  --t-accent-5-tertiary: #b7e2e4;
  --t-accent-5-fade: #e7f0e5;
  --t-accent-6: #e88db4;
  --t-accent-6-glass: rgba(232, 141, 180, 0.25);
  --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
  --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
  --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
  --t-accent-6-secondary: #eda7c1;
  --t-accent-6-tertiary: #f4d1d5;
  --t-accent-6-fade: #f8ebe1;
}

:root.dark-theme {
  --t-neutral-bg: #161512;
  --t-neutral-bg-glass: rgba(22, 21, 18, 0.25);
  --t-neutral-bg-glaze: rgba(22, 21, 18, 0.5);
  --t-neutral-bg-glossy: rgba(22, 21, 18, 0.86);
  --t-neutral-bg-glassy: rgba(22, 21, 18, 0.96);
  --t-neutral-bg-more: #21201d;
  --t-neutral-bg-more-glass: rgba(33, 32, 29, 0.25);
  --t-neutral-bg-more-glaze: rgba(33, 32, 29, 0.5);
  --t-neutral-bg-more-glossy: rgba(33, 32, 29, 0.86);
  --t-neutral-bg-more-glassy: rgba(33, 32, 29, 0.96);
  --t-neutral-fg-less: #7d7a70;
  --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
  --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
  --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
  --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
  --t-neutral-fg: #b2aea0;
  --t-neutral-fg-glass: rgba(178, 174, 160, 0.25);
  --t-neutral-fg-glaze: rgba(178, 174, 160, 0.5);
  --t-neutral-fg-glossy: rgba(178, 174, 160, 0.86);
  --t-neutral-fg-glassy: rgba(178, 174, 160, 0.96);
  --t-neutral-fg-more: #ebe4d3;
  --t-neutral-fg-more-glass: rgba(235, 228, 211, 0.25);
  --t-neutral-fg-more-glaze: rgba(235, 228, 211, 0.5);
  --t-neutral-fg-more-glossy: rgba(235, 228, 211, 0.86);
  --t-neutral-fg-more-glassy: rgba(235, 228, 211, 0.96);
  --t-accent-1: #8fb657;
  --t-accent-1-glass: rgba(143, 182, 87, 0.25);
  --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
  --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
  --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
  --t-accent-1-secondary: #718e46;
  --t-accent-1-tertiary: #404d2a;
  --t-accent-1-fade: #222519;
  --t-accent-2: #97abd4;
  --t-accent-2-glass: rgba(151, 171, 212, 0.25);
  --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
  --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
  --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
  --t-accent-2-secondary: #7786a4;
  --t-accent-2-tertiary: #434a56;
  --t-accent-2-fade: #232425;
  --t-accent-3: #ef9275;
  --t-accent-3-glass: rgba(239, 146, 117, 0.25);
  --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
  --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
  --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
  --t-accent-3-secondary: #b9735c;
  --t-accent-3-tertiary: #624135;
  --t-accent-3-fade: #2c221c;
  --t-accent-4: #d2a74c;
  --t-accent-4-glass: rgba(210, 167, 76, 0.25);
  --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
  --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
  --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
  --t-accent-4-secondary: #a3833e;
  --t-accent-4-tertiary: #584826;
  --t-accent-4-fade: #292418;
  --t-accent-5: #3bc0e0;
  --t-accent-5-glass: rgba(59, 192, 224, 0.25);
  --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
  --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
  --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
  --t-accent-5-secondary: #3295ad;
  --t-accent-5-tertiary: #23515a;
  --t-accent-5-fade: #1a2627;
  --t-accent-6: #e88db4;
  --t-accent-6-glass: rgba(232, 141, 180, 0.25);
  --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
  --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
  --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
  --t-accent-6-secondary: #b46f8c;
  --t-accent-6-tertiary: #5f3f4b;
  --t-accent-6-fade: #2b2122;
}

#theme-toggle {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  transition: color 0.3s ease;
}
#theme-toggle:hover {
  cursor: pointer;
  color: #8fb657;
  color: var(--t-accent-1);
}
#theme-toggle:active {
  cursor: pointer;
  color: #97abd4;
  color: var(--t-accent-2);
}
#theme-toggle > .dark {
  display: none;
}
@media (prefers-color-scheme: dark) {
  #theme-toggle > .light {
    display: none;
  }
  #theme-toggle > .dark {
    display: inherit;
  }
}
:root.light-theme #theme-toggle > .light {
  display: inherit;
}
:root.light-theme #theme-toggle > .dark {
  display: none;
}
:root.dark-theme #theme-toggle > .light {
  display: none;
}
:root.dark-theme #theme-toggle > .dark {
  display: inherit;
}

@media screen and (max-width: 991px) {
  .wd-only {
    display: none !important;
  }
}

@media screen and (max-width: 600px), screen and (max-height: 500px) {
  .tn-never {
    display: none !important;
  }
}

/*
 * 12-segment layout system using Flexbox and push grids.
 *
 * This layout system is designed around rows and cols; it is not a 12-column layout system.
 * For example, a simple page header may have one logical column of content, within which
 * there are two rows of content, and each row may be divided into several columns:
 *
 * <div class="row-container">
 *     <div class="row-12 row-container"> <!-- A full-height row which contains columns. -->
 *         <div class="col-12"></div> <!-- A full-width col. -->
 *     </div>
 * </div>
 *
 * Columns may be overridden with `col-wd-X` styles to specify alternate layouts
 * for wider screens.
 *
 * Rows may be overridden with `row-tl-X` styles to specify alternate layouts
 * for taller screens.
 *
 * Flexbox implemented based on: https://css-tricks.com/snippets/css/a-guide-to-flexbox/
 */
.col-container, .row-container {
  width: 100%;
  height: 100%;
  clear: both;
  content: "";
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  align-content: center;
  justify-content: center;
}
.con-left.col-container, .con-left.row-container {
  align-items: flex-start;
  align-content: flex-start;
  justify-content: flex-start !important;
}
.con-right.col-container, .con-right.row-container {
  align-items: flex-end;
  align-content: flex-end;
  justify-content: flex-end !important;
}
.con-distribute.col-container, .con-distribute.row-container {
  align-items: center;
  align-content: space-around;
  justify-content: space-evenly !important;
}
.con-bleed.col-container, .con-bleed.row-container {
  align-items: center;
  align-content: space-between;
  justify-content: space-between !important;
}

.row-container {
  flex-direction: column;
}
.row-container.con-bleed > [class^=row-]:first-of-type {
  padding-top: 1%;
}
.row-container.con-bleed > [class^=row-]:last-of-type {
  padding-bottom: 1%;
}
.row-container [class^=row-] {
  width: 100%;
}
.row-container [class^=row-] > * {
  max-height: 100%;
}

.col-container {
  flex-direction: row;
}
.col-container.con-bleed > [class^=col-]:first-of-type {
  padding-left: 2%;
}
.col-container.con-bleed > [class^=col-]:last-of-type {
  padding-right: 2%;
}
.col-container [class^=col-] {
  height: 100%;
}
.col-container [class^=col-] > * {
  max-width: 100%;
}

.row-1 {
  height: 7.25%;
}

.col-1 {
  width: 7.25%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-1 {
    height: 7.25%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-1 {
    width: 7.25%;
  }
}

.row-2 {
  height: 15.5%;
}

.col-2 {
  width: 15.5%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-2 {
    height: 15.5%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-2 {
    width: 15.5%;
  }
}

.row-3 {
  height: 23.75%;
}

.col-3 {
  width: 23.75%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-3 {
    height: 23.75%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-3 {
    width: 23.75%;
  }
}

.row-4 {
  height: 32%;
}

.col-4 {
  width: 32%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-4 {
    height: 32%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-4 {
    width: 32%;
  }
}

.row-5 {
  height: 40.25%;
}

.col-5 {
  width: 40.25%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-5 {
    height: 40.25%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-5 {
    width: 40.25%;
  }
}

.row-6 {
  height: 48.5%;
}

.col-6 {
  width: 48.5%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-6 {
    height: 48.5%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-6 {
    width: 48.5%;
  }
}

.row-7 {
  height: 56.75%;
}

.col-7 {
  width: 56.75%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-7 {
    height: 56.75%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-7 {
    width: 56.75%;
  }
}

.row-8 {
  height: 65%;
}

.col-8 {
  width: 65%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-8 {
    height: 65%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-8 {
    width: 65%;
  }
}

.row-9 {
  height: 73.25%;
}

.col-9 {
  width: 73.25%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-9 {
    height: 73.25%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-9 {
    width: 73.25%;
  }
}

.row-10 {
  height: 81.5%;
}

.col-10 {
  width: 81.5%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-10 {
    height: 81.5%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-10 {
    width: 81.5%;
  }
}

.row-11 {
  height: 89.75%;
}

.col-11 {
  width: 89.75%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-11 {
    height: 89.75%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-11 {
    width: 89.75%;
  }
}

.row-12 {
  height: 98%;
}

.col-12 {
  width: 98%;
}

@media screen and (max-width: 991px) {
  [class^=row-].row-tl-12 {
    height: 98%;
  }
}

@media screen and (min-width: 992px) {
  [class^=col-].col-wd-12 {
    width: 98%;
  }
}

@media screen and (max-width: 991px) {
  .wd-only {
    display: none !important;
  }
}

@media screen and (max-width: 600px), screen and (max-height: 500px) {
  .tn-never {
    display: none !important;
  }
}

:root {
  --t-neutral-bg: #faf5e6;
  --t-neutral-bg-glass: rgba(250, 245, 230, 0.25);
  --t-neutral-bg-glaze: rgba(250, 245, 230, 0.5);
  --t-neutral-bg-glossy: rgba(250, 245, 230, 0.86);
  --t-neutral-bg-glassy: rgba(250, 245, 230, 0.96);
  --t-neutral-bg-more: #ebe4d3;
  --t-neutral-bg-more-glass: rgba(235, 228, 211, 0.25);
  --t-neutral-bg-more-glaze: rgba(235, 228, 211, 0.5);
  --t-neutral-bg-more-glossy: rgba(235, 228, 211, 0.86);
  --t-neutral-bg-more-glassy: rgba(235, 228, 211, 0.96);
  --t-neutral-fg-less: #7d7a70;
  --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
  --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
  --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
  --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
  --t-neutral-fg: #4d4b45;
  --t-neutral-fg-glass: rgba(77, 75, 69, 0.25);
  --t-neutral-fg-glaze: rgba(77, 75, 69, 0.5);
  --t-neutral-fg-glossy: rgba(77, 75, 69, 0.86);
  --t-neutral-fg-glassy: rgba(77, 75, 69, 0.96);
  --t-neutral-fg-more: #21201d;
  --t-neutral-fg-more-glass: rgba(33, 32, 29, 0.25);
  --t-neutral-fg-more-glaze: rgba(33, 32, 29, 0.5);
  --t-neutral-fg-more-glossy: rgba(33, 32, 29, 0.86);
  --t-neutral-fg-more-glassy: rgba(33, 32, 29, 0.96);
  --t-accent-1: #8fb657;
  --t-accent-1-glass: rgba(143, 182, 87, 0.25);
  --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
  --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
  --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
  --t-accent-1-secondary: #aac67b;
  --t-accent-1-tertiary: #d5dfb4;
  --t-accent-1-fade: #efefd8;
  --t-accent-2: #97abd4;
  --t-accent-2-glass: rgba(151, 171, 212, 0.25);
  --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
  --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
  --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
  --t-accent-2-secondary: #b0bed9;
  --t-accent-2-tertiary: #d7dbe0;
  --t-accent-2-fade: #f0eee4;
  --t-accent-3: #ef9275;
  --t-accent-3-glass: rgba(239, 146, 117, 0.25);
  --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
  --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
  --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
  --t-accent-3-secondary: #f2ab91;
  --t-accent-3-tertiary: #f6d2be;
  --t-accent-3-fade: #f9ebdb;
  --t-accent-4: #d2a74c;
  --t-accent-4-glass: rgba(210, 167, 76, 0.25);
  --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
  --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
  --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
  --t-accent-4-secondary: #dcbb73;
  --t-accent-4-tertiary: #ecdab0;
  --t-accent-4-fade: #f6edd7;
  --t-accent-5: #3bc0e0;
  --t-accent-5-glass: rgba(59, 192, 224, 0.25);
  --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
  --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
  --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
  --t-accent-5-secondary: #6bcde2;
  --t-accent-5-tertiary: #b7e2e4;
  --t-accent-5-fade: #e7f0e5;
  --t-accent-6: #e88db4;
  --t-accent-6-glass: rgba(232, 141, 180, 0.25);
  --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
  --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
  --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
  --t-accent-6-secondary: #eda7c1;
  --t-accent-6-tertiary: #f4d1d5;
  --t-accent-6-fade: #f8ebe1;
}

@media (prefers-color-scheme: dark) {
  :root {
    --t-neutral-bg: #161512;
    --t-neutral-bg-glass: rgba(22, 21, 18, 0.25);
    --t-neutral-bg-glaze: rgba(22, 21, 18, 0.5);
    --t-neutral-bg-glossy: rgba(22, 21, 18, 0.86);
    --t-neutral-bg-glassy: rgba(22, 21, 18, 0.96);
    --t-neutral-bg-more: #21201d;
    --t-neutral-bg-more-glass: rgba(33, 32, 29, 0.25);
    --t-neutral-bg-more-glaze: rgba(33, 32, 29, 0.5);
    --t-neutral-bg-more-glossy: rgba(33, 32, 29, 0.86);
    --t-neutral-bg-more-glassy: rgba(33, 32, 29, 0.96);
    --t-neutral-fg-less: #7d7a70;
    --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
    --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
    --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
    --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
    --t-neutral-fg: #b2aea0;
    --t-neutral-fg-glass: rgba(178, 174, 160, 0.25);
    --t-neutral-fg-glaze: rgba(178, 174, 160, 0.5);
    --t-neutral-fg-glossy: rgba(178, 174, 160, 0.86);
    --t-neutral-fg-glassy: rgba(178, 174, 160, 0.96);
    --t-neutral-fg-more: #ebe4d3;
    --t-neutral-fg-more-glass: rgba(235, 228, 211, 0.25);
    --t-neutral-fg-more-glaze: rgba(235, 228, 211, 0.5);
    --t-neutral-fg-more-glossy: rgba(235, 228, 211, 0.86);
    --t-neutral-fg-more-glassy: rgba(235, 228, 211, 0.96);
    --t-accent-1: #8fb657;
    --t-accent-1-glass: rgba(143, 182, 87, 0.25);
    --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
    --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
    --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
    --t-accent-1-secondary: #718e46;
    --t-accent-1-tertiary: #404d2a;
    --t-accent-1-fade: #222519;
    --t-accent-2: #97abd4;
    --t-accent-2-glass: rgba(151, 171, 212, 0.25);
    --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
    --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
    --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
    --t-accent-2-secondary: #7786a4;
    --t-accent-2-tertiary: #434a56;
    --t-accent-2-fade: #232425;
    --t-accent-3: #ef9275;
    --t-accent-3-glass: rgba(239, 146, 117, 0.25);
    --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
    --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
    --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
    --t-accent-3-secondary: #b9735c;
    --t-accent-3-tertiary: #624135;
    --t-accent-3-fade: #2c221c;
    --t-accent-4: #d2a74c;
    --t-accent-4-glass: rgba(210, 167, 76, 0.25);
    --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
    --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
    --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
    --t-accent-4-secondary: #a3833e;
    --t-accent-4-tertiary: #584826;
    --t-accent-4-fade: #292418;
    --t-accent-5: #3bc0e0;
    --t-accent-5-glass: rgba(59, 192, 224, 0.25);
    --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
    --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
    --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
    --t-accent-5-secondary: #3295ad;
    --t-accent-5-tertiary: #23515a;
    --t-accent-5-fade: #1a2627;
    --t-accent-6: #e88db4;
    --t-accent-6-glass: rgba(232, 141, 180, 0.25);
    --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
    --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
    --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
    --t-accent-6-secondary: #b46f8c;
    --t-accent-6-tertiary: #5f3f4b;
    --t-accent-6-fade: #2b2122;
  }
}
:root.light-theme {
  --t-neutral-bg: #faf5e6;
  --t-neutral-bg-glass: rgba(250, 245, 230, 0.25);
  --t-neutral-bg-glaze: rgba(250, 245, 230, 0.5);
  --t-neutral-bg-glossy: rgba(250, 245, 230, 0.86);
  --t-neutral-bg-glassy: rgba(250, 245, 230, 0.96);
  --t-neutral-bg-more: #ebe4d3;
  --t-neutral-bg-more-glass: rgba(235, 228, 211, 0.25);
  --t-neutral-bg-more-glaze: rgba(235, 228, 211, 0.5);
  --t-neutral-bg-more-glossy: rgba(235, 228, 211, 0.86);
  --t-neutral-bg-more-glassy: rgba(235, 228, 211, 0.96);
  --t-neutral-fg-less: #7d7a70;
  --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
  --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
  --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
  --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
  --t-neutral-fg: #4d4b45;
  --t-neutral-fg-glass: rgba(77, 75, 69, 0.25);
  --t-neutral-fg-glaze: rgba(77, 75, 69, 0.5);
  --t-neutral-fg-glossy: rgba(77, 75, 69, 0.86);
  --t-neutral-fg-glassy: rgba(77, 75, 69, 0.96);
  --t-neutral-fg-more: #21201d;
  --t-neutral-fg-more-glass: rgba(33, 32, 29, 0.25);
  --t-neutral-fg-more-glaze: rgba(33, 32, 29, 0.5);
  --t-neutral-fg-more-glossy: rgba(33, 32, 29, 0.86);
  --t-neutral-fg-more-glassy: rgba(33, 32, 29, 0.96);
  --t-accent-1: #8fb657;
  --t-accent-1-glass: rgba(143, 182, 87, 0.25);
  --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
  --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
  --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
  --t-accent-1-secondary: #aac67b;
  --t-accent-1-tertiary: #d5dfb4;
  --t-accent-1-fade: #efefd8;
  --t-accent-2: #97abd4;
  --t-accent-2-glass: rgba(151, 171, 212, 0.25);
  --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
  --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
  --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
  --t-accent-2-secondary: #b0bed9;
  --t-accent-2-tertiary: #d7dbe0;
  --t-accent-2-fade: #f0eee4;
  --t-accent-3: #ef9275;
  --t-accent-3-glass: rgba(239, 146, 117, 0.25);
  --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
  --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
  --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
  --t-accent-3-secondary: #f2ab91;
  --t-accent-3-tertiary: #f6d2be;
  --t-accent-3-fade: #f9ebdb;
  --t-accent-4: #d2a74c;
  --t-accent-4-glass: rgba(210, 167, 76, 0.25);
  --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
  --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
  --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
  --t-accent-4-secondary: #dcbb73;
  --t-accent-4-tertiary: #ecdab0;
  --t-accent-4-fade: #f6edd7;
  --t-accent-5: #3bc0e0;
  --t-accent-5-glass: rgba(59, 192, 224, 0.25);
  --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
  --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
  --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
  --t-accent-5-secondary: #6bcde2;
  --t-accent-5-tertiary: #b7e2e4;
  --t-accent-5-fade: #e7f0e5;
  --t-accent-6: #e88db4;
  --t-accent-6-glass: rgba(232, 141, 180, 0.25);
  --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
  --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
  --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
  --t-accent-6-secondary: #eda7c1;
  --t-accent-6-tertiary: #f4d1d5;
  --t-accent-6-fade: #f8ebe1;
}

:root.dark-theme {
  --t-neutral-bg: #161512;
  --t-neutral-bg-glass: rgba(22, 21, 18, 0.25);
  --t-neutral-bg-glaze: rgba(22, 21, 18, 0.5);
  --t-neutral-bg-glossy: rgba(22, 21, 18, 0.86);
  --t-neutral-bg-glassy: rgba(22, 21, 18, 0.96);
  --t-neutral-bg-more: #21201d;
  --t-neutral-bg-more-glass: rgba(33, 32, 29, 0.25);
  --t-neutral-bg-more-glaze: rgba(33, 32, 29, 0.5);
  --t-neutral-bg-more-glossy: rgba(33, 32, 29, 0.86);
  --t-neutral-bg-more-glassy: rgba(33, 32, 29, 0.96);
  --t-neutral-fg-less: #7d7a70;
  --t-neutral-fg-less-glass: rgba(125, 122, 112, 0.25);
  --t-neutral-fg-less-glaze: rgba(125, 122, 112, 0.5);
  --t-neutral-fg-less-glossy: rgba(125, 122, 112, 0.86);
  --t-neutral-fg-less-glassy: rgba(125, 122, 112, 0.96);
  --t-neutral-fg: #b2aea0;
  --t-neutral-fg-glass: rgba(178, 174, 160, 0.25);
  --t-neutral-fg-glaze: rgba(178, 174, 160, 0.5);
  --t-neutral-fg-glossy: rgba(178, 174, 160, 0.86);
  --t-neutral-fg-glassy: rgba(178, 174, 160, 0.96);
  --t-neutral-fg-more: #ebe4d3;
  --t-neutral-fg-more-glass: rgba(235, 228, 211, 0.25);
  --t-neutral-fg-more-glaze: rgba(235, 228, 211, 0.5);
  --t-neutral-fg-more-glossy: rgba(235, 228, 211, 0.86);
  --t-neutral-fg-more-glassy: rgba(235, 228, 211, 0.96);
  --t-accent-1: #8fb657;
  --t-accent-1-glass: rgba(143, 182, 87, 0.25);
  --t-accent-1-glaze: rgba(143, 182, 87, 0.5);
  --t-accent-1-glossy: rgba(143, 182, 87, 0.86);
  --t-accent-1-glassy: rgba(143, 182, 87, 0.96);
  --t-accent-1-secondary: #718e46;
  --t-accent-1-tertiary: #404d2a;
  --t-accent-1-fade: #222519;
  --t-accent-2: #97abd4;
  --t-accent-2-glass: rgba(151, 171, 212, 0.25);
  --t-accent-2-glaze: rgba(151, 171, 212, 0.5);
  --t-accent-2-glossy: rgba(151, 171, 212, 0.86);
  --t-accent-2-glassy: rgba(151, 171, 212, 0.96);
  --t-accent-2-secondary: #7786a4;
  --t-accent-2-tertiary: #434a56;
  --t-accent-2-fade: #232425;
  --t-accent-3: #ef9275;
  --t-accent-3-glass: rgba(239, 146, 117, 0.25);
  --t-accent-3-glaze: rgba(239, 146, 117, 0.5);
  --t-accent-3-glossy: rgba(239, 146, 117, 0.86);
  --t-accent-3-glassy: rgba(239, 146, 117, 0.96);
  --t-accent-3-secondary: #b9735c;
  --t-accent-3-tertiary: #624135;
  --t-accent-3-fade: #2c221c;
  --t-accent-4: #d2a74c;
  --t-accent-4-glass: rgba(210, 167, 76, 0.25);
  --t-accent-4-glaze: rgba(210, 167, 76, 0.5);
  --t-accent-4-glossy: rgba(210, 167, 76, 0.86);
  --t-accent-4-glassy: rgba(210, 167, 76, 0.96);
  --t-accent-4-secondary: #a3833e;
  --t-accent-4-tertiary: #584826;
  --t-accent-4-fade: #292418;
  --t-accent-5: #3bc0e0;
  --t-accent-5-glass: rgba(59, 192, 224, 0.25);
  --t-accent-5-glaze: rgba(59, 192, 224, 0.5);
  --t-accent-5-glossy: rgba(59, 192, 224, 0.86);
  --t-accent-5-glassy: rgba(59, 192, 224, 0.96);
  --t-accent-5-secondary: #3295ad;
  --t-accent-5-tertiary: #23515a;
  --t-accent-5-fade: #1a2627;
  --t-accent-6: #e88db4;
  --t-accent-6-glass: rgba(232, 141, 180, 0.25);
  --t-accent-6-glaze: rgba(232, 141, 180, 0.5);
  --t-accent-6-glossy: rgba(232, 141, 180, 0.86);
  --t-accent-6-glassy: rgba(232, 141, 180, 0.96);
  --t-accent-6-secondary: #b46f8c;
  --t-accent-6-tertiary: #5f3f4b;
  --t-accent-6-fade: #2b2122;
}

#theme-toggle {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  transition: color 0.3s ease;
}
#theme-toggle:hover {
  cursor: pointer;
  color: #8fb657;
  color: var(--t-accent-1);
}
#theme-toggle:active {
  cursor: pointer;
  color: #97abd4;
  color: var(--t-accent-2);
}
#theme-toggle > .dark {
  display: none;
}
@media (prefers-color-scheme: dark) {
  #theme-toggle > .light {
    display: none;
  }
  #theme-toggle > .dark {
    display: inherit;
  }
}
:root.light-theme #theme-toggle > .light {
  display: inherit;
}
:root.light-theme #theme-toggle > .dark {
  display: none;
}
:root.dark-theme #theme-toggle > .light {
  display: none;
}
:root.dark-theme #theme-toggle > .dark {
  display: inherit;
}

/*
 * 4-layer type hierarchy.
 *
 * We use a variation of the 4-layer type hierarchy
 * which enforces a minimum base font size of 16px,
 * plus an additional scalar calculated from
 * the current viewport width.
 */
code, pre, .text button, .text .button, .text a, p, blockquote, ul, li, h3, h4, h5, h6, h2, h1, html, body, * {
  font-style: normal;
  margin: 0;
  text-decoration: none;
  -webkit-text-size-adjust: 100%;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
::selection {
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}
::-moz-selection {
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}

html, body {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
}
html strong, body strong {
  font-weight: 600;
}
html em, body em {
  font-style: italic;
}

h1, h2, h3, h4, h5, h6 {
  font-optical-sizing: none;
}

h1 {
  font-family: "Literata", serif;
  font-weight: 700;
  font-size: calc(24px + 1.05vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
}

h2 {
  font-family: "Literata", serif;
  font-weight: 500;
  font-size: calc(16px + 1.4vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
}
h2 strong {
  font-weight: 600;
}

h3, h4, h5, h6 {
  font-family: "Literata", serif;
  font-weight: 500;
  font-size: calc(16px + 1.4vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
  font-size: calc(18px + 0.525vw);
}
h3 strong, h4 strong, h5 strong, h6 strong {
  font-weight: 600;
}

h3 {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

p, blockquote, ul, li {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
}
p strong, blockquote strong, ul strong, li strong {
  font-weight: 600;
}
p em, blockquote em, ul em, li em {
  font-style: italic;
}

.text a {
  transition: all 0.3s ease;
  padding: 0 0.25em;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  white-space: nowrap;
}
.text a:hover {
  color: var(--t-accent-1-fade);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  outline: none !important;
}
.text a:active {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background: none;
}

.text button, .text .button {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0.25em;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
  color: var(--t-accent-1-fade);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  white-space: nowrap;
}
.text button strong, .text .button strong {
  font-weight: 600;
}
.text button em, .text .button em {
  font-style: italic;
}
.text button:hover, .text .button:hover {
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  outline: none !important;
}
.text button:active, .text .button:active {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background: none;
}

.text {
  box-sizing: border-box;
  padding: 1.4rem;
}
.text * {
  line-height: 1.45em;
}
.text > h2 {
  margin-top: 2.8rem;
  scroll-margin-top: 1.4rem;
}
.text > h1 + h1, .text > h1 + h2, .text > h1 + h3, .text > h1 + h4, .text > h1 + h5, .text > h1 + h6, .text > h2 + h1, .text > h2 + h2, .text > h2 + h3, .text > h2 + h4, .text > h2 + h5, .text > h2 + h6, .text > h3 + h1, .text > h3 + h2, .text > h3 + h3, .text > h3 + h4, .text > h3 + h5, .text > h3 + h6, .text > h4 + h1, .text > h4 + h2, .text > h4 + h3, .text > h4 + h4, .text > h4 + h5, .text > h4 + h6, .text > h5 + h1, .text > h5 + h2, .text > h5 + h3, .text > h5 + h4, .text > h5 + h5, .text > h5 + h6, .text > h6 + h1, .text > h6 + h2, .text > h6 + h3, .text > h6 + h4, .text > h6 + h5, .text > h6 + h6 {
  padding-top: 0.1rem;
}
.text > h1 + p, .text > h2 + p, .text > h3 + p, .text > h4 + p, .text > h5 + p, .text > h6 + p {
  padding-top: 1rem;
}
.text > h1 + blockquote, .text > h1 + pre, .text > h2 + blockquote, .text > h2 + pre, .text > h3 + blockquote, .text > h3 + pre, .text > h4 + blockquote, .text > h4 + pre, .text > h5 + blockquote, .text > h5 + pre, .text > h6 + blockquote, .text > h6 + pre {
  margin-top: 1rem;
}
.text hr {
  border: none;
  color: var(--t-neutral-fg-glass);
  backdrop-filter: blur(1px);
  font-family: "Inconsolata", monospace;
  font-weight: 600;
  font-variant-ligatures: normal;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
  margin-top: 1.4rem;
  margin-bottom: 2.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  align-content: space-between;
  flex-direction: row;
}
.text hr::after {
  content: " ";
  transition: all 0.3s ease;
  animation: hr-blink 2s infinite;
  font-family: "Inconsolata", monospace;
  font-size: calc(16px + 0.175vw);
  text-align: left;
  text-wrap-mode: nowrap;
  padding: 0px;
  margin-left: 0.5em;
  background: var(--t-accent-1-glass);
  flex: 0;
  border-radius: 7px 7px 7px 7px;
}
@keyframes hr-blink {
  50% {
    opacity: 0%;
  }
}
.text hr::before {
  content: " ";
  font-family: "Inconsolata", monospace;
  font-size: calc(16px + 0.175vw);
  text-align: right;
  text-wrap-mode: nowrap;
  padding-right: 0.5em;
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background: #ebe4d3;
  background: var(--t-neutral-bg-more);
  flex: 1;
  border-radius: 7px 7px 7px 7px;
}
.text ul, .text ol {
  padding-left: 2.5rem;
}
.text ul:not(:last-child), .text ol:not(:last-child) {
  margin-bottom: 1rem;
}
.text ul li:not(:last-child), .text ol li:not(:last-child) {
  margin-bottom: 1rem;
}
.text ul li:last-child, .text ol li:last-child {
  margin-bottom: 1rem;
}
.text p:not(:last-child), .text blockquote:not(:last-child), .text pre:not(:last-child) {
  margin-bottom: 1rem;
}
.text strong, .text p strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text em {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text blockquote {
  border-left: 4px solid var(--t-neutral-fg-glass);
  margin: 0;
  padding-left: 1.5rem;
}
.text blockquote, .text blockquote > * {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text blockquote strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text blockquote em {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.text blockquote > ul, .text blockquote > ol {
  padding-left: 1rem;
}
.text blockquote > ul > li, .text blockquote > ol > li {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text details {
  transition: all 0.3s ease;
  background-color: var(--t-neutral-bg-glaze);
  backdrop-filter: blur(1px);
  box-shadow: 0px 0px 18px 6px rgba(0, 0, 0, 0.2);
  border: 6px solid var(--t-neutral-bg-more);
  border-radius: 7px 7px 20px 7px;
  padding-left: 1.4rem;
  padding-right: 1.4rem;
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
}
.text details:hover, .text details[open] {
  border: 6px solid var(--t-accent-1);
}
.text details[open] {
  padding-bottom: 1.4rem;
}
.text details[open] > summary {
  margin-bottom: 1rem;
}
.text details > summary {
  color: #8fb657;
  color: var(--t-accent-1);
  cursor: pointer;
  font-style: italic;
}
.text details > summary::-webkit-details-marker, .text details > summary::marker {
  color: #8fb657;
  color: var(--t-accent-1);
}
.text details, .text details > * {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text details strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text details em {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.text details > ul, .text details > ol {
  padding-left: 1rem;
}
.text details > ul > li, .text details > ol > li {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text p:has(img:only-child) {
  transition: all 0.3s ease;
  display: flex;
  padding: 0.25em;
  overflow: hidden;
  height: auto;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
  backdrop-filter: blur(1px);
  border: 6px solid var(--t-neutral-bg);
  border-radius: 1em;
}
.text p:has(img:only-child):nth-of-type(even) {
  transform: rotate(-1deg) scale(95%);
}
.text p:has(img:only-child):nth-of-type(odd) {
  transform: rotate(1deg) scale(95%);
}
.text p:has(img:only-child) > img {
  transition: all 0.3s ease;
  filter: saturate(25%);
  opacity: 75%;
  object-fit: cover;
  width: 100%;
  flex: 1;
}
.text p:has(img:only-child)::after {
  transition: all 0.3s ease;
  content: " ";
  position: absolute;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 6px solid var(--t-neutral-bg);
  border-radius: calc(1em - 7px);
}
.text p:has(img:only-child):hover, .text p:has(img:only-child).in-center-view {
  box-shadow: 0px 0px 18px 6px rgba(0, 0, 0, 0.05);
  border: 6px solid var(--t-neutral-bg);
  transform: none;
}
.text p:has(img:only-child):hover > img, .text p:has(img:only-child).in-center-view > img {
  filter: saturate(100%);
  opacity: 100%;
}
.text p:has(img:only-child):hover::after, .text p:has(img:only-child).in-center-view::after {
  border: 6px solid var(--t-neutral-bg);
}

.text-mono, .text-mono * {
  font-family: "Inconsolata", monospace;
}

.text-sm, .text-sm * {
  font-size: calc(8px + 0.4666666667vw) !important;
}

.text-lg, .text-lg * {
  font-size: calc(16px + 0.7vw) !important;
}

.text-xlg, .text-xlg * {
  font-size: calc(16px + 1.4vw) !important;
}

.text-left {
  text-align: left !important;
}

.text-center {
  text-align: center !important;
}

.text-right {
  text-align: right !important;
}

.text-default {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.text-fade {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

.text-high-contrast {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

.text-accent {
  color: #8fb657;
  color: var(--t-accent-1);
}

.text-accent-1 {
  color: #8fb657;
  color: var(--t-accent-1);
}

.text-accent-2 {
  color: #97abd4;
  color: var(--t-accent-2);
}
.text-accent-2 a {
  color: #97abd4;
  color: var(--t-accent-2);
  background-color: var(--t-accent-2-fade);
}
.text-accent-2 a > i {
  color: #97abd4;
  color: var(--t-accent-2);
  transition: all 0.3s ease;
}
.text-accent-2 a:hover {
  color: var(--t-accent-2-fade);
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.text-accent-2 a:hover > i {
  color: var(--t-accent-2-fade);
}
.text-accent-2 button, .text-accent-2 .button {
  color: var(--t-accent-2-fade);
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.text-accent-2 button > i, .text-accent-2 .button > i {
  color: var(--t-accent-2-fade);
  transition: all 0.3s ease;
}
.text-accent-2 button:hover, .text-accent-2 .button:hover {
  color: #97abd4;
  color: var(--t-accent-2);
  background-color: var(--t-accent-2-fade);
}
.text-accent-2 button:hover > i, .text-accent-2 .button:hover > i {
  color: #97abd4;
  color: var(--t-accent-2);
}

.text-underscore {
  border-left-color: var(--t-accent-1-secondary);
  border-left-width: 0.25em;
  border-left-style: solid;
  padding-left: 0.5em;
  padding-right: 0.5em;
  padding-top: 0.25em;
  padding-bottom: 0.25em;
}

.text-trail {
  padding-left: calc((16px + 0.7vw) * 0.75);
}

@media screen and (max-width: 991px) {
  .wd-only {
    display: none !important;
  }
}

@media screen and (max-width: 600px), screen and (max-height: 500px) {
  .tn-never {
    display: none !important;
  }
}

/**
 * Primitive layout components which most (all?) pages should contain or utilize.
 *
 * None of the components in this file should require graceful degradation or
 * progressive enhancement.
 */
div {
  z-index: auto;
}

html, body {
  z-index: auto;
  width: calc(100vw - (100vw - 100%));
  height: calc(100vh - (100vh - 100%));
  margin: 0;
  padding: 0;
  margin-left: auto;
  margin-right: auto;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
}

#layout-nav {
  will-change: transform, background-color;
  transform: translateZ(0);
  -webkit-transform: translateZ(0);
  z-index: 10000;
  display: block;
  overflow: hidden;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  height: 3rem;
  line-height: 3rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  background: none;
  transition: all 0.5s ease;
  font-size: 1.5rem;
}
#layout-nav #layout-nav-logo {
  float: right;
  font-family: "Literata", serif;
  text-transform: uppercase;
  font-weight: 350;
  font-size: 1.5em;
}
#layout-nav a#layout-nav-logo {
  background: none !important;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
#layout-nav a#layout-nav-logo:hover {
  color: #8fb657;
  color: var(--t-accent-1);
}
#layout-nav ul {
  list-style-type: none;
  margin: 0;
}
#layout-nav ul li {
  float: right;
  font-family: "Literata", serif;
  text-transform: uppercase;
  font-weight: 350;
  font-size: 0.9rem;
  padding-left: 1.5rem;
}
#layout-nav ul li a {
  background: none !important;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
#layout-nav ul li a:hover {
  color: #8fb657;
  color: var(--t-accent-1);
}
#layout-nav.solid {
  background-color: var(--t-neutral-bg-glass);
  backdrop-filter: blur(5px);
}
#layout-nav.hide {
  transform: translateY(-100%);
}
#layout-nav.show {
  transform: translateY(0);
}
#layout-nav.solid.show {
  box-shadow: 0px 10px 42px 0px rgba(0, 0, 0, 0.5);
}

#layout-header {
  z-index: 7500;
  display: block;
  width: 100%;
  min-height: 100%;
  position: relative;
  box-sizing: border-box;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: 90vmin;
  background-position: center;
  overflow: hidden;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
#layout-header #layout-header-content {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 100%;
}

#layout-content {
  z-index: 5000;
  display: block;
  width: 100%;
  position: relative;
  box-sizing: border-box;
  -webkit-box-shadow: 0px 1px 10px 0px var(--t-neutral-bg);
  -moz-box-shadow: 0px 1px 10px 0px var(--t-neutral-bg);
  box-shadow: 0px 1px 10px 0px var(--t-neutral-bg);
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
#layout-content section {
  z-index: auto;
  padding-top: 3rem;
  padding-bottom: 3rem;
  position: relative;
  background-color: var(--t-neutral-bg-glassy);
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
#layout-content section.bleed {
  padding: 0 !important;
  min-height: 100vh;
}
#layout-content section:first-of-type {
  padding-top: 6rem;
}
#layout-content section:last-of-type {
  padding-bottom: 6rem;
}
#layout-content section .text {
  max-width: 39.75rem;
}
#layout-content section .background {
  z-index: -1;
  pointer-events: none;
  position: absolute;
  height: 100vh;
  width: 100%;
  top: 0;
  left: 0;
  background-position: center;
  background-size: cover;
}
#layout-content section .background.fixed {
  position: fixed;
}
#layout-content section.has-background-with-author:after {
  content: "Image by " attr(author);
  font-family: "Inconsolata", monospace;
  font-size: calc(8px + 0.4666666667vw);
  text-align: right;
  border-radius: 20px 0px 0px 0px;
  background-color: var(--t-neutral-bg-glass);
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  padding: 0.5em 0.5em 0.5em 1.5em;
  position: absolute;
  bottom: 0;
  right: 0;
}

#layout-footer {
  z-index: 7500;
  display: block;
  width: 100%;
  position: relative;
  box-sizing: border-box;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

/*
 * 4-layer type hierarchy.
 *
 * We use a variation of the 4-layer type hierarchy
 * which enforces a minimum base font size of 16px,
 * plus an additional scalar calculated from
 * the current viewport width.
 */
code, pre, *, html, body, h1, h2, h3, h4, h5, h6, p, blockquote, ul, li, .text a, .text button, .text .button {
  font-style: normal;
  margin: 0;
  text-decoration: none;
  -webkit-text-size-adjust: 100%;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
::selection, *::selection, html::selection, body::selection, h1::selection, h2::selection, h3::selection, h4::selection, h5::selection, h6::selection, p::selection, blockquote::selection, ul::selection, li::selection, .text a::selection, .text button::selection, .text .button::selection {
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}
::-moz-selection, *::-moz-selection, html::-moz-selection, body::-moz-selection, h1::-moz-selection, h2::-moz-selection, h3::-moz-selection, h4::-moz-selection, h5::-moz-selection, h6::-moz-selection, p::-moz-selection, blockquote::-moz-selection, ul::-moz-selection, li::-moz-selection, .text a::-moz-selection, .text button::-moz-selection, .text .button::-moz-selection {
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}

html, body {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
}
html strong, body strong {
  font-weight: 600;
}
html em, body em {
  font-style: italic;
}

h1, h2, h3, h4, h5, h6 {
  font-optical-sizing: none;
}

h1 {
  font-family: "Literata", serif;
  font-weight: 700;
  font-size: calc(24px + 1.05vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
}

h2 {
  font-family: "Literata", serif;
  font-weight: 500;
  font-size: calc(16px + 1.4vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
}
h2 strong {
  font-weight: 600;
}

h3, h4, h5, h6 {
  font-family: "Literata", serif;
  font-weight: 500;
  font-size: calc(16px + 1.4vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
  font-size: calc(18px + 0.525vw);
}
h3 strong, h4 strong, h5 strong, h6 strong {
  font-weight: 600;
}

h3 {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

p, blockquote, ul, li {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
}
p strong, blockquote strong, ul strong, li strong {
  font-weight: 600;
}
p em, blockquote em, ul em, li em {
  font-style: italic;
}

.text a {
  transition: all 0.3s ease;
  padding: 0 0.25em;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  white-space: nowrap;
}
.text a:hover {
  color: var(--t-accent-1-fade);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  outline: none !important;
}
.text a:active {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background: none;
}

.text button, .text .button {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0.25em;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
  color: var(--t-accent-1-fade);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  white-space: nowrap;
}
.text button strong, .text .button strong {
  font-weight: 600;
}
.text button em, .text .button em {
  font-style: italic;
}
.text button:hover, .text .button:hover {
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  outline: none !important;
}
.text button:active, .text .button:active {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background: none;
}

.text {
  box-sizing: border-box;
  padding: 1.4rem;
}
.text * {
  line-height: 1.45em;
}
.text > h2 {
  margin-top: 2.8rem;
  scroll-margin-top: 1.4rem;
}
.text > h1 + h1, .text > h1 + h2, .text > h1 + h3, .text > h1 + h4, .text > h1 + h5, .text > h1 + h6, .text > h2 + h1, .text > h2 + h2, .text > h2 + h3, .text > h2 + h4, .text > h2 + h5, .text > h2 + h6, .text > h3 + h1, .text > h3 + h2, .text > h3 + h3, .text > h3 + h4, .text > h3 + h5, .text > h3 + h6, .text > h4 + h1, .text > h4 + h2, .text > h4 + h3, .text > h4 + h4, .text > h4 + h5, .text > h4 + h6, .text > h5 + h1, .text > h5 + h2, .text > h5 + h3, .text > h5 + h4, .text > h5 + h5, .text > h5 + h6, .text > h6 + h1, .text > h6 + h2, .text > h6 + h3, .text > h6 + h4, .text > h6 + h5, .text > h6 + h6 {
  padding-top: 0.1rem;
}
.text > h1 + p, .text > h2 + p, .text > h3 + p, .text > h4 + p, .text > h5 + p, .text > h6 + p {
  padding-top: 1rem;
}
.text > h1 + blockquote, .text > h1 + pre, .text > h2 + blockquote, .text > h2 + pre, .text > h3 + blockquote, .text > h3 + pre, .text > h4 + blockquote, .text > h4 + pre, .text > h5 + blockquote, .text > h5 + pre, .text > h6 + blockquote, .text > h6 + pre {
  margin-top: 1rem;
}
.text hr {
  border: none;
  color: var(--t-neutral-fg-glass);
  backdrop-filter: blur(1px);
  font-family: "Inconsolata", monospace;
  font-weight: 600;
  font-variant-ligatures: normal;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
  margin-top: 1.4rem;
  margin-bottom: 2.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  align-content: space-between;
  flex-direction: row;
}
.text hr::after {
  content: " ";
  transition: all 0.3s ease;
  animation: hr-blink 2s infinite;
  font-family: "Inconsolata", monospace;
  font-size: calc(16px + 0.175vw);
  text-align: left;
  text-wrap-mode: nowrap;
  padding: 0px;
  margin-left: 0.5em;
  background: var(--t-accent-1-glass);
  flex: 0;
  border-radius: 7px 7px 7px 7px;
}
@keyframes hr-blink {
  50% {
    opacity: 0%;
  }
}
.text hr::before {
  content: " ";
  font-family: "Inconsolata", monospace;
  font-size: calc(16px + 0.175vw);
  text-align: right;
  text-wrap-mode: nowrap;
  padding-right: 0.5em;
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background: #ebe4d3;
  background: var(--t-neutral-bg-more);
  flex: 1;
  border-radius: 7px 7px 7px 7px;
}
.text ul, .text ol {
  padding-left: 2.5rem;
}
.text ul:not(:last-child), .text ol:not(:last-child) {
  margin-bottom: 1rem;
}
.text ul li:not(:last-child), .text ol li:not(:last-child) {
  margin-bottom: 1rem;
}
.text ul li:last-child, .text ol li:last-child {
  margin-bottom: 1rem;
}
.text p:not(:last-child), .text blockquote:not(:last-child), .text pre:not(:last-child) {
  margin-bottom: 1rem;
}
.text strong, .text p strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text em {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text blockquote {
  border-left: 4px solid var(--t-neutral-fg-glass);
  margin: 0;
  padding-left: 1.5rem;
}
.text blockquote, .text blockquote > * {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text blockquote strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text blockquote em {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.text blockquote > ul, .text blockquote > ol {
  padding-left: 1rem;
}
.text blockquote > ul > li, .text blockquote > ol > li {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text details {
  transition: all 0.3s ease;
  background-color: var(--t-neutral-bg-glaze);
  backdrop-filter: blur(1px);
  box-shadow: 0px 0px 18px 6px rgba(0, 0, 0, 0.2);
  border: 6px solid var(--t-neutral-bg-more);
  border-radius: 7px 7px 20px 7px;
  padding-left: 1.4rem;
  padding-right: 1.4rem;
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
}
.text details:hover, .text details[open] {
  border: 6px solid var(--t-accent-1);
}
.text details[open] {
  padding-bottom: 1.4rem;
}
.text details[open] > summary {
  margin-bottom: 1rem;
}
.text details > summary {
  color: #8fb657;
  color: var(--t-accent-1);
  cursor: pointer;
  font-style: italic;
}
.text details > summary::-webkit-details-marker, .text details > summary::marker {
  color: #8fb657;
  color: var(--t-accent-1);
}
.text details, .text details > * {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text details strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text details em {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.text details > ul, .text details > ol {
  padding-left: 1rem;
}
.text details > ul > li, .text details > ol > li {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text p:has(img:only-child) {
  transition: all 0.3s ease;
  display: flex;
  padding: 0.25em;
  overflow: hidden;
  height: auto;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
  backdrop-filter: blur(1px);
  border: 6px solid var(--t-neutral-bg);
  border-radius: 1em;
}
.text p:has(img:only-child):nth-of-type(even) {
  transform: rotate(-1deg) scale(95%);
}
.text p:has(img:only-child):nth-of-type(odd) {
  transform: rotate(1deg) scale(95%);
}
.text p:has(img:only-child) > img {
  transition: all 0.3s ease;
  filter: saturate(25%);
  opacity: 75%;
  object-fit: cover;
  width: 100%;
  flex: 1;
}
.text p:has(img:only-child)::after {
  transition: all 0.3s ease;
  content: " ";
  position: absolute;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 6px solid var(--t-neutral-bg);
  border-radius: calc(1em - 7px);
}
.text p:has(img:only-child):hover, .text p:has(img:only-child).in-center-view {
  box-shadow: 0px 0px 18px 6px rgba(0, 0, 0, 0.05);
  border: 6px solid var(--t-neutral-bg);
  transform: none;
}
.text p:has(img:only-child):hover > img, .text p:has(img:only-child).in-center-view > img {
  filter: saturate(100%);
  opacity: 100%;
}
.text p:has(img:only-child):hover::after, .text p:has(img:only-child).in-center-view::after {
  border: 6px solid var(--t-neutral-bg);
}

.text-mono, .text-mono * {
  font-family: "Inconsolata", monospace;
}

.text-sm, .text-sm * {
  font-size: calc(8px + 0.4666666667vw) !important;
}

.text-lg, .text-lg * {
  font-size: calc(16px + 0.7vw) !important;
}

.text-xlg, .text-xlg * {
  font-size: calc(16px + 1.4vw) !important;
}

.text-left {
  text-align: left !important;
}

.text-center {
  text-align: center !important;
}

.text-right {
  text-align: right !important;
}

.text-default {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.text-fade {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

.text-high-contrast {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

.text-accent {
  color: #8fb657;
  color: var(--t-accent-1);
}

.text-accent-1 {
  color: #8fb657;
  color: var(--t-accent-1);
}

.text-accent-2 {
  color: #97abd4;
  color: var(--t-accent-2);
}
.text-accent-2 a {
  color: #97abd4;
  color: var(--t-accent-2);
  background-color: var(--t-accent-2-fade);
}
.text-accent-2 a > i {
  color: #97abd4;
  color: var(--t-accent-2);
  transition: all 0.3s ease;
}
.text-accent-2 a:hover {
  color: var(--t-accent-2-fade);
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.text-accent-2 a:hover > i {
  color: var(--t-accent-2-fade);
}
.text-accent-2 button, .text-accent-2 .button {
  color: var(--t-accent-2-fade);
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.text-accent-2 button > i, .text-accent-2 .button > i {
  color: var(--t-accent-2-fade);
  transition: all 0.3s ease;
}
.text-accent-2 button:hover, .text-accent-2 .button:hover {
  color: #97abd4;
  color: var(--t-accent-2);
  background-color: var(--t-accent-2-fade);
}
.text-accent-2 button:hover > i, .text-accent-2 .button:hover > i {
  color: #97abd4;
  color: var(--t-accent-2);
}

.text-underscore {
  border-left-color: var(--t-accent-1-secondary);
  border-left-width: 0.25em;
  border-left-style: solid;
  padding-left: 0.5em;
  padding-right: 0.5em;
  padding-top: 0.25em;
  padding-bottom: 0.25em;
}

.text-trail {
  padding-left: calc((16px + 0.7vw) * 0.75);
}

/**
 * Typography coloring rules for all type, including code.
 */
/*
 * 4-layer type hierarchy.
 *
 * We use a variation of the 4-layer type hierarchy
 * which enforces a minimum base font size of 16px,
 * plus an additional scalar calculated from
 * the current viewport width.
 */
code, pre, *, html, body, h1, h2, h3, h4, h5, h6, p, blockquote, ul, li, .text a, .text button, .text .button {
  font-style: normal;
  margin: 0;
  text-decoration: none;
  -webkit-text-size-adjust: 100%;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
::selection, *::selection, html::selection, body::selection, h1::selection, h2::selection, h3::selection, h4::selection, h5::selection, h6::selection, p::selection, blockquote::selection, ul::selection, li::selection, .text a::selection, .text button::selection, .text .button::selection {
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}
::-moz-selection, *::-moz-selection, html::-moz-selection, body::-moz-selection, h1::-moz-selection, h2::-moz-selection, h3::-moz-selection, h4::-moz-selection, h5::-moz-selection, h6::-moz-selection, p::-moz-selection, blockquote::-moz-selection, ul::-moz-selection, li::-moz-selection, .text a::-moz-selection, .text button::-moz-selection, .text .button::-moz-selection {
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}

html, body {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
}
html strong, body strong {
  font-weight: 600;
}
html em, body em {
  font-style: italic;
}

h1, h2, h3, h4, h5, h6 {
  font-optical-sizing: none;
}

h1 {
  font-family: "Literata", serif;
  font-weight: 700;
  font-size: calc(24px + 1.05vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
}

h2 {
  font-family: "Literata", serif;
  font-weight: 500;
  font-size: calc(16px + 1.4vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
}
h2 strong {
  font-weight: 600;
}

h3, h4, h5, h6 {
  font-family: "Literata", serif;
  font-weight: 500;
  font-size: calc(16px + 1.4vw);
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-weight: 600;
  font-size: calc(18px + 0.525vw);
}
h3 strong, h4 strong, h5 strong, h6 strong {
  font-weight: 600;
}

h3 {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

p, blockquote, ul, li {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
}
p strong, blockquote strong, ul strong, li strong {
  font-weight: 600;
}
p em, blockquote em, ul em, li em {
  font-style: italic;
}

.text a {
  transition: all 0.3s ease;
  padding: 0 0.25em;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  white-space: nowrap;
}
.text a:hover {
  color: var(--t-accent-1-fade);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  outline: none !important;
}
.text a:active {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background: none;
}

.text button, .text .button {
  font-family: "Literata", serif;
  font-weight: 350;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0.25em;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
  color: var(--t-accent-1-fade);
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  white-space: nowrap;
}
.text button strong, .text .button strong {
  font-weight: 600;
}
.text button em, .text .button em {
  font-style: italic;
}
.text button:hover, .text .button:hover {
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  outline: none !important;
}
.text button:active, .text .button:active {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background: none;
}

.text {
  box-sizing: border-box;
  padding: 1.4rem;
}
.text * {
  line-height: 1.45em;
}
.text > h2 {
  margin-top: 2.8rem;
  scroll-margin-top: 1.4rem;
}
.text > h1 + h1, .text > h1 + h2, .text > h1 + h3, .text > h1 + h4, .text > h1 + h5, .text > h1 + h6, .text > h2 + h1, .text > h2 + h2, .text > h2 + h3, .text > h2 + h4, .text > h2 + h5, .text > h2 + h6, .text > h3 + h1, .text > h3 + h2, .text > h3 + h3, .text > h3 + h4, .text > h3 + h5, .text > h3 + h6, .text > h4 + h1, .text > h4 + h2, .text > h4 + h3, .text > h4 + h4, .text > h4 + h5, .text > h4 + h6, .text > h5 + h1, .text > h5 + h2, .text > h5 + h3, .text > h5 + h4, .text > h5 + h5, .text > h5 + h6, .text > h6 + h1, .text > h6 + h2, .text > h6 + h3, .text > h6 + h4, .text > h6 + h5, .text > h6 + h6 {
  padding-top: 0.1rem;
}
.text > h1 + p, .text > h2 + p, .text > h3 + p, .text > h4 + p, .text > h5 + p, .text > h6 + p {
  padding-top: 1rem;
}
.text > h1 + blockquote, .text > h1 + pre, .text > h2 + blockquote, .text > h2 + pre, .text > h3 + blockquote, .text > h3 + pre, .text > h4 + blockquote, .text > h4 + pre, .text > h5 + blockquote, .text > h5 + pre, .text > h6 + blockquote, .text > h6 + pre {
  margin-top: 1rem;
}
.text hr {
  border: none;
  color: var(--t-neutral-fg-glass);
  backdrop-filter: blur(1px);
  font-family: "Inconsolata", monospace;
  font-weight: 600;
  font-variant-ligatures: normal;
  font-style: normal;
  font-size: calc(16px + 0.175vw);
  margin-top: 1.4rem;
  margin-bottom: 2.8rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  align-content: space-between;
  flex-direction: row;
}
.text hr::after {
  content: " ";
  transition: all 0.3s ease;
  animation: hr-blink 2s infinite;
  font-family: "Inconsolata", monospace;
  font-size: calc(16px + 0.175vw);
  text-align: left;
  text-wrap-mode: nowrap;
  padding: 0px;
  margin-left: 0.5em;
  background: var(--t-accent-1-glass);
  flex: 0;
  border-radius: 7px 7px 7px 7px;
}
@keyframes hr-blink {
  50% {
    opacity: 0%;
  }
}
.text hr::before {
  content: " ";
  font-family: "Inconsolata", monospace;
  font-size: calc(16px + 0.175vw);
  text-align: right;
  text-wrap-mode: nowrap;
  padding-right: 0.5em;
  color: #faf5e6;
  color: var(--t-neutral-bg);
  background: #ebe4d3;
  background: var(--t-neutral-bg-more);
  flex: 1;
  border-radius: 7px 7px 7px 7px;
}
.text ul, .text ol {
  padding-left: 2.5rem;
}
.text ul:not(:last-child), .text ol:not(:last-child) {
  margin-bottom: 1rem;
}
.text ul li:not(:last-child), .text ol li:not(:last-child) {
  margin-bottom: 1rem;
}
.text ul li:last-child, .text ol li:last-child {
  margin-bottom: 1rem;
}
.text p:not(:last-child), .text blockquote:not(:last-child), .text pre:not(:last-child) {
  margin-bottom: 1rem;
}
.text strong, .text p strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text em {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text blockquote {
  border-left: 4px solid var(--t-neutral-fg-glass);
  margin: 0;
  padding-left: 1.5rem;
}
.text blockquote, .text blockquote > * {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text blockquote strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text blockquote em {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.text blockquote > ul, .text blockquote > ol {
  padding-left: 1rem;
}
.text blockquote > ul > li, .text blockquote > ol > li {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text details {
  transition: all 0.3s ease;
  background-color: var(--t-neutral-bg-glaze);
  backdrop-filter: blur(1px);
  box-shadow: 0px 0px 18px 6px rgba(0, 0, 0, 0.2);
  border: 6px solid var(--t-neutral-bg-more);
  border-radius: 7px 7px 20px 7px;
  padding-left: 1.4rem;
  padding-right: 1.4rem;
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
}
.text details:hover, .text details[open] {
  border: 6px solid var(--t-accent-1);
}
.text details[open] {
  padding-bottom: 1.4rem;
}
.text details[open] > summary {
  margin-bottom: 1rem;
}
.text details > summary {
  color: #8fb657;
  color: var(--t-accent-1);
  cursor: pointer;
  font-style: italic;
}
.text details > summary::-webkit-details-marker, .text details > summary::marker {
  color: #8fb657;
  color: var(--t-accent-1);
}
.text details, .text details > * {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text details strong {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.text details em {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.text details > ul, .text details > ol {
  padding-left: 1rem;
}
.text details > ul > li, .text details > ol > li {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.text p:has(img:only-child) {
  transition: all 0.3s ease;
  display: flex;
  padding: 0.25em;
  overflow: hidden;
  height: auto;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
  backdrop-filter: blur(1px);
  border: 6px solid var(--t-neutral-bg);
  border-radius: 1em;
}
.text p:has(img:only-child):nth-of-type(even) {
  transform: rotate(-1deg) scale(95%);
}
.text p:has(img:only-child):nth-of-type(odd) {
  transform: rotate(1deg) scale(95%);
}
.text p:has(img:only-child) > img {
  transition: all 0.3s ease;
  filter: saturate(25%);
  opacity: 75%;
  object-fit: cover;
  width: 100%;
  flex: 1;
}
.text p:has(img:only-child)::after {
  transition: all 0.3s ease;
  content: " ";
  position: absolute;
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 6px solid var(--t-neutral-bg);
  border-radius: calc(1em - 7px);
}
.text p:has(img:only-child):hover, .text p:has(img:only-child).in-center-view {
  box-shadow: 0px 0px 18px 6px rgba(0, 0, 0, 0.05);
  border: 6px solid var(--t-neutral-bg);
  transform: none;
}
.text p:has(img:only-child):hover > img, .text p:has(img:only-child).in-center-view > img {
  filter: saturate(100%);
  opacity: 100%;
}
.text p:has(img:only-child):hover::after, .text p:has(img:only-child).in-center-view::after {
  border: 6px solid var(--t-neutral-bg);
}

.text-mono, .text-mono * {
  font-family: "Inconsolata", monospace;
}

.text-sm, .text-sm * {
  font-size: calc(8px + 0.4666666667vw) !important;
}

.text-lg, .text-lg * {
  font-size: calc(16px + 0.7vw) !important;
}

.text-xlg, .text-xlg * {
  font-size: calc(16px + 1.4vw) !important;
}

.text-left {
  text-align: left !important;
}

.text-center {
  text-align: center !important;
}

.text-right {
  text-align: right !important;
}

.text-default {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.text-fade {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

.text-high-contrast {
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

.text-accent {
  color: #8fb657;
  color: var(--t-accent-1);
}

.text-accent-1 {
  color: #8fb657;
  color: var(--t-accent-1);
}

.text-accent-2 {
  color: #97abd4;
  color: var(--t-accent-2);
}
.text-accent-2 a {
  color: #97abd4;
  color: var(--t-accent-2);
  background-color: var(--t-accent-2-fade);
}
.text-accent-2 a > i {
  color: #97abd4;
  color: var(--t-accent-2);
  transition: all 0.3s ease;
}
.text-accent-2 a:hover {
  color: var(--t-accent-2-fade);
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.text-accent-2 a:hover > i {
  color: var(--t-accent-2-fade);
}
.text-accent-2 button, .text-accent-2 .button {
  color: var(--t-accent-2-fade);
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.text-accent-2 button > i, .text-accent-2 .button > i {
  color: var(--t-accent-2-fade);
  transition: all 0.3s ease;
}
.text-accent-2 button:hover, .text-accent-2 .button:hover {
  color: #97abd4;
  color: var(--t-accent-2);
  background-color: var(--t-accent-2-fade);
}
.text-accent-2 button:hover > i, .text-accent-2 .button:hover > i {
  color: #97abd4;
  color: var(--t-accent-2);
}

.text-underscore {
  border-left-color: var(--t-accent-1-secondary);
  border-left-width: 0.25em;
  border-left-style: solid;
  padding-left: 0.5em;
  padding-right: 0.5em;
  padding-top: 0.25em;
  padding-bottom: 0.25em;
}

.text-trail {
  padding-left: calc((16px + 0.7vw) * 0.75);
}

@media screen and (max-width: 991px) {
  .wd-only {
    display: none !important;
  }
}

@media screen and (max-width: 600px), screen and (max-height: 500px) {
  .tn-never {
    display: none !important;
  }
}

pre {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  background-color: var(--t-neutral-bg-more-glass);
  backdrop-filter: blur(5px);
  border: none;
  border-radius: 7px 20px 7px 20px;
}
pre:has(> code.language-markdown) {
  justify-content: center;
}
pre:after {
  pointer-events: none;
  content: attr(rel);
  font-family: "Inconsolata", monospace;
  font-size: calc(8px + 0.4666666667vw);
  text-align: right;
  padding: 0.2rem 2rem;
  color: #4d4b45;
  color: var(--t-neutral-fg);
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 0px 0px 7px 20px;
}

code {
  color: inherit;
  font-family: "Inconsolata", monospace !important;
  font-weight: 350;
  font-variant-ligatures: normal;
  font-style: normal;
  font-size: calc(10.6666666667px + 0.4666666667vw);
  white-space: pre-wrap;
  display: inline;
  padding-bottom: 0;
  padding-top: 0;
  padding-left: 0.25em;
  padding-right: 0.25em;
  padding: 0.1em 0.25em;
  border: none;
  border-radius: 0.25em 0.25em 0.25em 0.25em;
}
.text p > code, .text h1 > code, .text h2 > code, .text h3 > code, .text h4 > code, .text h5 > code, .text h6 > code {
  color: #4d4b45;
  color: var(--t-neutral-fg);
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
}

pre > code {
  color: #4d4b45;
  color: var(--t-neutral-fg);
  background-color: none;
  display: block;
  overflow-x: auto;
  overflow-y: auto;
  padding-bottom: 2.4rem;
  padding-top: 1rem;
  padding-left: 1rem;
  padding-right: 1rem;
  border-radius: 7px 20px 7px 20px;
}
pre > code.language-markdown {
  font-size: calc(8px + 0.4666666667vw);
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  white-space: pre-line;
}
pre > code.code-lg {
  font-size: calc(16px + 0.175vw) !important;
}

.hljs-comment,
.hljs-quote {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

.hljs-addition,
.hljs-selector-tag {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hljs-params {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hljs-keyword {
  color: var(--t-accent-5-secondary);
}

.hljs-doctag,
.hljs-literal,
.hljs-meta .hljs-meta-string,
.hljs-regexp,
.hljs-string {
  color: var(--t-accent-4-secondary);
}

.hljs-number {
  color: var(--t-accent-6-secondary);
}

.hljs-name,
.hljs-section,
.hljs-selector-class,
.hljs-selector-id {
  color: var(--t-accent-3-secondary);
}

.hljs-title {
  color: var(--t-accent-1-secondary);
}

.hljs-attr,
.hljs-attribute,
.hljs-class .hljs-title,
.hljs-template-variable,
.hljs-type,
.hljs-variable {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hljs-bullet {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hljs-link,
.hljs-meta,
.hljs-meta .hljs-keyword,
.hljs-selector-attr,
.hljs-selector-pseudo,
.hljs-subst,
.hljs-symbol {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hljs-built_in,
.hljs-deletion {
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hljs-formula {
  background: #4d4b45;
  background: var(--t-neutral-fg);
}

.hljs-emphasis {
  font-style: italic;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

.hljs-strong {
  font-weight: 700;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

html {
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
}

.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4.2rem 1.4rem;
  overflow: hidden;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 42rem;
  text-align: center;
}
.hero-content h1 {
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-size: calc(48px + 1.4vw);
  font-weight: 600;
  letter-spacing: 0.08em;
  margin: 0 0 1rem;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

.hero-tagline {
  font-family: "Literata", serif;
  font-size: calc(24px + 1.05vw);
  font-weight: 350;
  line-height: 1.35;
  margin: 0 0 1.5rem;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.hero-desc {
  font-family: "Literata", serif;
  font-size: calc(16px + 0.175vw);
  font-weight: 350;
  line-height: 1.55;
  max-width: 34rem;
  margin: 0 auto 2.5rem;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

.hero-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.hero-decoration {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  user-select: none;
  opacity: 0.1;
  padding: 2.8rem;
}
.hero-decoration pre {
  font-family: "Inconsolata", monospace;
  font-size: calc(12px + 0.7vw);
  line-height: 1.5;
  white-space: pre;
  margin: 0;
  background: none;
  border: none;
  box-shadow: none;
}
.hero-decoration pre code {
  background: none;
  padding: 0;
  font-size: inherit;
}

.btn-primary,
.btn-secondary {
  display: inline-block;
  font-family: "Literata", serif;
  font-size: calc(16px + 0.175vw);
  font-weight: 500;
  padding: 0.7em 1.8em;
  border-radius: 7px 20px 7px 20px;
  text-decoration: none;
  transition: all 0.25s ease;
  cursor: pointer;
}

.btn-primary {
  background-color: #8fb657;
  background-color: var(--t-accent-1);
  color: #faf5e6;
  color: var(--t-neutral-bg);
}
.btn-primary:hover {
  background-color: var(--t-accent-1-secondary);
  transform: translateY(-1px);
}

.btn-secondary {
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
}
.btn-secondary:hover {
  background-color: var(--t-accent-1-tertiary);
  transform: translateY(-1px);
}

.why-codas {
  padding: 5.6rem 1.4rem;
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
}

.why-codas-inner {
  max-width: 64rem;
  margin: 0 auto;
  text-align: center;
}
.why-codas-inner > h2 {
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-size: calc(24px + 1.4vw);
  font-weight: 600;
  margin: 0 0 0.8rem;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}

.why-codas-lead {
  font-family: "Literata", serif;
  font-size: calc(16px + 0.175vw);
  font-weight: 350;
  line-height: 1.55;
  max-width: 32rem;
  margin: 0 auto 2.8rem;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.why-codas-lead a {
  color: #8fb657;
  color: var(--t-accent-1);
  text-decoration: none;
}
.why-codas-lead a:hover {
  text-decoration: underline;
}

.why-codas-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.4rem;
  text-align: left;
}
@media screen and (max-width: 991px) {
  .why-codas-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 600px), screen and (max-height: 500px) {
  .why-codas-grid {
    grid-template-columns: 1fr;
  }
}

.why-card {
  position: relative;
  padding: 1.68rem;
  padding-top: 2.1rem;
  border-radius: 7px 20px 7px 20px;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
}
.why-card .card-accent {
  position: absolute;
  top: 1.12rem;
  left: 1.68rem;
  width: 2.2rem;
  height: 3px;
  border-radius: 2px;
}
.why-card .card-accent.accent-1 {
  background-color: #8fb657;
  background-color: var(--t-accent-1);
}
.why-card .card-accent.accent-2 {
  background-color: #97abd4;
  background-color: var(--t-accent-2);
}
.why-card .card-accent.accent-3 {
  background-color: #ef9275;
  background-color: var(--t-accent-3);
}
.why-card h4 {
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-size: calc(16px + 0.175vw);
  font-weight: 600;
  margin: 0 0 0.3rem;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.why-card p {
  font-family: "Literata", serif;
  font-size: calc(10.6666666667px + 0.4666666667vw);
  font-weight: 350;
  line-height: 1.5;
  margin: 0;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.why-card p a {
  color: #8fb657;
  color: var(--t-accent-1);
  text-decoration: none;
}
.why-card p a:hover {
  text-decoration: underline;
}

.playground {
  padding: 4.2rem 1.4rem 5.6rem;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
}

.playground-inner {
  max-width: 72rem;
  margin: 0 auto;
}

.playground-header {
  text-align: center;
  margin-bottom: 2.8rem;
}
.playground-header h2 {
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-size: calc(24px + 1.4vw);
  font-weight: 600;
  margin: 0 0 0.6rem;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.playground-header p {
  font-family: "Literata", serif;
  font-size: calc(16px + 0.175vw);
  font-weight: 350;
  line-height: 1.5;
  margin: 0 auto;
  max-width: 36rem;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

@media screen and (min-width: 992px) {
  .editors {
    display: grid;
    grid-template-columns: 2fr 3fr;
    align-items: start;
    gap: 1.4rem;
  }
}
@media screen and (max-width: 991px) {
  .editors {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
  }
}

@media screen and (min-width: 992px) {
  .editor-panel.editor-input {
    position: sticky;
    top: 1.4rem;
  }
}

.editor-panel {
  display: flex;
  flex-direction: column;
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
  border-radius: 7px 20px 7px 20px;
  overflow: hidden;
  min-height: 24rem;
}
.editor-panel > header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 1.4rem;
  border-bottom-color: #faf5e6;
  border-bottom-color: var(--t-neutral-bg);
  border-bottom-width: 2px;
  border-bottom-style: solid;
}
.editor-panel > header h3 {
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-size: calc(10.6666666667px + 0.4666666667vw);
  font-weight: 600;
  margin: 0;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}
.editor-panel [id$="-editor"] {
  flex: 1;
  padding: 1.4rem;
  font-family: "Inconsolata", monospace;
  font-size: calc(8px + 0.4666666667vw);
  line-height: 1.6;
  color: #4d4b45;
  color: var(--t-neutral-fg);
}

.editor-lang {
  font-family: "Inconsolata", monospace;
  font-size: calc(8px + 0.4666666667vw);
  padding: 0.15em 0.6em;
  border-radius: 3px;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
}

.editor-panel > header menu {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 0;
  border-radius: 6px;
  overflow: hidden;
  background-color: #faf5e6;
  background-color: var(--t-neutral-bg);
}
.editor-panel > header menu li {
  padding: 0.3em 0.75em;
  cursor: pointer;
  font-family: "Inconsolata", monospace;
  font-size: calc(8px + 0.4666666667vw);
  transition: all 0.2s ease;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  position: relative;
}
.editor-panel > header menu li:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 25%;
  height: 50%;
  width: 1px;
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
  transition: opacity 0.2s ease;
}
.editor-panel > header menu li:hover {
  color: #4d4b45;
  color: var(--t-neutral-fg);
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
}
.editor-panel > header menu li.selected {
  color: #8fb657;
  color: var(--t-accent-1);
  background-color: var(--t-accent-1-fade);
  font-weight: 500;
}
.editor-panel > header menu li.selected::after {
  opacity: 0;
}
.editor-panel > header menu li.selected + li::after, .editor-panel > header menu li:has(+ .selected)::after {
  opacity: 0;
}

.get-started {
  padding: 5.6rem 1.4rem;
  background-color: #ebe4d3;
  background-color: var(--t-neutral-bg-more);
}

.get-started-inner {
  max-width: 36rem;
  margin: 0 auto;
  text-align: center;
}
.get-started-inner h2 {
  font-family: "Literata", serif, "Comic Relief", "Comic Sans MS", "Comic Sans", "Chalkboard SE";
  font-size: calc(24px + 1.4vw);
  font-weight: 600;
  margin: 0 0 0.5rem;
  color: #21201d;
  color: var(--t-neutral-fg-more);
}
.get-started-inner p {
  font-family: "Literata", serif;
  font-size: calc(16px + 0.175vw);
  font-weight: 350;
  margin: 0 0 2rem;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}

.cta-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.site-footer {
  padding: 2.8rem 1.4rem;
  text-align: center;
}
.site-footer p {
  font-family: "Literata", serif;
  font-size: calc(10.6666666667px + 0.4666666667vw);
  font-weight: 350;
  margin: 0;
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
}
.site-footer p a {
  color: #7d7a70;
  color: var(--t-neutral-fg-less);
  text-decoration: none;
}
.site-footer p a:hover {
  color: #8fb657;
  color: var(--t-accent-1);
}

.github-corner svg {
  position: fixed;
  right: 0;
  top: 0;
  z-index: 100;
}
.github-corner svg .octo-bg {
  fill: #4d4b45;
  fill: var(--t-neutral-fg);
}
.github-corner svg .octo-arm,
.github-corner svg .octo-body {
  fill: #faf5e6;
  fill: var(--t-neutral-bg);
}

.github-corner:hover .octo-arm {
  animation: octocat-wave 0.56s;
}

@keyframes octocat-wave {
  0%, 100% {
    transform: rotate(0);
  }
  20%, 60% {
    transform: rotate(-20deg);
  }
  40%, 80% {
    transform: rotate(10deg);
  }
}
