a {
	color: var(--link_colour);
	cursor: default;
	text-decoration: underline
	}
a:active {
	color: orange
	}
a:focus,
input[type = "button"]:focus,
input[type = "checkbox"]:focus + label,
input[type = "radio"]:focus + label,
input[type = "range"]:focus,
input[type = "reset"]:focus,
input[type = "submit"]:focus,
summary:focus {
	outline: 1px dotted var(--text_colour) !important
	}
canvas {
	box-shadow: var(--inset_border);
	box-sizing: border-box;
	display: block;
	padding: 2px;
	width: 100%
	}
code {
	display: block;
	font-family: var(--monospace_font);
	margin: 0;
	overflow: auto;
	padding-top: 0;
	white-space: nowrap;
	width: calc(100% - 6px)
	}
code,
textarea,
ul.tree_view {
	padding-bottom: 2px;
	padding-left: 3px;
	padding-right: 3px
	}
code .tab {
	display: inline-block;
	width: 2.4em
	}
div.body {
	overflow: auto;
	padding: var(--element_spacing)
	}
fieldset {
	box-shadow:
		inset 0 0 var(--shadow_colour),
		inset 0 0 var(--shine_colour);
	box-sizing: border-box;
	margin: 0;
	padding: calc(var(--element_spacing) + 2px);
	padding-block-start: var(--element_spacing)
	}
h1 {
	font-size: 22px;
	font-style: italic;
	font-weight: bold;
	margin: 0
	}
h2 {
	color: var(--highlight_colour);
	font-size: 13px;
	font-weight: bold;
	margin: 0
	}
iframe {
	border: none
	}
img.i {
	float: left;
	margin-right: 8px
	}
input[type = "button"],
input[type = "email"],
input[type = "number"],
input[type = "password"],
input[type = "reset"],
input[type = "submit"],
input[type = "tel"],
input[type = "text"],
select,
textarea,
th[onclick],
ul.tree_view {
	color: var(--text_colour);
	}
input[type = "button"],
input[type = "reset"],
input[type = "submit"] {
	min-width: 75px;
	padding-left: 12px;
	padding-right: 12px
	}
input[type = "button"],
input[type = "reset"],
input[type = "submit"],
th[onclick] {
	border: none;
	box-sizing: border-box;
	background: var(--surface_colour);
	border-radius: 0;
	box-shadow: var(--outset_border);
	height: 26px
	}
input[type = "button"]:active,
input[type = "reset"]:active,
input[type = "submit"]:active,
th[onclick]:active,
.active {
	box-shadow: var(--inset_button_border) !important;
	color: transparent !important;
	text-shadow: 1px 1px var(--text_colour) !important
	}
input[type = "button"]:focus,
input[type = "reset"]:focus,
input[type = "submit"]:focus{
	outline-offset: -4px
	}
input[type = "button"]::-moz-focus-inner,
input[type = "reset"]::-moz-focus-inner,
input[type = "submit"]::-moz-focus-inner {
	border: 0
	}
input[type = "button"].warning {
	background-color: var(--warning_colour)
	}
input[type = "checkbox"],
input[type = "radio"] {
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	background: none;
	border: none;
	margin: 0;
	opacity: 0;
	position: fixed
	}
input[type = "checkbox"] + label,
input[type = "radio"] + label {
	line-height: calc(var(--font_size) - 3px)
	}
input[type = "checkbox"] + label {
	margin-left: calc(var(--tickbox_width) + var(--radio_label_spacing));
	position: relative
	}
input[type = "checkbox"] + label::before {
	background: var(--display_box_background_colour);
	box-shadow: var(--inset_border);
	content: "";
	display: inline-block;
	height: var(--tickbox_width);
	left: calc(-1 * (var(--tickbox_width) + var(--radio_label_spacing)));
	margin-right: var(--radio_label_spacing);
	position: absolute;
	width: var(--tickbox_width)
	}
input[type = "checkbox"]:active + label::before {
	background: var(--surface_colour)
	}
input[type = "checkbox"]:checked + label::after {
	background: url("images/interface_elements/tick.svg");
	content: "";
	display: block;
	height: 7px;
	left: calc(-1 * (var(--tickbox_width) + var(--radio_label_spacing)) + 3px);
	position: absolute;
	top: 3px;
	width: 7px
	}
input[type = "email"],
input[type = "number"],
input[type = "password"],
input[type = "tel"],
input[type = "text"] {
	border-radius: 0;
	box-shadow: var(--inset_border);
	padding-right: 5px;
	width: 128px
	}
input[type = "email"],
input[type = "number"],
input[type = "password"],
input[type = "tel"],
input[type = "text"],
progress,
select,
textarea,
ul.tree_view {
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	background: var(--display_box_background_colour);
	border: none;
	box-sizing: border-box
	}
input[type = "email"],
input[type = "number"],
input[type = "password"],
input[type = "tel"],
input[type = "text"],
progress,
select,
.working_indicator {
	height: 26px
	}
input[type = "email"],
input[type = "number"],
input[type = "password"],
input[type = "tel"],
input[type = "text"],
select {
	padding-left: 5px
	}
input[type = "email"]:focus,
input[type = "number"]:focus,
input[type = "password"]:focus,
input[type = "tel"]:focus,
input[type = "text"]:focus,
select:focus,
textarea:focus {
	outline: none
	}
input[type = "radio"] + label {
	margin-left: calc(var(--radio_width) + var(--radio_label_spacing));
	position: relative
	}
input[type = "radio"] + label::before {
	content: "";
	background: url("images/interface_elements/radio_border.svg");
	display: inline-block;
	height: var(--radio_width);
	left: calc(-1 * (var(--radio_width) + var(--radio_label_spacing)));
	margin-right: var(--radio_label_spacing);
	position: absolute;
	top: 0;
	width: var(--radio_width)
	}
input[type = "radio"]:active + label::before {
	background: url("images/interface_elements/radio_border_-_active.svg")
	}
input[type = "radio"]:checked + label::after {
	background: url("images/interface_elements/radio_dot.svg");
	content: "";
	display: block;
	height: var(--radio_dot_width);
	left: calc(-1 * (var(--radio_width) + var(--radio_label_spacing)) + var(--radio_width) / 2 - var(--radio_dot_width) / 2);
	position: absolute;
	top: calc(var(--radio_width) / 2 - var(--radio_dot_width) / 2);
	width: var(--radio_dot_width)
	}
input[type = "range"] {
	-webkit-appearance: none;
	background: transparent;
	margin: 2px 0 2px 0;
	width: 100%
	}
input[type = "range"]::-moz-range-thumb {
	background: url("images/interface_elements/range_handle.svg");
	border: 0;
	border-radius: 0;
	height: 21px;
	transform: translateY(2px);
	width: 11px
	}
input[type = "range"]::-moz-range-track {
	background: var(--range_background);
	border-bottom: var(--range_border);
	border-right: var(--range_border);
	box-shadow: var(--range_shadow);
	box-sizing: border-box;
	height: 2px;
	width: calc(100% - 3px)
	}
input[type = "range"]::-webkit-slider-runnable-track {
	background: var(--range_background);
	border-bottom: var(--range_border);
	border-right: var(--range_border);
	box-shadow: var(--range_shadow);
	box-sizing: border-box;
	height: 2px;
	width: calc(100% - 3px)
	}
input[type = "range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	background: url("images/interface_elements/range_handle.svg");
	border: none;
	box-shadow: none;
	height: 21px;
	transform: translateY(-8px);
	width: 11px
	}
label {
	align-items: center;
	cursor: default;
	display: inline-flex;
	margin-top: 1px;
	user-select: none;
	-webkit-user-select: none;
	word-break: normal
	}
legend {
	max-width: 256px
	}
menu[role = "tablist"] {
	display: flex;
	list-style-type: none;
	margin: 0 0 -2px 0;
	overflow-x: auto;
	padding: 0;
	position: relative;
	text-indent: 0
	}
menu[role = "tablist"] > li {
	background: var(--inactive_colour);
	clip-path: var(--tab_shape);
	-webkit-clip-path: var(--tab_shape);
	margin-right: -16px;
	padding-left: 12px;
	padding-right: 12px;
	white-space: nowrap
	}
menu[role = "tablist"] > li > a {
	color: var(--highlighted_text_colour);
	cursor: default;
	display: inline-block;
	margin: 6px;
	text-decoration: none;
	user-select: none;
	-webkit-user-select: none;
	white-space: nowrap
	}
menu[role = "tablist"] > li[aria-selected = "true"],
th[aria-selected = "true"][onclick] {
	background: var(--highlight_colour)
	}
progress {
	accent-color: var(--highlight_colour);
	box-shadow: var(--inset_border);
	padding: 3px
	}
progress::-moz-progress-bar {
	background: var(--highlight_colour)
	}
progress::-webkit-progress-value {
	background: var(--highlight_colour)
	}
section {
	margin: 0
	}
section:not(:last-of-type) {
	margin-bottom: calc(2 * var(--element_spacing))
	}
section + section > h1 {
	margin-top: calc(4 * var(--element_spacing))
	}
select {
	background-color: var(--display_box_background_colour);
	background-image: url("images/interface_elements/dropdown_button.svg");
	background-position: right 2px top 2px;
	background-repeat: no-repeat;
	border-radius: 0;
	box-shadow: var(--inset_border);
	max-width: 220px;
	padding-right: 32px;
	position: relative
	}
select:focus {
	background-color: var(--highlight_colour);
	color: var(--highlighted_text_colour)
	}
select:active {
	background-image: url("images/interface_elements/dropdown_button_-_active.svg")
	}
table {
	border-collapse: collapse;
	position: relative;
	text-align: left;
	white-space: nowrap
	}
td {
	height: 12px;
	padding: 0 var(--grouped_element_spacing);
	vertical-align: top
	}
td > label {
	margin-top: 3px
	}
textarea {
	resize: vertical;
	margin: 0 0 -2px 0;
	tab-size: 4;
	width: 100%
	}
th {
	background: var(--display_box_background_colour);
	font-weight: normal;
	padding: 0 var(--grouped_element_spacing);
	position: sticky;
	text-decoration: underline;
	top: 0
	}
th[aria-selected = "true"] {
	color: var(--highlighted_text_colour)
	}
th[onclick] {
	cursor: default;
	text-decoration: none;
	user-select: none;
	-webkit-user-select: none
	}
th[aria-selected = "true"][onclick]:active {
	text-shadow: 1px 1px var(--highlighted_text_colour) !important
	}
tr:nth-child(even) {
	background: lightcyan
	}
ul.tree_view {
	display: block;
	margin: 0;
	overflow: auto;
	padding-top: 2px
	}
ul.tree_view details {
	margin-top: 0
	}
ul.tree_view details > summary::after {
	background-color: var(--display_box_background_colour);
	border: 1px solid grey;
	content: "+";
	display: block;
	float: left;
	height: 9px;
	line-height: 8px;
	margin-right: 5px;
	margin-top: 4px;
	text-align: center;
	width: 9px
	}
ul.tree_view details > summary::marker,
ul.tree_view details > summary::-webkit-details-marker {
	content: ""
	}
ul.tree_view details[open] summary {
	margin-bottom: 0
	}
ul.tree_view details[open] > summary::after {
	content: "-"
	}
ul.tree_view li {
	list-style-type: none;
	white-space: nowrap
	}
ul.tree_view ul {
	margin-left: 16px;
	padding-left: 16px;
	border-left: var(--tree_view_branches)
	}
ul.tree_view ul details > summary::after {
	margin-left: -22px;
	position: relative
	}
ul.tree_view ul > li {
	position: relative
	}
ul.tree_view ul > li:last-child::before {
	background: var(--display_box_background_colour);
	bottom: 0;
	content: "";
	display: block;
	left: -18px;
	position: absolute;
	top: 10px;
	width: 3px
	}
ul.tree_view ul > li::after {
	border-bottom: var(--tree_view_branches);
	content: "";
	display: block;
	left: -16px;
	position: absolute;
	top: 9px;
	width: 12px
	}
ul.tree_view ul > li:has(details)::after {
	left: -11px;
	width: 7px
	}
ul.tree_view ul ul {
	margin-left: 0
	}
.button_image {
	height: 18px;
	margin-right: -18px;
	pointer-events: none;
	transform: translate(3px, -1px);
	user-select: none;
	-webkit-user-select: none
	}
.field_row {
	align-items: center;
	display: flex
	}
.field_row > * + * {
	margin-left: var(--grouped_element_spacing)
	}
.field_row > label + input[type = "range"] {
	margin-left: 6px
	}
.field_row + .field_row,
.field_row + .field_row_-_stacked,
.field_row_-_stacked + .field_row,
.field_row_-_stacked + .field_row_-_stacked {
	margin-top: var(--grouped_element_spacing)
	}
.field_row_-_stacked {
	display: flex;
	flex-direction: column
	}
.field_row_-_stacked > input[type = "email"],
.field_row_-_stacked > input[type = "password"],
.field_row_-_stacked > input[type = "tel"],
.field_row_-_stacked > input[type = "text"]{
	width: 100%
	}
.field_row_-_stacked > table {
	display: block
	}
.field_row_-_stacked > table,
.field_row_-_stacked > table > tbody > tr {
	background: transparent
	}
.field_row_-_stacked > table > tbody > tr > * {
	padding: 0
	}
.field_row_-_stacked > table > tbody > tr > td:first-child {
	padding-right: var(--element_spacing);
	text-align: right
	}
.field_row_-_stacked > table > tbody > tr > td:not(:first-child) {
	white-space: normal
	}
.fixed {
	height: calc(100% - 2 * var(--element_spacing));
	position: fixed;
	width: calc(100% - 2 * var(--element_spacing))
	}
.image_button {
	margin-left: 0;
	padding-left: 28px !important
	}
.image_view {
	margin-bottom: -5px;
	user-select: none;
	-webkit-user-select: none
	}
.image_view,
.table_container {
	height: 100%;
	overflow: auto;
	width: 100%
	}
.panel {
	background-color: var(--surface_colour);
	box-shadow: var(--outset_border);
	box-sizing: border-box;
	padding: 3px
	}
.panel[role = "tabpanel"] {
	position: relative
	}
.sunken_panel {
	background-color: var(--display_box_background_colour);
	box-shadow: var(--inset_border);
	box-sizing: border-box;
	display: block;
	padding: 2px
	}
.sunken_panel > table {
	width: 100%
	}
.table_container > table {
	width: 100%
	}
.working_indicator {
	background-color: var(--display_box_background_colour);
	background-image: url("images/interface_elements/working_indicator.png");
	background-position: left 2px top 2px;
	box-shadow: var(--inset_border);
	box-sizing: border-box;
	display: block;
	width: 75px
	}