/* ============================================================
   Diepgravers · Fuik — gedeelde stijl (Walsh × Ive)
   Gebruikt door index.html (werven) · kiezen.html · inschrijven.html
   ============================================================ */
:root{
  --ink:#16131f; --ink-soft:#3a3548; --mute:#6b6577; --coral-text:#e0344e;
  --cream:#f7f1e4; --paper:#fffdf7; --line:#e7ddc9;
  --blue:#2563ff; --coral:#ff5a6e; --amber:#ffb020; --green:#15b886;
  --purple:#a855f7; --magenta:#ec4899; --ethos:#c02026;
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --ui:"Space Grotesk",ui-sans-serif,system-ui,-apple-system,sans-serif;
  --shadow:0 22px 60px rgba(22,19,31,.10);
  --maxtext:760px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--ui);
  font-size:19px;line-height:1.56;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}
.text{max-width:var(--maxtext)}
.skip{position:absolute;left:-9999px}.skip:focus{left:12px;top:12px;background:#fff;padding:10px 16px;border-radius:10px;z-index:200}

/* ---------- HEADER ---------- */
.top{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:18px;
  padding:14px clamp(20px,5vw,64px);background:rgba(247,241,228,.82);
  backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid rgba(22,19,31,.08)}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand .mole{width:69px;flex:none}
.brand b{font-family:var(--display);font-weight:900;font-size:2.13rem;letter-spacing:.05em;text-transform:uppercase}
.brand i{display:block;font-style:normal;font-size:.6rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mute);margin-top:1px}
.top .sp{flex:1}
.cobrand{display:flex;align-items:center;gap:16px}
.cobrand .eth{display:flex;align-items:center;gap:8px}
.cobrand .eth img{height:30px;width:auto}
.cobrand .eth span{font-family:Georgia,serif;font-weight:700;font-size:1.02rem;line-height:1}
.cobrand .eth span em{font-style:normal;color:var(--ethos)}
.cobrand .vu{height:30px;width:auto;opacity:.92}
@media(max-width:760px){.cobrand .eth span{display:none}.cobrand .eth img{height:26px}.cobrand .vu{height:26px}}

/* ---------- STAPPEN-INDICATOR (de drie kelen van de fuik) ---------- */
.steps{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;
  padding:14px clamp(20px,5vw,64px);background:var(--paper);border-bottom:1px solid var(--line)}
.steps a,.steps span.st{display:inline-flex;align-items:center;gap:9px;font-size:.86rem;font-weight:600;
  color:var(--mute);text-decoration:none;padding:5px 10px;border-radius:999px}
.steps .n{width:23px;height:23px;border-radius:50%;border:2px solid var(--line);display:flex;align-items:center;
  justify-content:center;font-size:.78rem;font-weight:700;color:var(--mute);flex:none}
.steps .cur{color:var(--ink)}
.steps .cur .n{background:var(--ink);border-color:var(--ink);color:#fff}
.steps .done .n{background:var(--green);border-color:var(--green);color:#fff}
.steps .arr{color:var(--line);font-weight:700}
@media(max-width:560px){.steps a,.steps span.st{font-size:.74rem;gap:6px}.steps .arr{display:none}}

/* ---------- KNOPPEN ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--ui);font-weight:700;
  font-size:1.02rem;letter-spacing:.01em;text-decoration:none;border:none;cursor:pointer;
  padding:16px 26px;border-radius:16px;transition:transform .12s ease,box-shadow .15s,background .15s}
.btn svg{width:17px;height:17px;flex:none}
.btn-primary{background:var(--ink);color:#fff;box-shadow:0 4px 0 #000}
.btn-primary:hover{background:var(--blue);transform:translateY(-2px);box-shadow:0 6px 0 rgba(0,0,0,.3)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink);padding:14px 22px}
.btn-ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-lg{font-size:1.12rem;padding:18px 30px}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(54px,9vw,116px) 0 clamp(36px,5vw,64px)}
.hero.short{padding:clamp(44px,6vw,76px) 0 clamp(28px,3vw,40px)}
.blob{position:absolute;border-radius:50%;filter:blur(46px);opacity:.5;z-index:0;pointer-events:none}
.blob.a{width:440px;height:440px;background:var(--coral);top:-150px;right:-90px}
.blob.b{width:360px;height:360px;background:var(--amber);bottom:-160px;left:-110px;opacity:.42}
.blob.c{width:240px;height:240px;background:var(--blue);top:38%;right:24%;opacity:.22}
.hero .wrap{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;font-size:.72rem;background:var(--ink);color:#fff;padding:8px 15px 8px 11px;border-radius:999px}
.eyebrow .dnw{height:15px;width:auto;filter:brightness(0) invert(1);opacity:.95}
h1.hero-h{font-family:var(--display);font-weight:900;font-optical-sizing:auto;
  font-size:clamp(2.8rem,8.6vw,6.4rem);line-height:.94;letter-spacing:-.018em;margin:.34em 0 .26em;max-width:14ch}
h1.hero-h .slash{color:var(--amber);font-style:italic;font-weight:600;padding:0 .06em}
.lead{font-size:clamp(1.16rem,2.5vw,1.5rem);line-height:1.5;color:var(--ink-soft);max-width:32ch;font-weight:500}
.lead .em{color:var(--ink);font-weight:600}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px}
.chip{font-size:.84rem;font-weight:600;background:var(--paper);border:1.5px solid var(--line);
  border-radius:999px;padding:8px 15px;color:var(--ink-soft)}
.chip b{color:var(--ink);font-weight:700}
.hero-mole{position:absolute;right:clamp(-10px,3vw,40px);bottom:6px;width:clamp(120px,16vw,200px);z-index:1;
  opacity:.96;animation:dig 5.5s ease-in-out infinite;transform-origin:60% 80%}
@keyframes dig{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(16px) rotate(4deg)}}
@media(max-width:900px){.hero-mole{display:none}}

/* ---------- LEAD MAGNET (gratis proefcollege capture) ---------- */
.magnet{margin-top:30px;background:var(--paper);border:2px solid var(--ink);border-radius:20px;
  padding:20px 22px;max-width:540px;box-shadow:var(--shadow)}
.magnet .ml{font-family:var(--display);font-weight:600;font-size:1.16rem;margin:0 0 3px}
.magnet .ms{font-size:.9rem;color:var(--ink-soft);margin:0 0 14px}
.magnet .ms b{color:var(--ink)}
.magnet form{display:flex;gap:9px;flex-wrap:wrap}
.magnet input{flex:1;min-width:190px;font-family:var(--ui);font-size:1rem;padding:13px 15px;
  border:2px solid var(--line);border-radius:13px;background:#fff;transition:border-color .15s}
.magnet input:focus{outline:none;border-color:var(--blue)}
.magnet .okmsg{display:none;color:#0c7a55;font-weight:700;font-size:.94rem;margin-top:6px}
.magnet.done .okmsg{display:block}

/* ---------- SCHAARSTE-STRIP ---------- */
.scarcity{background:var(--ink);color:#fff;font-size:.92rem;font-weight:600;text-align:center;
  padding:11px 20px;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.scarcity b{color:var(--amber)}
.scarcity .pin{display:inline-flex;align-items:center;gap:7px}
.scarcity .dot{width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 0 var(--coral);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,90,110,.6)}70%{box-shadow:0 0 0 9px rgba(255,90,110,0)}100%{box-shadow:0 0 0 0 rgba(255,90,110,0)}}
@media(prefers-reduced-motion:reduce){.scarcity .dot{animation:none}}

/* ---------- SECTIE-RITME ---------- */
.band{padding:clamp(30px,4.2vw,52px) 0;position:relative}
.band.paper{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band.tight{padding-top:clamp(22px,3vw,38px)}
.kicker{font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.76rem;color:var(--blue);margin:0 0 12px}
h2{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4.8vw,3.1rem);line-height:1.02;
  letter-spacing:-.014em;margin:0 0 .46em}
h2 .it{font-style:italic;font-weight:600;color:var(--coral-text)}
h3{font-family:var(--display);font-weight:600;font-size:1.34rem;line-height:1.2;margin:0}
p{margin:0 0 .96em}
.big{font-size:clamp(1.2rem,2.3vw,1.46rem);line-height:1.5;color:var(--ink-soft);font-weight:500}
.story p{color:var(--ink-soft)}
.story p .em{color:var(--ink);font-weight:600}
.story h2{margin-top:1.3em}.story h2:first-child{margin-top:0}
.inset{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(1.3rem,3vw,1.8rem);
  line-height:1.34;color:var(--ink);border-left:4px solid var(--amber);padding:6px 0 6px 26px;margin:1.6em 0}
.readlist{display:flex;flex-wrap:wrap;gap:10px;margin:1.4em 0 0;padding:0;list-style:none}
.readlist li{font-size:.92rem;font-weight:600;background:var(--cream);border:1.5px solid var(--line);
  border-radius:12px;padding:9px 15px;color:var(--ink-soft)}
.readlist li b{color:var(--ink);font-family:var(--display);font-weight:600}

/* ---------- KEUZEMENU ---------- */
.reeksen{display:grid;gap:16px;margin:30px 0 0}
.reeks{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:start;
  background:var(--paper);border:2px solid var(--line);border-radius:20px;padding:22px 24px;cursor:pointer;
  transition:border-color .16s,box-shadow .16s,transform .12s,background .16s}
.reeks:hover{border-color:var(--c,var(--ink));box-shadow:var(--shadow);transform:translateY(-2px)}
.reeks input{position:absolute;opacity:0;width:0;height:0}
.box{width:30px;height:30px;border-radius:9px;border:2.5px solid var(--c,var(--ink));background:#fff;
  flex:none;position:relative;transition:background .16s;margin-top:3px}
.box::after{content:"";position:absolute;left:9px;top:4px;width:7px;height:13px;border:solid #fff;
  border-width:0 3px 3px 0;transform:rotate(45deg) scale(0);transition:transform .16s}
.reeks.on{border-color:var(--c,var(--ink));background:color-mix(in srgb,var(--c,var(--ink)) 7%,var(--paper))}
.reeks.on .box{background:var(--c,var(--ink))}
.reeks.on .box::after{transform:rotate(45deg) scale(1)}
.reeks:focus-within{outline:3px solid color-mix(in srgb,var(--c,var(--blue)) 45%,transparent);outline-offset:2px}
.rk{min-width:0}
.verb{display:block;font-family:var(--display);font-weight:900;font-size:1.46rem;line-height:1;letter-spacing:-.01em}
.rt{display:block;font-weight:700;font-size:.96rem;color:var(--c,var(--ink));margin:3px 0 8px}
.rd{font-size:.95rem;line-height:1.5;color:var(--ink-soft);margin:0}
.meta{text-align:right;flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:7px}
.per{font-size:.78rem;font-weight:600;letter-spacing:.02em;color:var(--mute);white-space:nowrap}
.price{font-family:var(--display);font-weight:900;font-size:1.5rem;line-height:1}
.price small{display:block;font-family:var(--ui);font-size:.72rem;font-weight:600;color:var(--mute);margin-top:3px}
.sub-h{font-family:var(--display);font-weight:600;font-size:1.18rem;margin:34px 0 4px;display:flex;align-items:center;gap:10px}
.sub-h .zon{width:.95em;height:.95em;color:var(--amber)}
.sub-note{font-size:.95rem;color:var(--ink-soft);margin:0 0 16px;max-width:var(--maxtext)}
.reeks.extra .verb{font-size:1.24rem}
.yearbar{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:var(--ink);color:#fff;border-radius:18px;padding:20px 26px;margin-top:22px}
.yearbar .yl{font-family:var(--display);font-weight:600;font-size:1.12rem}
.yearbar .yl small{display:block;font-family:var(--ui);font-size:.84rem;color:rgba(255,255,255,.62);font-weight:400;margin-top:3px}
.yearbar .yr{display:flex;align-items:center;gap:16px;margin-left:auto}
.yearbar .yp{font-family:var(--display);font-weight:900;font-size:1.7rem}
.linkbtn{background:none;border:none;font-family:var(--ui);font-weight:700;font-size:.95rem;color:#fff;
  text-decoration:underline;text-underline-offset:3px;cursor:pointer;padding:0}
.afterprice{font-size:.92rem;color:var(--mute);margin:14px 0 0}

/* ---------- DOCENTEN ---------- */
.docs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:26px 22px;margin-top:26px;padding:0;list-style:none;max-width:980px}
.doc{display:block}
.doc>span{display:block;margin-top:10px}
.doc:nth-child(4n+2) .av{border-bottom-color:var(--coral)}
.doc:nth-child(4n+3) .av{border-bottom-color:var(--amber)}
.doc:nth-child(4n+4) .av{border-bottom-color:var(--green)}
.doc .av{width:100%;aspect-ratio:4/3;height:auto;border-radius:0;object-fit:cover;object-position:center 25%;border-bottom:4px solid var(--blue);display:block;
  border:2.5px solid var(--ink);background:#fff;flex:none;box-shadow:0 0 0 4px var(--cream),0 0 0 5px var(--line)}
.doc .av.ini{display:flex;align-items:center;justify-content:center;font-family:var(--display);
  font-weight:900;font-size:1.1rem;color:#fff;background:var(--purple)}
.doc b{font-family:var(--display);font-weight:600;font-size:1.06rem;display:block;line-height:1.1}
.doc span span{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}
.plus{align-self:center;font-size:.95rem;color:var(--ink-soft);font-weight:600;max-width:200px}
.plus b{color:var(--ink)}

/* ---------- SOCIAL PROOF ---------- */
.proofbar{display:flex;flex-wrap:wrap;gap:14px 30px;align-items:center;margin:0 0 30px}
.proofbar .stat{display:flex;flex-direction:column}
.proofbar .stat b{font-family:var(--display);font-weight:900;font-size:2.1rem;line-height:1}
.proofbar .stat span{font-size:.86rem;color:var(--mute);font-weight:600}
.proofbar .vdiv{width:1px;height:42px;background:var(--line)}
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:8px}
.quote{background:var(--cream);border:1.5px solid var(--line);border-radius:18px;padding:24px 24px 20px;position:relative}
.quote.hl{background:color-mix(in srgb,var(--amber) 12%,var(--paper));border-color:color-mix(in srgb,var(--amber) 40%,var(--line))}
.quote::before{content:"\201C";position:absolute;top:2px;left:16px;font-family:var(--display);font-weight:900;
  font-size:3.4rem;color:var(--amber);line-height:1;opacity:.5}
.quote .qhead{display:flex;align-items:center;gap:12px;margin-bottom:4px;position:relative}
.quote .qhead img{width:46px;height:46px;border-radius:50%;object-fit:cover;object-position:center 22%;border:2px solid var(--ink)}
.quote .qhead .qa{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;
  background:var(--blue);color:#fff;font-family:var(--display);font-weight:900;border:2px solid var(--ink);flex:none}
.quote p{font-family:var(--display);font-style:italic;font-weight:400;font-size:1.04rem;line-height:1.42;
  color:var(--ink);margin:12px 0 12px;position:relative}
.quote cite{font-style:normal;font-size:.84rem;font-weight:700;color:var(--ink-soft)}
.quote cite small{display:block;font-weight:500;color:var(--mute)}

/* ---------- FAQ ---------- */
.faq{max-width:var(--maxtext);margin-top:24px}
.faq details{border-bottom:1.5px solid var(--line);padding:4px 0}
.faq summary{list-style:none;cursor:pointer;font-family:var(--display);font-weight:600;font-size:1.18rem;
  padding:16px 40px 16px 0;position:relative;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:13px;font-family:var(--ui);font-weight:400;
  font-size:1.7rem;color:var(--blue);transition:transform .18s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{font-size:.98rem;line-height:1.55;color:var(--ink-soft);padding:0 30px 18px 0;margin:0}
.faq .a a{color:var(--blue);font-weight:700}

/* ---------- CAPTURE ---------- */
.capture{background:
  radial-gradient(120% 130% at 8% 0%,rgba(255,90,110,.5) 0%,transparent 46%),
  radial-gradient(120% 130% at 96% 8%,rgba(255,176,32,.5) 0%,transparent 44%),
  radial-gradient(140% 150% at 70% 108%,rgba(37,99,255,.55) 0%,transparent 52%),
  var(--ink);color:#fff}
.capture h2{color:#fff}
.capture .big{color:rgba(255,255,255,.86)}
.cap-card{background:var(--paper);color:var(--ink);border-radius:24px;padding:clamp(28px,4vw,44px);
  max-width:560px;box-shadow:0 40px 90px rgba(0,0,0,.4)}
.cap-card h3{font-family:var(--display);font-weight:900;font-size:1.5rem;margin:0 0 6px}
.cap-card .sel-line{font-size:.95rem;color:var(--ink-soft);margin:0 0 20px;min-height:1.5em}
.cap-card .sel-line b{color:var(--ink);font-weight:700}
.signup{display:flex;gap:10px;flex-wrap:wrap}
.signup input[type=email]{flex:1;min-width:200px;font-family:var(--ui);font-size:1rem;padding:15px 17px;
  border:2px solid var(--line);border-radius:14px;background:#fff;transition:border-color .15s}
.signup input[type=email]:focus{outline:none;border-color:var(--blue)}
.cap-fine{font-size:.82rem;color:var(--mute);margin:16px 0 0}
.cap-ok{display:none;background:color-mix(in srgb,var(--green) 12%,#fff);border:2px solid var(--green);
  border-radius:16px;padding:20px 22px;margin-top:4px}
.cap-ok.show{display:block}
.cap-ok b{font-family:var(--display);font-weight:900;font-size:1.2rem;display:block;margin-bottom:4px;color:#0c7a55}

/* ---------- STICKY TOTAALBALK ---------- */
.totalbar{position:fixed;left:0;right:0;bottom:0;z-index:70;transform:translateY(110%);
  transition:transform .32s cubic-bezier(.22,1,.36,1)}
.totalbar.show{transform:none}
.totalbar .in{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:var(--ink);color:#fff;border-radius:20px 20px 0 0;padding:15px clamp(18px,4vw,30px);
  box-shadow:0 -16px 40px rgba(22,19,31,.26)}
.totalbar .tb-t{font-weight:600;font-size:.96rem}
.totalbar .tb-t b{font-family:var(--display);font-weight:900}
.totalbar .tb-amt{font-family:var(--display);font-weight:900;font-size:1.55rem;margin-left:auto}
.totalbar .btn{padding:13px 24px}
.totalbar .btn-primary{background:#fff;color:var(--ink);box-shadow:0 4px 0 rgba(0,0,0,.4)}
.totalbar .btn-primary:hover{background:var(--amber);color:var(--ink)}
@media(max-width:560px){.totalbar .tb-amt{margin-left:0}.totalbar .in{gap:10px}.totalbar .tb-t{flex:1 0 100%}}

/* ---------- FOOTER ---------- */
footer{background:var(--cream);border-top:5px solid var(--amber);padding:54px 0 96px;position:relative;overflow:hidden}
.foot-in{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}
.foot-logos{display:flex;align-items:center;justify-content:center;gap:clamp(26px,5.5vw,56px);flex-wrap:wrap}
.foot-logos .unit{display:flex;align-items:center;gap:16px}
.foot-logos .mole{width:80px}
.foot-logos .unit b{font-family:var(--display);font-weight:900;font-size:2.36rem}
.foot-logos .eth img{height:76px}
.foot-logos .eth span{font-family:Georgia,serif;font-weight:700;font-size:2.24rem}
.foot-logos .eth span em{font-style:normal;color:var(--ethos)}
.foot-logos .vu{height:68px;opacity:.9}
.foot-div{width:1px;height:60px;background:var(--line)}
.foot-addr{font-size:.9rem;color:var(--mute);max-width:560px;line-height:1.6}
.foot-addr a{color:var(--ink-soft);font-weight:600}
.lock{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;background:rgba(22,19,31,.05);
  border:1px solid rgba(22,19,31,.14);border-radius:999px;padding:7px 14px;color:var(--ink-soft)}
.colofon{font-size:.74rem;color:var(--mute);max-width:520px;line-height:1.6}
@media(max-width:560px){.foot-div{display:none}}

/* ---------- RESPONSIVE REEKS ---------- */
@media(max-width:600px){
  .reeks{grid-template-columns:auto 1fr;gap:14px}
  .meta{grid-column:1/-1;flex-direction:row;align-items:baseline;justify-content:space-between;
    text-align:left;border-top:1px dashed var(--line);padding-top:12px;margin-top:4px}
  .price{font-size:1.24rem}.price small{display:inline;margin-left:6px}
  .proofbar .vdiv{display:none}
}
@media(prefers-reduced-motion:reduce){.hero-mole{animation:none}.totalbar{transition:none}}
.sun{display:inline-block;line-height:0;color:var(--amber)}
.sun svg{width:1em;height:1em;display:block;animation:spin 22s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.sun svg{animation:none}}

/* ============================================================
   PORTRETTEN — denkers-galerij (statisch) + bewegende fotoband
   Huisstijl Centrum Èthos: staand portret 3:3.6, gekleurde
   onderrand die rouleert. Band schuift traag, pauzeert bij
   hover, staat stil bij prefers-reduced-motion.
   ============================================================ */

/* ---- statische denkers-galerij ---- */
.eth-gallery{display:grid;grid-template-columns:repeat(7,1fr);gap:13px;margin:30px 0 6px}
@media(max-width:900px){.eth-gallery{grid-template-columns:repeat(4,1fr);gap:11px}}
@media(max-width:520px){.eth-gallery{grid-template-columns:repeat(3,1fr);gap:9px}}
.eth-gallery figure{margin:0;overflow:hidden;border-radius:5px;background:#e9e0cd;
  box-shadow:0 8px 22px rgba(22,19,31,.10)}
.eth-gallery img{width:100%;aspect-ratio:3/3.6;object-fit:cover;object-position:center 16%;
  display:block;border-bottom:5px solid var(--blue);transition:transform .45s ease}
.eth-gallery figure:hover img{transform:scale(1.06)}
.eth-gallery figure:nth-child(3n) img{border-bottom-color:var(--coral)}
.eth-gallery figure:nth-child(3n+2) img{border-bottom-color:var(--amber)}
.eth-gallery figcaption{font-family:var(--display);font-weight:600;font-size:.88rem;color:var(--ink-soft);
  text-align:center;padding:7px 2px 9px;line-height:1.15}
.gal-note{font-size:.92rem;color:var(--mute);margin:2px 0 0;max-width:var(--maxtext)}
.gal-note b{color:var(--ink-soft);font-weight:600}

/* ---- bewegende portretband ---- */
.eth-band{position:relative;overflow:hidden;background:var(--ink);
  --tile-h:clamp(150px,19vw,206px);--tile-w:calc(var(--tile-h)*.82)}
.eth-band.tall{--tile-h:clamp(176px,23vw,248px)}
.eth-band::before,.eth-band::after{content:"";position:absolute;top:0;bottom:0;
  width:clamp(38px,7vw,120px);z-index:4;pointer-events:none}
.eth-band::before{left:0;background:linear-gradient(90deg,var(--ink),rgba(22,19,31,0))}
.eth-band::after{right:0;background:linear-gradient(270deg,var(--ink),rgba(22,19,31,0))}
.eth-track{display:flex;width:max-content;animation:eth-scroll 82s linear infinite;will-change:transform}
.eth-band.rev .eth-track{animation-direction:reverse;animation-duration:96s}
.eth-band:hover .eth-track{animation-play-state:paused}
.eth-tile{position:relative;flex:none;width:var(--tile-w);height:var(--tile-h);overflow:hidden}
.eth-tile img{width:100%;height:100%;object-fit:cover;object-position:center 19%;display:block;
  border-bottom:5px solid var(--blue)}
.eth-tile:nth-child(4n) img{border-bottom-color:var(--coral)}
.eth-tile:nth-child(4n+2) img{border-bottom-color:var(--amber)}
.eth-tile:nth-child(4n+3) img{border-bottom-color:var(--green)}
.eth-tile .nm{position:absolute;left:0;right:0;bottom:5px;padding:20px 10px 8px;
  font-family:var(--ui);font-size:.74rem;font-weight:700;letter-spacing:.01em;color:#fff;line-height:1.18;
  background:linear-gradient(0deg,rgba(0,0,0,.74),rgba(0,0,0,0));opacity:0;transition:opacity .25s}
.eth-tile .nm small{display:block;font-weight:600;font-size:.66rem;color:var(--amber);
  text-transform:uppercase;letter-spacing:.08em;margin-top:1px}
.eth-tile:hover .nm{opacity:1}
.eth-news{flex:none;width:clamp(184px,23vw,260px);height:var(--tile-h);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:0 24px;color:#fff}
.eth-news .t{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;opacity:.92}
.eth-news .h{font-family:var(--display);font-weight:700;font-size:clamp(1.08rem,1.7vw,1.4rem);line-height:1.1}
.eth-news.c-blue{background:var(--blue)}
.eth-news.c-coral{background:var(--coral)}
.eth-news.c-amber{background:var(--amber);color:var(--ink)}
.eth-news.c-amber .t{opacity:.7}
.eth-news.c-green{background:var(--green)}
@keyframes eth-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .eth-track{animation:none;overflow-x:auto;scrollbar-width:none}
  .eth-track::-webkit-scrollbar{display:none}
  .eth-tile .nm{opacity:1;background:linear-gradient(0deg,rgba(0,0,0,.62),rgba(0,0,0,0))}
}

/* ============================================================
   HERO-STILL — frame uit de Ad & Govert-uitnodigingsfilm,
   rechtsboven naast de hoofdkop (vervangt de gravende mol)
   ============================================================ */
.hero-mole{display:none}            /* still neemt de rechterkant over */
@media(min-width:1000px){
  .hero-grid{display:grid;grid-template-columns:minmax(0,1.06fr) minmax(330px,.94fr);
    gap:clamp(30px,4vw,68px);align-items:start}
  .hero-grid h1.hero-h{max-width:none}
  .hero-still{margin-top:54px}      /* op kophoogte */
}
.hero-still{position:relative}
@media(max-width:999px){.hero-still{max-width:480px;margin:30px 0 2px}}
.hero-still figure{margin:0;border-radius:18px;overflow:hidden;background:var(--paper);
  border:6px solid #fff;box-shadow:0 26px 60px rgba(22,19,31,.22),0 0 0 1px var(--line);
  transform:rotate(1.4deg);transition:transform .45s cubic-bezier(.22,1,.36,1)}
.hero-still:hover figure{transform:rotate(0deg) scale(1.012)}
.hero-still img{width:100%;height:auto;display:block}
.hs-cap{display:inline-flex;align-items:center;gap:8px;margin:15px 2px 0;
  font-size:.84rem;font-weight:600;color:var(--ink-soft)}
.hs-dot{width:8px;height:8px;border-radius:50%;background:var(--coral);flex:none;
  box-shadow:0 0 0 0 var(--coral);animation:pulse 2s infinite}
@media(prefers-reduced-motion:reduce){.hero-still figure{transform:none}.hs-dot{animation:none}}

/* ============================================================
   HEADER met stappen-in-de-balk + DNW-logo + footer-DNW
   (consistent op index, kiezen, inschrijven)
   ============================================================ */
.top .steps{flex:1 1 auto;justify-content:center;padding:0;background:none;border:none;flex-wrap:nowrap;gap:7px;min-width:0}
.top .steps a,.top .steps span.st{font-size:.8rem;white-space:nowrap}
.cobrand .dnw-head{height:39px;width:auto}
.foot-logos .dnw-foot{height:74px;width:auto}
@media(max-width:1120px){.top .steps a,.top .steps span.st{font-size:.74rem}.top .steps{gap:4px}}
@media(max-width:980px){.top .steps{display:none}}
@media(max-width:760px){.cobrand .dnw-head{height:30px}.foot-logos .dnw-foot{height:60px}}

/* bovenkop (kicker) en hoofdkop dicht bij elkaar, ook in story-secties */
.story .kicker + h2{margin-top:0}

/* ---------- FILOSOFENBAND (filo-*) — overgenomen uit diepgravers.css zodat fuik.css-pagina's (colleges.html) de bewegende portretband correct tonen ---------- */
.filoband{position:relative;overflow:hidden;background:var(--ink);
  --tile-h:clamp(104px,13vw,138px);--tile-w:calc(var(--tile-h)*.82)}
.filoband::before,.filoband::after{content:"";position:absolute;top:0;bottom:0;
  width:clamp(38px,7vw,120px);z-index:4;pointer-events:none}
.filoband::before{left:0;background:linear-gradient(90deg,var(--ink),rgba(22,19,31,0))}
.filoband::after{right:0;background:linear-gradient(270deg,var(--ink),rgba(22,19,31,0))}
.filo-track{display:flex;gap:2mm;width:max-content;animation:filoscroll 63s linear infinite;will-change:transform}
.filoband:hover .filo-track{animation-play-state:paused}
.filoband.rev .filo-track{animation-direction:reverse;animation-duration:48s}
.filo-tile{position:relative;flex:none;width:var(--tile-w);height:var(--tile-h);overflow:hidden;margin:0}
.filo-tile img{width:100%;height:100%;object-fit:cover;object-position:center 19%;display:block;
  border-bottom:5px solid var(--blue)}
.filo-tile:nth-child(4n) img{border-bottom-color:var(--coral)}
.filo-tile:nth-child(4n+2) img{border-bottom-color:var(--amber)}
.filo-tile:nth-child(4n+3) img{border-bottom-color:var(--green)}
.filo-tile .nm{position:absolute;left:0;right:0;bottom:5px;padding:20px 10px 8px;
  font-family:var(--ui);font-size:.74rem;font-weight:700;color:#fff;line-height:1.18;
  background:linear-gradient(0deg,rgba(0,0,0,.74),rgba(0,0,0,0));opacity:0;transition:opacity .25s}
.filo-tile .nm small{display:block;font-weight:600;font-size:.62rem;color:var(--amber);
  text-transform:uppercase;letter-spacing:.08em;margin-top:1px}
.filo-tile:hover .nm{opacity:1}
.filo-msg{flex:none;width:clamp(230px,27vw,320px);height:var(--tile-h);
  display:flex;flex-direction:column;justify-content:center;gap:4px;padding:0 24px;color:#fff}
.filo-msg .t{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:.92}
.filo-msg .h{font-family:var(--display);font-weight:700;font-size:clamp(1.08rem,1.7vw,1.38rem);line-height:1.08}
.filo-msg.c-blue{background:var(--blue)}
.filo-msg.c-coral{background:var(--coral)}
.filo-msg.c-amber{background:var(--amber);color:var(--ink)}
.filo-msg.c-green{background:var(--green)}
a.filo-msg{text-decoration:none;transition:filter .15s}
a.filo-msg:hover{filter:brightness(1.12)}
a.filo-msg .h{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;text-decoration-color:rgba(255,255,255,.45)}
a.filo-msg.c-amber .h{text-decoration-color:rgba(22,19,31,.35)}
a.filo-msg .go{font-size:.82rem;font-weight:700;margin-top:4px;opacity:.85}
@keyframes filoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .filo-track{animation:none;overflow-x:auto;scrollbar-width:none}
  .filo-tile .nm{opacity:1;background:linear-gradient(0deg,rgba(0,0,0,.62),rgba(0,0,0,0))}
}

.filoband.tall{--tile-h:clamp(176px,23vw,248px)}
