/* Familiearchief Klerks — warm & editorial.
   Aards palet (crème, salie/olijf, klei), serif-koppen, systeemlettertypes (geen internet nodig). */

:root {
  /* Aards, editorial palet: crème achtergronden, salie-/olijfgroen accent, warme lijnen. */
  --ink: #2c2e26;
  --muted: #6e7061;
  --zacht-muted: #9b9c8c;
  --bg: #f1efe6;
  --surface: #fbfaf4;
  --line: #e4e1d3;
  --line-zacht: #ece9dc;
  --accent: #6f8465;
  --accent-diep: #566645;
  --accent-zacht: #e8ecdd;
  --accent-rand: #cfd6bd;
  /* Gedempte, harmoniërende secundaire accenten (aards, niet schreeuwerig) +
     hun zachte tint voor vlakjes/chips. */
  --klei: #b0824a;         --klei-zacht: #f0e6d4;
  --goud: #b0922f;         --goud-zacht: #efe8cd;
  --terracotta: #bd7357;   --terracotta-zacht: #f2e1d8;
  --teal: #5f8a82;         --teal-zacht: #dfeae6;
  --schaduw: 0 1px 2px rgba(58, 52, 30, .05), 0 10px 30px rgba(58, 52, 30, .07);
  --schaduw-hover: 0 2px 6px rgba(58, 52, 30, .07), 0 18px 40px rgba(58, 52, 30, .12);
  --radius: 16px;
  --radius-s: 10px;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-diep); }
img { max-width: 100%; }

/* ---------- Kop / navigatie ---------- */
.kop {
  position: sticky; top: 0; z-index: 10;
  background: rgba(249, 246, 238, .68);
  backdrop-filter: saturate(1.6) blur(16px);
  -webkit-backdrop-filter: saturate(1.6) blur(16px);
  border-bottom: 1px solid var(--line);
}
.kop-binnen {
  max-width: 88rem; margin: 0 auto; padding: .85rem 1.5rem;
  display: flex; align-items: center; gap: .6rem 1rem; flex-wrap: wrap;
}
.merk {
  order: 1;
  display: flex; align-items: center; gap: .55rem;
  font-family: var(--serif); font-weight: 700; letter-spacing: 0; font-size: 1.2rem; color: var(--ink);
}
.merk:hover { color: var(--ink); }
.merk .stip {
  width: 27px; height: 27px; border-radius: 9px; flex: none;
  background: linear-gradient(135deg, var(--accent), #9fb389);
  display: grid; place-items: center; color: #fff; font-size: .85rem; font-weight: 800;
}
.merk-logo { height: 54px; width: auto; flex: none; display: block; }
.kop nav { order: 3; flex-basis: 100%; justify-content: flex-start; display: flex; flex-wrap: wrap; gap: .1rem .2rem; margin-left: -.7rem; }
.kop nav a {
  color: var(--muted); font-weight: 600; font-size: .93rem;
  padding: .45rem .7rem; border-radius: 9px; display: flex; align-items: center; gap: .4rem;
}
.kop nav a:hover { color: var(--ink); background: var(--line-zacht); }
/* Taalwissel NL / EN */
.taalwissel { order: 2; margin-left: auto; display: inline-flex; align-items: center; gap: 1px;
  border: 1px solid var(--accent-rand); border-radius: 999px; overflow: hidden; background: var(--surface); }
.taalwissel a { color: var(--muted); font-weight: 700; font-size: .78rem; letter-spacing: .03em;
  padding: .28rem .55rem; text-decoration: none; }
.taalwissel a:hover { background: var(--line-zacht); color: var(--ink); }
.taalwissel a.actief { background: var(--accent); color: #fff; }
.ico { width: 1.05em; height: 1.05em; stroke: currentColor; fill: none; stroke-width: 1.9;
       stroke-linecap: round; stroke-linejoin: round; flex: none; }
/* Echt (gevuld) hartje als PNG i.p.v. lijntekening */
.hart-png { width: 1.05em; height: 1.05em; object-fit: contain; vertical-align: -.14em; flex: none; }
h2 .hart-png { width: 1em; height: 1em; }
.hart-avatar { background: #fdeef0; border-color: #f3c7cd; }
.hart-avatar .hart-png { width: 34px; height: 34px; }

/* ---------- Layout ---------- */
main { max-width: 88rem; margin: 0 auto; padding: 2rem 1.5rem 1rem; }
.smal { max-width: 60rem; }
.terug { color: var(--muted); font-weight: 600; font-size: .9rem;
         display: inline-flex; align-items: center; gap: .35rem; margin-bottom: 1rem; }
.terug:hover { color: var(--accent); }

h1 { font-family: var(--serif); font-size: clamp(1.8rem, 1.2rem + 2.4vw, 2.7rem); line-height: 1.08;
     letter-spacing: -.01em; font-weight: 700; margin: 0 0 .3rem; }
h2 { font-family: var(--serif); font-size: 1.3rem; font-weight: 700; letter-spacing: 0;
     margin: 2rem 0 .8rem; display: flex; align-items: center; gap: .5rem; }
h2 .ico { color: var(--accent); }
/* Sectiekoppen elk een eigen aardse tint, voor rustige variatie op binnenpagina's.
   (stamlijn/foto/register blijven salie; onder .tak volgen ze de tak-kleur.) */
h2 .ico-kalender { color: var(--goud); }
h2 .ico-gezin, h2 .ico-personen { color: var(--teal); }
h2 .ico-boek { color: var(--terracotta); }
h2 .ico-document, h2 .ico-scan, h2 .ico-boom { color: var(--klei); }
h2 .ico-kaart { color: var(--teal); }

/* ---------- Levensverhaal + horizontale levenslijn ---------- */
.levensverhaal { font-size: 1.1rem; line-height: 1.7; color: var(--ink); max-width: 46rem;
  margin: 1.3rem 0 .2rem; }
.levenslijn-wrap { position: relative; }
.levenslijn { display: flex; overflow-x: auto; padding: 1.5rem 0 .6rem;
  scrollbar-width: none; -ms-overflow-style: none; }
.levenslijn::-webkit-scrollbar { display: none; }
.levenslijn.scrollbaar { cursor: grab; }
.levenslijn.sleept { cursor: grabbing; user-select: none; }
/* Pijltjes aan de uiteinden van de horizontale tijdlijn. */
.levenslijn-pijl { position: absolute; top: 2.2rem; transform: translateY(-50%);
  z-index: 3; width: 2.4rem; height: 2.4rem; border-radius: 50%;
  border: 1px solid var(--accent-rand); background: rgba(251,250,244,.82);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  color: var(--accent-diep); font: 700 1.5rem/1 var(--serif); cursor: pointer;
  display: flex; align-items: center; justify-content: center; padding-bottom: .2rem;
  box-shadow: 0 2px 10px rgba(44,46,38,.12); transition: background .15s, box-shadow .15s; }
.levenslijn-pijl:hover { background: var(--surface); box-shadow: 0 3px 14px rgba(44,46,38,.18); }
.levenslijn-pijl.links { left: -.4rem; }
.levenslijn-pijl.rechts { right: -.4rem; }
.levenslijn-pijl[hidden] { display: none; }
.moment { flex: 1 0 145px; min-width: 145px; position: relative; padding: 1.8rem .55rem 0; text-align: center; }
.moment::before { content: ""; position: absolute; top: 10px; left: 0; right: 0; height: 2px; background: var(--accent-rand); }
.moment::after { content: ""; position: absolute; top: 3px; left: 50%; transform: translateX(-50%);
  width: 15px; height: 15px; border-radius: 50%; background: var(--accent);
  border: 3px solid var(--surface); box-shadow: 0 0 0 2px var(--accent-rand); }
.moment:first-child::before { left: 50%; }
.moment:last-child::before { right: 50%; }
.moment-jaar { display: block; font-weight: 800; font-variant-numeric: tabular-nums; letter-spacing: -.01em; }
.moment-wat { display: block; font-weight: 600; font-size: .92rem; }
.moment-detail { display: block; color: var(--muted); font-size: .82rem; line-height: 1.35; margin-top: .12rem; }
.moment.huwelijk::after   { background: var(--terracotta); box-shadow: 0 0 0 2px var(--terracotta-zacht); }
.moment.kind::after       { background: var(--teal);       box-shadow: 0 0 0 2px var(--teal-zacht); }
.moment.mijlpaal::after   { background: var(--goud);       box-shadow: 0 0 0 2px var(--goud-zacht); }
.moment.overlijden::after { background: var(--ink);        box-shadow: 0 0 0 2px var(--line); }
@media (max-width: 700px) {
  .levenslijn { flex-direction: column; overflow-x: visible; padding: .6rem 0; }
  .moment { flex: none; min-width: 0; text-align: left; padding: .15rem 0 1.1rem 2rem; }
  .moment::before { top: 0; bottom: 0; left: 9px; right: auto; width: 2px; height: auto; }
  .moment:first-child::before { top: 11px; left: 9px; }
  .moment:last-child::before { left: 9px; right: auto; bottom: auto; height: 12px; }
  .moment::after { top: 4px; left: 10px; transform: translateX(-50%); }
  .moment-jaar { display: inline-block; margin-right: .5rem; }
  .moment-wat { display: inline; }
  .levenslijn-pijl { display: none; }
  .levenslijn.scrollbaar { cursor: default; }
}
/* ---------- Verhalende geschiedenis-pagina ---------- */
.geschiedenis { max-width: 44rem; margin: 0 auto; }
.geschiedenis .wapen { display: block; margin: .5rem auto 1.6rem; max-width: 230px; height: auto; }
.geschiedenis h1 { text-align: center; }
.geschiedenis h2 { margin-top: 2.2rem; }
.geschiedenis p { font-size: 1.1rem; line-height: 1.85; color: var(--ink); }
.geschiedenis .inleiding, .geschiedenis .slot { font-style: italic; color: var(--muted);
  font-size: 1.15rem; line-height: 1.7; text-align: center; max-width: 38rem; margin: 1.4rem auto; }
.geschiedenis .slot { margin-top: 2.2rem; padding-top: 1.4rem; border-top: 1px solid var(--accent-rand); }
.geschiedenis .verhaalfoto { margin: 1.9rem 0; }
.geschiedenis .verhaalfoto a { display: block; position: relative; }
.geschiedenis .verhaalfoto .kleur-knop::after { content: "z/w"; }
.geschiedenis .verhaalfoto .kleur-knop.actief::after { content: "kleur"; }
html[lang="en"] .geschiedenis .verhaalfoto .kleur-knop::after { content: "b/w"; }
html[lang="en"] .geschiedenis .verhaalfoto .kleur-knop.actief::after { content: "color"; }
.geschiedenis .verhaalfoto img { display: block; width: 100%; height: auto; cursor: zoom-in;
  border-radius: 10px; box-shadow: 0 3px 16px rgba(44,46,38,.16); }
.geschiedenis .verhaalfoto figcaption { margin-top: .55rem; font-size: .92rem; font-style: italic;
  color: var(--muted); text-align: center; }
.geschiedenis .verhaalfoto figcaption .cred { font-style: normal; color: var(--zacht-muted); }
.geschiedenis .verhaalfoto.duo { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }
.geschiedenis .verhaalfoto.duo a { flex: 1 1 45%; }
.geschiedenis .verhaalfoto.duo figcaption { flex-basis: 100%; margin-top: .35rem; }
@media (max-width: 480px) { .geschiedenis .verhaalfoto.duo a { flex-basis: 100%; } }
/* Compacte verhaalfoto: halve breedte, gecentreerd (voor hoge/lange foto's). */
.geschiedenis .verhaalfoto.klein a { max-width: 50%; margin-inline: auto; }
.geschiedenis .verhaalfoto.klein figcaption { text-align: center; }
@media (max-width: 560px) { .geschiedenis .verhaalfoto.klein a { max-width: 75%; } }
/* Duo met even hoge foto's: de breedte schaalt mee met de verhouding, zodat de
   hoogte gelijk wordt (zonder bijsnijden). flex-grow per foto = breedte/hoogte. */
.geschiedenis .verhaalfoto.duo.gelijk { align-items: flex-start; }
.geschiedenis .verhaalfoto.duo.gelijk a { flex-basis: 0; }
/* Vast kader (verhouding per foto via inline aspect-ratio) zodat de z/w- en
   kleurversie exact dezelfde ruimte innemen en het wisselen niet verspringt. */
.geschiedenis .verhaalfoto.duo.gelijk img { object-fit: cover; height: auto; }
@media (max-width: 480px) { .geschiedenis .verhaalfoto.duo.gelijk a { flex-basis: 100%; } }

.dun { color: var(--muted); font-weight: 400; }
.ondertitel { color: var(--muted); font-size: 1.05rem; margin: 0 0 1.5rem; }

/* Brede aankeiler voor de geschiedenis (homepage, onder de hero) */
.geschiedenis-teaser { display: flex; align-items: center; gap: 1.6rem;
  margin: 1.8rem 0; padding: 1.5rem 1.8rem; border-radius: var(--radius);
  background: var(--accent-zacht); border: 1px solid var(--accent-rand); }
.teaser-wapen { flex: 0 0 auto; order: 2; width: 100px; height: auto; }
.teaser-tekst { flex: 1 1 auto; min-width: 0; }
.teaser-kop { display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--serif); font-weight: 700; font-size: 1.35rem; color: var(--ink); }
.teaser-kop svg { width: 1.15em; height: 1.15em; flex: none; }
.teaser-tekst p { margin: .55rem 0 1rem; color: var(--ink); font-size: 1.02rem; line-height: 1.7; }
.knop-lees { display: inline-flex; align-items: center; gap: .45rem; font-weight: 700;
  font-size: .95rem; color: #fff; background: var(--accent); border: 1px solid var(--accent-diep);
  border-radius: 999px; padding: .5rem 1.1rem; text-decoration: none; }
.knop-lees:hover { background: var(--accent-diep); color: #fff; }
@media (max-width: 640px) {
  .geschiedenis-teaser { flex-direction: column; text-align: center; }
  .teaser-kop { justify-content: center; }
  .teaser-wapen { order: -1; }
}

/* ---------- Hero (voorpagina) ---------- */
.hero {
  position: relative; overflow: hidden;
  /* Zachte, meerkleurige "sunset"-gradient in aardse tinten. */
  background:
    radial-gradient(90% 120% at 10% -15%, rgba(176, 146, 47, .30), transparent 55%),
    radial-gradient(80% 105% at 96% -5%, rgba(189, 115, 87, .26), transparent 55%),
    radial-gradient(120% 130% at 72% 125%, rgba(111, 132, 101, .30), transparent 60%),
    radial-gradient(90% 120% at 30% 120%, rgba(95, 138, 130, .20), transparent 55%),
    linear-gradient(180deg, #f4f0e5, var(--surface));
  border: 1px solid var(--line); border-radius: 24px;
  padding: 2.6rem 2rem; margin-bottom: 1.6rem; box-shadow: var(--schaduw);
}
.hero .plaatsen { display: inline-flex; gap: .5rem; align-items: center;
  color: var(--accent-diep); background: #fff; border: 1px solid var(--accent-rand);
  padding: .3rem .7rem; border-radius: 999px; font-size: .82rem; font-weight: 600; margin-bottom: 1rem; }
.hero p.lead { font-size: 1.1rem; color: #5c5e4f; max-width: 40rem; margin: .4rem 0 0; }

/* Hero met portret van de samensteller ernaast.
   De kaart (.hero) blijft volle breedte; de inhoud (.hero-intro) is begrensd en
   gecentreerd, met een tussenruimte die met het venster meebeweegt. Zo blijft de
   verhouding tekst/foto op elke schermbreedte kloppen, zonder los te "zweven". */
.hero-intro { display: flex; align-items: center; justify-content: center;
  gap: clamp(1.5rem, 3vw, 3rem); flex-wrap: wrap; max-width: 62rem; margin: 0 auto;
  /* "Liquid glass": frosted panel dat op de gradient drijft. */
  background: rgba(251, 250, 244, .5); backdrop-filter: blur(16px) saturate(1.25);
  -webkit-backdrop-filter: blur(16px) saturate(1.25);
  border: 1px solid rgba(255, 255, 255, .6); border-radius: 20px;
  padding: clamp(1.4rem, 3vw, 2.2rem); box-shadow: 0 10px 34px rgba(58, 52, 30, .10),
    inset 0 1px 0 rgba(255, 255, 255, .5); }
.hero-intro .hero-tekst { flex: 0 1 40rem; min-width: 0; max-width: 40rem; }
.hero-intro p.lead { max-width: 42rem; }
/* Expressiever hero-kopje: groter, met warme kleurverloop-vulling. */
.hero-intro h1 {
  font-size: clamp(2.1rem, 1.1rem + 3.6vw, 3.5rem); line-height: 1.02; letter-spacing: -.015em;
  background: linear-gradient(95deg, var(--accent-diep) 8%, var(--klei) 58%, var(--terracotta));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.oprichter { margin: 0; flex: 0 0 auto; text-align: center; }
.oprichter-lijst {
  width: 190px; height: 232px; border-radius: 22px; overflow: hidden; background: var(--surface);
  border: 6px solid #fff; box-shadow: 0 14px 34px rgba(58, 52, 30, .18), 0 0 0 1px var(--line);
  transform: rotate(-1.4deg); transition: transform .2s ease;
}
.oprichter-lijst:hover { transform: rotate(0); }
.oprichter-lijst a { display: block; width: 100%; height: 100%; }
.oprichter-lijst img { width: 100%; height: 100%; object-fit: cover; display: block; }
.oprichter figcaption a { color: inherit; text-decoration: none; }
.oprichter figcaption a:hover { text-decoration: underline; }
h2 a.titel-link { color: inherit; text-decoration: none; }
h2 a.titel-link:hover { text-decoration: underline; text-decoration-color: var(--accent); text-underline-offset: 3px; }
.oprichter figcaption {
  margin-top: .9rem; font-weight: 700; color: var(--ink); font-size: .95rem;
  display: flex; flex-direction: column; line-height: 1.35;
}
.oprichter figcaption span { font-weight: 400; color: var(--muted); font-size: .85rem; }
@media (max-width: 620px) {
  .hero-intro { justify-content: center; text-align: center; }
  .hero-intro .plaatsen { margin-left: auto; margin-right: auto; }
  .oprichter-lijst { width: 160px; height: 196px; }
}

/* ---------- Statistiek-kaarten ---------- */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
         gap: 1rem; margin: 1.4rem 0; }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
        padding: 1.1rem 1.2rem; box-shadow: var(--schaduw); }
.stat .getal { font-size: 2rem; font-weight: 800; letter-spacing: -.03em;
               font-variant-numeric: tabular-nums; line-height: 1; }
.stat .label { color: var(--muted); font-size: .85rem; margin-top: .35rem;
               display: flex; align-items: center; gap: .4rem; }
.stat .label .ico { color: var(--accent); }

/* ---------- Keuzekaarten ---------- */
.keuze { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1rem; }
.keuze a { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
           padding: 1.2rem; box-shadow: var(--schaduw); color: var(--ink);
           display: flex; gap: .9rem; align-items: flex-start;
           transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease; }
.keuze a:hover { transform: translateY(-3px); box-shadow: var(--schaduw-hover); border-color: var(--accent-rand); }
.keuze .vak { width: 42px; height: 42px; border-radius: 12px; flex: none;
              background: var(--accent-zacht); color: var(--accent); display: grid; place-items: center; }
/* Elk blokje een eigen gedempte accentkleur, voor rustige variatie. */
.keuze a:nth-child(5n+2) .vak { background: var(--klei-zacht); color: var(--klei); }
.keuze a:nth-child(5n+3) .vak { background: var(--goud-zacht); color: var(--goud); }
.keuze a:nth-child(5n+4) .vak { background: var(--teal-zacht); color: var(--teal); }
.keuze a:nth-child(5n+5) .vak { background: var(--terracotta-zacht); color: var(--terracotta); }
.keuze .vak .ico { width: 20px; height: 20px; }
.keuze .titel { font-weight: 700; }
.keuze .uitleg { color: var(--muted); font-size: .9rem; }

/* ---------- Fotogalerij (startpagina) ---------- */
.galerij { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: .6rem; }
.galerij-tegel { position: relative; display: block; aspect-ratio: 1 / 1; border-radius: var(--radius-s);
  overflow: hidden; border: 1px solid var(--line); box-shadow: var(--schaduw);
  transition: transform .12s ease, box-shadow .12s ease; }
.galerij-tegel:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); }
.galerij-tegel img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Documenttegels: lichte papierachtergrond + bovenkant van de akte in beeld. */
.galerij-tegel.doc { background: #fbfaf6; }
.galerij-tegel.doc img { object-position: top center; }
.galerij-bij { position: absolute; left: 0; right: 0; bottom: 0; padding: .5rem .5rem .35rem;
  font-size: .72rem; color: #fff; line-height: 1.2;
  background: linear-gradient(transparent, rgba(10, 14, 20, .82));
  opacity: 0; transition: opacity .15s ease; }
.galerij-tegel:hover .galerij-bij { opacity: 1; }

/* ---------- Overzicht (foto's / documenten): tabs, tijdlijn, lijst ---------- */
.overzicht-tabs { display: flex; gap: .5rem; margin: .3rem 0 1.3rem; }
.ov-tab { display: inline-flex; align-items: center; gap: .4rem; font-family: inherit;
  font-weight: 600; font-size: .9rem; color: var(--muted); background: var(--surface);
  border: 1px solid var(--line); border-radius: 10px; padding: .45rem .8rem; cursor: pointer; }
.ov-tab:hover { color: var(--ink); }
.ov-tab.actief { background: var(--accent); color: #fff; border-color: var(--accent); }
.ov-tab .ico { width: 1em; height: 1em; }

.ov-view.tijdlijn { position: relative; padding-left: 1.6rem; border-left: 2px solid var(--line);
  margin-left: .4rem; }
.tl-jaar { position: relative; margin-bottom: 1.6rem; }
.tl-label { font-weight: 800; letter-spacing: -.01em; color: var(--accent-diep);
  font-size: 1.1rem; margin-bottom: .6rem; }
.tl-label::before { content: ""; position: absolute; left: calc(-1.6rem - 7px); top: .35em;
  width: 12px; height: 12px; border-radius: 50%; background: var(--accent);
  border: 2px solid #fff; box-shadow: 0 0 0 2px var(--accent-rand); }
.tl-grid { grid-template-columns: repeat(auto-fill, minmax(112px, 1fr)); }
/* Document-tijdlijn: kleine thumbnails, met de transcriptie-knop eronder.
   Bij het openen wordt het vakje breder, zodat de tekst goed leesbaar is. */
.tl-grid-doc { display: flex; flex-wrap: wrap; gap: 1rem; }
.tl-doc { display: flex; flex-direction: column; gap: .5rem; width: 170px; }
.tl-doc .galerij-tegel { width: 170px; }
.tl-doc-titel { margin: 0; font-size: .84rem; font-weight: 600; line-height: 1.3; color: var(--ink); }
.tl-doc:has(.tl-transcriptie[open]) { width: min(680px, 100%); }
.tl-transcriptie summary { font-size: .82rem; font-weight: 600; }

.ov-lijst { display: flex; flex-direction: column; gap: .6rem; }
.ov-rij { display: flex; gap: 1rem; align-items: center; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--schaduw);
  padding: .6rem .8rem; }
.ov-thumb { flex: none; display: block; width: 72px; height: 72px; border-radius: var(--radius-s);
  overflow: hidden; border: 1px solid var(--line); }
.ov-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; cursor: zoom-in; }
.ov-titel { font-weight: 600; margin: 0 0 .15rem; }
.ov-meta { color: var(--muted); font-size: .88rem; margin: 0; }

/* ---------- Chips / badges ---------- */
.chip { display: inline-flex; align-items: center; gap: .35rem; font-size: .78rem; font-weight: 600;
        background: var(--line-zacht); color: var(--muted); padding: .2rem .6rem; border-radius: 999px;
        font-variant-numeric: tabular-nums; white-space: nowrap; }
.chip.accent { background: var(--accent-zacht); color: var(--accent-diep); }
.chip.stamlijn { background: var(--accent-zacht); color: var(--accent-diep); }

/* ---------- Persoonskop ---------- */
.persoon-kop { display: flex; gap: 1.2rem; align-items: center; flex-wrap: wrap; }
.avatar { width: 64px; height: 64px; border-radius: 18px; flex: none; display: grid; place-items: center;
          background: var(--accent-zacht); color: var(--accent-diep); font-weight: 800; font-size: 1.5rem;
          letter-spacing: -.02em; border: 1px solid var(--accent-rand); }
.persoon-kop .rij { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; margin-top: .4rem; }
.avatar.foto { padding: 0; overflow: hidden; background: var(--line-zacht); }
.avatar.foto img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Pasfoto in de kop van de persoonspagina groter tonen. */
.persoon-kop .avatar.foto { width: 108px; height: 108px; border-radius: 26px; }
@media (max-width: 700px) { .persoon-kop .avatar.foto { width: 88px; height: 88px; border-radius: 22px; } }

/* Fotogalerij op de persoonspagina */
.fotos { display: flex; flex-wrap: wrap; gap: 1rem; }
.fotos figure.foto { margin: 0; width: 160px; }
.fotos figure.foto a { display: block; border-radius: var(--radius-s); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--schaduw); line-height: 0;
  transition: transform .12s ease, box-shadow .12s ease; }
.fotos figure.foto a:hover { transform: scale(1.02); box-shadow: var(--schaduw-hover); }
.fotos figure.foto img { width: 100%; height: 200px; object-fit: cover; display: block; cursor: zoom-in; }
.fotos figcaption { color: var(--muted); font-size: .82rem; margin-top: .45rem; }
/* Foto met een toelichting: iets breder vakje + notitie eronder. */
.fotos figure.heeft-toelichting { width: 340px; }
.foto-toelichting { display: flex; gap: .4rem; margin: .45rem 0 0; font-size: .82rem;
  line-height: 1.45; color: var(--ink); background: var(--accent-zacht);
  border: 1px solid var(--accent-rand); border-radius: var(--radius-s); padding: .5rem .6rem; }
.foto-toelichting .ico { color: var(--accent); flex: none; margin-top: .15rem; }

/* ---------- Kaarten & feiten ---------- */
.kaart { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
         padding: 1.1rem 1.3rem; box-shadow: var(--schaduw); margin: .8rem 0; }
dl.feiten { display: grid; grid-template-columns: max-content 1fr; gap: .55rem 1.4rem; margin: 0; }
dl.feiten dt { color: var(--muted); font-size: .92rem; }
dl.feiten dd { margin: 0; }
.afgeschermd { background: var(--accent-zacht); border: 1px solid var(--accent-rand);
               padding: 1.1rem 1.3rem; border-radius: var(--radius); color: #5c5e4f;
               display: flex; gap: .8rem; align-items: flex-start; }
.afgeschermd .ico { color: var(--accent); width: 22px; height: 22px; margin-top: .1rem; }

/* ---------- Tijdlijn (levensloop & stamlijn) ---------- */
.tijdlijn { list-style: none; margin: .4rem 0; padding: 0 0 0 1.4rem;
            border-left: 2px solid var(--line); }
.tijdlijn li { position: relative; padding: .15rem 0 1rem; }
.tijdlijn li:last-child { padding-bottom: 0; }
.tijdlijn li::before { content: ""; position: absolute; left: -1.4rem; top: .5rem;
  transform: translateX(-50%); width: 11px; height: 11px; border-radius: 50%;
  background: #fff; border: 2.5px solid var(--accent); }
.tijdlijn .wat { font-weight: 600; }
.tijdlijn .detail { color: var(--muted); }

/* Stamlijn: nodes als kaarten op een lijn */
.stamlijn { list-style: none; margin: 1rem 0; padding: 0 0 0 1.6rem;
            border-left: 2px solid var(--line); }
.stamlijn li { position: relative; margin-bottom: 1rem; }
.stamlijn li::before { content: ""; position: absolute; left: -1.6rem; top: 1.15rem;
  transform: translateX(-50%); width: 13px; height: 13px; border-radius: 50%;
  background: var(--accent); border: 3px solid #fff; box-shadow: 0 0 0 2px var(--accent-rand); }
.stamlijn .node { display: flex; align-items: center; gap: .9rem; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--radius); padding: .8rem 1.1rem;
  box-shadow: var(--schaduw); color: var(--ink);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease; }
.stamlijn .node:hover { transform: translateX(3px); box-shadow: var(--schaduw-hover); border-color: var(--accent-rand); }
.stamlijn .naam { font-weight: 700; }
.stamlijn a.stamnaam { color: var(--ink); text-decoration: none; }
.stamlijn a.stamnaam:hover { color: var(--accent-diep); text-decoration: underline; }
.stamlijn .jaren { color: var(--muted); font-variant-numeric: tabular-nums; }
.stamlijn .gen { margin-left: auto; }

/* Uitklapbare node (partner + kinderen) */
.stamnode > summary { list-style: none; cursor: pointer; }
.stamnode > summary::-webkit-details-marker { display: none; }
.stamnode > summary .chev { margin-left: .4rem; color: var(--zacht-muted); transition: transform .18s ease; }
.stamnode[open] > summary .chev { transform: rotate(180deg); }
.stamnode[open] > summary .node { border-color: var(--accent-rand); }
.uitklap { margin: .5rem 0 0 .6rem; padding: .9rem 1.1rem; background: var(--line-zacht);
  border: 1px solid var(--line); border-radius: var(--radius-s); }
.uitklap .gezin-blok + .gezin-blok { margin-top: 1rem; border-top: 1px solid var(--line); padding-top: 1rem; }
.uitklap .partner { font-weight: 600; margin: 0 0 .2rem; }
.uitklap .kop-klein { font-weight: 600; font-size: .85rem; color: var(--muted); margin: .6rem 0 .2rem; }
.uitklap .paginalink { margin: .7rem 0 0; }
.zet-voort { color: var(--accent-diep); font-size: .78rem; font-weight: 600; }
/* Stamlijnkind: alleen een sterretje + vette naam (geen label) */
.stamkind { font-weight: 700; }
.stamkind .jaren { font-weight: 400; }
.ster-merk { color: var(--accent-diep); margin-right: .2rem; }
.ster-merk .ico { fill: currentColor; stroke: none; vertical-align: -.12em; }

/* Mini-avatar (portret of initialen) bij partner en kinderen in de uitklap */
.avatar.mini { flex: none; }
.met-avatar { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; }
.met-avatar:hover span { text-decoration: underline; }
.uitklap .partner { display: flex; align-items: center; gap: .4rem; }
.uitklap .kinderen li { align-items: center; }

/* Twee stamlijnen naast elkaar (desktop), elk met eigen identiteitskleur.
   Door de accent-variabelen per tak te herdefiniëren kleuren avatars, stippen,
   de lijn, chips en links automatisch mee. */
.stamlijnen-naast { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem 2.5rem; align-items: start; }
.tak > h2 { margin-top: .3rem; color: var(--accent-diep);
  border-bottom-color: var(--accent-rand); }
.tak .stamlijn { border-left-color: var(--accent-rand); }
.tak-klerks {
  --accent: #6f8465; --accent-diep: #566645; --accent-zacht: #e8ecdd; --accent-rand: #cfd6bd;
}
.tak-persoon {
  --accent: #b0824a; --accent-diep: #8a6234; --accent-zacht: #f2ebdd; --accent-rand: #e4d3b4;
}

/* Samenkomst: het paar naast elkaar, daaronder de gezamenlijke lijn. */
.samenkomst { max-width: 52rem; margin: 2.4rem auto 0; }

/* Kinderen (broers/zussen, zelfde generatie) naast elkaar. */
.kinderen-rij { display: grid; grid-template-columns: repeat(auto-fill, minmax(165px, 1fr)); gap: .6rem; }
.kind-kaart { display: flex; align-items: center; gap: .6rem; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--radius-s); padding: .55rem .65rem;
  box-shadow: var(--schaduw); color: var(--ink);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease; }
.kind-kaart:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); border-color: var(--accent-rand); }
.kind-tekst { min-width: 0; display: flex; flex-direction: column; }
.kind-kaart .naam { font-weight: 600; font-size: .9rem; line-height: 1.2; }
.kind-kaart .jaren { font-size: .8rem; }
.samenkomst > h2 { justify-content: center; text-align: center; border-bottom: none; color: var(--ink); }
.paar { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: .7rem; }
.paar > .tak { flex: 1 1 210px; max-width: 300px; }
.paarvak { display: block; }
.paar .node { display: flex; align-items: center; gap: .9rem; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--radius); padding: .8rem 1rem;
  box-shadow: var(--schaduw); color: var(--ink);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease; }
.paarvak:hover .node { transform: translateY(-2px); box-shadow: var(--schaduw-hover); border-color: var(--accent-rand); }
.paar .node .chip.gen { margin-left: auto; }
.paar-x { color: var(--muted); font-weight: 700; font-size: 1.2rem; text-align: center; line-height: 1.2; flex: 0 0 auto; }
.paar-x small { font-weight: 500; font-size: .8rem; }
.tak-samen {
  --accent: #8a7f63; --accent-diep: #6a6049; --accent-zacht: #efece1; --accent-rand: #ddd6c3;
  max-width: 30rem; margin: 1.2rem auto 0;
}
.samen .stamlijn { border-left: 3px solid transparent;
  border-image: linear-gradient(180deg, #6f8465, #b0824a) 1; }

/* ---------- Vergrootweergave (lightbox) ---------- */
.lightbox { position: fixed; inset: 0; z-index: 100; background: rgba(12, 16, 24, .9);
  backdrop-filter: blur(4px); display: grid; place-items: center; padding: 1.5rem;
  overflow-y: auto; }
.lightbox[hidden] { display: none; }
.lightbox figure { margin: 0; display: flex; flex-direction: column; align-items: center; gap: .8rem;
  max-width: 100%; max-height: 100%; }
/* De afbeelding past altijd volledig in beeld, ook met bijschrift + doorklik-knop
   eronder (belangrijk voor documenten op een breed, laag scherm). */
.lightbox img { max-width: 100%; max-height: min(85vh, calc(100vh - 11rem)); object-fit: contain;
  border-radius: 8px; background: #fff; box-shadow: 0 24px 70px rgba(0, 0, 0, .55); }
.lightbox figcaption { color: #e7e9ee; font-size: .92rem; text-align: center; max-width: 42rem; }
.lightbox .hint { color: var(--zacht-muted); font-size: .82rem; }
.lb-sluit { position: fixed; top: 1rem; right: 1.1rem; width: 46px; height: 46px; border-radius: 50%;
  border: none; background: rgba(255, 255, 255, .16); color: #fff; font-size: 1.7rem; line-height: 1;
  cursor: pointer; display: grid; place-items: center; }
.lb-sluit:hover { background: rgba(255, 255, 255, .3); }
figure.scan img { cursor: zoom-in; }
.lb-ai { align-self: center; margin-top: .3rem; font-family: inherit; font-weight: 600;
  font-size: .85rem; color: #fff; background: rgba(255, 255, 255, .16);
  border: 1px solid rgba(255, 255, 255, .32); border-radius: 999px; padding: .35rem .9rem; cursor: pointer; }
.lb-ai:hover { background: rgba(255, 255, 255, .3); }
.lb-link { align-self: center; margin-top: .5rem; font-weight: 700; font-size: .9rem;
  color: #fff; background: var(--accent); border: 1px solid #fff;
  border-radius: 999px; padding: .4rem 1rem; text-decoration: none; }
.lb-link:hover { background: var(--accent-diep); color: #fff; }
/* Bladeren door meerpagina-documenten in de vergroting */
.lb-nav { position: fixed; top: 50%; transform: translateY(-50%); z-index: 101;
  width: 54px; height: 54px; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255, 255, 255, .16); color: #fff; font-size: 2rem; line-height: 1;
  display: grid; place-items: center; }
.lb-nav:hover { background: rgba(255, 255, 255, .32); }
.lb-nav:disabled { opacity: .25; cursor: default; }
.lb-prev { left: 1rem; }
.lb-next { right: 1rem; }
.lb-pag { align-self: center; margin-top: .1rem; color: #e7e9ee; font-size: .82rem;
  font-variant-numeric: tabular-nums; letter-spacing: .05em; }
@media (max-width: 560px) { .lb-nav { width: 44px; height: 44px; font-size: 1.6rem; }
  .lb-prev { left: .3rem; } .lb-next { right: .3rem; } }

/* Documentviewer: transcriptiepaneel naast de ingezoomde pagina */
.lb-inhoud { display: flex; align-items: flex-start; justify-content: center;
  gap: 1.2rem; max-width: 100%; max-height: 100%; }
.lb-beeld { flex: 0 1 auto; min-width: 0; }
.lb-tr { flex: 0 1 30rem; align-self: stretch; overflow-y: auto;
  max-height: min(85vh, calc(100vh - 6rem));
  background: rgba(255, 255, 255, .07); border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 10px; padding: 1rem 1.1rem; color: #eef0f4; }
.lb-tr[hidden] { display: none; }
.lb-tr-kop { display: flex; align-items: center; justify-content: space-between;
  gap: .8rem; margin-bottom: .55rem; }
.lb-tr-titel { font-weight: 700; font-size: .72rem; text-transform: uppercase;
  letter-spacing: .09em; color: var(--zacht-muted); }
.lb-tr-paginatitel { font-weight: 700; font-size: 1.02rem; line-height: 1.3;
  color: #fff; margin: .1rem 0 .7rem; padding-bottom: .55rem;
  border-bottom: 1px solid rgba(255, 255, 255, .18); }
.lb-tr-paginatitel[hidden] { display: none; }
.lb-tr-tekst { white-space: pre-wrap; font-size: .9rem; line-height: 1.6; }
@media (max-width: 820px) {
  .lb-inhoud { flex-direction: column; align-items: center; gap: .7rem; }
  .lb-tr { flex: none; width: 100%; max-width: 46rem; max-height: 42vh; }
  .lightbox:has(.lb-tr:not([hidden])) img { max-height: 45vh; }
}

/* "AI"-knopje: wissel op de foto tussen origineel en AI-verbeterde versie */
.ai-knop { position: absolute; top: .3rem; right: .3rem; z-index: 3; cursor: pointer;
  background: rgba(20, 24, 31, .78); color: #fff; font-family: inherit; font-size: .62rem;
  font-weight: 700; letter-spacing: .04em; padding: .12rem .38rem; border-radius: 5px;
  border: 1px solid transparent; }
.ai-knop:hover { background: rgba(20, 24, 31, .95); }
.ai-knop.actief { background: var(--accent); border-color: #fff; }
.fotos figure.foto a, .ov-thumb { position: relative; }
.ai-tag { font-size: .72rem; font-weight: 600; color: var(--accent-diep);
  background: var(--accent-zacht); padding: .05rem .45rem; border-radius: 999px; margin-left: .35rem; }

/* ---------- Lijsten ---------- */
ul.lijst { list-style: none; padding: 0; margin: .3rem 0; }
ul.lijst li { padding: .28rem 0; display: flex; align-items: baseline; gap: .5rem; }
ul.lijst .nr { color: var(--zacht-muted); font-variant-numeric: tabular-nums; min-width: 1.4rem; }
.jaren { color: var(--muted); font-size: .92rem; font-variant-numeric: tabular-nums; }
.kinderen li::marker { content: ""; }

/* ---------- Scan / bron ---------- */
figure.scan { margin: .4rem 0 0; }
figure.scan a { display: inline-block; border-radius: var(--radius-s); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--schaduw); line-height: 0;
  transition: transform .12s ease, box-shadow .12s ease; }
figure.scan a:hover { transform: scale(1.01); box-shadow: var(--schaduw-hover); }
figure.scan img { width: 240px; display: block; }

/* Documenten */
.document .doc-rij { display: flex; gap: 1rem; align-items: flex-start; flex-wrap: wrap; }
.doc-thumb { margin: 0; flex: none; }
.doc-thumb a { display: block; border-radius: var(--radius-s); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--schaduw); line-height: 0; }
.doc-thumb img { width: 130px; height: 170px; object-fit: cover; display: block; cursor: zoom-in; }
.doc-info { flex: 1 1 260px; min-width: 220px; }
.doc-download { display: inline-flex; align-items: center; gap: .3rem; font-size: .85rem;
  font-weight: 600; color: var(--accent); text-decoration: none; padding: .28rem .6rem;
  border: 1px solid var(--accent-rand); border-radius: 999px; background: var(--surface); }
.doc-download:hover { background: var(--line-zacht); }
.tl-download { margin-top: .35rem; font-size: .8rem; padding: .2rem .5rem;
  align-self: flex-start; white-space: nowrap; }
/* Meerpagina-documenten: badge op de eerste pagina + strook met de overige pagina's */
.doc-thumb a, .galerij-tegel.doc { position: relative; }
.pag-badge { position: absolute; top: .3rem; right: .3rem; z-index: 2;
  background: rgba(20, 24, 31, .82); color: #fff; font-size: .66rem; font-weight: 700;
  letter-spacing: .03em; padding: .1rem .34rem; border-radius: 5px; line-height: 1.3; }
.doc-paginas { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: .8rem; }
.doc-paginas .doc-pag { position: relative; display: block; width: 66px; line-height: 0;
  border: 1px solid var(--line); border-radius: var(--radius-s); overflow: hidden;
  box-shadow: var(--schaduw); }
.doc-paginas .doc-pag img { width: 100%; height: 86px; object-fit: cover;
  object-position: top center; display: block; cursor: zoom-in; }
.doc-paginas .pag-nr { position: absolute; bottom: 0; right: 0; z-index: 2;
  background: rgba(20, 24, 31, .82); color: #fff; font-size: .62rem; font-weight: 700;
  padding: .05rem .3rem; border-top-left-radius: 5px; }
.transcriptie summary { cursor: pointer; display: inline-flex; align-items: center; gap: .5rem;
  width: fit-content; list-style: none; font-weight: 700; font-size: .88rem; color: #fff;
  background: var(--terracotta); border-radius: 999px; padding: .42rem .95rem;
  box-shadow: 0 2px 8px rgba(189, 115, 87, .30); transition: background .15s, box-shadow .15s; }
.transcriptie summary::-webkit-details-marker { display: none; }
.transcriptie summary::after { content: "\25B8"; font-size: .72em; transition: transform .18s ease; }
.transcriptie[open] summary::after { transform: rotate(90deg); }
.transcriptie summary:hover { background: #a5614a; box-shadow: 0 3px 12px rgba(189, 115, 87, .42); }
.transcriptie-tekst { white-space: pre-wrap; margin-top: .5rem; padding: .8rem 1rem;
  background: var(--line-zacht); border: 1px solid var(--line); border-radius: var(--radius-s);
  font-size: .9rem; line-height: 1.5; }
/* Taal-schakelaar boven de transcriptie: groen segmented-control, duidelijk
   onderscheiden van de terracotta "Transcriptie tonen"-knop erboven. */
.transcriptie-switch { display: inline-flex; gap: 3px; margin: .7rem 0 .35rem; padding: 3px;
  background: var(--accent-zacht); border: 1px solid var(--accent-rand); border-radius: 9px; }
.transcriptie-switch .ts-knop { border: 0; background: transparent; cursor: pointer;
  font-family: inherit; font-size: .82rem; font-weight: 700; color: var(--accent-diep);
  padding: .32rem .95rem; border-radius: 7px; transition: background .12s, color .12s; }
.transcriptie-switch .ts-knop:hover { background: #fff; }
.transcriptie-switch .ts-knop.actief { background: var(--accent); color: #fff;
  box-shadow: 0 1px 3px rgba(44, 46, 38, .18); }
figure.scan figcaption { color: var(--muted); font-size: .85rem; margin-top: .5rem; }

/* ---------- Register ---------- */
.register-letter { position: sticky; top: 3.6rem; background: var(--bg); z-index: 2;
  color: var(--accent); font-weight: 800; font-size: 1rem; letter-spacing: .02em;
  padding: .5rem 0 .3rem; border-bottom: 1px solid var(--line); margin-top: 1.2rem; }
.kolommen { columns: 2; column-gap: 2.5rem; margin-top: .5rem; }
.kolommen li { break-inside: avoid; }

/* ---------- Zoeken ---------- */
.zoekbox { position: relative; margin: 1rem 0; }
.zoekbox .ico { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%);
  color: var(--zacht-muted); width: 20px; height: 20px; }
#zoekveld { width: 100%; font-size: 1.05rem; font-family: inherit; color: var(--ink);
  padding: .85rem 1rem .85rem 2.8rem; border: 1px solid var(--line); border-radius: 14px;
  background: var(--surface); box-shadow: var(--schaduw); }
#zoekveld:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-zacht); }
#zoekresultaten li { padding: .1rem 0; }
#zoekresultaten a { display: flex; align-items: baseline; gap: .5rem; padding: .55rem .8rem;
  border-radius: 10px; color: var(--ink); width: 100%; }
#zoekresultaten a:hover { background: var(--accent-zacht); }
.tel { color: var(--muted); font-size: .9rem; }

/* ---------- Kaart & tijdlijn ---------- */
#kaart { position: relative; z-index: 0; height: 68vh; min-height: 420px;
  border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--schaduw);
  background: var(--line-zacht); }
.kaart-balk { display: flex; align-items: center; gap: 1rem; margin: 1rem 0 .6rem; }
.kaart-balk input[type="range"] { flex: 1; accent-color: var(--accent); height: 6px; }
.jaar-label { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em;
  font-variant-numeric: tabular-nums; min-width: 3.6rem; text-align: right; }
.speelknop { display: inline-flex; align-items: center; gap: .4rem; font-family: inherit;
  font-weight: 600; font-size: .95rem; color: #fff; background: var(--accent);
  border: none; border-radius: 10px; padding: .55rem .9rem; cursor: pointer; white-space: nowrap; }
.speelknop:hover { background: var(--accent-diep); }
.speelknop .pauze { display: none; }
.speelknop.speelt .play { display: none; }
.speelknop.speelt .pauze { display: inline-flex; align-items: center; gap: .4rem; }
.kaart-opties { display: flex; flex-direction: column; gap: .5rem; align-items: flex-start;
  margin-bottom: .6rem; color: var(--muted); font-size: .9rem; }
.soort-legenda { display: flex; flex-wrap: wrap; gap: .35rem 1rem; align-items: center; }
.soort-legenda .schakel.soort { font-size: .9rem; }
.soort-legenda .stip { width: 12px; height: 12px; border-radius: 50%; display: inline-block;
  border: 1px solid #fff; box-shadow: 0 0 0 1px var(--line); }
.tak-legenda { display: flex; flex-wrap: wrap; gap: .35rem 1rem; align-items: center; }
.tak-legenda .tak-item { display: inline-flex; align-items: center; gap: .3rem; }
.tak-legenda .tak-item svg { display: block; }
/* Kaartmarkers als klein SVG-icoon (cirkel = Klerks, driehoek = Persoon), zonder Leaflet-kader. */
.kaart-icon { background: transparent; border: 0; }
.kaart-icon svg { display: block; overflow: visible; }
.kaart-schakels { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.legenda { display: inline-flex; align-items: center; gap: .5rem; }
.legenda .stip { width: 12px; height: 12px; border-radius: 50%; display: inline-block;
  border: 1px solid #fff; box-shadow: 0 0 0 1px var(--line); margin-left: .6rem; }
.legenda .stip:first-child { margin-left: 0; }
.stip-klerks { background: #6f8465; }
.stip-persoon { background: #b0824a; }
.schakel { display: inline-flex; align-items: center; gap: .4rem; cursor: pointer; }
.schakel input { accent-color: var(--accent); }
.reisknop { display: inline-flex; align-items: center; gap: .4rem; font-family: inherit;
  font-weight: 600; font-size: .9rem; color: var(--accent-diep); background: var(--accent-zacht);
  border: 1px solid var(--accent-rand); border-radius: 10px; padding: .45rem .8rem; cursor: pointer; }
.reisknop:hover { background: var(--accent-zacht); }
.reisknop.actief { background: var(--accent); color: #fff; border-color: var(--accent); }
.reis-tekst { margin: 0 0 .6rem; padding: .6rem .9rem; border-radius: var(--radius-s);
  background: var(--accent-zacht); border: 1px solid var(--accent-rand); color: #5c5e4f; font-size: .92rem; }
.leaflet-container { font: inherit; border-radius: var(--radius); }

/* ---------- Naam-evolutie ---------- */
.naam-evolutie-blok { margin-top: 2.4rem; }
.naam-evolutie { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.naam-stap { display: inline-flex; flex-direction: column; align-items: center;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-s);
  box-shadow: var(--schaduw); padding: .5rem .9rem; color: var(--ink); text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease; }
.naam-stap:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); border-color: var(--accent-rand); }
.naam-spelling { font-weight: 700; letter-spacing: -.01em; }
.naam-pijl { color: var(--zacht-muted); font-weight: 700; }

/* ---------- Grafische stamboom ---------- */
.boom-tabs { display: flex; gap: .5rem; margin: .5rem 0 1rem; }
.boom-tab { font-family: inherit; font-weight: 600; font-size: .9rem; color: var(--muted);
  background: var(--surface); border: 1px solid var(--line); border-radius: 10px;
  padding: .45rem .8rem; cursor: pointer; }
.boom-tab:hover { color: var(--ink); }
.boom-tab.actief { background: var(--accent); color: #fff; border-color: var(--accent); }
.boom-hint { color: var(--zacht-muted); font-size: .82rem; align-self: center; margin-left: auto; }

.boom-canvas { position: relative; height: min(78vh, 860px); overflow: hidden;
  border: 1px solid var(--line); border-radius: var(--radius); background: var(--bg);
  box-shadow: var(--schaduw); cursor: grab; touch-action: none; }
.boom-canvas.grabbing { cursor: grabbing; }
/* Volledig scherm: het canvas vult het hele venster. */
.boom-canvas.volledig { position: fixed; inset: 0; width: 100vw; height: 100vh;
  z-index: 2000; border-radius: 0; border: 0; }
body.boom-vol-open { overflow: hidden; }
.boom-pan { position: absolute; top: 0; left: 0; transform-origin: 0 0; }
.boom { display: inline-block; }
.boom-knoppen { position: absolute; top: .6rem; right: .6rem; z-index: 5;
  display: flex; flex-direction: column; gap: .35rem; }
.boom-knoppen button { width: 34px; height: 34px; border-radius: 9px; border: 1px solid var(--line);
  background: #fff; box-shadow: var(--schaduw); color: var(--ink); font-size: 1.15rem; font-weight: 600;
  cursor: pointer; display: grid; place-items: center; padding: 0; }
.boom-knoppen button:hover { background: var(--line-zacht); }

.boom ul { position: relative; padding-top: 22px; white-space: nowrap; margin: 0;
  text-align: center; display: flex; justify-content: center; }
.boom li { display: inline-block; vertical-align: top; list-style: none; position: relative;
  padding: 22px 8px 0; white-space: normal; }
/* verbindingslijnen tussen ouders en kinderen */
.boom li::before, .boom li::after { content: ""; position: absolute; top: 0; right: 50%;
  border-top: 2px solid var(--line); width: 50%; height: 22px; }
.boom li::after { right: auto; left: 50%; border-left: 2px solid var(--line); }
.boom li:only-child::before, .boom li:only-child::after { display: none; }
.boom li:first-child::before, .boom li:last-child::after { border: 0 none; }
.boom li:last-child::before { border-right: 2px solid var(--line); border-radius: 0 6px 0 0; }
.boom li:first-child::after { border-radius: 6px 0 0 0; }
.boom ul ul::before { content: ""; position: absolute; top: 0; left: 50%;
  border-left: 2px solid var(--line); width: 0; height: 22px; }
.boom li.dicht > ul { display: none; }

.boom-kaart { position: relative; display: inline-block; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--radius-s); box-shadow: var(--schaduw);
  padding: .5rem .6rem; }
.boom-paar { display: flex; align-items: center; gap: .4rem; }
.boom-x { color: var(--zacht-muted); font-weight: 700; }
.boom-persoon { display: flex; align-items: center; gap: .5rem; color: var(--ink);
  text-decoration: none; padding: .1rem .2rem; border-radius: 8px; }
.boom-persoon:hover { background: var(--line-zacht); }
.boom-naam { font-weight: 600; font-size: .82rem; line-height: 1.2; text-align: left; }
.boom-naam .jaren { font-weight: 400; font-size: .75rem; }
.boom-toggle { position: absolute; left: 50%; bottom: -11px; transform: translateX(-50%);
  width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--accent-rand);
  background: #fff; color: var(--accent-diep); font-weight: 700; line-height: 1; cursor: pointer;
  z-index: 1; display: grid; place-items: center; padding: 0; }
.boom-toggle:hover { background: var(--accent-zacht); }
.boom li.dicht > .boom-kaart::after { content: ""; position: absolute; left: 50%; bottom: -22px;
  transform: translateX(-50%); width: 8px; height: 8px; border-radius: 50%; background: var(--accent-rand); }

/* ---------- Voettekst ---------- */
footer { max-width: 88rem; margin: 2.5rem auto 3.5rem; padding: 1.4rem 1.5rem 0;
  color: var(--zacht-muted); font-size: .85rem; border-top: 1px solid var(--line);
  display: flex; gap: .6rem; align-items: flex-start; }
footer .ico { width: 18px; height: 18px; margin-top: .1rem; flex: none; }

@media (max-width: 40rem) {
  .kolommen { columns: 1; }
  main { padding: 1.4rem 1.1rem; }
  .hero { padding: 1.8rem 1.3rem; border-radius: 18px; }
  .kop nav a span { display: none; }
  .register-letter { top: 3.3rem; }
}
