:root{
  /* Kleuren uit het logo */
  --brand:#235f3e;         /* donkergroen */
  --brand-2:#649c71;       /* midden-groen */
  --accent:#ffe107;        /* geel */
  --accent-ink:#c03e48;    /* rood/roest (optioneel accent) */
  --accent-orange:#ffaa07;  /**oranje voor buttons */
  --bg:#F6F6F6;
  --soft:#f4f6f0;          /* zacht gebroken wit */
  --text:#17212b;
  --muted:#667085;
  --border:#e6e6db;
/*  --shadow:0 10px 20px rgba(23,33,43,.06), 0 2px 6px rgba(23,33,43,.04);*/
--shadow: 0 2px 4px rgba(35,95,62,0.08),
          0 8px 18px rgba(35,95,62,0.06),
          0 20px 40px rgba(0,0,0,0.04);
  --radius:18px; --radius-lg:22px; --radius-xl:28px;
  --ring:0 0 0 3px rgba(100,156,113,.25);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji"; color:var(--text); background:var(--bg); line-height:1.6}
a{color:inherit}
img{max-width:100%; height:auto; display:block}
.container{max-width:1200px; margin:0 auto; padding:0 16px}

/* Buttons */
.btn{display:inline-flex; align-items:center; gap:.55rem; padding:.72rem 1.05rem; border-radius:var(--radius); border:1px solid var(--border); text-decoration:none; font-weight:650; transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease}
.btn.primary{background:linear-gradient(180deg, var(--brand-2), var(--brand)); color:#fff; border-color:transparent; box-shadow:var(--shadow)}
.btn.primary:hover{transform:translateY(-1px)}
.btn.ghost{background:#fff}
.btn.ghost:hover{box-shadow:var(--shadow)}
.btn.accent{background:var(--accent-orange); border-color:#e5c800;}

.muted{color:var(--muted)}
.grid{display:grid; gap:1rem}
.card{border:1px solid var(--border); border-radius:var(--radius-lg); background:#fff; box-shadow:var(--shadow)}
.card .content{padding:1.25rem}

/* Topbar */
.topbar{position:sticky; top:0; z-index:50; background:#ffffffcc; backdrop-filter:saturate(180%) blur(8px); border-bottom:1px solid var(--border)}
.topbar .row{display:flex; align-items:center; justify-content:space-between; padding:.55rem 0}
.brand{display:flex; align-items:center; gap:.75rem}
.brand .title{font-weight:700; line-height:1}
.brand .subtitle{font-size:.82rem; color:var(--muted)}
.nav-actions{display:flex; gap:.5rem}

/* Hero */
.hero{padding:5rem 0; background:linear-gradient(180deg, var(--soft), #fff)}
.hero .cols{display:grid; gap:2.2rem; grid-template-columns:1fr}
@media(min-width:768px){.hero .cols{grid-template-columns:1.05fr .95fr}}
.eyebrow{display:inline-block; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--brand); background:rgba(35,95,62,.08); padding:.35rem .6rem; border-radius:999px; border:1px solid rgba(35,95,62,.15)}
.hero h1{font-size:clamp(1.9rem, 2.6vw + 1rem, 3.2rem); line-height:1.12; margin:.6rem 0 0 0}
.hero p{margin-top:1rem; color:var(--muted); font-size:1.1rem}
.hero .cta{margin-top:1.25rem; display:flex; gap:.75rem; flex-wrap:wrap}
.logo-box{aspect-ratio:4/3; border:1px solid var(--border); border-radius:var(--radius-xl); background:var(--soft); display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow)}
.logo-box img{max-height:11rem}
.note{font-size:.75rem; color:var(--muted); text-align:center; margin-top:.5rem}

/* Section blocks */
section{padding:4.5rem 0}
section.border-y{border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
h2{font-size:clamp(1.45rem, 1.2vw + 1rem, 2.1rem); margin:0; position:relative}
h2:after{content:""; display:block; width:82px; height:4px; border-radius:999px; margin-top:.6rem; background:linear-gradient(90deg, var(--accent), var(--brand-2))}
.lead{color:var(--muted); margin-top:.6rem; max-width:60ch}

/* Features & services */
.features{grid-template-columns:1fr}
@media(min-width:640px){.features{grid-template-columns:repeat(3,1fr)}}
.services{grid-template-columns:1fr}
@media(min-width:640px){.services{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services{grid-template-columns:repeat(3,1fr)}}

/* Projects */
.projects{grid-template-columns:1fr}
@media(min-width:640px){.projects{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.projects{grid-template-columns:repeat(3,1fr)}}
.ph{aspect-ratio:4/3; background:linear-gradient(180deg, #f7f9f5, #eef2ec)}
figure{border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; background:#fff; box-shadow:var(--shadow)}
figcaption{padding:1rem; font-size:.95rem; color:#374151}

/* Reviews */
.reviews{grid-template-columns:1fr}
@media(min-width:768px){.reviews{grid-template-columns:repeat(3,1fr)}}
.stars{color:#f7c948}

/* About */
.about{grid-template-columns:1fr}
@media(min-width:768px){.about{grid-template-columns:1fr 1fr}}

/* CTA */
.cta{background:linear-gradient(180deg, #0e1712, #0b1210); color:#e7f0ea}
.cta .muted{color:#cfe1d6}
.cta-card{border:1px solid #193826; background:linear-gradient(180deg, #10231a, #0c1b14); border-radius:var(--radius-lg); box-shadow:var(--shadow)}
.cta form .row{display:grid; gap:1rem}
@media(min-width:640px){.cta form .row{grid-template-columns:1fr 1fr}}
.input, .textarea{width:100%; border:1px solid #254a35; background:#0f2017; color:#ecf5ef; border-radius:14px; padding:.7rem .85rem; outline:none; transition:box-shadow .18s ease}
.input:focus, .textarea:focus{box-shadow:var(--ring)}
.textarea{min-height:120px}

/* Footer */
footer{border-top:1px solid var(--border); background:#fff}
.footer-grid{display:grid; gap:1.25rem}
@media(min-width:768px){.footer-grid{grid-template-columns:1fr 1fr 1fr}}
.tiny{font-size:.9rem; color:var(--muted)}
.copyright{border-top:1px solid var(--border); text-align:center; font-size:.8rem; color:var(--muted); padding:1rem 0}

/* Links */
.link{position:relative; text-decoration:none}
.link:after{content:""; position:absolute; left:0; right:0; bottom:-3px; height:2px; background:linear-gradient(90deg,var(--brand-2),var(--accent)); transform:scaleX(0); transform-origin:left; transition:transform .22s ease}
.link:hover:after{transform:scaleX(1)}
