:root {
  --bg-color-1: #cdd22e;
  --bg-color-2: #ffffcb;
  --bg-color-gradient: linear-gradient(125deg, var(--bg-color-1), var(--bg-color-2)) no-repeat fixed center;
  --bg-color-gradient-inverted: linear-gradient(125deg, var(--bg-color-2), var(--bg-color-1));
  --menubar-gradient-bg: linear-gradient(180deg,
      hsla(0, 0%, 100%, 0.95),
      hsla(214, 100%, 78%, 0.95));
  --menubar-hover-bg: linear-gradient(90deg,
      hsla(215, 100%, 98%, 0.95),
      hsla(214, 90%, 66%, 0.95));
  --menubar-active-bg: linear-gradient(0deg,
      hsla(215, 100%, 98%, 0.95),
      hsla(215, 54%, 53%, 0.95));
  --menubar-outline: 1px black solid;
  --menubar-hover-outline: 1px blue solid;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
html * {
  font-size: 16px;
  letter-spacing: 0.025rem;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
    Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
}

html * h1 {
  font-size: 2rem;
}

html * h2 {
  font-size: 1.5rem;
}

html * h3 {
  font-size: 1.25rem;
}


body {
  background: var(--bg-color-gradient);
  height: 100vh;
  height: 100dvh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  grid-template-columns: 1fr;
  grid-template-areas:
    "header"
    "main"
    "footer";
}

/* Navigation */

nav {
  display: flex;
  position: fixed;
  z-index: 2;
  width: 100%;
  height: fit-content;
  top: 6.5rem;
  margin: auto;
}

nav #menuToggle {
  display: none;
  overflow: hidden;
}

nav #menuToggle > svg {
  display: inline-block;
}

nav #menuToggle > svg > path {
  d: path("M120-240v-80h720v80H120Zm0-200v-80h720v80H120Zm0-200v-80h720v80H120Z");
}

nav #menuToggleCB:checked ~ #menuToggle svg > path {
  d: path("m256-200-56-56 224-224-224-224 56-56 224 224 224-224 56 56-224 224 224 224-56 56-224-224-224 224Z");
}

nav .menubar {
  background: var(--menubar-gradient-bg);
  list-style: none;
  display: flex;
  flex-direction: row;
  justify-content: baseline;
  align-items: center;
  outline: var(--menubar-outline);
  height: 2.5rem;
  width: fit-content;
  margin: auto;
  padding: 0;
  overflow: hidden;
}

nav .menubar li {
  display: flex;
  padding: 0.25rem 0.5rem;
  align-items: center;
  height: 2.5rem;
  width: fit-content;
}

nav .menubar li a {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  width: fit-content;
  height: fit-content;
  font-size: 0.85rem;
  color: black;
  padding: 0.5rem;
  text-decoration: none;
}

nav .menubar li:hover,
nav .menubar li:focus-visible {
  outline: var(--menubar-hover-outline);
  background: var(--menubar-hover-bg);
}

nav .menubar li:hover > a,
nav .menubar li:focus-visible > a {
  color: orangered;
}

nav .menubar li.menu-sub > a::after {
  width: 24px;
  height: 24px;
  margin-right: -.5rem;
  content: url("data:image/svg+xml, %3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 -960 960 960' width='24px' fill='black'%3E %3Cpath d='M480-360 280-560h400L480-360Z' /%3E%3C/svg%3E");
}

nav .menubar li.menu-sub:hover > a::after {
  width: 24px;
  height: 24px;
  margin-right: -.5rem;
  content: url("data:image/svg+xml, %3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 -960 960 960' width='24px' fill='black'%3E %3Cpath d='m280-400 200-200 200 200H280Z' /%3E%3C/svg%3E");
}

nav .menubar li.menu-sub ul {
  background: var(--menubar-gradient-bg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: absolute;
  margin: 0;
  top: 2.54rem;
  margin-left: -0.5rem;
  outline: var(--menubar-outline);
  width: fit-content;
  height: fit-content;
  max-height: 0;
  opacity: 0;
  transition: max-height 500ms ease-in-out, opacity 750ms ease-in-out;
}

nav .menubar li.menu-sub ul li {
  width: 100%;
  padding: 0.25rem 0;

}

nav .menubar li.menu-sub:hover > ul,
nav .menubar li.menu-sub:focus-visible > ul {
  outline: var(--menubar-outline);
  height: fit-content;
  max-height: 25rem;
  opacity: 1;
  transition: max-height 500ms ease-in-out;
}

nav .menubar li.menu-sub-JS > ul {
  display: none !important;
}


nav .menubar li.active-site,
nav .menubar li + :has(.active-site) {
  background: var(--menubar-active-bg);
  outline: var(--menubar-hover-outline);
}

nav .menubar li.active-site > a,
nav .menubar li + :has(.active-site) > a {
  font-weight: bold;
  text-decoration: underline;
}

/* Site Structure */


header,
main,
main > #mainContent,
footer {
  position: relative;
  z-index: 1;
  --outline: 1px red solid;
  display: flex;
  justify-content: center;
  align-items: center;
}

header {
  grid-area: header;
  height: fit-content;
}

header > .textLogo {
  display: block;
  position: relative;
  margin: 1rem auto;
  width: fit-content;
  height: fit-content;
  font-family: sans-serif;
}

header > .textLogo h1,
header > .textLogo h2 {
  margin: auto;
  display: inline-block;
  width: fit-content;
}

header > .textLogo h2 {
  margin-left: 0.25rem;
  color: #080;
}

header > .textLogo h3 {
  display: block;
  margin: auto;
  font-size: small;
  width: fit-content;
}


main {
  grid-area: main;
  flex: 1;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

main > #mainContent {
  position: absolute;
  border: 0.5rem solid transparent;
  border-image: var(--bg-color-gradient-inverted) 1;
  border-image-width: .5rem;
  box-sizing: border-box;
  width: 90%;
  inset: auto;
  top: 4.5rem;
  bottom: .5rem;
  overflow-y: auto;
}

main > #mainContent .infoBox {
  display: block;
  position: relative;
  margin: auto;
  margin-bottom: min(2rem, 10%);
  width: fit-content;
  height: fit-content;
  background: #fffce9;
  padding: 0.25rem 1.5rem;
  outline: 1px rgb(70, 70, 0) solid;
}

main > #mainContent .infoBox h1,
main > #mainContent .infoBox h2 {
  width: fit-content;
  color: green;
  font-size: small;
  margin: 0.125rem auto;
}

main > #mainContent .infoBox h2 {
  margin: 1rem auto 0.125rem;
}

main > #mainContent .infoBox ul {
  list-style: none;
  padding: 0.25rem;
  margin: auto;
  width: fit-content;
}

main > #mainContent .infoBox ul li {
  color: rgb(70, 70, 0);
  font-weight: 400;
  font-size: small;
  width: fit-content;
  margin: 0 auto;
  line-height: 160%;
}

main > #mainContent .infoBox h2 + ul li {
  margin: 0;
  font-family: "Courier New", Courier, monospace;
  font-weight: 500;
}


/* Page Content Area */

main > #mainContent .blurred-bg {
  background: rgba(255, 255, 255, 0.75);
  background-size: cover;

  position: absolute;
  width: 100%;
  height: 100%;
  overflow: auto;


  display: grid;
  gap: .5rem;
  grid-template-rows: auto 1fr;
  grid-template-columns: 1fr;
  grid-template-areas:
    "headline"
    "subcontent";
  justify-items: center;
  justify-content: center;
  align-items: center;
}


main > #mainContent .blurred-bg h1 {
  margin: 1rem auto .5rem;
  grid-area: headline;
  display: block;
  text-decoration: underline;
  font-size: large;
  font-weight: bold;
}

main > #mainContent .blurred-bg > div {
  grid-area: subcontent;
  padding: 0 2rem;
  display: flex;
  flex: 1;
  overflow: hidden;

  position: relative;
  width: 95%;
  height: 98%;
  min-height: fit-content;
  margin: auto;
  justify-items: center;
  justify-content: center;
  align-items: flex-start;
  align-content: center;
}

main > #mainContent .blurred-bg > div div {
  position: relative;
}

main > #mainContent .blurred-bg > div div p,
main > #mainContent .blurred-bg > div div ul,
main > #mainContent .blurred-bg > div div img {
  font-size: medium;
  margin: 2rem auto;
}

main > #mainContent .blurred-bg > div div p {
  margin: min(5%, 2rem) auto;
  display: block;
  width: fit-content;
  max-width: 95%;
  text-align: center;
}

main > #mainContent .blurred-bg > div div .para {
  text-align: left;
}

main > #mainContent .blurred-bg > div div img {
  height: fit-content;
  width: fit-content;
  border: 0.25rem groove green;
}

main > #mainContent .blurred-bg > div div table {
  font-size: medium;
  margin: min(2rem, 5%) auto;
  max-width: 95%;
}

main > #mainContent .blurred-bg > div div table tr > td:first-child {
  min-width: 10rem !important;
  max-width: 45% !important;
}

main > #mainContent .blurred-bg .flex-row {
  justify-content: space-evenly;
  flex-direction: row;
}

main > #mainContent .blurred-bg .flex-col {
  align-items: center;
  flex-direction: column;
}


main > #mainContent .blurred-bg a,
main > #mainContent .blurred-bg a:visited,
main > #mainContent .blurred-bg a:active {
  color: green;
}

main > #mainContent .blurred-bg a:hover,
main > #mainContent .blurred-bg a:hover {
  color: blue;
}

main > #mainContent .blurred-bg .special-link {
  grid-area: headline;
  display: inline-block;
  position: absolute;
  top: 1rem;
  right: 1.5rem;
  font-size: small;
}

footer {
  grid-area: footer;
  height: 2.5rem !important;
}

footer > .copyright {
  display: block;
  width: fit-content;
  margin: auto 1.5rem .5rem auto;
  font-size: small;
  letter-spacing: 0.025rem;
}

footer > .copyright > a {
  color: #080;
  text-decoration: none;
}

.offline {
  display: none !important;
}

/* 1100px */
@media (width < 950px) {

  nav {
    inset: unset;
    bottom: 1px;
    right: 1px;
    width: fit-content;
    height: 100%;
    flex-direction: column-reverse;
  }

  nav #menuToggle {
    display: flex;
    width: 2rem;
    height: 2rem;
    outline: var(--menubar-outline);
    background: var(--menubar-gradient-bg);
    justify-content: center;
    align-items: center;
    margin: 1px 0 auto auto;
  }

  nav #menuToggle:hover,
  nav #menuToggle:focus-visible {
    outline: var(--menubar-hover-outline);
    background: var(--menubar-hover-bg);
  }

  nav #menuToggleCB:checked ~ .menubar {
    width: 200px;
    max-width: 200px;
    outline: var(--menubar-outline);
    opacity: 1;
    transition: max-width 500ms ease-in-out, opacity 750ms ease-in-out;
  }

  nav .menubar {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow-y: auto;
    margin: auto 0 1px auto;
    width: 200px;
    max-width: 0px;
    opacity: 0;
    transition: max-width 500ms ease-in-out, opacity 750ms ease-in-out;
  }

  nav .menubar li {
    display: flex;
    flex-direction: column;
    justify-content: right;
    height: fit-content;
    width: 100%;
  }

  nav .menubar li a {
    font-size: large;
    width: fit-content;
  }

  nav .menubar li.menu-sub {
    padding: 0;
    padding-right: 0;
  }

  nav .menubar li.menu-sub > ul {
    outline: none;
    inset: unset;
    position: relative;
    margin: 0;
    padding: 0;
    height: fit-content;
    max-height: 0px;
    width: 100%;
    opacity: 0;
    transition: max-height 500ms ease-in-out, opacity 750ms ease-in-out;
  }

  nav .menubar li.menu-sub:hover > ul,
  nav .menubar li.menu-sub:focus-visible > ul {
    height: fit-content;
    max-height: 35rem;
    opacity: 1;
    transition: max-height 500ms ease-in-out, opacity 750ms ease-in-out;
  }

  main #mainContent {
    top: 0;
    bottom: 0;
  }

  main #mainContent .blurred-bg {
    gap: 0;
  }

  main #mainContent .blurred-bg > div {
    margin: auto;
    width: fit-content;
    height: fit-content;
  }

  main #mainContent .blurred-bg > div div {
    margin: auto;
  }

  main #mainContent .blurred-bg .flex-row {
    justify-content: flex-start;
    align-items: center;
    flex-direction: column;
  }

  footer > .copyright {
    margin-right: 3rem;
  }

}

@media (width < 750px) {

  main #mainContent .blurred-bg div {
    flex-direction: column;
  }
}

@media (width < 600px) {

  header .textLogo h1 {
    display: block;
    top: unset;
    margin: auto;
  }

  main #mainContent {
    width: 100%;
    height: 100%;
  }

  main #mainContent .infoBox {
    padding: 0.125rem;
    line-height: 120%;
    bottom: 2%;
  }
}

@media (width < 500px) {

  header .textLogo h2 {
    display: block;
    top: unset;
    margin: auto;
  }

  main #mainContent {
    width: 100%;
    border: 0;
  }

  main #mainContent .blurred-bg .special-link {
    top: 5px;
    right: 5px;
  }
}

@media (width < 250px) {
  header .textLogo h1 {
    font-size: 1.5rem !important;
  }

  header .textLogo h2 {
    font-size: 1rem !important;
  }

  header .textLogo h3 {
    font-size: .5rem !important;
  }
}

@media (height < 450px) {

  main > #mainContent > .blurred-bg div p,
  main > #mainContent > .blurred-bg div .para,
  main > #mainContent > .blurred-bg div ul,
  main > #mainContent > .blurred-bg div img {
    margin: 0 auto 2rem;
  }

  main > #mainContent > .blurred-bg div table {
    margin: 0 auto 2rem;
  }
}