:root {
  --navy: #0d1b3e;
  --navy-mid: #132251;
  --navy-light: #1a2d6b;
  --gold: #c9a84c;
  --gold-light: #e8c96a;
  --teal: #4ecdc4;
  --teal-dark: #2ab5ac;
  --white: #f8f6f0;
  --grey: #8a9bb5;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--navy); color:var(--white); font-family:'Jost',sans-serif; font-weight:300; overflow-x:hidden; }
h1,h2,h3 { font-family:'Cormorant Garamond',serif; }
img { max-width:100%; display:block; }

/* ── TOPBAR ── */
.topbar {
  position:fixed; top:0; left:0; right:0; z-index:990;
  height:64px; display:flex; align-items:center; justify-content:space-between;
  padding:0 24px; background:rgba(13,27,62,.95); backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(201,168,76,.15); transition:box-shadow .3s;
}
.topbar-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.topbar-logo img { width:44px; height:44px; object-fit:contain; border-radius:50%; mix-blend-mode:screen; }
.topbar-logo-text { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:700; color:var(--gold); line-height:1.2; }
.topbar-logo-text span { display:block; font-family:'Jost',sans-serif; font-size:.62rem; font-weight:400; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); }
.topbar-nav { display:flex; gap:28px; }
.topbar-nav a { color:rgba(248,246,240,.75); text-decoration:none; font-size:.84rem; letter-spacing:.05em; padding:4px 0; border-bottom:2px solid transparent; transition:color .2s, border-color .2s; }
.topbar-nav a:hover { color:var(--gold); border-bottom-color:var(--gold); }
.topbar-cta { background:#25D366; color:#fff; font-weight:600; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; text-decoration:none; padding:9px 20px; border-radius:4px; white-space:nowrap; transition:opacity .2s; }
.topbar-cta-email { background:linear-gradient(135deg,var(--gold),var(--gold-light)); color:var(--navy); font-weight:600; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; text-decoration:none; padding:9px 20px; border-radius:4px; white-space:nowrap; transition:opacity .2s; }
.topbar-cta:hover, .topbar-cta-email:hover { opacity:.88; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--gold); transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
/* SLIDE DRAWER */
.drawer-overlay { position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:988; opacity:0; pointer-events:none; transition:opacity .35s; backdrop-filter:blur(3px); }
.drawer-overlay.open { opacity:1; pointer-events:all; }
.mobile-menu {
  position:fixed; top:0; right:-320px; width:290px; height:100vh; z-index:989;
  background:linear-gradient(160deg,#0d1b3e 0%,#091530 100%);
  border-left:1px solid rgba(201,168,76,.22);
  box-shadow:-8px 0 40px rgba(0,0,0,.5);
  display:flex; flex-direction:column; justify-content:center; padding:60px 36px;
  transition:right .38s cubic-bezier(.4,0,.2,1);
}
.mobile-menu.open { right:0; }
.mobile-menu a { display:block; color:var(--white); text-decoration:none; font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:600; padding:12px 0; border-bottom:1px solid rgba(201,168,76,.12); letter-spacing:.04em; transition:color .2s,padding-left .2s; }
.mobile-menu a:hover { color:var(--gold); padding-left:6px; }
.mobile-menu a:last-of-type { border-bottom:none; }
.drawer-cta-group { margin-bottom:24px; display:flex; flex-direction:column; gap:10px; }
.mob-cta { background:#25D366; color:#fff!important; font-weight:600; text-align:center; border-radius:6px; padding:14px 20px!important; font-family:'Jost',sans-serif!important; font-size:.88rem!important; letter-spacing:.08em; text-transform:uppercase; border:none!important; }
.mob-cta-email { background:linear-gradient(135deg,var(--gold),var(--gold-light)); color:var(--navy)!important; font-weight:600; text-align:center; border-radius:6px; padding:14px 20px!important; font-family:'Jost',sans-serif!important; font-size:.88rem!important; letter-spacing:.08em; text-transform:uppercase; border:none!important; }

/* ── HERO ── */
.hero {
  min-height:100vh; padding-top:64px; position:relative;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 60% 40%, rgba(26,45,107,.8) 0%, var(--navy) 70%); }
.hero-orb { position:absolute; border-radius:50%; filter:blur(70px); opacity:.2; pointer-events:none; }
.orb1 { width:500px; height:500px; background:var(--gold); top:-120px; right:-120px; }
.orb2 { width:350px; height:350px; background:var(--teal); bottom:-60px; left:-80px; }
.hero-grid { position:absolute; inset:0; opacity:.04; background-image:linear-gradient(var(--gold) 1px,transparent 1px),linear-gradient(90deg,var(--gold) 1px,transparent 1px); background-size:60px 60px; }
.gold-line { position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent 0%,var(--gold) 30%,var(--gold-light) 50%,var(--gold) 70%,transparent 100%); }
.hero-content { position:relative; z-index:2; text-align:center; padding:60px 24px 80px; max-width:860px; }
.hero-logo { width:120px; height:120px; object-fit:contain; border-radius:50%; margin:0 auto 28px; animation:fadeUp .8s ease both; filter:drop-shadow(0 4px 24px rgba(201,168,76,.4)); mix-blend-mode:screen; }
.hero-badge { display:inline-block; background:rgba(201,168,76,.12); border:1px solid rgba(201,168,76,.35); border-radius:40px; padding:6px 20px; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; animation:fadeUp .8s .05s ease both; }
.hero h1 { font-size:clamp(2.4rem,6vw,5rem); font-weight:700; line-height:1.05; margin-bottom:8px; animation:fadeUp .8s .1s ease both; }
.hero h1 em { font-style:italic; color:var(--gold); }
.hero-sub { font-size:clamp(.85rem,2vw,1.15rem); color:var(--teal); margin:16px 0 32px; letter-spacing:.04em; animation:fadeUp .8s .2s ease both; white-space:nowrap; }
.hero-tags { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:40px; animation:fadeUp .8s .3s ease both; }
.hero-tag { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:4px; padding:6px 14px; font-size:.8rem; }
.hero-cta { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; animation:fadeUp .8s .4s ease both; }
.btn-primary { display:inline-flex; align-items:center; gap:10px; background:linear-gradient(135deg,var(--gold),var(--gold-light)); color:var(--navy); font-weight:600; font-size:.9rem; letter-spacing:.06em; text-transform:uppercase; text-decoration:none; padding:15px 32px; border-radius:4px; transition:transform .2s,box-shadow .2s; box-shadow:0 4px 24px rgba(201,168,76,.3); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 36px rgba(201,168,76,.45); }
.btn-secondary { display:inline-flex; align-items:center; gap:10px; background:transparent; border:1px solid rgba(78,205,196,.5); color:var(--teal); font-size:.9rem; letter-spacing:.06em; text-transform:uppercase; text-decoration:none; padding:15px 32px; border-radius:4px; transition:background .2s,border-color .2s; }
.btn-secondary:hover { background:rgba(78,205,196,.1); border-color:var(--teal); }

/* ── SECTIONS ── */
section { padding:90px 20px; scroll-margin-top:64px; }
.container { max-width:1100px; margin:0 auto; }
.section-label { font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.section-title { font-size:clamp(1.8rem,4vw,3rem); font-weight:700; line-height:1.1; margin-bottom:18px; }
.section-line { width:60px; height:2px; background:linear-gradient(90deg,var(--gold),var(--gold-light)); margin-bottom:40px; }

/* ── OVER ONS ── */
#over { background:linear-gradient(180deg,var(--navy) 0%,#0a1528 100%); }
.over-grid { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.over-text p { color:var(--grey); line-height:1.8; margin-bottom:18px; font-size:1rem; }
.over-text strong { color:var(--white); font-weight:500; }
.values { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; }
.value-card { background:rgba(255,255,255,.04); border:1px solid rgba(201,168,76,.15); border-radius:8px; padding:18px 14px; transition:border-color .3s,background .3s; }
.value-card:hover { border-color:rgba(201,168,76,.4); background:rgba(201,168,76,.05); }
.value-icon { font-size:1.3rem; margin-bottom:7px; }
.value-card h4 { font-family:'Cormorant Garamond',serif; font-size:1.05rem; color:var(--gold); margin-bottom:3px; }
.value-card p { font-size:.8rem; color:var(--grey); line-height:1.6; }
.over-visual { background:linear-gradient(135deg,var(--navy-light),var(--navy-mid)); border:1px solid rgba(201,168,76,.2); border-radius:16px; padding:48px 32px; display:flex; flex-direction:column; align-items:center; gap:24px; }
.stat { text-align:center; }
.stat-num { font-family:'Cormorant Garamond',serif; font-size:3.2rem; font-weight:700; color:var(--gold); line-height:1; }
.stat-label { font-size:.75rem; letter-spacing:.12em; color:var(--grey); text-transform:uppercase; margin-top:5px; }
.stat-divider { width:1px; height:50px; background:rgba(201,168,76,.2); }

/* ── FAMILY BADGE ── */
.family-badge { display:flex; align-items:center; gap:14px; background:rgba(201,168,76,.08); border:1px solid rgba(201,168,76,.25); border-radius:10px; padding:16px 20px; margin:24px 0; }
.family-icon { font-size:2rem; flex-shrink:0; }
.family-badge strong { display:block; color:var(--gold); font-size:1rem; font-weight:600; }
.family-badge span { font-size:.82rem; color:var(--grey); }

/* ── WHY TRUST ── */
.why-trust { background:linear-gradient(135deg,rgba(201,168,76,.07),rgba(26,45,107,.3)); border:1px solid rgba(201,168,76,.25); border-radius:14px; padding:26px 28px; margin:28px 0; }
.why-trust-header { display:flex; align-items:center; gap:16px; margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid rgba(201,168,76,.15); }
.why-trust-title { display:block; font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:700; color:var(--gold); margin-bottom:3px; }
.why-trust-sub { font-size:.78rem; color:var(--grey); letter-spacing:.02em; }
.why-list { list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.why-list li { display:flex; align-items:center; gap:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:8px; padding:12px 14px; color:var(--white); font-size:.86rem; line-height:1.4; transition:border-color .25s,background .25s; }
.why-list li:hover { background:rgba(78,205,196,.07); border-color:rgba(78,205,196,.3); }
.why-check { display:flex; align-items:center; justify-content:center; width:24px; height:24px; min-width:24px; border-radius:50%; background:rgba(78,205,196,.15); border:1.5px solid var(--teal); color:var(--teal); font-size:.72rem; font-weight:700; flex-shrink:0; }
@media (max-width:600px) { .why-list { grid-template-columns:1fr; } .why-trust { padding:20px 18px; } }

/* ── PRICING STRIP ── */
.pricing-strip { margin-bottom:22px; background:linear-gradient(135deg,rgba(201,168,76,.1),rgba(26,45,107,.25)); border:1px solid rgba(201,168,76,.35); border-radius:12px; padding:28px 36px; display:flex; gap:28px; align-items:center; flex-wrap:wrap; }
.pricing-left { flex: 1; min-width: 220px; }
.pricing-headline { font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:700; color:var(--white); margin-bottom:10px; }
.pricing-meta { display:flex; flex-wrap:wrap; gap:10px 20px; }
.pricing-meta span { font-size:.82rem; color:var(--grey); }
@media (max-width:600px) { .pricing-strip { flex-direction:column; padding:24px 20px; align-items:flex-start; } .pricing-strip .btn-primary { width:100%; justify-content:center; } }

/* ── EXTRA SERVICES ── */
.service-extra-title { font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin:16px 0 8px; }
.service-extra li::before { background:var(--gold) !important; }

/* ── DIENSTEN ── */
#diensten { background:#0a1528; }
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px; margin-bottom:48px; }
.service-card { background:linear-gradient(135deg,rgba(26,45,107,.4),rgba(13,27,62,.6)); border:1px solid rgba(201,168,76,.15); border-radius:12px; padding:32px 26px; position:relative; overflow:hidden; transition:transform .3s,border-color .3s,box-shadow .3s; }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); transform:scaleX(0); transition:transform .4s; }
.service-card:hover::before { transform:scaleX(1); }
.service-card:hover { transform:translateY(-4px); border-color:rgba(201,168,76,.35); box-shadow:0 12px 40px rgba(0,0,0,.3); }
.service-icon { font-size:1.8rem; margin-bottom:14px; }
.service-card h3 { font-size:1.4rem; font-weight:700; color:var(--white); margin-bottom:9px; }
.service-card p { color:var(--grey); line-height:1.7; font-size:.9rem; margin-bottom:18px; }
.service-list { list-style:none; }
.service-list li { color:var(--grey); font-size:.86rem; padding:6px 0; border-bottom:1px solid rgba(255,255,255,.06); display:flex; align-items:center; gap:9px; }
.service-list li::before { content:''; display:block; width:6px; height:6px; border-radius:50%; background:var(--teal); flex-shrink:0; }
.deep-banner { margin-top:36px; background:linear-gradient(135deg,rgba(78,205,196,.1),rgba(26,45,107,.3)); border:1px solid rgba(78,205,196,.3); border-radius:12px; padding:40px; display:flex; gap:32px; align-items:center; flex-wrap:wrap; }
.deep-banner h3 { font-size:1.8rem; font-weight:700; color:var(--teal); margin-bottom:8px; }
.deep-banner p { color:var(--grey); font-size:.95rem; line-height:1.7; }
.deep-checks { display:flex; flex-wrap:wrap; gap:9px; margin-top:18px; }
.deep-check { display:flex; align-items:center; gap:7px; background:rgba(78,205,196,.1); border:1px solid rgba(78,205,196,.2); border-radius:4px; padding:5px 13px; font-size:.82rem; color:var(--teal); }
.deep-check::before { content:'✓'; font-weight:700; }

/* ── GALLERY ── */
#galerij { background:var(--navy); }
.gallery-intro { max-width:600px; margin-bottom:40px; }
.gallery-intro p { color:var(--grey); line-height:1.8; }
.gallery-tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; }
.tab-btn { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); color:var(--grey); font-family:'Jost',sans-serif; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; padding:8px 18px; border-radius:4px; cursor:pointer; transition:all .2s; }
.tab-btn.active, .tab-btn:hover { background:rgba(201,168,76,.15); border-color:var(--gold); color:var(--gold); }

/* masonry-style grid */
.gallery-grid {
  columns:3; column-gap:14px;
}
.gallery-item {
  break-inside:avoid; margin-bottom:14px;
  position:relative; border-radius:10px; overflow:hidden; cursor:pointer;
  border:1px solid rgba(201,168,76,.1); transition:transform .3s,box-shadow .3s;
  display:block;
}
.gallery-item img { width:100%; height:auto; display:block; transition:transform .4s; }
.gallery-item:hover { transform:scale(1.01); box-shadow:0 8px 32px rgba(0,0,0,.45); }
.gallery-item:hover img { transform:scale(1.04); }
.gallery-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(13,27,62,.85) 0%,transparent 55%); opacity:0; transition:opacity .3s; display:flex; align-items:flex-end; padding:16px; }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay-text h4 { font-size:.95rem; font-weight:600; margin-bottom:2px; }
.gallery-overlay-text span { font-size:.75rem; color:var(--teal); }

/* LIGHTBOX */
.lightbox { position:fixed; inset:0; background:rgba(0,0,0,.94); z-index:2000; display:none; align-items:center; justify-content:center; padding:20px; }
.lightbox.open { display:flex; }
.lightbox img { max-width:92vw; max-height:88vh; object-fit:contain; border-radius:8px; }
.lightbox-close { position:absolute; top:18px; right:22px; background:rgba(255,255,255,.1); border:none; color:var(--white); font-size:1.5rem; line-height:1; width:40px; height:40px; border-radius:50%; cursor:pointer; transition:background .2s; display:flex; align-items:center; justify-content:center; }
.lightbox-close:hover { background:rgba(255,255,255,.2); }
.lightbox-nav { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.1); border:none; color:var(--white); font-size:1.5rem; width:48px; height:48px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.lightbox-nav:hover { background:rgba(255,255,255,.2); }
#lightboxPrev { left:16px; }
#lightboxNext { right:16px; }

/* ── CONTACT ── */
#contact { background:#0a1528; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:70px; }
.contact-info p { color:var(--grey); line-height:1.8; font-size:.98rem; margin-bottom:28px; }
.contact-methods { display:flex; flex-direction:column; gap:14px; }
.contact-method { display:flex; align-items:center; gap:18px; background:rgba(255,255,255,.04); border:1px solid rgba(201,168,76,.15); border-radius:8px; padding:18px 22px; text-decoration:none; transition:border-color .3s,background .3s; }
.contact-method:hover { border-color:rgba(201,168,76,.4); background:rgba(201,168,76,.05); }
.contact-icon { width:46px; height:46px; border-radius:8px; background:rgba(201,168,76,.12); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.contact-method h4 { color:var(--white); font-family:'Jost',sans-serif; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:3px; }
.contact-method p { color:var(--teal); font-size:.95rem; margin:0; }
.contact-form-box { background:linear-gradient(135deg,rgba(26,45,107,.4),rgba(13,27,62,.6)); border:1px solid rgba(201,168,76,.15); border-radius:12px; padding:36px; }
.form-group { margin-bottom:18px; }
label { display:block; font-size:.75rem; letter-spacing:.1em; text-transform:uppercase; color:var(--grey); margin-bottom:7px; }
input,textarea,select { width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:6px; padding:13px 16px; color:var(--white); font-family:'Jost',sans-serif; font-size:.92rem; transition:border-color .2s; -webkit-appearance:none; }
input:focus,textarea:focus,select:focus { outline:none; border-color:var(--gold); }
textarea { resize:vertical; min-height:110px; }
select option { background:var(--navy); }
.form-submit { width:100%; background:linear-gradient(135deg,var(--gold),var(--gold-light)); border:none; border-radius:6px; padding:15px; color:var(--navy); font-family:'Jost',sans-serif; font-size:.9rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; cursor:pointer; transition:opacity .2s,transform .2s; }
.form-submit:hover { opacity:.9; transform:translateY(-1px); }

/* ── FOOTER ── */
footer { background:#060e1f; border-top:1px solid rgba(201,168,76,.12); padding:40px 20px; text-align:center; }
.footer-inner { display:flex; flex-direction:column; align-items:center; gap:10px; }
.footer-logo-wrap { display:flex; align-items:center; gap:12px; }
.footer-logo-wrap img { width:48px; height:48px; object-fit:contain; border-radius:50%; mix-blend-mode:screen; }
.footer-brand { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:700; color:var(--gold); }
.footer-tagline { color:var(--teal); font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; }
footer p { color:var(--grey); font-size:.8rem; line-height:1.7; }


/* ── HERO PROBLEMS ── */
.hero-problems { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:48px; max-width:860px; width:100%; animation:fadeUp .8s .5s ease both; }
.prob-card { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:10px; padding:16px 14px; display:flex; align-items:center; gap:8px; text-align:left; transition:border-color .3s,background .3s; }
.prob-card:hover { background:rgba(255,255,255,.1); border-color:rgba(201,168,76,.3); }
.prob-before, .prob-after { flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; text-align:center; }
.prob-before p { color:rgba(248,246,240,.55); font-size:.76rem; line-height:1.4; }
.prob-after p { color:var(--teal); font-size:.76rem; line-height:1.4; font-weight:500; }
.prob-icon { font-size:1.4rem; }
.prob-arrow { font-size:1rem; color:var(--gold); flex-shrink:0; }
@media (max-width:700px) { .hero-problems { grid-template-columns:1fr; gap:8px; margin-top:32px; } .prob-card { padding:12px; } }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:translateY(0); } }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── WERKGEBIED ── */
#werkgebied { background:#0a1528; }
.werkgebied-content { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.area-card { background:rgba(255,255,255,.04); border:1px solid rgba(201,168,76,.15); border-radius:8px; padding:18px 22px; margin-bottom:12px; display:flex; align-items:center; gap:14px; }
.area-card p { color:var(--white); font-size:.92rem; }
.area-card span:not(.pin) { font-size:.78rem; color:var(--grey); display:block; margin-top:2px; }
.map-visual { width:100%; height:380px; border:1px solid rgba(201,168,76,.2); border-radius:12px; overflow:hidden; max-width:480px; margin:0 auto; }
@media (max-width:600px) { .map-visual { height:260px; } }

/* ── RESPONSIVE ── */
@media (max-width:900px) and (min-width:601px) {
  .topbar-cta, .topbar-cta-email { display:none; }
}
@media (max-width:600px) {
  .topbar-nav { display:none; }
  .topbar-cta, .topbar-cta-email { display:none; }
  .hamburger { display:flex; }
  .over-grid, .werkgebied-content, .contact-grid { grid-template-columns:1fr; gap:40px; }
  .over-visual { display:none; }
  .deep-banner { flex-direction:column; }
  .gallery-grid { columns:2; }
}
@media (max-width:600px) {
  section { padding:64px 16px; }
  .hero-logo { width:88px; height:88px; }
  .hero-cta a { width:100%; justify-content:center; }
  .values { grid-template-columns:1fr; }
  .contact-form-box { padding:22px 16px; }
  .gallery-grid { columns:1; }
  .topbar { padding:0 14px; }
  .topbar-logo-text { font-size:.95rem; }
}

/* ── COOKIE BANNER ── */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:999;
  background:rgba(13,27,62,.97); border-top:1px solid rgba(201,168,76,.25);
  padding:16px 24px; display:flex; align-items:center; justify-content:space-between;
  gap:20px; backdrop-filter:blur(12px);
}
.cookie-banner p { color:rgba(248,246,240,.8); font-size:.82rem; line-height:1.6; margin:0; }
.cookie-btn { background:linear-gradient(135deg,var(--gold),var(--gold-light)); color:var(--navy); font-weight:600; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; border:none; padding:9px 24px; border-radius:4px; cursor:pointer; white-space:nowrap; transition:opacity .2s; }
.cookie-btn:hover { opacity:.88; }
@media (max-width:600px) {
  .cookie-banner { flex-direction:column; align-items:flex-start; }
}

/* ── REDUCED MOTION ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ── GALLERY COLLAPSE ── */
.gallery-toggle { display:block; margin:16px auto 0; background:none; border:1px solid rgba(201,168,76,.35); color:var(--gold); border-radius:20px; padding:6px 18px; cursor:pointer; font-size:.75rem; letter-spacing:.08em; text-transform:uppercase; transition:background .2s, color .2s; }
.gallery-toggle:hover { background:rgba(201,168,76,.1); }
#galleryCollapsible { overflow:hidden; transition:max-height .4s ease, opacity .3s ease; max-height:4000px; opacity:1; }
#galleryCollapsible.collapsed { max-height:0; opacity:0; }

/* ── SOCIAL ICONS ── */
.footer-social { display:flex; justify-content:center; gap:12px; margin-top:16px; }
.social-icon { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:50%; border:1px solid rgba(201,168,76,.35); color:var(--gold); font-size:.95rem; transition:background .2s, color .2s; text-decoration:none; }
.social-icon:hover { background:var(--gold); color:var(--navy); }

/* LANGUAGE SWITCHER */
.lang-switcher { display:flex; gap:4px; }
.lang-btn { color:rgba(248,246,240,.6); font-size:.72rem; font-weight:600; letter-spacing:.06em; text-decoration:none; padding:4px 7px; border-radius:3px; border:1px solid transparent; transition:color .2s, border-color .2s; }
.lang-btn:hover, .lang-btn.active { color:var(--gold); border-color:var(--gold); }
@media (max-width:600px) { .lang-switcher { display:none; } }

/* DRAWER LANGUAGE LINKS */
.drawer-lang { display:flex; justify-content:center; gap:12px; margin-top:24px; padding-top:16px; border-top:1px solid rgba(201,168,76,.2); }
.drawer-lang a { color:rgba(248,246,240,.5); font-size:.78rem; font-weight:600; letter-spacing:.06em; text-decoration:none; padding:4px 8px; border-radius:3px; border:1px solid transparent; transition:color .2s, border-color .2s; }
.drawer-lang a:hover { color:var(--gold); border-color:var(--gold); }


