@import url('https://fonts.googleapis.com/css2?family=Open+Sans+Condensed:wght@300;700&display=swap');

:root {
  --background-base-hue: 210; /* HSL hue degrees */
  --background-base-saturation: 55%;
  --background-base-lightness: 90%;
  --base-hue: 210; /* HSL hue degrees */
  --base-saturation: 66.7%;
  --base-lightness: 65%;
  --accent-hue: 30;
  --accent-saturation: 100%;
  --accent-lightness: 50%;
  --ok-hue: 100;
  --ok-saturation: 100%;
  --warning-hue: 60;
  --warning-saturation: 100%;
  --base-font-family: 'Open Sans Condensed', 'Roboto', sans-serif;
  --base-font-size: 16px;
  --base-line-height: 1.5;
  --border-color: hsla(var(--base-hue), var(--base-saturation), 30%, 50%);
  --border-radius: 0.5em;
  --border-style: solid;
  --border-width: 0.25em;
  --box-shadow: -0.2em 0.2em 0.6em hsla(var(--base-hue), var(--base-saturation), 25%, 50%);
  --color: hsla(var(--base-hue), 100%, 15%, 100%);
  --height: auto;
  --margin: 1em;
  /*
  --max-height: 12vh;
  --max-width: 12vh;
  --min-height: 12vh;
  --min-width: 12vh;
 */
  --padding: 0 0.5em;
  --base-text-shadow: 0em 0.1em 0.2em hsla(var(--base-hue), var(--base-saturation), 100%, 50%);
  --width: auto;
  --legend-font-family: var(--base-font-family);
  --legend-font-size: 3em;
  --legend-line-height: 1;
  --legend-padding: 1em 0.5em;
  --legend-text-shadow: var(--base-text-shadow);
  --name-font-family: var(--base-font-family);
  --name-font-size: 1.5em;
  --name-line-height: 1;
  --name-padding: 0.5em;
  --name-text-shadow: var(--base-text-shadow);
  --value-font-family: var(--base-font-family);
  --value-font-size: 1.5em;
  --value-line-height: 1;
  --value-padding: 0 0.5em;
  --value-text-shadow: var(--base-text-shadow);
  --unit-font-family: var(--base-font-family);
  --unit-font-size: 1em;
  --unit-line-height: 1.5;
  --unit-padding: 0 0.5em;
  --unit-text-shadow: var(--base-text-shadow);
}
* {
  box-sizing: border-box;
  font-family: var(--base-font-family);
/*
  font-size: var(--base-font-size);
*/
}
html, body {
  height: 100vh;
  margin: 0;
  padding: 0;
  width: 100vw;
}
body {
  background-color: hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness));
  background: linear-gradient(209deg, hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness)), hsl(var(--background-base-hue), var(--background-base-saturation), calc(0.85 * var(--background-base-lightness))));
  background-attachment: fixed;
  height: 200vh;
}
h1 {
  color: hsl(var(--background-base-hue), calc(var(--background-base-saturation) * 1.5), calc(var(--background-base-lightness) * 0.25));
  font-size: 6em;
  padding: 1em 0 0 1em;
  position: sticky;
  text-align: center;
  text-shadow: -0.02em 0.02em 0.05em hsl(var(--base-hue), 50%, 35%);
  top: 0;
}
h1.sticky {
  font-size: 1em;
  text-align: left;
  text-shadow: none;
}
h1.sticky span {
  background-color: hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness));
  background: linear-gradient(209deg, hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness)), hsl(var(--background-base-hue), var(--background-base-saturation), calc(0.9 * var(--background-base-lightness))));
  border-top: 0.15em solid hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness));
  border-right: 0.15em solid hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness));
  border-bottom: 0.15em solid hsl(var(--background-base-hue), calc(var(--background-base-saturation) * 0.9), calc(var(--background-base-lightness) * 0.9));
  border-left: 0.15em solid hsl(var(--background-base-hue), calc(var(--background-base-saturation) * 1.15), calc(var(--background-base-lightness) * 0.9));
  border-radius: 0.5em;
  display: inline-block;
  height: 3em;
  margin: 0.15em;
  padding: 0.5em 0;
  text-align: center;
  width: 3em;
}
/*
h1.sticky span.toggled {
  background: linear-gradient(209deg, hsl(var(--background-base-hue), calc(var(--background-base-saturation) * 0.85), calc(var(--background-base-lightness) * 0.75)), hsl(var(--background-base-hue), var(--background-base-saturation), calc(var(--background-base-lightness) * 0.85)));
    border-bottom: 0.5em solid hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness));
    border-left: 0.5em solid hsl(var(--background-base-hue), var(--background-base-saturation), var(--background-base-lightness));
    border-top: 0.5em solid hsl(var(--background-base-hue), calc(var(--background-base-saturation) * 1.15), calc(var(--background-base-lightness) * 0.85));
    border-right: 0.5em solid hsl(var(--background-base-hue), calc(var(--background-base-saturation) * 1.15), calc(var(--background-base-lightness) * 0.85));
    padding: 0.3em 0 0.2em 0;
}
*/
table {
  border-spacing: 0.5em;
  height: 100vh;
  width: 100vw;
}
td {
  background-color: hsl(var(--base-hue), var(--base-saturation), var(--base-lightness));
  background: linear-gradient(209deg, hsl(var(--base-hue), var(--base-saturation), var(--base-lightness)), hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness))));
  border-width: 2px;
  border-style: solid;
  border-top-color: hsl(var(--base-hue), var(--base-saturation), calc(1 * var(--base-lightness)));
  border-right-color: hsl(var(--base-hue), var(--base-saturation), calc(1 * var(--base-lightness)));
  border-bottom-color: hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness)));
  border-left-color: hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness)));
  border-radius: 0.5em;
  box-shadow: -0.2em 0.25em 0.35em hsl(var(--base-hue), 50%, 35%);
  text-align: center;
  vertical-align: top;
}
td.active {
  background-color: hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness)));
  background: linear-gradient(209deg, hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness))), hsl(var(--base-hue), var(--base-saturation), calc(0.75 * var(--base-lightness))));
  border-top-color: hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness)));
  border-right-color: hsl(var(--base-hue), var(--base-saturation), calc(0.85 * var(--base-lightness)));
  border-bottom-color: hsl(var(--base-hue), var(--base-saturation), calc(0.75 * var(--base-lightness)));
  border-left-color: hsl(var(--base-hue), var(--base-saturation), calc(0.75 * var(--base-lightness)));
  box-shadow: -0.3em 0.35em 0.35em hsl(var(--base-hue), 50%, 35%);
  position: relative;
  top: -0.05em;
  left: 0.05em;
}
table.edit td {
  border-style: dashed;
}
table.edit tr.dropzone {
  border-color: blue;
}
table.edit td.dropzone {
  border-color: red;
}
table.edit td.active {
  border-style: solid;
}
.settings {
  display: none;
  float: right;
  font-size: smaller;
  /*
        position: relative;
        top: 0;
        left: calc(100% - 1em);
 */
  width: 1em;
}
td.active .settings {
  display: block;
}
td:hover .settings {
  display: block;
}
td:focus-within .settings {
  display: block;
}
.settings ul {
  margin: 0;
  padding: 0;
}
.settings li {
  list-style-type: none;
  margin: 0;
  padding: 0;
  text-align: center:
}
.settings li.move {
  cursor: move;
}
