/* ── THEME TOKENS ────────────────────────────── */
:root {
  --ink:           #f7f6f3;
  --surface:       #ffffff;
  --surface-hover: #f2f1ee;
  --border:        #e4e2dc;
  --muted:         #b0ada5;
  --dim:           #888580;
  --body:          #4a4844;
  --head:          #18170f;
  --accent:        #2e8b57;
  --accent2:       #f06543;
  --overlay-h:     rgba(247,246,243,1);
  --overlay-m:     rgba(247,246,243,.55);
  --overlay-t:     rgba(247,246,243,.05);
  --overlay-mob-t: rgba(247,246,243,.15);
  --overlay-mob-b: rgba(247,246,243,.97);
}
.dark {
  --ink:           #0c0c0c;
  --surface:       #141414;
  --surface-hover: #1c1c1c;
  --border:        #232323;
  --muted:         #555555;
  --dim:           #888888;
  --body:          #c8c8c8;
  --head:          #f0f0f0;
  --accent:        #52b788;
  --accent2:       #f4845f;
  --overlay-h:     rgba(12,12,12,1);
  --overlay-m:     rgba(12,12,12,.6);
  --overlay-t:     rgba(12,12,12,.05);
  --overlay-mob-t: rgba(12,12,12,.2);
  --overlay-mob-b: rgba(12,12,12,.96);
}

/* ── RESET / BASE ────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
/* Reserveer ruimte voor Iconify icons vóór ze laden om layout shift te voorkomen */
iconify-icon { display: inline-block; width: 1em; height: 1em; vertical-align: -0.125em; }
html {
  scroll-behavior: smooth;
  font-size: 16px;
  /* Reserveer altijd ruimte voor de scrollbar zodat de layout niet verschuift */
  scrollbar-gutter: stable;
}
body {
  background: var(--ink);
  color: var(--body);
  font-family: Inter, system-ui, sans-serif;
  line-height: 1.6;
  transition: background .25s, color .25s;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
a:hover { text-decoration: underline; }

/* Elementen die geen underline bij hover mogen */
.jw-nav a:hover,
.jw-mobile-nav a:hover,
.jw-logo:hover,
.jw-footer__nav a:hover,
.jw-post-card:hover,
.jw-archive__item:hover,
.jw-featured:hover,
.jw-route-row:hover,
.jw-gear-item:hover,
.jw-gear-list__item:hover,
.jw-gear-card:hover,
.jw-wandeling-card:hover,
.jw-4d-edition:hover,
.jw-vierdaagse__btn:hover,
.jw-pagination__btn:hover,
.jw-newsletter__btn:hover,
.jw-single__back:hover,
.jw-section-head a:hover,
.jw-about__links a:hover,
.jw-about-page__contact-link:hover { text-decoration: none; }
img { display: block; max-width: 100%; }

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* ── LAYOUT ──────────────────────────────────── */
.jw-wrap { max-width: 1024px; margin: 0 auto; padding: 0 1.5rem; }
.section-label {
  font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--accent2);
}
.divider { height: 1px; background: var(--border); margin: 0; }

/* ── TYPOGRAPHY ──────────────────────────────── */
.serif { font-family: Georgia, Cambria, serif; }
.text-head  { color: var(--head); }
.text-body  { color: var(--body); }
.text-dim   { color: var(--dim); }
.text-muted { color: var(--muted); }
.text-accent{ color: var(--accent); }

/* ── NAVBAR ──────────────────────────────────── */
.jw-header {
  position: sticky; top: 0; z-index: 50;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--ink) 92%, transparent);
  backdrop-filter: blur(8px);
}
.jw-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 3.5rem; gap: 1.5rem;
}
.jw-logo {
  font-family: Georgia, serif; font-weight: 700; font-size: 1.1rem;
  color: var(--head); white-space: nowrap; letter-spacing: -.01em;
}
.jw-logo span { color: var(--accent); }

.jw-nav { display: flex; align-items: center; gap: 1.5rem; flex: 1; }
.jw-nav a {
  font-size: .85rem; color: var(--dim);
  transition: color .15s;
}
.jw-nav a:hover { color: var(--head); }

.jw-header__right { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }

/* theme toggle */
.toggle-wrap { display: flex; align-items: center; gap: .4rem; cursor: pointer; }
.toggle-wrap iconify-icon { font-size: .9rem; color: var(--dim); transition: color .2s; }
.toggle-track {
  width: 38px; height: 21px;
  background: var(--border); border: 1px solid var(--muted);
  border-radius: 999px; position: relative;
  transition: background .2s, border-color .2s;
  cursor: pointer;
}
.dark .toggle-track { background: var(--accent); border-color: var(--accent); }
.toggle-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 15px; height: 15px;
  background: var(--head); border-radius: 50%;
  transition: transform .2s;
}
.dark .toggle-thumb { transform: translateX(17px); }

/* mobile hamburger */
.jw-hamburger {
  display: none; background: none; border: none; cursor: pointer;
  color: var(--dim); padding: .25rem;
}
.jw-hamburger:hover { color: var(--head); }

.jw-mobile-nav {
  display: none; border-top: 1px solid var(--border);
  padding: 1rem 1.5rem 1.25rem;
}
.jw-mobile-nav a {
  display: block; padding: .45rem 0;
  font-size: .875rem; color: var(--dim);
  transition: color .15s;
}
.jw-mobile-nav a:hover { color: var(--head); }
.jw-mobile-nav.open { display: block; }

@media (max-width: 767px) {
  .jw-nav { display: none; }
  .jw-hamburger { display: block; }
}

/* ── INTRO ───────────────────────────────────── */
.jw-intro {
  padding: 3.5rem 0 2.5rem;
  border-bottom: 1px solid var(--border);
}
.jw-intro h1 {
  font-family: Georgia, serif; font-weight: 700;
  font-size: clamp(2rem, 5vw, 3rem); line-height: 1.18;
  color: var(--head); margin: .75rem 0 1rem;
}
.jw-intro p { font-size: 1rem; max-width: 36rem; line-height: 1.7; }

/* ── SECTION HEADER ──────────────────────────── */
.jw-section-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1.5rem;
}
.jw-section-head a {
  font-size: .72rem; color: var(--dim); letter-spacing: .05em;
  display: flex; align-items: center; gap: .25rem;
  transition: color .15s;
}
.jw-section-head a:hover { color: var(--head); }

/* ── FEATURED POST ───────────────────────────── */
.jw-section--featured { padding-top: 3.5rem; }
.jw-featured {
  display: flex; align-items: flex-end;
  border-radius: .75rem; min-height: 380px;
  padding: 2.5rem; overflow: hidden;
}
@media (max-width: 767px) {
  .jw-featured { min-height: 300px; }
}
.jw-featured__inner { max-width: 32rem; }
.jw-featured__meta {
  font-size: .7rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent2); margin-bottom: .5rem;
}
.jw-featured__title {
  font-family: Georgia, serif; font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 700; line-height: 1.25; color: var(--head); margin-bottom: .75rem;
  transition: color .15s;
}
.jw-featured:hover .jw-featured__title { color: var(--accent); }
.jw-featured__excerpt {
  font-size: .875rem; line-height: 1.65; color: var(--body); opacity: .85;
}
.jw-featured__link {
  display: inline-flex; align-items: center; gap: .4rem;
  margin-top: 1rem; font-size: .875rem; font-weight: 500; color: var(--accent);
  white-space: nowrap; position: relative;
}
.jw-featured__link::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0;
  height: 1px; background: var(--accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s ease;
}
.jw-featured:hover .jw-featured__link::after { transform: scaleX(1); }

/* ── POST GRID ───────────────────────────────── */
.jw-section--posts { padding-top: 3.5rem; }
.jw-post-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--border);
  border-radius: .75rem; overflow: hidden;
}
@media (max-width: 767px) { .jw-post-grid { grid-template-columns: 1fr; } }
@media (min-width: 768px) and (max-width: 1023px) { .jw-post-grid { grid-template-columns: repeat(2, 1fr); } }

.jw-post-card {
  background: var(--surface); padding: 1.5rem;
  transition: background .15s; display: flex; flex-direction: column;
}
.jw-post-card:hover { background: var(--surface-hover); }
.jw-post-card__img {
  width: 100%; height: 9rem; object-fit: cover; border-radius: .5rem;
  margin-bottom: 1.25rem;
  filter: grayscale(1); transition: filter .5s ease;
}
.jw-post-card:hover .jw-post-card__img { filter: grayscale(0); }
.jw-post-card__placeholder {
  width: 100%; height: 9rem;
  background: var(--border);
  display: flex; align-items: center; justify-content: center;
  border-radius: .5rem; margin-bottom: 1.25rem;
}
.jw-post-card__placeholder iconify-icon { font-size: 2rem; color: var(--muted); }

.jw-post-card__meta {
  font-size: .7rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent2); margin-bottom: .5rem;
}
.jw-post-card__title {
  font-family: Georgia, serif; font-size: 1.05rem; font-weight: 700;
  color: var(--head); line-height: 1.3; margin-bottom: .5rem;
  transition: color .15s;
}
.jw-post-card:hover .jw-post-card__title { color: var(--accent); }
.jw-post-card__excerpt { font-size: .85rem; color: var(--dim); line-height: 1.6; flex: 1; }
.jw-post-card__more {
  display: inline-flex; align-items: center; gap: .25rem;
  font-size: .75rem; color: var(--muted); margin-top: 1rem;
  transition: color .15s;
}
.jw-post-card:hover .jw-post-card__more { color: var(--accent); }

/* ── 4DAAGSE ─────────────────────────────────── */
.jw-section--vierdaagse { padding-top: 5rem; }
.jw-vierdaagse {
  border: 1px solid var(--border); border-radius: .75rem;
  padding: 2.5rem; display: flex; align-items: center;
  gap: 2rem; flex-wrap: wrap;
}
.jw-vierdaagse__info { flex: 1; min-width: 220px; }
.jw-vierdaagse__label {
  display: flex; align-items: center; gap: .4rem;
  font-size: .7rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent); margin-bottom: .5rem;
}
.jw-vierdaagse__title {
  font-family: Georgia, serif; font-size: 1.6rem; font-weight: 700;
  color: var(--head); margin-bottom: .75rem;
}
.jw-vierdaagse__desc { font-size: .875rem; color: var(--dim); line-height: 1.65; max-width: 22rem; }
.jw-vierdaagse__btn {
  display: inline-flex; align-items: center; gap: .4rem;
  margin-top: 1.25rem; font-size: .85rem; font-weight: 600;
  color: var(--head); border: 1px solid var(--border);
  padding: .5rem 1rem; border-radius: .5rem;
  transition: border-color .15s, color .15s;
}
.jw-vierdaagse__btn:hover { border-color: var(--accent); color: var(--accent); }

.jw-countdown { display: flex; align-items: flex-start; gap: .6rem; flex-shrink: 0; }
.jw-countdown__unit { text-align: center; }
.jw-countdown__num {
  font-size: 2.25rem; font-weight: 800; color: var(--head);
  line-height: 1; font-variant-numeric: tabular-nums;
}
.jw-countdown__num--accent { color: var(--accent); }
.jw-countdown__lbl {
  font-size: .65rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted); margin-top: .2rem;
}
.jw-countdown__sep {
  font-size: 1.6rem; font-weight: 700; color: var(--border);
  line-height: 1; margin-top: .15rem;
}

/* ── WANDELGEAR ──────────────────────────────── */
.jw-section--gear { padding-top: 5rem; }
.jw-gear-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--border);
  border-radius: .75rem; overflow: hidden;
}
@media (max-width: 600px) { .jw-gear-grid { grid-template-columns: repeat(2, 1fr); } }
.jw-gear-item {
  background: var(--surface); padding: 1.1rem 1.25rem;
  display: flex; align-items: center; gap: 1rem;
  transition: background .15s;
}
.jw-gear-item:hover { background: var(--surface-hover); }
.jw-gear-item iconify-icon { font-size: 1.2rem; color: var(--accent); flex-shrink: 0; }
.jw-gear-item__name { font-size: .875rem; font-weight: 600; color: var(--head); }
.jw-gear-item__sub  { font-size: .75rem; color: var(--dim); margin-top: .1rem; }

/* ── WANDELINGEN LIST ────────────────────────── */
.jw-section--routes { padding-top: 5rem; }
.jw-route-list {
  border: 1px solid var(--border); border-radius: .75rem; overflow: hidden;
}
.jw-route-row {
  display: flex; align-items: center; gap: 1rem;
  padding: 1rem 1.5rem; background: var(--surface);
  border-bottom: 1px solid var(--border);
  transition: background .15s;
}
.jw-route-row:last-child { border-bottom: none; }
.jw-route-row:hover { background: var(--surface-hover); }
.jw-route-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 1px;
}
.jw-route-dot--done   { background: var(--accent); }
.jw-route-dot--planned { background: var(--surface); border: 2px solid var(--muted); }
.jw-route-row__name {
  flex: 1; font-size: .875rem; font-weight: 600; color: var(--head);
  transition: color .15s; min-width: 0;
}
.jw-route-row:hover .jw-route-row__name { color: var(--accent); }
.jw-route-row__loc { font-size: .75rem; color: var(--dim); margin-left: .75rem; }
.jw-route-row__meta { display: flex; align-items: center; gap: 1rem; flex-shrink: 0; font-size: .75rem; color: var(--muted); }
.jw-badge {
  padding: .15rem .6rem; border-radius: 999px; font-size: .7rem; font-weight: 600;
}
.jw-badge--done    { background: color-mix(in srgb, var(--accent) 15%, transparent); color: var(--accent); }
.jw-badge--planned { border: 1px solid var(--border); color: var(--muted); }

@media (max-width: 600px) {
  .jw-route-row__loc  { display: none; }
  .jw-route-row__meta span:not(.jw-badge) { display: none; }
}

/* ── OVER MIJ ────────────────────────────────── */
.jw-section--about { padding-top: 5rem; padding-bottom: 5rem; }
.jw-about {
  display: flex; gap: 2.5rem; padding-top: 2.5rem;
  border-top: 1px solid var(--border);
}
@media (max-width: 600px) { .jw-about { flex-direction: column; gap: 1.5rem; } }
.jw-about__avatar {
  width: 6rem; height: 6rem; border-radius: 50%; object-fit: cover;
  border: 1px solid var(--border); flex-shrink: 0;
}
.jw-about__label { font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--dim); margin-bottom: .75rem; }
.jw-about__title { font-family: Georgia, serif; font-size: 1.4rem; font-weight: 700; color: var(--head); margin-bottom: .75rem; }
.jw-about__text  { font-size: .875rem; line-height: 1.7; max-width: 38rem; }
.jw-about__links { display: flex; flex-wrap: wrap; gap: 1.25rem; margin-top: 1.25rem; font-size: .75rem; color: var(--dim); }
.jw-about__links a:hover { color: var(--head); }
.jw-about__links span, .jw-about__links a { display: flex; align-items: center; gap: .35rem; }
.jw-about__links iconify-icon { color: var(--accent); font-size: 1rem; }

/* ── NEWSLETTER ──────────────────────────────── */
.jw-section--newsletter { padding: 4rem 0 5rem; }
.jw-newsletter {
  border: 1px solid var(--border); border-radius: .75rem;
  padding: 2rem 2.5rem; display: flex;
  align-items: center; justify-content: space-between;
  gap: 1.5rem; flex-wrap: wrap;
}
.jw-newsletter__title { font-size: 1rem; font-weight: 600; color: var(--head); margin-bottom: .25rem; }
.jw-newsletter__sub   { font-size: .85rem; color: var(--dim); }
.jw-newsletter__form  { display: flex; }
.jw-newsletter__input {
  width: 14rem; background: var(--surface); color: var(--body);
  border: 1px solid var(--border); border-right: none;
  border-radius: .5rem 0 0 .5rem;
  padding: .6rem 1rem; font-size: .875rem;
  outline: none; transition: border-color .15s;
}
.jw-newsletter__input::placeholder { color: var(--muted); }
.jw-newsletter__input:focus { border-color: var(--accent); }
.jw-newsletter__btn {
  background: var(--accent); color: var(--ink);
  border: none; border-radius: 0 .5rem .5rem 0;
  padding: .6rem 1.25rem; font-size: .875rem; font-weight: 600;
  cursor: pointer; transition: opacity .15s;
}
.jw-newsletter__btn:hover { opacity: .88; }
@media (max-width: 600px) {
  .jw-newsletter__input { width: 100%; }
  .jw-newsletter__form  { width: 100%; }
}

/* ── FOOTER ──────────────────────────────────── */
.jw-footer {
  border-top: 1px solid var(--border);
  padding: 2rem 0;
}
.jw-footer__inner {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
}
.jw-footer__copy  { font-family: Georgia, serif; font-size: .85rem; color: var(--dim); }
.jw-footer__nav   { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.jw-footer__nav a { font-size: .75rem; color: var(--muted); transition: color .15s; }
.jw-footer__nav a:hover { color: var(--head); }
.jw-footer__email { font-size: .75rem; color: var(--muted); }

/* ── FEATURED – dynamic thumb via CSS custom property ────── */
.jw-featured {
  background:
    linear-gradient(to right, var(--overlay-h) 0%, var(--overlay-m) 50%, var(--overlay-t) 100%),
    var(--jw-thumb) center/cover no-repeat;
}
@media (max-width: 767px) {
  .jw-featured {
    background:
      linear-gradient(to bottom, var(--overlay-mob-t) 0%, var(--overlay-mob-b) 62%),
      var(--jw-thumb) center/cover no-repeat;
  }
}

/* ── FEATURED – geen thumbnail ───────────────── */
.jw-featured--no-thumb {
  background: var(--border);
  position: relative;
}
.jw-featured__placeholder-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 3rem;
  color: var(--muted);
  opacity: .5;
  pointer-events: none;
}

/* ── ROUTE LIST empty state ──────────────────── */
.jw-route-list__empty {
  padding: 1.5rem;
  font-size: .875rem;
  color: var(--dim);
}

/* ── PAGE INTRO (inner pages) ────────────────── */
.jw-page-intro {
  padding: 3.5rem 0 2.5rem;
  border-bottom: 1px solid var(--border);
}
.jw-page-intro p:first-child { margin-bottom: .75rem; }
.jw-page-intro h1 {
  font-family: Georgia, Cambria, serif;
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: var(--head);
  line-height: 1.18;
  margin-bottom: 1rem;
}
.jw-page-intro p:last-child { max-width: 36rem; line-height: 1.7; }

/* ── WANDELGEAR PAGE ─────────────────────────── */
.jw-gear-section { padding-top: 3.5rem; }
.jw-gear-section__label {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--dim);
}
.jw-gear-section__label iconify-icon { color: var(--accent); font-size: 1rem; }

.jw-gear-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
@media (max-width: 600px) {
  .jw-gear-cards { grid-template-columns: 1fr; }
}

.jw-gear-card {
  background: var(--surface);
  display: flex;
  flex-direction: column;
  transition: background .15s;
}
.jw-gear-card:hover { background: var(--surface-hover); }
.jw-gear-card__img {
  width: 100%;
  height: 11rem;
  object-fit: cover;
  display: block;
  filter: grayscale(1);
  transition: filter .5s;
}
.jw-gear-card:hover .jw-gear-card__img { filter: grayscale(0); }
.jw-gear-card__body { padding: 1.25rem 1.5rem 1.5rem; }
.jw-gear-card__title {
  font-family: Georgia, Cambria, serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--head);
  margin-bottom: .5rem;
}
.jw-gear-card__desc {
  font-size: .85rem;
  color: var(--dim);
  line-height: 1.65;
}

/* laatste gear section krijgt wat ruimte onderaan */
.jw-gear-section:last-of-type { padding-bottom: 5rem; }

/* Compacte gear list (wandelgear pagina) */
.jw-gear-list {
  border: 1px solid var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
.jw-gear-list__item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .875rem 1.25rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  transition: background .15s;
}
.jw-gear-list__item:last-child { border-bottom: none; }
.jw-gear-list__item:hover { background: var(--surface-hover); }
.jw-gear-list__img {
  width: 56px;
  height: 56px;
  object-fit: cover;
  border-radius: .375rem;
  flex-shrink: 0;
  filter: grayscale(1);
  transition: filter .4s;
}
.jw-gear-list__item:hover .jw-gear-list__img { filter: grayscale(0); }
.jw-gear-list__placeholder {
  width: 56px; height: 56px;
  background: var(--border);
  border-radius: .375rem;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.jw-gear-list__placeholder iconify-icon { font-size: 1.1rem; color: var(--muted); }

.jw-gear-list__body { flex: 1; min-width: 0; }
.jw-gear-list__title {
  font-size: .875rem;
  font-weight: 600;
  color: var(--head);
  margin-bottom: .2rem;
}
.jw-gear-list__desc {
  font-size: .8rem;
  color: var(--dim);
  line-height: 1.55;
}

/* ── 4DAAGSE PAGE ────────────────────────────── */
.jw-4d-section { padding-top: 3.5rem; }
.jw-4d-section--last { padding-bottom: 5rem; }

/* Countdown in page intro */
.jw-4d-countdown {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  margin-top: 2rem;
}
.jw-4d-countdown__unit { display: flex; flex-direction: column; align-items: center; }
.jw-4d-countdown__num {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--head);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.jw-4d-countdown__num--accent { color: var(--accent); }
.jw-4d-countdown__lbl {
  font-size: .65rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  margin-top: .25rem;
}
.jw-4d-countdown__sep {
  font-size: 2rem;
  font-weight: 700;
  color: var(--border);
  line-height: 1;
  margin-top: .1rem;
}

/* Intro grid: tekst + statistieken */
.jw-4d-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
@media (max-width: 680px) {
  .jw-4d-intro-grid { grid-template-columns: 1fr; }
}
.jw-4d-intro-grid__text {
  background: var(--surface);
  padding: 2rem;
}
.jw-4d-intro-grid__text p {
  font-size: .9rem;
  line-height: 1.75;
  color: var(--body);
  margin-bottom: .75rem;
}
.jw-4d-intro-grid__text p:last-child { margin-bottom: 0; }
.jw-4d-heading {
  font-family: Georgia, Cambria, serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--head);
  margin-bottom: 1rem;
}
.jw-4d-stats {
  background: var(--surface);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
}
.jw-4d-stat {
  background: var(--surface);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.jw-4d-stat__num {
  font-family: Georgia, Cambria, serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--head);
  line-height: 1;
}
.jw-4d-stat__lbl {
  font-size: .75rem;
  color: var(--dim);
  line-height: 1.4;
}

/* Detail rijen */
.jw-4d-details {
  border: 1px solid var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
.jw-4d-detail-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.jw-4d-detail-row:last-child { border-bottom: none; }
.jw-4d-detail-row iconify-icon {
  color: var(--accent);
  font-size: 1.1rem;
  flex-shrink: 0;
  margin-top: .1rem;
}
.jw-4d-detail-row div { display: flex; flex-direction: column; gap: .15rem; }
.jw-4d-detail-row__label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
}
.jw-4d-detail-row__value {
  font-size: .875rem;
  color: var(--head);
}

/* Voorbereiding cards */
.jw-4d-prep-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
@media (max-width: 680px) {
  .jw-4d-prep-grid { grid-template-columns: 1fr; }
}
@media (min-width: 681px) and (max-width: 900px) {
  .jw-4d-prep-grid { grid-template-columns: repeat(2, 1fr); }
}
.jw-4d-prep-card { background: var(--surface); display: flex; flex-direction: column; }
.jw-4d-prep-card__placeholder {
  width: 100%; height: 9rem;
  background: var(--border);
  display: flex; align-items: center; justify-content: center;
}
.jw-4d-prep-card__placeholder iconify-icon { font-size: 2rem; color: var(--muted); }
.jw-4d-prep-card__img {
  width: 100%; height: 9rem;
  object-fit: cover; display: block;
  filter: grayscale(1);
  transition: filter .5s;
}
.jw-4d-prep-card:hover .jw-4d-prep-card__img { filter: grayscale(0); }
.jw-4d-prep-card__body { padding: 1.25rem 1.5rem 1.5rem; }
.jw-4d-prep-card__meta {
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent2);
  margin-bottom: .4rem;
}
.jw-4d-prep-card__title {
  font-family: Georgia, Cambria, serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--head);
  margin-bottom: .5rem;
  line-height: 1.3;
}
.jw-4d-prep-card__text {
  font-size: .85rem;
  color: var(--dim);
  line-height: 1.65;
}

/* Dagverslagen */
.jw-4d-days {
  border: 1px solid var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
.jw-4d-day {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.jw-4d-day:last-child { border-bottom: none; }
.jw-4d-day--upcoming { opacity: .6; }
.jw-4d-day__num {
  font-family: Georgia, Cambria, serif;
  font-size: .8rem;
  font-weight: 700;
  color: var(--head);
  white-space: nowrap;
  min-width: 3rem;
}
.jw-4d-day__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .15rem;
  min-width: 0;
}
.jw-4d-day__date {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--accent2);
}
.jw-4d-day__route {
  font-size: .875rem;
  color: var(--head);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 560px) {
  .jw-4d-day__route { white-space: normal; }
}

/* Vorige edities */
.jw-4d-editions {
  border: 1px solid var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
.jw-4d-edition {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  padding: 1.5rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.jw-4d-edition:last-child { border-bottom: none; }
.jw-4d-edition__year {
  font-family: Georgia, Cambria, serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--head);
  min-width: 3.5rem;
  flex-shrink: 0;
}
.jw-4d-edition__body { flex: 1; }
.jw-4d-edition__title {
  font-size: .9rem;
  font-weight: 600;
  color: var(--head);
  margin-bottom: .4rem;
}
.jw-4d-edition__text {
  font-size: .85rem;
  color: var(--dim);
  line-height: 1.65;
}
@media (max-width: 480px) {
  .jw-4d-edition { flex-wrap: wrap; gap: .75rem; }
}

/* ── BERICHTEN ARCHIEF ───────────────────────── */
.jw-archive {
  margin-top: 1.5rem;
  margin-bottom: 5rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
@media (max-width: 767px) { .jw-archive { grid-template-columns: 1fr; } }
@media (min-width: 768px) and (max-width: 1023px) { .jw-archive { grid-template-columns: repeat(2, 1fr); } }

.jw-archive__item {
  background: var(--surface);
  display: flex;
  flex-direction: column;
  transition: background .15s;
}
.jw-archive__item:hover { background: var(--surface-hover); }
.jw-archive__img {
  width: 100%; height: 10rem;
  object-fit: cover; display: block;
  filter: grayscale(1);
  transition: filter .5s;
}
.jw-archive__item:hover .jw-archive__img { filter: grayscale(0); }

/* Placeholder als er geen uitgelichte afbeelding is */
.jw-archive__placeholder {
  width: 100%; height: 10rem;
  background: var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
}
.jw-archive__placeholder iconify-icon {
  font-size: 2rem;
  color: var(--muted);
}

.jw-archive__body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.jw-archive__meta {
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent2);
  margin-bottom: .5rem;
}
.jw-archive__title {
  font-family: Georgia, Cambria, serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--head);
  line-height: 1.3;
  margin-bottom: .5rem;
  transition: color .15s;
}
.jw-archive__item:hover .jw-archive__title { color: var(--accent); }
.jw-archive__excerpt {
  font-size: .85rem;
  color: var(--dim);
  line-height: 1.6;
  flex: 1;
}

/* Paginering */
.jw-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 2rem 0;
  margin-bottom: 5rem;
}
.jw-pagination__btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--head);
  border: 1px solid var(--border);
  padding: .5rem 1rem;
  border-radius: .5rem;
  transition: border-color .15s, color .15s;
}
.jw-pagination__btn:hover { border-color: var(--accent); color: var(--accent); }
.jw-pagination__info { font-size: .8rem; color: var(--muted); }

/* ── SINGLE POST ─────────────────────────────── */
.jw-single { padding: 3.5rem 0 5rem; }
.jw-single__back {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .8rem; color: var(--dim); margin-bottom: 2rem;
  transition: color .15s;
}
.jw-single__back:hover { color: var(--head); }
.jw-single__meta {
  font-size: .7rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent2); margin-bottom: .75rem;
}
.jw-single__title {
  font-family: Georgia, serif; font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700; color: var(--head); line-height: 1.2; margin-bottom: 1.5rem;
}
.jw-single__thumbnail {
  width: 100%; max-height: 28rem; object-fit: cover;
  border-radius: .75rem; margin-bottom: 2.5rem;
}
.jw-single__content {
  max-width: 42rem; font-size: 1.0125rem; line-height: 1.8; color: var(--body);
}
.jw-single__content h2,
.jw-single__content h3 { font-family: Georgia, serif; color: var(--head); margin: 2rem 0 .75rem; }
.jw-single__content p  { margin-bottom: 1.25rem; }
.jw-single__content a  { color: var(--accent); text-decoration: underline; }
.jw-single__content ul,
.jw-single__content ol { padding-left: 1.5rem; margin-bottom: 1.25rem; }
.jw-single__content li { margin-bottom: .35rem; }
.jw-single__content blockquote {
  border-left: 3px solid var(--accent); padding-left: 1.25rem;
  margin: 1.5rem 0; color: var(--dim); font-style: italic;
}

/* ── PAGE ────────────────────────────────────── */
.jw-page { padding: 3.5rem 0 5rem; max-width: 42rem; }
.jw-page__title {
  font-family: Georgia, serif; font-size: 2rem; font-weight: 700;
  color: var(--head); margin-bottom: 1.5rem;
}
.jw-page__content { font-size: 1rem; line-height: 1.8; color: var(--body); }
.jw-page__content p  { margin-bottom: 1.25rem; }
.jw-page__content a  { color: var(--accent); text-decoration: underline; }

/* ── OVER MIJ PAGE ───────────────────────────── */
.jw-about-page {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 3rem;
  padding-top: 3rem;
}
@media (max-width: 768px) {
  .jw-about-page { grid-template-columns: 1fr; gap: 2rem; }
}

/* Bio */
.jw-about-page__heading {
  font-family: Georgia, Cambria, serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--head);
  margin-bottom: 1.25rem;
}
.jw-about-page__bio p {
  font-size: .9375rem;
  line-height: 1.8;
  color: var(--body);
  margin-bottom: 1.1rem;
}
.jw-about-page__bio p:last-child { margin-bottom: 0; }

/* Aside */
.jw-about-page__aside {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}

/* Avatar */
.jw-about-page__avatar-wrap {
  border-radius: .75rem;
  overflow: hidden;
  border: 1px solid var(--border);
}
.jw-about-page__avatar {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  filter: grayscale(1);
  transition: filter .5s;
}
.jw-about-page__avatar-wrap:hover .jw-about-page__avatar { filter: grayscale(0); }

/* Facts */
.jw-about-page__facts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border-radius: .75rem;
  overflow: hidden;
}
.jw-about-page__fact {
  background: var(--surface);
  padding: 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.jw-about-page__fact-num {
  font-family: Georgia, Cambria, serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--head);
  line-height: 1.1;
}
.jw-about-page__fact-lbl {
  font-size: .72rem;
  color: var(--dim);
  line-height: 1.4;
}

/* Contact */
.jw-about-page__contact {
  border: 1px solid var(--border);
  border-radius: .75rem;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.jw-about-page__contact-label {
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--dim);
}
.jw-about-page__contact-link {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  color: var(--body);
  transition: color .15s;
}
.jw-about-page__contact-link:hover { color: var(--accent); }
.jw-about-page__contact-link iconify-icon { color: var(--accent); font-size: 1rem; flex-shrink: 0; }

/* Timeline */
.jw-about-page__timeline { padding: 3rem 0 5rem; }

/* ── WANDELINGEN PAGE ────────────────────────── */
.jw-wandelingen-grid {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
  gap: 1px;
  background: var(--border);
  border-radius: .75rem;
  overflow: hidden;
  margin-bottom: 5rem;
}
.jw-wandeling-card {
  background: var(--surface);
  display: flex;
  flex-direction: column;
  transition: background .15s;
}
.jw-wandeling-card:hover { background: var(--surface-hover); }
.jw-wandeling-card__img {
  width: 100%; height: 10rem;
  object-fit: cover; display: block;
  filter: grayscale(1);
  transition: filter .5s;
}
.jw-wandeling-card:hover .jw-wandeling-card__img { filter: grayscale(0); }
.jw-wandeling-card__placeholder {
  width: 100%; height: 10rem;
  background: var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
}
.jw-wandeling-card__placeholder iconify-icon { font-size: 2rem; color: var(--muted); }
.jw-wandeling-card__body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.jw-wandeling-card__meta {
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent2);
  margin-bottom: .4rem;
}
.jw-wandeling-card__title {
  font-family: Georgia, Cambria, serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--head);
  line-height: 1.3;
  margin-bottom: .5rem;
  transition: color .15s;
}
.jw-wandeling-card:hover .jw-wandeling-card__title { color: var(--accent); }
.jw-wandeling-card__desc {
  font-size: .85rem;
  color: var(--dim);
  line-height: 1.6;
  flex: 1;
}
.jw-wandeling-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1rem;
  padding-top: .75rem;
  border-top: 1px solid var(--border);
}
.jw-wandeling-card__stats {
  display: flex;
  gap: .75rem;
  font-size: .75rem;
  color: var(--muted);
}
.jw-wandeling-card__stat {
  display: flex;
  align-items: center;
  gap: .25rem;
}
.jw-wandeling-card__stat iconify-icon { font-size: .85rem; color: var(--dim); }

/* Totals bar */
.jw-wandelingen-totals {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  padding: 1.5rem 0 2.5rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2rem;
}
.jw-wandelingen-total {
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.jw-wandelingen-total__num {
  font-family: Georgia, Cambria, serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--head);
  line-height: 1;
}
.jw-wandelingen-total__lbl {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--dim);
}
