:root {
    --darkPrimary: #2851cd;
    --primary: #4069e5;
    --primaryHighlight: #5d82f1;
    --onPrimary: #f1f4ff;
    --onDarkPrimary: #96a3d1;
    --surfaceLight: #352e2c;
    --surface: #261f1c;
    --surfaceBright: #3e3430;
    --surfaceHighlight: #4a3f3a;
    --surfaceDark: #ff0000;
    --onSurface: #faf0e6;

    --backgroundHexBorder: #3e3430;
    --hexBorder: #000000;
    --targeting: #ff0000;
    --deployment: #00ff00;
    --worldBorder: #ff0000;

    --fontSize: 16px;
}
.all-center {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100%;
}
html, body {
    height: 100%;
    margin: 0;
    background-color: var(--surface);
    color: var(--onSurface);
    font-family: Arial, Helvetica, sans-serif;
    scrollbar-color: var(--primary) var(--surfaceHighlight);
}
.button, button {
    background-color: var(--primary);
    color: var(--onPrimary);
    border: none;
    padding: 6px 16px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: var(--fontSize);
    transition-duration: 0.2s;
    box-sizing: border-box;
}
button:disabled {
    background-color: var(--darkPrimary);
    color: var(--onDarkPrimary);
}
.button:hover, button:hover:enabled {
    background-color: var(--primaryHighlight);
}
.left-aligned-wide-button {
    text-align: left;
    width: 100%;
}
input {
    font-size: var(--fontSize);
    padding: 6px 10px;
    outline: none;
    background-color: var(--surfaceHighlight);
    color: var(--onSurface);
    border: none;
    border-bottom: 2px solid var(--primary);
    outline: none;
    box-sizing: border-box;
    accent-color: var(--primary);
}
input:focus {
    /*outline: 1px solid var(--primaryHighlight);*/
    border-bottom: 2px solid var(--primaryHighlight);
}
.align-two-ends {
    display: flex;
    justify-content: space-between;
}
label {
    font-size: var(--fontSize);
}
select {
    border: none;
    outline: none;
    padding: 0.25em 0.5em;
    font-size: var(--fontSize);
    line-height: 1.1;
    background-color: var(--primary);
    color: var(--onPrimary);
}
select:hover {
    background-color: var(--primaryHighlight);
}
select:disabled {
    background-color: var(--darkPrimary);
    color: var(--onDarkPrimary);
    opacity: 0.85;
}
.light-box {
    background-color: var(--surfaceBright);
    border: 2px solid var(--darkPrimary);
    border-radius: 2px;
    padding: 10px;
}
label {
    align-content: center;
    display: inline-block;
    padding-right: 10px;
}
svg {
    cursor: grab;
    border: 2px solid var(--darkPrimary);
    border-radius: 2px;
    background-color: var(--surfaceLight);
}
svg:active {
    cursor: grabbing;
}
.horizontal-line {
    height: 2px;
    margin-top: 6px;
    margin-bottom: 6px;
    background-color: var(--darkPrimary)
}
.vertical-line {
    width: 2px;
    margin-left: 6px;
    margin-right: 6px;
    background-color: var(--darkPrimary)
}
a {
    color: var(--onDarkPrimary);
}
th, td {
  padding-left: 12px;
  padding-right: 12px;
  padding-top: 2px;
  padding-bottom: 2px;
  text-align: center;
}
textarea {
    background-color: var(--surfaceHighlight);
    color: var(--onSurface);
    border: 1px solid var(--primary);
}
.slider {
  appearance: none;
  outline: none;
  padding: 0;
  width: 100%;
  height: 8px;
  margin: 12px 0;
  border: none;
}
.slider:focus {
    border: none;
}
/* WebKit (Chrome, Safari, Edge) */
.slider::-webkit-slider-thumb {
    width: 16px;
    height: 16px;
    background: var(--primary);
    appearance: none;
    border-radius: 0;
}
.slider:hover::-webkit-slider-thumb {
    background: var(--primaryHighlight);
}
/* Firefox */
.slider::-moz-range-thumb {
    width: 16px;
    height: 16px;
    background: var(--primary);
    appearance: none;
    border-radius: 0;
}
.slider:hover::-moz-range-thumb {
    background: var(--primaryHighlight);
}