/* ============================================================
   SCHOLENKIEZER — Amsterdam Scholenkiezer
   Stijlrichting: "Klassiek Amsterdamse School" (design-voorstel
   Claude Design, juni 2026). Warm, zakelijk, mobiel-eerst.
   Palet: baksteen / oker / glasgroen / inkt / crème.
   Typografie: Bricolage Grotesque (koppen) + Hanken Grotesk (tekst).
   ============================================================ */

:root {
  /* v2-palet (Claude Design, 11-6-2026): verweerde Amsterdamse School-tonen —
     aubergine-baksteen, stenige crème, getemperde oker, verdiept glasgroen */
  --creme: #e6dfce;
  --creme-licht: #f4efe1;
  --kaart: #fffdf6;
  --lijn: #e2d6be;
  --lijn-sterk: #d9c9b0;
  --inkt: #2b211c;
  --tekst-zacht: #6b5e50;
  --muted: #9a8b79;
  --baksteen: #7c3a34;
  --baksteen-donker: #5d2b27;
  --baksteen-tint: #e7d3c2;
  --baksteen-licht: #f1e6dd;
  --oker: #b07c38;
  --oker-tint: #ead9bc;
  --glasgroen: #2c625d;
  --glasgroen-tint: #9fc0bc;
  --glasgroen-licht: #e2ebe9;
  --whatsapp: #5bb073;
  --schaduw: 0 1px 2px rgba(43, 33, 28, .06), 0 8px 28px -10px rgba(43, 33, 28, .16);
  --radius: 14px;
  --radius-klein: 9px;
  --font-kop: "Bricolage Grotesque", "Segoe UI", sans-serif;
  --font-ui: "Hanken Grotesk", system-ui, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-ui);
  background: var(--creme);
  color: var(--inkt);
  line-height: 1.55;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

::selection { background: var(--baksteen); color: #fff; }

/* ---------- typografie ---------- */
h1, h2, h3 { font-family: var(--font-kop); font-weight: 700; line-height: 1.1; letter-spacing: -.015em; }
h1 { font-size: clamp(1.9rem, 6vw, 3.2rem); }
h2 { font-size: clamp(1.3rem, 3.4vw, 1.9rem); }
h3 { font-size: 1.1rem; }
a { color: var(--baksteen); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--baksteen-donker); }
small, .klein { font-size: .82rem; color: var(--tekst-zacht); }

/* drie Andreaskruisen als ruitjes */
.ruitjes { display: inline-flex; gap: .28em; align-items: center; }
.ruitjes i {
  width: .5em; height: .5em; transform: rotate(45deg); border-radius: 1px; display: inline-block;
}
.ruitjes i:nth-child(1) { background: var(--baksteen); }
.ruitjes i:nth-child(2) { background: var(--oker); }
.ruitjes i:nth-child(3) { background: var(--glasgroen); }

/* ---------- header ---------- */
.site-kop {
  position: sticky; top: 0; z-index: 1100;
  background: color-mix(in srgb, var(--creme-licht) 92%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--lijn);
}
.site-kop-inner {
  max-width: 1240px; margin: 0 auto; padding: .6rem 1rem;
  display: flex; align-items: center; gap: .9rem; flex-wrap: wrap;
}
.wordmark {
  font-family: var(--font-kop); font-weight: 800; font-size: 1.02rem;
  letter-spacing: .14em; text-decoration: none; color: var(--inkt);
  display: inline-flex; align-items: center; gap: .55rem; white-space: nowrap;
}
.wordmark .ruitjes { font-size: .85rem; }
.wordmark .sub {
  display: none; font-family: var(--font-ui); font-weight: 500; letter-spacing: 0;
  color: var(--muted); font-size: .8rem;
}
@media (min-width: 720px) { .wordmark .sub { display: inline; } }
.site-nav { margin-left: auto; display: flex; gap: .15rem; align-items: center; flex-wrap: wrap; }
.site-nav a {
  color: var(--tekst-zacht); text-decoration: none; font-size: .88rem; font-weight: 600;
  padding: .3rem .6rem; border-radius: 999px;
}
.site-nav a:hover { color: var(--inkt); background: var(--creme); }
.site-nav a.actief { color: var(--kaart); background: var(--inkt); }

/* ---------- knoppen ---------- */
.knop {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  font-family: var(--font-ui); font-weight: 700; font-size: .95rem;
  padding: .72rem 1.3rem; border-radius: var(--radius-klein); cursor: pointer;
  border: 1.5px solid var(--baksteen); background: var(--baksteen); color: #fff;
  text-decoration: none; transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
  box-shadow: 0 2px 0 var(--baksteen-donker);
}
.knop:hover { background: var(--baksteen-donker); border-color: var(--baksteen-donker); color: #fff; transform: translateY(-1px); }
.knop.secundair {
  background: var(--kaart); color: var(--inkt); border-color: var(--lijn-sterk); box-shadow: none;
}
.knop.secundair:hover { border-color: var(--inkt); background: var(--kaart); color: var(--inkt); transform: none; }
.knop.klein { padding: .38rem .85rem; font-size: .82rem; box-shadow: none; }
.knop.whatsapp { background: var(--whatsapp); border-color: var(--whatsapp); box-shadow: 0 2px 0 #46905c; }
.knop.whatsapp:hover { background: #4c9c64; border-color: #4c9c64; }

/* ---------- hero (landing) ---------- */
.hero-poort {
  /* metselwerk uit design v2: toonbanden per steenlaag, mortelvoegen en
     diagonale verwering (lichter rechtsboven, donkerder linksonder) */
  background: var(--baksteen);
  background-image:
    linear-gradient(100deg, rgba(0, 0, 0, .20), transparent 48%),
    radial-gradient(circle at 82% 12%, rgba(255, 250, 240, .07), transparent 42%),
    repeating-linear-gradient(0deg, rgba(255, 250, 240, .045) 0 14px, rgba(0, 0, 0, .05) 14px 15px, transparent 15px 30px),
    repeating-linear-gradient(0deg, rgba(0, 0, 0, .16) 0 1.5px, transparent 1.5px 30px),
    repeating-linear-gradient(90deg, rgba(0, 0, 0, .13) 0 1.5px, transparent 1.5px 58px);
  color: #f5eedd;
  text-align: center;
  padding: clamp(2.2rem, 7vw, 4.5rem) 1.2rem clamp(2.4rem, 6vw, 4rem);
  position: relative;
  overflow: hidden;
}
.hero-poort .boog {
  width: min(190px, 42vw); margin: 0 auto 1.4rem; display: block; opacity: .96;
}
.hero-poort h1 { color: #fffdf6; max-width: 16ch; margin: 0 auto .7rem; }
.hero-poort p.intro {
  max-width: 46ch; margin: 0 auto 1.6rem; color: #ecd9c9; font-size: 1.05rem;
}
.hero-acties { display: flex; flex-direction: column; gap: .7rem; max-width: 360px; margin: 0 auto; }
@media (min-width: 720px) { .hero-acties { flex-direction: row; justify-content: center; max-width: none; } }
.hero-poort .knop { box-shadow: 0 2px 0 rgba(0, 0, 0, .25); }
.hero-poort .knop.primair { background: var(--oker); border-color: var(--oker); color: #2b211c; }
.hero-poort .knop.primair:hover { background: #b87c2e; border-color: #b87c2e; }
.hero-poort .knop.secundair { background: #fffdf6; border-color: #fffdf6; color: var(--inkt); }

.trustline {
  display: flex; justify-content: center; gap: .6rem; flex-wrap: wrap;
  padding: 1rem 1.2rem; font-size: .9rem; color: var(--tekst-zacht);
}
.trustline strong { color: var(--baksteen); }
.trustline span + span::before { content: "·"; margin-right: .6rem; color: var(--muted); }

/* keuzetabs landing */
.deuren {
  max-width: 980px; margin: 1.6rem auto 0; padding: 0 1rem;
  display: grid; grid-template-columns: 1fr; gap: 1.1rem;
}
@media (min-width: 680px) { .deuren { grid-template-columns: 1fr 1fr; } }
.deur {
  position: relative; display: block; text-decoration: none; color: var(--inkt);
  background: var(--kaart); border: 1px solid var(--lijn);
  border-radius: 90px 90px var(--radius) var(--radius);
  padding: 2.4rem 1.6rem 1.7rem; text-align: center;
  box-shadow: var(--schaduw);
  transition: transform .18s ease, box-shadow .18s ease;
}
.deur:hover { transform: translateY(-4px); box-shadow: 0 2px 3px rgba(43,33,28,.07), 0 20px 46px -14px rgba(43,33,28,.3); }
.deur .huisnummer {
  display: inline-block; font-family: var(--font-kop); font-weight: 700; font-size: .9rem;
  color: #fffdf6; border-radius: 7px; padding: .18rem .75rem; margin-bottom: .9rem;
}
.deur.basis .huisnummer { background: var(--glasgroen); }
.deur.middelbaar .huisnummer { background: var(--oker); color: #2b211c; }
.deur h2 { margin-bottom: .45rem; }
.deur p { color: var(--tekst-zacht); font-size: .93rem; max-width: 36ch; margin: 0 auto 1.2rem; }
.deur .knop { pointer-events: none; }

.gevelrij { display: block; width: 100%; height: auto; margin-top: 2.6rem; opacity: .85; }
/* mobiel: homepage compact houden — decoratie en details wijken voor de kern */
@media (max-width: 680px) {
  .gevelrij { display: none; }
  .hero-poort { padding: 1.8rem 1rem 2rem; }
  .hero-poort .boog { width: 120px; margin-bottom: 1rem; }
  .hero-poort p.intro { font-size: .95rem; margin-bottom: 1.2rem; }
  .landing-feiten { padding: 1.6rem 1rem; gap: .7rem; }
  .feit .cijfer { font-size: 1.5rem; }
  .feit .label { font-size: .78rem; }
  .deur { padding: 1.8rem 1.3rem 1.4rem; border-radius: 64px 64px var(--radius) var(--radius); }
  .deur p { display: none; }
}

.landing-feiten {
  max-width: 980px; margin: 0 auto; padding: 2.4rem 1rem;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem;
}
@media (min-width: 720px) { .landing-feiten { grid-template-columns: repeat(4, 1fr); } }
.feit { border-top: 3px solid var(--baksteen); padding-top: .7rem; }
.feit:nth-child(2) { border-top-color: var(--oker); }
.feit:nth-child(3) { border-top-color: var(--glasgroen); }
.feit:nth-child(4) { border-top-color: var(--inkt); }
.feit .cijfer { font-family: var(--font-kop); font-weight: 800; font-size: 2rem; line-height: 1; }
.feit .label { color: var(--tekst-zacht); font-size: .85rem; margin-top: .25rem; }

/* ---------- tool-layout (mobiel-eerst) ---------- */
.tool-main { max-width: 1500px; margin: 0 auto; padding: .8rem .9rem 2rem; }
.tool-titelblok { padding: .8rem .1rem .6rem; display: flex; flex-wrap: wrap; align-items: baseline; gap: .4rem 1.2rem; }
.tool-titelblok h1 { font-size: clamp(1.5rem, 5vw, 2.3rem); }
.tool-titelblok .telling { color: var(--tekst-zacht); font-size: .9rem; }

.tool-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; align-items: start; }
@media (min-width: 1000px) { .tool-grid { grid-template-columns: 300px minmax(0, 1fr); } }

/* ---------- filters: mobiel een uitklapblad, desktop een zijbalk ---------- */
.filters {
  background: var(--kaart); border: 1px solid var(--lijn); border-radius: var(--radius);
  box-shadow: var(--schaduw); padding: 1rem;
}
@media (min-width: 1000px) {
  .filters { position: sticky; top: 60px; max-height: calc(100vh - 80px); overflow-y: auto; scrollbar-width: thin; }
  .filters-toggle { display: none; }
}
@media (max-width: 999px) {
  .filters { display: none; }
  .filters.open { display: block; }
}
.filters-toggle {
  width: 100%; justify-content: space-between;
}
.filters h2 { font-size: 1rem; display: flex; justify-content: space-between; align-items: center; }
.filterblok { border-top: 1px solid var(--lijn); margin-top: .85rem; padding-top: .85rem; }
.filterblok > label.bloklabel, .filterblok > span.bloklabel {
  font-weight: 700; font-size: .78rem; letter-spacing: .07em; text-transform: uppercase;
  color: var(--muted); display: block; margin-bottom: .45rem;
}

input[type="text"], input[type="search"], input[type="number"], select {
  width: 100%; padding: .6rem .75rem; font: inherit; font-size: .93rem;
  border: 1px solid var(--lijn-sterk); border-radius: var(--radius-klein);
  background: #fff; color: var(--inkt);
}
input:focus-visible, select:focus-visible, button:focus-visible {
  outline: 2px solid var(--glasgroen); outline-offset: 1px;
}

.chips { display: flex; flex-wrap: wrap; gap: .4rem; }
.chips.scrollbaar {
  flex-wrap: nowrap; overflow-x: auto; padding-bottom: .3rem; scrollbar-width: none;
}
.chips.scrollbaar::-webkit-scrollbar { display: none; }
.chip {
  font-size: .84rem; font-weight: 600; padding: .34rem .8rem; border-radius: 999px;
  border: 1px solid var(--lijn-sterk); background: var(--kaart); color: var(--inkt);
  cursor: pointer; user-select: none; white-space: nowrap; transition: all .12s ease;
  font-family: var(--font-ui);
}
.chip:hover { border-color: var(--inkt); }
.chip.aan { background: var(--inkt); color: var(--creme-licht); border-color: var(--inkt); }

.check-rij { display: flex; align-items: center; gap: .5rem; font-size: .9rem; padding: .2rem 0; cursor: pointer; }
.check-rij input { accent-color: var(--baksteen); width: 16px; height: 16px; cursor: pointer; flex: none; }

/* van/tot-invoer (schoolweging) */
.vantot { display: flex; align-items: center; gap: .5rem; }
.vantot input { width: 5.2rem; text-align: center; }
.vantot .tot { color: var(--muted); font-size: .85rem; }

.range-rij { display: flex; align-items: center; gap: .6rem; font-size: .85rem; }
input[type="range"] { flex: 1; accent-color: var(--baksteen); min-height: 28px; }
.range-waarde { min-width: 3.4rem; text-align: right; font-variant-numeric: tabular-nums; font-weight: 700; }

/* adres-autocomplete */
.adres-wrap { position: relative; }
.suggesties {
  position: absolute; left: 0; right: 0; top: 100%; z-index: 50;
  background: #fff; border: 1px solid var(--lijn-sterk); border-radius: var(--radius-klein);
  box-shadow: var(--schaduw); list-style: none; max-height: 240px; overflow-y: auto;
}
.suggesties li { padding: .55rem .75rem; font-size: .89rem; cursor: pointer; }
.suggesties li:hover, .suggesties li.actief { background: var(--creme-licht); }

/* ---------- resultaten ---------- */
.resultaten-kop {
  display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; padding-bottom: .7rem;
}
.resultaten-kop .aantal { font-weight: 800; font-family: var(--font-kop); font-size: 1.1rem; }
.sorteer { margin-left: auto; display: flex; align-items: center; gap: .45rem; font-size: .86rem; }
.sorteer select { width: auto; padding: .35rem .6rem; }

.weergave-toggle { display: flex; border: 1px solid var(--lijn-sterk); border-radius: 999px; overflow: hidden; background: var(--kaart); }
.weergave-toggle button {
  font: inherit; font-size: .82rem; font-weight: 700; border: 0; background: transparent;
  padding: .4rem .95rem; cursor: pointer; color: var(--tekst-zacht);
}
.weergave-toggle button.aan { background: var(--inkt); color: var(--creme-licht); }

#kaart {
  height: 420px; border-radius: var(--radius); border: 1px solid var(--lijn-sterk);
  box-shadow: var(--schaduw); margin-bottom: 1rem; z-index: 1;
}
@media (max-width: 640px) { #kaart { height: 320px; } }
.leaflet-container { font-family: var(--font-ui); background: var(--glasgroen-licht); }
.leaflet-popup-content-wrapper { border-radius: 10px; }

.schoollijst { display: grid; gap: .8rem; }

/* schoolkaart met ruit-tegel */
.schoolkaart {
  background: var(--kaart); border: 1px solid var(--lijn);
  border-radius: var(--radius); box-shadow: var(--schaduw); padding: .95rem 1.05rem;
  display: grid; gap: .5rem;
  animation: kaart-in .25s ease both;
}
@keyframes kaart-in { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; } }

.schoolkaart .kop-rij { display: flex; align-items: flex-start; gap: .7rem; }
.tegel {
  flex: none; width: 46px; height: 46px; border-radius: 10px;
  display: grid; place-items: center;
  background:
    repeating-linear-gradient(45deg, transparent 0 6px, rgba(43, 33, 28, .055) 6px 7px),
    var(--baksteen-licht);
  border: 1px solid var(--lijn);
}
.tegel i { width: 13px; height: 13px; transform: rotate(45deg); border-radius: 2px; background: var(--baksteen); display: block; }
.schoolkaart:nth-child(3n+2) .tegel { background-color: var(--glasgroen-licht); }
.schoolkaart:nth-child(3n+2) .tegel i { background: var(--glasgroen); }
.schoolkaart:nth-child(3n) .tegel { background-color: var(--oker-tint); }
.schoolkaart:nth-child(3n) .tegel i { background: var(--oker); }

.schoolkaart .kop-tekst { min-width: 0; flex: 1; }
.schoolkaart h3 { font-size: 1.1rem; line-height: 1.2; }
.schoolkaart h3 a { color: inherit; text-decoration: none; }
.schoolkaart h3 a:hover { color: var(--baksteen); }
.schoolkaart .adres { color: var(--tekst-zacht); font-size: .85rem; margin-top: .1rem; }
.schoolkaart .afstand {
  flex: none; font-weight: 800; font-variant-numeric: tabular-nums;
  font-size: .9rem; color: var(--glasgroen); white-space: nowrap;
}

.badges { display: flex; flex-wrap: wrap; gap: .35rem; }
.badge {
  font-size: .74rem; font-weight: 600; letter-spacing: .01em;
  padding: .18rem .6rem; border-radius: 999px; border: 1px solid var(--lijn-sterk);
  background: var(--creme-licht); color: var(--tekst-zacht);
}
.badge.concept { background: var(--glasgroen-licht); border-color: var(--glasgroen-tint); color: var(--glasgroen); }
.badge.niveau { background: var(--oker-tint); border-color: #d9b87a; color: #7d5414; }
.badge.kenmerk { background: var(--baksteen-licht); border-color: var(--baksteen-tint); color: var(--baksteen); }

.badge.oordeel-goed { background: #ddebdd; border-color: #4e7d52; color: #2e5430; }
.badge.oordeel-voldoende { background: var(--glasgroen-licht); border-color: var(--glasgroen-tint); color: var(--glasgroen); }
.badge.oordeel-onvoldoende { background: #f6e3c8; border-color: var(--oker); color: #7d5414; }
.badge.oordeel-zeerzwak { background: #f3d8cd; border-color: var(--baksteen); color: var(--baksteen-donker); }
.badge.oordeel-geen { background: transparent; border-style: dashed; color: var(--muted); }

.stat-rij {
  display: flex; flex-wrap: wrap; gap: .4rem 1.4rem; align-items: baseline;
  border-top: 1px dashed var(--lijn); padding-top: .55rem; font-size: .88rem;
}
.stat { display: flex; align-items: baseline; gap: .4rem; }
.stat .w { font-family: var(--font-kop); font-weight: 800; font-size: 1.04rem; font-variant-numeric: tabular-nums; }
.stat .l { color: var(--muted); font-size: .78rem; }
.geen-data { color: var(--muted); font-style: italic; font-size: .85rem; }

/* uitstroombalk: warm (praktijk/vmbo) -> koel (havo/vwo), duidelijk
   onderscheidbaar, geen goed/fout-kleuren */
.uitstroom { display: grid; gap: .3rem; }
.uitstroom .balk { display: flex; height: 15px; border-radius: 5px; overflow: hidden; border: 1px solid var(--lijn-sterk); }
.uitstroom .balk span { display: block; height: 100%; }
.uitstroom .legenda { display: flex; flex-wrap: wrap; gap: .15rem .8rem; font-size: .74rem; color: var(--tekst-zacht); }
.uitstroom .legenda i { display: inline-block; width: 10px; height: 10px; border-radius: 2px; margin-right: .3rem; vertical-align: -1px; }

.adv-vso { background: #b6aa97; }
.adv-pro { background: #8d8472; }
.adv-vmbo_b { background: #e3b974; }
.adv-vmbo_b_k { background: #d49a44; }
.adv-vmbo_k { background: #c07f2e; }
.adv-vmbo_k_gt { background: #b96a35; }
.adv-vmbo_gt { background: #7c3a34; }
.adv-vmbo_gt_havo { background: #7c4b41; }
.adv-havo { background: #6da39c; }
.adv-havo_vwo { background: #3f7f78; }
.adv-vwo { background: #1d4845; }
.adv-onb {
  background: repeating-linear-gradient(45deg, #efe7d6 0 5px, #d9c9b0 5px 9px);
}

/* schoolweging-strip */
.weging { display: grid; gap: .15rem; max-width: 340px; }
.weging .strip {
  position: relative; height: 9px; border-radius: 5px;
  background: linear-gradient(90deg, var(--glasgroen-licht), var(--creme-licht), var(--oker-tint));
  border: 1px solid var(--lijn-sterk);
}
.weging .strip i {
  position: absolute; top: -4px; width: 4px; height: 17px; background: var(--inkt); border-radius: 2px;
}
.weging .schaal { display: flex; justify-content: space-between; font-size: .72rem; color: var(--muted); }

.kaart-acties { display: flex; flex-wrap: wrap; gap: .5rem .9rem; align-items: center; border-top: 1px dashed var(--lijn); padding-top: .6rem; }
.kaart-acties .links { margin-left: auto; display: flex; flex-wrap: wrap; gap: .7rem; font-size: .82rem; }

/* BSO-paneel */
.bso-paneel { border-top: 1px dashed var(--lijn); padding-top: .6rem; display: grid; gap: .4rem; }
.bso-item { display: flex; gap: .6rem; align-items: baseline; font-size: .86rem; flex-wrap: wrap; }
.bso-item .afst { color: var(--glasgroen); font-variant-numeric: tabular-nums; font-size: .78rem; font-weight: 700; }
.bso-item .plaatsen { color: var(--muted); font-size: .78rem; }

/* sponsorslot — bewust afwijkend vormgegeven, altijd gelabeld */
.sponsorslot {
  background: var(--oker-tint); border: 1.5px dashed var(--oker); border-radius: var(--radius);
  padding: .85rem 1.05rem; display: grid; gap: .35rem;
}
.sponsorslot .label {
  font-size: .67rem; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; color: #7d5414;
}
.sponsorslot h4 { font-family: var(--font-kop); font-size: 1.04rem; }
.sponsorslot p { font-size: .87rem; color: var(--tekst-zacht); }

/* ---------- deelblok ---------- */
.deelblok {
  background: var(--baksteen); color: #f1e6dd; border-radius: var(--radius);
  padding: 1.1rem 1.2rem; display: grid; gap: .6rem;
}
.deelblok h3 { color: #fffdf6; }
.deelblok p { font-size: .9rem; color: #ecd9c9; }
.deelblok .rij { display: flex; gap: .6rem; flex-wrap: wrap; }

/* ---------- dialoog ---------- */
dialog {
  width: min(860px, calc(100vw - 1.6rem)); max-height: calc(100dvh - 3rem);
  border: 1px solid var(--lijn-sterk); border-radius: var(--radius); background: var(--kaart);
  padding: 0; box-shadow: 0 30px 80px -20px rgba(43, 33, 28, .5); color: var(--inkt);
  margin: auto;
}
dialog::backdrop { background: rgba(43, 33, 28, .55); backdrop-filter: blur(2px); }
.dialoog-kop {
  position: sticky; top: 0; z-index: 5; display: flex; align-items: baseline; gap: 1rem;
  background: var(--kaart); border-bottom: 1px solid var(--lijn); padding: .9rem 1.2rem;
}
.dialoog-kop h2 { font-size: 1.3rem; }
.dialoog-kop .sluit {
  margin-left: auto; border: 0; background: var(--creme-licht); border-radius: 50%;
  width: 34px; height: 34px; font-size: 1.05rem; cursor: pointer; color: var(--tekst-zacht); flex: none;
}
.dialoog-kop .sluit:hover { background: var(--lijn); color: var(--inkt); }
.dialoog-body { padding: 1rem 1.2rem 1.4rem; display: grid; gap: 1.05rem; }
.dialoog-body section { display: grid; gap: .5rem; }
.dialoog-body section > h3 {
  font-size: .8rem; font-family: var(--font-ui); font-weight: 800;
  letter-spacing: .09em; text-transform: uppercase; color: var(--muted);
  border-bottom: 1px solid var(--lijn); padding-bottom: .3rem;
  display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; flex-wrap: wrap;
}
.dialoog-body section > h3 .bron { font-weight: 500; text-transform: none; letter-spacing: 0; font-size: .75rem; }

.profieltekst {
  background: var(--creme-licht); border-left: 3px solid var(--glasgroen);
  border-radius: 0 var(--radius-klein) var(--radius-klein) 0;
  padding: .8rem 1rem; font-size: .92rem; white-space: pre-line;
}

table.datatabel { border-collapse: collapse; width: 100%; font-size: .87rem; }
.datatabel th, .datatabel td { text-align: left; padding: .42rem .6rem; border-bottom: 1px solid var(--lijn); vertical-align: top; }
.datatabel th { font-size: .74rem; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); font-weight: 700; }
.datatabel td.num, .datatabel th.num { text-align: right; font-variant-numeric: tabular-nums; }
@media (max-width: 640px) {
  .dialoog-body { padding: .8rem .8rem 1.2rem; }
  .datatabel { font-size: .8rem; }
  .datatabel th, .datatabel td { padding: .35rem .4rem; }
}

/* vergelijkbalk */
.vergelijkbalk {
  position: fixed; bottom: .8rem; left: 50%; transform: translateX(-50%); z-index: 1200;
  width: max-content; max-width: calc(100vw - 1.6rem);
  background: var(--inkt); color: var(--creme-licht); border-radius: var(--radius);
  padding: .6rem .7rem .6rem 1.1rem; display: flex; align-items: center; gap: .8rem; flex-wrap: wrap;
  box-shadow: 0 14px 44px -8px rgba(0, 0, 0, .5); font-size: .88rem;
}
.vergelijkbalk.leeg { display: none; }
.vergelijkbalk .knop { background: var(--oker); border-color: var(--oker); color: var(--inkt); box-shadow: none; }

/* ---------- uitleg / infoblokken ---------- */
.uitlegblok {
  background: var(--creme-licht); border: 1px solid var(--lijn-sterk); border-radius: var(--radius);
  padding: .9rem 1.1rem; font-size: .92rem;
}
.uitlegblok summary { font-weight: 700; cursor: pointer; }
.uitlegblok p { margin-top: .5rem; color: var(--tekst-zacht); }

.intro-strook {
  background: var(--glasgroen-licht); border: 1px solid var(--glasgroen-tint); border-radius: var(--radius);
  padding: .8rem 1rem; font-size: .9rem; display: flex; gap: .7rem; align-items: baseline; flex-wrap: wrap;
  margin-bottom: .9rem;
}
.intro-strook strong { color: var(--glasgroen); }

/* ---------- proza/bronnen/adverteren ---------- */
.prozapagina { max-width: 880px; margin: 0 auto; padding: 2rem 1rem 3.5rem; display: grid; gap: 1.3rem; }
.prozapagina h2 { margin-top: 1.1rem; border-bottom: 2px solid var(--baksteen); padding-bottom: .3rem; }
.bron-kaart {
  background: var(--kaart); border: 1px solid var(--lijn); border-radius: var(--radius);
  padding: 1rem 1.15rem; box-shadow: var(--schaduw); display: grid; gap: .3rem;
}
.bron-kaart h3 { font-size: 1.02rem; }
.bron-kaart .meta { font-size: .82rem; color: var(--muted); }

.prijskaarten { display: grid; grid-template-columns: 1fr; gap: 1.1rem; }
@media (min-width: 760px) { .prijskaarten { grid-template-columns: repeat(3, 1fr); } }
.prijskaart {
  background: var(--kaart); border: 1.5px solid var(--lijn-sterk); border-radius: var(--radius);
  padding: 1.3rem; display: grid; gap: .6rem; align-content: start; box-shadow: var(--schaduw);
}
.prijskaart .prijs { font-family: var(--font-kop); font-weight: 800; font-size: 1.9rem; }
.prijskaart .prijs small { font-size: .9rem; color: var(--muted); font-family: var(--font-ui); }
.prijskaart ul { padding-left: 1.1rem; font-size: .9rem; color: var(--tekst-zacht); display: grid; gap: .25rem; }
.prijskaart.uitgelicht { border-color: var(--baksteen); border-width: 2px; position: relative; }
.prijskaart.uitgelicht::before {
  content: "Meest gekozen"; position: absolute; top: -11px; left: 1rem;
  background: var(--baksteen); color: #fff; font-size: .67rem; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase; padding: .16rem .6rem; border-radius: 5px;
}

/* ---------- keuzehulp ---------- */
.kieshulp-main { max-width: 660px; margin: 0 auto; padding: 1.2rem 1rem 3rem; }
.kh-voortgang { display: flex; gap: .35rem; margin: .8rem 0 1.4rem; }
.kh-voortgang i { flex: 1; height: 6px; border-radius: 3px; background: var(--lijn); }
.kh-voortgang i.af { background: var(--baksteen); }
.kh-vraag-label {
  font-size: .78rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--muted);
}
.kh-kaart {
  background: var(--kaart); border: 1px solid var(--lijn); border-radius: var(--radius);
  box-shadow: var(--schaduw); padding: 1.3rem; display: grid; gap: 1rem;
}
.kh-opties { display: grid; gap: .6rem; }
.kh-optie {
  display: flex; align-items: center; gap: .8rem; text-align: left;
  font: inherit; font-size: .96rem; font-weight: 600; color: var(--inkt);
  background: var(--kaart); border: 1.5px solid var(--lijn-sterk); border-radius: var(--radius-klein);
  padding: .85rem 1rem; cursor: pointer; transition: all .12s ease;
}
.kh-optie:hover { border-color: var(--inkt); }
.kh-optie.aan { border-color: var(--baksteen); background: var(--baksteen-licht); }
.kh-optie .ruit {
  flex: none; width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center;
  background: var(--creme-licht); border: 1px solid var(--lijn);
}
.kh-optie .ruit i { width: 10px; height: 10px; transform: rotate(45deg); border-radius: 2px; background: var(--oker); display: block; }
.kh-optie.aan .ruit i { background: var(--baksteen); }
.kh-optie .check { margin-left: auto; opacity: 0; color: var(--baksteen); font-weight: 800; }
.kh-optie.aan .check { opacity: 1; }
.kh-nav { display: flex; gap: .6rem; justify-content: space-between; align-items: center; }
.kh-skip { background: none; border: 0; color: var(--muted); font: inherit; font-size: .85rem; cursor: pointer; text-decoration: underline; }

/* match-resultaten */
.match-lijst { display: grid; gap: .7rem; }
.match-kaart {
  display: flex; align-items: center; gap: .9rem;
  background: var(--kaart); border: 1px solid var(--lijn); border-radius: var(--radius);
  box-shadow: var(--schaduw); padding: .9rem 1.05rem; text-align: left;
}
.match-kaart .rang {
  flex: none; font-family: var(--font-kop); font-weight: 800; font-size: 1.3rem; color: var(--oker);
  width: 1.4rem; text-align: center;
}
.match-kaart:first-child { border-color: var(--baksteen); border-width: 1.5px; }
.match-kaart:first-child .rang { color: var(--baksteen); }
.match-kaart .info { flex: 1; min-width: 0; }
.match-kaart .pct {
  flex: none; text-align: right; font-family: var(--font-kop); font-weight: 800;
  font-size: 1.25rem; color: var(--baksteen);
}
.match-kaart .pct small { display: block; font-family: var(--font-ui); font-weight: 600; font-size: .68rem; color: var(--muted); }
.match-waarom { font-size: .82rem; color: var(--tekst-zacht); margin-top: .2rem; }
.match-waarom .ja { color: var(--glasgroen); font-weight: 700; }

/* ---------- footer ---------- */
.site-voet { border-top: 2px solid var(--inkt); margin-top: 3rem; background: var(--creme-licht); }
.site-voet-inner {
  max-width: 1240px; margin: 0 auto; padding: 1.8rem 1rem 2.2rem;
  display: grid; grid-template-columns: 1fr; gap: 1.4rem;
  font-size: .86rem; color: var(--tekst-zacht);
}
@media (min-width: 720px) { .site-voet-inner { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } }
.site-voet h4 { font-family: var(--font-kop); color: var(--inkt); margin-bottom: .45rem; font-size: .98rem; }
.site-voet a { color: var(--tekst-zacht); }
.site-voet a:hover { color: var(--baksteen); }
.site-voet ul { list-style: none; display: grid; gap: .25rem; }

.disclaimer-strook {
  border-top: 1px solid var(--lijn-sterk); font-size: .78rem; color: var(--muted);
  text-align: center; padding: .8rem 1rem;
}

/* ---------- toegankelijkheid ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
.visueel-verborgen {
  position: absolute; width: 1px; height: 1px; overflow: hidden;
  clip-path: inset(50%); white-space: nowrap;
}

/* ---------- kieshulp-uitslag v2 ---------- */
/* Herontwerp uitslagscherm keuzehulp (juni 2026). Alles hieronder is nieuw;
   gebruikt uitsluitend bestaande tokens + --ring-leeg. Prefix: khu- */
:root { --ring-leeg: #e2d6be; }

/* — matchring (herbruikbaar): conic-ring met klein getal in het midden — */
.matchring {
  flex: none; width: var(--mr, 46px); height: var(--mr, 46px); border-radius: 50%;
  background: conic-gradient(var(--baksteen) calc(var(--mr-p, 0) * 1%), var(--ring-leeg) 0);
  display: grid; place-items: center;
}
.matchring > span {
  width: 76%; height: 76%; border-radius: 50%; background: var(--kaart);
  display: flex; flex-direction: column; align-items: center; justify-content: center; line-height: 1;
}
.matchring .mr-getal {
  font-family: var(--font-kop); font-weight: 800; color: var(--baksteen);
  font-size: calc(var(--mr, 46px) * .3); font-variant-numeric: tabular-nums;
}
.matchring .mr-label {
  font-family: var(--font-ui); font-weight: 600; color: var(--muted);
  font-size: calc(var(--mr, 46px) * .155); margin-top: 1px;
}

/* — gemetselde kop (zelfde metselrecept als .hero-poort) — */
.khu-kop {
  background: var(--baksteen);
  background-image:
    linear-gradient(100deg, rgba(0, 0, 0, .20), transparent 48%),
    radial-gradient(circle at 82% 12%, rgba(255, 250, 240, .07), transparent 42%),
    repeating-linear-gradient(0deg, rgba(255, 250, 240, .045) 0 14px, rgba(0, 0, 0, .05) 14px 15px, transparent 15px 30px),
    repeating-linear-gradient(0deg, rgba(0, 0, 0, .16) 0 1.5px, transparent 1.5px 30px),
    repeating-linear-gradient(90deg, rgba(0, 0, 0, .13) 0 1.5px, transparent 1.5px 58px);
  color: #f5eedd;
  border-radius: 16px 16px 0 0;
  padding: 1.15rem 1.25rem 1.25rem;
}
.khu-kop .ruitjes i:nth-child(1) { background: var(--creme); }
.khu-kop .ruitjes i:nth-child(2) { background: var(--oker); }
.khu-kop .ruitjes i:nth-child(3) { background: var(--glasgroen-tint); }
.khu-kicker {
  font-size: .74rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--baksteen-tint); margin-top: .55rem;
}
.khu-kop h2 {
  font-family: var(--font-kop); font-weight: 800; letter-spacing: -.015em;
  font-size: clamp(1.45rem, 6vw, 1.8rem); line-height: 1.08; color: #fffdf6; margin-top: .25rem;
}

/* — gestileerde kaart + druppel-pins — */
.khu-kaartstrip { position: relative; height: 108px; background: var(--creme); }
.khu-kaartstrip svg, .khu-kaartvlak svg, .khu-detail-kaart svg {
  position: absolute; inset: 0; width: 100%; height: 100%; display: block;
}
.khu-gracht { vector-effect: non-scaling-stroke; }
.khu-pin {
  position: absolute; transform: translate(-50%, -50%);
  display: flex; align-items: center; justify-content: center;
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  background: var(--baksteen); box-shadow: 0 5px 10px rgba(43, 33, 28, .35);
  font-family: var(--font-kop); font-weight: 800; color: var(--kaart); font-size: .9rem;
}
.khu-pin i { width: 26%; height: 26%; background: var(--creme); transform: rotate(45deg); border-radius: 1px; }
.khu-pin.thuis { border-radius: 50%; background: var(--inkt); color: var(--creme-licht); font-size: .85rem; }
.khu-pin.p1 { width: 38px; height: 38px; font-size: 1rem; }
.khu-pin.p2 { width: 30px; height: 30px; background: var(--oker); color: var(--inkt); font-size: .85rem; }
.khu-pin.p3 { width: 30px; height: 30px; background: var(--glasgroen); font-size: .85rem; }
.khu-pin.p45 { width: 26px; height: 26px; background: var(--muted); font-size: .78rem; }
.khu-pinbtn {
  position: absolute; width: 44px; height: 44px; transform: translate(-50%, -50%);
  background: transparent; border: 0; padding: 0; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.khu-pinbtn .khu-pin { position: static; transform: none; }

/* — hero-kaart van school #1 (variant B) — */
.khu-hero {
  background: var(--kaart); border: 1px solid var(--lijn); border-top: 0;
  border-radius: 0 0 16px 16px; overflow: hidden; box-shadow: var(--schaduw); cursor: pointer;
}
.khu-hero-body { padding: .95rem 1rem 1.05rem; display: grid; gap: .8rem; }
.khu-hero-top { display: flex; align-items: flex-start; justify-content: space-between; gap: .8rem; }
.khu-hero-info { min-width: 0; }
.khu-plek { font-size: .84rem; color: var(--tekst-zacht); }
.khu-cijfers { display: flex; gap: .85rem; margin-top: .6rem; align-items: stretch; }
.khu-cijfers .scheiding { flex: none; width: 1px; background: var(--lijn); }
.khu-cijfer .w { font-family: var(--font-kop); font-weight: 700; font-size: .95rem; line-height: 1.2; }
.khu-cijfer .l { font-size: .7rem; color: var(--muted); margin-top: .1rem; }
.khu-waarom {
  background: var(--glasgroen-licht); border-radius: 12px; padding: .7rem .85rem;
  font-size: .88rem; line-height: 1.45; color: var(--glasgroen);
}
.khu-waarom strong { color: var(--glasgroen); }
.khu-hero .knop { width: 100%; }

/* — slanke lijst (#2-#5 / bottom-sheet-rijen) — */
.khu-lijstkop {
  font-size: .74rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); margin: 1.1rem .2rem .25rem;
}
.khu-rij {
  display: flex; align-items: center; gap: .75rem; width: 100%; min-height: 56px;
  padding: .55rem .35rem; background: none; border: 0; border-top: 1px solid var(--lijn);
  cursor: pointer; font: inherit; text-align: left; color: inherit;
}
.khu-lijst .khu-rij:first-child { border-top: 0; }
.khu-rij .rang, .khu-mini .rang {
  flex: none; width: 1.2rem; text-align: center;
  font-family: var(--font-kop); font-weight: 800; font-size: 1.05rem;
}
.khu-rang-1 { color: var(--baksteen); }
.khu-rang-2 { color: var(--oker); }
.khu-rang-3 { color: var(--glasgroen); }
.khu-rang-x { color: var(--muted); }
.khu-rij .mid { flex: 1; min-width: 0; }
.khu-rij .mid > span { display: block; }
.khu-rij .naam {
  font-family: var(--font-kop); font-weight: 700; font-size: .97rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.khu-rij .sub { font-size: .78rem; color: var(--tekst-zacht); margin-top: .1rem; }
.khu-rij .reden { font-size: .8rem; color: var(--glasgroen); font-weight: 600; margin-top: .15rem; }
.khu-rij .chevron { flex: none; color: var(--muted); font-size: 1.1rem; }

/* — variant A: kaart bovenaan + bottom-sheet — */
.khu-vlak { position: relative; }
.khu-kaartvlak {
  position: relative; height: clamp(320px, 58vh, 520px); background: var(--creme);
  border: 1px solid var(--lijn-sterk); border-radius: 16px 16px 0 0; overflow: hidden;
}
.khu-toggle {
  position: absolute; top: .7rem; left: 50%; transform: translateX(-50%); z-index: 6;
  display: flex; gap: .25rem; background: var(--creme-licht);
  border: 1px solid var(--lijn-sterk); border-radius: 999px; padding: .25rem;
  box-shadow: var(--schaduw);
}
.khu-toggle button {
  font: inherit; font-size: .85rem; font-weight: 700; border: 0; background: transparent;
  color: var(--tekst-zacht); padding: .35rem 1.1rem; min-height: 44px; min-width: 44px;
  border-radius: 999px; cursor: pointer;
}
.khu-toggle button.aan { background: var(--baksteen); color: #fff; }
.khu-sheet {
  position: relative; margin-top: -20px; z-index: 4;
  background: var(--creme-licht); border: 1px solid var(--lijn);
  border-radius: 20px 20px 16px 16px; padding: .7rem 1rem .8rem;
  box-shadow: 0 -10px 26px -18px rgba(43, 33, 28, .45);
}
.khu-greep { width: 42px; height: 4px; border-radius: 2px; background: var(--lijn-sterk); margin: 0 auto .55rem; }
.khu-sheet:not(.open) .khu-rij[data-extra] { display: none; }
.khu-toon5 {
  width: 100%; min-height: 44px; background: none; border: 0; font: inherit;
  font-weight: 700; font-size: .88rem; color: var(--baksteen); cursor: pointer;
}
.khu-sheet.open .khu-toon5 { display: none; }
.khu-vlak.lijst .khu-kaartvlak { display: none; }
.khu-vlak.lijst .khu-toggle { position: static; transform: none; margin: 0 auto .7rem; width: max-content; }
.khu-vlak.lijst .khu-sheet { margin-top: 0; border-radius: 16px; box-shadow: var(--schaduw); }
.khu-vlak.lijst .khu-sheet .khu-rij[data-extra] { display: flex; }
.khu-vlak.lijst .khu-toon5 { display: none; }

/* — detailweergave na een tik — */
.khu-detail { display: grid; gap: .9rem; }
.khu-detail-top { display: flex; align-items: center; justify-content: space-between; gap: .6rem; }
.khu-detail-top .knop.klein { min-height: 44px; }
.khu-positie { font-family: var(--font-kop); font-weight: 700; font-size: .85rem; color: var(--tekst-zacht); }
.khu-adresbalk {
  display: flex; align-items: center; gap: .7rem; background: var(--kaart);
  border: 1px solid var(--lijn); border-radius: 13px; padding: .65rem .85rem;
}
.khu-adresbalk .huisje {
  flex: none; width: 32px; height: 32px; border-radius: 8px;
  background: var(--inkt); color: var(--creme-licht); display: grid; place-items: center;
}
.khu-adresbalk .mid { flex: 1; min-width: 0; display: grid; }
.khu-adresbalk .lab {
  font-size: .64rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--muted);
}
.khu-adresbalk .adres {
  font-size: .88rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.khu-adresbalk .afstand {
  flex: none; font-family: var(--font-kop); font-weight: 800; color: var(--baksteen);
  font-variant-numeric: tabular-nums; white-space: nowrap;
}
.khu-detail-kaart {
  position: relative; height: 180px; border-radius: 16px;
  border: 1px solid var(--lijn-sterk); overflow: hidden; background: var(--creme);
}
.khu-detail-kop { display: flex; align-items: center; justify-content: space-between; gap: .8rem; }
.khu-detail-kop > div { min-width: 0; }
.khu-detail-kop h2 { font-size: 1.3rem; font-weight: 800; }
.khu-gegevens {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: var(--lijn); border: 1px solid var(--lijn); border-radius: 14px; overflow: hidden;
}
.khu-gegeven { background: var(--kaart); padding: .65rem .85rem; }
.khu-gegeven .l { font-size: .7rem; color: var(--muted); font-weight: 600; }
.khu-gegeven .w {
  font-family: var(--font-kop); font-weight: 700; font-size: .95rem;
  margin-top: .1rem; overflow-wrap: anywhere;
}
.khu-sectiekop {
  font-size: .72rem; font-family: var(--font-ui); font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase; color: var(--muted);
  border-bottom: 1px solid var(--lijn); padding-bottom: .3rem;
}
.khu-crits { display: grid; gap: .35rem; font-size: .88rem; }
.khu-crit { display: flex; gap: .5rem; align-items: baseline; }
.khu-crit .sym { flex: none; width: 1rem; text-align: center; font-weight: 800; }
.khu-crit.ja { color: var(--glasgroen); font-weight: 600; }
.khu-crit.nee { color: var(--tekst-zacht); }
.khu-crit.nee .sym { color: var(--baksteen); }
.khu-crit.grijs { color: var(--muted); }
.khu-links { display: flex; flex-wrap: wrap; gap: .5rem; }
.khu-links .knop { font-size: .86rem; }
.khu-mini-strip {
  display: flex; gap: .6rem; overflow-x: auto; padding: .2rem .1rem .5rem;
  scrollbar-width: thin;
}
.khu-mini {
  flex: none; width: 150px; min-height: 44px; background: var(--kaart);
  border: 1px solid var(--lijn); border-radius: 14px; padding: .6rem .7rem;
  cursor: pointer; font: inherit; text-align: left; color: inherit;
  display: grid; gap: .35rem; align-content: start;
}
.khu-mini.actief { border-color: var(--baksteen); border-width: 1.5px; cursor: default; }
.khu-mini .kop { display: flex; align-items: center; justify-content: space-between; }
.khu-mini .naam { font-family: var(--font-kop); font-weight: 700; font-size: .85rem; line-height: 1.2; }
