:root{
  --ink:#2A2359;          /* diep paarsblauw — tekst & vlakken */
  --paper:#FBF7FF;        /* zacht lila-wit — achtergrond */
  --coin:#FFC93C;         /* kwartje-geel — accent & CTA */
  --coin-deep:#F5A623;    /* muntrand */
  --coral:#FF6B6B;        /* speels rood-roze */
  --mint:#3ECFA3;         /* fris groen */
  --sky:#B9C7FF;          /* licht blauwpaars */
  --card:#FFFFFF;
  --radius:22px;
  --shadow:0 10px 30px rgba(42,35,89,.10);
  --display:'Fredoka',sans-serif;
  --body:'Nunito',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
}
h1,h2,h3,.btn{font-family:var(--display)}
h2{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:600;line-height:1.15;letter-spacing:-.01em}
h3{font-weight:600}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}
section{padding:84px 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--display);font-weight:500;font-size:.85rem;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);opacity:.65;margin-bottom:14px;
}
.eyebrow::before{content:"";width:14px;height:14px;border-radius:50%;background:var(--coin);border:2px solid var(--coin-deep)}
.lead{font-size:1.12rem;max-width:56ch}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,247,255,.85);
  backdrop-filter:blur(10px);
  border-bottom:2px dashed rgba(42,35,89,.12);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;font-family:var(--display);font-weight:700;font-size:1.45rem}
.logo-coin{
  width:38px;height:38px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,#FFE28A,var(--coin) 60%);
  border:3px solid var(--coin-deep);
  display:grid;place-items:center;
  font-size:.72rem;font-weight:700;color:#7A4E00;
  box-shadow:0 3px 0 var(--coin-deep);
  transform:rotate(-8deg);
}
.nav-links{display:flex;gap:26px;list-style:none;font-weight:700;font-size:.95rem}
.nav-links a{text-decoration:none;opacity:.8;transition:opacity .2s}
.nav-links a:hover{opacity:1}

/* ---------- de switch ---------- */
.mode-switch{
  display:flex;align-items:center;
  background:var(--ink);color:#fff;
  border-radius:999px;padding:5px;gap:4px;
  position:relative;cursor:pointer;border:none;
  font-family:var(--display);font-size:.88rem;font-weight:500;
}
.mode-switch span{
  position:relative;z-index:2;padding:8px 16px;border-radius:999px;
  transition:color .25s;white-space:nowrap;
}
.mode-switch .thumb{
  position:absolute;top:5px;left:5px;height:calc(100% - 10px);
  background:var(--coin);border:2px solid var(--coin-deep);
  border-radius:999px;z-index:1;
  transition:left .3s cubic-bezier(.6,-0.2,.3,1.4),width .3s cubic-bezier(.6,-0.2,.3,1.4);
}
.mode-switch span.active{color:var(--ink)}
.mode-switch:focus-visible{outline:3px solid var(--coral);outline-offset:3px}

/* mode visibility */
[data-mode]{display:none}
body.m-leerling [data-mode="leerling"]{display:block}
body.m-geven [data-mode="geven"]{display:block}

/* ---------- hero ---------- */
.hero{padding:70px 0 90px;position:relative}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.5rem,6vw,4.1rem);font-weight:700;line-height:1.05;letter-spacing:-.02em;margin-bottom:20px}
.hero h1 .mark{
  display:inline-block;position:relative;color:var(--coral);
}
.hero h1 .mark::after{
  content:"";position:absolute;left:0;right:0;bottom:6px;height:.32em;
  background:var(--coin);z-index:-1;border-radius:4px;transform:rotate(-1.2deg);
}
.hero p{font-size:1.15rem;max-width:52ch;margin-bottom:30px}
.btn{
  display:inline-block;text-decoration:none;font-weight:600;font-size:1.02rem;
  padding:15px 30px;border-radius:999px;border:3px solid var(--ink);
  transition:transform .15s, box-shadow .15s;cursor:pointer;
}
.btn:hover{transform:translateY(-3px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--coin);color:var(--ink);box-shadow:0 5px 0 var(--ink)}
.btn-primary:hover{box-shadow:0 8px 0 var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:none;margin-left:12px}
.hero-checks{display:flex;flex-wrap:wrap;gap:8px 26px;margin-top:26px;list-style:none;padding:0}
.hero-checks li{font-size:.98rem;font-weight:700;opacity:.85}
.hero-checks li::before{content:"✔";color:var(--mint);font-weight:800;margin-right:9px}

/* --- signatuur: het kwartje valt ín de spaarpot --- */
.coin-stage{
  --maskH:284px;   /* onderkant van het 'zichtvenster' = de hoogte van de gleuf */
  --rest:134px;    /* kwartje rust op de gleuf (maskH - munthoogte) */
  --sink:290px;    /* kwartje volledig ín de spaarpot (voorbij de gleuflijn) */
  position:relative;height:380px;display:flex;align-items:flex-end;justify-content:center;
  cursor:pointer;
}
.coin-mask{position:absolute;left:0;right:0;top:0;height:var(--maskH);overflow:hidden;pointer-events:none}
.big-coin{
  width:150px;height:150px;border-radius:50%;
  background:radial-gradient(circle at 32% 28%,#FFE9A8,var(--coin) 55%,var(--coin-deep));
  border:6px solid var(--coin-deep);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  font-family:var(--display);font-weight:700;font-size:1.3rem;color:#7A4E00;
  text-align:center;line-height:1.15;
  position:absolute;left:50%;transform:translateX(-50%);
  top:-190px;
}
.big-coin small{display:block;font-size:.6rem;font-weight:500;letter-spacing:.1em}
.coin-stage.drop .big-coin{animation:coindrop 1.7s cubic-bezier(.5,0,.5,1) forwards}
@keyframes coindrop{
  0%{top:-190px;transform:translateX(-50%) rotate(-20deg)}
  46%{top:var(--rest);transform:translateX(-50%) rotate(4deg)}
  57%{top:calc(var(--rest) - 16px);transform:translateX(-50%) rotate(-2deg)}
  68%{top:var(--rest);transform:translateX(-50%) rotate(0deg)}
  82%{top:var(--rest);transform:translateX(-50%) rotate(0deg)}
  100%{top:var(--sink);transform:translateX(-50%) rotate(0deg)}
}
.slot{
  width:250px;height:120px;border-radius:26px;
  background:var(--ink);position:relative;
  box-shadow:var(--shadow);
}
.slot::before{
  content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:170px;height:12px;border-radius:8px;background:var(--paper);opacity:.25;
}
.coin-stage.drop .slot{animation:gulp .5s ease 1.62s}
@keyframes gulp{
  0%,100%{transform:none}
  35%{transform:translateY(3px) scale(1.03,.96)}
  70%{transform:scale(.99,1.02)}
}
.slot::after{
  content:"pling! ✨";position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  font-family:var(--display);color:var(--coin);font-size:1rem;opacity:0;
}
.coin-stage.drop .slot::after{animation:pling .6s ease 1.85s forwards}
@keyframes pling{to{opacity:1;transform:translateX(-50%) translateY(-4px)}}
.doodle{position:absolute;border-radius:50%;opacity:.5;pointer-events:none}
.d1{width:26px;height:26px;background:var(--coral);top:8%;left:6%}
.d2{width:16px;height:16px;background:var(--mint);top:22%;right:10%}
.d3{width:34px;height:34px;background:var(--sky);bottom:14%;left:2%}

/* ---------- ticker ---------- */
.ticker{
  background:var(--ink);color:var(--paper);
  padding:14px 0;overflow:hidden;white-space:nowrap;
  font-family:var(--display);font-weight:500;font-size:1rem;
  transform:rotate(-1deg);margin:0 -10px;
}
.ticker-track{display:inline-block;animation:scroll 26s linear infinite}
.ticker span{margin:0 26px}
.ticker .c{color:var(--coin)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- cards / grids ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}
.card{
  background:var(--card);border:3px solid var(--ink);border-radius:var(--radius);
  padding:30px 26px;box-shadow:6px 6px 0 var(--sky);
  transition:transform .18s, box-shadow .18s;
}
.card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--sky)}
.card .emoji{font-size:2.1rem;display:inline-block;margin-bottom:12px}
.card h3{font-size:1.25rem;margin-bottom:8px}
.card p{font-size:.98rem;opacity:.85}

/* ---------- leren leren ---------- */
.ll{background:var(--ink);color:var(--paper);border-radius:40px;margin:0 14px}
.ll .eyebrow{color:var(--coin);opacity:1}
.ll .eyebrow::before{background:var(--coral);border-color:#d94f4f}
.ll h2 .mark2{color:var(--coin)}
.ll .card{background:#332B6E;border-color:var(--coin);box-shadow:6px 6px 0 rgba(255,201,60,.28);color:var(--paper)}
.ll .card:hover{box-shadow:9px 9px 0 rgba(255,201,60,.28)}
.ll .card p{opacity:.8}
.ll .lead{opacity:.9}

/* ---------- pakketten ---------- */
.price-card{position:relative;text-align:left;display:flex;flex-direction:column;padding-top:34px}
.price-card.featured{background:var(--coin);box-shadow:6px 6px 0 var(--coral)}
.price-card.featured:hover{box-shadow:9px 9px 0 var(--coral)}
.price-card .voorwie{font-size:.92rem;opacity:.75;min-height:3.2em;margin-top:4px}
.tag{
  position:absolute;top:-16px;right:18px;background:var(--coral);color:#fff;
  font-family:var(--display);font-weight:600;font-size:.8rem;
  padding:5px 14px;border-radius:999px;border:2px solid var(--ink);
  transform:rotate(3deg);
}
.save{
  display:inline-block;background:var(--mint);color:var(--ink);
  font-family:var(--display);font-weight:600;font-size:.8rem;
  padding:4px 12px;border-radius:999px;border:2px solid var(--ink);
  margin-left:10px;vertical-align:middle;
}
.price-row{display:flex;align-items:baseline;gap:10px;margin:16px 0 2px;flex-wrap:wrap}
.price{font-family:var(--display);font-size:2.7rem;font-weight:700;line-height:1}
.price small{font-size:1rem;font-weight:500;opacity:.7}
.was{font-family:var(--display);font-size:1.15rem;opacity:.55;text-decoration:line-through;text-decoration-color:var(--coral);text-decoration-thickness:2.5px}
.per{font-size:.9rem;opacity:.75;margin-bottom:18px}
.price-card ul{list-style:none;margin:0 0 26px;flex:1}
.price-card li{padding:7px 0;font-size:.96rem;border-bottom:1.5px dashed rgba(42,35,89,.18)}
.price-card li::before{content:"✔";margin-right:10px;color:var(--mint);font-weight:800}
.price-card li.plus{font-family:var(--display);font-weight:500;font-size:.85rem;opacity:.7;border-bottom:none;padding-bottom:2px}
.price-card li.plus::before{content:"↳";color:var(--coral)}
.price-card.featured li::before{color:var(--ink)}
.price-card.featured li.plus::before{color:var(--coral)}
.price-note{margin-top:26px;font-size:.92rem;opacity:.75;text-align:center}
.pak-extra{
  margin-top:34px;background:#fff;border:3px dashed var(--ink);border-radius:var(--radius);
  padding:22px 28px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between;
}
.pak-extra p{margin:0;max-width:60ch}
.pak-extra strong{font-family:var(--display)}

/* ---------- formulier ---------- */
.form-card{
  background:#fff;border:3px solid var(--ink);border-radius:26px;
  padding:34px 30px;margin-top:34px;text-align:left;box-shadow:6px 6px 0 rgba(42,35,89,.25);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--display);font-weight:600;font-size:.92rem}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:2.5px solid var(--ink);border-radius:14px;
  padding:12px 14px;width:100%;transition:box-shadow .15s,transform .15s;
}
.field textarea{resize:vertical;min-height:90px}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;box-shadow:3px 3px 0 var(--coin);transform:translate(-1px,-1px);
}
.form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;align-items:center}
.form-hint{font-size:.85rem;opacity:.7;margin-top:14px}
.btn-wa{background:#25D366;color:var(--ink);box-shadow:0 5px 0 var(--ink)}
.btn-wa:hover{box-shadow:0 8px 0 var(--ink)}
.field .err{display:none;color:var(--coral);font-weight:700;font-size:.85rem}
.field.invalid input{border-color:var(--coral);box-shadow:3px 3px 0 var(--coral)}
.field.invalid .err{display:block}

/* ---------- vakken ---------- */
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}
.chip{
  font-family:var(--display);font-weight:500;font-size:1rem;
  background:#fff;border:2.5px solid var(--ink);border-radius:999px;padding:9px 20px;
}
.chip:nth-child(4n+1){box-shadow:3px 3px 0 var(--coin)}
.chip:nth-child(4n+2){box-shadow:3px 3px 0 var(--coral)}
.chip:nth-child(4n+3){box-shadow:3px 3px 0 var(--mint)}
.chip:nth-child(4n+4){box-shadow:3px 3px 0 var(--sky)}

/* ---------- geven-mode ---------- */
.perk-num{
  font-family:var(--display);font-weight:700;font-size:1rem;color:#7A4E00;
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 32% 30%,#FFE28A,var(--coin) 60%);
  border:3px solid var(--coin-deep);margin-bottom:14px;
}

/* ---------- steden / gebied ---------- */
.area{background:#fff;border-top:3px dashed rgba(42,35,89,.15);border-bottom:3px dashed rgba(42,35,89,.15)}
.area .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.map-blob{
  background:var(--sky);border:3px solid var(--ink);border-radius:46% 54% 60% 40%/50% 42% 58% 50%;
  padding:44px 34px;box-shadow:8px 8px 0 var(--coin);
  font-family:var(--display);font-weight:500;text-align:center;
}
.map-blob strong{display:block;font-size:1.3rem;margin-bottom:6px}

/* ---------- FAQ ---------- */
details{
  background:#fff;border:3px solid var(--ink);border-radius:18px;
  padding:18px 22px;margin-bottom:14px;box-shadow:4px 4px 0 var(--sky);
}
summary{font-family:var(--display);font-weight:600;font-size:1.05rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
summary::after{content:"+";font-size:1.5rem;color:var(--coral);transition:transform .2s}
details[open] summary::after{transform:rotate(45deg)}
details p{margin-top:12px;opacity:.85}

/* ---------- contact ---------- */
.contact-box{
  background:var(--coin);border:3px solid var(--ink);border-radius:34px;
  padding:56px 40px;text-align:center;box-shadow:8px 8px 0 var(--ink);
}
.contact-box h2{margin-bottom:12px}
.contact-box p{max-width:50ch;margin:0 auto 28px}
.btn-dark{background:var(--ink);color:var(--coin);box-shadow:0 5px 0 #171240}
.btn-dark:hover{box-shadow:0 8px 0 #171240}

/* ---------- subtiele animaties ---------- */
.reveal{transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.3,1)}
.reveal:not(.in){opacity:0;transform:translateY(26px)}

.doodle{animation:bob 5s ease-in-out infinite}
.d2{animation-duration:6.5s;animation-delay:-2s}
.d3{animation-duration:7.5s;animation-delay:-4s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.logo-coin{transition:transform .35s cubic-bezier(.3,1.6,.5,1)}
.logo:hover .logo-coin{transform:rotate(8deg) scale(1.12)}

.card .emoji{transition:transform .3s cubic-bezier(.3,1.8,.5,1)}
.card:hover .emoji{transform:rotate(-8deg) scale(1.18)}
.perk-num{transition:transform .3s cubic-bezier(.3,1.8,.5,1)}
.card:hover .perk-num{transform:rotate(-8deg) scale(1.1)}

.chip{transition:transform .18s,box-shadow .18s}
.chip:hover{transform:translate(-2px,-3px) rotate(-1deg)}

.tag{animation:swing 3.5s ease-in-out infinite;transform-origin:top center}
@keyframes swing{0%,100%{transform:rotate(3deg)}50%{transform:rotate(-2deg)}}

.hero h1 .mark::after{transform-origin:left center;animation:markdraw .7s ease .5s backwards}
@keyframes markdraw{from{transform:scaleX(0) rotate(-1.2deg)}to{transform:scaleX(1) rotate(-1.2deg)}}

.contact-box .btn:hover{transform:translateY(-3px) rotate(-1deg)}

footer{padding:44px 0 60px;text-align:center;font-size:.92rem;opacity:.75}
footer .logo{justify-content:center;margin-bottom:10px}

/* ---------- extra speelsheid (subtiel) ---------- */
/* hero-tekst komt trapsgewijs binnen */
.hero .eyebrow{animation:fadeup .7s ease 0s backwards}
.hero h1{animation:fadeup .7s ease .08s backwards}
.hero p{animation:fadeup .7s ease .18s backwards}
.hero .btn-primary{animation:fadeup .7s ease .28s backwards}
.hero .btn-ghost{animation:fadeup .7s ease .36s backwards}
.hero .hero-checks{animation:fadeup .7s ease .46s backwards}
@keyframes fadeup{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* logo-munt flipt binnen bij het laden */
.logo-coin{animation:flipin .7s cubic-bezier(.3,1.6,.5,1) .15s backwards}
@keyframes flipin{from{transform:rotate(-8deg) scale(0)}to{transform:rotate(-8deg) scale(1)}}

/* 'leren' in de donkere sectie krijgt een onderstreep zodra 'ie in beeld komt */
.ll h2 .mark2{position:relative;display:inline-block;z-index:0}
.ll h2 .mark2::after{
  content:"";position:absolute;left:0;right:0;bottom:4px;height:.3em;
  background:var(--coral);z-index:-1;border-radius:4px;
  transform:scaleX(0) rotate(-1.2deg);transform-origin:left center;
}
.ll h2.in .mark2::after{animation:markdraw .6s ease .35s forwards}

/* FAQ-antwoorden schuiven zacht open */
details[open] p{animation:fadeslide .4s ease}
@keyframes fadeslide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ticker pauzeert als je eroverheen zweeft */
.ticker:hover .ticker-track{animation-play-state:paused}

/* chips floepen met een overshoot in beeld */
.chip.reveal{transition:opacity .55s ease,transform .55s cubic-bezier(.3,1.6,.4,1)}
.chip.reveal:not(.in){transform:translateY(20px) scale(.85) rotate(-2deg)}

/* de kaart-blob golft langzaam van vorm */
.map-blob{animation:blobmorph 9s ease-in-out infinite}
@keyframes blobmorph{
  0%,100%{border-radius:46% 54% 60% 40%/50% 42% 58% 50%}
  50%{border-radius:56% 44% 46% 54%/44% 56% 46% 54%}
}

/* ---------- eenvoudige pagina's (bedankt / privacy / voorwaarden) ---------- */
.simple-page{padding:70px 0 100px}
.simple-page .wrap{max-width:760px}
.simple-page h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:18px}
.simple-page h2{font-size:1.4rem;margin:34px 0 12px}
.simple-page p{margin-bottom:14px}
.simple-page ul{margin:0 0 14px 22px}
.simple-page li{margin-bottom:6px}
.thanks-box{
  background:#fff;border:3px solid var(--ink);border-radius:var(--radius);
  padding:44px 36px;box-shadow:6px 6px 0 var(--coin);text-align:center;
}
.thanks-box .big-emoji{font-size:3rem;display:block;margin-bottom:16px}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .grid3,.grid4{grid-template-columns:repeat(2,1fr)}
  .hero .wrap{grid-template-columns:1fr}
  .coin-stage{--maskH:204px;--rest:54px;--sink:210px;height:300px;margin-top:10px}
  .area .wrap{grid-template-columns:1fr}
  .nav-links{display:none}
}
@media(max-width:560px){
  .grid3,.grid4{grid-template-columns:1fr}
  section{padding:60px 0}
  .nav{flex-wrap:wrap;justify-content:center;gap:10px}
  .mode-switch span{padding:8px 10px;font-size:.78rem}
  .btn-ghost{margin-left:0;margin-top:10px}
  .form-grid{grid-template-columns:1fr}
  .pak-extra{justify-content:center;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .big-coin{top:var(--rest)}
  .slot::after{opacity:1}
  .coin-stage{cursor:default}
}
