:root {
  --stroke-color: rgba(224, 210, 164, 1);
  --card-stroke-color: #000;
  --card-color: #ffe;
  --bg-color: cornsilk;
  --shadow-hot: #ffbb0011;
  --shadow-cold: #003cff0e;
}

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

/* nameplate */
body {
  font-size: 1rem;

  background-color: var(--bg-color);
  font-family: monospace;
  margin: auto auto;
}

main {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);

  background-color: var(--card-color);
  border: 1px solid var(--card-stroke-color);
  box-shadow: var(--shadow-cold) 1ch 1ch;

  padding: 2ch;
  max-width: 25ch;
}

@media (max-width: 500px) {
  html {
    font-size: 18px;
  }
}

/* anchors */
a:link,
a:visited {
  color: black;
  text-decoration: black 1px dotted underline;
}

a:hover {
  text-decoration: black 1px solid underline;
}

a:active {
  outline: 1px dotted black;
  font-weight: bold;
}

/* layout */
main {
  display: flex;
  flex-flow: column wrap;
  gap: 1lh 1ch;
}

@media (min-width: 500px) {
  main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-width: 50ch;
  }
}

/* nameplate */
.bio {
  display: flex;
  flex-flow: column wrap;

  & .name {
    font-size: 1rem;
  }

  & .tag {
    font-size: 1rem;
    font-style: italic;
    font-weight: normal;
  }
}

/* socials */
.socials ul {
  display: flex;
  list-style: none;
  flex-flow: column nowrap;
  gap: 1lh;

  min-width: max-content;

  & .social-link a {
    display: flex;
    align-items: center;
    gap: 1ch;

    & img {
      width: 2ch;
    }
  }
}

@media (min-width: 500px) {
  .socials ul {
    gap: 0lh;
  }
}

/* links */
.nav {
  grid-column: 1 / span 2;
  & ul {
    list-style: none;
    display: flex;
    flex-flow: column;
    gap: 1lh;
  }
}

@media (min-width: 500px) {
  .socials ul {
    gap: 0lh;
  }

  .nav ul {
    flex-flow: row;
    gap: 2ch;
  }
}

.nav {
  & ul {
    & li {
      border: 1px solid var(--card-stroke-color);
      width: 100%;
      box-shadow: var(--shadow-cold) 1ch 1ch;
      text-align: center;

      & a {
        padding: 0.5lh 1ch;
        width: 100%;
        height: 100%;
        display: block;
      }
    }
  }
}

/* canvas */
#canvas {
  position: absolute;
  width: 100%;
  height: 100%;
}

@media (prefers-reduced-motion: reduce) {
  #canvas {
    display: none;
  }

  body {
    position: absolute;
    width: 100%;
    height: 100%;
    background-image: url("/assets/img/bg.png");
  }
}
