﻿body { font-family: 'DM Sans', sans-serif; font-size: 14px; line-height: 1.6; margin: 0; color: #1f242c; }
	body.KMCMSeditor { padding: 20px; }

h1 { font-weight: 200; color: #084d48; margin-bottom: 30px; font-size: 38px; line-height: 1.2; position: relative; }
h2 { font-weight: 400; color: #084d48; margin-bottom: 20px; font-size: 24px; color: #000; margin-top: 30px; }
h3 { font-weight: 700; color: #084d48; font-size: 20px; margin: 30px 0 20px 0; }
h4 { font-weight: 700; color: #084d48; font-size: 22px; }
h5 { font-weight: 700; color: #084d48; font-size: 20px; }
h6 { font-weight: 700; color: #084d48; font-size: 18px; }
p, ul, ol { color: #1f242c; font-size: 18px; line-height: 1.6; }
	p.intro { font-weight: bold; }
.fa-li { color: #ea5b0c; }


.modal { z-index: 9999; }
.modal-title h5 { text-align: center; }
.modal-body .popuptekst p a, .modal-body .popuptekst ul a { border-bottom: solid 1px #ea5b0c; }
	.modal-body .popuptekst p a:hover, .modal-body .popuptekst ul a:hover { border-bottom: solid 1px #084d48; }
.modal .btn:hover { background-color: #000; color: #fff; }

.doclist { margin-left: 25px; font-size: 14px; line-height: 24px; }
td.ico { padding: 0 8px; }
a { transition: ease-in-out .30s; text-decoration: none; color: #ea5b0c; }
	a:hover, a:focus, a:active { outline: none; text-decoration: none; color: #084d48; }
.ratio { margin: 40px 0; }

.page-loader { background: #fff; position: fixed; top: 0; bottom: 0; right: 0; left: 0; z-index: 9998; }
.loader { position: absolute; width: 70px; height: 70px; top: 50%; left: 50%; margin: -35px 0 0 -35px; }
	.loader .fa-light { font-size: 70px; line-height: 70px; color: #084d48; }


.hero { }
	.hero .cover { background-color: rgba(8,77,72,0.6); width: 100%; height: 500px; }
	.hero.herosmall, .hero.herosmall .cover { height: 350px; }
	.hero .herotext { font-size: 46px; color: #084d48; font-weight: 400; z-index: 9999; line-height: 1.2; }
		.hero .herotext span { font-weight: 700; }
	.hero.homehero .herotext { text-shadow: #fff 2px 2px 6px; margin-top: 210px; }
	.hero.herosmall .herotext { color: #fff; }

.homehero { height: 100vh; width: 100%; position: relative; background: url(../images/carport-met-zonnepanelen-2.jpg) center center no-repeat; background-size: cover; }
.hero a { }
.homehero img.meer { position: absolute; bottom: 0; left: 50%; margin-left: -45px; }

.carousel-section { background-color: rgba(100,100,100,0.05); background-color: #fff; }


.extracontainer { padding: 40px 0; background-color: rgba(100,100,100,0.05); }

.breadcrumbcontainer { padding: 10px 0; background-color: #fff; border-bottom: solid 1px #e4e5e6; }
.breadcrumb { font-size: 14px; font-weight: 300; line-height: 1.8; border-bottom: 0; padding-left: 0; border-radius: 0; text-transform: lowercase; background-color: transparent; margin-bottom: 0; }
	.breadcrumb a { color: #000; border-bottom: solid 0px #000; }
		.breadcrumb a:hover { color: #084d48; border-bottom: solid 0px #fff; }
.breadcrumb-item + .breadcrumb-item::before { color: #084d48; content: ">"; }

.pagecontent { margin: 60px 0; }
.introcontent { padding: 100px 0 50px 0; }
	.introcontent .pagecontent { margin: 0 !important; }
.bgcontent1 { background-color: rgba(121,180,38,0.3); }
.bgcontent2 { background: url(../images/bg-content2.jpg) center center repeat; background-size:cover; }
.movie-wrapper { padding: 60px 0; background: url(../images/bg-green.png) center center repeat; }
	.movie-wrapper h1 { margin-top: 28px; }
	.movie-wrapper iframe { box-shadow: #058282 0 0 30px; }

.content { }
	.content h1 { }
	.content .img-above { margin-bottom: 30px; }
	.content .img-below { margin: 30px 0; }
	.content a { color: #084d48; border-bottom: solid 1px #084d48; }
	.content p b { color: #084d48; }
	.content ul { list-style: none; padding: 0; margin-left: 1em; }
		.content ul li { padding-left: 1.9em; }
			.content ul li:before { content: '\e3d6'; font-family: 'Font Awesome 6 Pro'; display: inline-block; margin-left: -1.9em; width: 1.9em; color: #084d48; font-weight: 700; }
	.content .fa-li { color: #084d48; }
	.content ul.fa-ul { margin-left: 25px; }
		.content ul.fa-ul li { padding-left: 0; margin-left: 25px; }
			.content ul.fa-ul li:before { content: none; }
			.content ul.fa-ul li .fa-li { color: #084d48; }
	.content .subpagina { padding: 60px 0; margin: 60px 0; background: url(../images/sun-bg.jpg) center center repeat; background-size: cover; background-attachment: fixed; }
		.content .subpagina .dienstblok a { border-bottom: 0; }
	.content .feature { padding: 80px 0 60px 0; margin: 60px 0; background-color: rgba(121,180,38,0.3); }
	.content .cta { background-color: #79b426; text-align: center; padding: 36px 0; margin: 60px 0; color: #fff; font-size: 22px; font-weight: 700; }

.cta + .subpagina { margin-top: -60px; }
.subpagina + .cta { margin-top: -60px; }
.cta + .feature { margin-top: -60px; }
.feature + .cta { margin-top: -60px; }
.feature + .subpagina { margin-top: -60px; }
.subpagina + .feature { margin-top: -60px; }
.pagecontent + .movie-wrapper { margin-top: -60px; }
.content .feature:first-child { margin-top: 0; }
.content .feature:last-child { margin-bottom: 0; }
.content .subpage:first-child { margin-top: 0; }
.content .subpage:last-child { margin-bottom: 0; }
.content .cta:first-child { margin-top: 0; }
.content .cta:last-child { margin-bottom: 0; }

.content.content-home ul.fa-ul { margin-left: 0; }
	.content.content-home ul.fa-ul .fa-li { color: #79b426; }
	.content.content-home ul.fa-ul li { padding: 12px 0; border-bottom: solid 1px silver; }
		.content.content-home ul.fa-ul li:last-child { border-bottom: none; }
		.content.content-home ul.fa-ul li a { border-bottom: 0; color: #79b426; }

.dienstblok { text-align: center; transition: ease-in-out all 0.3s; border-radius: 0; border: 0; background-color: #084d48; box-shadow: #000 0 0 30px; }
a .dienstblok { }
	a .dienstblok h2 { transition: ease-in-out all 0.3s; text-align: center; color: #fff; margin: 0; }
a:hover .dienstblok .fa-thin { transform: scale(1.1); color: #084d48; }
a:hover .dienstblok h2 { color: silver; }
.dienstblok .card-footer { background-color: transparent; border: 0; padding-bottom: 25px; }
	.dienstblok .card-footer span { display: inline-block; background-color: transparent; color: #fff; padding: 8px 16px; border: solid 2px #fff; transition: ease-in-out all 0.3s; }
a:hover .dienstblok .card-footer span { background-color: #fff; color: #084d48; }

.homeblok { margin: 90px 0 10px 0; }
	.homeblok .dienstblok { box-shadow: none; background-color: #79b426; }
		.homeblok .dienstblok .card-footer { padding-top:25px; }
		.homeblok .dienstblok .card-footer span { min-width:140px; font-size:18px; font-weight:700; }


.featureblok { border: solid 4px #79b426; border-radius: 14px; }
	.featureblok .card-icon { text-align: center; margin-top: -46px; }
	.featureblok i { font-size: 30px; display: inline-block; line-height: 57px; border-radius: 50%; width: 57px; height: 57px; text-align: center; background-color: #79b426; color: #fff; }

.galerijcontainer { background: rgba(0,0,0,0.8); padding: 80px 0; background-color: #ea5b0c; background-color: #fff; background-color: rgba(255,255,255,0.9); }
.img-galery { background-color: #fff; padding: 60px 0; }
.content a.lightbox { border-bottom: 0; }
.thumbs { width: 100%; float: left; overflow: hidden; position: relative; margin-bottom: 2px; text-align: center; text-transform: uppercase; font-size: 14px; font-weight: 700; background-color: #fff; border-radius: 0px; box-shadow: 0 1px 13px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.24); transition: transform .3s cubic-bezier(.34,2,.6,1),box-shadow .2s ease; transform: translateY(0px); }
	.thumbs span.title { color: #fff; }
	.thumbs a { background-color: rgba(8,77,72,0.40); bottom: -200px; color: #fff; left: 0; opacity: 0; position: absolute; right: 0; text-align: left; top: 0; z-index: 100; transition: all 0.35s ease-in-out; -webkit-transition: all 0.35s ease-in-out; text-decoration: none; }
		.thumbs a .title { display: table; width: 100%; height: 100%; }
			.thumbs a .title .title-text { font-style: normal; font-weight: 300; font-size: 12px; line-height: 14px; color: #fff; vertical-align: bottom; padding: 8px; display: table-cell; }
				.thumbs a .title .title-text h5, .thumbs a .title .title-text p { color: #fff; font-weight: 700; font-size: 14px; }
				.thumbs a .title .title-text h5 { font-weight: 700; }
			.thumbs a .title .enlarge { font-style: normal; color: #fff; vertical-align: middle; padding: 20px; display: table-cell; text-align: center; }
		.thumbs a:hover { bottom: 0; opacity: 1; transition: opacity 0.30s ease-in-out 0s, bottom 0.4s cubic-bezier(0.25, 0.500, 0, 1) 0s; -webkit-transition: opacity 0.30s ease-in-out 0s, bottom 0.4s cubic-bezier(0.25, 0.500, 0, 1) 0s; }

.galery-container { display: grid; grid-template-columns: 1fr; grid-template-rows: repeat(auto-fill, 1fr); margin-bottom: 60px; }
.galery { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(auto-fill, 1fr); }
.galery-item .thumbs { margin-bottom: 0; }

.btn { display: inline-block; text-transform: uppercase; color: #084d48; padding: 4px 16px; border: solid 2px #084d48; font-weight: 700; border-radius: 4px; font-size: 16px; line-height: 28px; }
	.btn:before { background-color: #ea5b0c; }
	.btn:focus { box-shadow: none; }
	.btn:hover, .btn-active { background-color: #084d48; color: #fff; }
.btn-effect { position: relative; transition: 0.3s ease all; -webkit-transition: 0.3s all ease; z-index: 2; }
	.btn-effect:before { transition: 0.5s ease all; -webkit-transition: 0.5s all ease; position: absolute; top: 0; left: 50%; right: 50%; bottom: 0; opacity: 1; content: ''; z-index: -2; }
	.btn-effect:hover:before { transition: 0.5s ease all; -webkit-transition: 0.5s all ease; left: 0; right: 0; opacity: 1; }
.btn-white { border-color: #fff !important; color: #fff !important; border-bottom-width: 2px !important; }
	.btn-white:hover { background-color: #fff; color: #084d48 !important; }
.btn-yellow { background-color: #084d48; }

.contactcontainer { background: url(../images/contact-bg-1.jpg) center center no-repeat; background-size: cover; padding: 80px 0 120px 0; }
.formulier { background-color: #fff; padding: 20px; box-shadow: #000 0 0 30px; }
label { font-weight: 700; font-size: 14px; color: #084d48; }
	label.form-check-label { font-weight: 400; color: #084d48; }
.formulier p { color: #084d48; }
.formulier a { color: #084d48; text-decoration: underline; }
.form-control, .form-select { /*font-size:18px;line-height:1;*/ }
	.form-control:focus, .form-check-input:focus, .form-select:focus { color: #000; background-color: #fff; border-color: #084d48; outline: 0; box-shadow: 0 0 0 .25rem rgba(198,197,196,.25); }
textarea.form-control { min-height: 150px; }
.form-check { margin-bottom: 0; }
.form-check-input:checked { background-color: #084d48; border-color: #084d48; }
.form-group.required.error label:after, .form-check.required.error label:after { content: '*'; color: #ea5b0c; margin-left: 4px; }
.form-group .progress, .form-group .alert-success, .form-group .alert-danger { display: none; }

footer { background-color: #084d48; z-index: 20; position: relative; padding: 120px 0 90px 0; margin-top: 0px; }
	footer .aankondiging { margin-bottom: 20px; background-color: yellow; color: #000; padding: 10px; }
	footer p { color: #fff; font-size: 18px; line-height: 1.8; font-weight: 300; }
		footer p b { font-weight: 700; }
		footer p span { display: inline-block; width: 100px; }
		footer p a { border-bottom: dotted 1px #fff; }
		footer p span { color: silver; }
			footer p span:after { content: ": "; }
	footer a, footer a:focus, footer a.tel { color: #fff; text-decoration: none; }
		footer a:hover { color: silver; }
	footer .fa-light { display: inline-block; width: 25px; color: silver; }
	footer p.small { font-size: 12px; color: silver; margin-top: 40px; text-align: right; }
		footer p.small a { color: silver; }
	footer .social { margin: 25px 0; }
		footer .social a { background-color: #79b426; color: #fff !important; display: inline-block; line-height: 1; padding: 10px; font-size: 26px; border-radius: 50%; width: 47px; text-align: center; transition: 0.3s ease-in-out all; margin-right: 6px; }
			footer .social a:hover { background-color: #fff; color: #79b426 !important; }

.copycontainer { background-color: #000; padding-top: 15px; padding-bottom: 15px; color: #fff; font-size: 12px; }
	.copycontainer a { color: #ddd; }
a.toplink { cursor: pointer; position: fixed; right: 35px; bottom: 15px; display: none; color: #4f69c1; }
.wow { visibility: hidden; }

.scrollup { padding: 5px 10px; background-color: #7b7b73; color: #fff; position: fixed; bottom: 20px; right: 20px; z-index: 9999; display: none; }
.scrollshow { display: inline-block; }
.scrollup:hover { background-color: #000000; color: #fff; }

.wow { visibility: hidden; }

@media(min-width:1400px) {
	.container-fluid { width: 90%; max-width: 1700px; }
}

@media(min-width:1200px) and (max-width:1399px) {
	.navbar-brand { max-width: 250px; padding: 30px 0; display: inline-block; }
		.navbar-brand img { width: 250px; }
	.navfixed .navbar-brand { max-width: 200px; padding: 15px 0; }
		.navfixed .navbar-brand img { width: 200px; }
	.mainmenu .nav-item { font-size: 18px; }
}

@media (min-width: 1300px) {
	.toolbarcontainer .logo { max-width: 230px; }
	.galery-container { gap: 30px; }
	.galery { gap: 30px; }
}


@media (min-width:1200px) and (max-width: 1299px) {
	.toolbarcontainer .logo { max-width: 180px; }
	.galery-container { gap: 30px; }
	.galery { gap: 30px; }
}

@media (min-width: 992px) and (max-width: 1199px) {
	.galery-container { gap: 15px; }
	.galery { gap: 15px; }
}

@media (min-width: 992px) {
	.img-left, .img-right { margin-bottom: 25px; }
	.galery-item:nth-child(6n+1) { grid-area: 1 / 1 / 3 / 3; }
	.galery-item:nth-child(6n+4) { grid-area: 2 / 3 / 4 / 5; }
}

@media (max-width: 991px) {
	.homecontainer .card.card2 { border-radius: 0; }
	.pagecontainer { padding: 40px 0 120px 0; }
	.dienstcontainer { padding: 30px 0; }

	.img-left, .img-right { margin: 25px 0; }
	.galery-container { gap: 5px; }
	.galery { gap: 5px; }

	.contactcontainer { padding: 40px 0; }
	footer { background-position-x: center; }
}

@media (min-width: 576px) and (max-width: 1199px) {
	h1 { font-size: 34px; }
	h2 { font-size: 20px; }
	p, ul, table, form-label { font-size: 15px; }
	a .homeblok { margin-bottom: 60px; }
		a .homeblok .fa-thin { font-size: 60px; }
		a .homeblok h2 { margin: 15px 0; }
}

@media (min-width: 768px) and (max-width: 991px) {
	.card-columns { -webkit-column-count: 2; -moz-column-count: 2; column-count: 2; }
	.galery-item:nth-child(6n+1) { grid-area: 1 / 1 / 3 / 3; }
	.galery-item:nth-child(6n+4) { grid-area: 2 / 3 / 4 / 5; }
}

@media (max-width: 767px) {
	.hero .herotext { font-size: 36px; }
	.hero.homehero .herotext { margin-top: 170px; }
	.hero.herosmall, .hero.herosmall .cover { height: unset; }
		.hero.herosmall .herotext { padding: 40px 0; }
	.introcontent { padding: 60px 0 60px 0; }
	.movie-wrapper { padding: 50px 0; }
	.pagecontent { padding: 50px 0 40px 0; }
	.dienstcontainer { padding: 20px 0; }

	.feature .mb-4 { margin-bottom: 30px !important; }

	.galerijcontainer { padding: 15px 0; }
	.galery.impressie-galery { grid-template-columns: repeat(3, 1fr); }
	.card-columns { -webkit-column-count: 1; -moz-column-count: 1; column-count: 1; }

	footer { padding: 40px 0 25px 0; }
		footer .footer-logo { margin-bottom: 30px; text-align: center; max-width: 280px; }
		footer .social { text-align: center; }
		footer .footerwrapper { text-align: center; padding: 25px 0 40px 0; }
}

@media (max-width: 575px) {
	h1 { font-size: 24px; }
	h2 { font-size: 18px; }
	p, ul, table, form-label { font-size: 14px; }
	.modal .btn { display: block; width: 100%; margin-bottom: 5px; }
	.galery.impressie-galery { grid-template-columns: repeat(2, 1fr); }

	a .homeblok { padding-top: 30px; margin-bottom: 30px; border-top: solid 1px #ccc; }
		a .homeblok .fa-thin { font-size: 40px; }
		a .homeblok h2 { font-size: 20px; margin: 15px 0; }
	.pagetitle i { font-size: 90px; right: 5px; top: -30px; }
	a .dienstblok { text-align: center; padding: 15px 0; transition: ease-in-out all 0.3s; }
		a .dienstblok .fa-thin { color: #ea5b0c; font-size: 35px; line-height: 1; transition: ease-in-out all 0.3s; margin-bottom: 15px; }
		a .dienstblok h4 { font-size: 16px; min-height: unset; }
	.contactcontainer { padding: 15px 0; }
}

@media(max-width:380px) {
	.hero .herotext { font-size: 30px; }
	.hero.homehero .herotext { margin-top: 130px; }
}
