/* ══════════════════════════════════════════════════════════════════════════
   v3-pages.css — PAGINA-SPECIFIEKE STIJL (Fase 1)
   ──────────────────────────────────────────────────────────────────────────
   Bovenop rebuild.css (tokens + banen-lint + component-basis). Gebruikt
   UITSLUITEND de semantische rollen (--bg/--fg/--surface/--accent/--line/
   --edge/--mono-c/--fg-soft/--fg-mute/--star/--focus/--on-accent) zodat alles
   in beide modi (warm perkament / nacht-slate / nacht-warm-houtskool) klopt.

   Raakt rebuild.css en v3-globe.css NIET aan. file://-proof, mobiel-first,
   geen CDN, niets breder dan 100vw. Eén gevulde rode CTA per pagina (.cta).

   Bron: plannen/rebuild/front-end-designer.md §3 (per pagina), §4 (geen secties),
   §7 (audiospeler-skin); content-writer.md §2 (copy/CTA's); rebuild.css.
   ════════════════════════════════════════════════════════════════════════════ */


/* ════════════════════════════════════════════════════════
   GEDEELD — kop-ritme, secties, footer, scroll-cue, woordmerk-punt
════════════════════════════════════════════════════════ */
body{padding-top:0}
main{display:block}

/* het rode woordmerk-puntje achter "Bas Boudewijn" in de nav + heroes */
.wm-dot{color:var(--accent)}

/* sectie-kop-blok: eyebrow + h2 + optionele rechter-link op één lijn */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;
  margin-bottom:clamp(22px,4vw,38px)}
.sec-head h2{font-family:var(--f-d);font-weight:600;font-size:clamp(26px,4.4vw,40px);line-height:1.06;color:var(--fg)}
.sec-head .link{font-size:13.5px;white-space:nowrap}

/* grote display-kop */
.display{font-family:var(--f-d);font-weight:600;line-height:1.02;color:var(--fg);
  font-size:clamp(40px,8.5vw,84px);letter-spacing:-.01em}
.display em{font-style:italic;font-family:var(--f-i);font-weight:400}
.lede{font-family:var(--f-i);font-style:italic;font-size:clamp(18px,2.6vw,23px);line-height:1.5;
  color:var(--fg-soft);max-width:46ch}

/* scroll-cue onderaan een hero */
.scroll-cue{display:inline-flex;flex-direction:column;align-items:center;gap:8px;margin-top:clamp(28px,5vw,48px);
  font-family:var(--f-m);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-mute)}
.scroll-cue .arr{width:1px;height:34px;background:linear-gradient(var(--fg-mute),transparent)}
@media (prefers-reduced-motion:no-preference){
  .scroll-cue .arr{animation:cueBob 2.2s var(--ease) infinite}
}
@keyframes cueBob{0%,100%{transform:scaleY(.7);opacity:.5;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* gedeelde footer (warm én nacht) */
.foot{width:100%;background:var(--bg);color:var(--fg-soft);
  border-top:1px solid var(--line);padding:clamp(34px,6vw,54px) clamp(22px,5vw,40px)}
.foot .wrap{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.foot-sig{font-family:var(--f-i);font-style:italic;font-size:16px;color:var(--fg)}
.foot-meta{font-family:var(--f-m);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-mute)}
.foot-links{display:flex;gap:18px;flex-wrap:wrap;font-size:13.5px}
.foot-links a{color:var(--fg-soft);text-decoration:none}
.foot-links a:hover{color:var(--accent)}

/* live-badge — basis (.live-badge/.pip/livePulse) staat nu canoniek in
   rebuild.css (gedeeld door álle pagina's). Hier alleen nog de pagina-specifieke
   link-affordance (a.live-badge) + .live-text verderop; geen duplicaat meer. */

/* nieuwsbrief / consent-blok (EU-first: link/consent, geen tracking-iframe) */
.news{max-width:560px}
.news h2{font-family:var(--f-d);font-weight:600;font-size:clamp(24px,4vw,34px);line-height:1.08;color:var(--fg)}
.news p{margin-top:10px;color:var(--fg-soft);font-size:15.5px;line-height:1.6;max-width:48ch}
.news-form{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.news-form input[type=email]{flex:1 1 220px;min-width:0;background:var(--bg);color:var(--fg);
  border:1px solid var(--line);border-radius:100px;padding:13px 20px;font-family:var(--f-b);font-size:14.5px}
.news-form input::placeholder{color:var(--fg-mute)}
.news-form input:focus{outline:2px dashed var(--focus);outline-offset:2px;border-color:var(--accent)}
.news-note{margin-top:14px;font-family:var(--f-m);font-size:10.5px;letter-spacing:.06em;color:var(--fg-mute);line-height:1.7}
.news-note a{color:var(--fg-soft);text-decoration:underline;text-underline-offset:2px}
.news-msg{margin-top:12px;font-size:13.5px;color:var(--accent);min-height:1.2em}

/* lege-staat — kort, in stem, nooit een systeemmelding */
.empty{font-family:var(--f-i);font-style:italic;color:var(--fg-soft);font-size:16px;line-height:1.6;
  border:1px dashed var(--line);border-radius:12px;padding:26px 24px;text-align:center;max-width:52ch;margin:0 auto}


/* ════════════════════════════════════════════════════════
   HOME — gedeelde secties: atlas-uitnodiging · nieuwsbrief
════════════════════════════════════════════════════════ */
/* atlas-uitnodiging op home (nacht) — geen tweede globe, maar een rustige poort
   naar The Journey (B6). Het Zuiderkruis-merkteken keert klein terug als anker. */
.atlas-invite{display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:clamp(12px,2vw,18px);position:relative;max-width:60ch;margin:0 auto}
.atlas-invite .eyebrow{margin:0}
.atlas-invite h2{font-family:var(--f-d);font-weight:600;line-height:1.08;color:var(--fg);
  font-size:clamp(26px,4.4vw,40px);letter-spacing:-.01em;max-width:20ch}
.atlas-lede{font-family:var(--f-i);font-style:italic;font-size:clamp(17px,2.4vw,21px);
  line-height:1.55;color:var(--fg-soft);max-width:48ch}
.atlas-invite .cta{margin-top:6px}
.atlas-crux{width:44px;height:60px;opacity:.7;margin-bottom:2px}


/* ════════════════════════════════════════════════════════
   HOME — gedeelde band-overgangen + hero-elementen
   ────────────────────────────────────────────────────────
   ZACHTE HORIZON-OVERGANG tussen de atlas-uitnodiging (nacht slate) en de
   nieuwsbrief (nacht-warm houtskool): een overlappende strook in de twee
   bandkleuren, zodat de naad een horizon wordt. Pure pseudo-elementen op de
   band-naad; pointer-events none; raken geen tekst. CONTRAST blijft AA: de tekst
   staat op de volle bandkleur, de strook ligt enkel op de naad zónder tekst.
════════════════════════════════════════════════════════ */
#atlas-invite, #newsletter{ position:relative }
#atlas-invite::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:150px;z-index:0;pointer-events:none}
#newsletter::before{
  content:"";position:absolute;left:0;right:0;top:0;height:150px;z-index:0;pointer-events:none}
/* atlas(nacht slate) → nieuwsbrief(nacht-warm houtskool #16140F): koel → kampvuur-warm */
#atlas-invite::after{ background:linear-gradient(to bottom, transparent, color-mix(in srgb,var(--char) 78%,var(--night))) }
#newsletter::before{ background:linear-gradient(to top, transparent, color-mix(in srgb,var(--night) 26%,var(--char))) }
/* color-mix-loze terugval (oudere engines): effen buur-kleur i.p.v. meng */
@supports not (background:color-mix(in srgb,red,blue)){
  #atlas-invite::after{ background:linear-gradient(to bottom, transparent, #16140F) }
  #newsletter::before{ background:linear-gradient(to top, transparent, rgba(21,23,28,.26)) }
}
/* de wrap-inhoud blijft boven de horizon-strook op de band */
#atlas-invite > .wrap, #newsletter > .wrap{ position:relative;z-index:3}

/* live-badge is een ÉCHTE <a> — geef 'm linkgedrag-affordance + nette focus.
   De aria-live zit op .live-text (niet op de hele link). */
a.live-badge{text-decoration:none;align-self:flex-start;cursor:pointer;
  transition:border-color .2s var(--ease),color .2s var(--ease)}
a.live-badge:hover{border-color:var(--accent)}
a.live-badge:hover b{color:var(--accent)}
.live-badge .live-text{display:inline-flex;align-items:baseline;gap:6px}
.live-stop{white-space:nowrap}

/* ÉÉN dominante primaire CTA (groter) + een veel lichtere tweede actie. */
.cta--lg{padding:16px 32px;font-size:15px}
.link--quiet{color:var(--fg-mute);font-weight:500;font-size:13.5px;border-bottom-color:transparent}
.link--quiet:hover{color:var(--accent);border-bottom-color:transparent}


/* ════════════════════════════════════════════════════════
   BENDING POINTS — woordenboek-definitie · chronologische essay-rijen
════════════════════════════════════════════════════════ */
.bp-hero{min-height:70svh;display:flex;align-items:center}
.bp-hero .wrap{display:flex;flex-direction:column;gap:18px}
.bp-hero h1{font-family:var(--f-d);font-weight:600;font-size:clamp(42px,8vw,82px);line-height:1.0;color:var(--fg)}
.bp-def{border-left:2px solid var(--accent);padding:4px 0 4px 18px;max-width:54ch}
.bp-def .term{font-family:var(--f-d);font-style:italic;font-size:18px;color:var(--fg)}
.bp-def .term span{font-family:var(--f-m);font-style:normal;font-size:12px;color:var(--mono-c);letter-spacing:.06em}
.bp-def .gloss{margin-top:6px;font-family:var(--f-i);font-style:italic;color:var(--fg-soft);font-size:16px;line-height:1.55}
.bp-def .note{margin-top:10px;font-family:var(--f-m);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-mute)}

/* bending-lifeline — scroll-gedreven: de gebogen route daalt weg van de rechte
   stippellijn (het leven dat nooit geleefd werd); de afstand groeit met scroll. */
.bp-life-stage{position:relative;width:100%;max-width:640px;margin-top:14px;--gap:0}
.bp-life{width:100%;height:auto;display:block;overflow:visible}
.bp-life .bp-ghost{fill:none;stroke:var(--fg-mute);stroke-width:1.5;
  stroke-dasharray:2 9;stroke-linecap:round;opacity:.6;
  stroke-dashoffset:1;transition:stroke-dashoffset .12s linear}
.bp-life .bp-route{fill:none;stroke:var(--accent);stroke-width:2.4;stroke-linecap:round;
  stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset .12s linear}
.bp-life .bp-bend{fill:var(--bg);stroke:var(--accent);stroke-width:2.2}
.bp-life .bp-gap{stroke:var(--fg-mute);stroke-width:1;stroke-dasharray:3 4;opacity:0}
.bp-life .bp-gap-end{fill:var(--accent);opacity:0}
.bp-life-bend,.bp-life-ghost,.bp-life-gap{position:absolute;font-family:var(--f-m);
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;pointer-events:none}
.bp-life-bend{left:9%;top:-2px;color:var(--accent)}
.bp-life-ghost{right:6%;top:12%;font-family:var(--f-i);font-style:italic;text-transform:none;
  letter-spacing:0;font-size:13px;color:var(--fg-mute);opacity:.85}
.bp-life-gap{right:4%;bottom:6%;color:var(--fg-mute);
  opacity:calc(var(--gap) * .9);transition:opacity .15s linear}
@media (max-width:540px){
  .bp-life-bend,.bp-life-ghost,.bp-life-gap{font-size:9px}
  .bp-life-ghost{font-size:11px;max-width:46vw;white-space:normal;text-align:right}
}
@media (prefers-reduced-motion:reduce){
  .bp-life .bp-route,.bp-life .bp-ghost{stroke-dashoffset:0;transition:none}
  .bp-life .bp-gap,.bp-life .bp-gap-end{opacity:.7}
}

/* essay-lijst — groot cursief cijfer + titel + lezen/luisteren-rij */
.essay-list{display:flex;flex-direction:column}
.essay{display:grid;grid-template-columns:auto 1fr;gap:clamp(18px,3vw,34px);align-items:start;
  padding:clamp(24px,4vw,40px) 0;border-top:1px solid var(--line)}
.essay:first-child{border-top:none}
.essay-no{font-family:var(--f-i);font-style:italic;font-weight:400;font-size:clamp(40px,7vw,72px);
  line-height:.9;color:var(--accent);min-width:1.4em}
.essay-meta{font-family:var(--f-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mono-c);margin-bottom:8px}
.essay-title{font-family:var(--f-d);font-weight:600;font-size:clamp(22px,3.4vw,32px);line-height:1.08;color:var(--fg)}
.essay-dek{margin-top:8px;color:var(--fg-soft);font-size:15px;line-height:1.55;max-width:58ch}
.essay-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:16px}
.essay-read{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:14px;
  text-decoration:none;border:none;background:none;font-family:inherit;cursor:pointer}
.essay-read:hover{text-decoration:underline;text-underline-offset:3px}
.essay-listen{display:inline-flex;align-items:center;gap:9px;color:var(--fg);font-size:13.5px;font-weight:500;
  border:1px solid var(--line);background:none;border-radius:100px;padding:7px 14px 7px 9px;cursor:pointer;font-family:inherit}
.essay-listen:hover:not([disabled]){border-color:var(--accent);color:var(--accent)}
.essay-listen[disabled]{opacity:.5;cursor:not-allowed}
.essay-listen .pbtn{width:24px;height:24px;border-radius:50%;border:1px solid currentColor;display:inline-flex;align-items:center;justify-content:center}
.essay-listen .pbtn .tri{--t:5px;--h:8px;border-bottom-color:currentColor}
.essay-listen .pbtn .tri--play{border-left-color:currentColor;border-bottom-color:transparent}
@media (max-width:560px){
  .essay{grid-template-columns:1fr;gap:6px}
  .essay-no{font-size:clamp(34px,11vw,52px)}
}
/* "komt eraan"-staat: de seizoensreeks zonder gepubliceerde essays */
.bp-coming-intro{font-family:var(--f-i);font-style:italic;font-size:clamp(16px,2.2vw,19px);
  line-height:1.6;color:var(--fg-soft);max-width:60ch;margin:0 0 8px;padding-bottom:clamp(8px,2vw,16px)}
.essay--coming{opacity:.92}
.essay--coming .essay-no{color:var(--edge)}
.essay--coming .essay-title{color:var(--fg)}
.essay-soon{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-m);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--mono-c);
  border:1px solid var(--line);border-radius:100px;padding:6px 13px}
.essay-soon-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex:0 0 auto}
@media (prefers-reduced-motion:no-preference){
  .essay-soon-dot{animation:livePulse 2.4s ease-in-out infinite}
}


/* ════════════════════════════════════════════════════════
   MUSIC / VELDOPNAMES — draaiende plaat · Side A/B · lyrics · speler
════════════════════════════════════════════════════════ */
/* hero geharmoniseerd naar de inhouds-maat (review A1: content 64-72svh) */
.music-hero{min-height:72svh;display:flex;align-items:center}
.music-hero .scroll-cue{align-self:flex-start}
@media (max-width:760px){.music-hero .scroll-cue{align-self:center}}
.music-hero .wrap{display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:760px){.music-hero .wrap{grid-template-columns:1fr;justify-items:center;text-align:center}}
.disc{position:relative;width:min(74vw,300px);height:min(74vw,300px);border-radius:50%;flex:0 0 auto;
  background:
    linear-gradient(135deg, rgba(255,255,255,.14), transparent 42%),
    repeating-radial-gradient(circle at 50% 50%, #0c0a07 0 1px, #15110b 1px 3px),
    radial-gradient(circle at 38% 34%, rgba(255,255,255,.08), transparent 60%);
  box-shadow:0 18px 50px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.05)}
.disc::before{content:'';position:absolute;inset:30%;border-radius:50%;background:var(--accent);
  box-shadow:0 4px 16px rgba(0,0,0,.4)}
.disc::after{content:'';position:absolute;left:50%;top:50%;width:14px;height:14px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--char);z-index:2}
.disc .label-b{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1;
  font-family:var(--f-i);font-style:italic;font-size:34px;color:var(--on-accent)}
@media (prefers-reduced-motion:no-preference){
  .disc.spin{animation:discSpin 22s linear infinite}
  .disc.spin.paused{animation-play-state:paused}
}
@keyframes discSpin{to{transform:rotate(360deg)}}
.music-hero h1{font-family:var(--f-d);font-weight:600;font-size:clamp(40px,7vw,72px);line-height:1.0;color:var(--fg)}
.music-hero .cta-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px;align-items:center}
@media (max-width:760px){.music-hero .cta-row{justify-content:center}}

/* ════════════════════════════════════════════════════════
   DE PLATENMUUR — een strakke 2D-wand van Bas' albumhoezen
   nacht-warm · roest-accent · fotografisch · ingetogen, chic
   (pure 2D — geen WebGL, geen CDN; het grid ís de navigatie)
════════════════════════════════════════════════════════ */
/* de hero overschrijft de oude 2-koloms plaat-layout: nu een gestapelde
   "intro → muur → entreepunten → scroll-cue" */
.kb-hero{min-height:auto;padding-top:clamp(48px,8svh,96px);padding-bottom:clamp(40px,6svh,72px)}
.kb-hero .wrap{display:block;grid-template-columns:none;text-align:left;gap:0}
@media (max-width:760px){.kb-hero .wrap{justify-items:stretch;text-align:left}}
.kb-intro{max-width:62ch}
.kb-hero .cta-row{margin-top:18px}
@media (max-width:760px){.kb-hero .cta-row{justify-content:flex-start}}
.kb-hero .scroll-cue{align-self:flex-start;margin-top:clamp(20px,3vw,32px)}
@media (max-width:760px){.kb-hero .scroll-cue{align-self:flex-start}}

/* de muur-host: warme wand met een ingetogen avond-gloed; hoezen liggen erin */
.kb-stage{position:relative;width:100%;margin-top:clamp(22px,3.5vw,40px);border-radius:16px;
  overflow:hidden;background:
    radial-gradient(120% 80% at 50% 6%, rgba(181,71,31,.14), transparent 60%),
    linear-gradient(180deg, #221d15 0%, #15110b 100%);
  box-shadow:0 24px 70px rgba(0,0,0,.5), inset 0 0 0 1px rgba(255,255,255,.05),
    inset 0 60px 120px rgba(181,71,31,.05)}
.kb-noscript{padding:28px;color:var(--fg-soft);font-family:var(--f-i);font-style:italic;margin:0}

.kb-wall-inner{padding:clamp(20px,3.4vw,40px)}
.kb-wall-loading{padding:48px 28px;text-align:center;
  font-family:var(--f-m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mono-c, rgba(255,255,255,.45))}

/* ── het rustige grid van hoezen ─────────────────────────────────────────── */
.kb-grid{display:grid;gap:clamp(14px,1.8vw,24px);
  grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:900px){.kb-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:620px){.kb-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* één hoes = volledige knop; rustig, chic, hover-lift */
.kb-sleeve{display:flex;flex-direction:column;gap:10px;padding:0;border:0;background:none;
  text-align:left;cursor:pointer;font-family:inherit;color:inherit;-webkit-tap-highlight-color:transparent;
  opacity:0;transform:translateY(10px);
  animation:kbSleeveIn .6s var(--ease) forwards;animation-delay:calc(var(--kb-i,0) * 60ms)}
.kb-art{position:relative;display:block;aspect-ratio:1/1;width:100%;border-radius:6px;overflow:hidden;
  background:linear-gradient(180deg,#2a2318,#191510);
  box-shadow:0 10px 26px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.06);
  transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.kb-cover{display:block;width:100%;height:100%;object-fit:cover}
.kb-sleeve:hover .kb-art,.kb-sleeve:focus-visible .kb-art{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(0,0,0,.55), inset 0 0 0 1px rgba(214,96,60,.5)}
.kb-sleeve:focus-visible{outline:none}
.kb-sleeve:focus-visible .kb-art{outline:2px solid var(--accent);outline-offset:3px}

/* placeholder-hoes = bruin-papieren kraft/perkament platenhoes (merkstijl).
   Doffe warme kraft, subtiele papiergrain, bedrukt met titel + artiest.
   Nooit een gebroken-image-icoon. */
.kb-ph{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:flex-start;justify-content:flex-end;
  padding:clamp(12px,7%,20px);box-sizing:border-box;overflow:hidden;
  color:var(--umber,#5B5345);
  background:
    radial-gradient(135% 120% at 18% 8%, rgba(255,250,238,.55), transparent 55%),
    radial-gradient(120% 120% at 92% 96%, rgba(91,83,69,.22), transparent 60%),
    linear-gradient(168deg,#E4D8BE 0%,#D8C8A6 48%,#CBB88F 100%)}
/* subtiele kraft-grain (zelfde repeating-linear-gradient-aanpak als elders) */
.kb-ph-grain{position:absolute;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  background-image:
    repeating-linear-gradient(31deg, rgba(91,83,69,.05) 0 2px, transparent 2px 4px),
    repeating-linear-gradient(122deg, rgba(91,83,69,.04) 0 3px, transparent 3px 7px)}
/* klein merk-zegel ▲ rechtsboven */
.kb-ph-mark{position:absolute;top:clamp(11px,7%,18px);right:clamp(11px,7%,18px);
  font-size:11px;line-height:1;color:rgba(180,70,43,.62)}
/* de "druk" linksonder: titel + artiest */
.kb-ph-print{position:relative;display:flex;flex-direction:column;align-items:flex-start;
  width:100%;min-width:0}
.kb-ph-title{font-family:var(--f-d);font-weight:600;
  font-size:clamp(15px,4.6cqw,21px);line-height:1.16;color:var(--umber,#5B5345);
  overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  word-break:break-word;overflow-wrap:anywhere}
.kb-ph-rule{width:30px;height:2px;margin:8px 0;background:var(--outback,#B4462B);
  opacity:.8;border-radius:2px}
.kb-ph-artist{font-family:var(--f-m);font-size:clamp(8.5px,2.6cqw,11px);
  letter-spacing:.16em;text-transform:uppercase;color:rgba(91,83,69,.74);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
/* demo-release: roest-stempel, schuin op de hoes */
.kb-ph--demo .kb-ph-stamp{position:absolute;top:14%;left:8%;
  font-family:var(--f-d);font-weight:700;font-size:clamp(20px,8.4cqw,34px);
  line-height:1;letter-spacing:.04em;text-transform:lowercase;
  color:var(--outback,#B4462B);
  transform:rotate(-9deg);transform-origin:left center;
  padding:3px 12px 5px;border:2px solid var(--outback,#B4462B);border-radius:7px;
  opacity:.86;box-shadow:0 0 0 3px rgba(180,70,43,.08)}
.kb-art{container-type:inline-size}

/* onderschrift: titel · soort · jaar, klein-getypt */
.kb-cap{display:flex;flex-direction:column;gap:2px;min-width:0}
.kb-cap-title{font-family:var(--f-d);font-weight:500;font-size:14.5px;line-height:1.25;
  color:rgba(244,237,224,.94);
  overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.kb-cap-meta{font-family:var(--f-m);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(214,96,60,.78)}
.kb-sleeve:hover .kb-cap-title{color:#fff}

/* ── navigatie-entreepunten: getypte labels, geen objecten ───────────────── */
.kb-entries{display:flex;flex-wrap:wrap;align-items:baseline;gap:10px 18px;
  margin-top:clamp(20px,3vw,32px);padding-top:clamp(18px,2.6vw,26px);
  border-top:1px solid rgba(255,255,255,.08)}
.kb-entries-lead{font-family:var(--f-i);font-style:italic;font-size:14px;color:rgba(244,237,224,.55);margin-right:2px}
.kb-entry{display:inline-flex;flex-direction:column;align-items:flex-start;gap:1px;
  min-height:44px;justify-content:center;padding:6px 4px;border:0;background:none;cursor:pointer;
  font-family:inherit;color:inherit;-webkit-tap-highlight-color:transparent;
  transition:color .2s var(--ease)}
.kb-entry-label{position:relative;font-family:var(--f-d);font-weight:600;font-size:17px;color:rgba(244,237,224,.92);
  padding-bottom:3px;background-image:linear-gradient(var(--accent),var(--accent));
  background-size:0% 1.5px;background-position:0 100%;background-repeat:no-repeat;
  transition:background-size .26s var(--ease),color .2s var(--ease)}
.kb-entry-hint{font-family:var(--f-i);font-style:italic;font-size:12px;color:rgba(244,237,224,.5)}
.kb-entry:hover .kb-entry-label,.kb-entry:focus-visible .kb-entry-label{background-size:100% 1.5px;color:#fff}
.kb-entry:focus-visible{outline:none}
.kb-entry:focus-visible .kb-entry-label{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
.kb-entries--empty{border-top:none;margin-top:16px;padding-top:0}

/* lege staat: rustige regel + bruikbare entreepunten */
.kb-wall-empty{padding:clamp(28px,4vw,48px)}
.kb-empty-line{font-family:var(--f-i);font-style:italic;font-size:clamp(16px,2vw,19px);
  color:rgba(244,237,224,.7);margin:0 0 18px;max-width:46ch}

/* korte oriëntatie-puls op de kop van de aangeklikte plaat */
.rec-head--ping{animation:kbPing 1.4s var(--ease)}
@keyframes kbPing{0%,100%{box-shadow:none}25%{box-shadow:-12px 0 0 0 var(--accent)}}
/* korte oplicht-puls op de akoestiek-groepskop (oriëntatie na "Akoestisch") */
.demo-group-label--ping{animation:kbPing 1.6s var(--ease)}

@keyframes kbSleeveIn{to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion:reduce){
  .kb-sleeve{opacity:1;transform:none;animation:none}
  .kb-art,.kb-entry-label{transition:none}
  .rec-head--ping,.demo-group-label--ping{animation:none}
}

/* een plaat (record) op de plank */
.record{margin-top:clamp(32px,5vw,56px)}
.record-head{display:flex;align-items:baseline;justify-content:space-between;gap:18px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:8px}
.record-head h3{font-family:var(--f-d);font-weight:600;font-size:clamp(22px,3.2vw,30px);color:var(--fg)}
.record-head .meta{font-family:var(--f-m);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mono-c)}
.side-label{display:flex;align-items:center;gap:12px;margin:22px 0 6px;
  font-family:var(--f-m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.side-label::after{content:'';flex:1;height:1px;background:var(--line)}

/* track-rij */
.vs-track{display:grid;grid-template-columns:38px auto 1fr auto;gap:14px;align-items:center;
  padding:13px 6px;border-top:1px solid var(--line);background:none;width:100%;text-align:left;
  border-left:0;border-right:0;border-bottom:0;cursor:pointer;font-family:inherit;color:var(--fg)}
.vs-track:hover{background:var(--surface)}
.vs-track:first-of-type{border-top:none}
.vs-play{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.vs-track:hover .vs-play,.vs-track[aria-pressed=true] .vs-play{border-color:var(--accent)}
.vs-play .tri{--t:6px;--h:10px}
.vs-num{font-family:var(--f-m);font-size:12px;color:var(--mono-c);min-width:1.4em}
.vs-info{min-width:0}
.vs-title{font-family:var(--f-d);font-weight:500;font-size:16px;color:var(--fg);line-height:1.2}
.vs-sub{font-family:var(--f-i);font-style:italic;font-size:13px;color:var(--fg-soft)}
.vs-dur{font-family:var(--f-m);font-size:12px;color:var(--mono-c);justify-self:end}
.vs-track[aria-pressed=true] .vs-title{color:var(--accent)}

/* lyrics — prominent, op perkament-baan, per track uitklapbaar */
.lyrics-block{margin-top:18px}
.lyrics{border-top:1px solid var(--line);padding:18px 0}
.lyrics summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:12px;
  font-family:var(--f-d);font-weight:500;font-size:17px;color:var(--fg)}
.lyrics summary::-webkit-details-marker{display:none}
.lyrics summary .cap{font-family:var(--f-m);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mono-c);margin-left:auto}
.lyrics .text{margin-top:14px;font-family:var(--f-d);font-size:17px;line-height:1.85;color:var(--fg);white-space:pre-line}
.lyrics .none{font-family:var(--f-i);font-style:italic;color:var(--fg-soft);font-size:15px;margin-top:12px}

/* sticky mini-speler (player-bar) — voortgang als vullende routelijn */
.mini-player{position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:var(--surface);border-top:1px solid var(--edge);
  padding:12px clamp(16px,4vw,32px);display:flex;align-items:center;gap:16px;
  box-shadow:0 -8px 28px rgba(0,0,0,.3)}
.mini-player .pp{width:42px;height:42px;border-radius:50%;border:1px solid var(--edge);background:none;
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto}
.mini-player .pp:hover{border-color:var(--accent)}
.mini-player .pp .tri{--t:7px;--h:11px}
.mini-player .mp-info{min-width:0;flex:1}
.mini-player .mp-title{font-family:var(--f-d);font-weight:500;font-size:14px;color:var(--fg);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-player .mp-prog{margin-top:7px;height:2px;background:var(--edge);border-radius:2px;position:relative;overflow:hidden}
.mini-player .mp-prog i{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent)}
.mini-player .mp-time{font-family:var(--f-m);font-size:11px;color:var(--mono-c);flex:0 0 auto}
.mini-player .mp-close{background:none;border:none;color:var(--fg-mute);font-size:20px;cursor:pointer;flex:0 0 auto;line-height:1}
.mini-player .mp-close:hover{color:var(--accent)}


/* ════════════════════════════════════════════════════════
   APPS — boarding-pass-kaart met inline embed
════════════════════════════════════════════════════════ */
.apps-hero{min-height:60svh;display:flex;align-items:center}
.apps-hero .wrap{display:flex;flex-direction:column;gap:16px}
.apps-hero h1{font-family:var(--f-d);font-weight:600;font-size:clamp(40px,7vw,72px);line-height:1.0;color:var(--fg)}

/* easter egg: de vlieg op de muur (apps-hero, nacht) */
.fly-stage{position:relative;min-height:120px;margin-top:6px;overflow:hidden}
.fly-egg{position:absolute;top:0;left:0;color:var(--fg-soft);display:block;cursor:pointer;outline:none;
  transition:transform .5s cubic-bezier(.3,1.4,.4,1);will-change:transform}
.fly-egg svg{display:block}
.fly-egg:focus-visible{filter:drop-shadow(0 0 0 2px var(--accent))}
.fly-egg .wl,.fly-egg .wr{transform-box:fill-box;animation:flyFlap 1.6s ease-in-out infinite alternate}
.fly-egg .wl{transform-origin:85% 50%}
.fly-egg .wr{transform-origin:15% 50%;animation-name:flyFlapR}
@keyframes flyFlap{to{transform:rotate(-14deg) scaleY(.6)}}
@keyframes flyFlapR{to{transform:rotate(14deg) scaleY(.6)}}
.fly-egg.buzz{transition-duration:.14s}
.fly-egg.buzz .wl,.fly-egg.buzz .wr{animation-duration:.1s}
.fly-egg.caught{color:var(--accent);cursor:pointer}
.fly-egg.caught .wl,.fly-egg.caught .wr{animation-duration:.4s}
.fly-hint{position:absolute;bottom:6px;left:0;right:0;text-align:center;
  font-family:var(--f-i);font-style:italic;font-size:12.5px;color:var(--fg-mute);pointer-events:none}
.fly-hint.caught{color:var(--accent);font-style:normal;font-family:var(--f-m);
  font-size:11px;letter-spacing:.1em;text-transform:lowercase}
@media (prefers-reduced-motion:reduce){
  .fly-egg{transition:none}
  .fly-egg .wl,.fly-egg .wr{animation:none}
}

.app-list{display:flex;flex-direction:column;gap:clamp(22px,3.4vw,36px)}
.app-pass{display:grid;grid-template-columns:1.15fr 1fr;background:var(--surface);
  border:1px solid var(--line);border-radius:16px;overflow:hidden}
.app-embed{position:relative;background:var(--bg);min-height:300px;display:flex;align-items:center;justify-content:center}
.app-embed iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
.app-embed .embed-fallback{font-family:var(--f-i);font-style:italic;color:var(--fg-soft);font-size:15px;
  text-align:center;padding:30px;line-height:1.6}
/* ontworpen merk-paneel (geen live demo) — sterrenhemel + open-einde-route,
   in hetzelfde idioom als de reizen/nachtlucht-kaart. Vult de halve breedte. */
.app-visual{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;
  background-color:#16140F;
  background-image:radial-gradient(1.5px 1.5px at 16% 24%,rgba(214,222,231,.5),transparent),
    radial-gradient(1px 1px at 38% 64%,rgba(214,222,231,.32),transparent),
    radial-gradient(1px 1px at 64% 22%,rgba(214,222,231,.3),transparent),
    radial-gradient(1.5px 1.5px at 82% 56%,rgba(214,222,231,.4),transparent),
    radial-gradient(1px 1px at 90% 32%,rgba(214,222,231,.34),transparent)}
.app-visual-sky{position:relative;flex:1;display:flex;align-items:center;justify-content:center;padding:24px}
.app-route{width:min(86%,300px);height:auto;overflow:visible}
.app-route-ghost{fill:none;stroke:#39414a;stroke-width:1.5;stroke-dasharray:2 7;stroke-linecap:round}
.app-route-line{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:520;stroke-dashoffset:520}
@media (prefers-reduced-motion:no-preference){
  .app-route-line{animation:appDraw 2.4s ease-out .3s forwards}
}
@media (prefers-reduced-motion:reduce){
  .app-route-line{stroke-dashoffset:0}
}
@keyframes appDraw{to{stroke-dashoffset:0}}
.app-stop{fill:#16140F;stroke:var(--accent);stroke-width:2}
.app-stop.open{fill:#16140F;stroke:#9DB6C6;stroke-width:1.6}
.app-stop.end{fill:var(--accent);stroke:none}
.app-visual-tag{position:absolute;left:24px;bottom:18px;display:flex;flex-direction:column;gap:3px}
.app-visual-stamp{font-family:var(--f-d);font-weight:700;font-size:22px;letter-spacing:-.01em;color:#FBF9F1}
.app-visual-sub{font-family:var(--f-m);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ember,#D6603C)}
.app-visual-note{font-family:var(--f-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:#6f7886;padding:0 24px 18px;text-align:right}
.app-side{padding:clamp(24px,3.4vw,40px);display:flex;flex-direction:column;gap:14px;
  border-left:1px dashed var(--edge);position:relative}
/* perforatie-stippen op de naad */
.app-side::before{content:'';position:absolute;left:-7px;top:-7px;width:14px;height:14px;border-radius:50%;background:var(--bg)}
.app-side::after{content:'';position:absolute;left:-7px;bottom:-7px;width:14px;height:14px;border-radius:50%;background:var(--bg)}
.app-name{font-family:var(--f-d);font-weight:600;font-size:clamp(26px,4vw,38px);line-height:1.0;color:var(--fg)}
.app-ver{font-family:var(--f-m);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mono-c)}
.app-pitch{color:var(--fg-soft);font-size:15.5px;line-height:1.6}
.app-status{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-m);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--mono-c);align-self:flex-start;
  border:1px solid var(--line);border-radius:100px;padding:5px 12px}
.app-status.live{color:var(--accent);border-color:var(--accent)}
.app-status .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.app-cta-row{margin-top:auto;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
/* toekomstig werk — kleiner, "in de maak"-stempel */
.app-future{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.app-stub{background:var(--surface);border:1px dashed var(--line);border-radius:14px;padding:24px;position:relative}
.app-stub .stamp{position:absolute;top:14px;right:14px;font-family:var(--f-m);font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:6px;padding:3px 8px;transform:rotate(4deg)}
.app-stub h3{font-family:var(--f-d);font-weight:600;font-size:20px;color:var(--fg)}
.app-stub p{margin-top:8px;color:var(--fg-soft);font-size:14px;line-height:1.55}
@media (max-width:760px){
  .app-pass{grid-template-columns:1fr}
  .app-side{border-left:0;border-top:1px dashed var(--edge)}
  .app-side::before{left:-7px;top:-7px}
  .app-side::after{right:-7px;left:auto;top:-7px;bottom:auto}
  .app-embed{min-height:260px}
  .app-embed iframe{min-height:260px}
}


/* ════════════════════════════════════════════════════════
   ABOUT — bio · discipline-chips · contact-postkaart (warm + nacht-paneel)
════════════════════════════════════════════════════════ */
.about-hero{min-height:64svh;display:flex;align-items:center}
.about-hero .wrap{display:flex;flex-direction:column;gap:18px}
.about-hero .bseal{--d:96px;margin-bottom:6px}
.about-hero h1{font-family:var(--f-d);font-weight:600;font-size:clamp(34px,6vw,58px);line-height:1.04;color:var(--fg);max-width:18ch}
.about-bio{font-size:16.5px;line-height:1.75;color:var(--fg);max-width:62ch}
.about-bio em{font-style:italic;font-family:var(--f-i)}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.chip{font-family:var(--f-b);font-size:13px;font-weight:500;color:var(--fg);text-decoration:none;
  border:1px solid var(--line);border-radius:100px;padding:8px 16px;transition:border-color .2s,color .2s}
.chip:hover{border-color:var(--accent);color:var(--accent)}

/* contact-postkaart: twee panelen */
.postcard{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 14px 40px rgba(34,30,24,.12)}
.pc-front{background:var(--surface);padding:clamp(26px,3.4vw,40px);display:flex;flex-direction:column;gap:16px}
.pc-letter{font-family:var(--f-i);font-style:italic;font-size:16px;line-height:1.7;color:var(--fg)}
.pc-rows{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.pc-row{display:flex;align-items:center;gap:12px;font-family:var(--f-m);font-size:13px;color:var(--fg);text-decoration:none}
.pc-row .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.pc-row:hover{color:var(--accent)}
.pc-back{background:var(--char);color:var(--on-night);padding:clamp(26px,3.4vw,40px);position:relative;
  display:flex;flex-direction:column;justify-content:space-between;gap:24px;min-height:240px}
.pc-back .pc-stars{position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(1.4px 1.4px at 16% 24%,var(--warm-star),transparent),
    radial-gradient(1px 1px at 70% 40%,var(--warm-star),transparent),
    radial-gradient(1px 1px at 40% 76%,var(--warm-star),transparent),
    radial-gradient(1.2px 1.2px at 86% 70%,var(--warm-star),transparent)}
.pc-back .pc-coord{position:relative;font-family:var(--f-m);font-size:12px;letter-spacing:.08em;color:var(--on-night-mute)}
.pc-back .pc-sig{position:relative;font-family:var(--f-i);font-style:italic;font-size:18px;color:var(--on-night-hi)}
.pc-back .pc-stamp{position:relative;align-self:flex-end}
@media (max-width:680px){
  .postcard{grid-template-columns:1fr}
  .pc-back{min-height:180px}
}


/* ════════════════════════════════════════════════════════
   TRIP — per-reis hero (eigen kaartstijl) · route-tijdlijn · verhalen
   RONDE 3 — herontwerp: een reis als ATLAS-DOCUMENT. De kaart zit als een
   ingelijst kaartblad (perkament, hoeklabels, coördinaat-kantlijn) náást het
   titelblok i.p.v. los gecentreerd; de tijdlijn en verhaal-kaartjes delen
   dezelfde paper/atlas-DNA. Mobiel: alles stapelt; reduced-motion gerespecteerd.
════════════════════════════════════════════════════════ */
.trip-hero-band{min-height:auto;padding-block:clamp(40px,7vw,84px);display:block}
/* twee kolommen: tekstblok links, kaartblad rechts — stapelt op smal */
.trip-hero-band .wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  gap:clamp(24px,4vw,56px);align-items:center}
.trip-hero-copy{display:flex;flex-direction:column;gap:14px;min-width:0}
.trip-eyebrow{font-family:var(--f-m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--t-accent,var(--accent));display:inline-flex;align-items:center;gap:9px}
.trip-eyebrow::before{content:'';width:24px;height:1px;background:currentColor;opacity:.6}
.trip-hero-band h1{font-family:var(--f-d);font-weight:600;font-size:clamp(38px,6.4vw,70px);line-height:1.02;color:var(--fg);margin:0}
.trip-hero-band .lede{margin:0;max-width:46ch}
/* het kaartblad: perkament-frame met hoeklabels + coördinaat-kantlijn */
.trip-map-frame{position:relative;margin:0;padding:clamp(14px,2vw,22px);
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  box-shadow:0 1px 0 color-mix(in srgb,var(--fg) 6%,transparent),0 22px 50px -28px rgba(0,0,0,.5)}
.trip-map-frame::before{content:'';position:absolute;inset:7px;border:1px solid var(--line);
  border-radius:9px;opacity:.5;pointer-events:none}
/* hoek-ticks (kaart-merktekens) */
.trip-map-frame::after{content:'';position:absolute;left:14px;top:14px;width:13px;height:13px;
  border-left:1.5px solid var(--t-accent,var(--accent));border-top:1.5px solid var(--t-accent,var(--accent));
  opacity:.7;pointer-events:none}
.trip-map{width:100%;aspect-ratio:1/1;height:auto;max-width:520px;margin:0 auto;position:relative;z-index:1}
.trip-meta{display:flex;gap:18px 24px;flex-wrap:wrap;font-family:var(--f-m);font-size:11.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--mono-c);padding-top:6px;margin-top:2px;border-top:1px solid var(--line)}
.trip-meta .mono{color:var(--fg)}
.trip-meta b{color:var(--fg);font-weight:500}
@media (max-width:760px){
  .trip-hero-band .wrap{grid-template-columns:1fr;gap:clamp(22px,5vw,34px)}
  .trip-map-frame{order:2}
  .trip-map{max-width:min(86vw,460px)}
}

/* route-tijdlijn — een scroll-onthuld reisverhaal i.p.v. een kale lijst:
   genummerde haltes die in beeld rollen, een lijn die met je meeloopt, en
   "hier nu" als pulserend eindpunt. (markup uit page-trip.js) */
.route-list{position:relative;padding-left:clamp(34px,5vw,52px);margin-top:18px}
/* de rustende, gestippelde route-as */
.route-list::before{content:'';position:absolute;left:12px;top:14px;bottom:24px;width:2px;
  background:repeating-linear-gradient(var(--line) 0 5px,transparent 5px 11px)}
/* de groeiende, getrokken lijn (vult zich op scroll) */
.route-fill{position:absolute;left:12px;top:14px;width:2px;height:0;border-radius:2px;
  background:var(--t-accent,var(--accent));
  box-shadow:0 0 10px color-mix(in srgb,var(--t-accent,var(--accent)) 50%,transparent);
  transition:height .15s linear;will-change:height}
.route-stop{position:relative;padding:clamp(14px,2.4vw,22px) 0;display:block}
.route-stop .route-pt{position:absolute;left:calc(-1 * clamp(34px,5vw,52px) + 5px);top:clamp(22px,3vw,30px);
  width:14px;height:14px;border-radius:50%;background:var(--bg);
  border:2.5px solid var(--t-accent,var(--accent));box-shadow:0 0 0 4px var(--bg);z-index:1}
.route-stop--last .route-pt{background:var(--t-accent,var(--accent))}
@media (prefers-reduced-motion:no-preference){
  .route-stop--last .route-pt[data-here]{animation:livePulse 2.4s ease-in-out infinite}
}
.route-main{min-width:0}
.route-leg{display:block;font-family:var(--f-m);font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mono-c);margin-bottom:5px}
.route-name{font-family:var(--f-d);font-weight:600;font-size:clamp(19px,2.6vw,24px);color:var(--fg);line-height:1.1}
.route-land{font-family:var(--f-m);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--mono-c);margin-left:8px}
.route-coord{font-family:var(--f-m);font-size:10.5px;letter-spacing:.08em;color:var(--mono-c);margin-top:6px}
.route-go{margin-top:12px}
.route-read{display:inline-flex;align-items:center;gap:7px;background:none;
  border:1px solid color-mix(in srgb,var(--t-accent,var(--accent)) 45%,var(--line));
  border-radius:999px;padding:7px 15px;font-family:var(--f-m);font-size:11.5px;letter-spacing:.05em;
  color:var(--t-accent,var(--accent));font-weight:600;cursor:pointer;
  transition:background .22s var(--ease),color .22s var(--ease),border-color .22s var(--ease)}
.route-read:hover,.route-read:focus-visible{background:var(--t-accent,var(--accent));
  color:var(--bg);border-color:var(--t-accent,var(--accent));outline:none}

/* verhalen-kaartjes van deze reis — venster-glimp + plek/titel/quote in de
   atlas-DNA (zelfde taal als de aanbevolen-kaarten op Home). */
.story-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:clamp(16px,2.2vw,24px)}
.tstory{cursor:pointer;text-align:left;border:1px solid var(--line);background:var(--surface);
  border-radius:14px;padding:0;color:var(--fg);font-family:inherit;overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.tstory:hover,.tstory:focus-visible{transform:translateY(-4px);
  box-shadow:0 18px 40px -22px rgba(0,0,0,.5);border-color:color-mix(in srgb,var(--t-accent,var(--accent)) 40%,var(--line));outline:none}
.tstory-win{position:relative;display:block;width:100%;aspect-ratio:16/10;overflow:hidden;background:var(--surface-2)}
.tstory-win img{width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.92);transition:transform .5s var(--ease),filter .35s var(--ease)}
.tstory:hover .tstory-win img{transform:scale(1.045);filter:saturate(1)}
/* geen foto → rustig merk-zegel op perkament i.p.v. gebroken beeld */
.tstory-win--seal{display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 120% at 30% 20%,var(--surface-2),var(--surface))}
.tstory-seal{font-family:var(--f-d);font-weight:600;font-size:34px;color:var(--t-accent,var(--accent));opacity:.5}
.tstory-text{display:flex;flex-direction:column;gap:6px;padding:clamp(15px,1.8vw,19px)}
.tstory-where{font-family:var(--f-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mono-c)}
.tstory-title{font-family:var(--f-d);font-weight:600;font-size:clamp(17px,2vw,20px);line-height:1.15;color:var(--fg)}
.tstory-quote{font-family:var(--f-i);font-style:italic;font-size:14px;line-height:1.45;color:var(--fg-soft);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tstory-go{margin-top:4px;font-family:var(--f-m);font-size:11.5px;letter-spacing:.05em;
  color:var(--t-accent,var(--accent));font-weight:600}
.jr-empty{font-family:var(--f-i);font-style:italic;color:var(--fg-soft);font-size:16px;line-height:1.6;
  border:1px dashed var(--line);border-radius:12px;padding:26px 24px;text-align:center;max-width:52ch;margin:0 auto}


/* ════════════════════════════════════════════════════════
   IN-PLACE READER-OVERLAY  (BB.Reader gebruikt #reader / .r-*)
   Warme leeservaring; nacht-pagina's openen 'm ook warm (rust voor het oog).
════════════════════════════════════════════════════════ */
.reader-overlay{position:fixed;inset:0;z-index:120;background:rgba(15,17,22,.55);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s}
.reader-overlay.open{opacity:1;visibility:visible}
.reader-overlay[hidden]{display:none}
.r-scroll{position:absolute;right:0;top:0;bottom:0;width:min(680px,94vw);overflow-y:auto;
  background:var(--paper-warm);color:var(--reader);
  --bg:var(--paper-warm);--fg:var(--reader);--fg-soft:var(--umber);--fg-mute:var(--ink3);
  --surface:var(--paper-50);--accent:var(--outback);--line:var(--taupe);--mono-c:var(--drab);
  transform:translateX(40px);transition:transform .35s var(--ease);
  padding:clamp(30px,5vw,64px) clamp(22px,5vw,56px) 80px}
.reader-overlay.open .r-scroll{transform:none}
/* RONDE 4 — reader-gereedschap rechtsboven: NL/EN-taaltoggle + sluitknop.
   De toggle laat je al lezend van taal wisselen (core.js her-rendert het verhaal). */
.r-tools{position:absolute;top:14px;right:16px;z-index:3;display:flex;align-items:center;gap:10px}
.r-lang{display:inline-flex;align-items:stretch;padding:2px;border:1px solid var(--taupe);border-radius:100px;
  background:var(--paper-50);overflow:hidden;min-height:40px;-webkit-tap-highlight-color:transparent;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:border-color .18s var(--ease)}
.r-lang-btn{appearance:none;-webkit-appearance:none;border:none;background:none;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;min-width:38px;border-radius:100px;
  font-family:var(--f-m);font-weight:600;font-size:11px;letter-spacing:.1em;line-height:1;color:var(--drab);
  padding:0 13px;transition:background .18s var(--ease),color .18s var(--ease)}
.r-lang:hover{border-color:var(--outback)}
.r-lang-btn:hover{color:var(--reader)}
.r-lang-btn[aria-pressed="true"]{background:var(--outback);color:#fff}
.r-lang-btn[aria-pressed="true"]:hover{color:#fff}
.r-lang-btn:focus-visible{outline:2px solid var(--outback);outline-offset:2px}
.r-close{position:static;width:42px;height:42px;border-radius:50%;border:1px solid var(--taupe);
  background:var(--paper-50);color:var(--reader);font-size:22px;line-height:1;cursor:pointer;flex:0 0 auto}
.r-close:hover{border-color:var(--outback);color:var(--outback)}
.r-article{max-width:36rem;margin:0 auto}
.r-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-m);font-size:10.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--outback)}
.r-eyebrow-seal{width:8px;height:8px;border-radius:50%;background:var(--outback)}
.r-titel{font-family:var(--f-d);font-weight:600;font-size:clamp(28px,5vw,44px);line-height:1.06;
  color:var(--ink);margin:14px 0 0;letter-spacing:-.01em}
.r-byline{font-family:var(--f-m);font-size:11.5px;letter-spacing:.06em;color:var(--drab);margin-top:14px}
.r-byline .r-dot{margin:0 8px}
.r-lead{font-family:var(--f-i);font-style:italic;font-size:clamp(17px,2.4vw,20px);line-height:1.55;
  color:var(--umber);margin-top:18px}
.r-cover-fig{margin:24px 0}
/* RONDE D-beeld — reserveer de cover-hoogte vóór het laden zodat de tekst
   eronder niet verspringt als de lazy-image binnenkomt (CLS=0). Het FRAME
   (.r-cover-frame) draagt de vaste 4/3-verhouding; het beeld vult dat kader
   met object-fit:cover. 4/3 ligt rustig liggend voor een staande bron en
   voorkomt een te hoog beeldgat. */
.r-cover-fig img{width:100%;border-radius:10px}
.r-cover-window .r-cover-frame{aspect-ratio:4/3;background:var(--wash,#EAD6CB)}
.r-cover-window .r-cover-frame img{width:100%;height:100%;object-fit:cover}
.r-cover-fig figcaption{font-family:var(--f-m);font-size:10.5px;color:var(--drab);margin-top:8px;letter-spacing:.04em}
/* innovatie #2 — cover als ademend venster: perkament-marge + overflow-clip zodat
   de minimale Ken-Burns binnen het venster blijft (core.js zet de transform). */
.r-cover-window .r-cover-frame{display:block;overflow:hidden;border-radius:10px;
  padding:0;background:var(--wash, #EAD6CB)}
.r-cover-window img{will-change:transform;transform:scale(1.02);
  transition:transform .15s linear;border-radius:10px}
@media (prefers-reduced-motion:reduce){
  .r-cover-window img{transform:none;transition:none}
}
/* RONDE 4 — quote-kaart als beeld-fallback: bij ontbrekend/kapot beeld toont de
   reader GEEN gebroken icoon, maar deze rustige quote-kaart (key_quote). In stijl:
   perkament-venster, roest-leesteken, dezelfde marge als de cover. */
.quote-fallback{margin:24px 0;background:var(--paper-50);border:1px solid var(--taupe);
  border-left:3px solid var(--outback);border-radius:12px;padding:clamp(20px,3.4vw,30px)}
.quote-fallback-q{position:relative;margin:0;font-family:var(--f-i);font-style:italic;
  font-size:clamp(19px,2.8vw,24px);line-height:1.4;color:var(--umber);padding-left:30px}
.quote-fallback-mark{position:absolute;left:-2px;top:-8px;font-family:var(--f-d);font-style:normal;
  font-size:2.6em;line-height:1;color:var(--outback);opacity:.5}
.quote-fallback-cap{font-family:var(--f-m);font-size:10.5px;letter-spacing:.04em;color:var(--drab);
  margin-top:14px;text-transform:uppercase}
.r-body{margin-top:22px}
.r-body p{font-family:var(--f-d);font-size:18px;line-height:1.85;color:var(--reader);margin-bottom:1.1em}
/* CANONIEKE reader-drop-cap: Newsreader cursief (var(--f-i)) in roest — het meest
   merk-eigen letterbeeld (vgl. de 'b'-zegel). v3-globe.css:598-600 zet hier nog
   var(--f-d) (Spectral) → ander letterbeeld op the-journey/story; PM moet die
   gelijktrekken naar var(--f-i). Zie review/ronde-C-beeld.md. */
.r-body p:first-of-type::first-letter{font-family:var(--f-i);font-style:italic;float:left;
  font-size:3.6em;line-height:.78;padding:6px 10px 0 0;color:var(--outback)}
.r-coord{font-family:var(--f-m);font-size:12px;letter-spacing:.06em;color:var(--drab);
  border-top:1px solid var(--taupe);border-bottom:1px solid var(--taupe);padding:12px 0;margin:24px 0}
.r-coord b{color:var(--outback)}
.r-note{font-family:var(--f-i);font-style:italic;color:var(--umber);font-size:14.5px;
  background:var(--paper-50);border-left:2px solid var(--outback);padding:12px 16px;margin-bottom:20px}
.r-endmark{text-align:center;margin:34px 0 0}
.r-endmark span{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;
  background:var(--outback);color:#fff;font-family:var(--f-i);font-style:italic;font-size:22px}
.r-audio-mount{margin:22px 0}

/* reader-voet "volgende halte" — merk-KNOP/kaart (boven én onder het artikel).
   FIX 1 — duidelijk gescheiden label/titel/waar + pijl-affordance; ≥44px tap-target. */
.r-foot{margin:30px 0 8px}
.r-foot--top{margin:18px 0 26px}
.r-foot:empty,.r-foot--top:empty{margin:0}
.r-next{display:flex;align-items:center;gap:16px;text-decoration:none;
  border:1px solid var(--taupe);border-radius:14px;padding:16px 18px;min-height:44px;
  background:var(--paper-50);transition:border-color .2s,transform .2s,box-shadow .2s}
.r-next:hover{border-color:var(--outback);transform:translateY(-2px);box-shadow:0 12px 28px rgba(34,30,24,.12)}
.r-next:focus-visible{outline:2px solid var(--outback);outline-offset:3px}
.r-next-text{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1 1 auto}
.r-next-lab{font-family:var(--f-m);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--outback)}
.r-next-title{font-family:var(--f-d, var(--f-b));font-weight:600;font-size:18px;line-height:1.2;color:var(--ink)}
.r-next-where{font-family:var(--f-m);font-size:11px;letter-spacing:.06em;color:var(--drab)}
.r-next-arrow{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;border:1px solid var(--taupe);color:var(--outback);
  font-size:17px;line-height:1;transition:background .2s,border-color .2s,transform .2s}
.r-next:hover .r-next-arrow{background:var(--outback);border-color:var(--outback);color:#fff;transform:translateX(2px)}
.r-next--compact{padding:12px 14px;border-radius:12px}
.r-next--compact .r-next-title{font-size:15px}
.r-next--compact .r-next-arrow{width:30px;height:30px;font-size:15px}
@media (prefers-reduced-motion:reduce){
  .r-next,.r-next-arrow{transition:none}
  .r-next:hover,.r-next:hover .r-next-arrow{transform:none}
}

/* "luister tijdens lezen"-knop in de reader → voedt de site-brede speler */
.r-listen{display:inline-flex;align-items:center;gap:12px;cursor:pointer;
  font-family:var(--f-b);font-weight:600;font-size:13.5px;color:var(--reader);
  background:var(--paper-50);border:1px solid var(--taupe);border-radius:100px;padding:9px 18px 9px 9px;
  transition:border-color .2s,color .2s,background .2s}
.r-listen:hover{border-color:var(--outback);color:var(--outback)}
.r-listen[aria-pressed="true"]{border-color:var(--outback);background:var(--wash)}
.r-listen-ic{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;
  background:var(--outback);flex:0 0 auto}
.r-listen-ic .tri--play{--t:6px;--h:11px;border-left-color:#fff}

/* key-quote — rustige pull-quote die meeloopt met de taaltoggle (stories.key_quote) */
.r-quote{position:relative;font-family:var(--f-i);font-style:italic;font-size:clamp(20px,3vw,26px);
  line-height:1.4;color:var(--ink);margin:30px 0;padding:6px 0 6px 22px;border-left:2px solid var(--outback)}
.r-quote-mark{position:absolute;left:8px;top:-8px;font-size:46px;line-height:1;color:var(--outback);opacity:.32}

/* warmste verhalen op Home (innovatie #10) — één rustig roterend perkament-kaartje */
.warm-card{transition:opacity .4s var(--ease, ease);margin-top:6px}
.warm-link{display:inline-flex;flex-direction:column;gap:4px;text-decoration:none;
  border-left:3px solid var(--outback, #B4462B);padding:10px 0 10px 16px;max-width:60ch}
.warm-title{font-family:var(--f-d, var(--f-b));font-weight:600;font-size:clamp(18px,2.4vw,22px);
  color:var(--fg)}
.warm-where{font-family:var(--f-m);font-size:11px;letter-spacing:.06em;color:var(--fg-soft)}
.warm-go{font-family:var(--f-m);font-size:11.5px;letter-spacing:.04em;color:var(--outback, #B4462B);margin-top:4px}
.warm-link:hover .warm-title{color:var(--outback, #B4462B)}
@media (prefers-reduced-motion:reduce){ .warm-card{transition:none} }

/* ── aanbevolen verhalen op Home (gewogen op AI-kwaliteit) — "poststempel-kaartjes"
   met een venster-glimp links (innovatie #1: een fragment, geen hele scène). ── */
.rec-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:clamp(14px,2vw,20px)}
.rec-card{display:flex;gap:16px;align-items:flex-start;text-decoration:none;
  background:var(--surface, #fff);border:1px solid var(--taupe, #d9ccc0);border-radius:14px;
  padding:14px 16px 14px 14px;transition:transform .25s var(--ease, ease),box-shadow .25s var(--ease, ease)}
.rec-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(34,30,24,.13)}
/* het venster: een klein, rond uitsnede-detail door een perkament-vignet */
.rec-window{flex:0 0 auto;width:76px;height:76px;border-radius:50%;background-size:cover;
  background-position:center;position:relative;overflow:hidden;
  box-shadow:inset 0 0 0 3px var(--paper, #f4ece2),0 1px 4px rgba(34,30,24,.18)}
.rec-window::after{content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:inset 0 0 18px rgba(60,40,28,.28);pointer-events:none}
.rec-window--seal{background:repeating-linear-gradient(135deg,var(--stone,#e7dccf) 0 10px,var(--surface-2,#efe6da) 10px 20px);
  display:flex;align-items:center;justify-content:center}
.rec-seal-b{font-family:var(--f-i);font-style:italic;color:var(--outback,#B4462B);font-size:30px;opacity:.5}
.rec-card-text{display:flex;flex-direction:column;gap:5px;min-width:0}
.rec-card-where{font-family:var(--f-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent,#B4462B)}
.rec-card-title{font-family:var(--f-d, var(--f-b));font-weight:600;font-size:clamp(17px,2.1vw,20px);
  line-height:1.22;color:var(--fg)}
.rec-card-quote{font-family:var(--f-i);font-style:italic;font-size:14px;line-height:1.4;color:var(--umber,#6b5a4a);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rec-card-go{font-family:var(--f-m);font-size:11px;letter-spacing:.04em;color:var(--accent,#B4462B);margin-top:2px}
.rec-card:hover .rec-card-title{color:var(--outback,#B4462B)}

@media (prefers-reduced-motion:reduce){
  .rec-card{transition:none}
}

/* demo-archief op Music — ingetogen lijst, nacht-warm */
.demos-note{color:var(--fg-soft);font-size:15px;max-width:54ch;margin:0 0 18px}
.demo-list{display:flex;flex-direction:column;gap:2px}
.demo-item{display:flex;align-items:center;gap:14px;width:100%;text-align:left;cursor:pointer;
  background:none;border:0;border-bottom:1px solid var(--char-line, #241f19);padding:13px 6px;
  color:var(--fg);font-family:inherit;transition:background .2s}
.demo-item:hover{background:var(--char-1, #1B1813)}
.demo-item[aria-pressed="true"] .demo-title{color:var(--ember)}
.demo-play{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;
  border:1px solid var(--char-edge, #3a342a);flex:0 0 auto}
.demo-play .tri--play{--t:6px;--h:11px;border-left-color:var(--ember)}
.demo-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.demo-title{font-family:var(--f-d);font-weight:500;font-size:15.5px;color:var(--on-night, #ECE6D5);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.demo-sub{font-family:var(--f-m);font-size:10.5px;letter-spacing:.06em;color:var(--char-num, #5f5746)}
.demo-dur{font-family:var(--f-m);font-size:11.5px;color:var(--char-num, #5f5746);flex:0 0 auto}

/* gesproken Bending Points — luisterrij + link naar het essay */
.spoken-item{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  border-bottom:1px solid var(--char-line, #241f19)}
.spoken-item .demo-item{flex:1 1 260px;border-bottom:0}
.spoken-read{flex:0 0 auto;font-family:var(--f-m);font-size:11.5px;letter-spacing:.04em;
  color:var(--char-num, #8a8068);padding:6px 4px 6px 0;text-decoration:none;white-space:nowrap}
.spoken-read:hover{color:var(--ember)}

/* ── Paronella Park-audiotour — genummerde haltes met een meelopende lijn,
   scroll-onthuld (zelfde halte-taal als "De route" op trip.html), nacht-warm. ── */
.tour-stops{list-style:none;margin:8px 0 0;padding:0;position:relative}
.tour-stops::before{content:"";position:absolute;left:18px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(var(--char-edge,#3a342a),transparent);opacity:.6}
.tour-stop{position:relative;display:flex;gap:16px;padding:14px 0 16px 0;
  border-bottom:1px solid var(--char-line,#241f19)}
.tour-no{flex:0 0 auto;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-m);font-size:13px;color:var(--ember);
  background:var(--char-1,#1B1813);border:1px solid var(--char-edge,#3a342a);position:relative;z-index:1}
.tour-main{flex:1;min-width:0}
.tour-head{display:flex;align-items:center;gap:13px}
.tour-play{background:none;border:0;padding:0;cursor:pointer;flex:0 0 auto}
.tour-play[disabled]{cursor:default;opacity:.5}
/* telefoon: ruimer aantik-doel rond de afspeel-glyph (≥44px) */
@media (max-width:560px){
  .tour-play{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;margin:-5px 0}
}
.tour-play[aria-pressed="true"] .tour-title{color:var(--ember)}
.tour-titles{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.tour-title{font-family:var(--f-d);font-weight:500;font-size:16px;color:var(--on-night,#ECE6D5);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tour-plek{font-family:var(--f-m);font-size:10.5px;letter-spacing:.08em;color:var(--char-num,#8a8068)}
.tour-dur{font-family:var(--f-m);font-size:11.5px;color:var(--char-num,#5f5746);flex:0 0 auto}
/* "audio volgt"-staat per halte: rustige badge, halte iets gedempt, knop uit */
.tour-stop--soon{opacity:.74}
.tour-stop--soon .tour-play{cursor:default}
.tour-soon{font-family:var(--f-m);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--char-num,#8a8068);border:1px solid var(--char-edge,#3a342a);border-radius:999px;
  padding:3px 8px;white-space:nowrap}
.tour-transcript{margin:10px 0 0 51px}
.tour-transcript summary{font-family:var(--f-m);font-size:11px;letter-spacing:.08em;color:var(--char-num,#8a8068);
  cursor:pointer;list-style:none}
.tour-transcript summary::-webkit-details-marker{display:none}
.tour-transcript summary::before{content:"+ ";color:var(--ember)}
.tour-transcript[open] summary::before{content:"– "}
.tour-transcript .text{font-family:var(--f-d);font-size:14.5px;line-height:1.7;color:var(--on-night,#ECE6D5);
  opacity:.86;margin-top:8px;white-space:pre-wrap}

/* ── tour OP perkament (licht↔donker-ritme, D10) ──────────────────────────────
   De audiotour staat nu op een warme baan tussen de nacht-banden. Dezelfde
   halte-taal, maar met de licht-tokens zodat het een rustig leesblad wordt. */
#tour.band--paper .tour-stops::before{background:linear-gradient(var(--line),transparent)}
#tour.band--paper .tour-stop{border-bottom-color:var(--line)}
#tour.band--paper .tour-no{color:var(--accent);background:var(--surface);border-color:var(--line)}
#tour.band--paper .tour-title{color:var(--fg)}
#tour.band--paper .tour-play[aria-pressed="true"] .tour-title{color:var(--accent)}
#tour.band--paper .tour-plek{color:var(--mono-c)}
#tour.band--paper .tour-dur{color:var(--mono-c)}
#tour.band--paper .demo-play{border-color:var(--line)}
#tour.band--paper .demo-play .tri--play{border-left-color:var(--accent)}
#tour.band--paper .tour-soon{color:var(--mono-c);border-color:var(--line)}
#tour.band--paper .tour-transcript summary{color:var(--mono-c)}
#tour.band--paper .tour-transcript summary::before{color:var(--accent)}
#tour.band--paper .tour-transcript .text{color:var(--fg-soft);opacity:1}
#tour.band--paper .demos-note{color:var(--fg-soft)}
#tour.band--paper .sec-head h2{color:var(--fg)}

/* ── zachte papier-/toon-overgang (P3 A3): een haarscheiding tussen de banden op
   Music, zodat de wissels licht↔donker als één doorlopend vel voelen i.p.v.
   gestapelde dozen. Subtiel: 1px lijn in de bandkleur-rand. */
[data-page="music"] .band + .band{border-top:1px solid var(--edge)}

@media (prefers-reduced-motion:reduce){
  .reader-overlay,.r-scroll{transition:none}
  .r-scroll{transform:none}
}


/* ════════════════════════════════════════════════════════════════════════════
   HOME — A/B/n-VARIANTEN (live test van DRIE homepages in één pagina)
   ──────────────────────────────────────────────────────────────────────────
   ab-home.js zet html[data-home="a|b|c"] vóór eerste paint → géén flicker.
   Default (geen data-home / geen JS) = variant A zichtbaar, B & C verborgen.
   Atlas-uitnodiging + nieuwsbrief + footer zijn GEDEELD (buiten de wrappers) en
   blijven in alle varianten staan. Alleen de hero/pijlers/feed verschillen.
   Verbergen via display:none zodat verborgen varianten geen ruimte/route-haltes
   bezetten en niet in de tab-volgorde of voor screenreaders bestaan.

   ── CONTRAST-TOETS (WCAG AA: 4.5:1 body, 3:1 large/UI) ───────────────────────
   Beide nieuwe varianten erven dezelfde band-tonen (nacht #15171C, perkament
   #F4F0E4, zand #ECE6D5, nacht-warm #16140F) en semantische rollen als variant A,
   dus de bestaande, geverifieerde paren blijven gelden. Nieuwe paren:
     • B masthead-kop --on-night-hi #FBF9F1 op nacht #15171C        → 16.0:1 (AAA)
     • B cover-titel  #FBF9F1 op cover-overlay (#0d0f13 .55 → ≈#11131a) → ≈14:1 (AAA)
     • B cover-kicker --ember #D6603C op #11131a                    → 5.1:1 (AA, large/UI)
     • B rubriek-titel --umber #5B5345 op --surface(=paper #FBF9F1) → 7.5:1 (AAA)
     • C leaf-kop     #FBF9F1 op leaf-paneel (#1b1e25)              → ≈13:1 (AAA)
     • C pin-titel    --fg #221E18 op --surface #FBF9F1             → 13.6:1 (AAA)
     • C pin-body     --umber #5B5345 op #FBF9F1                    → 7.5:1 (AAA)
   De polaroid/wax/plaat-zegels zijn decoratief (aria-hidden); contrast n.v.t.
══════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════
   HOMEPAGE — "Het ene verhaal" (magazine-cover)
════════════════════════════════════════════════════════ */
.magb-hero{min-height:88svh;display:flex;align-items:center;
  background:radial-gradient(120% 90% at 50% -10%, rgba(63,94,118,.10), transparent 62%),var(--bg)}
.magb-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.magb-masthead{display:flex;flex-direction:column;gap:clamp(14px,2.4vw,22px);min-width:0}
.magb-masthead h1{font-family:var(--f-d);font-weight:600;line-height:1.0;letter-spacing:-.015em;
  font-size:clamp(40px,6.4vw,76px);color:var(--fg)}
.magb-masthead h1 em{font-style:italic;font-family:var(--f-i);font-weight:400;color:var(--fg)}
.magb-ident{font-family:var(--f-i);font-style:italic;font-size:clamp(16px,2.1vw,19px);
  line-height:1.55;color:var(--fg-soft);max-width:50ch}
.magb-hero .live-badge{align-self:flex-start}
/* QUICK-WIN #2 — de hero-CTA-rij: geef de secundaire "lees de essays"-link
   duidelijk lucht zodat hij niet tegen de "Begin de reis →"-knop plakt.
   Knop en link op één regel met ruime tussenruimte; de link krijgt extra
   left-marge zodat de scheiding ook optisch rust geeft. Wrapt netjes op smal. */
.magb-masthead .cta-row{display:flex;flex-wrap:wrap;align-items:center;
  gap:clamp(18px,2.4vw,30px);margin-top:clamp(6px,1.2vw,12px)}
.magb-masthead .cta-row .link--quiet{margin-left:clamp(2px,0.6vw,8px)}

/* het uitgelichte item als grote cover-kaart */
.magb-cover{position:relative;display:block;text-decoration:none;border-radius:16px;overflow:hidden;
  min-height:clamp(320px,46vw,520px);background:var(--night-slate-2,#1B1E25);
  border:1px solid var(--slate-edge,#2c3038);box-shadow:0 22px 60px rgba(0,0,0,.45);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.magb-cover:hover{transform:translateY(-4px);box-shadow:0 30px 72px rgba(0,0,0,.55)}
.magb-cover-media{position:absolute;inset:0;background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center}
/* leesbaarheids-overlay onder de tekst (donker → transparant) zodat de cover-titel
   altijd AA+ haalt, ook op een lichte foto */
.magb-cover::after{content:"";position:absolute;left:0;right:0;bottom:0;top:38%;
  background:linear-gradient(to bottom, transparent, rgba(13,15,19,.86));pointer-events:none}
.magb-cover-body{position:absolute;left:0;right:0;bottom:0;z-index:1;
  display:flex;flex-direction:column;gap:9px;padding:clamp(22px,3vw,34px)}
.magb-cover-kicker{font-family:var(--f-m);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ember,#D6603C)}
.magb-cover-title{font-family:var(--f-d);font-weight:600;font-size:clamp(24px,3.4vw,40px);
  line-height:1.08;color:#FBF9F1}
.magb-cover-dispatch{font-family:var(--f-m);font-size:11px;letter-spacing:.1em;color:#C2BBAA;min-height:1.1em}
.magb-cover-go{margin-top:4px;color:#FBF9F1;font-weight:600;font-size:13.5px}
.magb-cover:hover .magb-cover-go{color:var(--ember,#D6603C)}
/* merk-zegel als er geen foto is (nooit gebroken beeld) — sterrenveld + zegel */
.magb-cover-media--story,.magb-cover-media--essay,.magb-cover-media--record{
  background-color:#16140F;
  background-image:radial-gradient(1.5px 1.5px at 18% 26%,rgba(214,222,231,.5),transparent),
    radial-gradient(1px 1px at 42% 62%,rgba(214,222,231,.32),transparent),
    radial-gradient(1.5px 1.5px at 78% 34%,rgba(214,222,231,.4),transparent)}
.magb-seal{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--ember,#D6603C)}
.magb-seal--essay b{font-family:var(--f-i);font-style:italic;font-size:46px;color:var(--ember,#D6603C)}
.magb-seal--story .tri{--t:18px;--h:30px;border-bottom-color:var(--ember,#D6603C)}
.magb-seal--rec .rec{width:34px;height:34px;border-radius:50%;border:7px solid var(--ember,#D6603C);position:relative}
.magb-seal--rec .rec::after{content:'';position:absolute;inset:11px;border-radius:50%;background:var(--ember,#D6603C)}

/* "in dit nummer" — rubrieken-balk (de drie pijlers + Apps, compact) */
.magb-rubrics{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.8vw,18px)}
.magb-rubric{display:flex;align-items:center;gap:13px;text-decoration:none;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:16px 18px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.magb-rubric:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.12);background:var(--surface-2)}
.magb-rubric-mark{width:42px;height:42px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--accent)}
.magb-rubric-mark .bseal{--d:42px;border:none}
.magb-rubric-mark .tri{--t:9px;--h:15px}
.magb-rubric-mark .rec{width:19px;height:19px;border-radius:50%;border:4px solid var(--accent);position:relative}
.magb-rubric-mark .rec::after{content:'';position:absolute;inset:6px;border-radius:50%;background:var(--accent)}
.magb-rubric-mark .wire{display:flex;flex-direction:column;gap:3px;align-items:flex-start}
.magb-rubric-mark .wire i{display:block;height:2px;border-radius:2px;background:var(--accent)}
.magb-rubric-mark .wire i:nth-child(1){width:16px}.magb-rubric-mark .wire i:nth-child(2){width:10px}.magb-rubric-mark .wire i:nth-child(3){width:13px}
.magb-rubric-text{display:flex;flex-direction:column;gap:3px;min-width:0}
.magb-rubric-label{font-family:var(--f-m);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mono-c)}
.magb-rubric-title{font-family:var(--f-d);font-weight:600;font-size:16px;line-height:1.1;color:var(--fg)}

@media (max-width:860px){
  .magb-hero-grid{grid-template-columns:1fr}
  .magb-cover{min-height:clamp(280px,70vw,420px)}
  .magb-rubrics{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .magb-rubrics{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .magb-cover,.magb-rubric{transition:none}
}

/* ── B-COVER = de wereldbol-uitnodiging (atlas-SVG, dependency-vrij) ──────────
   De cover-kaart hergebruikt .magb-cover; de globe-variant krijgt een rustige
   nacht-achtergrond met een sterrenveld zodat ook zónder SVG nooit een leeg/
   gebroken vlak ontstaat. */
.magb-globe{background-color:#16140F;
  background-image:radial-gradient(1.5px 1.5px at 16% 22%,rgba(214,222,231,.55),transparent),
    radial-gradient(1px 1px at 38% 58%,rgba(214,222,231,.34),transparent),
    radial-gradient(1.5px 1.5px at 72% 30%,rgba(214,222,231,.46),transparent),
    radial-gradient(1px 1px at 86% 66%,rgba(214,222,231,.3),transparent)}
.magb-globe-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  padding:clamp(18px,4vw,40px) clamp(18px,4vw,40px) 38%}
.mg-svg{width:min(78%,360px);height:auto;display:block;filter:drop-shadow(0 18px 40px rgba(0,0,0,.5))}
.mg-ocean{fill:#22324A;stroke:#33536E;stroke-width:1}
.mg-rim{fill:none;stroke:rgba(214,222,231,.22);stroke-width:1.5}
.mg-grat{fill:none;stroke:rgba(157,182,198,.5);stroke-width:.8}
.mg-route{fill:none;stroke:var(--ember,#D6603C);stroke-width:2.4;stroke-linecap:round;stroke-dasharray:1 6}
.mg-stop{fill:#9DB6C6}
.mg-end{fill:var(--ember,#D6603C)}
.mg-pulse{fill:none;stroke:var(--ember,#D6603C);stroke-width:1.5;transform-origin:146px 86px;animation:mgPulse 2.6s ease-out infinite}
@keyframes mgPulse{0%{transform:scale(1);opacity:.8}70%{transform:scale(3.4);opacity:0}100%{opacity:0}}
/* de "draai" als zachte breathing van de meridianen (orthografische illusie, geen 3D nodig) */
.mg-svg.magb-globe-spin .mg-sphere{transform-origin:100px 100px;animation:mgBreathe 14s ease-in-out infinite}
@keyframes mgBreathe{0%,100%{transform:scaleX(1)}50%{transform:scaleX(.82)}}
@media (prefers-reduced-motion:reduce){
  .mg-svg.magb-globe-spin .mg-sphere{animation:none}
  .mg-pulse{display:none}
}

/* ── vierde rubriek-regel: body-tekst onder de titel (vier makerschappen) ───── */
.magb-rubrics--4{grid-template-columns:repeat(4,1fr)}
.magb-rubric{align-items:flex-start}
.magb-rubric-body{font-family:var(--f-i);font-style:italic;font-size:13px;line-height:1.42;
  color:var(--fg-soft,#6b5a4a);margin-top:2px}
@media (max-width:980px){.magb-rubrics--4{grid-template-columns:repeat(2,1fr)}}
/* W2 #110 — op smal worden de rubrieken een horizontale veeg-rij (scroll-snap +
   duim) i.p.v. een lange kolom. Eén kaart-breed per "schap", met een vleugje
   van de volgende zichtbaar zodat veegbaarheid voelbaar is. De wrapper krijgt
   position:relative zodat de JS-edge-hint (›) rechts kan zweven. */
@media (max-width:520px){
  .magb-issue .wrap{position:relative}
  /* veeg-rij blijft binnen de wrap-padding → nul kans op pagina-overflow (390px).
     Eén kaart-breed per "schap" met een vleugje van de volgende zichtbaar. */
  .magb-rubrics--4{
    display:flex;grid-template-columns:none;flex-wrap:nowrap;
    gap:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;scroll-padding-left:2px;
    padding-bottom:6px;scrollbar-width:none;
  }
  .magb-rubrics--4::-webkit-scrollbar{display:none}
  .magb-rubrics--4 .magb-rubric{
    flex:0 0 86%;scroll-snap-align:start;min-width:0;
  }
}

/* ── BB.Swipe — generieke veeg-rij-verrijking (W2 #110) ──────────────────────
   .bb-swipe wordt door JS toegevoegd zodra een rij werkelijk overflowt. De
   edge-hint (›) hangt rechts en dooft aan het einde. Puur additief: zonder de
   class verandert er niets; reduced-motion zet de puls uit. */
.bb-swipe{outline:none}
.bb-swipe:focus-visible{outline:2px dashed var(--accent);outline-offset:3px;border-radius:12px}
.bb-swipe-hint{position:absolute;right:6px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-d);font-size:18px;line-height:1;color:var(--fg);
  background:var(--surface);border:1px solid var(--line);box-shadow:0 4px 12px rgba(0,0,0,.12);
  pointer-events:none;opacity:.9;transition:opacity .25s var(--ease);animation:bbSwipeNudge 2.2s ease-in-out infinite}
.bb-swipe-hint.is-gone{opacity:0}
@keyframes bbSwipeNudge{0%,100%{transform:translateY(-50%) translateX(0)}50%{transform:translateY(-50%) translateX(3px)}}
/* op breed (geen veeg-rij) heeft de hint geen functie → verbergen */
@media (min-width:521px){.bb-swipe-hint{display:none}}
@media (prefers-reduced-motion:reduce){.bb-swipe-hint{animation:none}}

/* ── ZES TEGELS — instap-grid (story / essay / tour / demo / app / EP) ──────── */
.bt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.bt-tile{display:flex;flex-direction:column;text-align:left;text-decoration:none;cursor:pointer;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  font:inherit;color:inherit;padding:0;width:100%;
  transition:transform .26s var(--ease),box-shadow .26s var(--ease),border-color .26s var(--ease)}
.bt-tile:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(34,30,24,.14);border-color:var(--accent)}
.bt-tile:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
/* RONDE D-beeld — vaste beeldverhouding i.p.v. losse hoogte: reserveert de
   plek vóór het laden (geen layout-shift/CLS) en houdt de tegel-cover gelijk
   met de andere beeldvlakken (trip 16/10, hoes 1/1). De clamp blijft als
   min/max-rem zodat extreem brede/smalle tegels niet ontsporen. */
.bt-media{display:block;aspect-ratio:16/10;min-height:clamp(130px,17vw,168px);
  background-size:cover;background-position:center;background-color:#16140F}
.bt-media--seal{display:flex;align-items:center;justify-content:center;
  background-image:radial-gradient(1.4px 1.4px at 22% 30%,rgba(214,222,231,.5),transparent),
    radial-gradient(1px 1px at 64% 60%,rgba(214,222,231,.32),transparent),
    radial-gradient(1.4px 1.4px at 80% 26%,rgba(214,222,231,.42),transparent)}
.bt-seal{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--ember,#D6603C)}
.bt-seal--essay b{font-family:var(--f-i);font-style:italic;font-size:30px;color:var(--ember,#D6603C)}
.bt-seal--story .tri{--t:11px;--h:18px;border-bottom-color:var(--ember,#D6603C)}
.bt-seal--rec .rec{width:20px;height:20px;border-radius:50%;border:5px solid var(--ember,#D6603C);position:relative}
.bt-seal--rec .rec::after{content:'';position:absolute;inset:6px;border-radius:50%;background:var(--ember,#D6603C)}
.bt-seal--app .wire{display:flex;flex-direction:column;gap:3px;align-items:flex-start}
.bt-seal--app .wire i{display:block;height:2px;border-radius:2px;background:var(--ember,#D6603C)}
.bt-seal--app .wire i:nth-child(1){width:22px}.bt-seal--app .wire i:nth-child(2){width:14px}.bt-seal--app .wire i:nth-child(3){width:18px}
/* QUICK-WIN #5 — kluis/schatkist-zegel voor de demo-instap (verwijst naar de
   kluis-stijl op de kaart). Een klein roest-kistje met deksel-band + slotje,
   puur met CSS-randen — geen extra asset, file://-proof. */
.bt-seal--vault .vault-ic{position:relative;width:26px;height:20px;border:2px solid var(--ember,#D6603C);
  border-radius:3px;box-sizing:border-box}
.bt-seal--vault .vault-ic::before{content:'';position:absolute;left:-2px;right:-2px;top:5px;height:2px;
  background:var(--ember,#D6603C)}
.bt-seal--vault .vault-ic::after{content:'';position:absolute;left:50%;top:3px;transform:translateX(-50%);
  width:5px;height:7px;border-radius:1px;background:var(--ember,#D6603C)}
.bt-body{display:flex;flex-direction:column;gap:6px;padding:clamp(15px,1.8vw,20px)}
.bt-kicker{font-family:var(--f-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent,#B4462B)}
.bt-title{font-family:var(--f-d,var(--f-b));font-weight:600;font-size:clamp(17px,2vw,20px);
  line-height:1.18;color:var(--fg)}
.bt-sub{font-family:var(--f-b);font-size:13.5px;line-height:1.45;color:var(--fg-soft,#6b5a4a)}
.bt-sub i{font-family:var(--f-i);font-style:italic}
.bt-go{font-family:var(--f-m);font-size:11.5px;letter-spacing:.03em;color:var(--accent,#B4462B);margin-top:3px}
.bt-tile:hover .bt-title{color:var(--outback,#B4462B)}
.bt-tile:hover .bt-go{color:var(--ember,#D6603C)}
/* chips (demo-tags) inline naast de tegeltitel */
.bt-chips{display:inline-flex;flex-wrap:wrap;gap:5px;margin-left:8px;vertical-align:middle}
.bt-chip{font-family:var(--f-m);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent,#B4462B);background:var(--surface-2,#efe6da);border:1px solid var(--line);
  border-radius:999px;padding:2px 8px;line-height:1.5}
/* subtiele Spotify-link in de EP-tegel */
.bt-spotify{margin-left:8px}
.bt-spotify a{font-family:var(--f-m);font-size:11px;color:var(--accent,#B4462B);text-decoration:underline}
/* skeleton-tegel (audiotour/EP nog aan het laden) — rustige perkament-puls */
.bt-tile--skeleton{min-height:240px;background:var(--surface-2,#efe6da);border-style:dashed;cursor:default}
.bt-tile--skeleton:hover{transform:none;box-shadow:none;border-color:var(--line)}
@media (max-width:860px){.bt-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.bt-grid{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){.bt-tile{transition:none}}

/* ══════════════════════════════════════════════════════════════════════════
   MOBIEL: HOME HEROHERZIENING (≤680px).
   ──────────────────────────────────────────────────────────────────────────
   Bas: "op de main pagina ziet de globe er erg raar uit." Wat er raar was:
   • de globe-SVG zweefde hoog in een te hoge cover-kaart (padding-bottom 38%)
     met een grote dode nacht-vlek eronder, tekst onderin geperst;
   • de "breathing" scaleX-animatie kneep de bol zichtbaar samen → ogend als een
     glitch op klein scherm.
   Herontwerp: de bol staat eerst (cover bovenaan), nette vierkante-ish kaart met
   de globe gecentreerd, ademende marges, kalme/uitgezette wiebel, en het
   titelblok eronder met bewuste ritmiek. svh tegen de adresbalk-spring. ── */
@media (max-width:680px){
  .magb-hero{min-height:auto;padding-top:clamp(18px,5vh,30px);padding-bottom:clamp(26px,6vh,40px)}
  /* de bol als ster: cover EERST, dan het titelblok (leesvolgorde = beeld→woord) */
  .magb-hero-grid{display:flex;flex-direction:column;gap:clamp(22px,4vh,30px)}
  .magb-cover.magb-globe{order:0}
  .magb-masthead{order:1;gap:14px;text-align:center;align-items:center}
  .magb-hero .live-badge{align-self:center}
  .magb-masthead h1{font-size:clamp(34px,9vw,46px);line-height:1.02}
  .magb-ident{font-size:15px;line-height:1.5;max-width:40ch;margin-inline:auto}
  .cta-row{justify-content:center;flex-wrap:wrap;gap:12px}

  /* nette, niet te hoge cover-kaart met de globe echt in het midden */
  .magb-cover.magb-globe{min-height:0;aspect-ratio:1/1;max-height:62svh;
    display:flex;align-items:stretch}
  .magb-globe-stage{position:relative;inset:auto;flex:1;
    padding:clamp(22px,7vw,40px) clamp(22px,7vw,40px) clamp(78px,22vw,108px)}
  .mg-svg{width:min(72%,300px)}
  /* de cover-tekst netjes onderlangs (was absolute bottom — blijft, maar met
     wat meer lucht zodat ze niet tegen de globe plakt) */
  .magb-cover-body{padding:18px clamp(18px,5vw,22px) clamp(18px,5vw,22px);gap:7px}
  .magb-cover-title{font-size:clamp(22px,5.6vw,28px)}
}
/* de "breathing"-wiebel van de home-globe op smal scherm uitzetten: op een
   kleine SVG ogend als een glitch i.p.v. een draai. De pulse-puls blijft. */
@media (max-width:680px){
  .mg-svg.magb-globe-spin .mg-sphere{animation:none}
}

/* demo-chips óók op de Music-pagina (zelfde helper, zelfde stijl) */
.demo-title .demo-chips{display:inline-flex;flex-wrap:wrap;gap:5px;margin-left:8px;vertical-align:middle}
.demo-chip{font-family:var(--f-m);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ember,#D6603C);background:rgba(214,96,60,.12);border:1px solid rgba(214,96,60,.3);
  border-radius:999px;padding:2px 8px;line-height:1.5}

/* ═══ Music — release-type badge in de platenkast (EP / Single / Album / Live) ═══ */
.rec-type{display:inline-block;vertical-align:middle;font-family:var(--f-m);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent,#B4462B);
  border:1px solid rgba(180,70,43,.4);
  border-radius:999px;padding:2px 8px;margin-right:4px;line-height:1.6;position:relative;top:-2px}

/* "ook als demo →" onder een release-track (kruisverwijzing demo↔finale) */
.vs-also-demo{display:inline-flex;align-items:center;min-height:34px;background:none;border:0;cursor:pointer;
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;color:var(--mono-c);
  margin:-4px 0 8px 52px;padding:4px 0;text-align:left}
.vs-also-demo:hover{color:var(--accent,#B4462B)}

/* ═══ Music — demo weergave-schakelaar + groepen (nacht-warm) ═══ */
.demo-shuffle{font-family:var(--f-m);font-size:13px;letter-spacing:.02em;white-space:nowrap}
.demo-views{display:inline-flex;gap:4px;margin:0 0 16px;padding:4px;border-radius:999px;
  background:var(--char-1,#1B1813);border:1px solid var(--char-edge,#3a342a)}
.demo-view{font-family:var(--f-m);font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--char-num,#8a8068);background:none;border:0;border-radius:999px;cursor:pointer;
  min-height:38px;padding:8px 16px;transition:color .2s,background .2s}
.demo-view:hover{color:var(--on-night,#ECE6D5)}
.demo-view.is-on{color:var(--char-bg,#15120d);background:var(--ember,#D6603C)}
.demo-group-label{display:flex;align-items:center;gap:12px;margin:24px 0 4px;
  font-family:var(--f-m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--char-num,#8a8068)}
.demo-group-label>span:first-child{flex:0 0 auto;order:1}
.demo-group-label::after{content:'';flex:1;height:1px;background:var(--char-line,#241f19);order:2}
.demo-group-label:first-child{margin-top:6px}
.demo-group-count{flex:0 0 auto;order:3;color:var(--ember,#D6603C);letter-spacing:.08em;
  border:1px solid rgba(214,96,60,.32);border-radius:999px;padding:2px 9px;text-transform:none}
/* "ook verschenen op [plaat] →" onder een demo */
.demo-alsoon{font-family:var(--f-m);font-size:10.5px;letter-spacing:.04em;color:var(--char-num,#8a8068);margin-top:3px}
.demo-item:hover .demo-alsoon{color:var(--ember,#D6603C)}

/* ═══ Music — Playlists (warm/perkament; featured groot + bladerbare kaarten) ═══ */
.pl-featured{margin-top:6px}
.pl-hero{background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:clamp(20px,3.4vw,30px);box-shadow:0 1px 0 rgba(0,0,0,.02)}
.pl-hero-kick{font-family:var(--f-m);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent,#B4462B);margin:0 0 8px}
.pl-hero-title{font-family:var(--f-d);font-weight:600;font-size:clamp(22px,3.6vw,32px);color:var(--fg);margin:0}
.pl-hero-desc{color:var(--fg-soft);font-size:15.5px;line-height:1.55;max-width:58ch;margin:10px 0 18px}
.pl-hero-play{display:inline-flex;align-items:center;gap:10px}
.pl-hero-play .tri--play{--t:6px;--h:11px;border-left-color:currentColor}
.pl-hero-count{font-family:var(--f-m);font-size:11px;background:rgba(255,255,255,.22);
  border-radius:999px;padding:1px 8px;margin-left:2px}
.pl-rest{margin-top:18px}
.pl-cards{display:flex;gap:14px;flex-wrap:wrap}
.pl-card{display:flex;align-items:flex-start;gap:14px;text-align:left;cursor:pointer;
  flex:1 1 260px;min-width:0;background:var(--bg);border:1px solid var(--line);border-radius:14px;
  padding:16px;color:var(--fg);font-family:inherit;transition:border-color .2s,transform .2s}
.pl-card:hover{border-color:var(--accent,#B4462B);transform:translateY(-2px)}
.pl-card[disabled]{opacity:.55;cursor:default}
.pl-card[disabled]:hover{border-color:var(--line);transform:none}
.pl-card-play{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line)}
.pl-card:hover .pl-card-play{border-color:var(--accent,#B4462B)}
.pl-card-play .tri--play{--t:6px;--h:11px;border-left-color:var(--accent,#B4462B)}
.pl-card-body{display:flex;flex-direction:column;gap:5px;min-width:0;flex:1}
.pl-card-title{font-family:var(--f-d);font-weight:600;font-size:17px;color:var(--fg)}
.pl-card:hover .pl-card-title{color:var(--accent,#B4462B)}
.pl-card-desc{font-size:13.5px;line-height:1.5;color:var(--fg-soft);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.pl-card-count{font-family:var(--f-m);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--mono-c)}

/* telefoon (≤560px): schakelaar mag wrappen; kaarten één kolom; geen overflow */
@media (max-width:560px){
  .demo-views{display:flex;width:100%}
  .demo-view{flex:1 1 0;padding:8px 6px;text-align:center}
  .pl-cards{flex-direction:column}
  .pl-card{flex:1 1 auto}
}

/* ════════════════════════════════════════════════════════
   DE RELEASE-LADE — in-place, papieren overlay (Optie 1)
   Klik op een hoes → het paneel groeit eruit (FLIP). Licht/
   perkament/roest DNA; GEEN donkere modal, geen 3D-gatefold.
   Desktop: gecentreerd vel; mobiel: full-screen bottom-sheet.
════════════════════════════════════════════════════════ */
.rl-overlay{position:fixed;inset:0;z-index:130;display:flex;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,48px)}
.rl-overlay[hidden]{display:none}
/* ZACHTE, WARME dim — perkament, niet zwart; muur blijft zichtbaar */
.rl-dim{position:absolute;inset:0;background:
  radial-gradient(140% 100% at 50% 0%, rgba(180,70,43,.10), transparent 55%),
  rgba(34,28,18,.46);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
  opacity:0;transition:opacity .28s var(--ease)}
.rl-overlay.rl-open .rl-dim{opacity:1}

/* het papieren vel */
.rl-panel{position:relative;z-index:1;width:min(1020px,100%);max-height:90vh;
  display:flex;flex-direction:column;border-radius:18px;overflow:hidden;
  background:var(--paper-warm,#F4F0E4);color:var(--reader,#2A251D);
  --bg:var(--paper-warm);--fg:var(--reader);--fg-soft:var(--umber);--fg-mute:var(--ink3);
  --surface:var(--paper-50);--accent:var(--outback);--line:var(--taupe);--mono-c:var(--drab);
  box-shadow:0 40px 120px rgba(34,24,14,.5), 0 0 0 1px rgba(91,83,69,.16),
    inset 0 0 0 1px rgba(255,255,255,.5);
  opacity:0;transform:translateY(14px) scale(.985);
  transition:transform .3s var(--ease),opacity .3s var(--ease)}
.rl-overlay.rl-open .rl-panel{opacity:1;transform:none}
/* zachte perkament-grain bovenop het vel (merkstijl) */
.rl-panel::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.4;
  mix-blend-mode:multiply;
  background-image:repeating-linear-gradient(28deg, rgba(91,83,69,.035) 0 2px, transparent 2px 5px)}
.rl-panel.rl-xfade .rl-scroll{opacity:0;transition:opacity .11s ease}
.rl-scroll{position:relative;z-index:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;padding:clamp(18px,3vw,30px) clamp(18px,3.4vw,40px) clamp(28px,4vw,44px);
  transition:opacity .14s ease;outline:none}

/* kop-rij: bladeren ‹ › + sluiten × */
.rl-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.rl-head-spacer{flex:1}
.rl-nav,.rl-close{appearance:none;-webkit-appearance:none;border:1px solid var(--taupe);
  background:var(--paper-50);color:var(--reader);border-radius:50%;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
  min-width:44px;min-height:44px;font-family:var(--f-d);transition:border-color .18s var(--ease),color .18s var(--ease),background .18s var(--ease)}
.rl-nav{font-size:24px}
.rl-close{font-size:24px;margin-left:4px}
.rl-nav:hover:not([disabled]),.rl-close:hover{border-color:var(--outback);color:var(--outback)}
.rl-nav[disabled]{opacity:.35;cursor:default}
.rl-nav:focus-visible,.rl-close:focus-visible{outline:2px solid var(--outback);outline-offset:2px}

/* twee kolommen: cover/meta links · liner notes rechts */
.rl-release{display:grid;grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);
  gap:clamp(22px,3.4vw,44px);align-items:start}
.rl-left{min-width:0}
.rl-cover{position:relative;width:100%;max-width:360px}
.rl-cover-frame{display:block;width:100%;aspect-ratio:1/1;border-radius:8px;overflow:hidden;
  position:relative;container-type:inline-size;
  box-shadow:0 18px 44px rgba(34,24,14,.32), inset 0 0 0 1px rgba(91,83,69,.14)}
.rl-cover-img{display:block;width:100%;height:100%;object-fit:cover;
  animation:rlCoverIn .32s var(--ease)}
@keyframes rlCoverIn{from{opacity:0}to{opacity:1}}
.rl-typebadge{display:inline-block;margin-top:16px;font-family:var(--f-m);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--outback);
  border:1px solid rgba(180,70,43,.4);border-radius:999px;padding:3px 10px}
.rl-title{font-family:var(--f-d);font-weight:600;font-size:clamp(24px,3.6vw,38px);line-height:1.06;
  color:var(--ink,#221E18);margin:10px 0 0;letter-spacing:-.01em}
.rl-meta{font-family:var(--f-m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--drab);margin-top:10px}
.rl-desc{font-family:var(--f-i);font-style:italic;font-size:clamp(15px,1.9vw,17px);line-height:1.55;
  color:var(--umber);margin:14px 0 18px;max-width:46ch}
.rl-playrec{display:inline-flex;align-items:center;gap:10px;margin-top:4px}
.rl-playrec .tri--play{--t:6px;--h:11px;border-left-color:currentColor}
.rl-playrec[disabled]{opacity:.5;cursor:default}

.rl-right{min-width:0}
.rl-tracks-head{margin-top:0}
.rl-tracks .vs-track{grid-template-columns:38px 28px 1fr auto}
.rl-lyrics{margin-top:8px}
.rl-ablive{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* demo↔finale A/B-strip onder een track-rij */
.rl-ab{display:inline-flex;gap:4px;margin:-6px 0 8px 90px;padding:3px;border-radius:999px;
  background:rgba(180,70,43,.07);border:1px solid rgba(180,70,43,.22)}
.rl-ab-btn{appearance:none;-webkit-appearance:none;border:0;background:none;cursor:pointer;
  font-family:var(--f-m);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--drab);border-radius:999px;min-height:34px;padding:6px 13px;
  transition:background .18s var(--ease),color .18s var(--ease)}
.rl-ab-btn:hover{color:var(--outback)}
.rl-ab-btn[aria-pressed="true"]{background:var(--outback);color:#fff}
.rl-ab-btn:focus-visible{outline:2px solid var(--outback);outline-offset:2px}

/* ── Demo's-paneel binnen dezelfde lade (lichte variant) ── */
.rl-demos{min-width:0}
.rl-demos .sec-head{margin-bottom:6px}
.rl-demos .eyebrow{color:var(--outback)}
.rl-demos h2{font-family:var(--f-d);font-weight:600;font-size:clamp(24px,4vw,34px);color:var(--ink,#221E18)}
.rl-demos .demos-note{color:var(--umber);max-width:54ch}
/* de demo-schakelaar + groepen lichte-modus (overschrijf de nacht-tokens) */
.rl-demos .demo-views{background:var(--paper-50);border-color:var(--taupe)}
.rl-demos .demo-view{color:var(--drab)}
.rl-demos .demo-view:hover{color:var(--reader)}
.rl-demos .demo-view.is-on{color:#fff;background:var(--outback)}
.rl-demolist{margin-top:6px}
.rl-demos .demo-item{border-bottom-color:var(--taupe);color:var(--reader)}
.rl-demos .demo-item:hover{background:var(--paper-50)}
.rl-demos .demo-item[aria-pressed="true"] .demo-title{color:var(--outback)}
.rl-demos .demo-play{border-color:var(--taupe)}
.rl-demos .demo-play .tri--play{border-left-color:var(--outback)}
.rl-demos .demo-title{color:var(--ink,#221E18)}
.rl-demos .demo-sub,.rl-demos .demo-dur{color:var(--drab)}
.rl-demos .demo-group-label{color:var(--drab)}
.rl-demos .demo-group-label::after{background:var(--taupe)}
.rl-demos .demo-group-count{color:var(--outback);border-color:rgba(180,70,43,.32)}
.rl-demo-row{display:flex;flex-direction:column}
.rl-demo-row .demo-alsoon{align-self:flex-start;background:none;border:0;cursor:pointer;
  padding:2px 0 8px 48px;color:var(--drab)}
.rl-demo-row .demo-alsoon:hover{color:var(--outback)}

/* ── mobiel: full-screen bottom-sheet (van onderen omhoog) ── */
@media (max-width:760px){
  .rl-overlay{padding:0;align-items:flex-end}
  .rl-panel{width:100%;max-height:94vh;height:94vh;border-radius:20px 20px 0 0;
    transform:translateY(100%);transition:transform .32s var(--ease),opacity .32s var(--ease)}
  .rl-overlay.rl-open .rl-panel{transform:none}
  .rl-release{grid-template-columns:1fr;gap:18px}
  .rl-cover{max-width:none;margin:0 auto;width:min(78vw,360px)}
  .rl-left{text-align:center}
  .rl-title{margin-top:14px}
  .rl-desc{margin-left:auto;margin-right:auto}
  .rl-playrec{margin-top:8px}
  /* een grijp-handvat bovenaan de sheet */
  .rl-scroll{padding-top:30px}
  .rl-panel::after{content:"";position:absolute;top:9px;left:50%;transform:translateX(-50%);
    width:42px;height:4px;border-radius:999px;background:var(--taupe);z-index:2}
  .rl-ab{margin-left:0}
  .rl-tracks .vs-track{grid-template-columns:34px 26px 1fr auto}
}

@media (prefers-reduced-motion:reduce){
  .rl-dim,.rl-panel,.rl-scroll,.rl-cover-img{transition:none;animation:none}
  .rl-panel{transform:none;opacity:1}
}

/* ═══ QUICK-WIN #3 — vangnet voor het The-Journey-nav-submenu op niet-globe-pagina's ═══
   De volledige styling van het "Spring naar een reis"-submenu (.nav-sub) leeft in
   v3-globe.css, die ALLEEN The Journey laadt. Bij een zachte navigatie kon de
   The-Journey-header (mét submenu) op deze pagina's blijven hangen → rauwe,
   overlappende tekst over de titel. core.js trekt nu de nav-links gelijk met de
   doelpagina (dus het submenu hoort hier niet meer voor te komen), maar als
   vangnet houden we élk overgebleven submenu hier hard verborgen — zodat de
   ongestylede zooi nooit meer kan verschijnen, ook niet kort tijdens een transitie. */
.nav-sub{display:none !important}
