@font-face {
	font-family: Poppins;
	src: url(../fonts/poppins-regular.woff2);
}
@font-face {
	font-family: Poppins;
	src: url(../fonts/poppins-medium.woff2);
	font-weight: 500;
}
@font-face {
	font-family: Poppins;
	src: url(../fonts/poppins-semibold.woff2);
	font-weight: 600;
}

html{
	width:100%;
}
body{
	width:100%;
	background:#FFF;
	line-height:1.6;
	font-weight:normal;
	font-size:16px;
	font-family: Poppins, sans-serif;
}
body, a, table, input, select, textarea{
	color:#000;
}
h1,h2,h3,h4,h5,h6 {
	font-family: Poppins, sans-serif;
	font-weight: 600;

}
small {
	font-size: 80%;
}
.clear{
	clear:both;
}
.msg{
	margin-bottom:20px;
	padding:5px;
	background-color:#B9FFB9;
	border:solid 1px #00CC00;
}
.error{
	margin-bottom:20px;
	padding:5px;
	border:solid 2px #CD0025;
	border-radius:2px;
	background:#FFF;
	color:#CD0025;
}
[data-column=opstaplocatie] select option[value=Geen] {
	display: none;
}
table {width: 100%;}

th + td {
	padding: 5px;
}
th {
	text-align: left;
	font-weight: 400;
}
.align-top {
	vertical-align: top;
}

.youtube-video{
	width:100%;
	aspect-ratio:16/9;
}

input[type=text], input[type=date], input[type=email], input[type=tel], select, textarea, input[type=number] {
	width:300px;
	max-width:100%;
	padding: 7px;
	background:#FDFDFD;
	border:solid 1px #9F9387;
	box-sizing:border-box;
	border-radius: 0 15px;
	font-size: 100%;
}
textarea {
	min-height: 140px;
}
input[disabled] {
	background: #dcdada;
}


.button {
	position: relative;
	display: inline-block;
	border-radius: 100px;
	background: #0267CC;
	color: #ffffff;
	padding: 12px 20px;
	border: 0px;
	margin-top: 12px;
	text-align: left;
	text-decoration: none;
	cursor: pointer;
	font-family: Poppins, sans-serif;
    font-size: 16px;
    font-weight: 500;
}
.button:hover{
	background: #005f96;
}
.maxwidth {
	max-width: 652px;
}

label.checkbox{
	position:relative;
	display:block;
	cursor:pointer;
}
label.checkbox + label.checkbox{
	margin-top:7px;
}
	label.checkbox input[type=checkbox], label.checkbox input[type=radio]{
		position:absolute;
		top:0;
		left:0;
		opacity:.01;
	}
	label.checkbox span{
		display:inline-block;
		position:relative;
		padding-left:38px;
	}
	label.checkbox span:before{
		content:"";
		position:absolute;
		top:0;
		left:0;
		width:26px;
		height:26px;
		border-radius:50%;
		background:#FFF;
		border:solid 2px #C2C2C2;
	}
	label.checkbox span:before{
		border-radius:4px;
	}
	label.checkbox span:after{
		content:"";
		position:absolute;
		top:7px;
		left:5px;
		width:14px;
		height:6px;
		border-left:solid 5px #EEE;
		border-bottom:solid 5px #EEE;
		transform:rotate(-45deg);
	}
	label.checkbox:hover span:before, label.checkbox input:focus ~ span:before{
		border-color:#333;
	}
	label.checkbox:hover span:after, label.checkbox input:focus ~ span:after{
		border-color:#DDD;
	}
	label.checkbox input:checked ~ span:after{
		border-color:#0267CC;
	}
	label.checkbox input[disabled] ~ span:before{
		border-color:#C2C2C2;
	}
	label.checkbox input[disabled] ~ span:after{
		border-color:#DDD;
	}
	label.checkbox input[disabled]:checked ~ span:after{
		border-color:#999;
	}
	label.checkbox input[disabled] ~ span{
		opacity:.5;
		cursor:default;
	}
.keuzes:has(:checked) .checkbox:not(:has(:checked)) {
	pointer-events: none;
	opacity: .5;
}

label.radio{
	position:relative;
	display:block;
	cursor:pointer;
}
label.radio + label.radio{
	margin-top:5px;
}
br + label.radio{
	margin-top:5px;
}
	label.radio input[type=radio]{
		position:absolute;
		top:0;
		left:0;
		opacity:.01;
	}
	label.radio span{
		display:inline-block;
		position:relative;
		padding-left:38px;
		line-height:30px;
	}
		label.radio span img{
			display: block;
			margin-left:10px;
		}
	label.radio span:before{
		content:"";
		position:absolute;
		top:0;
		left:0;
		width:26px;
		height:26px;
		border-radius:50%;
		background:#FFF;
		border:solid 2px #C2C2C2;
	}
	label.radio--center span:before{
		top:50%;
		margin-top:-13px;
	}
	label.radio span:after{
		content:"";
		position:absolute;
		top:8px;
		left:8px;
		width:14px;
		height:14px;
		border-radius:50%;
		background:#EEE;
	}
	label.radio--center span:after{
		top:50%;
		margin-top:-5px;
	}
	label.radio:hover span:before{
		border-color:#0267CC;
	}
	label.radio:hover span:after, label.radio input:focus ~ span:after{
		background:#DDD;
	}
	label.radio input:checked ~ span:after{
		background:#0267CC;
	}
	label.radio input[disabled] ~ span:before{
		border-color:#C2C2C2;
	}
	label.radio input[disabled] ~ span:after{
		background:#DDD;
	}
	label.radio input[disabled]:checked ~ span:after{
		background:#999;
	}
	label.radio input[disabled] ~ span{
		opacity:.5;
		cursor:default;
	}
.phone-number{
	display:flex;
	gap:6px;
	width:300px;
	max-width: 100%;
}
	.phone-number input[type=tel]{
		width:100%;
	}

h1 {

	font-size: 32px;
}
h2 {
	font-size: 20px;
}
h1,  h2, h3 {
	color: #0267CC;
}


#header{
	position:fixed;
	top:0;
	left:0;
	width:50vw;
	height:100vh;
	background: url(../images/back.jpg) no-repeat center center;
	background-size:cover;
    border-radius: 85px 0;
	overflow: hidden;
    display: flex;
    align-items: flex-end;
}
.header-text{
	font-size:150%;
	color:#283583;
	font-weight:900;
	line-height: 1;
	width: 50vw;
	background: #0267CC;
    padding: 15px;
    box-sizing: border-box;
}
.header-text .title{
	color: #fff;
	padding: 12px 0;
}
#text{
	margin-left:50%;
	width: 50%;
	min-height:100vh;
	padding:75px 120px;
	box-sizing:border-box;
}
@media (min-width: 64em) {
	#text {padding: 60px;}
}
@media (max-width:64em){
	#header{
		position:relative;
		width:auto;
		height:300px;
		border-radius: 0 0 40px 0;
	}
	#text{
		margin:0;
		width:auto;
		padding:0 25px 100px;
	}
	.header-text {
		position: static;
		width: 100%;
		margin-top: 40px;
	}
}
@media (max-width:35.5em){
	#header{
		height:215px;
    background-position: right center;
	}
	.header-text{
		font-size:125%;
		bottom: 10px;
	}
	#text{
		min-height:0;
	}
}

.logo {
	margin-bottom: 15px;
}
.logo img {
	max-width: 290px;
	width: 70%;
}
.logo-bottom {
	float: right;
	max-width: 200px;
}

.vc-logo {
	width: 100%;
	display: flex;
    justify-content: center;
	margin-top: 50px;
	}
form {
	overflow: hidden;
}

.date, .location, .time {
	margin-top: 10px;
}

.location, .time {
	color: #FFF;
}

.header-text .date {
	color: #E5E5E5;
}

.date {
	font-size: 80%;
}

.title {
    font-size: 140%;
    color: #0267CC;
    font-weight: 600;
}

.location img, .time img {
	vertical-align: middle;
	margin-right: 5px;
}

.location span, .time span {
	font-size: 80%;
	font-weight: normal;
	line-height: 34px;
}

@media(max-width:35.5em){
	input[type=text], input[type=date], input[type=email], select, textarea, input[type=number], .phone-number {
		width: 190%;
	}

	#text {
		padding: 0px 25px 100px;
	}
}

.center {
    position: relative;
    margin: 0 16px;
    max-width: 1280px;
    box-sizing: border-box;
}
.overview {
	padding-top: 110px;
	padding-bottom: 50px;
}
@media (min-width: 48em) {
	.center {
		margin: 0 32px;
	}
}
@media (min-width: 80em) {
	.center {
		margin: 0 auto;
	}
	.overview {
		padding-top: 150px;
	}
}

.logo-overview {
	position: absolute;
	top: 20px;
	left: 20px;
	width: 80%;
	max-width: 300px;
	z-index: 30;
}
.event {
    display: block;
    text-decoration: none;
}
.event-image {
    display: block;
    margin-bottom: 32px;
    width: 100%;
    box-shadow: 0 12px 34px -13px rgb(0 0 0 / 25%);
}
.event b {
    display: block;
    font-size: 150%;
}
.event-date {
    display: block;
    margin: 4px 0 24px;
    padding-bottom: 4px;
}
.info-label {
    position: relative;
    display: block;
    position: relative;
    margin-top: 24px;
    padding-left: 46px;
}
.info-label img {
    position: absolute;
    top: 0;
    left: 0;
    width: 22px;
    height: 22px;
}

a,
a:hover,
a:focus,
label,
button {
    -webkit-tap-highlight-color: transparent;
}

@media (max-width: 64em) {
	.logo {
		position: absolute;
		top: 20px;
		left: 20px;
		text-align: left;
		width: 81%;
	}
	.title {    font-size: 100%;}
	#header {margin-top: 97px;}
	.hide-on-mobile {display: none;}
}
@media (max-width: 30em) {
	#header {
    	margin-top: 21%;
	}
}
@media (max-width: 80em) {
	td, th {
		display: block;
		padding: 0 !important;
		width: 100%;
	}
	td {
		margin-bottom: 20px;
	}
}
.radio:has(.disabled){pointer-events: none;opacity: .4;}