/*!
Theme Name: Routekaart het Groenbedrijf
Author: Devomo
Author URI: https://devomo.nl/
Text Domain: groenbedrijf-routekaart
Version: 1 
*/

@font-face {
	font-family: "PolySans";
	src: url("fonts/PolySans-Neutral.woff2") format("woff2");
	font-style: normal;
	font-weight: 400;
}

@font-face {
	font-family: "PolySans";
	src: url("fonts/PolySans-NeutralItalic.woff2") format("woff2");
	font-style: italic;
	font-weight: 400;
}

@font-face {
	font-family: "PolySans";
	src: url("fonts/PolySans-Median.woff2") format("woff2");
	font-style: normal;
	font-weight: 500;
}

*, *::before, *::after {
	font-size: inherit;
	font-family: inherit;
	font-weight: inherit;
	line-height: inherit;
	vertical-align: baseline;
	box-sizing: inherit;
	background-color: transparent;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	color: inherit;
	outline: none;
	border-radius: 0;
	border: 0;
	padding: 0;
	margin: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote::before, blockquote::after, q::before, q::after {
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

img, svg {
	max-width: 100%;
	height: auto;
}

[type=date], [type=datetime-local], [type=email], [type=number], [type=password], [type=search], [type=tel], [type=text], [type=time], [type=url], textarea, select {
	display: block;
	width: 100%;
}

select {
	background: url("data:image/svg+xml,%3Csvg height=\"10\" viewBox=\"0 0 12 10\" width=\"12\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath d=\"m12 0-6 10-6-10z\" fill=\"silver\"/%3E%3C/svg%3E") no-repeat right 1.5rem top 52%;
}

[type=submit], button {
	cursor: pointer;
}

img.alignright, .wp-caption.alignright {
	margin: .5em 0 1em 1em;
	float: right;
}

img.alignleft, .wp-caption.alignleft {
	margin: .5em 1em 1em 0;
	float: left;
}

img.aligncenter, .wp-caption.aligncenter {
	margin-right: auto;
	margin-left: auto;
	display: block;
}

.wp-caption-text {
	text-align: center;
	font-size: .8em;
	opacity: .7;
}

.embed-container {
	position: relative;
	aspect-ratio: 1.7777777778;
	overflow: hidden;
}

.embed-container iframe, .embed-container object, .embed-container embed, .embed-container video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

html {
	line-height: 1;
	font-size: 62.5%;
	font-weight: 400;
	font-family: "PolySans", system-ui, sans-serif;
	color: #000;
	-webkit-font-smoothing: antialiased;
	-webkit-tap-highlight-color: transparent;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	box-sizing: border-box;
}

body {
	font-size: 1.6rem;
}

@media (min-width: 60em) {
	body {
		font-size: 2rem;
	}
}

#site-container {
	position: relative;
	overflow: hidden;
}

.cover-image {
	position: relative;
	width: 100%;
}

.cover-image > img {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}

.wrapper {
	width: calc(100% - clamp(2.4rem, 8vw, 10rem) * 2);
	max-width: 150rem;
	margin: 0 auto;
}

.wrapper-narrow {
	max-width: 138rem;
}

.with-margin {
	margin: clamp(3rem, 12vw, 16rem) 0;
}

.with-padding {
	padding: clamp(3rem, 12vw, 16rem) 0;
}

@media (max-width: 59.99em) {
	header.hidden, section.hidden, footer.hidden {
		display: none !important;
	}
}

h1, h2, h3, .step-letter, h4 {
	color: #0bb83e;
	font-weight: 500;
}

h1 {
	font-size: clamp(3rem, 4vw, 6.5rem);
}

h2 {
	font-size: clamp(2.4rem, 3vw, 3rem);
}

h3, .step-letter {
	font-size: clamp(2rem, 2vw, 2.2rem);
}

b, strong {
	font-weight: 500;
}

em {
	font-style: italic;
}

a {
	text-decoration-thickness: from-font;
}

.text-container h2, .text-container h3, .text-container .step-letter, .text-container h4 {
	margin-block: 4rem 1.5rem;
}

.text-container h2:first-child, .text-container h3:first-child, .text-container .step-letter:first-child, .text-container h4:first-child {
	margin-top: 0;
}

.text-container p, .text-container ul, .text-container ol, .text-container blockquote, .text-container .embed-container, .text-container .wp-caption {
	line-height: 1.2;
	margin-bottom: 1.2em;
	max-width: 100%;
}

.text-container p:last-child, .text-container ul:last-child, .text-container ol:last-child, .text-container blockquote:last-child, .text-container .embed-container:last-child, .text-container .wp-caption:last-child {
	margin-bottom: 0;
}

.text-container ul, .text-container ol {
	position: relative;
	list-style: none;
}

.text-container ul li:not(.gfield), .text-container ol li:not(.gfield) {
	padding-left: 1.25em;
}

.text-container ul li:not(.gfield)::before, .text-container ol li:not(.gfield)::before {
	position: absolute;
	text-indent: -1.25em;
}

.text-container ul li:not(.gfield)::before {
	content: "-";
}

.text-container ol {
	counter-reset: ol-counter;
}

.text-container ol li {
	counter-increment: ol-counter;
}

.text-container ol li::before {
	content: counter(ol-counter) ".";
}

.text-container blockquote {
	padding-left: 1em;
	font-size: 1.4em;
	line-height: 1.2;
	border-left: .1rem solid currentColor;
}

.plus:hover, .extra-toggle:hover .plus {
	-webkit-transform: scale(1.05);
	transform: scale(1.05);
}

.plus {
	display: block;
	width: 4rem;
	height: 4rem;
	border-radius: 50%;
	background: #000 url("images/plus.svg") no-repeat center center/contain;
	-webkit-transition: all .2s ease;
	transition: all .2s ease;
	flex-shrink: 0;
}

.plus-green {
	background-color: #0bb83e;
}

.plus-blue {
	background-color: #008cff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.plus-blue:hover {
	-webkit-transform: scale(1.05) rotate(45deg);
	transform: scale(1.05) rotate(45deg);
}

[type=checkbox] {
	width: 1.6rem;
	height: 1.6rem;
	background: #fff url("images/checkbox.svg") no-repeat center center/0 0;
	box-shadow: 0 0 0 .1rem #000;
	border-radius: .3rem;
	margin-right: 1.2rem;
	-webkit-transition: all .2s ease;
	transition: all .2s ease;
	cursor: pointer;
}

[type=checkbox]:checked {
	background-size: 1.4rem 1.4rem;
}

.links {
	display: -webkit-flex;
	display: flex;
	gap: 1.6rem 3rem;
	flex-wrap: wrap;
}

.iconlink {
	display: -webkit-inline-flex;
	display: inline-flex;
	align-items: center;
	gap: 1.2rem;
	color: #008cff;
	-webkit-transition: color .2s ease;
	transition: color .2s ease;
	text-decoration: none;
}

@media (min-width: 60em) {
	.iconlink {
		font-size: 2.2rem;
	}
}

.iconlink svg {
	display: block;
	-webkit-transition: -webkit-transform .2s ease;
	transition: -webkit-transform .2s ease;
	transition: transform .2s ease;
}

.iconlink:hover {
	color: #0bb83e;
}

.iconlink:hover svg {
	-webkit-transform: translateX(.3rem);
	transform: translateX(.3rem);
}

.header {
	background-color: #e8e0d9;
	padding-top: clamp(3rem, 5vw, 6.6rem);
}

.header-wrapper {
	position: relative;
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2.4rem;
	padding-bottom: clamp(2.4rem, 4vw, 5rem);
}

@media (min-width: 48em) {
	.header-wrapper {
		flex-direction: row;
		align-items: flex-end;
	}
}

.header-logo {
	display: block;
	flex-shrink: 0;
}

@media (min-width: 48em) {
	.header-logo {
		order: 2;
	}
}

.header-logo img {
	display: block;
	width: clamp(18rem, 19vw, 24.5rem);
}

.header-menu {
	display: -webkit-flex;
	display: flex;
	gap: 1.2rem;
}

.header-menu li.current-menu-item a {
	text-decoration: none !important;
	background-color: #008cff;
	color: #fff;
}

.header-menu a {
	display: block;
	padding: 1.2rem 1.6rem 1.1rem;
	background-color: #fff;
	color: #008cff;
	text-decoration: none;
	border-radius: .8rem;
	-webkit-transition: all .2s ease;
	transition: all .2s ease;
}

.header-menu a:hover {
	text-decoration: underline;
}

.header-main {
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: clamp(2rem, 3vw, 4rem);
	flex-grow: 1;
}

@media (min-width: 80em) {
	.header-main {
		padding-right: calc(clamp(24rem, 25vw, 42.8rem) + 2rem);
	}
}

.header-title a {
	text-decoration: none;
	opacity: .5;
	font-size: .8em;
}

.header-title a:hover {
	opacity: 1;
}

.header-image {
	display: none;
}

@media (min-width: 105em) {
	.header-image {
		display: block;
		width: clamp(24rem, 25vw, 42.8rem);
		position: absolute;
		right: calc(clamp(18rem, 19vw, 24.5rem) + 2rem);
		top: 7rem;
		z-index: 5;
	}
}

.phases {
	background-color: #e8e0d9;
}

.phases-slider-container {
	gap: clamp(.5rem, 1.5vw, 1.6rem);
}

.phase {
	position: relative;
	font-size: clamp(1.8rem, 4vw, 2.4rem);
	padding: clamp(1.6rem, 2.5vw, 2.6rem) clamp(2rem, 2vw, 2.5rem);
	border-radius: 1.2rem 1.2rem 0 0;
	-webkit-transition: background-color .2s ease;
	transition: background-color .2s ease;
	flex: 1 1 100%;
	white-space: nowrap;
	background-color: rgba(0, 140, 255, .56);
	color: #fff;
	text-decoration: none;
	text-align: center;
}

@media (min-width: 90em) {
	.phase {
		min-width: 22.4rem;
	}
}

.phase:hover {
	background-color: rgba(0, 140, 255, .76);
}

.phase.active {
	background-color: #008cff;
	color: #fff;
}

.body-article {
	max-width: 70rem;
}

.slider-container {
	display: -webkit-flex;
	display: flex;
}

.slider-container > * {
	flex: 0 0 auto;
}

.home-main {
	padding: clamp(2.4rem, 5vw, 4.6rem) 0 clamp(4rem, 8vw, 12rem);
	background-color: #008cff;
	color: #fff;
}

.participants, .extra, .categories {
	margin-bottom: clamp(2.4rem, 5vw, 4.6rem);
}

.participants-wrapper {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 2.4rem;
}

.participants-items {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1.7rem;
	margin-right: auto;
}

.participant {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	padding: 1.2rem 2rem;
	border: 2px solid currentColor;
	border-radius: 3rem;
	font-size: 16px;
}

label.participant {
	-webkit-transition: all .2s ease;
	transition: all .2s ease;
	cursor: pointer;
}

label.participant:hover, :checked + label.participant {
	background-color: #0bb83e;
	border-color: transparent;
}

label.participant:last-of-type {
	margin-right: auto;
}

.extra-toggle {
	display: none;
	position: relative;
	align-items: center;
	flex: 0 0 auto;
	font-size: 1.6rem;
	gap: 1.2rem;
}

.extra-toggle .extra-toggle-text-open {
	display: none;
}

.extra-toggle.visible {
	display: -webkit-flex;
	display: flex;
}

.extra-toggle.open .plus {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.extra-toggle.open .extra-toggle-text-open {
	display: inline;
}

.extra-toggle.open .extra-toggle-text-closed {
	display: none;
}

.extra {
	display: none;
	background-color: rgba(255, 255, 255, .1);
	margin-inline: -2rem;
	padding: clamp(2.4rem, 8vw, 10rem) 2rem;
}

.extra.visible {
	display: block;
}

.extra-wrapper {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-gap: clamp(1.6rem, 3vw, 4.3rem) clamp(1.6rem, 3vw, 4.3rem);
	gap: clamp(1.6rem, 3vw, 4.3rem) clamp(1.6rem, 3vw, 4.3rem);
	-webkit-animation: extra-wrapper-slide-in .3s ease forwards;
	animation: extra-wrapper-slide-in .3s ease forwards;
}

@media (min-width: 60em) {
	.extra-wrapper {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-gap: clamp(1.6rem, 3vw, 4.3rem) clamp(2.4rem, 8vw, 10rem);
		gap: clamp(1.6rem, 3vw, 4.3rem) clamp(2.4rem, 8vw, 10rem);
	}
}

@-webkit-keyframes extra-wrapper-slide-in {
	from {
		-webkit-transform: translateY(-3rem);
		transform: translateY(-3rem);
		opacity: 0;
	}
	
	to {
		-webkit-transform: none;
		transform: none;
		opacity: 1;
	}
}

@keyframes extra-wrapper-slide-in {
	from {
		-webkit-transform: translateY(-3rem);
		transform: translateY(-3rem);
		opacity: 0;
	}
	
	to {
		-webkit-transform: none;
		transform: none;
		opacity: 1;
	}
}

.extra-title {
	color: inherit;
	grid-column: 1/-1;
}

.extra-video {
	border-radius: 1.2rem;
	overflow: hidden;
}

.steps-wrapper {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-gap: 2.4rem 2.4rem;
	gap: 2.4rem 2.4rem;
}

@media (min-width: 48em) {
	.steps-wrapper {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 2.4rem 2.4rem;
		gap: 2.4rem 2.4rem;
	}
}

@media (min-width: 80em) {
	.steps-wrapper {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		grid-gap: 2.4rem 2.4rem;
		gap: 2.4rem 2.4rem;
	}
}

.step {
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	gap: 2rem;
	background-color: #fff;
	color: #000;
	padding: clamp(3rem, 4vw, 5rem);
	border-radius: clamp(2rem, 4vw, 4.3rem);
	text-decoration: none;
	text-align: left;
}

.step:hover .step-title {
	color: #008cff;
}

.step:hover .step-letter, .step:hover .step-more {
	background-color: #008cff;
}

.step.hidden {
	display: none;
}

.step-header {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	-webkit-transition: color .2s ease;
	transition: color .2s ease;
}

.step-letter {
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	width: 4rem;
	aspect-ratio: 1;
	border-radius: 50%;
	background-color: #0bb83e;
	color: #fff;
	flex: 0 0 auto;
	margin-right: 1.8rem;
	font-size: 2rem;
	-webkit-transition: background-color .2s ease;
	transition: background-color .2s ease;
}

.step-title {
	-webkit-transition: color .2s ease;
	transition: color .2s ease;
}

.step-footer {
	display: -webkit-flex;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	width: 100%;
	margin-top: auto;
}

.steps-empty {
	font-size: 2.1rem;
}

.steps-empty:not(.visible) {
	display: none;
}

.participant-icons {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	gap: .6rem;
	flex: 0 0 auto;
}

.popup {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	background-color: rgba(0, 0, 0, .37);
	z-index: 99;
}

.popup.visible {
	display: block;
}

.popup-box {
	position: relative;
	background-color: #fff;
	padding: clamp(2.4rem, 6vw, 6rem) clamp(2.4rem, 6vw, 7rem);
	-webkit-animation: popup-slide-in-mobile .3s ease forwards;
	animation: popup-slide-in-mobile .3s ease forwards;
	scrollbar-width: none;
	scrollbar-width: none;
	overflow: hidden;
	overflow-y: auto;
	max-height: 100vh;
	max-height: 100 dvh;
}

@media (min-width: 60em) {
	.popup-box {
		box-shadow: 0 0 4rem 0 rgba(0, 0, 0, .3);
		position: absolute;
		width: 80%;
		max-width: 108rem;
		height: auto;
		max-height: 90%;
		left: 50%;
		top: 50%;
		border-radius: clamp(2rem, 4vw, 4.3rem);
		-webkit-animation: popup-slide-in-desktop .3s ease forwards;
		animation: popup-slide-in-desktop .3s ease forwards;
	}
}

@-webkit-keyframes popup-slide-in-mobile {
	from {
		-webkit-transform: translateY(4rem);
		transform: translateY(4rem);
		opacity: 0;
	}
	
	to {
		-webkit-transform: none;
		transform: none;
		opacity: 1;
	}
}

@keyframes popup-slide-in-mobile {
	from {
		-webkit-transform: translateY(4rem);
		transform: translateY(4rem);
		opacity: 0;
	}
	
	to {
		-webkit-transform: none;
		transform: none;
		opacity: 1;
	}
}

@-webkit-keyframes popup-slide-in-desktop {
	from {
		-webkit-transform: translate(-50%, -44%);
		transform: translate(-50%, -44%);
		opacity: 0;
	}
	
	to {
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		opacity: 1;
	}
}

@keyframes popup-slide-in-desktop {
	from {
		-webkit-transform: translate(-50%, -44%);
		transform: translate(-50%, -44%);
		opacity: 0;
	}
	
	to {
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		opacity: 1;
	}
}

.popup-header {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	margin-bottom: clamp(2rem, 5vw, 3rem);
	gap: 2rem;
}

.popup-letter {
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	font-weight: 500;
	text-transform: uppercase;
	font-size: 2.7rem;
	background-color: #0bb83e;
	color: #fff;
	width: 5rem;
	height: 5rem;
	border-radius: 50%;
	flex: 0 0 auto;
}

.popup-close {
	margin-left: auto;
}

@media (min-width: 60em) {
	.popup-close {
		position: absolute;
		right: 3rem;
		top: 3rem;
	}
}

.popup-main {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-gap: clamp(2.4rem, 6vw, 10rem) clamp(2.4rem, 6vw, 10rem);
	gap: clamp(2.4rem, 6vw, 10rem) clamp(2.4rem, 6vw, 10rem);
}

@media (min-width: 48em) {
	.popup-main {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		grid-gap: clamp(3rem, 6vw, 7rem) clamp(3rem, 6vw, 7rem);
		gap: clamp(3rem, 6vw, 7rem) clamp(3rem, 6vw, 7rem);
		align-items: start;
	}
}

@media (min-width: 48em) {
	.popup-text {
		grid-column-end: span 2;
	}
}

.popup-contacts {
	margin-top: clamp(2.4rem, 6vw, 7rem);
}

.popup-contacts-title {
	margin-bottom: 1.3rem;
}

.popup-contacts-items td {
	padding-top: .7rem;
}

.popup-contacts-item-name {
	padding-right: 2rem;
}

.popup-links {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-gap: clamp(2.4rem, 5vw, 4rem) clamp(2.4rem, 5vw, 4rem);
	gap: clamp(2.4rem, 5vw, 4rem) clamp(2.4rem, 5vw, 4rem);
}

.popup-links-group {
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1rem;
}

.popup-links-group-link {
	line-height: 1.25;
}

.popup-participants {
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1.4rem;
	margin-top: clamp(2.4rem, 5vw, 4rem);
}

.categories.empty {
	display: none;
}

.categories-wrapper {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	gap: clamp(2rem, 3vw, 3.7rem);
	flex-wrap: wrap;
}

.category {
	display: -webkit-flex;
	display: flex;
	align-items: center;
	cursor: pointer;
}

.category input {
	position: relative;
	top: -1px;
}

.empty-roadmap {
	background-color: #008cff;
	color: #fff;
}

.empty-roadmap-wrapper {
	min-height: 40rem;
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 2.4rem;
	padding-inline: 2.4rem;
	text-align: center;
}

.empty-roadmap-wrapper svg {
	display: block;
	width: 4rem;
}

.empty-roadmap-wrapper p {
	font-size: 2.4rem;
}

.with-columns {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-gap: clamp(2.4rem, 8vw, 10rem) clamp(2.4rem, 8vw, 10rem);
	gap: clamp(2.4rem, 8vw, 10rem) clamp(2.4rem, 8vw, 10rem);
}

@media (min-width: 48em) {
	.with-columns {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-gap: clamp(2.4rem, 8vw, 10rem) clamp(2.4rem, 8vw, 10rem);
		gap: clamp(2.4rem, 8vw, 10rem) clamp(2.4rem, 8vw, 10rem);
		align-items: start;
	}
}

.with-border-top + .with-border-top {
	margin-top: 0;
}

.with-border-top + .with-border-top > .wrapper {
	padding-top: clamp(3rem, 12vw, 16rem);
	border-top: 1px solid #008cff;
}

.footer {
	padding-block: clamp(2.4rem, 5vw, 5rem);
	background-color: #e8e0d9;
}

.footer-wrapper {
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: clamp(2.4rem, 6vw, 7.4rem);
}

.footer-payoff {
	display: block;
	font-size: clamp(2.4rem, 3vw, 3.5rem);
	font-weight: 500;
}

.footer-menu {
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	gap: clamp(1rem, 2.5vw, 4rem);
	font-size: 1.6rem;
	color: #4b4b4b;
}

@media (min-width: 32em) {
	.footer-menu {
		flex-direction: row;
	}
}

.footer-menu a {
	text-decoration: none;
}

.footer-menu a:hover {
	text-decoration: underline;
}
