@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,400..700;1,400..700&display=swap');
: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;
}

/* ALGEMEEN */
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 {
	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;
}
/* EINDE ALGEMEEN */

/* BASIS */
html.no_scroll,
html.no_scroll body{
	overflow-y: hidden;
}
html,
body {
	overflow-x: hidden;
}
body {
    font-family: 'Instrument Sans', sans-serif;
    font-size: var(--standaard-font-size);
    line-height: var(--standaard-line-height);
    font-weight: 400;
	color: var(--text-color);
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 0;
}

/* NAVIGATIE */
.navbar {
	padding: 0;
	width: 100%;
	height: 10rem;
	-webkit-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
    background-color: var(--color-licht-roze);

}
.navbar.scroll {
	background-color: var(--color-wit);
}
a.logo {
	display: block;
	padding: 0;
	margin-bottom: 0;
    z-index: 1;
}
a.logo img {
	width: auto;
	height: 12rem;
}
button.toggle_menu {
	border: none;
    font-size: 2rem;
    background: var(--color-zwart);
    color: var(--color-wit);
    border-radius: 0;
    width: 4rem;
    height: 4rem;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
button.toggle_menu.close {
	border: none;
	font-size: 2rem;
    color: var(--color-wit);
	background: var(--color-zwart);
	padding: 1rem;
}
.mainmenu_wrapper {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1000;
    visibility: hidden;
}
.mainmenu_container {
    position: relative;
    height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: var(--color-licht-roze);
    width: 80%;
    max-width: 40rem;
    z-index: 1;
    transform: translateX(-100%);
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.mainmenu_backdrop {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background-color: rgba(0,0,0,0.7);
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.mainmenu_header {
    padding: 2rem 2rem 0;
    display: flex;
    justify-content: flex-end;
}
.mainmenu_body {
    padding: 2rem 3rem;
    overflow-y: auto; 
    height: 100%;
}
ul.mainmenu {
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
}
    
ul.mainmenu > li > a::before {
    content: " ";
    position: absolute;
    width: 5px;
    height: 5px;
    background-color: var(--color-donker-oranje);
    border-radius: 50%;
    top: -2rem;
    left: 50%;
    transform: translateX(-50%);
    transition: all 0.2s ease-in-out;
}
ul.mainmenu li {
    list-style-type: none;
    margin-top: 1rem;
}
ul.mainmenu li a {
    font-size: 2rem;
    font-weight: bold;
    display: inline-block;
    color: var(--color-wit);
    text-decoration: none;
}
ul.mainmenu li a:hover,
ul.mainmenu > li.current_page_item > a,
ul.mainmenu > li.current_page_parent > a  {
    text-decoration: underline;
}
ul.mainmenu > li > a:hover::before, ul.socials > li > a:hover::before{
    outline: 10px solid var(--color-zwart);

}

ul.mainmenu > li.menu-item-has-children {
    position: relative;
}
ul.mainmenu > li > ul.sub-menu {
    display: 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.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    padding-left: 0;
}
ul.mainmenu > li:hover > ul.sub-menu {
    display: block;
}

ul.socials {
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    padding-top: 1rem;
    margin-top: 1rem;
    border-top: 1px solid var(--color-donker-oranje);
}
ul.socials li a::before {
    content: " ";
    position: absolute;
    width: 5px;
    height: 5px;
    background-color: var(--color-donker-oranje);
    border-radius: 50%;
    top: -2rem;
    left: 50%;
    transform: translateX(-50%);
    transition: all 0.2s ease-in-out;
}
ul.socials li {
    list-style-type: none;
    margin-top: 1rem;
}
ul.socials li a {
    font-size: 2rem;
    font-weight: bold;
    color: var(--color-wit);
    text-decoration: none;
}
ul.socials li a:hover,
ul.socials > li.current_page_item > a,
ul.socials > li.current_page_parent > a  {
    text-decoration: underline;
}

ul.socials > li.menu-item-has-children {
    position: relative;
}
ul.socials > li > ul.sub-menu {
    display: 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.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    padding-left: 0;
}
ul.socials > li:hover > ul.sub-menu {
    display: block;
}
@keyframes fade {
    from {
        opacity: 0;
        transform: translate3d(0, -5%, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.mainmenu_footer {
    margin-top: auto;
    padding: 1rem 2rem;
}


/* Menu active */
.navbar.active .mainmenu_wrapper {
    visibility: visible;
}
.navbar.active .mainmenu_container {
    transform: translateX(0);
}
.navbar.active .mainmenu_backdrop {
    visibility: visible;
    opacity: 1;
}


/* Social media buttons */
ul.socialmedia_buttons {
    display: flex;
    margin: 0;
    padding: 0;
}
ul.socialmedia_buttons li {
    list-style: none;
    margin-left: 1rem;
}
ul.socialmedia_buttons li:first-child {
    margin-left: 0;
}
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);
}
ul.socialmedia_buttons li:first-child {
    margin-left: 0;
}


ul.hoofdmenu {
	list-style: none;
	padding: 0;
	margin: 0;
}
ul.hoofdmenu > li {
	margin-top: 1rem;
}    
ul.hoofdmenu > li:first-child {
	margin-top: 0;
}
ul.hoofdmenu > li > a {
	font-size: 1.4rem;
	color: var(--color-zwart);
	text-decoration: none;
	font-weight: 600;
}
ul.hoofdmenu > li a:hover,
ul.hoofdmenu > li.current_page_item > a,
ul.hoofdmenu > li.current_page_parent > a   {
	text-decoration: underline;
}
ul.hoofdmenu > li.menu-item-has-children {
	position: relative;
}
ul.hoofdmenu ul.sub-menu {
	list-style: none;
	padding: 0 0 0 0.5rem;
}
ul.hoofdmenu ul.sub-menu > li {
	
}
ul.hoofdmenu ul.sub-menu > li > a {
	text-decoration: none;
    display: block;
}

/* Contentblokken */
.contentblok {
    position: relative;
	margin-top: var(--contentblok-margin-top);
}
#content .contentblok:first-of-type {
	margin-top: 6rem;
} 	
#content .contentblok:last-of-type {
	margin-bottom: var(--contentblok-margin-top);
} 	

/* FOOTER */
footer {
	font-size: 1.6rem;
	padding: 3rem 0;
	color: var(--color-zwart);
	background: var(--color-wit); 
	margin-top: auto;
}
.row_footer {
	--bs-gutter-y: 3rem;
}
footer ul {
	padding: 0;
	margin: 0;
	list-style: none;
}
footer a {
	color: var(--color-zwart);
}
footer a:hover {

}
footer ul,
footer p { 
}
footer .footer-content-1 {
    padding: 4rem 2rem;
    word-wrap: break-word;
}
footer .content-2 {
    color: var(--color-donker-oranje);
}

footer .footer-content-1 span {
    display: block;
}

footer .footer-content-1 h2 {
    color: var(--color-donker-oranje);

}
footer .footer-content-1 p {
}
footer .footer-content-3 {
    padding: 4rem 2rem;
    word-wrap: break-word;
}
footer .footer-content-3 p {
}


#copyright {
	padding: 2.4rem 0;
	font-size: 2rem;
	color: var(--color-wit); 
	background-color: var(--color-licht-roze); 
    letter-spacing: 2px;
}
#copyright span {
    color: var(--color-donker-oranje);
}

/*Shortcodes, zie /core/shortcodes.php*/
ul.socialmedia {

}
ul.socialmedia li {
	margin-left: 1rem;
	font-size: 2rem;
}
ul.socialmedia li:first-child {
	margin-left: 0;
}


/***********************************************
FORMULIEREN
***********************************************/

.gform_wrapper {
    --hoogte-veld: 3rem;
}

.gform_wrapper .gform_validation_errors,
.gform_ajax_spinner {
    display: none !important;
}
h2.gform_title {
    font-size: 4rem;
    margin: 0 0 1rem;
}
div.gform_wrapper .gform_heading {
    margin-bottom: 4rem;
}
div.gform_wrapper .gform_fields {
    grid-row-gap: 3rem;
}
div.gform_wrapper .gform_required_legend {
    display: none;
}
div.gform_wrapper .gfield_required {
    color: var(--color-zwart);
}
div.gform_wrapper input:not([type=radio]):not([type=checkbox]):not([type=image]):not([type=file]) {
    border: 0;
    background-color: var(--color-wit-roze);
    border-radius: 25px;
}
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*/
.gfield {
    position: relative !important;
}
div.gform_wrapper .gfield.gf_animate_label .gfield_label {

    font-size: 1.2rem;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
label.gfield_label.gform-field-label {
    position: absolute;
    top: 1rem;
    left: 1.25rem;
    margin: 0;
    z-index: 1;
    font-size: 1.4rem !important;

}
div.gform_wrapper .gfield.gf_focus_label .gfield_label {
    top: -22px;
    font-size: 60%;
    color: var(--zwart);
}

/*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);
}
div.gform_wrapper .validation_message {
    margin-left: 1.25rem;
} 
/*Footer / Button*/

div.gform_wrapper .gform_footer, 
div.gform_wrapper .gform_page_footer {
    margin: 3rem 0 0 0;
    padding: 0 0;
    justify-content: end;
}
div.gform_footer .gform-loader {
    order: 1;
    margin-right: 3rem;
}
div.gform_footer .gform_button {
    background-color: transparent !important;
    color: var(--color-donker-oranje) !important;
    margin-left: -3rem !important;
    box-shadow: none !important;
    position: relative !important;
    font-size: 1.4rem !important;
    order: 2 !important;
    display: flex !important;
    flex-direction: row !important;
    width: auto !important;
    font-weight: bold !important;
    border-radius: 25px !important;
}
div.gform_footer .gform_button:focus {
    outline: none !important;
    border: 0 !important;
}

div.gform_footer .gform_button:hover {
    color: var(--color-zwart) !important;
}


div.gform_footer .gform_button span::after {
    position: relative;
    left: 1rem;
    transform: translateX(-50%);
    width: 3rem;
    height: 3rem;
    background-color: var(--color-zwart);
    border: 4px solid var(--color-grijs);
    color: var(--color-donker-oranje);
    content: "\f054";
    font: var(--fa-font-regular);
    border-radius: 50%;
    font-size: 1rem;
    line-height: 1rem !important;
    padding: 0.8rem;
    cursor: pointer;
    order: 3 !important;
    display: inline-flex;
    margin-left: 1rem;
    justify-content: center;
    align-items: center;
}

/*Upload veld*/



@media (min-width: 576px) {
    .mainmenu_container {
        max-width: 40rem;
    }
} 


/***********************************************
TABLET
***********************************************/
@media (min-width: 768px) {
	/* VARIABELEN */
    :root {
        --standaard-font-size: 2rem;
        --contentblok-margin-top: 10rem;	
    }
    /* Standaard WP classes */
    .alignleft {
        float: left;
        margin: 0 2rem 2rem 0;
    }
    .alignright {
        float: right;
        margin: 0 0 2rem 2rem;
    }
    .alignnone {
        display: block;
    }

    
}

@media (min-width: 992px) {
    .navbar {
        -webkit-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out;
        position: absolute;
    }
    .mainmenu_wrapper {
        position: relative;
        height: auto;
        width: auto;
        visibility: visible;
    }
    .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 {

        overflow: initial;
        display: flex;
        gap: 3rem;
    }
    ul.mainmenu {
        flex-direction: row;
        gap: 3rem;
    }

    ul.mainmenu li {
        margin-top: 0;
        position: relative;
    }
    ul.mainmenu > li {
        margin-left: 1rem;
    }
    ul.mainmenu > li:first-child {
        margin-left: 0;
    }
    ul.mainmenu > li > ul.sub-menu {
        position: absolute;
        display: none;
        margin-top: 2rem; /* zelfde als before height */
        -webkit-animation-duration: 0.4s;
        animation-duration: 0.4s;
        -webkit-animation-fill-mode: both;
        animation-fill-mode: both;
        -webkit-animation-name: fade_submenu;
        animation-name: fade_submenu;
        -webkit-transition: all 0.2s ease-in-out;
  
        border-radius: 25px;
        transition: all 0.2s ease-in-out;        
        justify-content: center;
        align-items: center;
        width: 100%;
        white-space: nowrap;
    }
    ul.mainmenu > li > .sub-menu::before {
        content: "";
        display: flex;
        width: 100%;
        height: 2rem; /* zelfde als margin-top  */
        background-color: transparent;
        margin-top: -2rem; /* zelfde als hoogte  */
    }
    ul.mainmenu > li > .sub-menu li {
        padding: 1rem 2rem;
        background-color: var(--color-zwart);
        border-radius: 25px;
    }

    ul.mainmenu > li:hover > ul.sub-menu {
        display: flex;
        flex-direction: column;
    }
    ul.socials {
        flex-direction: row;
        margin-top: 0;
        padding-top: 0;
        border-top: none;
        padding-left: 3rem;
        border-left: 1px solid var(--color-donker-oranje);
    }

    ul.socials li {
        margin-top: 0;
        position: relative;
    }
    ul.socials > li {
        margin-left: 1rem;
    }
    ul.socials > li:first-child {
        margin-left: 0;
    }

    ul.socials > li:hover > ul.sub-menu {
        display: block;
    }

    @keyframes fade_submenu {
        from {
            opacity: 0;
            transform: translate3d(0, -20%, 0);
        }
        to {
            opacity: 1;
            transform: translate3d(0, 0, 0);
        }
    }
    ul.mainmenu > li, ul.mainmenu > li a {
        max-width: 18rem;
    }

    
        
    #content .contentblok:first-of-type {
        margin-top: 16rem;
    } 	
}

/***********************************************
DESKTOP
***********************************************/
@media (min-width: 1200px) {
	/* VARIABELEN */
    :root {
        --contentblok-margin-top: 15rem;	
    }

    
    a.logo img {
        height: 28rem;
        margin-top: 8rem;
    }
    .navbar {
        height: 22rem;
    }
}

@media (min-width: 1400px) {
    .container, .container-lg {
        max-width: 1735px !important; 
    }
    ul.mainmenu > li, ul.mainmenu > li a {
        max-width: 100%;
    }
    footer .footer-content-1 {
        padding: 4rem 8rem;
    }
    
    #content .contentblok:first-of-type {
        margin-top: 33rem;
    }

}

@media (min-width: 1620px) {
    footer .footer-content-1 {
        padding: 4rem 16.8rem;
    }
}

@media (min-width: 2560px) {
	
}

    @supports (animation-timeline: scroll()) {
        a.logo img{
            animation: rotate 2s linear both;
            animation-timeline: scroll(root);
            animation-range: contain;
        }


        @keyframes rotate {
            0% {
                transform: rotate(0deg);
            }
            100% {
                transform: rotate(360deg);
            }
        }
    }
