/* ---------------------- form items --------------------- */
form {
	color: var(--pure-white);
	font-family: 'Source Sans Pro', sans-serif;
	font-size: 1rem;
	padding: 1rem;
	background-color: var(--form-gray);
	border: 1px solid var(--pure-black);
	xx-margin-left: 40px;
}
form div {
	margin-bottom: 2rem;
}
form p {
	margin: 1rem 0;
}
form p.radio {
	margin: 1rem 0 0 5rem;
	text-indent: -8rem;
}
select,
textarea,
input[type=text],
input[type=password] {
	font-family: 'Source Sans Pro', sans-serif;
	font-size: 1.2em;
	padding: 0.2rem 1rem;
	color: #222;
	width: calc(100% - 2rem);
	border: 1px solid #00f;
}
select {
	width: 100%;
}
input[type=radio] {
	margin-left: 8rem;
	margin-right: 1.4em;
	transform: scale(1.4);
}
label {
	font-weight: 600;
}
label span.question {
	display: inline-block;
	font-size: 0.7em;
	text-align: center;
	line-height: 1.4;
	position: relative;
	top: -0.5rem;
	width: 1rem;
	height: 1rem;
	margin-left: 0.5rem;
	border: 1px solid #fff;
	border-radius: 50%;
	background-color: rgb(0,137,208);
	cursor: pointer;
}
label span.question:hover {
	background-color: rgb(0,100,208);
}
label span.answer {
	display: none;
	position: absolute;
	top: -0.5rem;
	left: 2rem;
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.3;
	text-align: center;
	border: 1px #fff solid;
	background-color: rgb(0,137,208);
	width: 10rem;
	padding: 0.25rem 1rem;
}

form table input[type=radio] {
	margin-left: 0;
	margin-right: 0;
	transform: initial;
}
td.center {
	text-align: center;
}
td.right {
	text-align: right;
}
td.first {
	border-top: 1px solid var(--pure-black);
}
table#product td.message {
	text-align: left;
	color: var(--yellow);
	background-color: var(--black);
}		
table#product th,
table#product td {
	line-height: 1.4rem;
	font-size: 0.8rem;
}
table#product label:hover {
	color: var(--yellow);
}
table#shopping-cart td {
	border-bottom: none;
}	
table#shopping-cart td.total {
	border-top: 1px solid var(--pure-black);
	border-bottom: 3px double var(--pure-black);
	font-weight: bold;
}
p.reverse-highlight {
	color: var(--yellow);
	background-color: var(--nav-black);
	font-weight: normal;
	padding: 1em 0;
	width: 100%;
	text-align: center;
	box-sizing: border-box;
	}
img#medium-icon {
	width: 48px;
	height: 48px;
	padding: 4px;
	background-color: #555;
	border: 3px solid;
	border-color: #666 #222 #222 #666;
}
div#story table a {
	text-decoration: none;
	border-bottom: none;
	outline-offset: 1px;
}
select.invalid,
textarea.invalid,
input.invalid {
	border: 2px #f00 dotted;
}
img.svglogo { width: 32px; height: 32px; padding: 0 1rem; }
 
