:root {
    /*Standaard ruimte tussen blokken*/
	--contentblok-margin-top: 6rem;	
}
/* Bootstrap gutter ruimtes */
.container, 
.container-fluid, 
.container-lg, 
.container-md, 
.container-sm, 
.container-xl, 
.container-xxl {
	--bs-gutter-x: 3rem;
}
.row {
	--bs-gutter-x: 3rem;
}

body [data-aos=fade-up] {
    transform: translate3d(0,20px,0);
}



/* ALGEMEEN */
.ratio {
    overflow: hidden;
}
.ratio>* {
    position: absolute;
    top: -2%;
    left: -2%;
    width: 104%;
    height: 104%;
    max-width: initial;
}
a,
a:hover,
a:focus {
	color: var(--link-color);
}
a:hover,
a:focus {
	color: var(--link-hover-color);
}
img {
    max-width: 100%;
    height: auto;
}
button:focus {
	outline: none;
}
.last_no_margin > *:last-child {
	margin-bottom: 0;
}
form, iframe, .wp-caption {
    max-width: 100%;
	margin-bottom: var(--standaard-margin-bottom);
}
p,
ul,
ol,
table {
	font-style: normal;
	font-weight: 400;
	margin-top: 0;
	margin-bottom: var(--standaard-margin-bottom);
}
img {
	max-width: 100%;
}
.alignleft, .alignright, .alignnone {
	display: block;
}
.wp-caption {
    width: 100% !important;
}
.wp-caption p {
	color: var(--color-zwart);
	font-size: 1.4rem;
	font-weight: 500;
	font-style: italic;
	letter-spacing: normal;
	text-align: left;
    margin-bottom: 0;
	padding: 0.5rem 2rem;
}
.wp-caption * {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}
.size-thumbnail, .size-medium, .size-large, .size-full {
	margin-bottom: var(--standaard-margin-bottom);
}
/*Mail shortcode*/
.cryptedmail:after {
	content: attr(data-name) "@" attr(data-domain) "." attr(data-tld); 
}
/*Ratio voor iframes > WP Rocket fix*/
.ratio > div {
    position: initial !important;
    padding: 0 !important;
}

.typewriter-container .word {
    display: inline-block;
}
.typewriter-container .letter {
    opacity: 0;
    display: inline-block;
    transition: opacity 0.1s ease-in-out;
}


 

@keyframes fade {
    from {
        opacity: 0;
        transform: translate3d(0, -5%, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}
/* EINDE ALGEMEEN */

/* BASIS */
html.no_scroll,
html.no_scroll body{
	overflow-y: hidden;
}
html,
body {
	overflow-x: hidden;
}
body {
    font-size: var(--standaard-font-size);
    line-height: var(--standaard-line-height);
    background-color: var(--color-donkerpaars);
    font-weight: 400;
	color: var(--text-color);
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 0;
}

/* NAVIGATIE */
.navbar {
	padding: 0;
	width: 100%;
	height: 8.8rem;
	background-color: transparent;
	-webkit-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
.navbar.scroll {
}
.navbar.hide {
    transform: translateY(-100%);
}
.navbar_wrapper {
    position: relative;
    column-gap: 0.8rem;
}

a.logo {
	display: block;
	padding: 0;
	margin-bottom: 0;
    margin-right: auto;
    align-self: flex-start;
    position: relative;
    z-index: 10;
}
a.logo img {
	width: auto;
	height: 3.2rem;
}
button.toggle_menu {
    flex-shrink: 0;
    display: flex;
    width: 4rem;
    height: 4rem;
    padding: 1.2rem 1.6rem;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    border: none;
    background: none;
    position: relative;
    z-index: 10;
}
button.toggle_menu svg {
	width: 1.6rem;
    height: 1.6rem;
    flex-shrink: 0;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
button.toggle_menu svg.close_menu {
    display: none;
}
button.toggle_menu.toggle_menu_active svg.open_menu {
    display: none;
}
button.toggle_menu.toggle_menu_active svg.close_menu {
    display: block;
}
.mainmenu_wrapper {
    position: fixed;
    width: 100%;
    height: auto;
    padding-top: 12rem;
    padding-bottom: 20rem;
    top: 0;
    left: 0;
    display: block;
    visibility: hidden;
    opacity: 0;
    filter: alpha(opacity=0);
    -webkit-transform-origin: 0 0;
    -moz-transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    transform-origin: 0 0;
    -webkit-transition: all 0.2s ease-in-out 0s;
    -o-transition: all 0.2s ease-in-out 0s;
    transition: all 0.2s ease-in-out 0s;
    -webkit-transform: rotateX(-90deg);
    -ms-transform: rotateX(-90deg);
    -o-transform: rotateX(-90deg);
    transform: rotateX(-90deg);
    background: rgb(24,24,40);
    background: linear-gradient(180deg, rgba(24,24,40,1) 0%, rgba(24,24,40,1) 60%, rgba(239,239,239,0) 100%);
}

/* Menu active */
.navbar.active .mainmenu_wrapper {
    visibility: visible;
    opacity: 1;
    filter: alpha(opacity=100);
    -webkit-transform: rotateX(0deg);
    -ms-transform: rotateX(0deg);
    -o-transform: rotateX(0deg);
}

.mainmenu_container {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 100%;
    z-index: 1;
    background-color: transparent
}
.mainmenu_body {
    display: flex;
    padding: 0.8rem calc(var(--bs-gutter-x) * .5) 2.4rem;
    height: 100%;
    width: 100%;
    flex-direction: column;
    flex-grow: 1;
}
ul.mainmenu {
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    gap: 1.6rem;
    flex-grow: 1;
    height: 100%;
}
ul.mainmenu li {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    padding-top: 1.8rem;
    line-height: 100%;
    list-style-type: none;
}
ul.mainmenu > li {
    border-top: 1px solid rgba(26, 64, 75, 0.15);
}
ul.mainmenu > li:first-of-type {
    padding-top: 0;
    border: none;
}
ul.mainmenu > li a {
    display: inline-block;
	font-family: "Montserrat", sans-serif;
    font-size: 2rem;
    text-transform: uppercase;
    color: var(--color-wit);
    font-weight: 700;
    text-decoration: none;
}

ul.mainmenu li a:hover,
ul.mainmenu > li.current_page_item > a,
ul.mainmenu > li.current_page_parent > a  {
    color: var(--color-wit);
}

ul.mainmenu > li.menu-item-has-children {
    position: relative;
}
ul.mainmenu > li.menu-item-has-children span.toggle_submenu {
    display: block;
    width: 3.2rem;
    height: 2.6rem;
    margin-left: auto;
    background-repeat: no-repeat;
    background-size: 16px 16px;
    background-position: center center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='none'%3E%3Crect y='7' width='16' height='2' rx='1' fill='%231A404B'/%3E%3Crect x='7' width='2' height='16' rx='1' fill='%231A404B'/%3E%3C/svg%3E");
}

ul.mainmenu > li > ul.sub-menu {
    display: none;
    width: 100%;
    padding-left: 0;
    list-style-type: none;
    -webkit-animation-duration: 0.4s;
    animation-duration: 0.4s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-name: fade;
    animation-name: fade;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}
ul.mainmenu > li.submenu_active > ul.sub-menu {
    display: flex;
    flex-direction: column;
    row-gap: 0.8rem;
    padding: 0.8rem 1.2rem;
}

ul.mainmenu > li > ul.sub-menu li a {
    color: var(--color-wit);
    font-size: 1.8rem;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
ul.mainmenu > li > ul.sub-menu li a:hover {
    color: var(--color-paars);
}

/* Social media buttons */
ul.socialmedia_buttons {
    display: flex;
    margin: 0;
    padding: 0;
    gap: 1rem;
}
ul.socialmedia_buttons li {
    list-style: none;
}
ul.socialmedia_buttons li a {
    list-style: none;
    font-size: 2rem;
    color: var(--color-wit);
}
ul.socialmedia_buttons li a:hover {
    color: var(--color-secondary);
}



/* Contentblokken */
.contentblok {
    position: relative;
	padding-top: var(--contentblok-margin-top);
	padding-bottom: var(--contentblok-margin-top);
}
#content .contentblok:last-of-type {
	/* margin-bottom: var(--contentblok-margin-top); */
} 	

.contentblok.has_bg.wit {
    background-color: var(--color-wit);
    color: var(--color-zwart);
}

.contentblok.has_bg.wit:has(+ .contentblok.has_bg.wit),
.contentblok.has_bg.donkerpaars:has(+ .contentblok.has_bg.donkerpaars) {
	padding-bottom: calc(var(--contentblok-margin-top) / 2);
}
.contentblok.has_bg.wit + .contentblok.has_bg.wit,
.contentblok.has_bg.donkerpaars + .contentblok.has_bg.donkerpaars {
	padding-top: calc(var(--contentblok-margin-top) / 2);
}

.divider {
    height: var(--contentblok-margin-top);
}
.contentblok.has_bg.donkerpaars + .divider {
    background-color: var(--color-donkerpaars);
}
.contentblok.has_bg.wit + .divider {
    background-color: var(--color-wit);
}

.contentblok_titel {
    margin-bottom: 3rem;
}
.contentblok_titel h2 {
	letter-spacing: 5px;
    margin-bottom: 0;
}
.contentblok_titel h2.lijn_onder {
    margin-bottom: 3rem;
}
.contentblok_titel p {
    text-transform: uppercase;
    color: var(--color-grijs);
}
/* FOOTER */
footer {
	font-size: 1.4rem;
	padding: 3rem 0;
	color: var(--color-grijs);
	background: var(--color-donkerpaars); 
	margin-top: auto;
}
.row_footer {
	--bs-gutter-y: 3rem;
}
footer ul {
	padding: 0;
	margin: 0;
	list-style: none;
}
footer a {
    text-decoration: none;
	color: var(--color-grijs);
}
footer a:hover {

}
footer ul {
    display: flex;
    flex-wrap: wrap;
}
footer ul.footermenu li:not(:first-child) {
    padding-left: 1.5rem;
    margin-left: 1.5rem;
    border-left: 1px solid #4e5b6b;
}
footer ul.footermenu li a {
	color: var(--color-grijs);
}



/*Shortcodes, zie /core/shortcodes.php*/
footer ul.socialmedia_buttons {
    display: flex;
    column-gap: 1rem;
}
ul.socialmedia_buttons li {
	font-size: 2rem;
}
ul.socialmedia_buttons li a {
	color: var(--color-groen);
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
ul.socialmedia_buttons li a:hover {
	color: var(--color-oranje);
}


/***********************************************
FORMULIEREN
***********************************************/
/*
.gform_wrapper.gravity-theme {
    --hoogte-veld: 3rem;
}

.gform_wrapper.gravity-theme .gform_validation_errors,
.gform_ajax_spinner {
    display: none !important;
}
h2.gform_title {
    font-size: 4rem;
    margin: 0 0 1rem;
}
div.gform_wrapper.gravity-theme .gform_heading {
    margin-bottom: 4rem;
}
div.gform_wrapper.gravity-theme .gform_fields {
    grid-row-gap: 3rem;
}
div.gform_wrapper.gravity-theme .gform_required_legend {
    display: none;
}
div.gform_wrapper.gravity-theme .gfield_required {
    color: var(--color-zwart);
}
div.gform_wrapper.gravity-theme input:not([type=radio]):not([type=checkbox]):not([type=image]):not([type=file]) {
    background-color: transparent;
    border: 2px solid var(--color-zwart);
    outline: none;
    padding: 0;
    height: 3rem;
    color: var(--color-zwart);
    font-weight: 600;
    font-size: 2rem;
}
div.gform_wrapper.gravity-theme .gfield textarea {
    font-weight: 600;
    background-color: transparent;
    border: none;
    border-bottom: 2px solid var(--color-zwart);
    color: var(--color-zwart);
    padding: 0;
    outline: none;
    font-size: 2rem;
    resize: none;
    height: 18rem;
}
.gfield {
    position: relative;
}*/

/*Animeer labels, gebruik hiervoor de class gf_animate_label per veld*/
/*
div.gform_wrapper.gravity-theme .gfield.gf_animate_label .gfield_label {
    position: absolute;
    top: var(--hoogte-veld);
    transform: translateY(-100%);
    left: 0;
    margin: 0;
    font-size: 2.2rem;
    cursor: text;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
div.gform_wrapper.gravity-theme .gfield.gf_animate_label.gf_focus_label .gfield_label {
    font-size: 60%;
    transform: translateY(calc(-100% - 3rem));
    color: var(--color-zwart);
}
div.gform_wrapper.gravity-theme .gfield.gf_animate_label.gf_focus_label .gfield_required {
    color: var(--color-zqwart);
}*/

/*Errors*/
/*
div.gform_wrapper.gravity-theme .gfield_validation_message, 
div.gform_wrapper.gravity-theme .validation_message {
    padding: 0;
    background: none;
    border: none;
}
div.gform_wrapper.gravity-theme .gfield_error label {
    color: var(--color-wit);
}*/

/*Footer / Button*/
/*
div.gform_wrapper.gravity-theme .gform_footer, 
div.gform_wrapper.gravity-theme .gform_page_footer {
    margin: 4rem 0 0 0;
    padding: 0 0;
}
div.gform_wrapper.gravity-theme .gform_button {
    background-color: transparent;
    color: var(--color-zwart);
    border: 0.2rem solid var(--color-zwart);
    font-size: 2.2rem;
    margin: 0 !important;
}
div.gform_wrapper.gravity-theme .gform_button:hover {
    color: var(--color-wit);
    background-color: var(--color-zwart);
    border: 0.2rem solid var(--color-zwart);
}*/

/*Upload veld*/
/*
div.gform_wrapper.gravity-theme .button_upload label {
    position: relative !important;
    margin-bottom: 0.5rem !important;
}
div.gform_wrapper.gravity-theme .button_upload input[type="file"] {
    width: 350px;
    max-width: 100%;
    color: var(--color-zwart);
    padding: 12px;
    background: #fff;
    border-radius: 10px;
    border: 1px solid var(--color-zwart);
    font-size: 2rem;
}
div.gform_wrapper.gravity-theme .gform_fileupload_rules {
    margin-top: 0;
}


@media (min-width: 576px) {
    .mainmenu_container {
        max-width: 40rem;
    }
}
*/

/***********************************************
TABLET
***********************************************/
@media (min-width: 768px) {
	
    /* Standaard WP classes */
    .alignleft {
        float: left;
        margin: 0 2rem 2rem 0;
    }
    .alignright {
        float: right;
        margin: 0 0 2rem 2rem;
    }
    .alignnone {
        display: block;
    }

    
    .contentblok_titel {
        margin-bottom: 6rem;
    }
    
}

@media (min-width: 992px) {
    /* VARIABELEN */
    :root {
        --standaard-font-size: 1.6rem;
        --contentblok-margin-top: 10rem;	
    }
    .navbar {
        height: 13rem;
        -webkit-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out;
    }
    .navbar > .container-xl {
        width: 95%;
    }
    
    a.logo img {
        height: 9rem;
    }
    .mainmenu_wrapper {
        position: absolute;
        visibility: visible;
        padding: 0;
        background: none;
        opacity: 1;
        width: auto;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
    }
    .mainmenu_container {
        height: auto;
        width: 100%;
        max-width: 100%;
        transform: initial;
        background: none;
    }
    .mainmenu_header,
    .mainmenu_footer {
        display: none;
    }
    button.toggle_menu {
        display: none;
    }
    .mainmenu_body {
        padding: 0;
        overflow: initial;
    }
    ul.mainmenu {
        flex-direction: row;
        justify-content: flex-end;
    }
    ul.mainmenu li {
        margin-top: 0;
        padding-top: 0;
    }
    ul.mainmenu > li {
        border: none;
        margin-left: 4rem;
    }
    ul.mainmenu > li:first-child {
        margin-left: 0;
    }
    ul.mainmenu > li a {
        position: relative;
        font-size: 1.4rem;
    }
    ul.mainmenu > li > a::after {
        content: "";
        display: block;
        position: absolute;
        width: 0;
        height: 2px;
        bottom: -4px;
        background-color: var(--color-wit);
        -webkit-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out;
    }
    
    ul.mainmenu li a:hover::after,
    ul.mainmenu > li.current_page_item > a::after,
    ul.mainmenu > li.current_page_parent > a::after  {
        width: 100%;
    }

    ul.mainmenu > li > ul.sub-menu {
        position: absolute;
        display: block;
        margin-top: 2rem; /* zelfde als before height */
        visibility: hidden;
        opacity: 0;
        filter: alpha(opacity=0);
        -webkit-transform-origin: 0 0;
        -moz-transform-origin: 0 0;
        -ms-transform-origin: 0 0;
        transform-origin: 0 0;
        -webkit-transition: all 0.2s ease-in-out 0s;
        -o-transition: all 0.2s ease-in-out 0s;
        transition: all 0.2s ease-in-out 0s;
        -webkit-transform: rotateX(-90deg);
        -ms-transform: rotateX(-90deg);
        -o-transform: rotateX(-90deg);
        transform: rotateX(-90deg);
    }
    ul.mainmenu > li > .sub-menu::before {
        content: "";
        display: block;
        width: 100%;
        height: 2rem; /* zelfde als margin-top  */
        background-color: transparent;
        margin-top: -2rem; /* zelfde als hoogte  */
    }
    ul.mainmenu > li:hover > ul.sub-menu {
        visibility: visible;
        opacity: 1;
        filter: alpha(opacity=100);
        -webkit-transform: rotateX(0deg);
        -ms-transform: rotateX(0deg);
        -o-transform: rotateX(0deg);
    
    }
    
}

/***********************************************
DESKTOP
***********************************************/
@media (min-width: 1200px) {
	/* VARIABELEN */
    :root {
        --contentblok-margin-top: 12rem;	
    }
    
    .contentblok_titel {
        margin-bottom: 9.5rem;
    }
}

@media (min-width: 1400px) {
	
}

@media (min-width: 1920px) {
	
}

@media (min-width: 2560px) {
	
}