
html, body {
	margin: 0;
	background-color: black;
	color: white;
	height: 100%;
	overflow: hidden;
}

body {
	font-family: sans-serif;
	display: flex;
	flex-direction: column;
	padding: 2em;
	box-sizing: border-box;
	background: linear-gradient(0deg, rgba(2,0,36,1) 0%, rgba(0,11,88,1) 100%);
}

h1 {
	margin-top: 0;
}

#maincontent {
	flex: 1 1 auto;
	display: flex;
}

#weaponlist {
	flex: 0 0 auto;
	width: 14em;
	overflow: auto;
	background-color: #555;
	color: white;
}

#traitList {
	margin-left: 2em;
	flex: 0 0 auto;
	display: grid;
	grid-template-columns: 12em 5em 5em 5em 5em;
	grid-auto-rows: 2em;
}

#traitList > .header {
	font-weight: bold;
}

#traitList > div.value {
	text-align: center;
}

#traitList .valueCheckbox {
	transform: scale(2);
	accent-color: deepskyblue;
	cursor: pointer;
}

#traitList .valueCheckbox.dimmed {
	opacity: .3;
}

#traitList .valueCheckbox:disabled {
	opacity: .2;
	cursor: not-allowed;
}

option.fullyowned {
	color: green;
}
