@charset "UTF-8";
/* CSS Document */

/* =========================================================
   RESPONSIVE FOUNDATION (mobile-first overrides)
   Laadt NA style.css
========================================================= */

/* =========================================================
   0) TOKENS
========================================================= */
:root{
  --brand:#B4BD00;

  /* spacing */
  --s-2: clamp(6px, 0.4rem + 0.3vw, 10px);
  --s-1: clamp(10px, 0.6rem + 0.5vw, 14px);
  --s0:  clamp(12px, 0.75rem + 0.8vw, 20px);
  --s1:  clamp(16px, 1rem + 1.2vw, 28px);
  --s2:  clamp(24px, 1.2rem + 2vw, 44px);
  --s3:  clamp(32px, 1.6rem + 3vw, 64px);

  --gap: var(--s1);

  /* containers */
  --container: 90rem;          /* ~1440px */
  --container-narrow: 62.5rem; /* ~1000px */
  --gutter: var(--s1);

  /* header */
  --header-h: 75px;
  --header-top: clamp(10px, 1.5vh, 20px);

  /* radii */
  --r2: 20px;
  --r3: 40px;
  --r4: 50px;
}

/* =========================================================
   1) GLOBAL BASE / RESETS
========================================================= */
img, video, svg { max-width: 100%; height: auto; display: block; }
body { overflow-x: hidden;}

/* Fluid typography (globaal) */
h1{ font-size: clamp(34px, 5vw, 55px); }
h2{ font-size: clamp(28px, 4vw, 45px); }
h3{ font-size: clamp(22px, 3vw, 35px); }

.back-button { font-size: clamp(20px, 3vw, 25px); }
	
/* Let op: ul/ol globaal kan menu's beïnvloeden; hieronder fixen we footer-menu expliciet. */
p, ol, ul{ font-size: clamp(18px, 2vw, 25px); line-height: 1.45; }

/* container helpers */
.container{
  width: min(var(--container), calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
}
.container--narrow{
  width: min(var(--container-narrow), calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
}

/* =========================================================
   2) GLOBAL WIDTH OVERRIDES (wrappers fluid)
========================================================= */
#header{
  width: min(var(--container), calc(100% - (2 * var(--gutter))));
  height: var(--header-h);
  top: var(--header-top);
  border-radius: var(--r2);
}

.home-banner-text,
#page-content,
#officials-content,
#portfolio-single,
.footer-content,
.cta{
  width: min(var(--container), calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
}

#disciplines,
.card{
  width: min(var(--container-narrow), calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
}

.page-content-bullets{
  width: min(50rem, calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
}

.featured-content,
.blog-content{
  width: min(var(--container), calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
}

/* =========================================================
   3) COMPONENT BASE (niet media-gebonden)
========================================================= */
.nav-toggle{
  display:none;
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
}
.nav-toggle span{
  display:block;
  height: 2px;
  width: 24px;
  margin: 6px auto;
  background: #fff;
  transition: transform .25s ease, opacity .25s ease;
}

/* Nav show/hide per breakpoint */
.nav-desktop { display: block; }
.nav-mobile  { display: none; }

/* Mobile menu logo default */
.mobile-menu-logo{ display: none; }

/* =========================================================
   4) TYPOGRAPHY / SIZES (component-level, global)
========================================================= */
.payoff{
  font-size: clamp(30px, 4.5vw, 55px);
  line-height: 1;
}

.discipline-title-1, .discipline-title-2{
  font-size: clamp(25px, 4.2vw, 40px);
  line-height: 1.5;
}

.discipline-intro-1, .discipline-intro-2{
  font-size: clamp(20px, 4.2vw, 25px);
  line-height: 1.3;
}

.card-text p{
  font-size: clamp(20px, 4.2vw, 25px);
  line-height: 1.3;
}

.card-text h2{
  font-size: clamp(30px, 4.2vw, 40px);
  line-height: 1.3;
}

.cta p{
  font-size: clamp(25px, 4.2vw, 35px);
  line-height: 1.3;
}

.discipline-icon{
  height: clamp(35px, 4.2vw, 115px);
}

#about-me{
  margin-top: clamp(50px, 4.2vw, 100px);
}

#featured, #blog{
  padding-top: clamp(40px, 4.2vw, 90px);
  padding-bottom: clamp(0px, 4.2vw, 0px);
  padding-left: 0;
  padding-right: 0;
}

/* =========================================================
   4.1) FOOTER MENU FIX (desktop 15px)
   Oorzaak: globale ul font-size clamp() maakt menu te groot
========================================================= */
@media (min-width: 901px){
  .footer-menu,
  .footer-menu ul,
  .footer-menu li,
  .footer-menu li a{
    font-size: 15px !important;
    line-height: 1.2;
  }
}

/* =========================================================
   4.2) FOOTER CONTACT (global, één consistente versie)
========================================================= */
.footer-contact{
  font-family: 'Oswald', sans-serif;
  color: #fff;
  text-transform: none;
  letter-spacing: .02em;
}

.footer-contact-title{
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: var(--s-1);
  font-size: clamp(16px, 1.8vw, 18px);
}

.footer-contact-list{
  list-style: none;
  margin: 0;
  padding: 0;

  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Layout op LI zodat items met/zonder <a> gelijk zijn */
.footer-contact-item{
  margin: 0;
  padding: 0;

  display: grid;
  grid-template-columns: 44px 1fr;
  column-gap: 16px;
  align-items: center;

  line-height: 1.2;
  font-size: clamp(16px, 2vw, 18px);
}

/* Als er een <a> is: klikbaar, maar layout blijft van het <li> */
.footer-contact-item > a{
  display: contents;
  color: #fff;
  text-decoration: none;
}

.footer-contact-key{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  color: var(--brand);
  font-weight: 800;
  line-height: 1;
  min-width: 44px;
}

.footer-contact-key img.contact-icon{
  width: 18px;
  height: 18px;
  display: block;
  margin: 0 !important;
}

.footer-contact-value{
  color: #fff;
  opacity: .95;
}

/* hover alleen voor klikbare items */
.footer-contact-item > a:hover .footer-contact-value{
  color: var(--brand);
}

/* Desktop: iets ruimer + (optioneel) niet afbreken */
@media (min-width: 901px){
  .footer-contact-item{ grid-template-columns: 48px 1fr; }
  .footer-contact-value{ white-space: nowrap; text-align: left; }
}

/* =========================================================
   5) MOBILE (<= 900px)
========================================================= */
@media (max-width: 900px){

  /* 5.1 GLOBAL MOBILE SAFETY */
  html, body{ overflow-x: clip; }

  .nav-desktop { display: none; }
  .nav-mobile  { display: block; }

  /* 5.2 HEADER + MOBILE MENU */
  #header{
    left: 0;
    right: 0;
    width: 100%;
    max-width: 100%;
    transform: none;

    top: 0;
    border-radius: 0;
    padding-inline: var(--s0);
    padding-top: env(safe-area-inset-top);
    box-sizing: border-box;

    z-index: 1000;

    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: var(--s0);
  }

  .logo{
    width: 300px;
    height: 90px;
    margin: 10px 0 0 0;
  }

  /* Toggle: zichtbaar + fixed rechtsboven */
  .nav-toggle{
    display:block;
    position: fixed;
    top: calc(var(--s0) + env(safe-area-inset-top));
    right: var(--s0);
    z-index: 3000;
  }

  .navigation{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.92);

    transform: translateY(-100%);
    transition: transform .3s ease;
    z-index: 998;

    padding: calc(var(--header-h) + var(--s2) + env(safe-area-inset-top)) var(--s1) var(--s2);

    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }

  .navigation > ul,
  .navigation .menu{
    flex-direction: column;
    align-items: center;
    text-align: center;
    justify-content: flex-start;
    gap: var(--s1);
    font-size: 22px;
  }

  .navigation .menu li{
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .navigation .menu li a{
    justify-content: center;
    text-align: center;
  }

  .navigation .menu li a::before{ display:none; }

  /* Menu open */
  body.nav-open .navigation{ transform: translateY(0); }

  #header .navigation{ display:none; }
  body.nav-open #header .navigation{ display:block; }

  body.nav-open .nav-toggle span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
  body.nav-open .nav-toggle span:nth-child(2){ opacity: 0; }
  body.nav-open .nav-toggle span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }

  /* Mobile menu CTA (item 259) */
  .nav-mobile .menu .menu-item-259{
    display: flex;
    justify-content: center;
    margin-top: var(--s1);
  }

  .nav-mobile .menu .menu-item-259 a{
    width: auto;
    min-width: 200px;
    justify-content: center;
    padding: var(--s0) var(--s1);
    border-radius: 12px;
    font-size: clamp(18px, 5vw, 22px);
    background-color: var(--brand);
    color: #fff !important;
  }
  .nav-mobile .menu .menu-item-259 a:visited,
  .nav-mobile .menu .menu-item-259 a:active,
  .nav-mobile .menu .menu-item-259 a:focus{
    color: #fff !important;
  }
  .nav-mobile .menu .menu-item-259 a:hover{
    color: var(--brand) !important;
    background-color: #fff !important;
  }

  /* CTA: stack + netjes centreren */
  .cta{
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  /* Knop: centreren + ruimte ONDER de knop */
  .cta-button{
    width: 100%;
    display: flex;
    justify-content: center;

    /* omhoog t.o.v. tekst (jouw “hack”, maar fluid) */
    margin-top: clamp(-100px, -10vw, -40px);

    /* ruimte onderaan (groen vak langer) */
    margin-bottom: clamp(60px, 12vw, 120px);
  }

  /* CONTACT FORM — submit knop: altijd breed genoeg */
  .wpcf7-form input[type="submit"],
  .wpcf7-form button[type="submit"],
  input.wpcf7-submit,
  button.wpcf7-submit{
    width: fit-content !important;     /* override 25% */
    min-width: 10ch !important;        /* genoeg voor “VERZENDEN” */
    max-width: 100% !important;

    height: auto !important;
    min-height: 52px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    padding: 14px 28px !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
    line-height: 1.1 !important;
  }

  /* Als je pijltje-icoon via background-image gebruikt */
  .wpcf7-form input[type="submit"]{
    padding-left: 44px !important; /* ruimte voor het icoon links */
    background-position: left 14px center !important;
    background-size: 22px !important;
  }

  /* 5.3 LAYOUT: stack columns */
  #page-content,
  #officials-content,
  .portfolio-grid,
  .cta,
  .footer-content,
  .card{
    flex-direction: column;
    align-items: stretch;
  }

  #page-content{ padding-top: clamp(50px, 4.2vw, 100px); }

  .page-content-text,
  .page-content-img,
  .page-content-imgs,
  .page-content-form,
  .portfolio-col{
    width: 100%;
  }

  #disciplines{ flex-direction: column; }

  /* 5.4 HOME HERO */
  #home-banner{
    min-height: clamp(390px, 50svh, 520px);
    padding-top: 0 !important;
  }

  .home-banner-overlay{
    top: 0; right: 0; bottom: 0; left: 0;
    height: auto;
    min-height: 0;
  }

  .home-banner-text{
    width: min(var(--container), calc(100% - (2 * var(--gutter)))) !important;
    margin: 0 auto !important;
    padding: 0 !important;

    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--s2) !important;
    align-content: start;
  }

  .payoff{
    margin-top: calc(var(--header-h) + env(safe-area-inset-top) + var(--s1)) !important;
    padding: 0 !important;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }

  .intro{
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;

    font-size: clamp(18px, 5vw, 22px) !important;
    line-height: 1.35 !important;
    text-align: left;
  }

  /* 5.5 DISCIPLINES + ABOUT */
  #disciplines{ margin-top: clamp(-100px, -10vw, -50px) !important; }

  .discipline-1, .discipline-2{ max-width: 100%; }

  #about-me, #about-me .card{ overflow-x: hidden; }
  #about-me .card{ height: auto; }

  #about-me .card-img{
    flex: none;
    min-height: clamp(340px, 50vw, 340px);
    margin: var(--s1) 0;

    transform: none !important;
    animation: none !important;
    opacity: 1 !important;
  }

  #about-me .card-text{
    transform: none !important;
    animation: none !important;
    opacity: 1 !important;
  }

  /* 5.6 FOOTER LAYOUT (mobile) */
  #footer, .footer-content{ height: auto !important; overflow: visible !important; }

  .footer-content{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--s2);
  }

  .footer-contact{
    width: 100%;
    text-align: left;
    margin-top: var(--s1);
    order: 1;
    position: static !important;
    display: flex !important;
    flex-direction: column;
    gap: var(--s0);
    padding-bottom: var(--s2);
    z-index: 2;
  }

  .footer-menu{
    width: 100%;
    order: 2;
  }

  .footer-menu ul{
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  /* Mobiel: key/value iets compacter */
  .footer-contact-item{ grid-template-columns: 40px 1fr; }
  .footer-contact-item > a .footer-contact-value{ white-space: nowrap; }

  /* 5.7 TYPOGRAPHY — mobile tuning */
  h1{
    font-size: clamp(28px, 7.5vw, 40px);
    line-height: 1.05;
    margin-top: 100px;
    margin-left: 20px;
    color: #FFFFFF;
  }

  h2{ font-size: clamp(30px, 6vw, 32px);  line-height: 1.1; }
  h3{ font-size: clamp(20px, 5vw, 28px);  line-height: 1.15; }

  p, ol, ul{
    font-size: clamp(20px, 4.2vw, 25px);
    line-height: 1.5;
  }
  ol, ul{ line-height: 1.55; }

  /* MOBILE MENU LOGO */
  body.nav-open .mobile-menu-logo{ display: block; }

  body.nav-open .mobile-menu-logo img{
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    bottom: calc(100px + env(safe-area-inset-bottom));
    max-width: min(200px, 35vw);
    height: auto;
    z-index: 4000;
  }

  /* PORTFOLIO SINGLE: volgorde omdraaien */
  #portfolio-single .portfolio-grid{
    display: flex;
    flex-direction: column;
  }
  #portfolio-single .portfolio-grid > *:first-child{ order: 2; }
  #portfolio-single .portfolio-grid > *:last-child{  order: 1; }
}

/* =========================================================
   6) PAGE BANNER (>=900 basis)
========================================================= */
@media (min-width: 900px){
  #page-banner{ min-height: clamp(240px, 22vh, 360px); }

  #page-banner .page-banner-text{
    width: min(1440px, calc(100% - (2 * var(--gutter, 24px))));
    margin-inline: auto;
    padding-top: clamp(80px, 8vh, 140px) !important;
    padding-bottom: clamp(24px, 4vh, 72px) !important;
  }
}

@media (max-width: 600px){
  #page-banner{ min-height: clamp(190px, 22vh, 360px); }
  h1 {line-height: 35px;}
	.portfolio-intro { padding: 35px 0px 25px 0px;}
    .blog-intro {margin-top: -15px;}
	.page-content-back .back-button {margin: 30px 0px -10px 0px !important;}
	#blog-index .blog-card-title {font-size: 30px;}
}

/* =========================================================
   7) PAGE BANNER — LAPTOP/TABLET (900–1440 override)
   (moet NA de basis staan zodat dit wint)
========================================================= */
@media (min-width: 900px) and (max-width: 1440px){
  #page-banner{
    padding-top: 0 !important;
    min-height: clamp(240px, 24vh, 360px);
  }

  #page-banner .page-banner-text{
    width: min(var(--container), calc(100% - (2 * var(--gutter)))) !important;
    margin-inline: auto !important;

    padding-top: calc(
      var(--header-h) +
      var(--header-top) +
      clamp(24px, 3vw, 80px)
    ) !important;

    padding-bottom: clamp(16px, 3vw, 48px) !important;

    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #page-banner .page-banner-text h1{ margin: 0; }
}

/* =========================================================
   8) PAGE BANNER — very large screens (>=1980)
========================================================= */
@media (min-width: 1980px){
  #page-banner .page-banner-text{
    padding-top: clamp(80px, 7vh, 100px) !important;
  }
}

/* =========================================================
   PAGE FEATURED — mobile: laat hoogte meeschalen
========================================================= */
#page-featured{
  height: auto !important;      /* kill: height: 400px */
  min-height: 0 !important;     /* kill: min-height van desktop als die wringt */
  padding-block: var(--s3) !important;
  overflow: hidden;
}

/* =========================================================
   BLOG - flex verdeling voor class .page-content-single-content
========================================================= */

#page-content.page-content-single-content .page-content-text { flex: 2; }
#page-content.page-content-single-content .page-content-imgs { flex: 1; min-width: 0; }

/* =========================================================
   HOOGTE afbeelding op volgpagina's
========================================================= */

@media (max-width: 900px){
	.page-content-img-inner {
		min-height: 250px !important;
	}
	.page-content-shadow {
		height: 265px;
	}
}

/* =========================================================
   BACK button op single posts — geen gat naar content
========================================================= */

.page-content-back{
  width: min(var(--container), calc(100% - (2 * var(--gutter))));
  margin-inline: auto;
  margin-bottom: 20px;   /* klein beetje lucht */
  padding: 0;
}

.page-content-back .back-button{
  margin-top: 60px;         /* override portfolio -75px */
}

/* Belangrijk: als back-button vóór #page-content staat, kill de top-padding */
.page-content-back + #page-content.page-content-single-content{
  padding-top: 0;        /* was 100px */
}

/* =========================================================
   PORTFOLIO mobiel — kader niet afkappen, logo blijft contain
========================================================= */
@media (max-width: 900px){

  /* 1) Geef het kader voldoende hoogte (meest voorkomende fix) */
  .portfolio-image-inner, .portfolio-image-inner-screens {
    height: auto !important;
    min-height: clamp(220px, 55vw, 360px) !important; /* tune indien nodig */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
	margin-bottom: 40px;
  }

  /* 2) Logo blijft netjes binnen het kader */
  .portfolio-image-inner img{
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center !important;
    transform: none !important;
  }

  /* 3) Als er een parent is die het kader afsnijdt: alleen die “ontclippen” */
  .portfolio-image,
  .portfolio-item,
  .portfolio-col{
    overflow: visible !important;
  }
}

/* Footer menus wrapper */
.footer-menus{
  display: flex;
  gap: var(--s2);
  align-items: flex-start;
  justify-content: flex-end;
}

/* Mobile: menus onder elkaar */
@media (max-width: 900px){
  .footer-menus{
    width: 100%;
    flex-direction: column;
    gap: var(--s1);
  }

/* BLOG INDEX — fluid grid (alleen /blog) */
#blog-index .blog-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(520px, 1fr));
  gap: var(--s2);
}

/* kill oude flex-basis regels op cards (alleen /blog) */
#blog-index .blog-card{
  flex: initial;
  width: auto;
}

/* fluid image width binnen card (desktop/tablet) */
#blog-index .blog-card-img{
  flex: 0 0 clamp(140px, 18vw, 220px);
}

/* MOBIEL */
@media (max-width: 900px){

  /* grid mag nooit breder eisen dan viewport */
  #blog-index .blog-grid{
    grid-template-columns: 1fr;
  }

  /* image boven tekst */
  #blog-index .blog-card-link{
    flex-direction: column;
    min-width: 0;
  }

  #blog-index .blog-card-img{
    flex: none;
    width: 100%;
    border-right: 0;
    border-bottom: 10px solid #FFFFFF;
    min-height: 220px; /* of vervang door aspect-ratio */
  }

  /* safety: voorkom overflow door min-width:auto */
  #blog-index .blog-card{
    min-width: 0;
    max-width: 100%;
  }
	
  #blog-index {
    padding: 50px 0px 175px 0px;
}
}
