/* Codif shared styles — keep comments in English */
:root{
  --brand-500:#27A39A;
  --brand-600:#20807A;
  --brand-700:#165F5A;
  --brand-50:#F1FBFA;
  --brand-100:#E4F6F4;
  --surface:#FFFFFF;
  --surface-2:#F6FAF9;
  --text:#102726;
  --muted:#5E6E6C;
  --ring: rgba(32,128,122,.35);
  --radius:16px;
  --shadow:0 8px 24px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--surface)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.container{max-width:1100px;margin:0 auto;padding:0 20px}

/* Header */
header{position:sticky;top:0;background:#fff;border-bottom:1px solid #eef2f2;z-index:20}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;font-weight:700}
.brand img{width:32px;height:32px}
.menu{display:flex;align-items:center;gap:22px}
.menu a{font-weight:500;color:#2a3a39}
.menu a.active{background:var(--brand-600);color:#fff;padding:8px 12px;border-radius:999px}
.cta{display:inline-flex;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 16px;border-radius:12px;border:1px solid var(--brand-600);background:var(--brand-600);color:#fff;font-weight:600;box-shadow:var(--shadow)}

.menu a.over-codif {
  margin-left: 2rem; /* of bv. 40px */
  display: inline-block;
}

/* 2 kolommen layout voor contact */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 48px;
}

/* Zorg dat de twee cards klein blijven */
.contact-grid .usps {
  grid-template-columns: 1fr; /* i.p.v. 3 of 4 kolommen */
}

/* Portret lekker groot */
.contact-grid .portrait {
  width: 320px;
  height: 380px;
  object-fit: cover;
  border-radius: 20px;
  box-shadow: var(--shadow);
  border: 1px solid #e9efee;
}

/* Mobiel: onder elkaar */
@media (max-width: 860px) {
  .contact-grid {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .contact-grid .portrait {
    margin: 24px auto 0;
  }
}


/* Mobile */
.hamburger{display:none;background:transparent;border:0;font-size:24px}
@media (max-width:860px){
  .menu{display:none}
  .hamburger{display:block}
}
/* Added later */

/* --- Landing additions --- */
.btn-ghost{
  /* Button with outline (secondary action) */
  background: transparent;
  color: var(--brand-600);
  border: 1px solid var(--brand-600);
}

.portrait{
  /* Make personal photo friendly, crisp and consistent */
  width: 320px;
  height: 380px;
  object-fit: cover;           /* keep proportions, crop to frame */
  border-radius: 20px;
  box-shadow: var(--shadow);
  border: 1px solid #e9efee;
}

/* Light alternate surface for contrast sections */
.surface-alt{ background: var(--surface-2); }

.sr-only{
  /* Accessibility helper for screen readers */
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}


/* Sections */
section{padding:56px 0}
section h1{font-size:40px;line-height:1.1;margin:14px 0}
section h2{font-size:28px;margin:0 0 18px}
section .sub{color:var(--muted);margin-top:-8px}

.hero{padding:64px 0;background:linear-gradient(180deg, #ffffff 0%, var(--surface-2) 100%)}
.hero .wrap
{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:36px;
  align-items:stretch
}
.hero .wrap > .illustration {
  display: flex;
  align-items: center;   /* plaatje verticaal centreren */
  justify-content: center;
}
.hero .wrap > .illustration img {
  height: 100%;   /* afbeelding past zich aan de containerhoogte aan */
  width: auto;    /* verhouding blijft behouden */
  max-height: 100%; /* voor de zekerheid */
}
@media (max-width:860px){.hero .wrap{grid-template-columns:1fr}section h1{font-size:34px}}
.usps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px}
.card{background:#fff;border:1px solid #e9efee;border-radius:var(--radius);padding:18px;box-shadow:0 4px 14px rgba(0,0,0,.04)}
.card h3{margin:0 0 6px;font-size:16px}
.card p{margin:0;color:var(--muted);font-size:14px}
@media (max-width:860px){.usps{grid-template-columns:1fr 1fr}}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media (max-width:860px){.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}
.list{margin:10px 0 0 0;padding:0 0 0 18px;color:var(--muted)}

.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.step{position:relative;padding-top:8px}
.step::before{content:\"\";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--brand-600),var(--brand-500));border-radius:999px;opacity:.25}

.case{display:flex;gap:14px}
.case .tag{font-weight:700;color:var(--brand-700)}

form{display:grid;gap:12px}
input,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #dfe7e6;background:#fff;font:inherit}
input:focus,textarea:focus{outline:2px solid var(--ring);border-color:var(--brand-600)}
.check{display:flex;gap:10px;align-items:flex-start;color:var(--muted);font-size:14px}

footer{padding:40px 0;border-top:1px solid #eef2f2;background:#fff;color:#485A58}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:18px}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr}}

.muted{color:var(--muted)}
.badge{display:inline-block;padding:6px 10px;border-radius:8px;background:var(--brand-50);border:1px solid var(--brand-100);color:var(--brand-700);font-weight:600;font-size:12px}