/* Hard fix: forceer vaste 1200px canvas (zoals index) */
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  min-width:1200px;
}
body{
  min-width:1200px;
  margin:0;
  overflow-x:auto; /* liever horizontaal scrollen dan auto-zoom */
}

/* Canvas */
.wdw-canvas{
  position: relative;
  width: var(--page-width, 1200px);
  margin: 40px auto 80px;
  height: auto;  /* niet vastzetten */
  min-height: calc(100vh - var(--header-space, 120px)); /* korte schermen vullen */
  box-sizing: border-box;
  overflow: visible !important;
}

/* Anker dat de canvas-hoogte oprekt tot onder je laagste bollen
   Laagste bollen: top 850px, hoogte = 45% van 1200px (=540px)
   + extra marge (bijv. 140px) voor ademruimte onderaan
*/
.wdw-canvas::after{
  content: "";
  display: block;
  height: 0; /* we gebruiken padding voor hoogte */
  padding-top: calc(850px + 45% + 140px); /* 850 + 540 + 140 ≈ 1530px */
  pointer-events: none; /* puur layout, niet klikbaar */
}






/* Basis vlek */
.vlek{
  position: absolute;
  width: var(--w, 50%);
  top: var(--top, auto);
  left: var(--left, auto);
  right: var(--right, auto);
  aspect-ratio: 1 / 1;
  box-sizing: border-box;
  padding: var(--pad, 6%);
  background: center / contain no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,.45);
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.18));
  z-index: var(--z, 1);
}

/* Tekst in de grote blauwe bol */
.vlek .vlek-inhoud{
  max-width: 70%;
  margin: 0 auto;
  text-align: left;
}
.vlek p{ font-size: 1.15rem; line-height: 1.35; margin: 6px 0; }
.wdw-titel{ font-size: 72px; margin: 0 0 6px; }
.wdw-sub{   font-size: 28px; margin: 0 0 16px; }
.wdw-lead{  font-size: 0.85rem; line-height: 1.35; margin: 4px 0 16px; }

/* Kleine bollen met foto + caption */
.vlek.klein{ --pad: 0; --img: 72%; overflow: hidden; }
.wdw-fig{
  width: var(--img);
  margin: 0;
  display: grid;
  gap: 10px;
  justify-items: center;
  box-sizing: border-box;
}
.wdw-fig img{
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid #fff;
  box-shadow: 0 6px 16px rgba(0,0,0,.28);
}
.wdw-fig figcaption{
  font-family: 'Amatic SC', cursive;
  font-size: 24px;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,.35);
}

/* Achtergronden */
.blauw{ background-image: url('vlek-blauw.png'); }
.rood { background-image: url('vlek-rood.png'); }
.oker { background-image: url('vlek-geel.png'); }

/* Posities */
#wdw-blauw{ --w: 80%; --pad: 6%; --top: 10px;  --left: 10%; --z: 1; }
#wdw-rood { --w: 45%; --top: 850px; --left: 8%;  --img: 45%; --z: 2; }
#wdw-oker { --w: 45%; --top: 850px; --right: 8%; --img: 45%; --z: 2; }
