* {
  font-family: monospace;
  font-size: 14px;
  
  --bg-color: #210;
  --fg-color: #a64;
  --p-small: 0.25em;
  --p: 0.5em;
  --p-large: 1em;
}

body {
  background-color: var(--bg-color);
  color: var(--fg-color);
}

header, main {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

h1 {
  font-size: 20px;
}

h2 {
  font-size: 16px;
}

header h1 {
  text-align: center;
}

nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-block-start: var(--p-large);
}

th, td {
  padding-block: var(--p);
  padding-inline: var(--p);
}

th {
  font-weight: bold;
  color: var(--bg-color);
  background-color: var(--fg-color);
  text-align: left;
}

tr:not(:last-child) {
  border-bottom: 0.5px solid var(--fg-color);
}

.numeric {
  text-align: right;
}

.comment {
  font-size: smaller;
}

.pb {
  font-weight: bold;
}

.pb::before {
  content: "*";
  padding-right: var(--p);
}

a, a:visited, a:active {
  color: var(--fg-color);
}

form label {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: top;
  justify-content: space-between;
  margin-block-end: var(--p);
}

label input, label textarea {
  width: 400px; 
}

input, textarea, button, .button {
  background-color: var(--bg-color);
  color: var(--fg-color);
  border: 1px solid var(--fg-color);
  padding: var(--p-small);
}

button, .button {
  cursor: pointer;
}

button:hover, .button:hover {
  color: var(--bg-color);
  background-color: var(--fg-color);
}

.button {
  text-decoration: none;
}

.controls {
  display: flex;
  flex-direction: row;
  justify-content: end;
}

dt {
  color: var(--bg-color);
  background-color: var(--fg-color);
  padding-inline: var(--p);
  padding-block: var(--p-small);
}

dd {
  text-align: right;
  margin-block-start: var(--p-small);
  margin-block-end: var(--p);
}

canvas {
  margin-block-start: var(--p-large);
}
