/* Van der Ven Onderhoudsbedrijf — hoofdstylesheet */
:root{
  --red:#c1121f;
  --red-dark:#9b0e18;
  --black:#191919;
  --grey-900:#232323;
  --grey-700:#454545;
  --grey-500:#6d6d6d;
  --grey-200:#e4e4e4;
  --grey-100:#f5f5f4;
  --white:#ffffff;
  --radius:10px;
  --shadow:0 2px 14px rgba(0,0,0,.08);
  --container:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  font-size:17px;line-height:1.65;
  color:var(--grey-900);background:var(--white);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--red)}
a:hover{color:var(--red-dark)}
h1,h2,h3{line-height:1.25;color:var(--black);font-weight:800;margin:0 0 .5em}
h1{font-size:clamp(1.85rem,4.5vw,2.8rem)}
h2{font-size:clamp(1.45rem,3vw,2rem)}
h3{font-size:1.15rem}
p{margin:0 0 1em}
ul{padding-left:1.2em}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.lead{font-size:1.12rem;color:var(--grey-700)}
.kicker{text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:.82rem;color:var(--red);margin-bottom:.6em}
section{padding:56px 0}
.section-grey{background:var(--grey-100)}
.section-head{max-width:720px;margin-bottom:2rem}

/* Knoppen */
.btn{display:inline-block;padding:14px 26px;border-radius:8px;font-weight:700;text-decoration:none;text-align:center;border:2px solid transparent;transition:background .15s,color .15s,border-color .15s}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dark);color:#fff}
.btn-outline{border-color:var(--grey-900);color:var(--grey-900)}
.btn-outline:hover{border-color:var(--red);color:var(--red)}
.btn-light{background:#fff;color:var(--red)}
.btn-light:hover{background:var(--grey-100);color:var(--red-dark)}
.btn-whatsapp{background:#25d366;color:#fff;display:inline-flex;align-items:center;gap:9px}
.btn-whatsapp:hover{background:#1eb857;color:#fff}
.btn svg{width:20px;height:20px;fill:currentColor;flex:none}

/* Header */
.site-header{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--grey-200)}
.header-inner{display:flex;align-items:center;gap:28px;min-height:76px}
.logo img{height:48px;width:auto}
.main-nav{margin-left:auto}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:26px;align-items:center}
.main-nav a{color:var(--grey-900);text-decoration:none;font-weight:600;font-size:.98rem}
.main-nav a:hover{color:var(--red)}
.has-sub{position:relative}
.has-sub>a::after{content:" \25BE";font-size:.7em;color:var(--grey-500)}
.sub{position:absolute;top:100%;left:-14px;background:#fff;border:1px solid var(--grey-200);border-radius:var(--radius);box-shadow:var(--shadow);min-width:290px;padding:8px !important;display:none;flex-direction:column;gap:0 !important}
.sub li{width:100%}
.sub a{display:block;padding:10px 14px;border-radius:6px}
.sub a:hover{background:var(--grey-100)}
.has-sub:hover .sub,.has-sub:focus-within .sub{display:flex}
.header-cta{display:flex;align-items:center;gap:12px}
.header-cta .btn{padding:11px 18px;font-size:.92rem}
.wa-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:#25d366}
.wa-icon svg{width:24px;height:24px;fill:#fff}
.wa-icon:hover{background:#1eb857}
.nav-toggle{display:none;margin-left:auto;background:none;border:2px solid var(--grey-900);border-radius:8px;padding:8px 12px;font-size:1.1rem;font-weight:700;cursor:pointer;color:var(--grey-900)}

/* Hero */
.hero{background:linear-gradient(180deg,var(--grey-100) 0%,#fff 100%);padding:64px 0}
.hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:1.4em 0}
.badges{list-style:none;display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:1.2em 0 0}
.badges li{background:var(--black);color:#fff;font-size:.8rem;font-weight:700;padding:6px 13px;border-radius:99px;letter-spacing:.02em}

/* Fotoplaceholders */
.photo-placeholder{margin:0}
.ph-box{border:2px dashed var(--grey-500);border-radius:var(--radius);background:repeating-linear-gradient(45deg,var(--grey-100),var(--grey-100) 12px,#ececeb 12px,#ececeb 24px);color:var(--grey-700);display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;min-height:260px;font-size:.95rem;font-weight:600}
.ph-box::before{content:"\1F4F7";display:block;margin-right:10px;font-size:1.4rem}
.ph-wide .ph-box{min-height:200px}

/* Kaarten / grids */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--grey-200);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card h3 a{color:var(--black);text-decoration:none}
.card h3 a:hover{color:var(--red)}
.card p{color:var(--grey-700);font-size:.97rem}
.card .card-link{margin-top:auto;font-weight:700;text-decoration:none}
.card .card-link::after{content:" \2192"}
.card .ph-box{min-height:150px;margin-bottom:18px;font-size:.85rem}
.usp{display:flex;gap:14px;align-items:flex-start}
.usp-dot{flex:none;width:14px;height:14px;border-radius:50%;background:var(--red);margin-top:7px}

/* Kruimelpad */
.breadcrumbs{background:var(--grey-100);border-bottom:1px solid var(--grey-200);font-size:.88rem;padding:10px 0}
.breadcrumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}
.breadcrumbs li+li::before{content:"\203A";margin-right:6px;color:var(--grey-500)}
.breadcrumbs a{color:var(--grey-700);text-decoration:none}
.breadcrumbs a:hover{color:var(--red)}
.breadcrumbs [aria-current]{color:var(--black);font-weight:600}

/* CTA-band */
.cta-band{background:var(--red);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:#ffd9dc;max-width:640px;margin:0 auto 1.4em}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* Reviews */
.review-card{background:#fff;border:1px solid var(--grey-200);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.review-card .stars{color:var(--red);letter-spacing:2px;font-size:1.05rem;margin-bottom:8px}
.review-card blockquote{margin:0 0 12px;font-style:italic;color:var(--grey-700)}
.review-card cite{font-style:normal;font-weight:700;color:var(--black);font-size:.92rem}

/* Inhoudspagina's */
.page-body{max-width:760px}
.page-body ul li{margin-bottom:.45em}
.check-list{list-style:none;padding:0}
.check-list li{padding-left:30px;position:relative;margin-bottom:.55em}
.check-list li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--red);font-weight:800}
.info-box{background:var(--grey-100);border-left:4px solid var(--red);border-radius:0 var(--radius) var(--radius) 0;padding:20px 24px;margin:1.6em 0}

/* Formulier */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid .full{grid-column:1/-1}
label{display:block;font-weight:700;font-size:.92rem;margin-bottom:6px}
input,select,textarea{width:100%;padding:13px 14px;border:1.5px solid var(--grey-500);border-radius:8px;font:inherit;background:#fff;color:var(--grey-900)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--red);border-color:var(--red)}
.hp-field{position:absolute;left:-9999px;top:-9999px}
.form-note{font-size:.86rem;color:var(--grey-500)}
.alert{padding:16px 20px;border-radius:var(--radius);margin-bottom:1.4em;font-weight:600;display:none}
.alert-ok{background:#e7f6ec;border:1.5px solid #2e9e5b;color:#1c6339}
.alert-error{background:#fdeaea;border:1.5px solid var(--red);color:var(--red-dark)}

/* Footer */
.site-footer{background:var(--black);color:#cfcfcf;margin-top:56px}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;padding:52px 0 36px}
.site-footer h3{color:#fff;font-size:1rem;margin-bottom:.9em}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:.55em}
.site-footer a{color:#cfcfcf;text-decoration:none}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-logo{background:#fff;border-radius:8px;padding:10px 14px;display:inline-block;margin-bottom:16px}
.footer-logo img{height:40px;width:auto}
.nap{font-style:normal;line-height:1.7}
.footer-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.footer-badges span{border:1px solid #4c4c4c;color:#e6e6e6;font-size:.74rem;font-weight:700;padding:4px 10px;border-radius:99px}
.footer-cokeur{margin:14px 0 0}
.footer-cokeur img{height:80px;width:auto;border-radius:8px}
.cokeur-hero{margin-top:18px}
.cokeur-hero img{height:72px;width:auto;border:1px solid var(--grey-200);border-radius:8px}
.kvk{font-size:.82rem;color:#8f8f8f;margin-top:14px}
.footer-bottom{border-top:1px solid #363636;padding:18px 0;font-size:.85rem;color:#8f8f8f}
.footer-bottom a{color:#8f8f8f}

/* Sticky mobiele CTA-balk */
.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--black);box-shadow:0 -2px 12px rgba(0,0,0,.25)}
.mobile-cta-bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:15px 6px;color:#fff;text-decoration:none;font-weight:700;font-size:.9rem}
.mobile-cta-bar svg{width:19px;height:19px;fill:currentColor;flex:none}
.mobile-cta-bar .m-bel{background:var(--grey-900)}
.mobile-cta-bar .m-wa{background:#25d366}
.mobile-cta-bar .m-offerte{background:var(--red)}

/* Responsief */
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  body{padding-bottom:52px}
  .nav-toggle{display:block}
  .header-cta{display:none}
  .main-nav{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--grey-200);box-shadow:var(--shadow);display:none;margin:0}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:10px 0}
  .main-nav li{border-bottom:1px solid var(--grey-100)}
  .main-nav a{display:block;padding:13px 22px}
  .sub{position:static;display:flex;flex-direction:column;border:none;box-shadow:none;min-width:0;padding:0 0 6px !important;background:var(--grey-100)}
  .sub a{padding:10px 22px 10px 38px;font-weight:500;font-size:.93rem}
  .mobile-cta-bar{display:flex}
  section{padding:42px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .hero{padding:44px 0}
}
