/*
Theme Name: Start met gemak site
Theme URI: https://startmetgemak.nl
Author: Start Met Gemak - Vincent
Author URI: https://startmetgemak.nl
Description: Maatwerk design
Version: 2.3
Text Domain: startmetgemak.nl
*/

@import url('https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');


html, body {
	margin: 0px;
	padding: 0px;	
	font-family: 'Rubik', sans-serif;	
	scroll-behavior: smooth;
}
p a {
	color: #0f458f;
	text-decoration: initial;
}
p a:hover {
	color: #000;
}
.top_bar {width: 100%;
padding-right: 0%;
text-align: right;
float: left;
height: 40px;
	line-height: 40px;
margin-top: 25px;
background: #0f458f;
color: #fff;
}
.dot {color: orange;}
.omslag .hidden_label,
.hidden_label {
	margin-bottom: -30px !important;
}

.omslag .gform_button {
	margin-top: 15px !important;
}
.omslag textarea,
.omslag input {
border: 1px solid #f2f2f2 !important;
}
h1, h2, h3 {
	font-family: 'Rubik', sans-serif;	
}
h1 {
	font-size: 50px;
	font-weight: light;
}
.omslag h1 {
	color: #fff !important;
}
h2 {
	font-size: 30px;
}
p {
	line-height: 34px;  	
	font-family: 'Rubik', sans-serif;	
}
  .reviews-inline {
      display: flex;
      gap: 1.5rem;
      align-items: center;
    }
    .review-item {
      xdisplay: inline-flex;
      align-items: center;
      gap: 0.25rem;
      color: #fff;
      font-size: 22px;
      font-weight: 500;
    }
    .review-item i {
      font-size: 1rem;
    }
    .review-item .rating {
      margin: 0 0.25rem;
    }
    .review-item .stars i {
      color: #fff;
      font-size: 0.85rem;
      margin: 0 1px;
    }
    .review-item .count {
      margin-left: 0.25rem;
      opacity: 0.8;
      font-size: 0.8rem;
    }
.sticky-content {
	position: sticky;
	top: 75px;
}
.xanimate-on-scroll {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease-out, visibility 0.2s ease-out;
}

.xanimate-on-scroll.animate__animated {
    opacity: 1;
    visibility: visible;
}

img.alignright {float:right; margin:0 0 1em 1em}
img.alignleft {float:left; margin:0 1em 1em 0}
img.aligncenter {display: block; margin-left: auto; margin-right: auto}
a img.alignright {float:right; margin:0 0 1em 1em}
a img.alignleft {float:left; margin:0 1em 1em 0}
a img.aligncenter {display: block; margin-left: auto; margin-right: auto}
.header {
	width: 100%;
	height: 100px;
	position: relative;
	float: left;
	z-index: 1;
}
.blok {
	width: 100%;
	position: relative;
	float: left;
}
.has-transparent-menu .blok {
	margin-top: -100px;
	padding-top: 125px !important;
}
.items ul {
  clear: both;
	list-style: none;
	margin: 0px; 
	padding: 0px;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
}
.items li {
    flex: 1 1 27.3%;
	min-width: 0;
	list-style: none;
	margin: 1%; 
	padding: 2%;
	position: relative;
  align-items: baseline;
  align-content: flex-start;
}
.home-diensten ul li {
    flex: 1 1 19% !important;
}
.home-diensten h2 {
	font-size: 22px;
}
.home-diensten p {
	line-height: initial;
}
.items li.bericht {
	margin: calc(1% - 2px); 
}
.items li img {
	border-radius: 10px;
}
/* 1/3 – 2/3 verdeling met nth-of-type */
.items.blok-1-3 ul {
  flex-wrap: nowrap;
}
.items.blok-1-3 ul li {
  flex: 0 0 auto;
}

/* échte eerste <li> */
.items.blok-1-3 ul li:nth-of-type(1) {
  flex-basis: 27.5%;
}

/* échte tweede <li> */
.items.blok-1-3 ul li:nth-of-type(2) {
  flex-basis: 60.5%;
}
.has-image {
	min-height: 350px;
}
.bericht {
	background: #fff;
	min-height: 200px;
	transition: all 0.5s;
	border: 1px solid #dadada;
}
.bericht:hover {
	box-shadow: 1px 1px 20px rgba(0,0,0,0.2);
}
.bericht a {
	text-decoration: none;
	color: #000;
}
.titel-content,
.button-content {
	margin: 0px !important;
	padding: 0px !important;
	padding-top: 0px !important;
padding-bottom: 0px !important;
}
.titel-content {
	margin-bottom: -55px !important;
}

.button-content {
	margin-top: -55px !important;
}
.uitgelicht-bericht {
	position: relative;
	min-height: 300px;
}

.uitgelicht-bericht .overlay {
	background: rgba(0,0,0,0.4);
	position: absolute;
	left: 0px;
	top: 0px;
	right: 0px;
	bottom: 0px;
}
.uitgelicht-bericht:hover .overlay {
	background: rgba(0,0,0,0.2);	
	transition: all 0.5s;
}

.uitgelicht-bericht h3 {
	color: #fff;
	font-size: 30px;
}

.uitgelicht-bericht span {
	text-align: center;
	 position: absolute;
  top: 50%;
	left: 50%;
  	-webkit-transform: translateY(-50%) translateX(-50%);
  	-ms-transform: translateY(-50%) translateX(-50%);
  	transform: translateY(-50%) translateX(-50%);
}
.uitgelicht-bericht .item-button {
	top: 30px;
	position: relative;
}
.vert-center-content {
	left: 5%;
	width: 90%;
	position: absolute;
  top: 50%;
  	-webkit-transform: translateY(-50%);
  	-ms-transform: translateY(-50%);
  	transform: translateY(-50%);
}
.vert-bottom-content {
	left: 5%;
	width: 90%;
	position: absolute;
  bottom: 5%;
}

.item-button {
	background: rgba(255,255,255,0.9);
	border: 2px solid rgba(255,255,255,0.4);
	padding: 15px;
	padding-left: 25px;
	padding-right: 25px;
	text-decoration: none;
	color: rgba(0,0,0,0.95);
	margin: 5px;
	text-align: center;
	font-weight: bold;
}
.item-button:hover {
	-webkit-animation: pulse 1s;
    animation: pulse 1s;
	background: rgba(0,0,0,0.6);
	color:rgba(255,255,255,0.95);
	transition: all 0.5s;
}

.item-afbeelding {
	width: 100%;
	position: absolute;
	left: 0px;
	top: 0px;
	right: 0px;
	height: 200px;
}
.bericht:hover,
.uitgelicht-bericht:hover {
	-webkit-animation: pulse 1s;
    animation: pulse 1s;
}

.item-button-vert {
	xwidth: calc(100% - 60px);
	display: block;
}
.item-button-hor {
	display: inline-block;
}
.button-style-vierkant {
	border-radius: 0px;
}
.button-style-rond {
	border-radius: 5px;
}

/* FILTER TABS */
.project-filter {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.project-filter .filter-item {
  text-decoration: none;
  color: #003E7E;
  font-weight: 600;
  padding: 0.25rem 0.5rem;
  border-bottom: 3px solid transparent;
  transition: border-color .2s;
	    font-size: 15px;
    text-align: center;
    background: #fff;
    border-radius: 9px;
	
	 display: flex;
  align-items: center;   /* verticale alignering */
  justify-content: center; /* horizontale alignering */
}
.project-filter .filter-item.active,
.project-filter .filter-item:hover {
  border-color: #0f458f;
}

/* GRID 2x2 */
.project-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: 300px; /* pas hoogte aan naar wens */
  gap: 1rem;
}
.project-thumb {
  background-size: cover;
  background-position: center;
  border-radius: 8px;
}

/* “Bekijk meer” knop */
.project-more {
  text-align: center;
  margin-top: 1.5rem;
}
.project-more .btn-more {
  display: inline-block;
  background: #0f458f;
  color: #fff;
  padding: 0.75rem 1.5rem;
  border-radius: 4px;
  text-decoration: none;
  font-weight: 600;
}

.logo img {
	position: absolute;
	height: 100px;
	width: auto;
	left: 0px;
	top: -17.5px;	
}
.wrapper {
	width: 98%;
	max-width: 1400px;
	margin: 0 auto;
	position: relative;
}

.hoofdmenu-container ul {
	float: right;
	margin: 0px;
	padding: 0px;
	padding-top: 25px;
}
.hoofdmenu-container ul ul {
	display: none;
}
.hoofdmenu-container ul li > ul {

	position: absolute;
	left: 0px;
	width: 300px;
	background: #fff;
	padding-left: 25px;
	padding-right: 25px;
	padding-bottom: 50px;
	box-shadow: 1px 10px 5px rgba(0,0,0,0.3);
	border-bottom-left-radius: 25px;
	border-bottom-right-radius: 25px;
}
.hoofdmenu-container ul li:hover ul {
	display: block;
}
.hoofdmenu-container li {
	list-style: none;
	position: relative;
	float: left;
	padding-left: 15px;
	padding-right: 15px;
}
.hoofdmenu-container li {
    position: relative;
}

/* Add the arrow for menu items that have children */
.hoofdmenu-container li > ul {
    display: none;
}

.hoofdmenu-container li.has-children > a::after {
    content: "▼"; /* Unicode for down arrow */
    font-size: 12px;
    margin-left: 8px;
    display: inline-block;
    transition: transform 0.3s ease;
}

/* Rotate the arrow when hovered */
.hoofdmenu-container li:hover > a::after {
    transform: rotate(180deg);
}
.hoofdmenu-container li a {
	text-decoration: none;
	text-transform: uppercase;
	font-size: 15px;
	font-weight: bold;
	line-height: 50px;
}
.hoofdmenu-container li:hover {
	-webkit-animation: pulse 1s;
    animation: pulse 1s;
}
.hoofdmenu-container ul li > ul {
	padding-top: 25px;
}
.hoofdmenu-container ul li > ul li {
	width: 100%;
	float: left;
	line-height: 35px;
}
.hoofdmenu-container li.current_page_item > a,
.hoofdmenu-container li:hover > a {
}


.hoofdmenu-container ul li.has-children > a::after {
    content: "▼";
    font-size: 12px;
    margin-left: 8px;
    display: inline-block;
    transition: transform 0.3s ease;
}

/* Draai pijltje bij hover */
.hoofdmenu-container ul li.has-children:hover > a::after {
    transform: rotate(180deg);
}

/* ❌ Verwijder pijltjes in submenu's */
.hoofdmenu-container ul li > ul li.has-children > a::after {
    content: none !important;
}

/* ===== MEGA MENU STRUCTUUR ===== */
.hoofdmenu-container ul li > ul {
    display: none;
    position: absolute;
    top: 100%;
    
    left: 50%;
    transform: translateX(-50%); /* midden op scherm */
    
    width: 1000px;
    background: #fff;
    box-shadow: 0 8px 16px rgba(0,0,0,0.2);
    border-radius: 10px;
    padding: 20px 20px 20px;
    z-index: 9999;
    flex-wrap: wrap;
}
.hoofdmenu-container ul li > ul a:hover {
	color: #0f458f;
}
/* Mega menu tonen */
.hoofdmenu-container ul li:hover > ul {
    display: flex;
}

/* ===== MEGA MENU KOLOMMEN ===== */
.mega-col {
    width: 22%;
    padding: 1%;
	border-right: 1px solid #f1f1f1;
}

.mega-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mega-col li a {
    font-size: 15px;
    padding: 0px;
	line-height: 26px !important;
    display: block;
    text-transform: none;
	font-weight: initial !important;
}

/* Titel van elke kolom */
li.submenu-titel > a {
    color: #0f458f !important;
    font-weight: bold !important;
    font-size: 16px;
    padding-bottom: 0px;
    display: block;
}

.mobile-menu {
	display: none;
}
.menu-full { 
display: none;
position: fixed;
background: #fff;
width: 100%;
height: 100%;
padding-top: 75px;
text-align: left;
bottom: 0px;
z-index: 8;
top: 0%; 
	right: 0px;
	left: 0px;
}
	.menu-full a {
		text-decoration: none;
	color: #000;
	}
.menu-full ul {
	padding: 0px;
	margin: 0px;
}
	.menu-full li {
		list-style: none;
		width: 100%;
		text-align: center;
		line-height: 50px;
		text-transform: uppercase;
	}
.footer {
	float: left;
	width: 100%;
	min-height: 300px;
	background: #f1f1f1;
}

.footer_blok {
	color: #666;
}
.footer a {
	color: #666; text-decoration: none;
}
.orange {
	background: #0f458f !important;
	color: #fff !important;
	border: 3px solid #0f458f !important;
	border-radius: 3px;
}
.white {
	background: rgba(0,0,0,0.2) !important;
	color: #fff !important;
	border: 3px solid #fff !important;
}

.gform_body li {
	flex: none !important;
list-style: none;
margin: 1%;
padding: 2%;
position: relative;
align-items: initial;
align-content: initial;
}

.cta-hoofdmenu {
	color: #fff;
	background: #0f458f;
	border-radius: 5px;
	line-height: 40px;
	position: absolute;
	top: 0px;
}
.cta-hoofdmenu-2 {
	color: #13b0c1;
	border: #13b0c1;
	border-radius: 5px;
	line-height: 40px;
	position: absolute;
	top: -10px;
}
.cta-hoofdmenu a {
	color: #fff !important;
		
}

.omslag .orange,
.omslag .white {
	border-radius: 3px !important;
}
.content-blok ul li {
    all: unset;
  list-style: disc !important; /* of een andere gewenste waarde */
  list-style-position: inside; /* als je bolletjes binnen wilt zien */
	float: left;
	display: list-item !important;
	line-height: 30px;
	width: 100%;

	
}
.wp-gallery-slider .swiper-wrapper {
  width: 100% !important;
  transform: translate3d(0, 0, 0);
}

.wp-gallery-slider .swiper-slide {
  width: 100% !important; /* één slide per view */
}

.wp-gallery-slider .swiper-button-prev,
.wp-gallery-slider .swiper-button-next {
  background-color: rgba(0, 0, 0, 0.6);
  width: 40px;
  height: 40px;
  border-radius: 4px; /* minder rond */
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wp-gallery-slider .swiper-button-prev::after,
.wp-gallery-slider .swiper-button-next::after {
  font-size: 18px;
}

.wp-gallery-slider .swiper-button-prev:hover,
.wp-gallery-slider .swiper-button-next:hover {
  background-color: rgba(0, 0, 0, 0.8);
}
/* 2) Zorg dat de slider de hele tegel opvult */
.items li .wp-gallery-slider {
  position: absolute;     /* li is al position:relative, dus dit werkt */
  inset: 0;               /* top/right/bottom/left: 0 */
  width: 100%;
  height: 100%;
  border-radius: inherit; /* volgt de 10px radius van je li */
}

/* 3) Clip alles netjes binnen de afgeronde hoeken */
.items li { overflow: hidden; }

/* 4) Laat wrapper/slides en de img de hoogte vullen */
.items li .wp-gallery-slider .swiper-wrapper,
.items li .wp-gallery-slider .swiper-slide { min-height: 350px; height: 100%; }

.items li .wp-gallery-slider img {
  width: 100%;
  height: 100%;
  object-fit: cover;      /* mooi bijsnijden binnen de tegel */
  display: block;
}
/* 1) Turn the WP gallery into a clean grid */
.gallery {
  --gap: 10px;          /* adjust spacing here */
  display: grid;
  gap: var(--gap);
}

/* Make grid columns follow the WP setting (1–6 shown; add more if needed) */
.gallery.gallery-columns-1 { grid-template-columns: 1fr; }
.gallery.gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.gallery.gallery-columns-3 { grid-template-columns: repeat(3, 1fr); }
.gallery.gallery-columns-4 { grid-template-columns: repeat(4, 1fr); }
.gallery.gallery-columns-5 { grid-template-columns: repeat(5, 1fr); }
.gallery.gallery-columns-6 { grid-template-columns: repeat(6, 1fr); }

/* 2) Neutralize legacy floats & widths WP sets on items */
.gallery .gallery-item {
  float: none !important;
  width: auto !important;
  margin: 0;            /* WP sometimes adds margins */
}

/* 3) Make the images square with cover, nice and tidy */
.gallery .gallery-icon { 
  line-height: 0;       /* remove gaps around images */
  overflow: hidden;     /* crop corners if you round images */
  border-radius: 10px;  /* optional, matches your design */
}

.gallery .gallery-item img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;  /* force square */
  height: auto;         /* keep for older browsers; aspect-ratio handles height */
  object-fit: cover;    /* crop to fill */
  border: 0px !important;            /* kill default image borders if any */
}
.gallery br {
  display: none !important;
}
.item-button {
    color: #fff;
    border: 3px solid #0f458f !important;
    background: #0f458f !important;
    color: #fff !important;
    border-radius: 15px;
}
.kwaliteiten li.item .content_icon {
	float: left;
	position: absolute;
	color: green;
	left: 20px;
	width: 30px;
} 
.kwaliteiten li.item h3 {
	margin-left: 40px;
}

.kwaliteiten li.item .content_icon i {
	font-size: 28px !important;
}
.kwaliteiten li.item {
	
}
.blok-buttons {
	width: 100%; 
}
.top_bar a {
	color: #fff;
}
@media (max-width: 960px) {
	.project-filter {
    display: flex;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; /* smooth scroll op iOS */
    scrollbar-width: none; /* Firefox: hide scrollbar */
    gap: 20px;
    padding: 10px 0;
    white-space: nowrap;
}

.project-filter::-webkit-scrollbar {
    display: none; /* Chrome/Safari: hide scrollbar */
}

.project-filter a {
    flex: 0 0 auto; /* voorkom dat items wrappen */
}
 .logo img {
	position: absolute;
	height: 80px;
	width: auto;
	left: 0px;
	top: -5px;	
}
.blok-buttons {
	width: initial !important; 
}
	.project-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 180px;
  }

.sticky-content {
	position: initial;
	top: initial;
}
.vert-center-content,
	.vert-bottom-content {
	left: 5%;
	width: 90%;
	position: relative;
  top: 0%;
  bottom: initial;
  	-webkit-transform: translateY(-0%);
  	-ms-transform: translateY(-0%);
  	transform: translateY(-0%);
		padding-top: 25px;
		float: left;
}	
	.has-image {
	min-height: 50vh;
}
	nav.hoofdmenu,
	.mob-hide {
		display: none;
	}
	.mobile-menu {
		display: block;
font-size: 40px;
color: #000;
		margin-top: 65px;
	}
	.menu-full .mobile-menu  {
		color: #000;
		z-index: 9;
	}
	.mobile-menu  {
		xcolor: #000;
	}
	.menu-full .menu-button, .menu-button {
		color: #000;
		z-index: 2;
top: 20px;
right: 20px;
		position: absolute;

	}
	
	.menu-button {
		color: #000;
	}
	.footer_blok {
	width: 96%;
	margin: 2%;
	float: left;
		text-align: center;
}
	.items ul {
  display: block;
  flex-wrap: initial;
  flex-direction: initial;
}
.items li {
    flex: initial;
width: 94%;
	overflow: initial;
	margin-top: 25px;
	margin-bottom: 25px;
	float: left;
	xmin-height: 350px;
}
	.kwaliteiten li.item {
		min-height: initial;
		padding-top: 0px;
		padding-bottom: 0px;
		margin: 0px;
		margin-bottom: -10px;
	}
	.kwaliteiten li.item h3 {
		margin-left: 40px;
		padding-bottom: 0px;
		margin-bottom: 0px;
	}
	.kwaliteiten li.item p {
		margin-left: 40px;
		margin-top: 0px !important;
	}
	.kwaliteiten li.item .content_icon {
		left: 5px;
	}
	a.item-button {
		width: 85% !important;
	}
	.has-style h1, h1 {
		font-size: 30px;
	}
}