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

:root { --maincolor: #1e2d6e; --bgcolor: rgba(30,45,110,0.85); }

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


.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 var(--maincolor); }
			.modal .btn:hover {background-color:#000;color:#fff;}

.doclist { margin-left: 25px; font-size: 18px; line-height: 1.6; }
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: var(--maincolor); }
.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: var(--maincolor); }

.hero {height:350px;}
.hero .cover {background-color:rgba(0,0,0,0);width:100%;height:500px;}
.hero .herotext {font-size:46px;color:#fff;font-weight:700;z-index:9999;line-height:1.2;text-shadow:#000 0 0 10px;}
	.hero .herotext span { color: #fff; font-weight:300; display:block; }
.hero.herosmall { background: url(../images/mttc-2.jpg) center center no-repeat; background-size: cover; height: 350px; }
	.hero.herosmall .cover {height:350px;}

.homegrid { display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(auto-fill, 1fr); gap: 30px; margin-top: 0px;margin-bottom:30px; }
	.homegrid div:nth-child(4n+1) { grid-area: 1 / 1 / 3 / 3; }
	.homegrid div:nth-child(4n+2) { grid-area: 2 / 2 / 4 / 4; }
	.homegrid div:nth-child(4n+3) { grid-area: 1 / 3 / 2 / 4; }
	.homegrid div:nth-child(4n+4) { grid-area: 3 / 1 / 4 / 2; }
	.homegrid .intro { padding: 50px; background-color: var(--bgcolor); border-radius: 180px 0 0 0; }
		.homegrid .intro h1, .homegrid .intro p, .homegrid ul { color: #fff; }
		.homegrid .intro h1 { margin-top:15px; }
	.homegrid div.extra { background: url(../images/home-1.jpg) center center no-repeat; background-size: 100% 100%; animation: mymove 7s forwards; }

@keyframes mymove {
	100% { background-size: 115% 115%; }
}

.dienstcontainer { padding: 60px 0; }
.dienstblok { text-align: center; transition: ease-in-out all 0.3s; background-color: #e4e5e6; border-radius: 0; border: 0; box-shadow: #e4e5e6 0 0 10px; }
	.dienstblok .card-img-top {border-radius:0;}
	.dienstblok h2 { transition: ease-in-out all 0.3s; text-align: center; color: var(--maincolor);margin:0;padding:0; font-size:16px;font-weight:700; text-transform:uppercase; }
.dienstblok .card-footer { background-color: #e4e5e6; border: 0; padding-bottom: 25px; }
	.dienstblok .card-footer span { display: inline-block; background-color: var(--maincolor); color: #fff; padding: 8px 16px; border: solid 2px var(--maincolor); transition: ease-in-out all 0.3s; }
.dienstblok a:hover .card-footer span { background-color: #fff; color: var(--maincolor);  }

.breadcrumbcontainer { padding: 10px 0; background-color: var(--maincolor); }
.breadcrumb { font-size: 14px; font-weight:400; line-height: 1.8; border-bottom: 0; padding-left: 0; border-radius: 0; text-transform: uppercase; background-color: transparent; margin-bottom: 0; }
	.breadcrumb a { color: #fff; border-bottom:solid 0px #fff; }
		.breadcrumb a:hover { color: silver; border-bottom: solid 0px #fff; }
.breadcrumb-item + .breadcrumb-item::before { color: silver; content: ">"; }

.pagecontent { padding: 90px 0 70px 0; }

.cta { background-color: var(--maincolor); text-align: center; padding: 22px 36px 32px 36px; margin: 40px 0 -140px 0; z-index: 100; position: relative; }
	.cta p { color: #fff; }

.content { }
	.content h1 { }
	.content .img-above { margin-bottom: 30px; }
	.content .img-below { margin: 30px 0; }
	.content a { color: var(--maincolor); border-bottom: solid 1px var(--maincolor); }
	.content p b { color: var(--maincolor); }
	.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: var(--maincolor); font-weight: 700; }
			.content ul ul li:before { content: '\f061'; font-family: 'Font Awesome 6 Pro'; display: inline-block; margin-left: -0.9em; width: 1.9em; color: var(--maincolor); font-weight: 400; }
	.content .fa-li { color: var(--maincolor); }
	.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: var(--maincolor); }

.content .dienstblok a {border-bottom:0;}
.content.content-home ul.fa-ul { margin-left:0; }
	.content.content-home ul.fa-ul .fa-li { color: var(--maincolor); }
	.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:var(--maincolor); }

.teamblok {padding:15px;box-shadow:#ddd 0 0 30px;margin-bottom:30px;}
.teamblok h2 {color:#1e2d6e;font-weight:700;margin-top:0;}

.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(30,45,110,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; }

.btn { display: inline-block; text-transform: uppercase; color: var(--maincolor); padding: 4px 16px; border: solid 2px var(--maincolor); 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:var(--maincolor);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: var(--maincolor) !important; }
.btn-yellow { background-color: var(--maincolor); }

.contactadres { background-color: var(--maincolor); padding: 8px 0; font-size: 16px;text-align:center;color:#fff; border-radius:6px; }
	.contactadres .fa-light { color: #fff; }
	.contactadres a { color: #fff; }
		.contactadres a:hover { color: #fff; border-bottom: solid 1px #fff; }
.contact-img { border-radius: 6px 6px 6px 120px; }

label { font-weight: 400; font-size: 14px; }
	label.form-check-label { font-weight: 400; }
		label.form-check-label a { color: #000; border-bottom: solid 1px #000; }
			label.form-check-label a:hover { color: var(--maincolor); border-bottom: solid 1px var(--maincolor); }
.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: var(--maincolor); outline: 0; box-shadow: none; }
textarea.form-control { min-height: 150px !important; }
.form-check { margin-bottom: 0; }
.form-check-input { margin-top: .3em; }
	.form-check-input:checked { background-color: var(--maincolor); border-color: #000; }
.form-floating.required.error .form-control { border-color:red;}
.form-floating.required.error label:after, .form-check.required.error label:after { content: '*'; color: red; margin-left: 4px; }
.form-group .progress, .form-group .alert-success, .form-group .alert-danger { display: none; }

.floatingform .form-control { border: solid 1px var(--maincolor); background-color: #fff; line-height: 1; border-radius: 0; }
.floatingform .form-select { border: none; background-color: #f0f0f0; color: #AAA; font-size: 14px; line-height: 2.8; padding-left: 15px; }
.floatingform .form-floating > label { left: 15px; }

footer { background: url(../images/footer-bg.jpg) center center no-repeat; background-size:cover; position: relative; padding: 120px 0 90px 0; margin-top: 0px; }
	footer p { color: #fff; font-size: 18px; line-height: 1.8; font-weight: 300; }
		footer p b { font-weight: 700; }
		footer p a { border-bottom: dotted 1px #fff; }
	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; color:var(--maincolor);color:silver; }
	footer p.small { font-size: 12px; color: silver; margin-top: 40px; text-align: right; }
		footer p.small a { color: silver; }

.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: var(--maincolor); color: #fff; }

.wow { visibility: hidden; }

@media (min-width: 1200px) and (max-width: 1349px) {
	.hero, .hero.herosmall, .hero.herosmall .cover {height:300px;}
}


@media (min-width: 992px) and (max-width: 1199px) {
	.homegrid { display: grid; grid-template-columns:1fr 3fr 1fr; grid-template-rows: repeat(auto-fill, 1fr); gap: 20px; margin-top: 0px; margin-bottom: 30px; }
	.hero, .hero.herosmall, .hero.herosmall .cover { height: 270px; }
}

@media (min-width: 992px) {
	.img-left, .img-right { margin-bottom: 25px; }
}

@media (max-width: 991px) {
	.homegrid { display: grid; grid-template-columns: 1fr 4fr; grid-template-rows: 1fr 5fr 1fr 1fr; gap: 20px; margin-top: 0px; margin-bottom: 30px; }
		.homegrid div:nth-child(4n+1) { grid-area: 1 / 1 / 3 / 3; }
		.homegrid div:nth-child(4n+2) { grid-area: 2 / 2 / 5 / 3; }
		.homegrid div:nth-child(4n+3) { grid-area: 3 / 1 / 4 / 2; }
		.homegrid div:nth-child(4n+4) { grid-area: 4 / 1 / 5 / 2; }
	.hero, .hero.herosmall, .hero.herosmall .cover { height: 250px; }
	.hero .herotext {font-size:40px;}

	.homecontainer .card.card2 {border-radius:0;}
	.pagecontainer { padding: 40px 0 120px 0; }
	.dienstcontainer { padding: 30px 0; }

	.img-left, .img-right { margin: 25px 0; }

	.contactcontainer { padding: 40px 0; }
	.contactadres { margin-bottom: 5px; }
}

@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) {
	a .dienstblok h4 { font-size: 16px; min-height: 45px; }
	.card-columns { -webkit-column-count: 2; -moz-column-count: 2; column-count: 2; }
}

@media (max-width: 767px) {
	.homegrid { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 4fr 1fr 1fr; gap: 20px; margin-top: 0px; margin-bottom: 30px; }
		.homegrid div:nth-child(4n+1) { grid-area: 1 / 1 / 3 / 3; }
		.homegrid div:nth-child(4n+2) { grid-area: 2 / 1 / 4 / 3; }
		.homegrid div:nth-child(4n+3) { grid-area: 4 / 1 / 5 / 2; }
		.homegrid div:nth-child(4n+4) { grid-area: 4 / 2 / 5 / 3; }
	.hero, .hero.herosmall, .hero.herosmall .cover { height: 200px; }
		.hero .herotext { font-size: 34px; }

	.pagecontent { padding: 50px 0 40px 0; }
	.dienstcontainer {padding: 20px 0;}

	.galerijcontainer { padding: 15px 0; }
	.card-columns { -webkit-column-count: 1; -moz-column-count: 1; column-count: 1; }

	footer {padding:40px 0 25px 0;}
	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; }

	.hero, .hero.herosmall, .hero.herosmall .cover { height: 200px; }
		.hero .herotext { font-size: 28px; }

	.modal .btn {display:block;width:100%;margin-bottom:5px;}

	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; }

	footer span {display:block;}
}
