/* =========================================================
   JCV Makelaars — schone huisstijl (zonder WordPress)
   ========================================================= */
:root{
  --accent:#91b2c3;
  --accent-dark:#7c9db0;
  --ink:#303030;
  --grey:#818181;
  --bg:#ffffff;
  --bg-alt:#f8f8f8;
  --line:#e8e8e8;
  --line2:#dbdbdb;
  --wrap:1150px;
  --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{
  margin:0;
  font-family:"Open Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  font-size:14px;line-height:1.7;color:var(--grey);background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:inherit;color:var(--ink);margin:0 0 .5em;font-weight:600;line-height:1.25}
p{margin:0 0 1.2em}
a{color:var(--accent-dark);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:24px}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;min-height:90px;gap:24px}
.brand img{height:56px;width:auto}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  display:block;padding:10px 14px;font-size:13px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink);border-radius:3px;transition:color .2s var(--ease)
}
.nav a:hover,.nav a[aria-current="page"]{color:var(--accent)}
.nav .flag{padding:8px 10px}
.nav .flag img{height:18px;width:auto;display:block}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;margin:-8px;color:var(--ink)}

/* ---------- Hero ---------- */
.hero{width:100%;height:clamp(320px,46vw,560px);overflow:hidden}
.hero img{width:100%;height:100%;object-fit:cover;object-position:center}

/* ---------- CTA band ---------- */
.cta-band{background:var(--bg-alt);border-bottom:1px solid var(--line)}
.cta-band .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-block:34px}
.cta-band p{margin:0;font-size:clamp(1.1rem,2.4vw,1.5rem);font-weight:300;color:var(--grey)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;background:var(--accent);color:#fff;border:0;cursor:pointer;
  font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:14px 30px;transition:background .2s var(--ease),transform .15s var(--ease)
}
.btn:hover{background:var(--accent-dark);color:#fff;transform:translateY(-1px)}

/* ---------- Sections ---------- */
section{padding-block:clamp(56px,8vw,90px)}
.section-alt{background:var(--bg-alt)}
.section-head{text-align:center;margin-bottom:clamp(36px,5vw,54px)}
.section-head h2{font-size:24px;text-transform:uppercase;letter-spacing:.03em;margin:0}
.section-head .rule{width:70px;height:2px;background:var(--accent);border:0;margin:20px auto 0}
.lead{max-width:860px;margin-inline:auto;text-align:center;font-size:15px}
.lead p:last-child{margin-bottom:0}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);max-width:960px;margin:clamp(30px,4vw,50px) auto 0}
.team-member{text-align:center}
.team-member h3{font-size:19px;text-transform:uppercase;letter-spacing:.03em;margin-bottom:18px}
.team-member img{width:100%;aspect-ratio:3/2;object-fit:cover}
.socials{display:flex;justify-content:center;gap:14px;margin-top:16px}
.socials a{color:var(--accent);display:grid;place-items:center;transition:color .2s var(--ease),transform .15s var(--ease)}
.socials a:hover{color:var(--accent-dark);transform:translateY(-2px)}
.socials svg{width:26px;height:26px;display:block}

/* ---------- Aanbod ---------- */
.aanbod-inner{text-align:center}
.aanbod-inner p{font-size:15px}
.aanbod-inner .btn{margin-top:10px}

/* ---------- Diensten (tijdlijn) ---------- */
.timeline{position:relative;max-width:960px;margin:0 auto}
.timeline::before{content:"";position:absolute;top:6px;bottom:6px;left:50%;width:2px;background:var(--accent);transform:translateX(-50%)}
.tl-item{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:0 56px;align-items:center;margin-bottom:64px}
.tl-item:last-child{margin-bottom:0}
.tl-item::after{content:"";position:absolute;left:50%;top:14px;width:16px;height:16px;border-radius:50%;background:var(--accent);transform:translateX(-50%);border:3px solid #fff;box-shadow:0 0 0 1px var(--accent)}
.tl-item .tl-img{margin:0}
.tl-item .tl-img img{width:100%;aspect-ratio:3/2;object-fit:cover}
.tl-item .tl-text h3{font-size:18px;text-transform:uppercase;letter-spacing:.02em;margin-bottom:14px}
.tl-item .tl-text p:last-child{margin-bottom:0}
/* even rijen: tekst links, beeld rechts */
.tl-item:nth-child(even) .tl-img{order:2}
.tl-item:nth-child(even) .tl-text{order:1;text-align:right}

/* ---------- Nieuws ---------- */
.news{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,50px);max-width:1000px;margin-inline:auto}
.news-item img{width:100%;aspect-ratio:16/9;object-fit:cover;margin-bottom:20px}
.news-item p:last-child{margin-bottom:0}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,6vw,70px);max-width:1050px;margin-inline:auto;align-items:start}
.contact-form label{display:block;margin-bottom:16px}
.contact-form span{display:block;margin-bottom:6px;color:var(--ink);font-weight:600}
.contact-form input,.contact-form textarea{
  width:100%;border:1px solid var(--line2);border-radius:4px;padding:11px 12px;
  font-family:inherit;font-size:14px;color:var(--ink);background:#fff
}
.contact-form textarea{min-height:150px;resize:vertical}
.contact-form input:focus,.contact-form textarea:focus{outline:0;border-color:var(--accent)}
.contact-info h3{font-size:18px;text-transform:uppercase;letter-spacing:.02em;margin-bottom:6px}
.contact-info .row{margin-bottom:14px}
.contact-info .lbl{color:var(--ink);font-weight:600}
.contact-info a{color:var(--grey)}
.contact-info a:hover{color:var(--accent)}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-alt);border-top:1px solid var(--line);padding-block:26px;text-align:center;font-size:13px}

/* ---------- Responsive ---------- */
@media (max-width:820px){
  .team,.news,.contact-grid{grid-template-columns:1fr}
  .timeline::before{left:26px}
  .tl-item{grid-template-columns:1fr;gap:16px;padding-left:64px;margin-bottom:44px}
  .tl-item::after{left:26px}
  .tl-item .tl-img{order:1 !important}
  .tl-item .tl-text{order:2 !important;text-align:left !important}
}
@media (max-width:720px){
  .nav{
    position:fixed;inset:90px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--line);padding:10px 16px 18px;
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:all .22s var(--ease);
    box-shadow:0 12px 24px rgba(0,0,0,.06)
  }
  .nav.open{transform:none;opacity:1;visibility:visible}
  .nav a{padding:13px 8px;font-size:14px}
  .nav-toggle{display:block}
  .cta-band .wrap{flex-direction:column;align-items:flex-start;gap:16px}
}
