/*
	Created by Michael Schuijff <michael@reglobe.nl>
	Copyright Lost Images, The Netherlands
	
	For more information, visit www.michaelschuijff.nl
*/

.main-form {
	max-width: 680px;
	margin: 0 auto;
}
.main-form, .main-form fieldset {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	align-items: flex-start;
	column-gap: 20px;
	row-gap: 32px;
}

.main-form h2 {
	font-size: 22px;
	width: 100%;
}
.main-form h3 {
	font-size: 18px;
	width: 100%;
}
.main-form p {
	width: 100%;
}
.main-form h2 + p, .main-form h3 + p {
	margin-top: -18px;
}
.main-form p + p {
	margin-top: -9px;
}

.main-form label {
	width: calc(50% - 10px);
}
.main-form .small-column {
	width: auto;
}

@media (max-width: 600px) {
	.main-form label {
		width: 100% !important;
	}
}

.main-form label > span:first-child, .main-form .label > span:first-child {
	display: block;
	padding-bottom: 4px;
	font-weight: 500;
	color: #5a5c65;
}
.main-form label > input[type=checkbox], .main-form label > input[type=radio] {
	margin: 0 8px 0 4px;
}
.main-form label > input[type=checkbox] + span, .main-form label > input[type=radio] + span {
	display: inline-block;
	color: #5a5c65;
	vertical-align: middle;
}
.main-form label > .error, .main-form label > .hint {
	display: block;
	padding-top: 4px;
}
.main-form label > .error {
	color: #e80028;
}
.main-form label input:not([type=checkbox]):not([type=radio]), .main-form label textarea, .main-form label select {
	width: 100%;
}

.main-form .price, .main-form .number {
	max-width: 120px;
	text-align: right;
}

.main-form .price-suggestions {
	padding-top: 16px;
}

.main-form .digits {
	display: flex;
	gap: 10px;
}
.main-form .digits input {
	width: 46px !important;
	font-size: 22px;
	text-align: center;
}

.main-form fieldset {
	padding: 18px;
	border: solid 1px #ececed;
	border-radius: 8px;
}
.main-form fieldset.collapse > *:not(.toggle-fieldset) {
	display: none;
}

.main-form button.toggle-fieldset {
	position: relative;
	display: block;
	-webkit-appearance: none;
	appearance: none;
	width: calc(100% + 36px);
	margin: -18px;
	padding: 18px;
	font-weight: 500;
	color: #0d6efd;
	background: transparent;
	border: none;
	text-align: left;
	text-decoration: underline;
	cursor: pointer;
	overflow: hidden;
}
.main-form button.toggle-fieldset::after {
	position: absolute;
	content: '';
	top: 20px;
	right: 18px;
	width: 14px;
	height: 14px;
	background: url(svg/toggle-fieldset.svg) no-repeat center center;
	transform: rotate(-90deg);
	transition: all .5s;
}
.main-form .expand > button.toggle-fieldset::after {
	transform: rotate(90deg);
}