@charset "utf-8";
/* CSS Document */

/*
Theme Name: VanderVeer leeg basisthema
Author: VanderVeer Creative Agency
Author URI: https://vdveer.nl
Description: Custom template door VanderVeer
Version: 1.0
Tags: 
*/

body, html {
	padding:0;
	margin:0;
    background-color:#000000;
    color:#FFFFFF;
    font-family: "effra", sans-serif; /* 400, 500, 900 */
    font-size:17px;
    font-size: clamp(17px, 1.4vw, 24px);
    line-height:1.16em;
}
body {
    min-height:100vh;
    background:linear-gradient(115deg, #000000 25%, #00EF93 125%);
    background-attachment: fixed;
    background-size: 120% 120%;
    transition: .3s ease;
	animation: gradient 12s ease infinite;
}

@keyframes gradient {
	0% {
		background-position: 0% 60%;
	}
	50% {
		background-position: 100% 60%;
	}
	100% {
		background-position: 0% 60%;
	}
}

* {	box-sizing: border-box;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale; }

p { font-size:1rem;line-height: 1.16rem;color:inherit;font-weight:400;}
a { color:inherit; }

a.button {
    display: inline-block;
    text-decoration: none;
    color:black;
    background-color: #00EF93;
    border-radius: 1000px;
    font-size:1.05em;
    font-weight:500;
    padding:.5em 1em;
}

.content a:not(.button) {
    text-decoration: none;
    color:#00EF93;
}

.content ul {
    padding:0;
    list-style: none;
    font-weight:300;
}
.content ul li {
    position: relative;
    margin:1em 0;
    padding-left:18px;
}
.content ul li::before {
    content:'•';
    position: absolute;
    font-size:.8em;
    color:#00EF93;
    left:0;
    top:0;
	font-weight:700;
}


.center { text-align: center; }

.space-bottom {	margin-bottom:80px; }
.space-top { margin-top:80px; }
.space { margin-top:80px;margin-bottom:80px; }
.smallspace-bottom { margin-bottom:40px; }
.smallspace-top { margin-top:40px; }
.smallspace { margin-top:40px; margin-bottom:40px; }
.bigspace-bottom { margin-bottom:120px; }
.bigspace-top { margin-top:120px; }
.bigspace {	margin-top:120px;margin-bottom:120px; }

.bodytext {
    margin-top:190px;
}

h1, h2, h3 {
    color:inherit;
}
h1 span, h2 span, h3 span {
    color:#00EF93;
}
h1 {
    font-size:80px;
    font-size: clamp(40px, 5vw, 80px);
    line-height: 0.85em;
    font-weight:700;
    margin:0 0 1.5rem 0;
}
h2 {
    font-size:64px;
    font-size: clamp(30px, 3vw, 58px);
    line-height: 1em;
    font-weight:700;
    margin:0 0 2rem 0;
}
h3 {
    font-size:34px;
    font-size: clamp(22px, 2vw, 34px);
    line-height: 1em;
    font-weight:500;
    margin:1rem 0;
}

.bigcontainer, .container, .midcontainer, .smallcontainer, .minicontainer, .flexrow {
    display: flex;
    flex-wrap: wrap;
	position: relative;
	max-width:100%;
	padding-left:15px;
	padding-right:15px;
	margin-left:auto;
	margin-right:auto;
	overflow:hidden;
}
.row, .flexrow {
	width:100%;
	overflow:hidden;
    padding-left:0;
    padding-right:0;
}
.reverse { flex-direction: row-reverse; }
.bigcontainer { width:1260px; }
.container { width:845px; }
.midcontainer {	width:620px; }

.div5  { width:calc(5% - 12px);  }
.div10 { width:calc(10% - 12px); }
.div15 { width:calc(15% - 12px); }
.div20 { width:calc(20% - 12px); }
.div25 { width:calc(25% - 12px); }
.div30 { width:calc(30% - 12px); }
.div35 { width:calc(35% - 12px); }
.div33 { width:calc(33% - 12px); }
.div40 { width:calc(40% - 12px); }
.div45 { width:calc(45% - 12px); }
.div50 { width:calc(50% - 12px); }
.div55 { width:calc(55% - 12px); }
.div60 { width:calc(60% - 12px); }
.div65 { width:calc(65% - 12px); }
.div70 { width:calc(70% - 12px); }
.div75 { width:calc(75% - 12px); }
.div80 { width:calc(80% - 12px); }

@media screen and (min-width:768px) {
    
}
@media screen and (max-width:767px) {
    .space-bottom { margin-bottom:60px; }
    .space-top { margin-top:60px; }
    .space { margin-top:60px;margin-bottom:60px; }
    .smallspace-bottom { margin-bottom:25px; }
    .smallspace-top { margin-top:25px; }
    .smallspace { margin-top:25px;margin-bottom:25px; }
    .bigspace-bottom { margin-bottom:90px; }
    .bigspace-top { margin-top:90px; }
    .bigspace { margin-top:90px;margin-bottom:90px; }
    .bodytext {
        margin-top:120px;
    }
    .div10, .div15, .div20, .div25 { width:calc(50% - 8px); }
    .div30, .div33, .div35, .div40, .div45, .div50, .div55, .div60, .div65, .div70, .div75, .div80 { width:100%; }
}

header {
    position: fixed;
    width:100%;
    top:0;
    left:0;
    z-index: 99;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.header-logo img, .header-logo lottie-player {
    height:59px;
    width:140px;
    object-fit: contain;
    object-position: center;
    margin: 2em 3em;
}
header nav {
    margin:0 0 0 auto;
}
header nav ul {
    margin:0;
    padding:0;
    list-style: none;
}
header nav ul li {
    display: inline-block;
    padding:0;
    margin:0 1.3em 0 0;
}
header nav a {
    text-decoration: none;
}
header nav.mainnav {
    flex:1 1 0px;
    text-align: center;
}
header nav.mainnav ul li {
    margin:.2em 0 .2em 1.3em;
}
header nav.mainnav a {
    display: block;
    padding:.5em 1.3em;
    border:2px solid #00EF93;
    border-radius: 300px;
    transition: .3s ease;
}
header nav.mainnav a:hover, header nav.mainnav li.current-button-item a {
    background-color:#00EF93!important;
    color:black!important;
}
@media screen and (min-width:769px) {
    header::before {
        content:'';
        position: absolute;
        top:0;
        left:0;
        width:100%;
        height:0;
        background: linear-gradient(to bottom, rgba(0,0,0,.6), rgba(0,0,0,.4), rgba(0,0,0,0.00));
        z-index: -1;
        transition: .3s ease-in-out;
    }
    header.scrolled::before {
        height:100%;
    }
    header.scrolled nav.mainnav a {
        background-color: rgba(0,0,0,0.3);
        backdrop-filter: blur(10px);
    }
}

@media screen and (max-width:960px) {
    .header-logo img, .header-logo lottie-player {
        height:48px;
        width:111px;
        margin: 1em 1.2em;
    }
    header {
        background:linear-gradient(to bottom, rgba(0,0,0,1), rgba(0,0,0,0.00));
    }
}

ul.socials {
    margin:0;
    padding:0;
}
ul.socials li {
    display: inline-block;
    margin:6px;
    padding:0;
    float:left;
}
ul.socials a {
    position: relative;
    display: block;
    border-radius: 100px;
    border:2px solid #00EF93;
    text-decoration: none;
    width:42px;
    aspect-ratio:1/1;
    transition: .3s ease;
}
ul.socials a:hover {
    background-color: #00EF93;
}
ul.socials a img {
    display: block;
    max-width: 21px;
    max-height: 21px;
    aspect-ratio:1/1;
    object-fit: contain;
    object-position: center;
    position: absolute;
    inset:50% 0 0 50%;
    transform:Translate(-50%, -50%);
    transition: .3s ease;
}
ul.socials a:hover img {
    filter:brightness(0);
}

@media screen and (max-width:480px) {
    ul.socials {
        width:100%;
        text-align: center;
    }
    ul.socials li {
        float:none;
    }
}

.hamburger {
    display: none;
    position: absolute;
    top:19px;
    right:35px;
	z-index:99;
	width:45px;
	height:45px;
	cursor: pointer;
}
.hamburger span {
	display:block;
	position: absolute;
	left:50%;
	height:3px;
	width:33px;
	background:#00EF93;
    border-radius: 10px;
	transition: 0.3s ease;
    transform-origin: center;
    transform:translate(-50%, -50%);
}
.hamburger span:nth-child(1) { top:calc(50% - 9px); }
.hamburger span:nth-child(2) { top:50%; }
.hamburger span:nth-child(3) { top:calc(50% + 9px); }
.opennav .hamburger span:nth-child(1) {
	top:50%; transform:translate(-50%, -50%) rotate(45deg);
}
.opennav .hamburger span:nth-child(2) {
	top:50%; opacity:0;
}
.opennav .hamburger span:nth-child(3) {
	top:50%; transform:translate(-50%, -50%) rotate(-45deg);
}

@media screen and (max-width:768px) {
    header {
        align-items: flex-start;
    }
    nav {
        display: none;
    }
    .hamburger {
        display: block;
    }
    header.opennav {
        height:100vh;
        background-color: #00EF93;
        z-index: 999;
        flex-direction: column;
    }
    header.opennav nav {
        display: block!important;
    }
    
    header nav {
        margin:35px auto 0 auto;
    }
    header nav.mainnav {
        flex:0;
    }
    header nav.mainnav ul li {
        display: block;
        margin:15px 0;
    }
}


form input:not([type="submit"]), form textarea {
    -webkit-appearance:none;
    border:none;
    width:100%;
    background-color:rgba(0,239,147,0.35);
    border-radius: 30px;
    font-size:17px;
    color:white;
    resize:none;
    padding:15px;
    font-family: inherit;
}
form input:focus, form textarea:focus {
    outline:none;
}
.forminator-label {
    display: block;
    color:rgba(255,255,255,0.66);
    margin-bottom:.4em;
}
.forminator-error-message {
    font-size:14px;
    color:red;
}
form button {
    -webkit-appearance:none;
    font-family: inherit;
    display: inline-block;
    text-decoration: none;
    color:black;
    background-color: #00EF93;
    border:none;
    cursor: pointer;
    border-radius: 1000px;
    font-size:1.05em;
    font-weight:500;
    padding:.4em 1em;
}

