/* ============================================================
   MTO BOUW — Themastijl
   Merkkleuren conform brandboek / logo-map:
   MTO Blauw #008BEA · Diep Blauw #0076CF · Navy #00558F
   Typografie: Montserrat (koppen) + Inter (tekst)
   ============================================================ */

:root{
  --mto-blue:#008BEA;
  --mto-blue-dark:#0076CF;
  --mto-navy:#00558F;
  --mto-ink:#111418;
  --mto-grey:#6B7280;
  --mto-grey-light:#EEF1F5;
  --mto-grey-mid:#D9DEE5;
  --mto-gradient:linear-gradient(160deg,#008BEA 0%,#0076CF 55%,#00558F 100%);
  --mto-radius:16px;
  --mto-shadow:0 18px 40px rgba(0,80,140,.10);

  /* Bootstrap overrides */
  --bs-primary:#008BEA;
  --bs-primary-rgb:0,139,234;
  --bs-link-color:#0076CF;
  --bs-link-hover-color:#00558F;
  --bs-body-color:#1b2228;
  --bs-body-font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --bs-border-radius:16px;
}

body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#1b2228;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,.font-head{font-family:'Montserrat',sans-serif;font-weight:800;letter-spacing:-.02em;color:var(--mto-ink)}
.fw-900{font-weight:900!important}
.eyebrow{font-family:'Montserrat';font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mto-blue)}
.text-blue{color:var(--mto-blue)!important}
a{text-decoration:none}
section{scroll-margin-top:80px}

/* Buttons */
.btn{font-family:'Montserrat';font-weight:600;letter-spacing:.01em;border-radius:12px;padding:.7rem 1.4rem}
.btn-mto{background:var(--mto-blue);border:none;color:#fff}
.btn-mto:hover{background:var(--mto-blue-dark);color:#fff}
.btn-outline-mto{border:2px solid #fff;color:#fff;background:transparent}
.btn-outline-mto:hover{background:#fff;color:var(--mto-navy)}
.btn-ghost{border:2px solid var(--mto-grey-mid);color:var(--mto-ink);background:#fff}
.btn-ghost:hover{border-color:var(--mto-blue);color:var(--mto-blue)}
.btn-wa{background:#25D366;border:none;color:#fff}
.btn-wa:hover{background:#1da851;color:#fff}

/* Gradient helpers */
.bg-mto-gradient{background:var(--mto-gradient)}
.bg-mto-ink{background:var(--mto-ink)}
.text-on-dark, .text-on-dark h1, .text-on-dark h2, .text-on-dark h3{color:#fff}

/* NAV */
.navbar{background:rgba(255,255,255,.94);backdrop-filter:blur(10px);box-shadow:0 1px 0 rgba(0,0,0,.06);padding:.6rem 0}
.navbar-brand{display:flex;align-items:center;margin-right:auto;padding-top:0;padding-bottom:0}
.navbar-brand img,.navbar-brand .custom-logo{height:34px;width:auto;max-height:34px;display:block}
.navbar-toggler{margin-left:auto;padding:.35rem .5rem}  /* hamburger altijd hard rechts */
.navbar-toggler:focus{box-shadow:none}
.navbar .nav-link{font-family:'Montserrat';font-weight:600;font-size:.95rem;color:#2a3138!important;margin:0 .35rem}
.navbar .nav-link:hover,.navbar .nav-link.active{color:var(--mto-blue)!important}
.navbar .btn{padding:.5rem 1.1rem}
@media(max-width:991.98px){
  .navbar-collapse{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--mto-grey-light)}
  .navbar .nav-link{margin:0;padding:.55rem .25rem}
  .navbar-collapse .btn{margin-top:.5rem;width:100%}
}

/* HERO */
.hero{position:relative;background:var(--mto-gradient);color:#fff;overflow:hidden;padding:120px 0 110px}
.hero:before{content:"";position:absolute;inset:0;background:
   radial-gradient(900px 500px at 80% -10%, rgba(255,255,255,.20), transparent 60%);
   pointer-events:none}
.hero:after{content:"";position:absolute;right:-8%;bottom:-30%;width:60%;height:140%;
   background:url('../img/icon-white.png') no-repeat center/contain;opacity:.06;pointer-events:none}
.hero .container{position:relative;z-index:3}

/* Hero met achtergrondvideo */
.hero--video:after{display:none}            /* watermerk uit als er video is */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;
   background:linear-gradient(90deg, rgba(3,24,46,.62) 0%, rgba(3,30,56,.40) 55%, rgba(4,38,70,.24) 100%),
              linear-gradient(160deg, rgba(0,55,100,.16), rgba(0,35,70,.16))}
@media(max-width:575px){
  .hero-overlay{background:linear-gradient(180deg, rgba(3,24,46,.50), rgba(3,38,70,.52))}
}
@media (prefers-reduced-motion: reduce){
  .hero-video{display:none}                 /* respecteer 'minder beweging' */
}
.hero h1{color:#fff;font-weight:900;font-size:clamp(2.3rem,5vw,4rem);line-height:1.05}
.hero .lead{color:rgba(255,255,255,.92);font-size:1.18rem;max-width:36ch}
.hero .badge-soft{background:rgba(255,255,255,.16);color:#fff;font-family:'Montserrat';font-weight:600;
   padding:.45rem .9rem;border-radius:30px;font-size:.82rem}

/* USP strip */
.usp{display:flex;gap:.8rem;align-items:flex-start}
.usp .ico{flex:0 0 46px;height:46px;border-radius:12px;background:rgba(0,139,234,.10);
   display:flex;align-items:center;justify-content:center;color:var(--mto-blue)}
.usp h3{font-size:1.05rem;margin:0 0 .2rem}
.usp p{color:var(--mto-grey);margin:0;font-size:.95rem}

/* Portret (over-sectie) */
.portret-frame{position:relative;border-radius:var(--mto-radius);overflow:hidden;background:var(--mto-gradient);
   aspect-ratio:1/1;box-shadow:var(--mto-shadow)}
.portret-frame:before{content:"";position:absolute;right:-12%;bottom:-22%;width:60%;height:120%;
   background:url('../img/icon-white.png') no-repeat center/contain;opacity:.10}
.portret-img{position:absolute;bottom:0;left:50%;transform:translateX(-50%);height:100%;width:auto;max-width:none;
   object-fit:contain;object-position:bottom}

/* 5 uitgangspunten */
.punt{background:#fff;border:1px solid var(--mto-grey-light);border-radius:var(--mto-radius);padding:24px 22px;transition:.2s}
.punt:hover{border-color:transparent;box-shadow:var(--mto-shadow);transform:translateY(-4px)}
.punt-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;
   background:rgba(0,139,234,.10);color:var(--mto-blue);font-family:'Montserrat';font-weight:900;font-size:1.2rem;margin-bottom:14px}
.punt h3{font-size:1.1rem;margin:0 0 .35rem}
.punt p{color:var(--mto-grey);font-size:.93rem;margin:0}

/* Afsluiter */
.afsluiter{background:var(--mto-ink);color:#fff;border-radius:var(--mto-radius);padding:26px 30px;
   display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}
.afsluiter p{color:#cdd6df;font-size:1.02rem}
.afsluiter-sign{font-family:'Montserrat';font-weight:800;font-size:1.15rem;color:#fff}
.afsluiter-sign:before{content:"";display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--mto-blue);margin-right:10px;vertical-align:middle}

/* Section heading */
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
.sec-head p{color:var(--mto-grey);max-width:60ch}

/* Project cards */
.project-card{display:block;border-radius:var(--mto-radius);overflow:hidden;background:#fff;
   border:1px solid var(--mto-grey-light);transition:.2s;height:100%}
.project-card:hover{transform:translateY(-5px);box-shadow:var(--mto-shadow);border-color:transparent}
.project-card .thumb{aspect-ratio:4/3;background:var(--mto-grey-light) center/cover no-repeat;position:relative}
.project-card .thumb .tag{position:absolute;left:12px;top:12px;background:rgba(17,20,24,.78);color:#fff;
   font-family:'Montserrat';font-weight:600;font-size:.72rem;padding:.3rem .7rem;border-radius:20px}
.project-card .body{padding:18px 20px}
.project-card .body h3{font-size:1.18rem;margin:0 0 .25rem;color:var(--mto-ink)}
.project-card .body .meta{color:var(--mto-grey);font-size:.88rem}
.project-card .body p{color:#4a5159;font-size:.93rem;margin:.5rem 0 0}
.thumb-empty{display:flex;align-items:center;justify-content:center;background:var(--mto-grey-light)}
.thumb-empty img{width:46%;opacity:.5}

/* Single project */
.project-hero{background:var(--mto-gradient);color:#fff;padding:90px 0 70px}
.project-hero h1{color:#fff}
.project-meta{list-style:none;padding:0;margin:0}
.project-meta li{padding:14px 0;border-bottom:1px solid var(--mto-grey-light);display:flex;justify-content:space-between;gap:1rem}
.project-meta li span:first-child{color:var(--mto-grey);font-family:'Montserrat';font-weight:600;font-size:.85rem}
.project-meta li span:last-child{font-weight:500;text-align:right}
.gallery-grid img{width:100%;height:100%;object-fit:cover;border-radius:12px;aspect-ratio:4/3;cursor:zoom-in;transition:.2s}
.gallery-grid a{position:relative;display:block;border-radius:12px;overflow:hidden}
.gallery-grid a:after{content:"";position:absolute;inset:0;background:rgba(0,85,143,0);transition:.2s}
.gallery-grid a:hover:after{background:rgba(0,85,143,.18)}
.gallery-grid a:hover img{transform:scale(1.04)}

/* Lightbox */
.mto-lb{position:fixed;inset:0;z-index:1080;background:rgba(8,11,15,.92);backdrop-filter:blur(4px);
   display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.mto-lb.open{display:flex;opacity:1}
.mto-lb-stage{margin:0;max-width:92vw;max-height:86vh;display:flex;flex-direction:column;align-items:center;gap:14px}
.mto-lb-stage img{max-width:92vw;max-height:80vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5);object-fit:contain}
.mto-lb figcaption{color:#dfe6ee;font-family:'Inter';font-size:.95rem;text-align:center;max-width:60ch}
.mto-lb-close{position:absolute;top:18px;right:22px;background:none;border:none;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer;opacity:.85}
.mto-lb-close:hover{opacity:1}
.mto-lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;
   width:52px;height:52px;border-radius:50%;font-size:2rem;line-height:1;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center}
.mto-lb-nav:hover{background:var(--mto-blue)}
.mto-lb-prev{left:18px}.mto-lb-next{right:18px}
.mto-lb-count{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#cfd8e1;font-family:'Montserrat';font-weight:600;font-size:.85rem;letter-spacing:.05em}
@media(max-width:575px){.mto-lb-nav{width:42px;height:42px;font-size:1.6rem}.mto-lb-prev{left:8px}.mto-lb-next{right:8px}}

/* Contact */
.contact-section{background:var(--mto-ink);color:#fff;position:relative;overflow:hidden}
.contact-section:after{content:"";position:absolute;left:-6%;bottom:-40%;width:46%;height:160%;
   background:url('../img/icon-white.png') no-repeat center/contain;opacity:.05}
.contact-card{background:#fff;border-radius:var(--mto-radius);padding:30px;color:#1b2228;box-shadow:var(--mto-shadow)}
.contact-card .form-control{border-radius:10px;padding:.8rem 1rem;border:1px solid var(--mto-grey-mid)}
.contact-card .form-control:focus{border-color:var(--mto-blue);box-shadow:0 0 0 .2rem rgba(0,139,234,.15)}
.contact-actions .btn{display:flex;align-items:center;gap:.6rem;justify-content:center}
.contact-info a{color:#cfe6fb}
.contact-info a:hover{color:#fff}
.notice{border-radius:10px;padding:.9rem 1.1rem;font-size:.95rem}
.notice-ok{background:rgba(37,211,102,.12);color:#0f7a3c;border:1px solid rgba(37,211,102,.4)}
.notice-err{background:rgba(226,59,59,.10);color:#b62121;border:1px solid rgba(226,59,59,.35)}

/* Juridische pagina's (privacy / voorwaarden) */
.legal-toc{position:sticky;top:90px;background:var(--mto-grey-light);border-radius:var(--mto-radius);padding:22px}
.legal-toc h2{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--mto-blue);margin-bottom:12px}
.legal-toc ol{list-style:none;counter-reset:toc;padding:0;margin:0}
.legal-toc li{counter-increment:toc;margin-bottom:2px}
.legal-toc a{display:block;padding:7px 10px;border-radius:8px;font-size:.9rem;color:#3a424b;line-height:1.3}
.legal-toc a:before{content:counter(toc) ". ";color:var(--mto-blue);font-family:'Montserrat';font-weight:700}
.legal-toc a:hover{background:#fff;color:var(--mto-blue)}
.legal-content{max-width:760px}
.legal-content .artikel{padding:26px 0;border-bottom:1px solid var(--mto-grey-light);scroll-margin-top:90px}
.legal-content .artikel:first-child{padding-top:0}
.legal-content .artikel:last-child{border-bottom:none}
.legal-content h2{display:flex;gap:14px;align-items:baseline;font-size:1.45rem;margin-bottom:14px}
.legal-content h2 .nr{flex:0 0 auto;font-family:'Montserrat';font-weight:900;color:var(--mto-blue);font-size:1.1rem;
   background:rgba(0,139,234,.10);border-radius:9px;padding:.15em .5em;line-height:1.2}
.legal-content p{color:#3a424b}
.legal-content ul{padding-left:0;list-style:none}
.legal-content ul li{position:relative;padding-left:26px;margin-bottom:.5rem;color:#3a424b}
.legal-content ul li:before{content:"";position:absolute;left:4px;top:.55em;width:8px;height:8px;border-radius:2px;background:var(--mto-blue)}
.legal-content ol.sub{padding-left:1.1rem;color:#3a424b}
.legal-content ol.sub li{margin-bottom:.55rem}
.legal-intro{font-size:1.1rem;color:#2a323b;border-left:4px solid var(--mto-blue);padding:6px 0 6px 18px;margin-bottom:8px}
.legal-updated{color:var(--mto-grey);font-size:.85rem}

/* Footer */
.site-footer{background:#0c0f13;color:#aeb7c0;padding:64px 0 28px}
.site-footer img{height:40px;margin-bottom:18px}
.site-footer h5{color:var(--mto-blue);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.site-footer a{color:#aeb7c0}
.site-footer a:hover{color:#fff}
.site-footer .copy{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:20px;font-size:.82rem;color:#7b8590}

/* Generic page content */
.entry-content h2{margin-top:1.8rem}
.entry-content img{max-width:100%;height:auto;border-radius:12px}
.float-cta{position:fixed;right:18px;bottom:18px;z-index:60;display:flex;gap:10px}
@media(max-width:575px){.hero{padding:90px 0 80px}}
