/* Snoek Hoveniers Template CSS v1.0.0 */

/* ══════════════════════════════════════════
   RESET
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

/* ══════════════════════════════════════════
   TOKENS
══════════════════════════════════════════ */
:root{
  --green:       #9eaf50;
  --green-dark:  #7a8c35;
  --green-light: #e7ebd1;
  --grey-nav:    #63686e;
  --grey-mid:    #a9aaae;
  --grey-dark:   #63686e;
  --red:         #bf3a2d;
  --ink:         #1a1a1a;
  --body:        #3d3d3d;
  --muted:       #666;
  --sand:        #f5f3ee;
  --white:       #fff;
  --max:         1320px;
  --r:           6px;
}

/* ══════════════════════════════════════════
   BASE
══════════════════════════════════════════ */
body{
  font-family:'Nunito Sans','Proxima Nova',Arial,sans-serif;
  font-size:16px;
  line-height:1.75;
  color:var(--body);
  background:var(--white);
  overflow-x:hidden;
}
h1,h2,h3{font-family:'Nunito Sans',Arial,sans-serif;font-weight:800;line-height:1.15;color:var(--ink)}
h1{font-size:clamp(2.8rem,5vw,5rem)}
h2{font-size:clamp(1.9rem,3vw,2.8rem)}
h3{font-size:1.25rem;font-weight:700}
p{font-size:16px;line-height:1.75;color:var(--body)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 48px}
section{padding:100px 0}

/* ══════════════════════════════════════════
   EYEBROW
══════════════════════════════════════════ */
.eyebrow{
  font-size:0.72rem;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--green);
  display:flex;align-items:center;gap:10px;margin-bottom:0.9rem;
}
.eyebrow::before{content:'';width:28px;height:2px;background:var(--green);flex-shrink:0}

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:inherit;font-size:16px;font-weight:700;
  text-decoration:none;padding:13px 28px;
  border-radius:var(--r);border:none;cursor:pointer;
  transition:all .22s ease;white-space:nowrap;
}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(158,175,80,.35)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45)}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn-outline-dark{background:transparent;color:var(--green-dark);border:2px solid var(--green)}
.btn-outline-dark:hover{background:var(--green);color:#fff}
.btn-white{background:#fff;color:var(--green-dark)}
.btn-white:hover{background:var(--green-light);transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.78);font-size:16px;font-weight:400;text-decoration:none;transition:color .2s}
.btn-ghost:hover{color:#fff}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  background:var(--grey-nav);
  transition:box-shadow .35s;
}
#nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.25)}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:0 48px;
  height:72px;display:flex;align-items:center;
  justify-content:space-between;gap:2rem;
}
.nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.nav-logo-leaf{
  width:40px;height:40px;background:var(--green);
  border-radius:50%;display:flex;align-items:center;
  justify-content:center;flex-shrink:0;transition:background .2s;
}
.nav-logo:hover .nav-logo-leaf{background:var(--green-dark)}
.nav-logo-leaf i{font-size:17px;color:#fff}
.nav-logo-name{font-size:1rem;font-weight:800;color:#fff;display:block;letter-spacing:-.01em}
.nav-logo-sub{font-size:.62rem;color:rgba(255,255,255,.48);letter-spacing:.1em;text-transform:uppercase;display:block}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{
  font-size:.87rem;font-weight:600;color:rgba(255,255,255,.82);
  text-decoration:none;padding:8px 14px;border-radius:4px;transition:all .2s;
}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-links .nav-cta{
  background:var(--green);color:#fff!important;
  border-radius:4px;margin-left:6px;
}
.nav-links .nav-cta:hover{background:var(--green-dark)!important}

/* ══════════════════════════════════════════
   HERO  (V1 layout: full-height, content bottom-left,
          stats column right, scroll indicator)
══════════════════════════════════════════ */
.hero{
  height:100vh;min-height:640px;
  position:relative;display:flex;align-items:flex-end;overflow:hidden;
}
/* Slider */
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block}
/* Overlay: left-heavy like V1 */
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to right, rgba(0,0,0,.72) 0%, rgba(0,0,0,.42) 55%, rgba(0,0,0,.12) 100%),
    linear-gradient(to top,   rgba(0,0,0,.55) 0%, transparent 45%);
}
/* Content */
.hero-content{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;padding:0 48px 88px;width:100%;
}
.hero-eyebrow{
  font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--green);display:flex;align-items:center;gap:12px;margin-bottom:1.4rem;
}
.hero-eyebrow-line{width:36px;height:2px;background:var(--green);flex-shrink:0}
.hero h1{
  color:#fff;font-weight:800;
  line-height:1.08;max-width:680px;
  margin-bottom:1.4rem;letter-spacing:-.02em;
}
.hero h1 span{color:var(--green)}
.hero-lead{
  font-size:18px;color:rgba(255,255,255,.75);
  max-width:500px;margin-bottom:2.5rem;
  font-weight:300;line-height:1.75;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* Stats column removed */

/* Scroll indicator */
.hero-scroll{
  position:absolute;right:48px;bottom:40px;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:rgba(255,255,255,.4);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
}
.hero-scroll-line{
  width:1px;height:56px;
  background:linear-gradient(to bottom,rgba(255,255,255,0),rgba(255,255,255,.35));
  animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.3;transform:scaleY(.6)}
  50%{opacity:1;transform:scaleY(1)}
}

/* Slide dots */
.hero-dots{
  position:absolute;bottom:40px;left:48px;z-index:2;
  display:flex;gap:10px;align-items:center;
}
.hero-dot{
  width:8px;height:8px;border-radius:50%;
  border:2px solid rgba(255,255,255,.4);background:transparent;
  cursor:pointer;transition:all .25s;padding:0;
}
.hero-dot.active{
  background:var(--green);border-color:var(--green);
  width:24px;border-radius:4px;
}

/* ══════════════════════════════════════════
   DIENSTEN  (V1 layout: left intro col + right 2×2 cards)
══════════════════════════════════════════ */
.diensten{background:var(--white);padding:100px 0}
.diensten-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:start;margin-top:3.5rem;
}
.diensten-left h2{margin-bottom:1.1rem}
.diensten-left p{font-size:16px;color:var(--muted);margin-bottom:1.8rem;max-width:420px}
.diensten-right{display:grid;grid-template-columns:1fr 1fr;gap:16px}
/* Cards */
.d-card{
  background:var(--sand);padding:2.2rem 2rem;
  position:relative;overflow:hidden;transition:background .3s;cursor:default;
}
.d-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .32s;
}
.d-card:hover{background:var(--grey-nav)}
.d-card:hover::after{transform:scaleX(1)}
.d-card:hover .d-title{color:#fff}
.d-card:hover .d-text{color:rgba(255,255,255,.58)}
.d-card:hover .d-link{color:var(--green)}
.d-card:hover .d-icon-wrap{background:rgba(158,175,80,.18);color:var(--green)}
/* Featured card spans full width */
.d-card.featured{
  background:var(--green);grid-column:1 / -1;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.6rem;
  margin-top:0;
}
.d-card.featured::after{background:rgba(255,255,255,.3)}
.d-card.featured:hover{background:var(--green-dark)}
.d-card.featured .d-icon-wrap{background:rgba(255,255,255,.2);color:#fff;width:52px;height:52px}
.d-card.featured .d-title{color:#fff;font-size:1.25rem;margin-bottom:.3rem}
.d-card.featured .d-text{color:rgba(255,255,255,.78);margin-bottom:0}
.d-card.featured .d-link{color:rgba(255,255,255,.85);white-space:nowrap}
.d-featured-badge{
  position:absolute;top:1.2rem;right:1.2rem;
  background:rgba(255,255,255,.22);color:#fff;
  font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:3px;
}
.d-icon-wrap{
  width:48px;height:48px;border-radius:10px;
  background:var(--green-light);color:var(--green-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:19px;margin-bottom:1.4rem;transition:all .3s;flex-shrink:0;
}
.d-title{
  font-size:1.1rem;font-weight:800;color:var(--ink);
  margin-bottom:.65rem;transition:color .3s;line-height:1.25;
}
.d-text{
  font-size:15px;line-height:1.75;color:var(--muted);
  margin-bottom:1.2rem;transition:color .3s;
}
.d-link{
  font-size:.83rem;font-weight:700;color:var(--green-dark);
  text-decoration:none;display:inline-flex;align-items:center;
  gap:7px;transition:color .2s, gap .2s;
}
.d-link:hover{gap:11px}

/* ══════════════════════════════════════════
   OVER ONS  (V1 dark-green strip + 2-col grid)
══════════════════════════════════════════ */
.over-strip{background:var(--grey-nav);padding:100px 0}
.over-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:6rem;align-items:center;
}
/* Single photo frame — V1 style */
.over-imgs{position:relative}
.over-img-frame{
  width:100%;aspect-ratio:3/4;
  border-radius:var(--r);overflow:hidden;
  position:relative;
}
.over-img-frame img{width:100%;height:100%;object-fit:cover;display:block}
.over-img-badge{
  position:absolute;bottom:1.8rem;left:1.8rem;
  background:rgba(10,20,8,.75);color:#fff;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;padding:8px 14px;
  border-left:3px solid var(--green);
}
/* Round badge top-right */
.over-badge{
  position:absolute;top:-20px;right:-20px;
  background:#fff;border-radius:50%;
  width:110px;height:110px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  z-index:2;
}
.over-badge i{font-size:1.6rem;color:var(--green);display:block;margin-bottom:4px}
.over-badge-label{
  font-size:.62rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--grey-dark);text-align:center;line-height:1.3;
}
/* Text */
.over-text .eyebrow{color:rgba(255,255,255,.55)}
.over-text .eyebrow::before{background:rgba(255,255,255,.4)}
.over-text h2{color:#fff;margin-bottom:1.2rem}
.over-text p{font-size:16px;color:rgba(255,255,255,.68);margin-bottom:.9rem}
.over-checks{
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px;margin:1.8rem 0;
}
.check-item{
  display:flex;align-items:center;gap:9px;
  font-size:15px;font-weight:600;color:rgba(255,255,255,.82);
}
.check-item i{color:var(--green);font-size:14px;flex-shrink:0}

/* ══════════════════════════════════════════
   PROJECTEN  (V1 sand bg + filter + 3-col grid + lightbox)
══════════════════════════════════════════ */
.projecten{background:var(--sand);padding:100px 0}
.proj-head{
  display:flex;justify-content:space-between;
  align-items:flex-end;margin-bottom:2.5rem;
}
/* Filter */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:2rem}
.f-btn{
  padding:8px 18px;border-radius:20px;
  font-size:.82rem;font-weight:700;font-family:inherit;
  border:1.5px solid var(--green);background:transparent;
  color:var(--green-dark);cursor:pointer;transition:all .2s;
}
.f-btn:hover,.f-btn.active{background:var(--green);border-color:var(--green);color:#fff}
/* Grid — V1 3-col with meta bar below image */
.proj-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.proj-card{
  border-radius:var(--r);overflow:hidden;
  cursor:pointer;position:relative;background:#fff;
}
.proj-img-wrap{
  position:relative;overflow:hidden;
  aspect-ratio:4/3;
}
.proj-img-wrap img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .55s ease;
}
.proj-card:hover .proj-img-wrap img{transform:scale(1.06)}
.proj-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,20,10,.88) 0%,transparent 55%);
  opacity:0;transition:opacity .32s;
}
.proj-card:hover .proj-overlay{opacity:1}
.proj-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:1.3rem;transform:translateY(7px);
  opacity:0;transition:all .32s;color:#fff;
}
.proj-card:hover .proj-info{transform:translateY(0);opacity:1}
.proj-cat{
  font-size:.67rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:var(--green);margin-bottom:3px;
}
.proj-name{font-size:1rem;font-weight:700;line-height:1.3}
/* Meta bar below image — V1 signature */
.proj-meta{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;background:#fff;
}
.proj-meta-title{font-size:.87rem;font-weight:600;color:var(--ink)}
.proj-meta-type{
  font-size:.72rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--green);
}
.proj-more{display:flex;justify-content:center;margin-top:3rem}

/* ══════════════════════════════════════════
   LIGHTBOX
══════════════════════════════════════════ */
.lightbox{
  position:fixed;inset:0;z-index:900;
  background:rgba(5,8,4,.94);backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.lightbox.open{opacity:1;pointer-events:all}
.lb-wrap{width:min(960px,90vw);position:relative}
.lb-img{
  border-radius:var(--r);overflow:hidden;aspect-ratio:16/10;background:#222;
}
.lb-img img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .25s}
.lb-footer{
  display:flex;justify-content:space-between;align-items:center;
  padding:1.1rem 0 0;color:#fff;
}
.lb-cat{
  font-size:.69rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:var(--green);margin-bottom:4px;
}
.lb-title{font-size:1.25rem;font-weight:800}
.lb-controls{display:flex;align-items:center;gap:10px}
.lb-count{font-size:.8rem;color:rgba(255,255,255,.32);margin-right:4px}
.lb-btn{
  width:42px;height:42px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);color:#fff;
  font-size:.95rem;display:flex;align-items:center;
  justify-content:center;cursor:pointer;transition:all .2s;
}
.lb-btn:hover{background:var(--green);border-color:var(--green)}
.lb-close{
  position:absolute;top:-3.4rem;right:0;
  background:none;border:none;color:rgba(255,255,255,.5);
  font-size:1.8rem;cursor:pointer;line-height:1;
  transition:color .2s;padding:0;
}
.lb-close:hover{color:#fff}

/* ══════════════════════════════════════════
   WERKWIJZE  (V1: white bg, 5 steps, connecting line)
══════════════════════════════════════════ */
.werkwijze{background:var(--white);padding:100px 0}
.ww-head{text-align:center;max-width:580px;margin:0 auto 4.5rem}
.ww-head h2{margin-bottom:.9rem}
.ww-head p{font-size:16px;color:var(--muted)}
.steps{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:0;position:relative;
}
.steps::before{
  content:'';position:absolute;top:40px;left:10%;right:10%;
  height:1px;background:var(--green);opacity:.35;z-index:0;
}
.step{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:0 1rem;position:relative;z-index:1;
}
.step-num{
  width:80px;height:80px;border-radius:50%;
  border:2px solid var(--green);background:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.55rem;font-weight:800;color:var(--green-dark);
  margin-bottom:1.4rem;transition:all .3s;
}
.step:hover .step-num{background:var(--green);color:#fff;border-color:var(--green)}
.step-title{font-size:.97rem;font-weight:800;color:var(--ink);margin-bottom:.5rem}
.step-text{font-size:14px;color:var(--muted);line-height:1.7}

/* ══════════════════════════════════════════
   CTA BANNER  (V1: green bg, centred)
══════════════════════════════════════════ */
.cta-section{
  background:var(--green);padding:100px 0;
  text-align:center;position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 2px 2px,rgba(255,255,255,.05) 1px,transparent 0);
  background-size:40px 40px;
}
.cta-inner{position:relative;z-index:1}
.cta-section .eyebrow{justify-content:center;color:rgba(255,255,255,.7)}
.cta-section .eyebrow::before{background:rgba(255,255,255,.45)}
.cta-section h2{color:#fff;margin-bottom:1rem}
.cta-section p{font-size:17px;color:rgba(255,255,255,.78);max-width:460px;margin:0 auto 2.5rem;font-weight:300}
.cta-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* ══════════════════════════════════════════
   FOOTER  (V1: dark, 4-col)
══════════════════════════════════════════ */
footer{background:#1a1e14;padding:80px 0 40px}
.foot-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:4rem;padding-bottom:3.5rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.foot-logo-name{font-size:1rem;font-weight:800;color:#fff;display:block;letter-spacing:-.01em}
.foot-logo-sub{font-size:.62rem;color:rgba(255,255,255,.3);letter-spacing:.1em;text-transform:uppercase;display:block;margin-top:2px}
.foot-tagline{font-size:14px;color:rgba(255,255,255,.35);line-height:1.8;margin-top:.9rem;max-width:280px}
.foot-socials{display:flex;gap:8px;margin-top:1.5rem}
.foot-soc{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.35);text-decoration:none;
  font-size:.78rem;transition:all .2s;
}
.foot-soc:hover{border-color:var(--green);color:var(--green)}
.foot-col-h{
  font-size:.68rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:1.2rem;
}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.foot-links a{
  font-size:14px;color:rgba(255,255,255,.42);
  text-decoration:none;display:flex;align-items:center;gap:8px;transition:color .2s;
}
.foot-links a:hover{color:var(--green)}
.foot-links i{font-size:11px;opacity:.6}
.foot-bottom{
  padding-top:1.8rem;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
}
.foot-copy{font-size:13px;color:rgba(255,255,255,.22)}
.foot-legal{display:flex;gap:1.5rem}
.foot-legal a{font-size:13px;color:rgba(255,255,255,.22);text-decoration:none;transition:color .2s}
.foot-legal a:hover{color:rgba(255,255,255,.5)}

/* ══════════════════════════════════════════
   SCROLL REVEALS
══════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(48px);transition:opacity .8s ease,transform .8s ease}
.reveal.vis{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-56px);transition:opacity .8s ease,transform .8s ease}
.reveal-left.vis{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(56px);transition:opacity .8s ease,transform .8s ease}
.reveal-right.vis{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s ease}
.stagger.vis>*:nth-child(1){opacity:1;transform:none;transition-delay:.06s}
.stagger.vis>*:nth-child(2){opacity:1;transform:none;transition-delay:.16s}
.stagger.vis>*:nth-child(3){opacity:1;transform:none;transition-delay:.26s}
.stagger.vis>*:nth-child(4){opacity:1;transform:none;transition-delay:.36s}
.stagger.vis>*:nth-child(5){opacity:1;transform:none;transition-delay:.46s}
.stagger.vis>*:nth-child(6){opacity:1;transform:none;transition-delay:.56s}
/* ══════════════════════════════════════════
   JOOMLA MODULE CHROME
══════════════════════════════════════════ */
.moduletable { margin: 0; padding: 0; }
.moduletable h3 { margin: 0 0 1rem; }

/* ══════════════════════════════════════════
   INNER PAGE LAYOUT (non-homepage)
══════════════════════════════════════════ */
.inner-page-wrap {
    max-width: var(--max);
    margin: 0 auto;
    padding: 120px 48px 80px;
}
.inner-page-wrap h1 {
    font-size: clamp(1.9rem, 3vw, 2.8rem);
    margin-bottom: 1.2rem;
}
.inner-page-wrap p { margin-bottom: 1rem; }
.inner-page-wrap img { max-width: 100%; height: auto; border-radius: var(--r); }

/* Page title bar */
.page-header {
    background: var(--grey-nav);
    padding: 100px 0 50px;
    margin-bottom: 0;
}
.page-header .eyebrow { color: rgba(255,255,255,.6); }
.page-header .eyebrow::before { background: rgba(255,255,255,.4); }
.page-header h1 { color: #fff; font-size: clamp(2rem,4vw,3.2rem); }

/* ══════════════════════════════════════════
   JOOMLA ARTICLES / BLOG LAYOUT
══════════════════════════════════════════ */
.com-content-article__body { font-size: 16px; line-height: 1.75; color: var(--body); }
.com-content-article__body h2 { margin: 2rem 0 .8rem; font-size: 1.6rem; }
.com-content-article__body h3 { margin: 1.5rem 0 .6rem; }
.com-content-article__body p  { margin-bottom: 1rem; }
.com-content-article__body ul,
.com-content-article__body ol { padding-left: 1.4rem; margin-bottom: 1rem; }
.com-content-article__body li { margin-bottom: .4rem; }
.com-content-article__body a  { color: var(--green-dark); text-decoration: underline; }
.com-content-article__body a:hover { color: var(--green); }
.com-content-article__body blockquote {
    border-left: 3px solid var(--green);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    background: var(--green-light);
    border-radius: 0 var(--r) var(--r) 0;
    font-style: italic;
}

/* Blog category */
.blog-items { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; margin-top: 2rem; }
.blog-item { background: var(--sand); border-radius: var(--r); overflow: hidden; }
.blog-item img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.blog-item-body { padding: 1.5rem; }
.blog-item-body h2 { font-size: 1.1rem; margin-bottom: .5rem; }

/* ══════════════════════════════════════════
   CONTACT FORM (Joomla Contact component)
══════════════════════════════════════════ */
.contact-form { max-width: 680px; }
.contact-form .control-group { margin-bottom: 1.2rem; }
.contact-form label { display: block; font-size: .87rem; font-weight: 700; color: var(--ink); margin-bottom: .4rem; }
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form textarea,
.contact-form select {
    width: 100%;
    padding: 12px 16px;
    font-family: inherit;
    font-size: 16px;
    border: 1.5px solid var(--grey-mid);
    border-radius: var(--r);
    background: #fff;
    color: var(--ink);
    transition: border-color .2s;
    appearance: none;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
    outline: none;
    border-color: var(--green);
    box-shadow: 0 0 0 3px rgba(158,175,80,.15);
}
.contact-form textarea { min-height: 140px; resize: vertical; }
.contact-form .btn { margin-top: .5rem; }

/* ══════════════════════════════════════════
   NAV MOBILE
══════════════════════════════════════════ */
.nav-hamburger {
    display: none;
    background: none;
    border: none;
    color: #fff;
    font-size: 1.4rem;
    cursor: pointer;
    padding: 6px;
    line-height: 1;
}
.nav-mobile {
    display: none;
    background: var(--grey-nav);
    padding: 1rem 48px 1.5rem;
    border-top: 1px solid rgba(255,255,255,.1);
}
.nav-mobile.open { display: block; }
.nav-mobile .nav-links { flex-direction: column; gap: 4px; }
.nav-mobile .nav-links a { color: rgba(255,255,255,.82); display: block; padding: 10px 14px; }

/* ══════════════════════════════════════════
   JOOMLA MENU MODULE — nav-links style
══════════════════════════════════════════ */
.nav-menu-wrap ul { display: flex; align-items: center; gap: 2px; list-style: none; margin: 0; padding: 0; }
.nav-menu-wrap ul li a {
    font-size: .87rem; font-weight: 600;
    color: rgba(255,255,255,.82);
    text-decoration: none;
    padding: 8px 14px;
    border-radius: 4px;
    transition: all .2s;
    display: block;
    white-space: nowrap;
}
.nav-menu-wrap ul li a:hover,
.nav-menu-wrap ul li.current > a,
.nav-menu-wrap ul li.active > a { color: #fff; background: rgba(255,255,255,.1); }
.nav-menu-wrap ul li.contact-item > a,
.nav-menu-wrap ul li:last-child > a {
    background: var(--green); color: #fff !important;
    border-radius: 4px; margin-left: 6px;
}
.nav-menu-wrap ul li.contact-item > a:hover,
.nav-menu-wrap ul li:last-child > a:hover { background: var(--green-dark) !important; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 1024px) {
    .wrap { padding: 0 32px; }
    .nav-inner { padding: 0 32px; }
    .diensten-grid { grid-template-columns: 1fr; gap: 3rem; }
    .over-grid { grid-template-columns: 1fr; gap: 3rem; }
    .over-imgs { max-width: 480px; }
    .proj-grid { grid-template-columns: repeat(2,1fr); }
    .foot-grid { grid-template-columns: 1fr 1fr; gap: 3rem; }
    .steps { grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
    .steps::before { display: none; }
}
@media (max-width: 768px) {
    .wrap { padding: 0 20px; }
    section { padding: 72px 0; }
    .nav-menu-wrap { display: none; }
    .nav-hamburger { display: block; }
    h2 { font-size: 1.7rem; }
    .hero h1 { font-size: 2.4rem; }
    .hero-scroll { display: none; }
    .diensten-right { grid-template-columns: 1fr; }
    .d-card.featured { grid-template-columns: 1fr; }
    .proj-grid { grid-template-columns: 1fr; }
    .steps { grid-template-columns: 1fr 1fr; }
    .over-checks { grid-template-columns: 1fr; }
    .foot-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .foot-bottom { flex-direction: column; gap: .8rem; text-align: center; }
    .blog-items { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
    .steps { grid-template-columns: 1fr; }
    .hero-actions { flex-direction: column; align-items: flex-start; }
    .cta-btns { flex-direction: column; align-items: center; }
}

/* ══════════════════════════════════════════
   PRINT
══════════════════════════════════════════ */
@media print {
    #nav, .hero-dots, .hero-scroll, .cta-section, footer { display: none; }
    .hero { min-height: auto; height: auto; }
    body { font-size: 12pt; }
}
