body,
html {
  margin: 0;
  padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}


textarea {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

* {
  box-sizing: border-box;
}

.wrapper {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  .wrapper {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  .wrapper {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  .wrapper {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .wrapper {
    max-width: 1140px;
  }
}


.d-grid {
  display: grid;
}

.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

button,
select {
  outline: none;
  appearance: none;
  -webkit-appearance: none;
}

button,
.btn,
select {
  cursor: pointer;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

a {
  text-decoration: none;
}

iframe {
  border: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

p {
  margin: 0;
  padding: 0;
}

/* Section top bottom gap */
.section-gap {
  padding: 4.5rem 0;
}

@media screen and (max-width:767px) {
  .section-gap {
    padding: 3.5rem 0;
  }
}

@media screen and (max-width:480px) {
  .section-gap {
    padding: 3rem 0;
  }
}

/* / Section top bottom gap */

/* title-styling */
h3.global-title {
  font-size: 40px;
  line-height: 45px;
  color: #16191e;
  margin-bottom: 50px;
  text-transform: capitalize;
}

@media screen and (max-width:767px) {
  h3.global-title {
    font-size: 40px;
    line-height: 45px;
  }
}

@media screen and (max-width:600px) {
  h3.global-title {
    font-size: 35px;
    line-height: 40px;
  }
}

@media screen and (max-width:500px) {
  h3.global-title {
    font-size: 30px;
    line-height: 35px;
  }
}

/* / title-styling */

.contant11-top-bg {
  background: url('achtergrond.jpg') no-repeat;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}

.contact-info h4 {
  font-size: 20px;
  color: #000;
  margin: 10px 0 5px 0;
}

.contact-info-left {
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 50px;
}

.contact-info {
  -o-box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  padding: 2rem;
  background: #fff;
  border-radius: 20px;
}

.contact p {
  font-size: 16px;
  color: #636363;
  line-height: 24px;
}

.contact a {
  display: block;
  color: #636363;
}

.contact {
  grid-template-columns: 1fr;
}

.contact a:hover {
  display: block;
  color: #d1242a;  /* was #002663 */
}

.contact span.fa {
  font-size: 40px;
  color: #d1242a;
  margin-bottom: 10px;
}

iframe {
  width: 100%;
  height: 450px;
}

@media (max-width: 1024px) {
  .contact-info-left {
    grid-gap: 40px;
  }
}

@media (max-width: 991px) {
  .contact-info-left {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .contact p {
    font-size: 17px;
  }
}

@media (max-width: 800px) {
  .contact a {
    font-size: 16px;
  }

  .contact {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .map {
    float: none;
    width: 100%;
    text-align: left;
  }

  iframe {
    height: 280px;
  }
}

@media (max-width: 375px) {
  .contact p {
    font-size: 15px;
  }
}

/*--//responsive--*/

.align-form-map {
  grid-template-columns: 1fr 1fr;
  grid-gap: 80px;
}

h3.cont-head {
  font-size: 25px;
  line-height: 35px;
  color: #d1242a;
  margin-bottom: 35px;
}

form.signin-form {
  text-align: left;
}

.form-input {
  margin-bottom: 15px;
}

.form-inner-cont label {
  font-size: 16px;
  line-height: 20px;
  margin-bottom: 10px;
  color: #636363;
  display: block;
}

.form-inner-cont input,
.form-inner-cont textarea {
  outline: none;
  width: 100%;
  font-size: 15px;
  padding: 0px 15px;
  margin-bottom: 25px;
  color: #304659;
  height: 45px;
  text-align: left;
  -webkit-appearance: none;
  background: #ffffff;
  display: grid;
  grid-template-columns: .1fr 1fr;
  align-items: center;
  padding-left: 15px;
  border: 1px solid rgba(31, 94, 180, 0.22);
  border-radius: 20px;
}

.form-inner-cont input:focus,
.form-inner-cont textarea:focus {
  border: 1px solid #304659;
}

.form-inner-cont textarea {
  height: 125px;
  resize: none;
  padding: 15px 15px;
}

.btn-contact {
  min-width: 130px;
  cursor: pointer;
  text-decoration: none;
  -webkit-appearance: none;
  display: inline-block;
  font-style: normal;
  font-weight: normal;
  font-size: 15px;
  text-align: center;
  color: white;
  background: #d1242a;
  padding: 14px 18px;
  border-radius: 20px;
  transition: 0.3s ease;
  border: 2px solid #d1242a;
  width: 100%;
  margin-top: 15px;
  text-transform: uppercase;
}

.btn-contact:hover {
    color: #d1242a;
    background-color: white;
}

iframe {
  width: 100%;
  height: 100%;
  border: 5px solid #f5f5f5;
  border-radius: 20px;
}


@media all and (max-width: 1280px) {
  .form-41-mian {
    padding: 4em 0;
  }
}

@media all and (max-width: 1024px) {
  .align-form-map {
    grid-gap: 60px;
  }
}

@media all and (max-width: 991px) {
  .align-form-map {
    grid-gap: 60px;
    grid-template-columns: 1fr;
  }

  iframe {
    height: 350px;
  }
}

@media all and (max-width: 590px) {
  h3.cont-head {
    font-size: 30px;
    margin-bottom: 30px;
  }

  iframe {
    height: 300px;
  }
}

* {
	margin: 0;
	margin: 0;
	box-sizing: border-box;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

html {
    scroll-behavior: smooth;
}

section {
    padding-top: 50px;
}

hr {
    color: #a0a0a0;
    opacity: 0.3;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}
.container {        /*algemene container*/
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
}

/* -----------------------    nav-bar--------------------------*/

nav {
    background-color: #f8f9fa;
    box-shadow: 3px 3px 5px rgba(0,0,0,0.1);
}

nav ul {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    list-style-type: none;
}

nav li {
    height: 50px;
    text-decoration: none;
    display: flex;
    align-items: center;
}

nav li:first-child {
    height: 60px;
    margin-right: auto;
    margin-top: 10px;
    margin-bottom: 10px;
}

nav a, .menu {
    font-size: 1.1rem;
    height: 100%;
    padding: 0 20px;
    text-decoration: none;
    display: flex;
    align-items: center;
    color: black;
    text-align: center;
}

nav a:hover {
    background-color: #d1242a;
    color: white;
    transition: all 300ms ease-in-out;
}

ul svg:hover {
    fill: #d1242a;
    cursor: pointer
}

nav img {
    height: 85%;
}

.sidebar {
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    width: 250px;
    z-index: 999;
    background-color: rgba(255,255,255,0.7);
    box-shadow: -10px 0 10px rgba(0,0,0,0.05);
    backdrop-filter: blur(10px);
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    display: none;
}

.sidebar li, .sidebar a {
    width: 100%;
}

.sidebar a, .sidebar svg {
    padding: 0;
    padding-left: 15px;
}

.menu {
    display: none;
}

.invisible {
    display: none;
}

/* -----------------------    HERO --------------------------*/ 
.navbar-hero-wrapper {
    display: flex;
    flex-direction: column;
    height: 95dvh;
}



.hero {
    display: flex;
    flex-direction: column;
    justify-content: stretchd;
    height: 100%;
    padding-top: 10px;
}

.hero-left {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    flex-grow: 1;
    max-width: 100%;
}
.hero-left span {
  position: relative;
  display: inline-block;
}

.hero-left span::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 0.4em;
  background: #fcce1d; /* FFEB3B */
  z-index: -1;
  transform: rotate(-2deg); /* een tikje scheef, lijkt handgetrokken */
  border-radius: 0.2em; /* afgeronde uiteinden */
}

.hero-left img {
	width: 75%;
	margin-bottom: 1.5rem;
	margin-top: 1rem;
}

main h2 {
    font-size: 2.25rem;    
    max-width: 75%;
}

main h3 {
    padding-left: 15px;
    padding-right: 15px;
}

.hero-left h2,
.hero-left h3 {
    text-align: center;

}

.hero-right {
    background-image: url("hero_img2.jpg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
	display: none;
	width: 100%;
	margin: 70px;
	margin-right: 20px;
}


section {
    padding-bottom: 40px;
}

/* -----------------------    section-header--------------------------*/
.section-header {
	text-align: center;
	margin-bottom: 50px;
}

@font-face {
  font-family: 'BankGothic';
  src: url('BankGothic.ttf') format('truetype');
}

.section-header h2 {
	font-size: 25px;
	font-weight: 600;
	line-height: 1.2;
	position: relative;
	/* font-family: 'BankGothic', sans-serif; */
	margin-bottom: 60px;
	margin-top: 30px;
}
	
.section-header h2::after {
    display: block;
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    border-radius: 20px ;
    bottom: -0.65rem;
    content: "";
    width: 8rem;
    height: 0.15rem;
    background-color: #d1242a;
}

.section-header h2::before {
    display: block;
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    border-radius: 20px ;
    top: -0.65rem;
    content: "";
    width: 8rem;
    height: 0.15rem;
    background-color: #fcce1d;
}

/* -----------------------    diensten--------------------------*/

.container2 {       /*container voor de diensten*/
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    gap: 7px;
}

.panel {            /*bevat één naam en afbeelding van een dienst*/
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 80vh;
    min-width: 50px;
    max-height: 500px;
    border-radius: 50px;
    color: #fff;
    cursor: pointer;
    flex: 0.2;
    /* margin: 10px; */
    position: relative;
    *transition: all 700ms ease-in;
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    display: flex;
    box-shadow: 0 8px 8px 0 rgba(0, 0, 0, 0.15);
}
.panel H2 {
    font-size: calc(1rem + 0.50vw);
    transform: rotate(-90deg) translate(50%);
    width: max-content;
    backdrop-filter: blur(5px) saturate(100%);
    padding: 4px;
    border-radius: 4px;
    user-select: none;
}

.panel.active  {    /*het actieve panel wordt breder*/
    flex: 5;
}

.panel.fas, .panel i {
    user-select: none;
}
.panel.active H2 {
    opacity: 1;
    transform: rotate(0deg) translateY(-10px);
    left: 20px;
    bottom: 30px;
}
.container-testimonials {   /*container klantengetuigenissen*/
	max-width: 1170px;
	margin: auto;
	padding: 0 15px;

}

.panel.active a {
    background-color: #d1242a;
    height: 35px;
    width: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    text-decoration: none;
    font-size: 25px;
    z-index: 2000;
    *transition: all 300ms ease-in-out;
    *transition-delay: 25ms;
    opacity: 0;
    position: absolute;
    top: 50%;
}

.panel a {
    display: none;
}
.panel.active a {
    opacity: 1;
}

.previousBtn {
    left: 20px;
}

.nextBtn {
    right: 20px;
}


/* -----------------------    testimonials  --------------------------*/

.testimonials-item {
	background-color: #f8f9fa;
	padding: 30px;
	border-radius: 30px;
}

.testimonials-item .info{
	display: flex;
	align-items: center;
}

.testimonials-item  img{
	margin-right: 20px;
	vertical-align: middle;
}

.testimonials-item .name{
	font-size: 24px;
	font-weight: 600;	
	text-transform: capitalize;
	line-height: 1.2;
}

.testimonials-item p{
	margin-top: 20px;
	color: hsl(0, 0%, 40%);	
}

.testimonials-item .rating{
	margin-top: 15px;
	font-size: 14px;
	color: hsl(36, 88%, 66%); 
}

.testimonials-item .rating .google-logo{
	height: 18px;
	margin-right: 5px;
}

.testimonials .swiper-pagination {
	position: relative;
	margin-top: 40px;
	bottom: auto;
}
.testimonials .swiper-pagination-bullet {
	height: 12px;
	width: 12px;
	
}

.swiper-pagination-bullet-active {
     background: #d1242a;
}


/* -----------------------    logos  --------------------------*/

.logos {
	  width: 100%;
	  display: flex; 
	  flex-wrap: wrap;
	  justify-content: center;
	  gap: 3rem;
	  margin-left: auto;
	  margin-right: auto;
}

/* -----------------------    Team  --------------------------*/

#team p {
    margin-bottom: 25px;
    color: rgb(102, 102, 102);
    font-size: 1.2rem;
}
#team strong {
  font-size: 1.2rem;
  display: inline-block;
  position: relative;
  z-index: 1; /* tekst bovenop */
}
#team strong::after {
  content: "";
  opacity: 0.8;
  position: absolute;
  left: -2%;
  right: -2%;
  bottom: -0.05em;              /* bepaalt hoe laag de streep komt */
  height: 0.2em;               /* dikte van de stift */
  background: linear-gradient(
    2deg,                      /* lichte schuine hoek */
    transparent 10%, 
    #fcce1d 20%, 
    #fcce1d 80%, 
    transparent 90%
  );
  z-index: -1;                 /* achter de tekst */
}

ul.diensten {
  list-style: none; /* standaard bolletjes weg */
  padding: 0;
  margin: 0;
  margin-bottom: 2rem;
}

ul.diensten li {
  display: flex;
  align-items: center;
  padding: 0.8rem 0;
  border-bottom: 1px solid #e2e2e2;
  font-size: 1.2rem;
  color: #333;
}

ul.diensten li::before {
  content: "✔";
  color: #d1242a;
  margin-right: 0.6rem;
  font-size: 1.1rem;
}

.card-container {
    display: flex;    
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 2rem;
}

.card {
    position: relative;
    width: 300px;
    min-width: 220px;
    background-color: #f8f9fa;
    border-radius: 20px;
    box-shadow: 0 8px 8px 0 rgba(0,0,0,0.15);
    padding: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: 75px;
}

.card-image {
    width: 100px;
    border-radius: 50%;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 15px 35px -15px rgba(0,0,0,0.5), 0 5px 20px 0 rgba(0,0,0,0.1);
    
}

.card-image img  {
    width: 100%;

}
.card p {
    text-align: center;
}

.name {
    margin-top: 60px;
    margin-bottom: 8px;
    font-size: 24px;
    font-weight: 600;
    text-transform: capitalize;
    line-height: 1.2;
}



.functie, .omschrijving-persoon {
    color: hsl(0, 0%, 40%);
    margin-bottom: 12px;
}

.functie {
    font-size: 20px;
}

.top-fade {
    opacity: 0;
    transition: 400ms;
    transform: translateY(150px);
}

.top-fade.show {
    transform: translateY(0);
    opacity: 1;
}

/* -----------------------    vacatures  --------------------------*/

.vacatures {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 2rem;
}

.vacature {
    max-width: 475px;
    background-color: #f8f9fa;
    border-radius: 20px;
    padding: 20px;
    box-shadow: 0 8px 8px 0 rgba(0, 0, 0, 0.15);
    flex-shrink: 1;
    flex-grow: 1;
}

.vacature h3 {
    font-size: 1.5rem;
    margin-bottom: 15px;
    text-align: center;
}

.vacature a {
    color: white;
    text-decoration: none;
}

.vacature a:hover {
    color: #d1242a;
}

.vacature p {
    margin-bottom: 25px;
    text-align: justify;
    hyphens: auto;
}


.contact-btn {
    box-sizing: border-box;
    text-align: center;
    font-size: 1.15rem;
    border: none;
    border-radius: 15px;
    padding: 10px 20px;
    color: white;
    background-color: #d1242a;
    border: 2px solid #d1242a;
    transition: all 0.3s ease-in-out;
    
}
.contact-btn:hover {
    color: #d1242a;
    background-color: white;

}

.vacature-tekst {
    color: hsl(0, 0%, 40%);
}

.vacature-titel {
    margin-bottom: 8px;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.2;
}

/* -----------------------    contactformulier  --------------------------*/

label {
    color: black;
}

/* -----------------------    to top knop  --------------------------*/

.to-top {
 
    background-color: #d1242a;
    position: fixed;
    bottom: 16px;
    right: 32px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    text-decoration: none;
    font-size: 32px;
    z-index: 1000;
    opacity: 0;
    pointer-events: none;
    transition: all 300ms ease-in-out;

}

.to-top.actief {
    bottom: 32px;
    pointer-events: auto;
    opacity: 1;
}

.to-top:hover {
    opacity: 0.5;
}


/* -----------------------    footer  --------------------------*/

footer {
    position: relative;
    width: 100%;
    height: auto;
    padding: 50px 50px;
    background-color: #f8f9fa;
}

footer ul {
    padding-inline-start: 0;
    list-style: none;
}

footer .container {
    width: 100%;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    grid-gap: 20px;
    
}

footer .container .sec h2 {
    position: relative;
    color: #333;
    font-weight: 600;
    margin-bottom: 15px;
    font-size: 1.1rem;
}

footer .container .sec p {
    color:#555;
}

footer .container .sci  {
    margin-top: 20px;
    display: grid;
    grid-template-columns: repeat(4, 50px);
    
}

footer .container .sci li a  {
    display: inline-block;
    width: 36px;
    height: 36px;
    background: #d1242A;
    display: grid;
    align-content: center;
    justify-content: center;
    text-decoration: none;

}

footer .container .sci li a i  {
    color: white;
    font-size: 20px;
}

footer .container .quicklinks {
    position: relative;
}

footer .container .quicklinks ul li a {
    color: #555;
    text-decoration: none;
    margin-bottom: 10px;
    display: inline-block;
}

footer .container .contact .info {
    position: relative;
}

footer .container .contact .info li {
    display: grid;
    grid-template-columns: 30px 1fr;
    margin-bottom: 8px;
}

footer .container .contact .info li span {
    color: #555;
    font-size: 20px;
}

footer .container .contact .info li a {
    color: #555;
}

footer .wrapper-embuild {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-top: 8px;
}

footer .wrapper-embuild > *:nth-child(1){
    margin-right: 8px;
}

footer .embuild {
    color: black;
    font-size: 25px;
    font-family: "DM sans";
}

.copyright {
    width: 100%;
    background-color: #f8f9fa;
    text-align: center;
    padding: 20px 100px 30px;
    color: #555;
    border-top: 1px solid rgba(0,0,0,0.15);
}

/* -----------------------    media queries  --------------------------*/

@media (min-width: 576px) {
    .container {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 720px;
    }
    .sidebar {
        display: none;
    }
}  

@media (min-width: 992px) {
    .container {
        max-width: 960px;
    }
    section {
        padding-bottom: 70px;
        padding-top: 25px;
    }
    .hero {
        flex-direction: row;
    }
    .hero-left {
        max-width: 50%;
    }
    .hero-right {
		display: block;
    }
}

@media (min-width: 1200px) {
    .container {
        max-width: 1140px;
    }   
}  

@media (max-width: 767px) {
    .hideOnMobile {
        display: none;
    }
    .menu {
        display: block;
    }
    nav img {
        height: 70%;
    }
}

@media (max-width: 991px) {
    footer {
        padding: 40px;
    }
    
    footer .container {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 20px;
    }
}
@media (max-width: 767px) {
    footer .container {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr;
        grid-gap: 20px;
    }   
}


@media (max-width: 767px) and (orientation: portrait) {
    .container2 {
        flex-direction: column;
        justify-content: flex-start;
        height: 750px;
    }
    .panel {
        width: 95%;
        /* max-height: 50px; */
        justify-content: center;
    }
    
    .active {
        max-height: 500px;
        justify-content: flex-end; 
    }

    .panel h2 {
        transform: rotate(0deg) translate(0);
    }
    .vacatures {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding-left: 15px;
        padding-right: 15px;
    }
    .vacature, .card {
        width: 100%;
    }
    
    .section-header h2 {
        margin-bottom: 40px;
    }
}  

@media (max-width: 550px) {
    .card-container {
        flex-direction: column;
        margin-left: 15px;
        margin-right: 15px;
    }
    .section-header h2 {
    	font-size: 25px;
    }
} 
@media (max-height: 617px) {
	.navbar-hero-wrapper {
    	height: 100%;
	}
	.hero-right {
		margin: 20px;
		
	}
}



.swiper-wrapper{
    padding-bottom: 30px;
}

.swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction{
    bottom: 0px !important;
}

