    body { background: #f3e6cc; }
    .page-wrap { background-color: #f3e6cc;max-width: 1200px; margin: 0 auto; padding: 0 12px 48px; }

    .blog-layout { display: grid; grid-template-columns: 300px 1fr; gap: 24px; align-items: start; }
    @media (max-width: 900px) { .blog-layout { grid-template-columns: 1fr; } }

    .content-card {
      background: #fff; border: 1px solid #e8e8ef; border-radius: 12px;
      box-shadow: 0 6px 20px rgba(0,0,0,.06); padding: 18px; margin-top: 18px;
    }

    /* Sidebar – modern + drawer */
    .sidebar-modern {
      background: #ffffff; border: 1px solid #e6e8ee; border-radius: 12px; padding: 16px;
      box-shadow: 0 6px 20px rgba(0,0,0,.06); position: sticky; top: 90px; z-index: 10;
    }
    .sidebar-modern .sidebar-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
    .sidebar-modern h2 { font-size: 1.1rem; margin: 0; font-weight: 700; color: #0a2a4a; }
    .sidebar-modern .sidebar-close { display: none; background: none; border: none; font-size: 28px; line-height: 1; cursor: pointer; color: #222; }

    .form-group { margin-top: 14px; }
    .form-group label { display: block; font-weight: 600; margin-bottom: 6px; color: #222; }
    .help { font-size: .85rem; color: #6b7280; }

    .select-wrap { position: relative; }
    .select-wrap select {
      width: 100%; appearance: none; background: #fff; border: 1px solid #d8dbe4; border-radius: 10px;
      padding: 10px 36px 10px 12px; font-size: 0.98rem; line-height: 1.2;
    }
    .select-wrap .chev {
      position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
      pointer-events: none; color: #6b7280; font-size: 0.9rem;
    }

    .btn-primary, .btn-reset, .btn-outline {
      width: 100%; padding: 11px 12px; border-radius: 10px; font-weight: 700; cursor: pointer;
      border: 1px solid transparent; font-size: .95rem;
    }
    .btn-primary { background: #f4cd00; color: #fff; margin-top: 12px; }
    .btn-primary:hover { background: #1bd3c6; }
    .btn-reset { background: #f4cd00; color: #fff; margin-top: 10px; }
    .btn-reset:hover { background: #1bd3c6; }

    .filters-trigger { display: none; justify-content: flex-end; margin: 10px 0 14px; }
    .btn-outline { background: #f4cd00; color: #fff; margin-top: 12px; }

    @media (max-width: 900px) {
      .filters-trigger { display: flex; }
      .sidebar-modern {
        position: fixed; inset: 0 0 0 auto; width: min(90vw, 360px); height: 100vh; top: 0; right: -100%;
        border-radius: 0; box-shadow: -8px 0 24px rgba(0,0,0,.2); transition: right .28s ease; padding: 18px 16px 22px; overflow-y: auto; z-index: 15;
      }
      .sidebar-modern.open { right: 0; }
      .sidebar-modern .sidebar-close { display: inline-block; }

      body.filters-open { overflow: hidden; }
      body.filters-open header { display: none; }
      body.filters-open .page-wrap { padding-top: 0; }

      .filters-backdrop {
        position: fixed; inset: 0; background: rgba(0,0,0,.35);
        opacity: 0; pointer-events: none; transition: opacity .2s ease; z-index: 14;
      }
      .filters-backdrop.show { opacity: 1; pointer-events: auto; }
    }

    /* Bloglijst */
    .blog-lijst { list-style: none; padding: 0; margin: 0; }
    .blog-item { display: flex; align-items: flex-start; justify-content: space-between; gap: 15px; border-bottom: 1px solid #eee; padding: 14px 4px; }
    .blog-item:last-child { border-bottom: none; }
    .blog-tekst { flex: 1; }
    .blog-tekst .meta { font-size: 0.85rem; color: #777; margin-bottom: 6px; }
    .blog-tekst h2 { font-size: 1.1rem; margin: 0; line-height: 1.35; }
    .blog-tekst h2 a { text-decoration: none; color: #0a2a4a; }
    .blog-tekst h2 a:hover { text-decoration: underline; }
    .blog-thumbnail img { width: 110px; height: 74px; object-fit: cover; border-radius: 8px; border: 1px solid #eee; }

    .badge { display: inline-block; background-color:#cd95ccbd; color: white; padding: 4px 8px; font-size: .85rem; border-radius: 12px; margin: 2px; text-decoration: none; }

    /* Intro & categorie-tegels */
    .lead { font-size: 1.05rem; color: #384250; line-height: 1.65; }
    .grid-cats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 0; margin: 12px 0 0; list-style: none; }
    .grid-cats a { display: block; background: #fff; border: 1px solid #e8e8ef; border-radius: 10px; padding: 12px; text-decoration: none; color: #0a2a4a; box-shadow: 0 2px 10px rgba(0,0,0,.04); }
    .grid-cats strong { display: block; margin-bottom: 4px; }
    @media (max-width: 900px){ .grid-cats { grid-template-columns: 1fr; } }
    /* Full-width intro boven de grid */
.intro-card {
  margin-top: 18px;margin-bottom: 20px;
}

/* Zorg dat de eerste rij van de grid (filters + lijst) bovenaan gelijk staat */
.blog-layout {
  align-items: start; /* staat er al, maar expliciet is prima */
}

/* Optioneel: iets minder ruimte boven de lijst-kaart */
.posts-card {
  margin-top: 0;
}
body {
  margin: 0;
}

.page-wrap {
  width: min(1200px, 100%);
  margin-left: auto !important;
  margin-right: auto !important;
}
/* ========== 1) Sticky sidebar blijft mee scrollen ========== */
/* Sticky werkt NIET als een parent overflow/transform heeft */
main, .page-wrap, .blog-layout {
  overflow: visible !important;
  transform: none !important;
}

/* (jij had 'm al sticky, maar dit forceert de goede setup) */
.sidebar-modern{
  position: sticky;
  top: 90px;          /* pas aan naar hoogte van je header */
  align-self: start;  /* belangrijk in grid/flex context */
}

/* ========== 2) Sidebar en “Laatste blog berichten” exact gelijk starten ========== */
/* Waarschijnlijk komt het verschil door .content-card { margin-top: 18px; } */
.blog-layout .content-card{
  margin-top: 0 !important;     /* eerste kaart in de grid flush bovenaan */
}

/* Als je meerdere cards onder elkaar in de rechterkolom hebt: geef die wél ruimte */
.blog-layout .content-card + .content-card{
  margin-top: 18px;
}
/* Desktop: kolommen even hoog (sidebar-col strecht mee) */
.blog-layout{ align-items: stretch; }

.sidebar-col{ align-self: stretch; }

/* Sticky blijft netjes */
.sidebar-modern{
  position: sticky;
  top: 90px;
  align-self: start;
}

/* Zorg dat beide kolommen exact gelijk starten */
.blog-layout > *{ margin-top: 0; }

/* Mobiel: drawer gedrag behouden */
@media (max-width: 900px){
  .blog-layout{ align-items: start; }
  .sidebar-col{ align-self: auto; }
}

/* Forceer: altijd 1 rij: sidebar links, posts rechts */
.blog-layout{
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 24px;
  grid-template-areas: "sidebar posts";
  align-items: start;
}

.sidebar-col{ grid-area: sidebar; }
.posts-col{ grid-area: posts; }

/* Sticky/floating */
.sidebar-modern{
  position: sticky;
  top: 90px;       /* pas aan naar je headerhoogte */
  align-self: start;
}

/* Mobiel: 1 kolom */
@media (max-width: 900px){
  .blog-layout{
    grid-template-columns: 1fr;
    grid-template-areas:
      "posts";
  }
  /* sidebar blijft je drawer (fixed) via je bestaande CSS */
}

/* ==============================
   BLOG LAYOUT (OVERRIDE)
   Plak dit HELEMAAL ONDERAAN
   ============================== */

/* Basis */
body{
  margin: 0;
  background: #f3e6cc;
}

.page-wrap{
  width: min(1200px, 100%);
  margin: 0 auto;
  padding: 0 12px 48px;
  background-color: #f3e6cc;
}

/* Sticky kan breken door overflow/transform op parents */
main, .page-wrap, .blog-layout{
  overflow: visible !important;
  transform: none !important;
}

/* ==============================
   GRID: sidebar links, posts rechts
   ============================== */
.blog-layout{
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 24px;
  align-items: start;

  /* Forceer placement (voorkomt “sidebar zakt naar beneden”) */
  grid-template-areas: "sidebar posts";
}

/* Alleen als je de wrappers gebruikt:
   <aside class="sidebar-col"> en <section class="posts-col"> */
.sidebar-col{ grid-area: sidebar; }
.posts-col{ grid-area: posts; }

/* Extra safety: zelfs zonder areas blijft het goed */
.blog-layout > .sidebar-modern{ grid-column: 1; grid-row: 1; }
.blog-layout > .posts-card{ grid-column: 2; grid-row: 1; }

/* ==============================
   Cards / uitlijning bovenkant
   ============================== */
.content-card{
  background: #fff;
  border: 1px solid #e8e8ef;
  border-radius: 12px;
  box-shadow: 0 6px 20px rgba(0,0,0,.06);
  padding: 18px;
  margin-top: 18px;
}

/* Zorg dat intro en grid netjes starten */
.intro-card{
  margin-top: 18px;
  margin-bottom: 20px;
}

/* Zorg dat de posts-card en sidebar exact gelijk starten */
.posts-card{
  margin-top: 0 !important;
}

/* Sidebar “kaart” zelf heeft geen extra margin-top nodig */
.sidebar-modern{
  margin-top: 0 !important;
}

/* ==============================
   Sidebar: sticky / floating desktop
   ============================== */
.sidebar-modern{
  background: #fff;
  border: 1px solid #e6e8ee;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 6px 20px rgba(0,0,0,.06);

  position: sticky;
  top: 90px;        /* pas aan naar je headerhoogte */
  z-index: 10;

  align-self: start;
}

/* ==============================
   Mobiel: 1 kolom, sidebar wordt drawer (jouw bestaande gedrag)
   ============================== */
@media (max-width: 900px){
  .blog-layout{
    grid-template-columns: 1fr;
    grid-template-areas:
      "posts";
  }

  .filters-trigger{
    display: flex;
    justify-content: flex-end;
    margin: 10px 0 14px;
  }

  .sidebar-modern{
    position: fixed;
    inset: 0 0 0 auto;
    width: min(90vw, 360px);
    height: 100vh;
    top: 0;
    right: -100%;
    border-radius: 0;
    box-shadow: -8px 0 24px rgba(0,0,0,.2);
    transition: right .28s ease;
    padding: 18px 16px 22px;
    overflow-y: auto;
    z-index: 15;
  }

  .sidebar-modern.open{ right: 0; }

  .sidebar-modern .sidebar-close{ display: inline-block; }

  .filters-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.35);
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
    z-index: 14;
  }

  .filters-backdrop.show{
    opacity: 1;
    pointer-events: auto;
  }

  body.filters-open{
    overflow: hidden;
  }
  body.filters-open header{
    display: none;
  }
  body.filters-open .page-wrap{
    padding-top: 0;
  }
}
/* =========================
   BLOG-OVERZICHT FIX (main.page-wrap)
   ========================= */
@media (max-width: 768px) {

  /* zet de blog-main terug naar normaal gedrag */
  main.page-wrap{
    display: block !important;   /* weg met flex/align-items */
    padding: 0 12px 48px !important;
    max-width: 1200px;
    margin: 0 auto;
    box-sizing: border-box;
  }

  /* intro-card en andere cards netjes binnen de wrap */
  main.page-wrap .content-card{
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    box-sizing: border-box;
  }

  /* als je intro-card 'net' smaller/meer gecentreerd wil (optioneel) */
  main.page-wrap .content-card.intro-card{
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
  }
}

