*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --black: #0a0a0a;
  --white: #f5f4f0;
  --gray: #888;
  --yellow: #f0d000;
  --font-display: 'Montserrat', sans-serif;
  --font-body: 'Montserrat', sans-serif;
}

html { scroll-behavior: smooth; }

body {
  background: var(--white);
  color: var(--black);
  font-family: var(--font-display);
  overflow-x: hidden;
}

/* NAV */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 48px;
  background: linear-gradient(0deg, rgba(255, 255, 255, 0.00) 0%, #FFF 100%);
  transition: border-color 0.3s;
}
nav.scrolled { border-color: #e0dfd9; }

.logo {
  font-size: 3rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  text-decoration: none;
  color: var(--black);
}

.nav-links {
  display: flex;
  gap: 32px;
  list-style: none;
}
.nav-links a {
  text-decoration: none;
  color: var(--black);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  transition: opacity 0.2s;
}
.nav-links a:hover { opacity: 0.45; }

/* Inverted nav op homepage — alleen boven de bildwerk-hero */
body.home:not(.past-hero) nav {
  background: linear-gradient(0deg, rgba(10, 10, 10, 0.00) 0%, #0a0a0a 100%);
}
body.home:not(.past-hero) nav.scrolled { border-color: #222; }
body.home:not(.past-hero) .logo,
body.home:not(.past-hero) .nav-links a { color: var(--white); }
body.home:not(.past-hero) .hamburger span { background: var(--white); }

body.home nav,
body.home .logo,
body.home .nav-links a,
body.home .hamburger span { transition: background 0.3s ease, color 0.3s ease; }

.social-link {
  display: none;
}

/* HERO */
.hero {
  padding-top: 80px;
}

.hero-image {
  width: 100%;
  height: clamp(400px, 55vw, 800px);
  background: #d8d6d0;
  overflow: hidden;
  position: relative;
}

.hero-image img,
.hero-image video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}


/* INTRO TEXT */
.intro {
  padding: 40px 48px 0;
	 margin-bottom: 40px;
}
.intro-label {
  font-size: 1.5rem;
  color: var(--black);
  margin-bottom: 70px;
  font-weight: 400;
}
.intro-heading {
  font-family: 'Montserrat', sans-serif;
  font-stretch: condensed;
  font-size: clamp(3rem, 5.5vw, 17rem);
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  max-width: 1440px;

}
.intro-heading .read-more {
  font-family: var(--font-body);
   
  font-size: clamp(1rem, 1vw, 1.25rem);
  font-weight: 400;
  color: var(--black);
  margin-left: 16px;
  vertical-align: middle;
	letter-spacing: 0.01em;
  cursor: pointer;
  transition: color 0.2s;
}
.intro-heading .read-more:hover { color: var(--black); }

/* PORTFOLIO GRID */
.portfolio {
  padding: 30px 30px 0;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.portfolio-item {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.portfolio-item img {
  width: 100%;
  display: block;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.portfolio-item:hover img { transform: scale(1.05); }

/* Project: Bouwrijk */
.project-bouwrijk {
  width: 100%;
  aspect-ratio: 16/7;
  overflow: hidden;
  border-radius: 12px;
  background: #d0ceca;
  position: relative;
}



/* Project: Crane */
.project-bildwerk {
  background: #2a1a0e;
  aspect-ratio: 16/7;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 32px;
}

.project-crane,
.project-labor2 {
  width: 100%;
  overflow: hidden;
  border-radius: 12px;
  background: #d0ceca;
  position: relative;
}

.project-bouwrijk img,
.project-crane img,
.project-labor2 img {
  width: 100%;
  height: auto;
  display: block;
}


/* Project: Labor 2 */
.project-bildwerk {
  background: #d8d6d0;
  aspect-ratio: 16/7;
  display: flex;
  align-items: center;
  justify-content: center;
}


/* ticker */
  .ticker-wrapper {
      width: 100%;
      overflow: hidden;
      background: #0a0a0a;
      padding: 100px 0 120px;
      border-top: 1px solid #222;
      border-bottom: 1px solid #222;
	  margin-top: 70px;
	  
    }

    .ticker-label {
      font-size: 1.25rem;
      color: var(--white);
      margin: 0 0 70px;
      padding: 0 48px;
      font-weight: 400;
    }

   .ticker-track {
  display: flex;
  gap: clamp(40px, 8vw, 120px);
  animation: ticker 14s linear infinite;
  white-space: nowrap;
  width: max-content;
}

.ticker-track:hover {
  animation-play-state: paused;
}

.ticker-item {
  display: flex;
  align-items: center;
  gap: clamp(40px, 8vw, 120px);
  flex-shrink: 0;
}

.logo-name:hover {
  opacity: 1;
}

.ticker-logo {
  height: clamp(100px, 10vw, 150px);
  width: auto;
  display: block;
  filter: invert(1);
}/* maakt donkere logo's wit op zwarte achtergrond */

/* .dot {
      width: 6px;
      height: 6px;
      background: #f0d000;
      border-radius: 50%;
      flex-shrink: 0;
    } 
*/
   
    @keyframes ticker {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }

    @media (max-width: 768px) {
      .ticker-wrapper { padding: 60px 0 80px; margin-top: 40px; }
      .ticker-label { margin: 0 0 40px; padding: 0 24px; }
      .ticker-track { animation-duration: 24s; gap: 48px; }
      .ticker-item { gap: 48px; }
      .ticker-logo { height: 60px; }
    }

/* FOOTER */
footer {
  background: #1a1a1a;
  padding: 56px 48px 40px;
}
.footer-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 150px;
  flex-wrap: wrap;
  gap: 32px;
}
.footer-links {
  display: flex;
  gap: 24px;
}
.footer-links a {
  text-decoration: none;
  color: #f5f4f0;
  font-size: 1.25rem;
  transition: opacity 0.2s;
}
.footer-links a:hover { opacity: 0.4; }
.footer-contact {
  max-width: 600px;
  font-size: 1.25rem;
  line-height: 1.7;
  color: #aaa;
  font-family: var(--font-body);
}
.footer-contact a {
  color: #f5f4f0;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.footer-wordmark {
  font-size: clamp(3.5rem, 14vw, 10rem);
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 0.85;
  color: #f5f4f0;
}

.additional-text {
  font-size: 1rem;
  color: #aaa;
  font-family: var(--font-body);
  text-align: right;
  padding-bottom: 0.15em;
  margin: 0;
}
.additional-text .contact-link {
  color: #aaa;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.additional-text .contact-link:hover {
  color: #f5f4f0;
}

.legal-links {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.legal-links .separator {
  color: #666;
}

/* ANIMATIES */
.fade-up {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* HAMBURGER BUTTON */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  z-index: 200;
}
.hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--black);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transform-origin: center;
}

/* Hamburger → X animatie */
.hamburger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.hamburger.open span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.hamburger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* =====================
   WERK-OVERZICHT PAGINA
   ===================== */

/* Actieve nav link */
.nav-links a.active {
  border-bottom: 1.5px solid var(--black);
  padding-bottom: 2px;
}

/* Nav achtergrond op werk-pagina (lichte tint ipv wit gradient) */
nav.werk-nav {
  background: linear-gradient(0deg, rgba(245,244,240,0.00) 0%, #f5f4f0 100%);
}
nav.werk-nav.scrolled {
  border-bottom: none;
}

/* PAGE HEADER */
.page-header {
  padding: 140px 48px 48px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
}

.page-title {
  font-size: clamp(3rem, 6vw, 7rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 0.95;
}

.werk-count {
  font-size: 1rem;
  color: var(--gray);
  font-weight: 400;
  white-space: nowrap;
  align-self: flex-end;
  padding-bottom: 8px;
}

.pill-btn {
  background: none;
  border: 1px solid #ccc;
  border-radius: 999px;
  padding: 10px 30px;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 400;
  cursor: pointer;
  color: var(--black);
  transition: all 0.2s;
  letter-spacing: 0.01em;
  text-decoration: none;
}

.pill-btn:hover {
  background: var(--black);
  color: var(--white);
  border-color: var(--black);
}


/* FILTER BAR */
.filter-bar {
  padding: 0 48px 40px;
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.filter-btn {
  background: none;
  border: 1px solid #ccc;
  border-radius: 999px;
  padding: 6px 20px;
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 400;
  cursor: pointer;
  color: var(--gray);
  transition: all 0.2s;
  letter-spacing: 0.01em;
}

.filter-btn:hover,
.filter-btn.active {
  background: var(--black);
  border-color: var(--black);
  color: var(--white);
}

/* WERK GRID — 2 kolommen */
.werk-grid {
  padding: 0 30px 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.werk-item {
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

/* Featured item: full-width */
.werk-item.featured {
  grid-column: 1 / -1;
}

.werk-thumb {
  width: 100%;
  aspect-ratio: 8/7;
  overflow: hidden;
  border-radius: 12px;
  background: #d0ceca;
  position: relative;
}

.werk-item.featured .werk-thumb {
  aspect-ratio: 16/7;
}

.werk-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.werk-item:hover .werk-thumb img {
  transform: scale(1.05);
}

/* Placeholder achtergrondkleuren per project */
.thumb-bouwrijk { background: #2a1a0e; }
.thumb-crane    { background: #1a1a2e; }
.thumb-labor    { background: #d8d6d0; }
.thumb-studio   { background: #e8e4de; }
.thumb-brand5   { background: #1c2b1a; }
.thumb-brand6   { background: #1e1e1e; }

/* Project metadata onder thumbnail */
.werk-meta {
  padding: 14px 4px 0;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.werk-name {
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--black);
}

.werk-tags {
  font-size: 0.85rem;
  color: var(--gray);
  font-weight: 400;
  text-align: right;
}

/* Hover overlay */
.werk-overlay {
  position: absolute;
  inset: 0;
  background: rgba(10,10,10,0);
  transition: background 0.4s ease;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.werk-item:hover .werk-overlay {
  background: rgba(10,10,10,0.12);
}

.overlay-label {
  font-size: 1.1rem;
  font-weight: 500;
  color: white;
  letter-spacing: 0.04em;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.3s ease 0.05s, transform 0.3s ease 0.05s;
  text-transform: uppercase;
}

.werk-item:hover .overlay-label {
  opacity: 1;
  transform: translateY(0);
}

/* Footer border op werk-pagina */
footer.werk-footer {
  border-top: none;
  padding-top: 24px;
}

/* =====================
   WERK-DETAIL PAGINA
   ===================== */

.detail-hero {
  padding-top: 80px;
}

.detail-hero-image {
  width: 100%;
  height: clamp(400px, 55vw, 800px);
  background: #d8d6d0;
  overflow: hidden;
  position: relative;
}

.detail-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.detail-intro {
  padding: 40px 48px 0;
  margin-bottom: 40px;
}

.detail-intro-label {
  font-size: 1.25rem;
  color: var(--black);
  margin-bottom: 70px;
  font-weight: 400;
}

.detail-intro-heading {
  font-family: 'Montserrat', sans-serif;
  font-stretch: condensed;
  font-size: clamp(3rem, 5.5vw, 17rem);
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  max-width: 1440px;
}

.detail-body {
  padding: 80px 48px 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.detail-body-text {
  max-width: 680px;
  font-size: 1.25rem;
  line-height: 1.75;
  font-weight: 400;
  color: #333;
  text-align: left;
}

.detail-images {
  padding: 0 30px 80px;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.detail-image-block {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
}

.detail-image-block img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.detail-image-block:hover img {
  transform: scale(1.04);
}

.detail-image-block.ratio-wide {
  aspect-ratio: 16/7;
}

.detail-image-block.ratio-half {
  aspect-ratio: 8/7;
}

.detail-image-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}

.detail-nav {
  padding: 48px 48px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid #e0dfd9;
}

.detail-nav a {
  text-decoration: none;
  color: var(--black);
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  transition: opacity 0.2s;
}

.detail-nav a:hover { opacity: 0.45; }

.detail-nav .nav-prev::before { content: '← '; }
.detail-nav .nav-next::after  { content: ' →'; }

/* RESPONSIVE */
@media (max-width: 768px) {
  .detail-intro,
  .diensten-intro { padding: 32px 24px 0; }
  .detail-body  { padding: 48px 24px 64px; }
  .detail-images { padding: 0 16px 60px; gap: 20px; }
  .detail-image-row { grid-template-columns: 1fr; }
  .detail-image-block.ratio-wide,
  .detail-image-block.ratio-half { aspect-ratio: 4/3; }
  .detail-nav { padding: 40px 24px; }
  .detail-nav a { font-size: 1rem; }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
  }
  .additional-text { text-align: left; }
  .legal-links { justify-content: flex-start; }
  .footer-wordmark {
    font-size: calc((100vw - 48px) / 4.4);
    white-space: nowrap;
    display: block;
  }
}

/* RESPONSIVE */
@media (max-width: 768px) {
  nav { padding: 16px 24px; }

  .hamburger { display: flex; }

  .nav-links {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;

    background: var(--white);
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 120px 40px 60px;
    gap: 32px;
    box-shadow: -8px 0 40px rgba(0,0,0,0.08);
    transform: translateX(100%);
    transition: transform 0.25s ease-out;
    z-index: 150;
    overflow-y: auto;
  }

  .nav-links.open {
    transform: translateX(0);
  }

  .nav-links a {
    font-size: 3rem;
    font-weight: 400;
    letter-spacing: -0.02em;
  }

  body.home:not(.past-hero) .nav-links.open a { color: var(--black); }
	
  .social-link {
    display: block;
	
  }
	 .social-link a {
    font-size: 1.6rem;
  }
  .social-link:nth-child(4) {
    margin-top: 100px; 
}
.project-bouwrijk img,
.project-crane img,
.project-labor2 img {
  width: 100%;
  height: auto;
  display: block;
}

.project-crane,
.project-labor2 {
  width: 100%;
  overflow: hidden;
  border-radius: 12px;
  background: #d0ceca;
  position: relative;
}

	
	
  .intro, .portfolio, footer { padding-left: 24px; padding-right: 24px; }
  .footer-top { flex-direction: column; }

  /* Werk pagina responsive */
  .page-header { padding: 110px 24px 32px; flex-direction: column; align-items: flex-start; }
  .filter-bar { padding: 0 24px 32px; }

  .werk-grid {
    padding: 0 16px 60px;
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .werk-item.featured { grid-column: 1; }
  .werk-item.featured .werk-thumb { aspect-ratio: 4/3; }
  .werk-thumb { aspect-ratio: 4/3; }

  .project-bouwrijk,
  .project-crane,
  .project-labor2 { aspect-ratio: auto; }
}



/* =====================
   CONTACT PAGINA
   ===================== */

.contact-wrap {
      padding: 80px 48px 120px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: start;
      max-width: 1400px;
      background: var(--white);
    }

    .contact-left h1 {
      font-family: 'Montserrat', sans-serif;
      font-stretch: condensed;
      font-size: clamp(3rem, 5.5vw, 6.5rem);
      font-weight: 900;
      letter-spacing: -0.03em;
      line-height: 0.95;
      text-transform: uppercase;
      margin-bottom: 40px;
    }

    .contact-left p {
      font-size: 1.25rem;
      line-height: 1.75;
      color: #444;
      max-width: 420px;
    }

    .contact-left .contact-details {
      margin-top: 48px;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .contact-left .contact-details a {
      font-size: 1.1rem;
      color: var(--black);
      text-decoration: underline;
      text-underline-offset: 3px;
      transition: opacity 0.2s;
    }

    .contact-left .contact-details a:hover {
      opacity: 0.45;
    }

    /* FORM */
    .contact-form {
      display: flex;
      flex-direction: column;
      gap: 24px;
    }

    .form-field {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .form-field label {
      font-size: 0.85rem;
      font-weight: 500;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--gray);
    }

    .form-field input,
    .form-field textarea {
      width: 100%;
      background: none;
      border: none;
      border-bottom: 1px solid #ccc;
      padding: 12px 0;
      font-family: var(--font-body);
      font-size: 1.15rem;
      font-weight: 400;
      color: var(--black);
      outline: none;
      transition: border-color 0.2s;
      border-radius: 0;
      -webkit-appearance: none;
    }

    .form-field input::placeholder,
    .form-field textarea::placeholder {
      color: #bbb;
    }

    .form-field input:focus,
    .form-field textarea:focus {
      border-bottom-color: var(--black);
    }

    .form-field textarea {
      resize: none;
      height: 140px;
      line-height: 1.6;
    }

    .form-submit {
      margin-top: 8px;
      display: flex;
      align-items: center;
      gap: 16px;
    }

    .submit-btn {
      background: var(--black);
      color: var(--white);
      border: 1px solid var(--black);
      border-radius: 999px;
      padding: 14px 40px;
      font-family: var(--font-display);
      font-size: 1rem;
      font-weight: 400;
      cursor: pointer;
      letter-spacing: 0.01em;
      transition: background 0.2s, color 0.2s;
    }

    .submit-btn:hover {
      background: none;
      color: var(--black);
    }

    .form-success {
      display: none;
      font-size: 1rem;
      color: #444;
    }

    @media (max-width: 768px) {
      .contact-wrap {
        grid-template-columns: 1fr;
        padding: 60px 24px 80px;
        gap: 56px;
      }
      .contact-left p { max-width: 100%; }
    }

/* ========================
   COOKIE TAB + PANEEL
   ======================== */

/* Altijd-zichtbare tab rechtsonder */
.cookie-tab {
  position: fixed;
  right: 32px;
  bottom: 0;
  z-index: 301;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px 11px;
  background: var(--black);
  color: var(--white);
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 8px 8px 0 0;
  cursor: pointer;
  border: none;
  transition: background 0.2s;
  user-select: none;
}

.cookie-tab:hover {
  background: #333;
}

.cookie-tab__icon {
  font-size: 0.9rem;
  line-height: 1;
  transition: transform 0.3s ease;
  display: inline-block;
}

.cookie-tab.panel-open .cookie-tab__icon {
  transform: rotate(180deg);
}

/* Paneel — schuift omhoog vanuit de onderkant, rechtsonder */
.cookie-banner {
  position: fixed;
  right: 32px;
  bottom: 0;
  z-index: 300;
  width: min(420px, calc(100vw - 48px));
  opacity: 0;
  visibility: hidden;
  transform: translateY(100%);
  transition: opacity 0.35s ease, transform 0.35s ease, visibility 0.35s ease;
  pointer-events: none;
}

.cookie-banner.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.cookie-banner__inner {
  background: var(--white);
  border: 1px solid #d9d6cf;
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  padding: 28px 28px 40px;
  box-shadow: -4px -8px 40px rgba(10, 10, 10, 0.1);
}

.cookie-banner__title {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray);
  margin-bottom: 10px;
}

.cookie-banner__text {
  font-size: 0.92rem;
  line-height: 1.7;
  color: #444;
  font-family: var(--font-body);
  margin-bottom: 24px;
}

.cookie-banner__text a {
  color: var(--black);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.cookie-banner__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.cookie-btn {
  border-radius: 999px;
  padding: 10px 20px;
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  white-space: nowrap;
}

.cookie-btn--ghost {
  background: transparent;
  color: var(--black);
  border: 1px solid #c9c6bf;
}

.cookie-btn--ghost:hover {
  border-color: var(--black);
}

.cookie-btn--primary {
  background: var(--black);
  color: var(--white);
  border: 1px solid var(--black);
}

.cookie-btn--primary:hover {
  background: transparent;
  color: var(--black);
}

@media (max-width: 768px) {
  .cookie-tab {
    right: 20px;
    font-size: 0.68rem;
    padding: 8px 14px 10px;
  }

  .cookie-banner {
    right: 0;
    left: 0;
    width: 100%;
  }

  .cookie-banner__inner {
    border-radius: 16px 16px 0 0;
    border-left: none;
    border-right: none;
    padding: 24px 20px 36px;
  }

  .cookie-banner__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .cookie-btn {
    text-align: center;
  }

  .legal-links {
    justify-content: flex-start;
    gap: 8px;
  }
}

/* LEGAL PAGINA'S */
.legal-section {
  padding: 0 48px 120px;
}

.legal-shell {
  max-width: 900px;
}

.legal-lead {
  font-size: 1.35rem;
  line-height: 1.75;
  color: #333;
  margin-bottom: 48px;
}

.legal-block + .legal-block {
  margin-top: 40px;
}

.legal-block h2 {
  font-size: clamp(1.6rem, 2vw, 2.4rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}

.legal-block p,
.legal-block li {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #333;
  font-family: var(--font-body);
}

.legal-block ul {
  list-style: none;
  display: grid;
  gap: 8px;
  padding: 0;
}

.legal-block a {
  color: var(--black);
  text-decoration: underline;
  text-underline-offset: 2px;
}

@media (max-width: 768px) {
  .legal-section {
    padding: 0 24px 80px;
  }

  .legal-lead {
    font-size: 1.1rem;
    margin-bottom: 36px;
  }
}

/* DIENSTEN */
.diensten-intro {
  padding: 40px 48px 0;
  margin-bottom: 40px;
}

@media (max-width: 768px) {
  .diensten-intro { padding: 32px 24px 0; }
}

.diensten-intro-label {
  font-size: 1.25rem;
  color: var(--black);
  margin-bottom: 70px;
  font-weight: 400;
}

.diensten-intro-heading {
  font-family: 'Montserrat', sans-serif;
  font-stretch: condensed;
  font-size: clamp(2.25rem, 4vw, 7rem);
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  max-width: 1440px;
}

.diensten-label {
  text-align: center;
  font-size: 1rem;
  font-weight: 400;
  text-decoration: underline;
  text-underline-offset: 2px;
  color: rgba(10, 10, 10, 0.5);
  letter-spacing: 0em;
  text-transform: uppercase;
  margin-bottom: 48px;
}

.diensten-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(24px, 3vw, 48px);
  max-width: 1440px;
}

.diensten-col h3 {
  font-size: clamp(0.95rem, 0.95vw, 1.1rem);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 16px;
  color: var(--black);
}

.diensten-col p {
  font-size: clamp(1rem, 1.1vw, 1.35rem);
  line-height: 1.75;
  color: #333;
  font-weight: 400;
}

@media (max-width: 1024px) {
  .diensten-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
}

@media (max-width: 600px) {
  .diensten-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .diensten-intro-heading {
    font-size: 2rem;
  }
}

/* ---------- Bildwerk-stijl hero ---------- */
.bildwerk-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--black);
}
.bildwerk-hero .big-text {
  font-family: 'Montserrat', sans-serif;
  font-stretch: condensed;
  font-weight: 900;
  font-size: clamp(80px, 13vw, 220px);
  line-height: 0.82;
  text-align: center;
  letter-spacing: -0.04em;
  color: var(--white);
  pointer-events: none;
  user-select: none;
  margin: 0;
  text-transform: none;
}
.bildwerk-hero .showcase {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(50vw, 50vh) translate(-50%, -50%);
  width: 320px;
  height: 380px;
  background: #1a1a1a;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.25);
  z-index: 2;
  pointer-events: none;
}
.bildwerk-hero .showcase img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Slinger / trail effect achter de showcase */
.bildwerk-hero .showcase.trail {
  z-index: 1;
  filter: blur(2px);
}
.bildwerk-hero .showcase.trail:nth-of-type(1) { opacity: 0.60; }
.bildwerk-hero .showcase.trail:nth-of-type(2) { opacity: 0.42; }
.bildwerk-hero .showcase.trail:nth-of-type(3) { opacity: 0.27; }
.bildwerk-hero .showcase.trail:nth-of-type(4) { opacity: 0.15; }
.bildwerk-hero .showcase.trail:nth-of-type(5) { opacity: 0.07; }
@media (max-width: 760px) {
  .bildwerk-hero .showcase { width: 220px; height: 280px; }
  .bildwerk-hero .big-text {
    font-size: clamp(64px, 22vw, 150px);
    line-height: 0.85;
  }
  .bildwerk-hero .big-text span { display: block; }
  .bildwerk-hero .big-text .desktop-br { display: none; }
}

.bildwerk-hero .scroll-arrow {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--white);
  z-index: 3;
  animation: bildwerk-bounce 2s ease-in-out infinite;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.bildwerk-hero .scroll-arrow .scroll-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
}
.bildwerk-hero .scroll-arrow:hover { color: #ccc; }

@keyframes bildwerk-bounce {
  0%, 100% { transform: translate(-50%, 0); }
  50%      { transform: translate(-50%, 10px); }
}
