/* === v3 componenten === */

/* ---------- Reisweek-radar ---------- */
.radar{ padding:30px 32px 26px; }
.radar-top{ display:grid; grid-template-columns:1fr auto; gap:30px; align-items:start; }
.radar-title{ font-size:clamp(22px,2.6vw,30px); margin:10px 0 8px; }
.radar-sub{ color:var(--ink-3); font-size:15px; max-width:34ch; }

.radar-detail{ display:flex; gap:22px; align-items:center; }
.radar-detail-txt{ min-width:230px; }
.dt-wk{ font-size:11px; letter-spacing:.14em; color:var(--ink-3); }
.dt-date{ display:block; font-size:20px; font-weight:800; letter-spacing:-0.02em; margin:2px 0 12px; }

/* score ring */
.ring{ position:relative; flex:none; }
.ring-mid{ position:absolute; inset:0; display:grid; place-items:center; align-content:center; gap:0; padding:6%; text-align:center; }
.ring-val{ font-size:40px; font-weight:700; color:var(--c-ink); line-height:1; }
.ring-lab{ font-size:12px; font-weight:700; color:var(--c-ink); text-transform:uppercase; letter-spacing:.06em; margin-top:3px; line-height:1.05; max-width:100%; }

/* factor meters */
.factors{ display:flex; flex-direction:column; gap:9px; }
.factor{ display:grid; grid-template-columns:18px 60px 1fr 26px; align-items:center; gap:9px; font-size:13px; }
.factor-ic{ color:var(--c-ink); font-size:13px; text-align:center; }
.factor-lab{ color:var(--ink-2); font-weight:600; }
.factor-bar{ height:7px; border-radius:99px; background:var(--line); overflow:hidden; }
.factor-bar i{ display:block; height:100%; border-radius:99px; background:var(--c); transition:width .5s cubic-bezier(.2,.7,.3,1); }
.factor-val{ font-size:12px; color:var(--ink-3); text-align:right; }

/* week-balken chart */
.radar-chart{
  display:grid; grid-auto-flow:column; grid-auto-columns:1fr;
  gap:5px; align-items:end; height:184px; margin:28px 0 14px;
  padding:0 2px;
}
.wkbar{
  position:relative; background:none; border:none; padding:0;
  display:flex; flex-direction:column; align-items:center; gap:7px;
  height:100%; justify-content:flex-end;
}
.wkbar-track{
  width:100%; max-width:30px; height:100%;
  display:flex; align-items:flex-end; border-radius:9px;
  background:var(--paper-2);
}
.wkbar-fill{
  width:100%; border-radius:9px; background:var(--c);
  min-height:8px; transition:height .6s cubic-bezier(.2,.7,.3,1), filter .15s;
  animation:rise .5s both;
}
.wkbar:hover .wkbar-fill{ filter:brightness(1.06); }
.wkbar-num{ font-size:11px; color:var(--ink-3); transition:color .15s; }
.wkbar.on .wkbar-track{ box-shadow:0 0 0 2.5px var(--bg), 0 0 0 4.5px var(--c); }
.wkbar.on .wkbar-num{ color:var(--c-ink); font-weight:700; }
.best-flag{
  position:absolute; top:-22px; left:50%; transform:translateX(-50%);
  white-space:nowrap; font-family:var(--mono); font-size:9.5px; letter-spacing:.06em;
  color:var(--rustig-ink); background:var(--rustig-soft); padding:3px 7px; border-radius:99px;
  border:1px solid oklch(86% 0.06 162);
}
.radar-legend{ display:flex; align-items:center; gap:18px; font-size:12.5px; color:var(--ink-3); padding-top:6px; border-top:1px solid var(--line); margin-top:6px; padding-top:14px; }
.radar-legend .dot{ display:inline-block; width:9px; height:9px; border-radius:3px; background:var(--c); margin-right:6px; vertical-align:middle; }
.radar-legend span{ display:inline-flex; align-items:center; }
.radar-hint{ margin-left:auto; color:var(--ink-3); font-style:italic; }

@media(max-width:880px){
  .radar-top{ grid-template-columns:1fr; gap:20px; }
  .radar-detail{ flex-direction:row; }
}
@media(max-width:560px){
  .radar{ padding:22px 18px; }
  .radar-detail{ flex-direction:column; align-items:flex-start; }
  .radar-detail-txt{ min-width:0; width:100%; }
  .radar-chart{ height:150px; gap:3px; }
  .best-flag{ display:none; }
  .wkbar-num{ font-size:9px; }
}

/* ---------- hero kiezer ---------- */
.hero{ padding-block:54px 12px; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:30px; }
.hero h1{ font-size:clamp(34px,5.4vw,60px); max-width:16ch; }
.hero .lead{ font-size:clamp(16px,2vw,20px); color:var(--ink-2); max-width:50ch; margin-top:20px; line-height:1.5; }
.hero .accent-word{ color:var(--accent); }

.picker{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:26px; }
.seg{ display:inline-flex; background:var(--paper); border:1px solid var(--line-2); border-radius:13px; padding:4px; gap:2px; box-shadow:var(--shadow-sm); }
.seg button{ background:none; border:none; padding:9px 15px; border-radius:10px; font-size:14px; font-weight:600; color:var(--ink-2); transition:.15s; }
.seg button.on{ background:var(--accent); color:#fff; box-shadow:0 3px 10px var(--accent-glow); }
.seg button:not(.on):hover{ background:var(--accent-soft); color:var(--accent-ink); }
.picker-lab{ font-size:13px; color:var(--ink-3); font-weight:600; margin-right:2px; }

/* ---------- mini druktekaart (homepage) ---------- */
.minimap{ display:grid; grid-template-columns:1.3fr 1fr; gap:24px; align-items:stretch; }
.minimap .map-wrap{ position:relative; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; box-shadow:var(--shadow); }
.minimap svg{ width:100%; height:auto; display:block; }
/* realistische Europa-kaart: dunne landgrenzen, grijze context-landen */
.country-shape, .country-ctx{ stroke:var(--paper); stroke-width:0.8; stroke-linejoin:round; }
.country-shape{ cursor:pointer; transition:fill .25s ease; }
.country-ctx{ transition:fill .25s ease; }
.country-shape:hover{ filter:brightness(0.95); }
.country-shape.sel{ stroke:var(--ink); stroke-width:1.6; }
.map-side{ display:flex; flex-direction:column; gap:14px; justify-content:center; }
.map-rank{ display:flex; flex-direction:column; gap:8px; }
.map-rank-row{ display:flex; align-items:center; gap:11px; padding:10px 13px; background:var(--paper); border:1px solid var(--line); border-radius:14px; transition:.15s; cursor:pointer; }
.map-rank-row:hover{ border-color:var(--accent-line); box-shadow:var(--shadow-sm); }
.map-rank-row.sel{ border-color:var(--accent); background:var(--accent-soft); }
.map-rank-row .flag{ font-size:20px; }
.map-rank-row .nm{ font-weight:700; font-size:14.5px; }
.map-rank-row .mini-bar{ flex:1; height:7px; border-radius:99px; background:var(--line); overflow:hidden; }
.map-rank-row .mini-bar i{ display:block; height:100%; border-radius:99px; }
.map-rank-row .pct{ font-family:var(--mono); font-size:12px; color:var(--ink-3); min-width:30px; text-align:right; }

/* week slider */
.wkslider{ display:flex; align-items:center; gap:14px; margin-top:14px; padding:14px 18px; background:var(--paper); border:1px solid var(--line); border-radius:16px; }
.wkslider input[type=range]{ flex:1; accent-color:var(--accent); height:4px; }
.wkslider .wknow{ font-family:var(--mono); font-size:13px; font-weight:700; color:var(--accent-ink); min-width:118px; }

/* ---------- bestemmings-cards ---------- */
.dest-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.dest{ border-radius:var(--r-lg); overflow:hidden; background:var(--paper); border:1px solid var(--line); box-shadow:var(--shadow); transition:transform .18s cubic-bezier(.2,.7,.3,1), box-shadow .18s; cursor:pointer; }
.dest:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.dest-img{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.dest-img img{ width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.dest:hover .dest-img img{ transform:scale(1.05); }
.dest-badge{ position:absolute; top:12px; right:12px; display:flex; align-items:center; gap:6px; background:color-mix(in oklab, var(--paper) 90%, transparent); backdrop-filter:blur(6px); border-radius:99px; padding:6px 11px 6px 8px; box-shadow:var(--shadow-sm); }
.dest-badge .bdot{ width:22px; height:22px; border-radius:99px; display:grid; place-items:center; font-family:var(--mono); font-size:10px; font-weight:700; color:#fff; }
.dest-badge .blab{ font-size:11px; font-weight:700; color:var(--ink-2); }
.dest-tag{ position:absolute; bottom:12px; left:12px; font-size:11.5px; font-weight:600; color:#fff; background:oklch(30% 0.03 285 / 0.55); backdrop-filter:blur(4px); padding:5px 10px; border-radius:99px; }
.dest-body{ padding:15px 17px 17px; }
.dest-body .nm{ font-size:17px; font-weight:800; letter-spacing:-0.02em; }
.dest-body .ld{ font-size:13px; color:var(--ink-3); margin-top:1px; }
.dest-body .row{ display:flex; align-items:center; gap:7px; margin-top:11px; font-size:12.5px; color:var(--ink-2); }
.dest-body .heart{ color:var(--accent); }

/* ---------- beste periodes / kennisbank ---------- */
.tipbar{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.tip{ display:flex; gap:14px; align-items:flex-start; padding:20px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r); }
.tip .ic{ width:42px; height:42px; flex:none; border-radius:13px; background:var(--accent-soft); display:grid; place-items:center; font-size:20px; }
.tip h3{ font-size:15px; margin-bottom:5px; }
.tip p{ font-size:13.5px; color:var(--ink-3); line-height:1.5; }

.kb{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.kb-item{ padding:16px 18px; border-radius:var(--r); border:1px solid var(--line); background:var(--paper-2); transition:.15s; }
.kb-item:hover{ background:var(--paper); box-shadow:var(--shadow-sm); }
.kb-item .k{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); }
.kb-item h4{ font-size:14.5px; margin:7px 0 4px; letter-spacing:-0.01em; }
.kb-item p{ font-size:12.5px; color:var(--ink-3); }

/* ---------- fullscreen druktekaart ---------- */
.kaart{ display:grid; grid-template-columns:1fr 380px; gap:0; height:calc(100vh - 64px); position:relative; }
.kaart-stage{ display:grid; place-items:center; padding:30px 30px 90px; background:linear-gradient(160deg, var(--bg), var(--bg-2)); overflow:hidden; }
.europe.big{ max-width:620px; width:100%; height:auto; filter:drop-shadow(0 12px 30px oklch(40% 0.04 285 / .12)); }
.kaart-panel{ background:var(--paper); border-left:1px solid var(--line); padding:26px 26px 100px; overflow-y:auto; display:flex; flex-direction:column; gap:16px; }
.kp-head h1{ font-size:26px; margin-top:8px; }
.kp-detail{ display:flex; align-items:center; gap:14px; padding:16px 18px; border-radius:18px; background:var(--c-soft); border:1px solid var(--line); }
.kp-flag{ font-size:34px; }
.kp-detail-info{ display:flex; flex-direction:column; }
.kp-detail-info strong{ font-size:18px; }
.kp-detail-band{ font-size:13px; color:var(--c-ink); font-weight:700; }
.kp-detail-val{ margin-left:auto; font-size:34px; font-weight:700; }
.kp-rank{ display:flex; flex-direction:column; gap:7px; }
.kp-row{ display:flex; align-items:center; gap:11px; padding:9px 12px; background:var(--paper); border:1px solid var(--line); border-radius:13px; cursor:pointer; transition:.12s; text-align:left; }
.kp-row:hover{ border-color:var(--accent-line); }
.kp-row.on{ border-color:var(--accent); background:var(--accent-soft); }
.kp-row .flag{ font-size:18px; }
.kp-row .nm{ font-size:14px; font-weight:700; }
.kp-row .mini-bar{ flex:1; height:7px; border-radius:99px; background:var(--line); overflow:hidden; }
.kp-row .mini-bar i{ display:block; height:100%; border-radius:99px; }
.kp-row .pct{ font-size:12px; color:var(--ink-3); min-width:26px; text-align:right; }
.kp-tip{ display:flex; gap:11px; align-items:flex-start; padding:14px 16px; background:var(--rustig-soft); border:1px solid oklch(86% 0.06 162); border-radius:14px; }
.kp-tip-ic{ width:24px; height:24px; flex:none; border-radius:99px; background:var(--rustig); color:#fff; display:grid; place-items:center; font-size:13px; font-weight:700; }
.kp-tip p{ font-size:13.5px; color:var(--ink-2); line-height:1.45; }
.kp-legend{ display:flex; gap:16px; font-size:12.5px; color:var(--ink-3); padding-top:4px; }
.kp-legend span{ display:inline-flex; align-items:center; gap:6px; }
.kp-legend i{ width:11px; height:11px; border-radius:4px; display:inline-block; }

.kaart-slider{ position:absolute; left:24px; right:404px; bottom:22px; background:color-mix(in oklab, var(--paper) 92%, transparent); backdrop-filter:blur(10px); border:1px solid var(--line); border-radius:18px; padding:14px 22px; box-shadow:var(--shadow-lg); display:flex; flex-direction:column; gap:6px; }
.kaart-slider .ks-now{ font-size:13px; font-weight:700; color:var(--accent-ink); }
.kaart-slider input[type=range]{ width:100%; accent-color:var(--accent); height:5px; }
.ks-marks{ display:flex; justify-content:space-between; font-size:11px; color:var(--ink-4); font-family:var(--mono); }

@media(max-width:880px){
  .kaart{ grid-template-columns:1fr; height:auto; }
  .kaart-stage{ padding:24px 20px 30px; }
  .kaart-panel{ border-left:none; border-top:1px solid var(--line); padding-bottom:120px; }
  .kaart-slider{ left:16px; right:16px; }
}

/* regio-indeling */
.regio-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.regio-col{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; }
.regio-col h3{ font-size:16px; margin-bottom:8px; }
.regio-col p{ font-size:13.5px; color:var(--ink-3); line-height:1.55; }
.regio-col{ transition:border-color .2s, box-shadow .2s, background .2s; }
.regio-col.is-hit{ border-color:var(--accent); background:var(--accent-soft);
  box-shadow:0 0 0 2px var(--accent-line); }

/* NL plaats → regio zoeker */
.plaats-zoek{ margin:0 0 20px; max-width:520px; }
.pz-label{ display:block; font-size:13.5px; font-weight:600; color:var(--ink-2); margin-bottom:6px; }
.pz-field{ position:relative; }
.pz-field input{ width:100%; box-sizing:border-box; padding:12px 16px; font-size:15px;
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  border:1.5px solid var(--line); border-radius:12px; transition:border-color .15s, box-shadow .15s; }
.pz-field input:focus{ outline:none; border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-line); }
.pz-suggest{ position:absolute; z-index:20; left:0; right:0; top:calc(100% + 6px);
  list-style:none; margin:0; padding:6px; background:var(--paper);
  border:1px solid var(--line); border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.12);
  max-height:320px; overflow:auto; }
.pz-suggest li{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:9px 12px; border-radius:8px; cursor:pointer; }
.pz-suggest li.is-active,.pz-suggest li:hover{ background:var(--accent-soft); }
.pz-nm{ font-size:14.5px; color:var(--ink); }
.pz-rg{ flex:none; font-size:11.5px; font-weight:700; letter-spacing:.02em;
  padding:2px 9px; border-radius:999px; background:var(--accent-soft); color:var(--accent-ink); }
.pz-result{ margin-top:14px; padding:14px 16px; font-size:14.5px; line-height:1.5;
  background:var(--accent-soft); border:1px solid var(--accent-line); border-radius:12px; color:var(--ink); }
.pz-regio{ font-weight:700; padding:1px 8px; border-radius:999px; white-space:nowrap;
  background:var(--accent-soft); color:var(--accent-ink); }
.pz-regio--noord{ background:#dbeafe; color:#1e40af; }
.pz-regio--midden{ background:#dcfce7; color:#166534; }
.pz-regio--zuid{ background:#fee2e2; color:#991b1b; }

/* Kennisbank: hub + detail */
.kb-hub{ max-width:1000px; margin:0 auto; }
.kb-hero{ max-width:64ch; margin:0 0 28px; }
.kb-hero h1{ margin:8px 0 10px; }
.kb-hero .lead{ color:var(--ink-2); }
.kb-filters{ display:flex; flex-direction:column; gap:12px; margin:0 0 16px; padding:16px 18px;
  background:var(--paper); border:1px solid var(--line); border-radius:14px; }
.kb-filter-row{ display:grid; grid-template-columns:88px 1fr; gap:10px; align-items:start; }
.kb-filter-lbl{ font-size:13px; color:var(--ink-3); font-weight:700; padding-top:6px; }
.kb-chips{ display:flex; flex-wrap:wrap; gap:7px; }
.kb-chip{ font-size:13px; padding:6px 12px; border-radius:999px; text-decoration:none;
  background:var(--bg); border:1px solid var(--line); color:var(--ink-2); transition:border-color .15s, background .15s, color .15s; }
.kb-chip:hover{ border-color:var(--accent); color:var(--accent-ink); }
.kb-chip.on{ border-color:var(--accent); color:#fff; background:var(--accent); }
.kb-count{ font-size:14px; color:var(--ink-2); margin:0 0 16px; }
.kb-count a{ color:var(--accent); }
@media(max-width:560px){ .kb-filter-row{ grid-template-columns:1fr; gap:5px; } .kb-filter-lbl{ padding-top:0; } }
.kb-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.kb-grid.three{ grid-template-columns:repeat(3,1fr); }
.kb-card{ display:block; padding:18px 20px; background:var(--paper); border:1px solid var(--line);
  border-radius:16px; text-decoration:none; color:var(--ink); transition:border-color .15s, box-shadow .15s, transform .14s; }
.kb-card:hover{ border-color:var(--accent); box-shadow:var(--shadow-sm); transform:translateY(-2px); }
.kb-card h2,.kb-card h3{ font-size:17px; margin:7px 0 0; line-height:1.35; }
.kb-card p{ font-size:13.5px; color:var(--ink-3); line-height:1.55; margin:8px 0 0; }
.kb-card-cat{ font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; color:var(--accent-ink); }
.kb-card-meta{ display:inline-block; margin-top:10px; font-size:12.5px; color:var(--ink-3); }
.kb-empty{ padding:32px; text-align:center; background:var(--paper); border:1px dashed var(--line);
  border-radius:16px; color:var(--ink-3); }
.kb-detail{ max-width:1000px; margin:0 auto; }
.kb-bron{ margin-top:26px; padding-top:16px; border-top:1px solid var(--line); font-size:13px; color:var(--ink-3); word-break:break-all; }
.kb-bron a{ color:var(--accent); }
@media(max-width:720px){ .kb-grid.three{ grid-template-columns:1fr; } }

/* Samenwerken: widget-promo */
.sw-widget-cta{ display:flex; align-items:center; justify-content:space-between; gap:24px;
  flex-wrap:wrap; padding:26px 30px; background:var(--accent-soft);
  border:1px solid var(--accent-line); border-radius:var(--r-md); }
.sw-widget-cta p{ color:var(--ink-2); max-width:54ch; margin:0; }
.sw-widget-cta .btn{ flex:none; }

/* Widget-generator (/widget/) */
.wgen{ max-width:760px; margin:0 auto; }
.wgen-hero{ text-align:center; margin:0 0 26px; }
.wgen-hero h1{ margin:8px 0 10px; }
.wgen-hero .lead{ color:var(--ink-2); max-width:60ch; margin:0 auto; }
.wgen-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md);
  padding:26px 28px; box-shadow:var(--shadow-sm); }
.wgen-form{ display:flex; flex-direction:column; }
.wgen-lbl{ font-size:14px; font-weight:600; margin:16px 0 6px; }
.wgen-form input, .wgen-form select, .wgen-code{ width:100%; box-sizing:border-box; font-size:15px;
  font-family:var(--sans); color:var(--ink); background:var(--bg); border:1.5px solid var(--line);
  border-radius:10px; padding:11px 14px; transition:border-color .15s, box-shadow .15s; }
.wgen-form input:focus, .wgen-form select:focus, .wgen-code:focus{ outline:none;
  border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-line); }
.wgen-hint{ font-size:12.5px; color:var(--ink-3); margin:5px 0 0; }
.wgen-opt{ font-weight:400; color:var(--ink-3); }
.wgen-btn{ align-self:flex-start; margin-top:20px; background:var(--accent); color:#fff; border:0;
  font-size:15px; font-weight:700; padding:12px 22px; border-radius:10px; cursor:pointer;
  font-family:var(--sans); transition:background .15s; }
.wgen-btn:hover{ background:var(--accent-ink); }
.wgen-fout{ background:#fee2e2; color:#991b1b; border:1px solid #fecaca; border-radius:10px;
  padding:11px 14px; font-size:14px; margin:0 0 18px; }
.wgen-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.wgen-done h2{ margin:0 0 10px; }
.wgen-code{ font-family:var(--mono); font-size:13px; line-height:1.5; resize:vertical;
  margin:6px 0 12px; white-space:pre; }
.wgen-note{ margin-top:22px; padding:16px 18px; background:var(--accent-soft);
  border:1px solid var(--accent-line); border-radius:12px; }
.wgen-note h3{ font-size:15px; margin:0 0 8px; }
.wgen-note ul{ margin:0; padding-left:18px; }
.wgen-note li{ font-size:13.5px; color:var(--ink-2); margin:5px 0; line-height:1.55; }
.wgen-note code, .wgen-hint code{ font-family:var(--mono); font-size:12.5px; background:var(--bg);
  border:1px solid var(--line); border-radius:5px; padding:1px 5px; }
.wgen-again{ margin:18px 0 0; }
.wgen-again a{ color:var(--accent); font-weight:600; text-decoration:none; }

/* FAQ accordion (native details) */
.faq{ display:flex; flex-direction:column; gap:10px; }
.faq-item{ background:var(--paper); border:1px solid var(--line); border-radius:16px; overflow:hidden; transition:box-shadow .15s; }
.faq-item[open]{ box-shadow:var(--shadow-sm); }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:17px 20px; font-size:15.5px; font-weight:700; color:var(--ink); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary:hover{ color:var(--accent-ink); }
.faq-ic{ flex:none; width:26px; height:26px; border-radius:8px; background:var(--accent-soft); color:var(--accent-ink); display:grid; place-items:center; font-size:18px; font-weight:700; transition:transform .2s; }
.faq-item[open] .faq-ic{ transform:rotate(45deg); }
.faq-item p{ padding:0 20px 18px; font-size:14px; color:var(--ink-2); line-height:1.6; max-width:74ch; margin:0; }

/* bron-voetregel */
.bronregel{ font-size:12.5px; color:var(--ink-3); line-height:1.55; max-width:80ch; margin:8px 0 4px; padding:14px 16px; background:var(--paper-2); border:1px solid var(--line); border-radius:14px; }
.bronregel .bron-upd{ color:var(--ink-4); }

/* visueel verborgen, wél voor screenreaders/SEO */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* kerngegevens-tabel (snippet-bait, direct onder de hero) */
.land-kern{ margin-top:4px; }
.kern-tabel{ width:100%; max-width:640px; border-collapse:collapse; font-size:15px;
  background:var(--paper); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.kern-tabel th, .kern-tabel td{ text-align:left; padding:12px 16px; border-bottom:1px solid var(--line); vertical-align:top; }
.kern-tabel tr:last-child th, .kern-tabel tr:last-child td{ border-bottom:0; }
.kern-tabel th{ width:42%; color:var(--ink-2); font-weight:600; background:var(--paper-2); }
.kern-tabel td{ color:var(--ink); font-weight:600; }

/* compact vakantie-overzicht (featured-snippet-bait, boven de detailtabellen) */
.vak-overzicht{ width:100%; max-width:680px; border-collapse:collapse; font-size:15px; margin:0 0 26px;
  background:var(--paper); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.vak-overzicht th, .vak-overzicht td{ text-align:left; padding:11px 16px; border-bottom:1px solid var(--line); }
.vak-overzicht tbody tr:last-child td{ border-bottom:0; }
.vak-overzicht thead th{ background:var(--paper-2); color:var(--ink-2); font-weight:700; font-size:13px; }
.vak-overzicht td:first-child{ font-weight:600; color:var(--ink); }
.vak-overzicht td:last-child{ color:var(--ink-2); }
.vo-tag{ display:inline-block; margin-left:6px; font-size:11.5px; font-weight:600; padding:2px 8px;
  border-radius:999px; background:var(--accent-soft); color:var(--accent-ink); white-space:nowrap; }

/* interne links naar andere landen */
.land-links{ display:flex; flex-wrap:wrap; gap:9px; }
.land-link{ display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600;
  color:var(--ink-2); background:var(--paper); border:1px solid var(--line-2); border-radius:999px;
  padding:8px 15px; transition:.14s; }
.land-link:hover{ border-color:var(--accent-line); color:var(--accent-ink); background:var(--accent-soft); }
.ll-flag{ font-size:16px; line-height:1; }

@media(max-width:760px){
  .regio-cols{ grid-template-columns:1fr; }
}

/* ---------- land: live controls (jaar/land/badge) ---------- */
.land-controls{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin-bottom:24px; }

/* country picker (schaalt naar heel Europa) */
.country-picker{ position:relative; }
.cp-trigger{ display:inline-flex; align-items:center; gap:10px; background:var(--paper); border:1px solid var(--line-2); border-radius:14px; padding:10px 14px; box-shadow:var(--shadow-sm); font-size:15px; font-weight:700; color:var(--ink); min-width:210px; transition:border-color .14s, box-shadow .14s; }
.cp-trigger:hover{ border-color:var(--accent-line); box-shadow:var(--shadow); }
.country-picker.compact .cp-trigger{ min-width:0; padding:9px 13px; font-size:14px; border-radius:13px; }
.country-picker.compact .cp-trigger-name{ flex:none; }
.country-picker.compact .cp-flag{ font-size:18px; }
.cp-flag{ font-size:20px; line-height:1; }
.cp-trigger-name{ flex:1; text-align:left; letter-spacing:-0.01em; }
.cp-chev{ color:var(--ink-3); transition:transform .2s; }
.cp-chev.up{ transform:rotate(180deg); }
.cp-panel{ position:absolute; top:calc(100% + 8px); left:0; z-index:60; width:340px; max-width:88vw; background:var(--paper); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow-lg); overflow:hidden; animation:cpIn .16s ease both; }
@keyframes cpIn{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:translateY(0); } }
.cp-search{ display:flex; align-items:center; gap:9px; padding:13px 16px; border-bottom:1px solid var(--line); color:var(--ink-3); }
.cp-search input{ flex:1; border:none; background:none; font-family:inherit; font-size:15px; color:var(--ink); padding:0; }
.cp-search input:focus{ outline:none; }
.cp-list{ max-height:330px; overflow-y:auto; padding:6px; }
.cp-group{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-4); padding:10px 10px 5px; }
.cp-row{ display:flex; align-items:center; gap:11px; width:100%; border:none; background:none; padding:10px 11px; border-radius:11px; font-size:14.5px; font-weight:600; color:var(--ink); cursor:pointer; transition:background .12s; }
.cp-row:hover{ background:var(--paper-2); }
.cp-row.on{ background:var(--accent-soft); color:var(--accent-ink); }
.cp-name{ flex:1; text-align:left; }
.cp-live{ font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--rustig-ink); background:var(--rustig-soft); padding:3px 8px; border-radius:99px; }
.cp-soon{ font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-4); background:var(--bg-2); padding:3px 8px; border-radius:99px; }
.cp-empty{ padding:24px 14px; text-align:center; color:var(--ink-3); font-size:13.5px; }
.cp-foot{ display:flex; align-items:center; gap:8px; padding:11px 16px; border-top:1px solid var(--line); background:var(--paper-2); font-size:11.5px; color:var(--ink-3); }
.cp-livedot{ width:8px; height:8px; border-radius:99px; background:var(--rustig); box-shadow:0 0 0 3px var(--rustig-soft); flex:none; }

/* binnenkort-live staat */
.land-soon{ text-align:center; max-width:60ch; margin:30px auto; padding:44px 28px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); }
.land-soon-flag{ font-size:54px; line-height:1; margin-bottom:8px; }
.land-soon h2{ font-size:26px; margin-bottom:12px; letter-spacing:-0.02em; }
.land-soon p{ color:var(--ink-2); font-size:15.5px; line-height:1.6; margin-bottom:24px; }
.land-soon-live{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.live-badge.soon i{ background:var(--ink-4); box-shadow:0 0 0 3px var(--bg-2); animation:none; }

.year-switch{ display:flex; align-items:center; gap:6px; background:var(--paper); border:1px solid var(--line-2); border-radius:14px; padding:5px 5px 5px 14px; box-shadow:var(--shadow-sm); }
.year-switch .ys-lab{ font-size:12px; font-weight:600; color:var(--ink-3); text-transform:uppercase; letter-spacing:.05em; margin-right:4px; }
.year-switch a{ font-family:var(--mono); font-size:13px; font-weight:700; padding:6px 12px; border-radius:10px; border:1px solid var(--line-2); background:var(--paper); color:var(--ink-2); }
.year-switch a.on{ background:var(--accent-soft); border-color:var(--accent-line); color:var(--accent-ink); }
.year-switch a:hover{ border-color:var(--accent-line); }
.live-badge{ display:inline-flex; align-items:center; gap:8px; font-size:12.5px; font-weight:700; color:var(--ink-3); padding:8px 14px; border-radius:99px; border:1px solid var(--line-2); background:var(--paper); }
.live-badge i{ width:9px; height:9px; border-radius:99px; background:var(--rustig); box-shadow:0 0 0 3px var(--rustig-soft); }
.live-badge.live i{ animation:pulse 2s infinite; }
.live-badge.loading i{ background:var(--matig); box-shadow:0 0 0 3px var(--matig-soft); }
.live-badge.error i{ background:var(--druk); box-shadow:0 0 0 3px var(--druk-soft); }
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.4; } }

.vooruitblik{ margin-top:14px; font-size:14.5px; color:var(--ink-2); background:var(--accent-soft); border:1px solid var(--accent-line); border-radius:14px; padding:11px 16px; display:inline-block; }

.ring-skel{ width:104px; height:104px; border-radius:99px; border:9px solid var(--line); border-top-color:var(--accent-line); animation:spin 1s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.land-loading{ display:flex; flex-direction:column; align-items:center; gap:16px; padding:70px 0; color:var(--ink-3); font-size:15px; }
.spinner{ width:38px; height:38px; border-radius:99px; border:4px solid var(--line); border-top-color:var(--accent); animation:spin .9s linear infinite; }
.land-error{ background:var(--druk-soft); border:1px solid oklch(88% 0.05 28); border-radius:16px; padding:18px 22px; color:var(--druk-ink); font-size:14.5px; margin:20px 0; }
.linklike{ background:none; border:none; color:var(--accent); font-weight:700; text-decoration:underline; padding:0; font-size:inherit; }

@media(max-width:600px){
  .land-controls{ gap:10px; }
  .year-switch{ padding-left:10px; }
  .year-switch .ys-lab{ display:none; }
}

/* ---------- land: naslag-secties (vakanties / feestdagen) ---------- */
.land-switch{ display:inline-flex; gap:4px; background:var(--paper); border:1px solid var(--line-2); border-radius:14px; padding:5px; box-shadow:var(--shadow-sm); margin-bottom:26px; }
.land-switch button{ display:inline-flex; align-items:center; gap:8px; border:none; background:none; padding:9px 16px; border-radius:10px; font-size:14.5px; font-weight:700; color:var(--ink-2); transition:.15s; }
.land-switch button.on{ background:var(--accent); color:#fff; box-shadow:0 3px 10px var(--accent-glow); }
.land-switch button:not(.on):hover{ background:var(--accent-soft); color:var(--accent-ink); }
.land-switch .fl{ font-size:18px; }

.land-intro{ color:var(--ink-2); font-size:16px; max-width:74ch; line-height:1.6; margin:4px 0 0; }

/* vakantieblokken */
.vakgrid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.vakblok{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px 24px; box-shadow:var(--shadow-sm); }
.vakblok.wide{ grid-column:1 / -1; }
.vakblok-head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:4px; }
.vakblok-head h3{ font-size:20px; letter-spacing:-0.02em; }
.vakblok-head .alias{ font-size:13px; color:var(--ink-3); font-weight:600; }
.vakblok .status{ font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; padding:4px 10px; border-radius:99px; background:var(--accent-soft); color:var(--accent-ink); white-space:nowrap; }
.vakblok .status.verplicht{ background:var(--rustig-soft); color:var(--rustig-ink); }
.ftable{ width:100%; border-collapse:collapse; margin-top:12px; font-size:13.5px; }
.ftable th, .ftable td{ text-align:left; padding:8px 10px; border-bottom:1px solid var(--line); }
.ftable th{ font-size:10.5px; font-family:var(--mono); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-4); font-weight:700; }
.ftable td:first-child{ font-weight:700; color:var(--ink); }
.ftable td .wk{ font-family:var(--mono); font-size:11.5px; color:var(--ink-3); }
.ftable tr:last-child td{ border-bottom:none; }
.ftable.scroll{ display:block; max-height:none; }
.vakblok .note{ font-size:12.5px; color:var(--ink-3); line-height:1.5; margin-top:12px; padding-top:12px; border-top:1px dashed var(--line-2); }

/* feestdagen tabel */
.feest{ display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); gap:10px; }
.feest-row{ position:relative; display:flex; align-items:center; gap:12px; padding:12px 15px; background:var(--paper); border:1px solid var(--line); border-radius:14px; }
.feest-day{ width:38px; height:38px; flex:none; border-radius:11px; background:var(--accent-soft); color:var(--accent-ink); display:grid; place-items:center; font-family:var(--mono); font-size:12px; font-weight:700; text-transform:uppercase; }
.feest-info{ display:flex; flex-direction:column; min-width:0; }
.feest-info .nm{ font-size:14px; font-weight:700; }
.feest-info .dt{ font-size:12.5px; color:var(--ink-3); }
.feest-note{ font-size:13px; color:var(--ink-3); line-height:1.55; margin:14px 2px 0; background:var(--paper-2); border:1px solid var(--line); border-radius:14px; padding:14px 16px; }

/* studiedagen */
.studie{ display:grid; grid-template-columns:1.1fr 1fr; gap:20px; align-items:start; }
.studie-txt{ color:var(--ink-2); font-size:15px; line-height:1.6; }
.studie-list{ display:flex; flex-direction:column; gap:9px; }
.studie-list .it{ display:flex; gap:11px; align-items:center; padding:11px 15px; background:var(--paper); border:1px solid var(--line); border-radius:13px; font-size:13.5px; color:var(--ink-2); }
.studie-list .it::before{ content:""; width:7px; height:7px; border-radius:2px; background:var(--accent); flex:none; }

/* officieuze feestdagen chips */
.officieus{ display:flex; flex-wrap:wrap; gap:11px; }
.officieus .off-chip{ padding-right:32px; }
.off-chip{ position:relative; display:flex; align-items:center; gap:11px; padding:11px 18px; background:var(--paper); border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-sm); transition:transform .14s; }
.off-chip:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.off-chip{ transition:transform .14s, border-color .2s, background .2s, box-shadow .2s; }
.off-chip.is-hit{ border-color:var(--accent); background:var(--accent-soft); box-shadow:0 0 0 2px var(--accent-line); }
.off-chip .em{ font-size:24px; }
.off-chip .oc-txt{ display:flex; flex-direction:column; }
.off-chip .oc-nm{ font-size:14px; font-weight:700; }
.off-chip .oc-dt{ font-size:12px; color:var(--ink-3); font-family:var(--mono); }
.off-chip .feest-i{ position:absolute; top:50%; right:8px; transform:translateY(-50%); margin:0; width:18px; height:18px; font-size:10px; }

/* NL-vertaling achter een buitenlandse vakantienaam */
.vak-nl{ font-weight:600; font-size:0.78em; color:var(--accent-ink); opacity:.85; letter-spacing:0; }

/* info-icoon + tooltip bij feestdagen én officieuze dagen */
.feest-i{ position:relative; flex:0 0 auto; width:20px; height:20px; border-radius:50%; border:1px solid var(--line-2);
  background:var(--paper); color:var(--ink-3); font-size:11px; font-weight:700; font-style:italic;
  line-height:1; cursor:pointer; display:grid; place-items:center; margin-left:auto; align-self:center; }
.feest-i:hover, .feest-i.open{ background:var(--accent-soft); border-color:var(--accent-line); color:var(--accent-ink); }
.feest-i::after{ content:attr(data-tip); position:absolute; right:0; bottom:calc(100% + 8px); z-index:30;
  width:max-content; max-width:260px; padding:10px 12px; border-radius:12px; background:var(--ink);
  color:var(--paper); font-size:12.5px; font-weight:500; font-style:normal; line-height:1.45; text-align:left;
  box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transform:translateY(4px); transition:opacity .15s, transform .15s; pointer-events:none; }
.feest-i:hover::after, .feest-i.open::after{ opacity:1; visibility:visible; transform:translateY(0); }

/* 'binnenkort'-notitie als er nog geen schoolvakantiedata is */
.vak-soon{ padding:18px 20px; background:var(--paper-2); border:1px solid var(--line);
  border-radius:var(--r); font-size:14.5px; color:var(--ink-2); line-height:1.55; max-width:70ch; }
.vak-soon strong{ color:var(--ink); }

/* NL-regio-overzicht: provincie-chips + uitleg */
.prov-chips{ display:flex; flex-wrap:wrap; gap:6px; margin:4px 0 10px; }
.prov-chip{ font-size:12.5px; font-weight:600; padding:4px 10px; border-radius:999px;
  background:var(--accent-soft); color:var(--accent-ink); border:1px solid var(--accent-line); }
.rc-note{ font-size:13px; color:var(--ink-3); }

/* Frankrijk: zonekaart + legenda */
.fr-zones-intro{ margin:0 0 18px; max-width:62ch; }
.fr-zones-intro p{ color:var(--ink-2); }
.fr-zones{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.05fr); gap:26px;
  align-items:center; margin:0 0 30px; padding:22px; border:1px solid var(--line);
  border-radius:var(--r-md); background:var(--paper); }
.fr-zones-map{ min-width:0; }
.fr-zone-map{ width:100%; height:auto; display:block; }
.fr-zone-map path{ transition:filter .2s ease; }
.fr-zone-map path:hover{ filter:brightness(0.94); }
.fr-zones-legenda{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px; }
.fzl-item{ display:flex; gap:12px; align-items:flex-start; }
.fzl-chip{ flex:0 0 auto; width:30px; height:30px; border-radius:9px; color:#fff;
  font-weight:800; font-size:13px; display:flex; align-items:center; justify-content:center; }
.fzl-tx{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.fzl-tx b{ font-size:15px; }
.fzl-reg{ font-size:13px; color:var(--ink-2); }
.fzl-st{ font-size:12.5px; color:var(--ink-3); }
@media (max-width:720px){ .fr-zones{ grid-template-columns:1fr; gap:18px; } }

@media(max-width:760px){
  .vakgrid{ grid-template-columns:1fr; }
  .studie{ grid-template-columns:1fr; }
}

/* ---------- landenpagina ---------- */
.land{ padding:44px 26px 56px; }
.land-hero{ display:grid; grid-template-columns:1fr auto; gap:30px; align-items:center; padding-bottom:34px; border-bottom:1px solid var(--line); }
.land-hero-main{ display:flex; gap:20px; align-items:flex-start; }
.land-flag{ font-size:56px; line-height:1; }
.land-hero h1{ font-size:clamp(34px,5vw,52px); margin:10px 0 0; }
.land-sub{ color:var(--ink-2); font-size:16px; max-width:46ch; margin-top:12px; line-height:1.5; }
.overlap-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px 24px; box-shadow:var(--shadow); text-align:center; min-width:230px; }
.ov-lab{ font-size:13px; font-weight:700; color:var(--ink-2); }
.ov-ring{ display:flex; justify-content:center; margin:12px 0 10px; }
.ov-note{ font-size:12.5px; color:var(--ink-2); line-height:1.45; max-width:30ch; margin:0 auto; }

.land-block{ padding:36px 0; border-bottom:1px solid var(--line); }
.land-block:last-of-type{ border-bottom:none; }

/* gantt deelstaten */
.gantt{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:18px 22px; box-shadow:var(--shadow); }
.gantt-axis{ display:grid; grid-template-columns:150px 1fr; gap:14px; margin-bottom:10px; }
.gantt-weeks{ display:grid; grid-auto-flow:column; grid-auto-columns:1fr; }
.gantt-weeks .wkn{ font-family:var(--mono); font-size:10px; color:transparent; text-align:center; }
.gantt-weeks .wkn.show{ color:var(--ink-4); }
.gantt-row{ display:grid; grid-template-columns:150px 1fr; gap:14px; align-items:center; padding:5px 0; cursor:pointer; border-radius:10px; transition:background .12s; }
.gantt-row:hover{ background:var(--paper-2); }
.gantt-row.on{ background:var(--accent-soft); }
.gantt-name{ font-size:13.5px; font-weight:600; color:var(--ink-2); padding-left:6px; }
.gantt-row.on .gantt-name{ color:var(--accent-ink); font-weight:700; }
.gantt-track{ position:relative; height:26px; background:var(--paper-2); border-radius:8px; }
.gantt-bar{ position:absolute; top:0; bottom:0; background:linear-gradient(90deg, var(--accent-2), var(--accent)); border-radius:8px; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 8px var(--accent-glow); }
.gantt-bar .mono{ font-size:10px; color:#fff; font-weight:700; white-space:nowrap; }

/* drukte timeline */
.timeline{ display:grid; grid-auto-flow:column; grid-auto-columns:1fr; gap:5px; align-items:end; height:160px; padding:18px 20px; }
.tl-col{ display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:7px; transition:opacity .2s; }
.tl-col.dim{ opacity:.22; }
.tl-bar{ width:100%; max-width:26px; border-radius:8px; min-height:6px; transition:height .5s cubic-bezier(.2,.7,.3,1); }
.tl-wk{ font-size:10px; color:var(--ink-4); }

/* beste weken + weer split */
.land-split{ display:grid; grid-template-columns:1fr 1.3fr; gap:34px; }
.best-weeks{ display:flex; flex-direction:column; gap:10px; }
.bw-row{ display:flex; align-items:center; gap:14px; padding:14px 18px; background:var(--paper); border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-sm); }
.bw-rank{ width:38px; height:38px; border-radius:11px; background:var(--c-soft); color:var(--c-ink); display:grid; place-items:center; font-size:14px; font-weight:700; }
.bw-info{ display:flex; flex-direction:column; }
.bw-info strong{ font-size:15px; }
.bw-info span{ font-size:12px; color:var(--ink-3); }
.bw-score{ margin-left:auto; font-size:22px; font-weight:700; color:var(--c-ink); }

.weather{ display:grid; grid-auto-flow:column; grid-auto-columns:1fr; gap:6px; align-items:end; height:170px; padding:18px 20px; }
.we-col{ display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:6px; }
.we-band{ width:100%; max-width:34px; border-radius:8px 8px 6px 6px; min-height:30px; }
.we-wk{ font-size:10px; color:var(--ink-4); }

@media(max-width:880px){
  .land-hero{ grid-template-columns:1fr; }
  .land-split{ grid-template-columns:1fr; }
  .gantt-axis, .gantt-row{ grid-template-columns:110px 1fr; }
}

/* ---------- planner ---------- */
.planner{ padding:48px 26px 60px; }
.planner-head{ max-width:60ch; margin-bottom:26px; }
.planner-head h1{ font-size:clamp(30px,4.4vw,46px); margin:14px 0 0; }
.planner-head .lead{ font-size:17px; color:var(--ink-2); margin-top:16px; line-height:1.5; }

.planner-inputs{ display:flex; flex-wrap:wrap; gap:26px 34px; align-items:flex-end; padding:22px 26px; }
.stepper{ display:flex; flex-direction:column; gap:9px; }
.stepper-lab{ font-size:12px; font-weight:700; color:var(--ink-3); text-transform:uppercase; letter-spacing:.06em; }
.stepper-ctl{ display:inline-flex; align-items:center; gap:4px; background:var(--paper-2); border:1px solid var(--line-2); border-radius:13px; padding:4px; }
.stepper-ctl button{ width:34px; height:34px; border:none; background:var(--paper); border-radius:10px; font-size:18px; font-weight:700; color:var(--accent-ink); box-shadow:var(--shadow-sm); transition:.12s; }
.stepper-ctl button:hover:not(:disabled){ background:var(--accent-soft); }
.stepper-ctl button:disabled{ opacity:.35; cursor:not-allowed; }
.stepper-ctl .mono{ min-width:30px; text-align:center; font-size:16px; font-weight:700; }
.inp-block{ display:flex; flex-direction:column; gap:9px; }

.advice{ display:flex; gap:20px; align-items:flex-start; padding:24px 28px; margin-top:22px; background:var(--accent-soft); border-color:var(--accent-line); }
.advice-ic{ width:50px; height:50px; flex:none; border-radius:15px; background:var(--accent); color:#fff; display:grid; place-items:center; font-size:24px; box-shadow:0 6px 16px var(--accent-glow); }
.advice-txt{ flex:1; }
.advice-line{ font-size:18px; color:var(--ink); line-height:1.5; margin:8px 0 16px; max-width:62ch; }
.advice-line .good{ color:var(--rustig-ink); }
.advice-actions{ display:flex; gap:12px; flex-wrap:wrap; }

@media(max-width:560px){
  .advice{ flex-direction:column; }
  .planner-inputs{ gap:18px 24px; }
}

/* ---------- footer ---------- */
.foot{ margin-top:64px; background:var(--ink); color:oklch(86% 0.012 285); }
.foot-in{ max-width:var(--maxw); margin:0 auto; padding:64px 26px 30px; }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; }

.foot-brand .foot-logo{ display:flex; align-items:center; gap:11px; font-family:var(--sans); font-weight:800; font-size:20px; color:oklch(98% 0.01 285); letter-spacing:-.01em; }
.foot-brand .foot-logo .mark{ display:grid; place-items:center; width:34px; height:34px; border-radius:10px; background:var(--accent); color:#fff; }
.foot-brand .foot-logo .mark svg{ width:19px; height:19px; }
.foot-brand .foot-logo .nl{ color:var(--accent-2); }
.foot-desc{ margin:18px 0 22px; font-size:13.5px; line-height:1.6; color:oklch(74% 0.012 285); max-width:34ch; }
.foot-contact{ display:flex; flex-direction:column; gap:9px; }
.foot-contact a{ display:flex; align-items:center; gap:9px; font-size:13.5px; color:oklch(82% 0.012 285); text-decoration:none; transition:color .14s; }
.foot-contact a:hover{ color:#fff; }
.foot-contact .lbl{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:oklch(72% 0.012 285); width:58px; flex:none; }

.foot-col h2{ margin:0 0 16px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:oklch(72% 0.015 285); font-weight:500; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.foot-col li button{ background:none; border:0; padding:0; cursor:pointer; text-align:left; font-family:inherit; font-size:14px; color:oklch(82% 0.012 285); transition:color .14s, transform .14s; }
.foot-col li button:hover{ color:#fff; transform:translateX(3px); }

.foot-bottom{ margin-top:52px; padding-top:24px; border-top:1px solid oklch(34% 0.02 285); display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; }
.foot-bottom .copy{ font-size:12.5px; color:oklch(73% 0.012 285); }
.foot-legal{ display:flex; gap:20px; }
.foot-legal a{ font-size:12.5px; color:oklch(74% 0.012 285); text-decoration:none; transition:color .14s; }
.foot-legal a:hover{ color:#fff; }
.foot-ver{ font-family:var(--mono); font-size:11px; color:oklch(70% 0.012 285); }

@media(max-width:880px){
  .foot-top{ grid-template-columns:1fr 1fr; gap:36px 28px; }
  .foot-brand{ grid-column:1 / -1; }
}
@media(max-width:560px){
  .foot-top{ grid-template-columns:1fr; }
  .foot-bottom{ flex-direction:column; align-items:flex-start; }
}

@media(max-width:880px){
  .minimap{ grid-template-columns:1fr; }
  .dest-grid{ grid-template-columns:repeat(2,1fr); }
  .tipbar{ grid-template-columns:1fr; }
  .kb{ grid-template-columns:1fr 1fr; }
}
@media(max-width:560px){
  .dest-grid{ grid-template-columns:1fr; }
  .kb{ grid-template-columns:1fr; }
}

/* ---------- E-E-A-T: avatar, byline, auteurskaart, controle-balk ---------- */
.eeat-av{ display:inline-grid; place-items:center; flex:none; border-radius:50%;
  background:var(--accent); color:#fff; font-family:var(--mono); font-weight:700;
  letter-spacing:-.02em; line-height:1; }

.eeat-link{ background:none; border:0; padding:0; cursor:pointer; font:inherit;
  color:var(--accent-ink); font-weight:700; border-bottom:1px solid transparent; transition:border-color .14s; }
.eeat-link:hover{ border-bottom-color:currentColor; }

.eeat-check{ display:inline-grid; place-items:center; flex:none; width:20px; height:20px;
  border-radius:50%; background:var(--rustig, oklch(72% 0.13 150)); color:#fff; font-size:12px; font-weight:700; }
.eeat-check.lg{ width:30px; height:30px; font-size:16px; }

/* byline onder titel */
.eeat-byline{ display:flex; align-items:center; gap:13px; margin-top:18px; }
.eeat-byline-txt{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.eeat-by-name{ font-size:14.5px; color:var(--ink); }
.eeat-by-name a{ color:inherit; text-decoration:none; }
.eeat-by-name a:hover strong{ text-decoration:underline; }
.eeat-by-check{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; color:var(--ink-3); }
.eeat-by-check strong{ color:var(--ink-2); font-weight:700; }
.eeat-by-meta{ font-size:12.5px; color:var(--ink-3); font-family:var(--mono); }

/* losse pagina's (privacy / cookies / voorwaarden) */
.legal{ padding-top:18px; padding-bottom:40px; }
.legal .art-head{ max-width:68ch; }
.legal-lead{ font-size:17px; color:var(--ink-2); line-height:1.55; margin-top:14px; }
.legal-body{ margin-top:30px; }
.legal-body h2{ font-size:22px; }
.legal-body h3{ font-size:17px; margin:24px 0 8px; }
.legal-body ul{ margin:0 0 20px; padding-left:22px; }
.legal-body ul li{ font-size:16px; color:var(--ink-2); line-height:1.6; margin:6px 0; }
.legal-body table{ border-collapse:collapse; width:100%; margin:8px 0 24px; font-size:15px; }
.legal-body th, .legal-body td{ text-align:left; padding:9px 12px; border:1px solid var(--line); vertical-align:top; }
.legal-body th{ background:var(--paper-2); color:var(--ink); font-weight:700; }
.legal-body .legal-meta{ margin-top:28px; padding:16px 18px; background:var(--paper-2);
  border:1px solid var(--line); border-radius:14px; font-size:14.5px; color:var(--ink-2); line-height:1.6; }
.legal-body .legal-meta strong{ color:var(--ink); }

/* volledige auteurskaart */
.eeat-card{ margin:40px 0 8px; padding:24px 26px; background:var(--paper-2);
  border:1px solid var(--line); border-radius:var(--r-lg); }
.eeat-card-head{ display:flex; align-items:center; gap:15px; }
.eeat-eyebrow{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-4); }
.eeat-card-name{ margin:3px 0 2px; font-size:18px; }
.eeat-card-rol{ font-size:13px; color:var(--ink-3); }
.eeat-card-bio{ margin:16px 0 14px; font-size:14.5px; line-height:1.65; color:var(--ink-2); }
.eeat-cred{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; }
.eeat-cred li{ font-size:12.5px; color:var(--ink-2); background:var(--bg-2); border:1px solid var(--line);
  padding:6px 11px; border-radius:999px; }
.eeat-cred li::before{ content:"✓ "; color:var(--rustig, oklch(60% 0.13 150)); font-weight:700; }
.eeat-review-line{ display:flex; align-items:flex-start; gap:10px; margin-top:18px; padding-top:16px;
  border-top:1px solid var(--line); font-size:13.5px; line-height:1.55; color:var(--ink-2); }

/* controle-balk (tool-/contentpagina's) */
.eeat-bar{ max-width:var(--maxw); margin:8px auto 0; padding:0 26px; }
.eeat-bar-in{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding:18px 22px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm); }
.eeat-bar-main{ display:flex; align-items:center; gap:14px; min-width:0; }
.eeat-bar-txt{ display:flex; flex-direction:column; gap:2px; }
.eeat-bar-lead{ font-size:14.5px; color:var(--ink); }
.eeat-bar-sub{ font-size:12.5px; color:var(--ink-3); }
/* E-E-A-T-team (blog + landenpagina's): grid van auteurskaarten */
.eeat-team-block{ margin-top:8px; }
.eeat-team{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:18px; margin-top:6px; }
.eeat-team .eeat-card{ margin:0; }
img.eeat-av{ background:var(--paper-2); }
.eeat-sources{ display:flex; align-items:center; gap:12px; }
.eeat-src-lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-4); }
.eeat-src-list{ display:flex; flex-wrap:wrap; gap:7px; }
.eeat-src{ font-size:12px; font-family:var(--mono); color:var(--ink-2); background:var(--bg-2);
  border:1px solid var(--line); padding:5px 10px; border-radius:8px; cursor:default; }

@media(max-width:680px){
  .eeat-bar-in{ flex-direction:column; align-items:flex-start; }
}

/* ---------- Over ons ---------- */
.overons{ max-width:var(--maxw); margin:0 auto; padding:38px 26px 20px; }
.oo-hero{ padding:24px 0 8px; }
.oo-hero h1{ font-size:clamp(34px,5vw,52px); line-height:1.04; margin:12px 0 0; letter-spacing:-.02em; }
.oo-hero .lead{ max-width:60ch; margin:18px 0 0; font-size:17px; line-height:1.6; color:var(--ink-2); }
.oo-trust{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:34px; }
.oo-trust-it{ display:flex; flex-direction:column; gap:3px; padding:18px 18px; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow-sm); }
.oo-trust-it strong{ font-size:18px; color:var(--ink); }
.oo-trust-it span{ font-size:12.5px; color:var(--ink-3); }

.oo-body, .oo-missie .oo-body{ max-width:72ch; font-size:16px; line-height:1.7; color:var(--ink-2); margin:0; }

.oo-team{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.oo-expert{ padding:24px 24px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-lg); box-shadow:var(--shadow-sm); }
.oo-expert-head{ display:flex; align-items:center; gap:14px; }
.oo-expert-head h3{ margin:0 0 2px; font-size:17px; }
.oo-expert-rol{ font-size:12.5px; color:var(--accent-ink); font-weight:600; }
.oo-expert-bio{ margin:16px 0 14px; font-size:14px; line-height:1.6; color:var(--ink-2); }

.oo-werk{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.oo-werk-step{ padding:22px 22px; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); }
.oo-werk-n{ font-size:13px; color:var(--accent-ink); font-weight:700; }
.oo-werk-step h3{ margin:10px 0 8px; font-size:15.5px; }
.oo-werk-step p{ margin:0; font-size:13.5px; line-height:1.6; color:var(--ink-2); }

.oo-onder{ display:grid; grid-template-columns:1.2fr 1fr; gap:24px; }
.oo-bronnen, .oo-contact{ padding:26px 28px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-lg); box-shadow:var(--shadow-sm); }
.oo-bronnen ul{ list-style:none; margin:16px 0 0; padding:0; display:flex; flex-direction:column; gap:12px; }
.oo-bronnen li{ display:flex; flex-direction:column; gap:2px; padding-bottom:12px; border-bottom:1px solid var(--line); }
.oo-bronnen li:last-child{ border-bottom:0; padding-bottom:0; }
.oo-bronnen li strong{ font-size:14.5px; }
.oo-bronnen li span{ font-size:12.5px; color:var(--ink-3); }
.oo-contact p{ margin:16px 0 20px; font-size:14.5px; line-height:1.6; color:var(--ink-2); }

@media(max-width:880px){
  .oo-trust{ grid-template-columns:1fr 1fr; }
  .oo-team{ grid-template-columns:1fr 1fr; }
  .oo-werk{ grid-template-columns:1fr 1fr; }
  .oo-onder{ grid-template-columns:1fr; }
}
@media(max-width:560px){
  .oo-trust{ grid-template-columns:1fr; }
  .oo-team{ grid-template-columns:1fr; }
  .oo-werk{ grid-template-columns:1fr; }
}

/* ===================================================================
   SAMENWERKEN — B2B / partnerships (uit het v3-ontwerp)
   =================================================================== */
.sw-hero{ padding:30px 0 6px; max-width:780px; }
.sw-hero h1{ margin-top:12px; }
.sw-trust{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:26px; }
.sw-trust-it{ display:flex; flex-direction:column; gap:3px; padding:16px 18px; background:var(--paper-2);
  border:1px solid var(--line); border-radius:var(--r); }
.sw-trust-it strong{ font-size:18px; letter-spacing:-0.02em; }
.sw-trust-it span{ font-size:12.5px; color:var(--ink-3); line-height:1.35; }
.sw-hero-cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:24px; align-items:center; }

.sw-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.sw-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px 26px 24px; box-shadow:var(--shadow-sm); transition:transform .16s, box-shadow .16s; }
.sw-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.sw-ic{ width:50px; height:50px; display:grid; place-items:center; border-radius:15px;
  background:var(--accent-soft); color:var(--accent-ink); margin-bottom:16px; }
.sw-ic svg{ width:26px; height:26px; }
.sw-card h3{ font-size:20px; letter-spacing:-0.02em; }
.sw-card-d{ font-size:14.5px; color:var(--ink-2); line-height:1.6; margin-top:8px; }
.sw-pts{ list-style:none; margin-top:16px; display:flex; flex-direction:column; gap:9px; padding:0; }
.sw-pts li{ display:flex; align-items:flex-start; gap:9px; font-size:13.5px; color:var(--ink-2); line-height:1.45; }
.sw-pts li svg{ flex:none; margin-top:2px; color:var(--rustig-ink, #11825e); }

.sw-mini-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.sw-mini{ display:flex; gap:14px; align-items:flex-start; padding:18px 20px; background:var(--paper-2);
  border:1px solid var(--line); border-radius:var(--r); }
.sw-mini-ic{ width:42px; height:42px; flex:none; display:grid; place-items:center; border-radius:12px;
  background:var(--paper); border:1px solid var(--line); color:var(--accent-ink); }
.sw-mini-ic svg{ width:21px; height:21px; }
.sw-mini h3{ font-size:15px; letter-spacing:-0.01em; }
.sw-mini p{ font-size:13px; color:var(--ink-3); line-height:1.5; margin-top:4px; }

.sw-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.sw-step{ position:relative; padding:22px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r); }
.sw-step-n{ font-size:13px; font-weight:700; color:var(--accent-ink); background:var(--accent-soft);
  width:38px; height:38px; border-radius:11px; display:grid; place-items:center; margin-bottom:14px; }
.sw-step h3{ font-size:16px; letter-spacing:-0.01em; }
.sw-step p{ font-size:13.5px; color:var(--ink-3); line-height:1.55; margin-top:6px; }

.sw-contact-block{ border-bottom:none; }
.sw-contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:40px; align-items:start;
  background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r-xl); padding:34px 36px; }
.sw-contact-intro h2{ font-size:26px; }
.sw-contact-intro p{ font-size:15px; color:var(--ink-2); line-height:1.6; margin-top:12px; max-width:42ch; }
.sw-contact-direct{ display:flex; flex-direction:column; gap:10px; margin-top:22px; }
.sw-contact-direct a{ display:flex; flex-direction:column; gap:1px; text-decoration:none; color:var(--ink);
  font-size:15px; font-weight:600; }
.sw-contact-direct .lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); font-weight:700; }
.sw-contact-direct a:hover{ color:var(--accent-ink); }

.sw-form{ display:flex; flex-direction:column; gap:14px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:24px 24px 22px; box-shadow:var(--shadow-sm); }
.sw-field{ display:flex; flex-direction:column; gap:6px; font-size:13px; font-weight:700; color:var(--ink-2); }
.sw-field.two{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.sw-field input, .sw-field select, .sw-field textarea{ font:inherit; font-weight:400; font-size:14.5px;
  color:var(--ink); background:var(--bg); border:1px solid var(--line-2); border-radius:var(--r-sm);
  padding:11px 13px; outline:none; transition:border-color .14s; width:100%; }
.sw-field input:focus, .sw-field select:focus, .sw-field textarea:focus{ border-color:var(--accent); }
.sw-field textarea{ resize:vertical; min-height:90px; }
.sw-form .btn{ margin-top:4px; }
.sw-form-note{ font-size:12px; color:var(--ink-4); line-height:1.45; }
.sw-hp{ position:absolute !important; left:-9999px; width:1px; height:1px; overflow:hidden; }
.sw-form-fout{ background:var(--druk-soft); color:var(--druk-ink); border:1px solid oklch(88% 0.05 28);
  border-radius:var(--r-sm); padding:11px 14px; font-size:13.5px; font-weight:600; }
.sw-form-done{ align-items:center; text-align:center; justify-content:center; gap:10px; padding:44px 28px; }
.sw-done-ic{ width:54px; height:54px; display:grid; place-items:center; border-radius:50%;
  background:var(--rustig-soft); color:var(--rustig-ink); }
.sw-form-done h3{ font-size:20px; letter-spacing:-0.02em; }
.sw-form-done p{ font-size:14px; color:var(--ink-2); line-height:1.55; max-width:34ch; }

@media(max-width:860px){
  .sw-trust{ grid-template-columns:1fr 1fr; }
  .sw-grid, .sw-mini-grid{ grid-template-columns:1fr; }
  .sw-steps{ grid-template-columns:1fr; }
  .sw-contact-grid{ grid-template-columns:1fr; gap:26px; padding:26px 22px; }
  .sw-field.two{ grid-template-columns:1fr; }
}

/* ---------- landen-overzicht (verplaatst uit landen.html) ---------- */
.landen-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; }
.landtegel{ display:flex; align-items:center; gap:12px; padding:16px 18px; background:var(--paper);
  border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow-sm);
  transition:border-color .15s, box-shadow .15s, transform .15s; }
.landtegel:hover{ border-color:var(--accent-line); box-shadow:var(--shadow); transform:translateY(-2px); }
.landtegel.soon{ opacity:.7; }
.lt-flag{ font-size:26px; }
.lt-name{ font-weight:700; flex:1; }

/* ---------- planner: invoer-rijen + waarheen-kaarten (verplaatst uit planner.html) ---------- */
.planner-inputs.card{ flex-direction:column; align-items:stretch; gap:22px; }
.pl-row{ display:flex; flex-wrap:wrap; gap:16px 34px; align-items:flex-start; }
.pl-row .inp-block, .pl-row .stepper{ min-width:0; }
.regio-window{ display:block; margin-top:7px; font-size:12.5px; color:var(--ink-3); }
[data-regio-seg]{ vertical-align:middle; }
.waarheen{ margin-top:22px; }
.wh-list{ display:grid; grid-template-columns:repeat(auto-fill,minmax(232px,1fr)); gap:12px; margin-top:12px; }
.wh-card{ text-align:left; background:var(--paper); border:1px solid var(--line);
  border-radius:16px; padding:14px 16px; cursor:pointer; font:inherit;
  display:flex; flex-direction:column; gap:11px; transition:border-color .14s, box-shadow .14s; }
.wh-card:hover{ border-color:var(--accent-line); }
.wh-card.on{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-glow); }
.wh-card-top{ display:flex; align-items:center; gap:9px; }
.wh-flag{ font-size:18px; line-height:1; }
.wh-nm{ font-weight:700; color:var(--ink); flex:1; min-width:0; }
.wh-score{ font-weight:800; font-size:19px; line-height:1; }
.wh-score.is-rustig{ color:var(--rustig); } .wh-score.is-matig{ color:var(--matig); } .wh-score.is-druk{ color:var(--druk); }
.wh-meters{ display:flex; flex-direction:column; gap:6px; }
.wh-meter{ display:grid; grid-template-columns:34px 1fr; align-items:center; gap:9px; }
.wh-lab{ font-size:10px; color:var(--ink-3); text-transform:uppercase; letter-spacing:.04em; }
.wh-card .mini-bar{ height:7px; background:var(--paper-2); border-radius:6px; overflow:hidden; }
.wh-card .mini-bar i{ display:block; height:100%; border-radius:6px; }
.wh-back{ font-size:11.5px; color:var(--accent-ink); font-weight:600; }
.wh-hint{ font-size:12.5px; color:var(--ink-3); }
.accent-ink{ color:var(--accent-ink); }
