/*
Theme Name: EDEW – ede-wageningen.com
Description: Child theme van Twenty Twenty-Five voor de onafhankelijke reizigersgids ede-wageningen.com. Kleurenpalet "De Kap" (kaphout, Veluwe-groen, zink-teal), systeemfonts, componenten uit designhoofdstuk 5.
Template: twentytwentyfive
Version: 1.3.0
Author: ede-wageningen.com
Text Domain: edew
*/

/* ============================================================
   ede-wageningen.com — design tokens v1.0 (hoofdstuk 5), licht thema
   ============================================================ */
:root {
  /* -- Primitieven -- */
  --hout-800: #533317;  --hout-700: #6E4520;  --hout-500: #A9784A;
  --hout-300: #D9B98C;  --hout-200: #E4D3B8;  --hout-100: #F1E9DC;
  --groen-800: #1E4633; --groen-600: #2E5F45; --groen-300: #7FA98E;
  --heide-600: #744570; --heide-400: #A06E9B; --heide-300: #C9A0C2;
  --teal-600:  #0B6B5D; --teal-300:  #57C7AF;
  --inkt-900:  #26221B; --inkt-600:  #5B5348;
  --papier:    #FAF7F2; --zand:      #F1E9DC; --rand-licht:#E2DACC;
  --wit: #FFFFFF;
  --warn-700: #7A5200; --warn-bg: #FBF3E0;
  --fout-600: #9C3A22; --fout-bg: #FBEAE4;
  --info-bg:  #E3F2EC;

  /* -- Semantische tokens -- */
  --kleur-achtergrond: var(--papier);
  --kleur-oppervlak:   var(--wit);
  --kleur-oppervlak-2: var(--zand);
  --kleur-tekst:       var(--inkt-900);
  --kleur-tekst-2:     var(--inkt-600);
  --kleur-kop:         var(--groen-800);
  --kleur-merk:        var(--hout-700);
  --kleur-merk-zacht:  var(--hout-200);
  --kleur-accent:      var(--teal-600);
  --kleur-accent-tekst: var(--wit);
  --kleur-sfeer:       var(--heide-600);
  --kleur-rand:        var(--rand-licht);
  --kleur-info-vlak:   var(--info-bg);
  --kleur-succes:      var(--groen-600);
  --kleur-warn:        var(--warn-700);   --kleur-warn-vlak: var(--warn-bg);
  --kleur-fout:        var(--fout-600);   --kleur-fout-vlak: var(--fout-bg);
  --schaduw-kaart: 0 1px 3px rgb(38 34 27 / .08), 0 4px 16px rgb(38 34 27 / .06);
  --logo-groen: var(--groen-800);
  --logo-hout: var(--hout-500);
  --logo-spoor: var(--teal-600);

  /* -- Vorm & ruimte -- */
  --radius-s: 6px; --radius-m: 12px; --radius-l: 20px;
  --ruimte-1: .25rem; --ruimte-2: .5rem; --ruimte-3: .75rem;
  --ruimte-4: 1rem;   --ruimte-6: 1.5rem; --ruimte-8: 2rem;
  --ruimte-12: 3rem;  --ruimte-16: 4rem;
  --breedte-content: 72rem; --breedte-tekst: 42rem;

  /* -- Typografie: systeemfonts, géén externe fonts -- */
  --font-kop: ui-sans-serif, system-ui, -apple-system, "Segoe UI",
              Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-body: ui-sans-serif, system-ui, -apple-system, "Segoe UI",
               Roboto, "Helvetica Neue", Arial, sans-serif;
  --tekst-s:  0.875rem;
  --tekst-m:  1rem;
  --tekst-l:  clamp(1.0625rem, 1rem + .3vw, 1.125rem);
  --tekst-xl: clamp(1.25rem, 1.1rem + .7vw, 1.5rem);
  --tekst-2xl: clamp(1.5rem, 1.3rem + 1vw, 1.95rem);
  --tekst-3xl: clamp(1.95rem, 1.6rem + 1.8vw, 2.6rem);
  --regel-body: 1.6;
  --regel-kop: 1.15;
}

/* ============ Basis ============ */
*, *::before, *::after { box-sizing: border-box; }
html { color-scheme: light; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--kleur-achtergrond) !important;
  color: var(--kleur-tekst);
  font: var(--tekst-l)/var(--regel-body) var(--font-body);
}
a { color: var(--kleur-accent); text-underline-offset: 2px; }
:focus-visible { outline: 3px solid var(--kleur-accent); outline-offset: 2px; }
img { max-width: 100%; height: auto; }
h1, h2, h3, .wp-block-heading {
  font-family: var(--font-kop); color: var(--kleur-kop);
  line-height: var(--regel-kop); letter-spacing: -0.015em;
}
h1 { font-size: var(--tekst-3xl); font-weight: 800; margin: 0 0 var(--ruimte-4); }
h2 { font-size: var(--tekst-2xl); font-weight: 700; margin: var(--ruimte-12) 0 var(--ruimte-4); }
h3 { font-size: var(--tekst-xl);  font-weight: 650; margin: var(--ruimte-8) 0 var(--ruimte-3); }
table { font-variant-numeric: tabular-nums; border-collapse: collapse; width: 100%; }
.site-main p, .site-main ul, .site-main ol { max-width: var(--breedte-tekst); }
.site-main table th, .site-main table td { padding: var(--ruimte-2) var(--ruimte-3); text-align: left; border-bottom: 1px solid var(--kleur-rand); }
.site-main table thead th { background: var(--kleur-oppervlak-2); }
.site-main table tbody tr:nth-child(even) { background: var(--kleur-oppervlak-2); }

.wrapper { max-width: var(--breedte-content); margin-inline: auto; padding-inline: var(--ruimte-4); }
.site-main { padding-block: var(--ruimte-4) 0; }
.tekstbreedte { max-width: var(--breedte-tekst); }
.meta { color: var(--kleur-tekst-2); font-size: var(--tekst-s); }

/* ============ Header + logo ============ */
.site-header {
  background: var(--kleur-oppervlak);
  border-bottom: 1px solid var(--kleur-rand);
}
.header-binnen {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--ruimte-4); flex-wrap: wrap; padding-block: var(--ruimte-3);
}
.logo-link {
  display: flex; align-items: center; gap: var(--ruimte-3);
  text-decoration: none; color: var(--kleur-kop);
}
.logo-link svg { width: 56px; height: 28px; }
.logo-link .driehoek-groen { fill: var(--logo-groen); }
.logo-link .driehoek-hout { fill: var(--logo-hout); }
.logo-link .spoor { fill: var(--logo-spoor); }
.logo-naam { font-family: var(--font-kop); font-weight: 700; font-size: 1.05rem; line-height: 1.2; }
.logo-naam .koppel { color: var(--kleur-accent); }
.logo-sub { display: block; font-weight: 400; font-size: var(--tekst-s); color: var(--kleur-tekst-2); }
.hoofdnav a { text-decoration: none; font-weight: 600; font-size: var(--tekst-m); color: var(--kleur-tekst); }
.hoofdnav a:hover { color: var(--kleur-accent); text-decoration: underline; }
.hoofdnav .current-menu-item > a { color: var(--kleur-merk); text-decoration: underline; }

/* ============ Kaart-basisrecept ============ */
.kaart, .infokaart, .bedrijfskaart, .instructiekaart {
  background: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand);
  border-radius: var(--radius-m);
  box-shadow: var(--schaduw-kaart);
  padding: var(--ruimte-6);
}

/* 1. Infokaart (feitenblok) */
.infokaart { border-top: 4px solid var(--kleur-merk); margin-block: var(--ruimte-6); }
.infokaart h2, .infokaart h3 { margin-top: 0; display: flex; align-items: center; gap: var(--ruimte-2); }
.infokaart svg { color: var(--kleur-merk); flex: none; }
.infokaart dl { margin: 0; max-width: var(--breedte-tekst); }
.infokaart dt { color: var(--kleur-tekst-2); font-size: var(--tekst-s); margin-top: var(--ruimte-3); }
.infokaart dd { margin: 0; }

/* 2. Tarieventabel */
.tarieven-wrap { max-width: var(--breedte-tekst); overflow-x: auto; }
.tarieven th, .tarieven td { padding: var(--ruimte-2) var(--ruimte-3); text-align: left; border-bottom: 1px solid var(--kleur-rand); }
.tarieven thead th { background: var(--kleur-oppervlak-2); }
.tarieven tbody tr:nth-child(even) { background: var(--kleur-oppervlak-2); }
.tarieven td:last-child, .tarieven th:last-child { text-align: right; white-space: nowrap; }
.tabel-bijschrift { color: var(--kleur-tekst-2); font-size: var(--tekst-s); margin-top: var(--ruimte-2); }

/* 3. Stappenplan-blok (driehoekige markers = knipoog naar de kap) */
.stappen { list-style: none; margin: var(--ruimte-6) 0; padding: 0; counter-reset: stap; max-width: var(--breedte-tekst); }
.stappen > li {
  counter-increment: stap;
  position: relative; padding-left: 3.25rem; padding-bottom: var(--ruimte-6);
}
.stappen > li::before {
  content: counter(stap);
  position: absolute; left: 0; top: 0;
  width: 2.25rem; height: 2rem;
  display: grid; place-items: center; padding-top: .45rem;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  background: var(--kleur-merk-zacht); color: var(--kleur-merk);
  font-weight: 700; font-size: var(--tekst-s); font-family: var(--font-kop);
}
.stappen > li:not(:last-child)::after {
  content: ""; position: absolute; left: 1.05rem; top: 2.4rem; bottom: .3rem;
  width: 1px; background: var(--kleur-rand);
}
.stappen strong:first-child { display: block; color: var(--kleur-kop); }

/* 4. Alert/mededeling-banner */
.alert {
  display: flex; gap: var(--ruimte-3); align-items: flex-start;
  border-left: 4px solid; border-radius: var(--radius-s);
  padding: var(--ruimte-4); margin: var(--ruimte-6) 0;
  max-width: var(--breedte-tekst);
}
.alert svg { flex: none; margin-top: .15rem; }
.alert p { margin: 0; max-width: none; }
.alert-info  { background: var(--kleur-info-vlak); border-color: var(--kleur-accent); }
.alert-info svg { color: var(--kleur-accent); }
.alert-succes { background: var(--kleur-info-vlak); border-color: var(--kleur-succes); }
.alert-succes svg { color: var(--kleur-succes); }
.alert-warn  { background: var(--kleur-warn-vlak); border-color: var(--kleur-warn); }
.alert-warn svg { color: var(--kleur-warn); }
.alert-fout  { background: var(--kleur-fout-vlak); border-color: var(--kleur-fout); }
.alert-fout svg { color: var(--kleur-fout); }

/* 5. FAQ-accordeon (native details/summary, géén JS) */
.faq { max-width: var(--breedte-tekst); }
.faq details {
  border: 1px solid var(--kleur-rand); border-radius: var(--radius-s);
  background: var(--kleur-oppervlak); margin-bottom: var(--ruimte-2);
}
.faq summary {
  cursor: pointer; padding: var(--ruimte-3) var(--ruimte-4);
  font-weight: 600; color: var(--kleur-kop);
  display: flex; justify-content: space-between; align-items: center; gap: var(--ruimte-2);
  list-style: none;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary svg { flex: none; transition: transform .2s; color: var(--kleur-accent); }
.faq details[open] { background: var(--kleur-oppervlak-2); }
.faq details[open] summary svg { transform: rotate(180deg); }
.faq .faq-antwoord { padding: 0 var(--ruimte-4) var(--ruimte-4); }
.faq .faq-antwoord p { margin-top: 0; }

/* 6. Bedrijvenkaartje (gids) */
.bedrijfskaart { max-width: 26rem; margin-block: var(--ruimte-6); }
.bedrijfskaart .categorie-badge {
  display: inline-block; background: var(--kleur-sfeer); color: var(--wit);
  border-radius: var(--radius-s); padding: .1rem var(--ruimte-2);
  font-size: var(--tekst-s); font-weight: 600;
}
.bedrijfskaart h3 { margin: var(--ruimte-3) 0 var(--ruimte-1); }
.bedrijfskaart .disclosure { font-style: italic; color: var(--kleur-tekst-2); font-size: var(--tekst-s); }
.bedrijfskaart .afstand { display: flex; align-items: center; gap: var(--ruimte-2); color: var(--kleur-tekst-2); font-size: var(--tekst-s); margin: var(--ruimte-2) 0; }
.bedrijfskaart .acties { display: flex; flex-wrap: wrap; gap: var(--ruimte-3); align-items: center; margin-top: var(--ruimte-3); }

/* 7. Breadcrumb */
.breadcrumb { font-size: var(--tekst-s); margin: 0 0 var(--ruimte-4); }
.breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; gap: var(--ruimte-1); margin: 0; padding: 0; max-width: none; }
.breadcrumb li + li::before { content: "›"; margin-inline: var(--ruimte-1); color: var(--kleur-tekst-2); }
.breadcrumb a { color: var(--kleur-accent); }
.breadcrumb [aria-current="page"] { color: var(--kleur-tekst-2); }

/* 8. Sticky mobiele snelbalk (patroon h.05, zelfde als snippet 837) */
.snelbalk {
  position: fixed; inset-inline: 0; bottom: 0; z-index: 50;
  display: grid; grid-auto-flow: column;
  background: var(--kleur-oppervlak);
  border-top: 1px solid var(--kleur-rand);
  padding-bottom: env(safe-area-inset-bottom);
  margin: 0;
}
.snelbalk a {
  display: grid; justify-items: center; gap: 2px;
  padding: var(--ruimte-2) 0; min-height: 56px;
  font-size: var(--tekst-s); color: var(--kleur-tekst-2);
  text-decoration: none;
}
.snelbalk a:active { color: var(--kleur-accent); }
.snelbalk svg { width: 22px; height: 22px; }
@media (min-width: 48rem) { .snelbalk { display: none; } }
@media (max-width: 47.99rem) { body { padding-bottom: 72px; } }

/* ============ Knoppen ============ */
.knop {
  display: inline-flex; align-items: center; gap: var(--ruimte-2);
  background: var(--kleur-accent); color: var(--kleur-accent-tekst);
  border: none; border-radius: var(--radius-s);
  padding: var(--ruimte-3) var(--ruimte-4);
  font: 600 var(--tekst-m)/1.2 var(--font-body);
  text-decoration: none; cursor: pointer;
}
a.knop { color: var(--kleur-accent-tekst); }
.knop:hover { filter: brightness(1.08); }
.knop-secundair, a.knop-secundair {
  background: transparent; color: var(--kleur-accent);
  border: 2px solid var(--kleur-accent);
}

/* ============ Hero + taaktegels (home) ============ */
.hero { padding-block: var(--ruimte-4) var(--ruimte-6); }
.subregel { color: var(--kleur-tekst-2); font-size: var(--tekst-xl); margin-top: 0; }
.hero-foto, .wp-block-image.hero-foto { border-radius: var(--radius-l); overflow: hidden; margin-block: var(--ruimte-6); box-shadow: var(--schaduw-kaart); max-width: none; }
.hero-foto img { display: block; width: 100%; height: auto; border-radius: 0 !important; }
.tegels {
  display: grid; gap: var(--ruimte-4);
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  list-style: none; padding: 0; margin: var(--ruimte-6) 0; max-width: none !important;
}
.tegel {
  display: block; text-decoration: none;
  background: var(--kleur-oppervlak); border: 1px solid var(--kleur-rand);
  border-radius: var(--radius-m); box-shadow: var(--schaduw-kaart);
  padding: var(--ruimte-6); color: var(--kleur-tekst);
}
.tegel:hover { border-color: var(--kleur-accent); }
.tegel svg { color: var(--kleur-merk); width: 32px; height: 32px; }
.tegel strong { display: block; font-family: var(--font-kop); font-size: var(--tekst-xl); color: var(--kleur-kop); margin-block: var(--ruimte-2) var(--ruimte-1); }
.tegel span { color: var(--kleur-tekst-2); font-size: var(--tekst-m); }
.hero-knoppen { display: flex; flex-wrap: wrap; gap: var(--ruimte-3); margin-top: var(--ruimte-4); }

/* Snelle feiten-strip */
.feitenstrip {
  display: flex; flex-wrap: wrap; gap: var(--ruimte-2) var(--ruimte-6);
  background: var(--kleur-oppervlak-2); border-radius: var(--radius-m);
  padding: var(--ruimte-4) var(--ruimte-6); margin-block: var(--ruimte-6);
  list-style: none; max-width: none !important; font-size: var(--tekst-m);
}
.feitenstrip li { display: flex; align-items: center; gap: var(--ruimte-2); }
.feitenstrip svg { color: var(--kleur-merk); flex: none; }

/* Toen & nu */
.toen-nu { display: grid; gap: var(--ruimte-4); grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); max-width: var(--breedte-content); margin-block: var(--ruimte-6); }
.toen-nu figure { margin: 0; }
.toen-nu img { border-radius: var(--radius-m); display: block; width: 100%; height: auto; }
.toen-nu figcaption { color: var(--kleur-tekst-2); font-size: var(--tekst-s); margin-top: var(--ruimte-2); }

/* Snel-antwoord-box bovenaan taakpagina's */
.snel-antwoord {
  background: var(--kleur-info-vlak); border-radius: var(--radius-m);
  padding: var(--ruimte-6); margin-block: var(--ruimte-6);
  max-width: var(--breedte-tekst);
  border-left: 4px solid var(--kleur-succes);
}
.snel-antwoord p:first-child { margin-top: 0; }
.snel-antwoord p:last-child { margin-bottom: 0; }

/* Peildatum-badge */
.peildatum {
  display: inline-flex; align-items: center; gap: var(--ruimte-2);
  background: var(--kleur-merk-zacht); color: var(--kleur-merk);
  border-radius: var(--radius-s); padding: var(--ruimte-1) var(--ruimte-3);
  font-size: var(--tekst-s) !important; font-weight: 600;
}
.peildatum svg { flex: none; }

/* Figuur + bijschrift (fotocredits verplicht) */
figure.foto, .wp-block-image.foto { margin: var(--ruimte-6) 0; max-width: var(--breedte-tekst); }
figure.foto img { border-radius: var(--radius-m); display: block; }
figure.foto figcaption, .wp-block-image.foto figcaption, .wp-element-caption {
  color: var(--kleur-tekst-2); font-size: var(--tekst-s); margin-top: var(--ruimte-2); text-align: left;
}

/* Bronnen-blok */
.bronnen {
  border-top: 1px solid var(--kleur-rand); margin-top: var(--ruimte-12);
  padding-top: var(--ruimte-4); font-size: var(--tekst-s); color: var(--kleur-tekst-2);
  max-width: var(--breedte-tekst);
}
.bronnen h2 { font-size: var(--tekst-m); margin: 0 0 var(--ruimte-2); color: var(--kleur-tekst-2); }
.bronnen ul { margin: 0; padding-left: 1.2rem; }
.bronnen a { color: inherit; }

/* Instructiekaart (deelbaar, /ophalen/) */
.instructiekaart { border-top: 4px solid var(--kleur-accent); max-width: var(--breedte-tekst); margin-block: var(--ruimte-6); }
.instructiekaart h3 { margin-top: 0; }
.instructiekaart ol { margin: 0 0 var(--ruimte-4); padding-left: 1.3rem; }

/* Twee blokken vóór/na (parkeren) */
.periode-blok { border-radius: var(--radius-m); padding: var(--ruimte-6); margin-block: var(--ruimte-6); max-width: var(--breedte-tekst); }
.periode-blok h3, .periode-blok h2 { margin-top: 0; }
.periode-voor { background: var(--kleur-oppervlak-2); border: 1px solid var(--kleur-rand); }
.periode-na { background: var(--kleur-oppervlak); border: 2px solid var(--kleur-succes); }
.periode-label {
  display: inline-block; font-family: var(--font-kop); font-weight: 700; font-size: var(--tekst-s);
  text-transform: uppercase; letter-spacing: .04em; margin-bottom: var(--ruimte-2);
}
.periode-voor .periode-label { color: var(--kleur-warn); }
.periode-na .periode-label { color: var(--kleur-succes); }

/* ============ Footer ============ */
.site-footer {
  margin-top: var(--ruimte-16);
  background: var(--kleur-oppervlak);
  border-top: 1px solid var(--kleur-rand);
  padding-block: var(--ruimte-8);
  font-size: var(--tekst-m);
}
.site-footer nav ul { list-style: none; display: flex; flex-wrap: wrap; gap: var(--ruimte-2) var(--ruimte-4); padding: 0; margin: 0 0 var(--ruimte-4); max-width: none; }
.site-footer .disclaimer { color: var(--kleur-tekst-2); font-size: var(--tekst-s); max-width: var(--breedte-tekst); }
.site-footer .meta-regel { color: var(--kleur-tekst-2); font-size: var(--tekst-s); margin-top: var(--ruimte-4); }

/* ============================================================
   Arena-ronde 4/7: fundament voor F3/F6/F1 — nog nergens in content gebruikt
   (.edew-afstand: alleen gemeten waarden, altijd met meetdatum)
   ============================================================ */
.edew-afstand { display: inline-flex; align-items: center; gap: .35rem; font-variant-numeric: tabular-nums; white-space: nowrap; }
.edew-afstand::before { content: "🚶"; font-size: .95em; }
.edew-afstand .meetdatum { color: var(--teal-600, #4a6b6f); font-size: .85em; }
table.edew-tarief caption, .edew-tarief-noot { font-size: .9rem; color: inherit; opacity: .85; }
.edew-verwant { border-top: 3px solid var(--groen-800, #2f5233); margin-top: 2.5rem; padding-top: 1rem; max-width: var(--breedte-tekst); }
.edew-verwant h2 { font-size: 1.15rem; }
.edew-verwant ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.edew-verwant li a { text-decoration: underline; }

/* Wachtwoordformulier (/omgeving/ zolang beveiligd) */
.post-password-form { max-width: var(--breedte-tekst); background: var(--kleur-oppervlak); border: 1px solid var(--kleur-rand); border-radius: var(--radius-m); padding: var(--ruimte-6); box-shadow: var(--schaduw-kaart); }
.post-password-form input[type="password"] { padding: var(--ruimte-2) var(--ruimte-3); border: 1px solid var(--kleur-rand); border-radius: var(--radius-s); font-size: var(--tekst-m); }
.post-password-form input[type="submit"] { background: var(--kleur-accent); color: var(--kleur-accent-tekst); border: none; border-radius: var(--radius-s); padding: var(--ruimte-2) var(--ruimte-4); font-weight: 600; cursor: pointer; }

/* ============================================================
   Uitbreiding 4/7 (avond): 404-pagina + zoekblok
   ============================================================ */
.wp-block-search { max-width: var(--breedte-tekst); margin-block: var(--ruimte-4); }
.wp-block-search .wp-block-search__input {
  padding: var(--ruimte-3) var(--ruimte-4); border: 1px solid var(--kleur-rand);
  border-radius: var(--radius-s); font: var(--tekst-m)/1.2 var(--font-body);
  background: var(--kleur-oppervlak); color: var(--kleur-tekst);
}
.wp-block-search .wp-block-search__button {
  background: var(--kleur-accent); color: var(--kleur-accent-tekst);
  border: none; border-radius: var(--radius-s);
  padding: var(--ruimte-3) var(--ruimte-4); font: 600 var(--tekst-m)/1.2 var(--font-body);
  cursor: pointer;
}
.wp-block-search .wp-block-search__button:hover { filter: brightness(1.08); }

/* ============================================================
   Bedrijvengids /in-de-buurt/ (arena-verdict 21b)
   ============================================================ */
.gids-zoek { max-width: var(--breedte-tekst); margin-block: var(--ruimte-6) var(--ruimte-3); }
#gidszoek {
  width: 100%; padding: var(--ruimte-3) var(--ruimte-4);
  border: 1px solid var(--kleur-rand); border-radius: var(--radius-s);
  font: var(--tekst-m)/1.2 var(--font-body);
  background: var(--kleur-oppervlak); color: var(--kleur-tekst);
}
.edew-gids-anker {
  list-style: none; display: flex; flex-wrap: wrap; gap: var(--ruimte-2);
  padding: 0; margin: 0 0 var(--ruimte-8); max-width: none;
}
.edew-gids-anker a {
  display: inline-block; background: var(--kleur-oppervlak);
  border: 1px solid var(--kleur-rand); border-radius: 999px;
  padding: .35rem .9rem; text-decoration: none;
  font-weight: 600; font-size: var(--tekst-s); color: var(--kleur-kop);
}
.edew-gids-anker a:hover { border-color: var(--kleur-accent); color: var(--kleur-accent); }
.edew-gids-sectie { scroll-margin-top: var(--ruimte-6); }
.edew-gids-lijst { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--ruimte-2); max-width: none; }
.edew-gids-item {
  background: var(--kleur-oppervlak); border: 1px solid var(--kleur-rand);
  border-radius: var(--radius-s); padding: var(--ruimte-2) var(--ruimte-3);
  font-size: var(--tekst-m);
}
.edew-gids-item .gids-afstand { white-space: nowrap; font-variant-numeric: tabular-nums; }
.edew-gids-item .gids-noot, .gids-noot { color: var(--kleur-tekst-2); font-size: var(--tekst-s); }
.gids-voetnoot { color: var(--kleur-tekst-2); font-size: var(--tekst-s); max-width: var(--breedte-tekst); }
