*,
*::before,
*::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	/* border: 1px solid blue; */
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: "Roboto", sans-serif;
}

h1,
h2,
h3,
h4,
button {
	font-family: "Bebas Neue", cursive;
	line-height: 0.9;
}

h1 {
	font-size: 24px;
	line-height: 1;
}

h2 {
	font-size: 3rem;
}

h3 {
	font-size: 3.5rem;
	font-weight: 400;
}

h4 {
	font-size: 1em;
	font-weight: 400;
	letter-spacing: 0.375em;
	line-height: 1.3;
}

img {
	display: block;
	max-width: 100%;
}

.image {
	border-radius: 10px;
}

p {
	line-height: 1.8;
	padding-top: 1rem;
}

.lighttext {
	color: white;
}

.darktext {
	color: #4d4e56;
}

.bluetext {
	color: #00a9c5;
}

.container {
	max-width: 1440px;
	margin: 0 auto;
}

.navbar {
	flex-direction: column;
	align-items: flex-start;
	padding: 1em;
}

.toggle-button {
	position: absolute;
	top: 2.3rem;
	right: 2rem;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 35px;
	height: 25px;
}

.toggle-button .bar {
	height: 3px;
	width: 100%;
	background-color: #00a9c5;
	border-radius: 10px;
	transition: 0.4s;
}

.open .bar1 {
	-webkit-transform: rotate(-45deg) translate(-6px, 6px);
	transform: rotate(-45deg) translate(-7px, 8px);
}

.open .bar2 {
	opacity: 0;
}

.open .bar3 {
	-webkit-transform: rotate(45deg) translate(-6px, -8px);
	transform: rotate(45deg) translate(-7px, -8px);
}

.navbar-links {
	display: none;
	width: 100%;
}

.navbar-links ul {
	font-family: "Bebas Neue", cursive;
	width: 100%;
	flex-direction: column;
}

.navbar-links li {
	font-size: 1.2em;
	padding-block: 0.2em;
	list-style: none;
	text-align: center;
}

.navbar-links li a:link,
.navbar-links li a:visited {
	display: block;
	color: #00a9c5;
	text-decoration: none;
}

.navbar-links.active {
	display: flex;
}

.logo {
	width: min(70%, 320px);
}

.hero {
	color: white;
	height: 700px;
	background: #4d4e56 url("../images/hero.png") 50% 15% no-repeat;
	position: relative;
}

.caption {
	width: 20em;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: 25%;
}
.caption--content {
	position: relative;
	left: 1em;
}

.shaperight {
	position: absolute;
	left: 4em;
	top: -2em;
}

.lineright {
	height: 12px;
	width: 220px;
	background-color: #00a9c5;
	position: absolute;
}

.lineright::before {
	content: "";
	height: 12px;
	width: 6px;
	background-color: #00a9c5;
	position: absolute;
	right: 100%;
	border-bottom-left-radius: 12px;
	border-top-left-radius: 12px;
}

.curveright {
	height: 44px;
	width: 44px;
	border-top: 12px solid #00a9c5;
	border-right: 12px solid #00a9c5;
	position: absolute;
	left: 220px;
	border-top-right-radius: 100%;
}

.curveright::after {
	content: "";
	height: 6px;
	width: 12px;
	background-color: #00a9c5;
	position: absolute;
	top: 100%;
	left: 100%;
	border-bottom-left-radius: 12px;
	border-bottom-right-radius: 12px;
}

.shapeleft {
	position: absolute;
	left: -1em;
}

.curveleft {
	height: 44px;
	width: 44px;
	border-bottom: 12px solid #00a9c5;
	border-left: 12px solid #00a9c5;
	border-bottom-left-radius: 100%;
	position: absolute;
}

.curveleft::before {
	content: "";
	height: 6px;
	width: 12px;
	background-color: #00a9c5;
	position: absolute;
	bottom: 100%;
	right: 100%;
	border-top-left-radius: 12px;
	border-top-right-radius: 12px;
}

.lineleft {
	height: 12px;
	width: 220px;
	background-color: #00a9c5;
	position: absolute;
	top: 32px;
	left: 44px;
}

.lineleft::after {
	content: "";
	height: 12px;
	width: 6px;
	background-color: #00a9c5;
	position: absolute;
	left: 100%;
	border-bottom-right-radius: 12px;
	border-top-right-radius: 12px;
}

#engineering {
	z-index: -1;
	padding-block: 5.25em;
	background: url("../images/grid.png");
}

#landmeten {
	z-index: 0;
	padding-block: 5.25em;
	background-color: #4d4e56;
	position: relative;
}

.landscape {
	z-index: -2;
	opacity: 18%;
	width: 100%;
	height: 100%;
	background: url("../images/landscape.png");
	position: absolute;
	top: 0;
}

.darkgradient {
	z-index: -1;
	height: 440px;
	width: 100%;
	background-image: linear-gradient(
		rgba(77, 78, 86, 0),
		rgba(77, 78, 86, 0.5),
		rgba(66, 67, 74, 1)
	);
	opacity: 20%;
	position: absolute;
	bottom: 0;
}

.image--right {
	z-index: 5;
	position: relative;
	bottom: 5em;
}

#verkeer {
	padding-block: 5.25em;
	background: url("../images/grid.png");
	position: relative;
}

.bluegradient {
	height: 714px;
	width: 100%;
	background-image: linear-gradient(
		rgba(255, 255, 255, 0),
		rgba(255, 255, 255, 0.5),
		rgba(0, 169, 197, 1)
	);
	opacity: 20%;
	position: absolute;
	bottom: 0;
}

#contact {
	position: relative;
	background: url("../images/kantoor.png") no-repeat;
}

.split {
	display: flex;
	flex-direction: column;
}

.col {
	margin: 1em;
	position: relative;
}

.col--single {
	width: 80%;
	text-align: center;
	margin-inline: auto;
	padding-block: 5em;
}

.textbox {
	max-width: 20rem;
}

.logos {
	padding-top: 3.25em;
	/* display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 2em 4em; */
}

.row {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	gap: 0em 2em;
	margin-block: 2em;
}

/* .logoimage {
	display: inline-block;
} */

.bottom-logo {
	width: 60%;
	margin: 0 auto 2.5em;
}

.button {
	background-color: #00a9c5;
	border: 2px solid #00a9c5;
	color: white;
	padding: 0.5em 1.5em;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	border-radius: 24px;
	margin: 2.75em auto 2.75em;
	font-weight: 400;
	font-size: 2em;
	line-height: 1;
	cursor: pointer;
	transition-duration: 0.4s;
}

.button:hover {
	background-color: white; /* Green */
	color: #00a9c5;
}

@media (min-width: 50em) {
	.toggle-button {
		display: none;
	}

	.navbar {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 45px 12.5%;
		border-bottom: 4px solid #00a9c5;
		position: relative;
		flex-direction: row;
	}

	.navbar-links {
		display: block;
		width: 100%;
	}

	.navbar-links ul {
		display: flex;
		flex-direction: row;
		align-items: flex-end;
		justify-content: flex-end;
		font-size: 19px;
		color: #00a9c5;
		height: 37px;
	}

	.navbar-links li {
		padding-left: 20px;
		font-size: 1em;
	}

	.caption {
		left: -30%;
		top: 45%;
	}

	.shaperight {
		left: 25%;
	}

	.shapeleft {
		left: -15%;
	}

	.split {
		flex-direction: row;
	}

	.split > * {
		flex-basis: 100%;
	}

	.split > * + * {
		margin-left: 1.5em;
	}

	.push-right {
		margin-left: auto;
	}

	#engineering {
		padding-bottom: 11em;
	}

	.vcenter {
		display: flex;
		align-items: center;
	}

	.leftcolumn {
		position: relative;
		max-width: 22.5rem;
		margin-left: auto;
	}

	.rightcolumn {
		width: 22.5em;
		position: absolute;
		left: 25em;
		bottom: 0em;
	}

	.image--right {
		position: absolute;
		bottom: 274px;
		left: 104%;
	}

	.bottom-logo {
		width: 20%;
		margin-inline: auto;
	}
}
