
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#C9A84C;
  --gold-light:#E8C96E;
  --gold-dark:#A07830;
  --black:#14141A;
  --dark:#1A1A24;
  --dark2:#222230;
  --dark3:#2A2A2A;
  --cream:#F8F4EC;
  --cream2:#EDE8DF;
  --white:#FFFFFF;
  --gray:#888880;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Outfit',sans-serif;
  --ease-smooth:cubic-bezier(0.4,0,0.2,1);
  --ease-bounce:cubic-bezier(0.34,1.56,0.64,1);
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--black);color:var(--cream);font-family:var(--font-body);overflow-x:hidden;line-height:1.7}
::selection{background:var(--gold);color:var(--black)}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}

/* ─── NAV ─────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 2rem;display:flex;align-items:center;justify-content:space-between;transition:all .4s var(--ease-smooth)}
#nav.scrolled{background:rgba(10,10,10,.95);backdrop-filter:blur(20px);padding:.8rem 2rem;border-bottom:1px solid rgba(201,168,76,.15)}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-text span:first-child{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--cream);letter-spacing:.02em}
.nav-logo-text span:last-child{font-size:.65rem;font-weight:300;color:var(--gold);letter-spacing:.15em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{color:rgba(245,240,232,.75);text-decoration:none;font-size:.85rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease-smooth)}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-social{display:flex;align-items:center;gap:.75rem}
.nav-social a{width:32px;height:32px;border:1px solid rgba(201,168,76,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);text-decoration:none;transition:all .3s;font-size:.8rem}
.nav-social a:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.nav-social svg{width:14px;height:14px;fill:currentColor}
.nav-cta{background:var(--gold);color:var(--black);padding:.55rem 1.4rem;border-radius:2px;font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all .3s;white-space:nowrap}
.nav-cta:hover{background:var(--gold-light);transform:translateY(-1px)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem}
.nav-hamburger span{width:24px;height:1.5px;background:var(--cream);transition:all .3s;display:block}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,10,10,.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--cream);text-decoration:none;font-family:var(--font-display);font-size:2.5rem;font-weight:300;transition:color .3s}
.mobile-menu a:hover{color:var(--gold)}
.mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--cream);font-size:2rem;cursor:pointer}

/* ─── HERO ─────────────────────────────────────────── */
#hero{height:100vh;min-height:600px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.5s var(--ease-smooth);background-size:cover;background-position:center}
.hero-slide.active{opacity:1}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(10,10,10,.75) 0%,rgba(10,10,10,.3) 60%,rgba(10,10,10,.1) 100%)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.8) 0%,transparent 50%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:760px;padding:0 2rem}
.hero-tag{display:inline-flex;align-items:center;gap:.6rem;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.3);padding:.4rem 1rem;border-radius:2px;margin-bottom:1.5rem}
.hero-tag span{font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}
.hero-tag::before{content:'';width:20px;height:1px;background:var(--gold)}
.hero-h1{font-family:var(--font-display);font-size:clamp(3rem,7vw,5.5rem);font-weight:300;line-height:1.08;color:var(--cream);margin-bottom:1rem}
.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:1.05rem;font-weight:300;color:rgba(245,240,232,.7);max-width:480px;margin-bottom:2.5rem;line-height:1.7}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-gold{background:var(--gold);color:var(--black);padding:.85rem 2.2rem;border-radius:2px;font-size:.85rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all .35s var(--ease-smooth);border:2px solid var(--gold);display:inline-flex;align-items:center;gap:.6rem}
.btn-gold:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--cream);padding:.85rem 2.2rem;border-radius:2px;font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:all .35s;border:1px solid rgba(245,240,232,.3);display:inline-flex;align-items:center;gap:.6rem}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.hero-indicators{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:.6rem}
.hero-dot{width:24px;height:2px;background:rgba(245,240,232,.3);cursor:pointer;transition:all .4s;border:none;border-radius:0}
.hero-dot.active{width:40px;background:var(--gold)}
.hero-scroll{position:absolute;bottom:2.5rem;right:2.5rem;z-index:3;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(245,240,232,.4);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(201,168,76,.8),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}

/* ─── SECTIONS ──────────────────────────────────────── */
section{padding:7rem 2rem}
.container{max-width:1200px;margin:0 auto}
.section-tag{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.section-tag::before{content:'';width:30px;height:1px;background:var(--gold)}
.section-tag span{font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1.15;color:var(--cream)}
.section-title em{font-style:italic;color:var(--gold)}
.section-sub{font-size:1rem;font-weight:300;color:var(--gray);max-width:540px;margin-top:.75rem;line-height:1.8}

/* ─── OVER ONS ──────────────────────────────────────── */
#over{background:var(--dark)}
.over-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-top:4rem}
.over-image-wrap{position:relative}
.over-img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;filter:grayscale(20%)}
.over-img-frame{position:absolute;top:-1.5rem;left:-1.5rem;right:1.5rem;bottom:1.5rem;border:1px solid rgba(201,168,76,.25);border-radius:0;z-index:0;pointer-events:none}
.over-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--gold);color:var(--black);padding:1.5rem;text-align:center;min-width:130px}
.over-badge .num{font-family:var(--font-display);font-size:2.8rem;font-weight:700;line-height:1;display:block}
.over-badge .lab{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-top:.25rem;display:block}
.over-content{position:relative}
.over-text{font-size:1rem;color:rgba(245,240,232,.75);line-height:1.9;margin-top:1.5rem}
.over-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem}
.stat-card{border-left:2px solid var(--gold);padding-left:1.2rem}
.stat-num{font-family:var(--font-display);font-size:2.2rem;font-weight:600;color:var(--gold);line-height:1}
.stat-label{font-size:.8rem;color:var(--gray);margin-top:.25rem;letter-spacing:.05em}
.over-values{margin-top:2.5rem;display:flex;flex-direction:column;gap:.75rem}
.value-item{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:rgba(245,240,232,.75)}
.value-item::before{content:'✦';color:var(--gold);font-size:.7rem;flex-shrink:0}

/* ─── DIENSTEN ──────────────────────────────────────── */
#diensten{background:var(--black)}
.diensten-intro{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem;gap:2rem}
.diensten-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;background:rgba(201,168,76,.1)}
.dienst-card{background:var(--dark);padding:2.2rem 1.8rem;transition:all .4s var(--ease-smooth);cursor:default;position:relative;overflow:hidden}
.dienst-card::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-smooth)}
.dienst-card:hover{background:var(--dark2);transform:translateY(-3px)}
.dienst-card:hover::before{transform:scaleX(1)}
.dienst-icon{width:48px;height:48px;border:1px solid rgba(201,168,76,.25);display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;font-size:1.4rem;transition:all .4s}
.dienst-card:hover .dienst-icon{border-color:var(--gold);background:rgba(201,168,76,.1)}
.dienst-name{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--cream);margin-bottom:.5rem}
.dienst-desc{font-size:.85rem;color:var(--gray);line-height:1.7}

/* ─── PROJECTEN ─────────────────────────────────────── */
#projecten{background:var(--dark)}
.gallery-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;gap:2rem}
.gallery-filter{display:flex;gap:.5rem;flex-wrap:wrap}
.filter-btn{background:none;border:1px solid rgba(245,240,232,.15);color:rgba(245,240,232,.5);padding:.4rem 1rem;border-radius:2px;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .3s;font-family:var(--font-body)}
.filter-btn.active,.filter-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.07)}
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}
.gallery-item{overflow:hidden;position:relative;cursor:pointer}
.gallery-item:nth-child(1){grid-column:span 8;grid-row:span 2}
.gallery-item:nth-child(2){grid-column:span 4}
.gallery-item:nth-child(3){grid-column:span 4}
.gallery-item:nth-child(4){grid-column:span 5}
.gallery-item:nth-child(5){grid-column:span 7}
.gallery-item:nth-child(6){grid-column:span 4}
.gallery-item:nth-child(7){grid-column:span 4}
.gallery-item:nth-child(8){grid-column:span 4}
.gallery-img{width:100%;height:100%;min-height:220px;object-fit:cover;display:block;transition:transform .7s var(--ease-smooth);filter:saturate(.9)}
.gallery-item:hover .gallery-img{transform:scale(1.06);filter:saturate(1.1)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.8) 0%,transparent 60%);opacity:0;transition:opacity .4s}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-label{position:absolute;bottom:1rem;left:1rem;right:1rem;transform:translateY(10px);transition:transform .4s;opacity:0}
.gallery-item:hover .gallery-label{transform:translateY(0);opacity:1}
.gallery-label-cat{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.25rem}
.gallery-label-title{font-family:var(--font-display);font-size:1.2rem;color:var(--cream)}
.gallery-logo{position:absolute;top:.75rem;right:.75rem;opacity:.7;font-family:var(--font-display);font-size:.65rem;letter-spacing:.1em;color:var(--gold);background:rgba(10,10,10,.6);padding:.25rem .5rem;border:1px solid rgba(201,168,76,.3)}

/* ─── REVIEWS ───────────────────────────────────────── */
#reviews{background:var(--black)}
.reviews-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:4rem}
.reviews-list{display:flex;flex-direction:column;gap:1.5rem}
.review-card{background:var(--dark);border:1px solid rgba(201,168,76,.1);padding:2rem;position:relative;transition:all .4s}
.review-card:hover{border-color:rgba(201,168,76,.3);transform:translateX(4px)}
.review-quote{font-family:var(--font-display);font-size:3rem;line-height:1;color:var(--gold);position:absolute;top:.75rem;right:1.25rem;opacity:.2}"
.review-stars{display:flex;gap:3px;margin-bottom:1rem}
.star{color:var(--gold);font-size:.85rem}
.review-text{font-size:.95rem;color:rgba(245,240,232,.8);line-height:1.8;font-style:italic;margin-bottom:1.25rem}
.review-author{display:flex;align-items:center;gap:.75rem}
.review-avatar{width:38px;height:38px;background:linear-gradient(135deg,var(--gold-dark),var(--gold));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--black);flex-shrink:0}
.review-name{font-size:.9rem;font-weight:600;color:var(--cream)}
.review-date{font-size:.75rem;color:var(--gray)}
.review-form-wrap{background:var(--dark);border:1px solid rgba(201,168,76,.1);padding:2.5rem}
.form-title{font-family:var(--font-display);font-size:1.6rem;font-weight:300;color:var(--cream);margin-bottom:.5rem}
.form-sub{font-size:.85rem;color:var(--gray);margin-bottom:2rem}
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,240,232,.5);margin-bottom:.5rem}
.form-input,.form-textarea,.form-select{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(245,240,232,.1);color:#eeac28;padding:.75rem 1rem;font-family:var(--font-body);font-size:.9rem;border-radius:0;outline:none;transition:border .3s;-webkit-appearance:none}.form-select{background-color:#222 !important;color:#F5F0E8 !important}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--gold)}
.form-select option{background:#1a1a1a;color:#F5F0E8;padding:8px}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23C9A84C' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L2 5h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.form-textarea{resize:vertical;min-height:110px}
.star-select{display:flex;gap:.3rem;margin-bottom:1.25rem}
.star-btn{font-size:1.5rem;cursor:pointer;color:rgba(245,240,232,.2);transition:color .2s;background:none;border:none}
.star-btn.active{color:var(--gold)}
.success-msg{display:none;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.3);color:var(--gold);padding:1rem;font-size:.9rem;margin-top:1rem;text-align:center}
.success-msg.show{display:block}

/* ─── OFFERTE ───────────────────────────────────────── */
#offerte{background:var(--dark)}
.offerte-inner{max-width:800px;margin:0 auto}
.offerte-form{background:var(--dark2);border:1px solid rgba(201,168,76,.1);padding:3.5rem;margin-top:3rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.file-drop{border:1px dashed rgba(201,168,76,.3);padding:2rem;text-align:center;cursor:pointer;transition:all .3s;position:relative}
.file-drop:hover{border-color:var(--gold);background:rgba(201,168,76,.04)}
.file-drop-icon{font-size:2rem;margin-bottom:.5rem;color:var(--gold)}
.file-drop-text{font-size:.85rem;color:var(--gray)}
.file-drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.file-names{margin-top:.75rem;font-size:.8rem;color:var(--gold)}

/* ─── CONTACT ───────────────────────────────────────── */
#contact{background:var(--black)}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;margin-top:4rem}
.contact-info{display:flex;flex-direction:column;gap:2rem}
.contact-block .ci-label{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.contact-block .ci-value{font-family:var(--font-display);font-size:1.4rem;font-weight:400;color:var(--cream)}
.contact-block .ci-value a{color:var(--cream);text-decoration:none;transition:color .3s}
.contact-block .ci-value a:hover{color:var(--gold)}
.social-row{display:flex;gap:.75rem;margin-top:.5rem}
.social-btn{width:44px;height:44px;border:1px solid rgba(201,168,76,.25);display:flex;align-items:center;justify-content:center;color:var(--gold);text-decoration:none;transition:all .3s;font-size:.95rem}
.social-btn svg{width:18px;height:18px;fill:currentColor}
.social-btn:hover{background:var(--gold);color:var(--black)}
.contact-form{background:var(--dark);border:1px solid rgba(201,168,76,.1);padding:2.5rem}

/* ─── FOOTER ────────────────────────────────────────── */
footer{background:var(--dark2);border-top:1px solid rgba(201,168,76,.1);padding:4rem 2rem 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto}
.footer-brand .fb-logo{font-family:var(--font-display);font-size:1.6rem;font-weight:600;color:var(--cream);margin-bottom:.5rem}
.footer-brand .fb-logo span{color:var(--gold)}
.footer-brand p{font-size:.85rem;color:var(--gray);line-height:1.7;max-width:260px;margin-top:.75rem}
.footer-col h4{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col ul li a{font-size:.85rem;color:var(--gray);text-decoration:none;transition:color .3s}
.footer-col ul li a:hover{color:var(--gold)}
.footer-bottom{max-width:1200px;margin:3rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(245,240,232,.06);display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-bottom p{font-size:.78rem;color:rgba(245,240,232,.3)}
.footer-social{display:flex;gap:.6rem}
.footer-social a{width:34px;height:34px;border:1px solid rgba(201,168,76,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);text-decoration:none;transition:all .3s}
.footer-social a:hover{background:var(--gold);color:var(--black)}
.footer-social svg{width:14px;height:14px;fill:currentColor}

/* ─── FLOATING CTA ─────────────────────────────────── */
.float-cta{position:fixed;bottom:2rem;right:2rem;z-index:500;display:flex;flex-direction:column;gap:.6rem;align-items:flex-end}
.float-btn{background:var(--gold);color:var(--black);padding:.75rem 1.4rem;border-radius:2px;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;box-shadow:0 8px 30px rgba(201,168,76,.3);transition:all .35s;white-space:nowrap;display:flex;align-items:center;gap:.5rem}
.float-btn:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 12px 40px rgba(201,168,76,.4)}
.float-phone{background:var(--dark2);color:var(--cream);border:1px solid rgba(201,168,76,.2);font-size:.78rem;padding:.65rem 1.2rem;border-radius:2px;text-decoration:none;display:flex;align-items:center;gap:.5rem;transition:all .3s}
.float-phone:hover{border-color:var(--gold);color:var(--gold)}

/* ─── REVEAL ANIMATIONS ──────────────────────────────── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease-smooth),transform .7s var(--ease-smooth)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-30px);transition:opacity .7s var(--ease-smooth),transform .7s var(--ease-smooth)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(30px);transition:opacity .7s var(--ease-smooth),transform .7s var(--ease-smooth)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* ─── LIGHTBOX ──────────────────────────────────────── */
.lightbox{display:none;position:fixed;inset:0;z-index:2000;background:rgba(10,10,10,.97);align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;display:block}
.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--cream);font-size:2rem;cursor:pointer;transition:color .3s}
.lightbox-close:hover{color:var(--gold)}

/* ─── GOLD DIVIDER ──────────────────────────────────── */
.gold-divider{width:60px;height:1px;background:var(--gold);margin:1.5rem 0}

/* ─── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:1024px){
  .over-grid{grid-template-columns:1fr}
  .over-img{aspect-ratio:16/9}
  .diensten-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-layout{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-item:nth-child(1){grid-column:span 12}
  .gallery-item:nth-child(2),.gallery-item:nth-child(3){grid-column:span 6}
  .gallery-item:nth-child(4),.gallery-item:nth-child(5),.gallery-item:nth-child(6),.gallery-item:nth-child(7),.gallery-item:nth-child(8){grid-column:span 6}
}
@media(max-width:768px){
  section{padding:5rem 1.25rem}
  #nav{padding:1rem 1.25rem}
  #nav.scrolled{padding:.8rem 1.25rem}
  .nav-links,.nav-social,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .hero-h1{font-size:clamp(2.2rem,8vw,4rem)}
  .diensten-intro{flex-direction:column;align-items:flex-start}
  .diensten-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-item{grid-column:span 1!important;grid-row:span 1!important}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .offerte-form{padding:2rem 1.5rem}
  .float-cta{bottom:1rem;right:1rem}
  .gallery-header{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .hero-actions{flex-direction:column}
  .btn-gold,.btn-outline{width:100%;justify-content:center}
  .over-badge{display:none}
}

/* ─── HERO VIDEO BG EFFECT (CSS ONLY) ───────────────── */
.hero-grain{position:absolute;inset:0;z-index:1;opacity:.04;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}

/* ─── KVK STRIPE ─────────────────────────────────────── */
.kvk-stripe{background:rgba(201,168,76,.06);border-top:1px solid rgba(201,168,76,.1);padding:.6rem 2rem;text-align:center;font-size:.75rem;color:rgba(245,240,232,.35);letter-spacing:.05em}

/* ─── GALLERY CTA ─────────────────────────────── */
.gallery-cta{text-align:center;margin-top:2.5rem;padding:0 2rem}
.gallery-cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 2rem;border:1px solid rgba(201,168,76,.3);color:var(--gold);text-decoration:none;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;transition:all .3s;background:transparent}
.gallery-cta-btn:hover{background:rgba(201,168,76,.07);transform:translateY(-2px)}
.gallery-cta-arrow{font-size:1.2rem;transition:transform .3s}
.gallery-cta-btn:hover .gallery-cta-arrow{transform:translateX(4px)}
.gallery-cta-text{margin-top:.75rem;font-size:.8rem;color:rgba(245,240,232,.4)}

/* --- COOKIE BANNER ------------------------------- */
.cookie-banner{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#1A1A24;border-top:1px solid rgba(201,168,76,.2);padding:1rem 1.5rem;box-shadow:0 -4px 20px rgba(0,0,0,.4)}
.cookie-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.cookie-text p{font-size:.85rem;color:rgba(245,240,232,.7);line-height:1.5;margin:0}
.cookie-link{color:var(--gold);text-decoration:underline;transition:color .3s}
.cookie-link:hover{color:var(--gold-light)}
.cookie-buttons{display:flex;gap:.6rem;flex-shrink:0}
.cookie-btn{padding:.6rem 1.4rem;font-size:.8rem;font-weight:500;letter-spacing:.05em;cursor:pointer;transition:all .3s;font-family:var(--font-body);border-radius:2px}
.cookie-btn-necessary{background:transparent;color:rgba(245,240,232,.6);border:1px solid rgba(245,240,232,.2)}
.cookie-btn-necessary:hover{color:var(--cream);border-color:rgba(245,240,232,.4)}
.cookie-btn-accept{background:var(--gold);color:var(--black);border:none;font-weight:600}
.cookie-btn-accept:hover{background:var(--gold-light)}
@media(max-width:640px){
 .cookie-banner{padding:.75rem 1rem}
 .cookie-content{flex-direction:column;text-align:center;gap:.75rem}
 .cookie-text p{font-size:.8rem}
 .cookie-buttons{width:100%}
 .cookie-btn{flex:1;padding:.55rem 1rem;font-size:.75rem}
}
/* --- TOUCH EFFECTS ------------------------------- */
@media(hover:hover){
 .btn-gold,.btn-outline,.nav-cta,.float-btn,.float-phone,.filter-btn,.gallery-cta-btn,.cookie-btn{transition:all .25s var(--ease-smooth)}
 .btn-gold:active,.btn-outline:active,.nav-cta:active,.float-btn:active,.gallery-cta-btn:active{transform:scale(.97)}
}
@media(hover:none){
 .btn-gold:active,.btn-outline:active,.nav-cta:active,.float-btn:active,.float-phone:active,.gallery-cta-btn:active{opacity:.7;transform:scale(.97)}
 .dienst-card:active{transform:scale(.98)!important}
 .social-btn:active,.nav-social a:active,.footer-social a:active{transform:scale(.9)}
}

/* --- iOS FIXES ----------------------------------- */
@supports(-webkit-touch-callout:none){
 input,textarea,select,button{font-size:16px!important}
 .hero{min-height:-webkit-fill-available}
}
input,textarea,select{font-size:16px}

/* --- MOBILE MENU ANIMATIE ------------------------ */
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,10,10,.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;transform:translateX(100%);transition:transform .4s var(--ease-smooth);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}
.mobile-menu.open{display:flex;transform:translateX(0)}
.mobile-menu a{opacity:0;transform:translateY(20px);transition:all .35s var(--ease-smooth);transition-delay:0s}
.mobile-menu.open a{opacity:1;transform:translateY(0)}
.mobile-menu.open a:nth-child(1){transition-delay:.05s}
.mobile-menu.open a:nth-child(2){transition-delay:.1s}
.mobile-menu.open a:nth-child(3){transition-delay:.15s}
.mobile-menu.open a:nth-child(4){transition-delay:.2s}
.mobile-menu.open a:nth-child(5){transition-delay:.25s}
.mobile-menu.open a:nth-child(6){transition-delay:.3s}
.mobile-menu.open a:nth-child(7){transition-delay:.35s}
.mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--cream);font-size:2rem;cursor:pointer;z-index:1000}

/* --- RESET MOBILE MENU (verwijder oude display:flex zonder animatie) -- */
.mobile-menu.open{display:flex}

/* --- MOBIELE SPACING & OVERFLOW FIXES ----------- */
@media(max-width:430px){
 section{padding:3.5rem 1rem!important}
 .hero-h1{font-size:clamp(2rem,8vw,3rem)!important}
 .hero-sub{font-size:.9rem!important;max-width:100%!important}
 .hero-actions{flex-direction:column;width:100%}
 .hero-actions .btn-gold,.hero-actions .btn-outline{width:100%;justify-content:center}
 .hero-scroll{display:none}
 .over-stats{grid-template-columns:1fr}
 .over-badge{position:relative;bottom:0;right:0;margin-top:-1rem;min-width:100%;padding:1rem}
 .over-badge .num{font-size:2rem}
 .diensten-intro{flex-direction:column;align-items:flex-start;margin-bottom:2rem}
 .diensten-grid{gap:1px}
 .dienst-card{padding:1.5rem 1.2rem}
 .gallery-header{flex-direction:column;align-items:flex-start}
 .gallery-filter{flex-wrap:nowrap;overflow-x:auto;width:100%;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}
 .gallery-filter::-webkit-scrollbar{height:2px}
 .gallery-filter::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}
 .filter-btn{white-space:nowrap;flex-shrink:0}
 .offerte-form{padding:1.5rem 1rem}
 .contact-form{padding:1.5rem}
 .review-form-wrap{padding:1.5rem}
 .contact-grid{gap:2rem}
 .footer-grid{gap:2rem}
 .float-cta{bottom:.75rem;right:.75rem;gap:.4rem}
 .float-btn,.float-phone{font-size:.7rem;padding:.5rem 1rem;white-space:nowrap}
 .hero-indicators{bottom:1.5rem}
 .hero-dot{width:20px;height:2px}
 .hero-dot.active{width:32px}
}
@media(max-width:390px){
 .hero-h1{font-size:clamp(1.8rem,7vw,2.5rem)!important}
 .nav-logo-icon{width:36px;height:36px;font-size:1.1rem}
 .nav-logo-text span:first-child{font-size:1.1rem}
 .nav-logo-text span:last-child{font-size:.55rem}
 .section-title{font-size:clamp(1.5rem,5vw,2rem)}
 .dienst-name{font-size:1.1rem}
 .form-row{grid-template-columns:1fr}
 .over-image-wrap{margin-bottom:1rem}
 .over-img-frame{top:-.75rem;left:-.75rem;right:.75rem;bottom:.75rem}
}
@media(max-width:375px){
 .hero-h1{font-size:1.6rem!important}
 .hero-tag{padding:.25rem .6rem}
 .hero-tag span{font-size:.55rem}
 .hero-sub{font-size:.8rem!important}
 .nav-links,.nav-social,.nav-cta{display:none}
 .nav-hamburger{display:flex}
 .mobile-menu a{font-size:2rem}
 .gallery-grid{grid-template-columns:1fr!important}
 .gallery-item{grid-column:span 1!important;grid-row:span 1!important}
 .footer-grid{grid-template-columns:1fr}
 .footer-bottom{flex-direction:column;text-align:center}
}

/* --- REDUCED MOTION ------------------------------- */
@media(prefers-reduced-motion:reduce){
 .reveal,.reveal-left,.reveal-right,.mobile-menu,.hero-slide{transition:none!important;opacity:1!important;transform:none!important}
 .hero-h1,.hero-sub,.hero-content,.dienst-card{opacity:1!important;transform:none!important}
}
/* --- COMPACT MOBILE MENU (zonder Over Ons) --- */
.mobile-menu-compact{gap:1.8rem!important}
.mobile-menu-compact a{font-size:1.6rem!important}
@media(max-width:375px){
 .mobile-menu-compact a{font-size:1.3rem!important}
 .mobile-menu-compact{gap:1.2rem!important}
}
