@charset "UTF-8";
/* resources index */
@font-face {
  font-family: "Instrument Sans";
  font-display: swap;
  src: url("/_assets/fonts/Instrument_Sans/InstrumentSans-VariableFont_wdth-wght.woff2") format("woff2"), url("/_assets/fonts/Instrument_Sans/InstrumentSans.woff") format("woff"), url("/_assets/fonts/Instrument_Sans/InstrumentSans-VariableFont_wdth-wght.ttf") format("truetype");
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
:root {
  --links-hover-bg: white;
  --light-font: rgb(63, 48, 48);
  --light-bg: rgb(232, 221, 235);
  --light-bg-article: ghostwhite;
  --light-links: rgb(88, 24, 56);
  --light-links-hover: rgb(140, 42, 221);
  --dark-font: white;
  --dark-bg: black;
  --dark-links: rgb(255, 166, 181);
  --dark-links-hover: rgb(255, 234, 176);
}

* {
  scrollbar-width: thin;
  scrollbar-color: rgb(184, 140, 184) transparent;
  scrollbar-width: thin;
}

html {
  text-rendering: optimizeLegibility;
}

body {
  color: white;
  background-color: rgb(46, 41, 48);
  font-family: "Instrument Sans", sans-serif;
  font-weight: 450;
}

a {
  color: plum;
}

dl {
  margin-right: 1em;
  display: grid;
  row-gap: 1em;
  margin-left: 2em;
}

dt {
  font-weight: bolder;
  grid-column: 1;
}

dd:not(:last-child) {
  grid-column: 2/5;
  margin-left: 0;
  padding-left: 0.5em;
}
dd ul {
  padding-left: 0;
}
dd p:first-child {
  margin-top: 0;
}
dd dl {
  grid-template-columns: 2fr 5fr;
}
dd dl dd {
  grid-column: 2 !important;
  margin-left: 0 !important;
  padding-left: 0.5em !important;
}

dt:not(:last-child, :last-of-type), dd:not(:last-child, :last-of-type) {
  border-bottom: 1px solid rgba(128, 128, 128, 0.575);
}
dt:last-child, dd:last-child {
  grid-column: span 4;
}

ul dl {
  grid-auto-flow: column;
  grid-template-columns: 2fr 5fr;
}
ul dt, ul dd {
  border-bottom: 1px solid rgba(128, 128, 128, 0.575);
}
ul dd {
  margin-left: 0;
}

footer {
  margin: 3em auto;
  text-align: center;
  font-size: 1em;
  display: flex;
  flex-direction: column;
  row-gap: 1em;
}
footer ul {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin: 0 auto;
  padding-left: 0;
  list-style: none;
  justify-content: center;
  align-items: center;
  row-gap: 1em;
}
footer ul:last-of-type {
  -moz-column-gap: 1em;
       column-gap: 1em;
}
footer li:not(ul:last-of-type li)::before {
  content: "⬩";
  font-size: 1.25em;
  margin: 0 1em;
}
footer li:not(ul:last-of-type li):first-of-type::before {
  content: none;
}
footer a img {
  text-decoration: none;
}

::-moz-selection {
  background-color: rgb(248, 208, 170);
  color: black;
}

::selection {
  background-color: rgb(248, 208, 170);
  color: black;
}

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-thumb {
  background-color: rgb(164, 118, 170);
  border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
  background-color: plum;
}

body {
  font-size: 1.1em;
  margin: auto;
  width: 90%;
  max-width: 1300px;
  margin-top: 5%;
  display: flex;
  flex-direction: row-reverse;
}

header {
  display: flex;
  flex-direction: column;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin-left: 5%;
  align-self: flex-start;
  position: sticky;
  top: 2em;
}
header h1 {
  font-size: 1.75em;
  letter-spacing: 0.05em;
}
header time {
  font-weight: 600;
  display: block;
}
header nav {
  border-top: 1px solid;
  border-bottom: 1px solid;
  letter-spacing: 0.1em;
  padding: 0.25em;
}
header nav ul {
  margin-top: 0.25em;
  margin-bottom: 0.25em;
  padding: 0.7em;
}
header nav li {
  display: flex;
  margin-bottom: 0.5em;
}
header nav li::before {
  content: "✧";
  margin-right: 0.5em;
}
header nav a {
  text-decoration: none;
  padding: 0px 5px 3px 5px;
}
header #resources a {
  -webkit-text-decoration: wavy underline 1px;
          text-decoration: wavy underline 1px;
  text-underline-offset: 0.25em;
}

#themeSwitch {
  padding: 0.5em;
  margin-bottom: 1em;
  width: -moz-fit-content;
  width: fit-content;
  order: -1;
}

#left-col-group {
  display: flex;
  flex-direction: row;
}

#legend {
  padding: 1em 2em;
  margin-bottom: 1em;
  border: 2px dashed rgb(141, 102, 141);
}
#legend h2 {
  font-size: 1.2em;
  margin-bottom: 1.5em;
  text-transform: uppercase;
  -webkit-text-decoration: 1.5px wavy underline rgb(167, 121, 168);
          text-decoration: 1.5px wavy underline rgb(167, 121, 168);
  text-underline-offset: 0.5em;
  letter-spacing: 0.2em;
}
#legend li p {
  font-size: 1em;
}

#guide {
  margin-right: 5%;
  margin-bottom: 5% !important;
  max-width: -moz-fit-content;
  max-width: fit-content;
}
#guide h2 {
  background-color: transparent !important;
  padding-left: 0 !important;
  padding-bottom: 0 !important;
}
#guide ol, #guide ul {
  padding-left: 1em;
}
#guide li {
  padding-left: 0;
  margin-left: 0;
  margin-bottom: 1em;
}
#guide li:first-child {
  margin-top: 1em;
}

main {
  line-height: 1.6em;
  letter-spacing: 0.01em;
}
main h2:not(#legend h2) {
  background-color: rgba(110, 60, 139, 0.233);
  padding: 1em;
  margin-top: 0;
}
main h2:not(#legend h2):nth-of-type(2n) {
  text-align: right;
}
main h2:not(#legend h2) + p {
  margin: 2em;
  font-style: italic;
}
main h2:not(#legend h2) + p::before {
  content: "→";
  margin-right: 0.5em;
}

article {
  border: 1px solid rgb(143, 117, 143);
  padding-bottom: 1em;
}
article ul {
  margin-bottom: 2em;
  padding-right: 2em;
}
article li p:first-child {
  font-size: 1.2em;
}
article > p:first-child {
  padding: 1em 2em;
}

details p {
  margin-left: 3em;
}

hr {
  border: 1px dashed pink;
  margin-top: 2em;
  margin-bottom: 2em;
}

a {
  background-color: transparent;
  font-weight: 600;
}
a:hover {
  background-color: var(--links-hover-bg);
  color: black;
}

button {
  font: inherit;
  background-color: inherit;
  color: inherit;
  border: 1px solid;
  cursor: pointer;
}
button:hover {
  background-color: thistle;
  color: black;
}

@media all and (min-width: 1400px) {
  main li {
    margin-left: 1em;
    margin-bottom: 2em;
  }
  main li p:not(:first-child) {
    margin-left: 2em;
  }
  main li details {
    margin-left: 2em;
  }
}
@media all and (min-width: 1100px) {
  main {
    max-width: 75vw;
  }
}
@media all and (max-width: 1100px) {
  #left-col-group {
    flex-direction: column;
  }
  #guide {
    position: static !important;
    top: 0;
    width: 80%;
    margin: auto;
    margin-left: 10vw;
    font-size: larger;
  }
}
@media all and (min-width: 1000px) {
  main ul {
    margin-top: 2em;
  }
  main li p:not(:first-child) {
    margin-left: 1em;
  }
  main li details {
    margin-left: 1em;
  }
}
@media all and (min-width: 768px) {
  #guide {
    width: 60%;
    top: 2em;
    position: sticky;
    align-self: flex-start;
  }
}
@media all and (max-width: 768px) {
  body {
    width: -moz-fit-content;
    width: fit-content;
    margin-top: 5%;
    flex-direction: column;
  }
  header {
    max-width: 80%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10%;
    position: relative;
    top: 0;
  }
  header nav li {
    display: inline-flex;
    margin-right: 0.5em;
  }
  header nav li:last-child::after {
    content: "✧";
    margin-left: 0.5em;
  }
  #themeSwitch {
    margin-left: auto;
  }
  main {
    max-width: 100vw;
    margin: auto;
    margin-top: 5%;
  }
  main h2:not(#legend h2) {
    font-size: 1.75em;
  }
  article {
    border-left: none;
    border-right: none;
  }
  #legend {
    width: 70vw;
    margin: auto;
    margin-bottom: 10vh;
  }
  #guide {
    font-size: 1.2em;
    border-top: 8px double rgba(122, 90, 122, 0.479);
    border-bottom: 8px double rgba(122, 90, 122, 0.479);
    padding-bottom: 1em;
    min-width: 80vw;
  }
  #guide li {
    margin-left: 1em;
  }
  footer {
    font-size: inherit;
    text-align: center;
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    border: none;
  }
}/*# sourceMappingURL=resources.css.map */