.input-label {
	background-color: var(--swift-button-primary-background-color);
	color: var(--swift-button-primary-foreground-color);

	font-size: 1.25rem;
	font-weight: bold;
	display: block;
	padding: 1rem;
	border-radius: .25rem;
	margin-bottom: 16px;
}

.input-control
{
  flex-wrap: wrap;
  display: grid;
  gap: 16px;
  margin-bottom: 16px;
}
.input-control-col-2 { grid-template-columns: repeat(2, 1fr); }
.input-control-col-3 { grid-template-columns: repeat(3, 1fr); }
.input-control-col-4 { grid-template-columns: repeat(4, 1fr); }
.input-control-col-5 { grid-template-columns: repeat(5, 1fr); }
.input-control-col-6 { grid-template-columns: repeat(6, 1fr); }
.input-control-col-7 { grid-template-columns: repeat(7, 1fr); }
.input-control-col-8 { grid-template-columns: repeat(8, 1fr); }

.input-control > div
{
  flex-shrink: 1;
}

.input-control label {
	display: flex;
	cursor: pointer;
	font-weight: 500;
	position: relative;
	overflow: hidden;
	margin-top: 0.2em;
	margin-bottom: 0.2em;
}
  
.input-control label input {
	position: absolute;
	left: -9999px;
}
  
.input-control label input:checked+span {
	background-color: #3498db;
	color: white;
}
  
.input-control label input:checked+span:before {
	box-shadow: inset 0 0 0 0.4375em #3498db;
	/* background-color: white; */
}
  
.input-control label span {
	display: flex;
	align-items: center;
	padding: 0.375em 0.375em 0.375em 0.375em;
	border-radius: 99em;
	transition: 0.25s ease;
	color: black;
}
  
.input-radiobox-container .input-control>div,
.input-checkboxLarge-container .input-control>div {
	display: flex;
	align-items: center;
	-webkit-box-align: center;
	gap: .5rem;
	-webkit-box-orient: vertical;
	flex-direction: column;
	-webkit-box-direction: normal;
	border: 1px solid #ddd;
	border-radius: 8px;
	padding: 8px;
	text-align: center;
	background-color: #ffffff;
	cursor: pointer;
	position: relative;
	transition: border-color 0.3s, background-color 0.3s;
}
  
.input-radiobox-container .input-control>div.selected,
.input-checkboxLarge-container .input-control>div.selected {
	border-color: #3498db;
	background-color: #e7f0ff;
}
  
.input-radiobox-container .input-control>div.selected::before,
.input-checkboxLarge-container .input-control>div.selected::before {
	content: '✔';
	position: absolute;
	top: -8px;
	right: -8px;
	background-color: #3498db;
	color: white;
	width: 16px;
	height: 16px;
	border-radius: 2px;
	display: flex;
	align-items: center;
	justify-content: center;
}
  
.input-radiobox-container .input-control>div input[type="radio"],
.input-checkboxLarge-container .input-control>div input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.input-checkboxLarge-container label span:before {
	display: flex;
	flex-shrink: 0;
	content: "";
   
}

.input-checkbox-container label span {
	width: fit-content;
}
  
.input-checkbox-container label span:before {
	display: flex;
	flex-shrink: 0;
	content: "";
	/* background-color: white; */
	width: 1.5em;
	height: 1.5em;
	margin-right: 0.375em;
	transition: 0.25s ease;
	box-shadow: inset 0 0 0 0.125em #3498db;
}

.input-checkbox-container input[type="checkbox"]:checked+span:before {
	box-shadow: inset 0 0 0 0.375em #3498db;
	/* background-color: white; */
	content: "✔";
	display: flex;
	align-items: center;
	justify-content: center;
}
  
.input-checkbox-container label span:hover:before {
	box-shadow: inset 0 0 0 0.175em #ffffff;
}