:root {
    --mosgroen: #8BA17F;
    --blauw: #59C6F2;
    --grijs: #545E75;
}

/* ======== STANDAARD STYLING ======== */

html {
    scroll-behavior: smooth;
}

body,
html {
    overflow-x: hidden;
}

.container {
    max-width: 1300px;
}

body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body.no-scroll {
    overflow: hidden;
}

a {
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    text-decoration: none;
}

p {
    color: #221E1F;
    font-size: 17px;
    line-height: 30px;
  	 font-family: "open-sans", sans-serif;
}

input:focus,
textarea {
    outline: none !important;
}

h1, h2, h3, h4, h5, h6 {
    font-family: "bodoni-urw", serif;
    font-weight: 600;
	letter-spacing: 0.5px;
}

/* ======== HEADER ======== */

.header {
    background: var(--mosgroen);
    padding-top: 25px;
    padding-bottom: 25px;
}

h1.titelwebsite {
    color: #fff;
    margin-bottom: 0;
    font-size: clamp(24px, 5vw, 35px);
}

.menuwrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.nav-ul {
    padding-left: 0 !important;
    list-style: none;
    display: flex;
    margin-bottom: 0;
}



ul.nav-ul li a:hover {
    color: #393939;
}

/* ======== MENU FIXED ======== */

.menu-fixed {
    position: fixed;
    top: 0;
    width: 100%;
    background: #202f20;
    z-index: 1000;
    transform: translateY(-100%);
    transition: transform 0.4s;
    -webkit-box-shadow: 0 0 30px 5px rgba(0, 0, 0, .2);
    -moz-box-shadow: 0 0 30px 5px rgba(0, 0, 0, .2);
    box-shadow: 0 0 30px 5px rgba(0, 0, 0, .2);
}

.menu-fixed.visible {
    transform: translateY(0);
}

.header-visible {
    padding-top: 20px;
    padding-bottom: 20px;
    background-color: var(--mosgroen);
}

.visible h1.titelwebsite {
    color: #fff;
    margin-bottom: 0;
    font-size: clamp(24px, 5vw, 28px);
}

/* ======== CONTENT ======== */

.innertekst {
  
}

.innertekst-left {
    padding-left: 30px;
}

.innertekst p {
    margin-bottom: 20px;
}

.slider-top img {
    border-radius: 10px;
}

.inhoud {
    padding-top: 80px;
    padding-bottom: 80px;
}

.inhoud h1 {
    font-size: 50px;
    color: #393939;
    margin-bottom: 10px;
    font-weight: 600;
}

.dik {
    display: block;
    margin-bottom: 10px;
    font-weight: 800;
}

.inhoud h2 {
    color: var(--mosgroen);
    font-size: 50px;
    font-weight: 600;
}

.blauw-inhoud {
    padding-top: 100px;
    padding-bottom: 100px;
    background-color: #687560;
}

.blauw-inhoud h3 {
    color: #393939;
    font-size: 25px;
    line-height: 30px;
    font-weight: 600;
    position: relative;
    text-align: center;
    margin-top: 10px;
}

.blauw-inhoud h3::after {
    content: "";
    display: block;
    height: 1px;
    background-color: #d4d4d4;
    margin: 20px auto;
}

.witblok {
    padding: 40px 25px;
    display: flex;
    flex-direction: column;
    text-wrap-style: balance;
    border-radius: 10px;
}

.afbeelding-kavel {
    border-radius: 10px;
    -webkit-box-shadow: 0 0 25px 5px rgba(0, 0, 0, 0.05);
    -moz-box-shadow: 0 0 25px 5px rgba(0, 0, 0, 0.05);
    box-shadow: 0 0 25px 5px rgba(0, 0, 0, 0.05);
    margin-bottom: 20px;
    margin-top: 20px;
}


/* ======== OVERLAY MENU ======== */

.menu-btn {
    position: fixed;
    top: 20px;
    right: 20px;
    width: 60px;
    height: 60px;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 8000;
    border-radius: 10px;
    display: none;
}

.menu-btn div {
    width: 40px;
    height: 4px;
    background: #fff;
    margin: 4px 0;
    border-radius: 50px;
    transition: transform 0.4s cubic-bezier(0.77, 0, 0.18, 1), opacity 0.3s ease, width 0.2s ease;
}

.overlay-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgb(0 0 0 / 72%);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.6s ease-in-out;
    z-index: 100;
}

.menu-overlay li a {
    color: var(--donker);
}

.overlay-menu.show {
    opacity: 1;
    visibility: visible;
}

.menu-overlay .aanvraag-doen {
    margin-top: 40px;
}

.menu-overlay .aanvraag-doen a {
    color: #fff !important;
    font-size: 24px !important;
}

/* Menu Overlay Container */
.menu-overlay {
    position: fixed;
    top: 0;
    right: -400px;
    width: 400px;
    height: 100vh;
    background: var(--mosgroen);
    color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: right 0.6s cubic-bezier(0.77, 0, 0.18, 1);
    z-index: 102;
    overflow-y: auto;
}

.menu-overlay ul {
    list-style: none;
    padding: 0;
    text-align: center;
}

.menu-overlay li {
    margin: 20px 0;
    font-size: 32px;
    cursor: pointer;
    transition: 0.3s;
    color: var(--donker);
}

.menu-overlay li:hover {
    color: gray;
}

/* Toggle Animation */
.menu-overlay.open {
    right: 0;
}

/* Smoother, fluid animation for menu button */
.menu-btn.open div:nth-child(1) {
    transform: translateY(12px) rotate(45deg);
}

.menu-btn.open div:nth-child(2) {
    opacity: 0;
    width: 0;
}

.menu-btn.open div:nth-child(3) {
    transform: translateY(-12px) rotate(-45deg);
}

.current-menu-item a {
    color: #ef7e2a;
    font-weight: 400;
}

.menu-items a:hover {
    color: #ef7e2a;
}

.open ul#menu-hoofdmenu {
    display: flex;
    flex-direction: column;
}

ul.nav-ul li a {
    color: #fff;
    margin-left: 20px;
    font-size: 22px;
    font-weight: 600;
    font-family: "open-sans", sans-serif;
}

/* ======== INTERESSE ======== */

.footer-interesse {
    padding-top: 80px;
    padding-bottom: 80px;
}

.footer-interesse h4 {
    font-size: 45px;
}

.wpcf7-form input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
select,
textarea {
    width: 100% !important;
    padding: 8px;
    margin-top: 5px;
    background: #eeeeee;
    border: 0;
}

.wpcf7-form label {
    width: 100% !important;
    color: #221e1f;
    font-weight: 600;
    font-size: 16px;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner {
    background: var(--grijs);
    color: #fff;
    border: none;
    padding: 10px 20px;
    text-transform: uppercase;
    font-weight: 600;
    border-radius: 30px;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner:hover {
    background: var(--mosgroen);
}

.wpcf7 form.sent .wpcf7-response-output {
    border-color: #46b450;
    background: #46b450;
    text-align: center;
    padding: 15px;
    font-size: 17px;
    font-weight: 600;
}

div#formVerstuurdModal .modal-content {
    padding: 30px !important;
    -webkit-box-shadow: 0 10px 30px 0 rgba(0, 0, 0, .2)!important;
    -moz-box-shadow: 0 10px 30px 0 rgba(0, 0, 0, .2)!important;
    box-shadow: 0 10px 30px 0 rgba(0, 0, 0, .2)!important;
    border: none!important;
}

h5#formVerstuurdModalLabel {
    font-size: 25px;
    margin-bottom: 0;
    margin-top: 0;
    font-weight: 600;
}

div#formVerstuurdModal .modal-body {
    font-size: 18px;
}

div#formVerstuurdModal .modal-content {
    padding: 30px !important;
}

div#formVerstuurdModal {
    text-align: center;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
    border-color: #ffb900 !important;
    background: #ffb900 !important;
    color: #393939;
    font-size: 17px;
    padding: 15px;
    text-align: center;
    font-weight: 600;
}

.blok-partijen {
    display: flex;
    justify-content: center;
}

.blok-partijen img {
    width: 170px;
    margin-right: 10px;
}

.footer {
    padding: 50px 0;
    color: #fff;
}

.footer h5 {
    font-size: 27px;
    color: #393939;
    margin-right: 35px;
    margin-bottom: 30px;
    font-weight: 700;
}

.blok-partijen {
    display: flex;
}

img.logo-holleman {
    width: 195px;
    margin-right: 32px;
}

#woning,#situatie,#omgeving,#interesse {
    scroll-margin-top: 73px;
}

img.binnenkort {
    width: 300px;
    position: absolute;
    left: 0;
}

.innertekst strong {
    font-size: 18px;
}


.tekst-left-twee p {
    font-size: 18px !important;
}

.slider-vervolg {
    aspect-ratio: 16 / 6;
    object-fit: cover;
}

.downloads-loop {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 gelijke kolommen */
    gap: 20px; /* ruimte tussen items */
    margin: 40px 0;
}

.download-item {
    background: #fff;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: center;
    margin-bottom: 15px;
    -webkit-box-shadow: 0 0 20px 5px rgba(0, 0, 0, .2);
    -moz-box-shadow: 0 0 20px 5px rgba(0, 0, 0, .2);
    box-shadow: 0 0 20px 5px rgba(0, 0, 0, .2);
    padding-top: 30px;
}

.download-btn {
    display: inline-block;
    margin-top: 15px;
    padding: 10px 20px;
    background: #2d3629;
    color: #fff;
    text-decoration: none;
    border-radius: 0px 0px 9px 9px;
    font-weight: 500;
    padding: 15px 20px;
    font-weight: 600;
    font-size: 15px;
    width: 100%;
    font-family: "open-sans", sans-serif;
    display: flex;
    justify-content: center;
    flex-direction: row;
    align-items: center;
    text-transform: uppercase;
}

.download-btn:hover {
    background: #000000;
}

i.fa-solid.fa-arrow-right {
    margin-left: 5px;
}

.download-item h3 {
    margin-bottom: 10px;
    color: #393939;
    font-size: 25px;
    line-height: 30px;
}

/* Responsive */
@media (max-width: 992px) {
    .downloads-loop {
        grid-template-columns: repeat(2, 1fr); /* 2 kolommen op medium schermen */
    }
}

@media (max-width: 600px) {
    .downloads-loop {
        grid-template-columns: 1fr; /* 1 kolom op kleine schermen */
    }
}

.downloads-blok {
    background-color: #687560;
    padding-top: 40px;
    padding-bottom: 40px;
}

.inhoud-vervolg {
    padding-top: 75px;
    padding-bottom: 75px;
}

li.interesse a {
    background: #fff;
    color: #000 !important;
    padding: 10px 20px;
    border-radius: 40px;
    font-size: 20px !important;
    font-weight: 600 !important;
    position: relative;
    top: 2px;
}