	/*
 Theme Name:     2Special
 Theme URI:      https://www.elegantthemes.com/gallery/divi/
 Description:    2Special customizations
 Author:         Elegant Themes
 Author URI:     https://www.elegantthemes.com
 Template:       Divi
 Version:        1.0.0
*/


/* =Theme customization starts here
------------------------------------------------------- */

:root {
    --color-first: var(--gcid-primary-color);
    --color-second: var(--gcid-secondary-color);
    --color-third: var(--gcid-fhsfxjyclt); 
	--color-fourth: var(--gcid-krvil1x3o0);
	--0\.125: clamp(0.109375rem, 0.125vw, 0.140625rem);	
	--0\.25: var(--gvid-vy57bgnxct);
	--0\.375: clamp(0.328125rem, 0.375vw, 0.421875rem);	
	--0\.5: var(--gvid-0ne3fxa72f);
	--0\.75: var(--gvid-2ed209119i);
	--1: var(--gvid-vslsac6s0g);
	--1\.25: var(--gvid-vd58ybg19s);
	--1\.5: var(--gvid-9h3ud2r780);
	--1\.75: var(--gvid-705m5imous);
	--2: var(--gvid-r0azl771if);
	--2\.5: var(--gvid-qbq8hdutc4);
	--3: var(--gvid-8fxn9shd9v);
	--3\.5: var(--gvid-ng6xggmgbh);
	--4: var(--gvid-rdq1ib6die);
	--4\.5: var(--gvid-0rh7tmkqew);
	--5: var(--gvid-209c1xt2u5);

}

html,
body {
	font-size:15px;
	line-height:1.4!important;
	font-weight:400;
}



.et_pb_text h1,
.et_pb_text h2,
.et_pb_text h3,
.et_pb_text h4,
.et_pb_text h5,
.et_pb_text h6
{
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
	line-height:1.2;
}

/*-------------------------------- START Buttons ------------------------------------------- */

a.custom-button, .custom-button a, .custom-form.custom-button input.gform_button {
	text-align: center!important;
    display: flex!important;
    transition: var(--transition);
	align-items: center;
	width:fit-content;
	border-radius: var(--0\.25)!important;
	padding-top: var(--0\.5)!important;
	padding-bottom: var(--0\.5)!important;
	padding-left: var(--1\.5)!important;
	padding-right: var(--1\.5)!important;
	
}

.custom-form.custom-button input.gform_button {
	height:0!important;
}

/* add icon to custom button */
.custom-button.icon a {
	gap:.5rem;
}
.custom-button.icon a:after {
	content: '$';
    font-family: ETmodules !important;
	font-size: var(--icon-size);
	line-height: 0;
	margin-top: 3px;
	transition: var(--transition);
}

/* makes buttons full width */
.custom-button.wide a{
	width:100%;
	justify-content: space-between;
}
/* start define color first */
		.custom-button.color-first a {
			color: white!important;
			border: 1px solid var(--color-first)!important;
			background-color: var(--color-first)!important;
		}
		.custom-button.color-first a:hover {
			color: var(--color-first)!important;
			border: 1px solid var(--color-first)!important;
			background-color: white!important;
		}

		/* variation color first outline */
		.custom-button.color-first.outline a {
			color: var(--color-black)!important;
			border: 1px solid var(--color-first)!important;
			background-color: unset!important;
		}

		.custom-button.color-first.outline a:hover {
			color: white!important;
			border: 1px solid var(--color-first)!important;
			background-color: var(--color-first)!important;
		}

		.custom-button.color-first.outline.icon a:after {
				color: var(--color-first)!important;
		}	

		.custom-button.color-first.outline.icon a:hover:after {
				color: white!important;
		}
/* end define color first */
/* start define color second */
		.custom-button.color-second a, .custom-form.custom-button input.gform_button {
			color: white!important;
			border: 1px solid var(--color-second)!important;
			background-color: var(--color-second)!important;
		}
		.custom-button.color-second a:hover, .custom-form.custom-button input.gform_button:hover {
			color: var(--color-second)!important;
			border: 1px solid var(--color-second)!important;
			background-color: white!important;
		}

		/* variation color second outline */
		.custom-button.color-second.outline a {
			color: var(--color-black)!important;
			border: 1px solid var(--color-second)!important;
			background-color: white!important;
		}

		.custom-button.color-second.outline a:hover {
			color: white!important;
			border: 1px solid white!important;
			background-color: var(--color-second)!important;
		}

		.custom-button.color-second.outline.icon a:after {
				color: var(--color-second)!important;
		}	

		.custom-button.color-second.outline.icon a:hover:after {
				color: white!important;
		}
/* end define color second */
/* start define color third */
		.custom-button.color-third a {
			color: white!important;
			border: 1px solid var(--color-third)!important;
			background-color: var(--color-third)!important;
		}
		.custom-button.color-third a:hover {
			color: var(--color-third)!important;
			border: 1px solid var(--color-third)!important;
			background-color: white!important;
		}

		/* variation color third outline */
		.custom-button.color-third.outline a {
			color: var(--color-black)!important;
			border: 1px solid var(--color-third)!important;
			background-color: white!important;
		}

		.custom-button.color-third.outline a:hover {
			color: white!important;
			border: 1px solid white!important;
			background-color: var(--color-third)!important;
		}
		.custom-button.color-third.outline.icon a:after {
				color: var(--color-third)!important;
		}	

		.custom-button.color-third.outline.icon a:hover:after {
				color: white!important;
		}
/* end define color third */
/* start define color fourth */
		.custom-button.color-fourth a {
			color: white!important;
			border: 1px solid var(--color-fourth)!important;
			background-color: var(--color-fourth)!important;
		}
		.custom-button.color-fourth a:hover {
			color: var(--color-fourth)!important;
			border: 1px solid var(--color-fourth)!important;
			background-color: white!important;
		}

		/* variation color fourth outline */
		.custom-button.color-fourth.outline a {
			color: var(--color-black)!important;
			border: 1px solid var(--color-fourth)!important;
			background-color: unset!important;
		}

		.custom-button.color-fourth.outline a:hover {
			color: white!important;
			border: 1px solid white!important;
			background-color: var(--color-fourth)!important;
		}
		.custom-button.color-fourth.outline.icon a:after {
				color: var(--color-fourth)!important;
		}	

		.custom-button.color-fourth.outline.icon a:hover:after {
				color: white!important;
		}
/* end define color fourth */

.category-item:hover{
	cursor:pointer;
	background-color: hsl(from var(--gcid-primary-color) calc(h + 0) calc(s + 0) calc(l + 0) / 0.25);
}

.category-item .et_pb_image {
	transition: all 0.2s ease-in-out;max-width:30%;
}

.category-item:hover .et_pb_image {
	transform:scale(1.1);
	
}

.category-item .et_pb_icon{
	opacity:0;
	margin-left:-20px;
	transition: all 0.2s ease-in-out;
	margin-top:3px;
}

.category-item:hover .et_pb_icon{
	opacity:1;
	margin-left:0;
}

/*---------------------------start-vertical-menu----------------------*/
.vertical-menu.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul {
	flex-direction: column;
	gap:0;
}

.vertical-menu.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul a {
	line-height: var(--line-height)!important;
}

.vertical-menu.et_pb_menu .et_pb_menu__menu {
        display: flex;
    }

.vertical-menu.et_pb_menu .et_mobile_nav_menu {
	display: none;
}

.vertical-menu.et_pb_menu .et_pb_menu__wrap {
        justify-content: flex-start!important;
}
/*---------------------------end-vertical-menu----------------------*/

@media only screen and (min-width: 768px) {
.unequal {
	transform: translateY(calc(var(--gvid-r0azl771if) * -1));
}
	}
/*-------------------------------- START BULLITS ------------------------------------------- */

.et_pb_text_inner ul {
	list-style: none;
	padding:0;
	display:flex;
	gap: var(--0\.75);
    flex-direction: column;
}

.et_pb_text_inner li {
	display:flex;
	gap: var(--0\.75);
	line-height:1.4;
}

.et_pb_text_inner li::before {
	content: '$';
	font-family: ETmodules !important;
	display: inline-block;
	width: 28px;
	height: 28px;
	min-width: 28px;
	min-height: 28px;
	line-height: 28px;
	text-align: center;
	font-size:var(--rem)!important;
	border-radius: 60px;
	background: var(--color-first);
	box-shadow: 0 1px 0 rgba(0,0,0,0.02) inset;
	color:white;
}

.color-first .et_pb_text_inner li::before {
	background: var(--color-first);
}
.color-second .et_pb_text_inner li::before {
	background: var(--color-second);
}
.color-third .et_pb_text_inner li::before {
	background: var(--color-third);
}
.color-fourth .et_pb_text_inner li::before {
	background: var(--color-fourth);
}
/* ---------------------------------- ***** END BULLITS ***** ----------------------------------*/

/* ------------------------------ > START tables --------------------------*/

@media only screen and (max-width: 768px) {
.table-holder {
	overflow-x: scroll;
}
}
	
.table-holder .et_pb_code_inner{
	padding:1px;	
}

.table-holder .et_pb_code_inner table {
 	border-collapse: collapse;
    border-radius: var(--0\.5);
    border-style: hidden; /* hide standard table (collapsed) border */
    box-shadow: 0 0 0 1px #666; /* this draws the table border  */ 
	width:100%;
}

.table-holder .et_pb_code_inner table tr:first-child th:first-child  {
    border-top-left-radius: var(--0\.5);
}

.table-holder .et_pb_code_inner table tr:first-child th:last-child  {
    border-top-right-radius: var(--0\.5);
}


.table-holder .et_pb_code_inner td, .table-holder .et_pb_code_inner th {
	padding:var(--1);
}

.table-holder .et_pb_code_inner th {
	background:var(--color-first);
	color:white!important;
	text-align:left;
}

.table-holder .et_pb_code_inner tr {
	border:1px solid var(--color-first);
}

.table-holder .et_pb_code_inner tr td {
	border-top:none;	
	color:var(--color-first);
}

.price {
	display: flex;
    justify-content: space-between;
    gap: .5rem;
}

.table-holder .et_pb_code_inner tr td:first-child{
	background:	hsl(from var(--color-second) calc(h + 0) calc(s + 0) calc(l + 0) / 0.1);
}

/*----------------- menu aanpassingen ----------------------*/

.horizontal-menu.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul {
	display:flex;
	align-items: center;
	gap:2rem;
}

.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul>li {
    margin-top: 0px;
	border-bottom:2px solid rgba(0,0,0,0.00)!important;
}

.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul>li a{
	border-bottom:2px solid rgba(0,0,0,0.00)!important;
}

.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul>li.current_page_item a {
	border-color:var(--color-first)!important;
}

.et_pb_menu .et-menu>li {
    padding-left: 0px;
    padding-right: 0px;
	font-size:1rem;
	line-height: var(--line-height)!important;
}

.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul>li>a {
    padding-bottom: 0px;
	/*color:var(--color-first)!important;*/
}

.et_pb_menu .et-menu {
    margin-left: 0px;
    margin-right: 0px;
}

.vertical-menu.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul {
	flex-direction: column;
	gap:0;
}

.vertical-menu.et_pb_menu--without-logo .et_pb_menu__menu>nav>ul a {
	line-height: var(--line-height)!important;
}

.vertical-menu.et_pb_menu .et_pb_menu__menu {
        display: flex;
    }

.vertical-menu.et_pb_menu .et_mobile_nav_menu {
	display: none;
}

.vertical-menu.et_pb_menu .et_pb_menu__wrap {
        justify-content: flex-start!important;
    }

/*----------------- hamburger menu ---------------------------------*/

.hamburger {
  width: 30px;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  gap:5px;
}

.line {
  display: block;
  height: 3px;
  width: 100%;
  background: var(--color-first);
  opacity: 1;
  -webkit-transition: .3s ease-in-out;
  -moz-transition: .3s ease-in-out;
  -o-transition: .3s ease-in-out;
  transition: .3s ease-in-out;
}

.hamburger.open .line {
	background:white;
}

.hamburger .line-1 {
	position: relative;
    top: 0px;
}

.hamburger.open .line-1 {
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-o-transform: rotate(135deg);
	transform: rotate(135deg);
 	position: relative;
    top: 8px;

}

.hamburger.open .line-2 {
	opacity:0;
  
  transition-delay: 100ms;
   transition: all 0.5s ease;
}

.hamburger .line-3 {
	position: relative;
    bottom: 0px;
}

.hamburger.open .line-3 {
  -webkit-transform: rotate(-135deg);
  -moz-transform: rotate(-135deg);
  -o-transform: rotate(-135deg);
  transform: rotate(-135deg);
	position: relative;
    bottom: 8px;
}  

#slide-in-menu-container {
  -webkit-transition: all 0.3s ease !important;
  -moz-transition: all 0.3s ease !important;
  -o-transition: all 0.3s ease !important;
  -ms-transition: all 0.3s ease !important;
  transition: all 0.3s ease !important;
	height: 100vh;
    position: fixed;
    top: 0;
    left: 100%;
    width: 100dvw;
	z-index:9;
}

#slide-in-menu-container.slide-in-menu-open {
	left:0!important;
}

#section-mobile-menu{
  -webkit-transition: all 0.3s ease !important;
  -moz-transition: all 0.3s ease !important;
  -o-transition: all 0.3s ease !important;
  -ms-transition: all 0.3s ease !important;
  transition: all 0.3s ease !important;
}

#section-mobile-menu.open{
	background-color:rgba(0,0,0,0.00)!important;
}

.hide-scrollbar {
	overflow:hidden;
}

#logo.hidden {
    opacity: 1;
	transition: all .3s;
}

#logo.hidden {
    opacity: 0;
}

/* ------------------------------ START CUSTOM FORMS ------------------------------*/

form{
	padding-bottom:1px!important;
}

.custom-form input,
.custom-form textarea {
    border: 1px solid vhsl(from var(--color-first) calc(h + 0) calc(s + 0) calc(l + 0) / 0.1)!important; 
    border-radius: var(--0\.5)!important;
    background-color: hsl(from var(--color-first) calc(h + 0) calc(s + 0) calc(l + 0) / 0.1)!important;
    padding-left: var(--1)!important;
    padding-right: var(--1)!important;
    font-size: var(--1)!important;
	box-shadow: none!important;
}

.custom-form input{
    height: var(--3\.5)!important;
}


/* << ---------------<<  RADIO BUTTONS IN FORM -------------------<<*/


.gfield_radio label, .gfield_checkbox label {
	font-size:1rem!important;
}

input[type=radio] {
  display: none!important;
}

.gfield_radio label {
	position: relative;
	cursor: pointer;
	display: flex!important;
    align-items: center!important;
}

/* RADIO BUTTONS IN FORM */

.form-wizard .gform_wrapper.gravity-theme .gf_step_label {
	padding-left:0;	
}

.form-wizard .hide-radio .gfield_radio label, .form-wizard .gfield_checkbox label {
	font-size: var(--1)!important;
}

/*hide radio voor verbergen radio field om het als knop weer te geven*/
.form-wizard .hide-radio input[type=radio] {
  	display: none!important;
}

.form-wizard .hide-radio .gfield_radio {
	align-items: flex-start;
}

.form-wizard .hide-radio .gfield_radio .gchoice {
	cursor: pointer;
	background: var(--color-first);
    color: white;
	padding-left: var(--1\.5)!important;
    padding-right: var(--1\.5)!important;
	border-radius: 100px;
	height: var(--3\.5)!important;
	padding-bottom: 0!important;
	Border:1px solid var(--color-first);
	display:flex;
}

.form-wizard .hide-radio .gfield_radio label {
    color: white !important;
	margin-left: 0;
}

.form-wizard .hide-radio .gfield_radio .gchoice:hover {
	background-color:white;
	border-color:var(--color-first)!important;
}


.form-wizard .hide-radio .gfield_radio .gchoice:hover label {
	color:var(--color-first)!important;
}

.form-wizard input[type=radio] ~ label {
	display:flex;
	margin-left:0;
}

.form-wizard input[type=radio] ~ label:before {
    content: '';
    display: block!important;
    float: left;
    width: var(--1\.5)!important;
    height: var(--1\.5)!important;
    margin-right: var(--0\.5)!important;
    vertical-align: middle;
    cursor: pointer;
    border-radius: 50%;
    background-color: hsl(from var(--color-first) calc(h + 0) calc(s + 0) calc(l + 0) / 0.1)!important;
}

.form-wizard .hide-radio input[type=radio] ~ label:before {
	display:none!important;
}

input[type=radio]:checked ~ label:before {
	background: radial-gradient(circle, var(--color-second) 45%, rgba(255,255,255,1) 55%, white 100%);
	background: radial-gradient(circle, white 25%, var(--color-second) 35%, var(--color-second) 100%);
	border:none;
 }

/* << ---------------<< END radio Field -------------------<<*/


/* ------------------------------------- start custom checkbox -----------------------------------*/

.gfield_checkbox .gchoice {
  display: block;
  position: relative;
  padding-left: var(--2);
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Hide the browser's default checkbox */
.gfield_checkbox .gchoice input {
  position: absolute;
  opacity: 0!important;
  cursor: pointer;
}

.gfield_checkbox .gchoice label:after{
  	position: absolute;
  	top: 0;
  	left: 0;
  	height: var(--1\.5);
  	width: var(--1\.5);
 	background-color: hsl(from var(--color-first) calc(h + 0) calc(s + 0) calc(l + 0) / 0.1);
	content:'';
	border-radius: var(--0\.25);
	border:1px solid hsl(from var(--color-first) calc(h + 0) calc(s + 0) calc(l + 0) / 0.1);
}

/* On mouse-over, add a grey background color */
.gfield_checkbox .gchoice input:hover ~ label:after {
  background-color: hsl(from var(--color-first) calc(h + 0) calc(s + 0) calc(l + 0) / 0.2);
}

.gfield_checkbox .gchoice label{
	margin-left:0;
}

.gfield_checkbox .gchoice input:hover, .gfield_checkbox .gchoice label:hover{
	cursor:pointer;
}

/* When the checkbox is checked, add a blue background */
.gfield_checkbox .gchoice input:checked ~ label:after {
  background-color: var(--color-second);
border-color:var(--color-second);
}

/* Create the checkmark/indicator (hidden when not checked) */
.gfield_checkbox .gchoice label:before {
    content: "";
    position: absolute;
    display: none;
    left: var(--0\.375);
    top: var(--0\.125);
    width: var(--0\.75);
    height: var(--1);
    border: solid white;
    border-width: 0 var(--0\.25) var(--0\.25) 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    z-index: 9;
}

/* Show the checkmark when checked */
.gfield_checkbox .gchoice input:checked ~ label:before {
  display: block;
}


/* ------------------------------------- end custom checkbox -----------------------------------*/

.gf_page_steps {
    background-color: white;
	border-radius:35px;
	justify-content: center;
	width: fit-content;
    margin: auto;
	padding:0.5rem!important;
	gap: 0.5rem!important;
}

.gf_step_label {
	display:none;
}

.gf_step{
	gap: 0!important;
	border-radius:25px;
	/*padding-top: 0.25rem;
    padding-bottom: 0.25rem;*/
}


.gf_step_active {
	background:var(--color-first);
	
}

.gf_step_number {
	border:none!important;
	background:none!important;
		width: 47px!important;
	height:47px!important;
}

.gf_step_active .gf_step_label {
	display:revert;
}

.gpmpn-page-link {
	gap: 0!important;
}

.gf_step_active .gf_step_number{color:white;}
.gf_step_active .gf_step_label{
	color:white;
	padding-right:1.5rem;
}
.gf_step_active.gf_step {
	gap:0!important;
}

.gf_step {

    
    display: flex;
    justify-content: center;

}

.gform-theme--framework .gf_step_completed .gf_step_number:after {
	background-color:var(--color-second)!important;	
	border:none;
	width: 47px;
	height:47px;
}

.gf_step_completed {
	padding-top:0;
	padding-bottom:0;
	width: 47px;
	height:47px;
}


.form-wizard .button.gform_last_page_button {
	display:none
}

.form-wizard .hide_next_button .gform_next_button/*, .form-wizard .hide_next_button .gform_page_footer*/{
	display:none!important;
}

/*-------------------------- buttons-hover -------------------------*/

.form-wizard .buttons-big .gfield_radio .gchoice {
	border:2px solid var(--color-first);
	transition: all .25s!important;
}

.form-wizard .buttons-big .gfield_radio .gchoice:hover {
	background:white;
	color:var(--color-first);
	transition: all .25s!important;
}

.form-wizard .buttons-big .gfield_radio .gchoice {
	width:100%;
}

.form-wizard .buttons-big .gfield_radio .gchoice label{
	justify-content: center;
	text-align: center;
	width:100%;
	max-width:100%;
}

/*-------------------------- end buttons-big-------------------------*/

.form-wizard input[type=submit], .form-wizard .gform_previous_button, .form-wizard .gform_next_button {
    border-radius: 25px!important;
}

.form-wizard .gform_previous_button, .form-wizard .gform_next_button, .form-wizard input[type=submit] {
    border: 1px solid var(--color-first) !important;
    background: white !important;
}

.form-wizard .gform_next_button, .form-wizard input[type=submit] {
	background-color: var(--color-first)!important;
	color:white;
}

.form-wizard .gform_next_button:hover, .form-wizard .gform_previous_button:hover, .form-wizard input[type=submit]:hover {
	background-color: white!important;
	color: var(--color-first)!important;
}


.form-wizard .read-only input[type=text] {
	background-color:#eee!important;
box-shadow: none!important;
}

.hide-label .gfield_label {
	visibility: hidden;
}

::placeholder {
  opacity: .4; 
}

.gfield_description.validation_message.gfield_validation_message {
	color:var(--color-second);
}

.ginput_container_date input {
	width:100%!important;
}

.alert {    
	background-color: var(--grey);
    padding: 1rem 2rem 2rem!important;
    margin-bottom: 1rem;
    color: white;
	border-radius:5px;
}
.alert-green{background-color: var(--alertGreen);}
.alert-orange{background-color: var(--alertOrange);}
.alert-red{background-color: var(--alertRed);}

.alert h2 {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    padding-bottom: 0.5rem;
    text-transform: uppercase;
    font-style: italic;
    color: white !important;
}

.gform-theme--framework .gfield--type-image_choice.gfield--image-choice-appearance-card .gchoice:where(:has(input:checked))::after {
	background-color:var(--color-second)!important;
}

.gform-theme--foundation .gform_fields {
	row-gap: var(--0\.5)!important;
}