/* handboeken.be (2026) — stylesheet
   Premium editorial: donkere hero → heldere body. Cover-kleuren oranje/blauw. */

:root{
  --navy:#0C1F36; --navy-2:#0A1A2F; --navy-deep:#06111F;
  --accent:#eb8f3f; --accent-bright:#F2A35E; --accent-deep:#B5651D;
  --blue:#0092c9; --blue-deep:#0177a3;
  --cream:#F8F3EA; --cream-2:#EFE7D7; --warm-white:#F4EFE4;
  --ink:#1C2A3A; --muted:#69788C; --muted-d:rgba(244,239,228,.66);
  --line:rgba(17,37,63,.12); --line-d:rgba(244,239,228,.16);
  --font-display:'Cormorant',Georgia,serif;
  --font-sans:'DM Sans',system-ui,-apple-system,sans-serif;
  --radius:14px; --shadow:0 24px 60px -28px rgba(8,18,32,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important} /* zodat het hidden-attribuut altijd wint van display:flex e.d. */
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(22px,5vw,68px)}
.skip{position:absolute;left:-9999px}
.skip:focus{left:16px;top:10px;z-index:200;background:#fff;color:var(--navy);padding:10px 16px;border-radius:8px}
main{display:block}

/* ── Knoppen ─────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:10px;cursor:pointer;transition:.22s;font-family:var(--font-sans);
  font-weight:600;font-size:.95rem;border-radius:999px;border:1px solid transparent;text-align:center}
.btn svg{width:16px;height:16px;transition:transform .22s}
.btn-primary{background:var(--navy);color:var(--cream);padding:13px 26px}
.btn-primary:hover{background:var(--accent);color:var(--navy-deep);transform:translateY(-2px)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy);padding:12px 24px}
.btn-outline:hover{background:var(--navy);color:var(--cream)}
.btn-sm{padding:9px 18px;font-size:.86rem}
.btn-pill-dark{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--warm-white);
  border:1px solid rgba(244,239,228,.45);border-radius:999px;padding:16px 32px}
.btn-pill-dark:hover{background:var(--accent);border-color:var(--accent);color:var(--navy-deep);transform:translateY(-2px)}
.btn-pill-dark:hover svg{transform:translateX(4px)}

/* ── Navigatie (donker, sticky) ──────── */
header.nav{position:sticky;top:0;z-index:50;background:rgba(8,18,32,.72);
  backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--line-d)}
header.nav.scrolled{background:rgba(7,15,28,.92)}
.nav-in{display:flex;align-items:center;gap:28px;height:74px;color:var(--warm-white)}
.logo{display:inline-flex;flex-direction:column;gap:1px;line-height:1.04}
.logo .wm{font-family:var(--font-sans);font-weight:700;font-size:1.3rem;letter-spacing:.14em;text-transform:uppercase}
.logo .dot{color:var(--accent);font-weight:500}
.logo-tag{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:.86rem;color:var(--accent-bright);text-transform:none;letter-spacing:.01em}
nav.menu{margin:0 auto;display:flex;gap:28px}
nav.menu a{font-size:.74rem;text-transform:uppercase;letter-spacing:.15em;color:var(--warm-white);opacity:.8;
  position:relative;padding:8px 0;transition:opacity .2s}
nav.menu a:hover,nav.menu a.actief{opacity:1}
nav.menu a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--accent);transition:right .25s}
nav.menu a:hover::after,nav.menu a.actief::after{right:0}
.nav-ico{display:flex;gap:18px;align-items:center}
.nav-ico a{display:flex;opacity:.85;transition:.2s;position:relative}
.nav-ico a:hover{opacity:1;color:var(--accent-bright)}
.nav-ico svg{width:20px;height:20px}
.cart .b{position:absolute;top:-7px;right:-9px;background:var(--accent);color:var(--navy-deep);font-size:.6rem;
  font-weight:700;min-width:15px;height:15px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 3px}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:var(--warm-white);transition:.25s}
.mobielmenu{display:none;flex-direction:column;background:var(--navy-deep);border-bottom:1px solid var(--line-d)}
.mobielmenu a{padding:14px 24px;color:var(--warm-white);font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;border-top:1px solid var(--line-d)}

/* ── Hero (donker) ───────────────────── */
.hero{position:relative;overflow:hidden;user-select:none;-webkit-user-select:none;
  background:radial-gradient(125% 90% at 50% -10%, #18365a 0%, #0d2138 42%, #081626 78%, #060f1c 100%)}
.hero .glow,.hero .atmos{position:absolute;pointer-events:none}
.hero .glow{inset:0;background:radial-gradient(38% 46% at 72% 54%, rgba(235,143,63,.18), transparent 70%),radial-gradient(42% 50% at 16% 8%, rgba(0,146,201,.10), transparent 72%)}
.hero .atmos{left:0;right:0;bottom:0;height:46%}
.hero-in{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  min-height:calc(100vh - 74px);padding-top:38px;padding-bottom:64px}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.2em;color:var(--accent-bright);margin-bottom:22px}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--accent)}
.eyebrow .ey-w{color:var(--warm-white)}
.eyebrow .ey-o{color:var(--accent)}
.eyebrow .ey-b{color:var(--blue)}
h1.slogan{font-family:var(--font-display);font-weight:500;font-style:italic;color:var(--warm-white);
  font-size:clamp(2.6rem,4.4vw,4rem);line-height:1.04;letter-spacing:.5px;margin-bottom:22px}
h1.slogan .g{color:var(--accent-bright)}
.lead{font-size:1.06rem;color:var(--muted-d);max-width:46ch;margin-bottom:32px}
.specs{display:flex;align-items:stretch;gap:28px;margin-bottom:36px;flex-wrap:wrap}
.price{display:flex;flex-direction:column;gap:4px}
.price .lab,.fact .l{font-size:.68rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted-d)}
.price .now{font-family:var(--font-display);font-weight:600;font-size:2.6rem;color:var(--warm-white);line-height:1;display:flex;align-items:center;gap:12px}
.price .now .promo{font-family:var(--font-sans);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--navy-deep);background:var(--accent);padding:4px 9px;border-radius:6px}
.price .was{font-size:.9rem;color:var(--muted-d)}
.vrule{width:1px;background:var(--line-d)}
.fact{display:flex;flex-direction:column;justify-content:center;gap:5px}
.fact .n{font-family:var(--font-display);font-weight:600;font-size:1.85rem;color:var(--blue);line-height:1}
.hero .cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.hero .ghost{color:var(--warm-white);font-size:.92rem;opacity:.82;border-bottom:1px solid rgba(244,239,228,.4);padding-bottom:3px}
.hero .ghost:hover{opacity:1;color:var(--blue);border-color:var(--blue)}

/* ── 3D-boek ─────────────────────────── */
.stage-col{display:flex;flex-direction:column;justify-content:center;align-items:center}
.stage{width:380px;height:560px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;touch-action:none}
.floor{position:absolute;bottom:74px;left:50%;width:300px;height:46px;transform:translateX(-50%);border-radius:50%;background:radial-gradient(closest-side,rgba(0,0,0,.6),transparent 72%);filter:blur(3px)}
.scene{perspective:1750px;transition:transform .22s ease-out;-webkit-box-reflect:below 14px linear-gradient(transparent 58%, rgba(255,255,255,.13))}
.book{position:relative;width:300px;height:474px;transform-style:preserve-3d;transform:rotateX(-9deg) rotateY(29deg);cursor:grab;will-change:transform}
.book.grabbing{cursor:grabbing}
.face{position:absolute;top:50%;left:50%;overflow:hidden;backface-visibility:hidden;box-shadow:inset 0 0 0 1px rgba(0,0,0,.14)}
.face img{width:100%;height:100%;object-fit:cover;-webkit-user-drag:none;user-select:none;pointer-events:none}
.f-front,.f-back{width:300px;height:474px}
.f-front{border-radius:2px 7px 7px 2px;transform:translate(-50%,-50%) translateZ(16px)}
.f-back{border-radius:7px 2px 2px 7px;transform:translate(-50%,-50%) rotateY(180deg) translateZ(16px)}
.f-spine{width:32px;height:474px;transform:translate(-50%,-50%) rotateY(-90deg) translateZ(150px)}
.f-pages{width:32px;height:474px;transform:translate(-50%,-50%) rotateY(90deg) translateZ(150px);background:repeating-linear-gradient(to right,#fafafa 0 1px,#d6d6d6 1px 2px)}
.f-top{width:300px;height:32px;transform:translate(-50%,-50%) rotateX(90deg) translateZ(237px);background:repeating-linear-gradient(to bottom,#fafafa 0 1px,#d6d6d6 1px 2px)}
.f-bot{width:300px;height:32px;transform:translate(-50%,-50%) rotateX(-90deg) translateZ(237px);background:repeating-linear-gradient(to bottom,#fafafa 0 1px,#d6d6d6 1px 2px)}
.hint{margin-top:12px;display:inline-flex;align-items:center;gap:8px;font-size:.76rem;color:var(--muted-d);background:rgba(255,255,255,.06);border:1px solid var(--line-d);border-radius:999px;padding:7px 15px;white-space:nowrap}
.hint svg{width:15px;height:15px}
.hint.hide{opacity:0;transition:opacity .5s;pointer-events:none}

/* ── USP-strip (licht) ───────────────── */
.below{background:var(--cream);color:var(--ink)}
.usps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:28px 0;border-bottom:1px solid var(--line)}
.usp{display:flex;align-items:flex-start;gap:13px;padding:6px 24px;border-right:1px solid var(--line)}
.usp:last-child{border-right:none}
.usp svg{width:26px;height:26px;color:var(--blue-deep);flex:none;margin-top:2px;stroke-width:1.4}
.usp b{display:block;font-size:.9rem;color:var(--navy);font-weight:600;margin-bottom:2px}
.usp span{font-size:.8rem;color:var(--muted)}

/* ── Secties ─────────────────────────── */
.sectie{padding:clamp(48px,7vw,88px) 0}
.sectie-kop{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.sectie-kop .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--accent-deep);font-weight:600}
.sectie-kop h2{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,3.6vw,2.9rem);color:var(--navy);line-height:1.1;margin-top:8px}
.sectie-kop p{color:var(--muted);max-width:52ch;margin-top:6px}

/* Boekenkaarten — in de kijker */
.boeken-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}
.boek-kaart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.25s;box-shadow:0 1px 2px rgba(8,18,32,.04)}
.boek-kaart:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(17,37,63,.18)}
.boek-cover{position:relative;background:linear-gradient(160deg,#16304f,#0c1f36);padding:32px;display:flex;justify-content:center;align-items:center;min-height:330px}
.boek-cover>img{width:auto;max-height:256px;border-radius:3px 7px 7px 3px;box-shadow:0 18px 36px -14px rgba(0,0,0,.6);transition:transform .3s}
.boek-kaart:hover .boek-cover>img{transform:translateY(-6px)}
/* mini 3D-boek met zichtbare rug (Onze titels) */
.boek3d{position:relative;perspective:1000px;width:172px;height:264px;display:flex;align-items:center;justify-content:center}
.boek3d::after{content:"";position:absolute;bottom:6px;left:50%;width:120px;height:16px;transform:translateX(-50%);background:radial-gradient(closest-side,rgba(0,0,0,.55),transparent 75%);filter:blur(3px)}
.boek3d .b3{position:relative;width:166px;height:258px;transform-style:preserve-3d;transform:rotateX(3deg) rotateY(26deg);transition:transform .45s cubic-bezier(.22,1,.36,1)}
.boek-kaart:hover .boek3d .b3{transform:rotateX(3deg) rotateY(17deg)}
.boek3d .f{position:absolute;top:50%;left:50%;overflow:hidden;backface-visibility:hidden}
.boek3d .f img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none}
.boek3d .voor{width:166px;height:258px;border-radius:1px 5px 5px 1px;transform:translate(-50%,-50%) translateZ(9px);box-shadow:inset 0 0 0 1px rgba(0,0,0,.18)}
.boek3d .rug{width:18px;height:258px;transform:translate(-50%,-50%) rotateY(-90deg) translateZ(83px)}
.boek3d .snede{width:18px;height:258px;transform:translate(-50%,-50%) rotateY(90deg) translateZ(83px);background:repeating-linear-gradient(to right,#fafafa 0 1px,#d6d6d6 1px 2px)}
.boek3d .boven{width:166px;height:18px;transform:translate(-50%,-50%) rotateX(90deg) translateZ(129px);background:repeating-linear-gradient(to bottom,#fafafa 0 1px,#d6d6d6 1px 2px)}
.badge{position:absolute;top:16px;left:16px;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.badge-bestseller{background:var(--accent);color:var(--navy-deep)}
.badge-binnenkort{background:var(--blue);color:#fff}
.badge-info{background:var(--cream-2);color:var(--accent-deep)}
.boek-body{padding:22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.boek-cat{font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent-deep);font-weight:600}
.boek-titel{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--navy);line-height:1.1}
.boek-sub{font-size:.92rem;color:var(--muted);font-style:italic;margin-top:-2px}
.boek-kort{font-size:.88rem;color:var(--ink);opacity:.85;margin-top:4px}
.boek-meta{margin-top:auto;display:flex;align-items:baseline;gap:10px;padding-top:14px}
.boek-prijs{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--navy)}
.boek-prijs-was{font-size:.85rem;color:var(--muted);text-decoration:line-through}
.boek-pag{font-size:.78rem;color:var(--muted);margin-left:auto}
.boek-acties{display:flex;gap:10px;padding:0 24px 22px}
.boek-acties .btn{flex:1;justify-content:center}

/* Verouderde boeken — compacte lijst */
.oud-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;margin-top:8px}
.oud-kaart{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px}
.oud-kaart img{width:64px;height:auto;border-radius:3px;box-shadow:0 6px 14px -6px rgba(0,0,0,.4);flex:none}
.oud-kaart h3{font-family:var(--font-display);font-size:1.15rem;color:var(--navy);font-weight:600;line-height:1.1}
.oud-kaart p{font-size:.78rem;color:var(--muted);margin-top:3px}

/* ── Scholenblok (donker) ────────────── */
.scholen{background:var(--navy);color:var(--warm-white);padding:clamp(54px,7vw,90px) 0}
.scholen-in{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.scholen .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.2em;color:var(--accent-bright);font-weight:600}
.scholen h2{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,3.4vw,2.8rem);margin:10px 0 16px;line-height:1.1}
.scholen p{color:var(--muted-d);margin-bottom:26px;max-width:48ch}
.scholen .cta{display:flex;gap:16px;flex-wrap:wrap}
.scholen .btn-outline{color:var(--warm-white);border-color:rgba(244,239,228,.5)}
.scholen .btn-outline:hover{background:var(--warm-white);color:var(--navy)}
.voordelen{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.voordeel{background:rgba(255,255,255,.05);border:1px solid var(--line-d);border-radius:12px;padding:20px}
.voordeel svg{width:24px;height:24px;color:var(--accent-bright);stroke-width:1.5;margin-bottom:10px}
.voordeel b{display:block;font-size:.92rem;margin-bottom:3px}
.voordeel span{font-size:.8rem;color:var(--muted-d)}

/* ── Footer ──────────────────────────── */
.site-footer{background:var(--navy-deep);color:var(--muted-d)}
.footer-in{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:60px 0 40px}
.footer-in .logo{color:var(--warm-white);margin-bottom:14px;display:inline-flex;flex-direction:column;gap:1px}
.footer-tag{font-family:var(--font-display);font-style:italic;font-size:1.2rem;color:var(--accent-bright)}
.footer-col h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--warm-white);margin-bottom:14px}
.footer-col a,.footer-col p{display:block;font-size:.88rem;color:var(--muted-d);margin-bottom:9px;transition:.2s}
.footer-col a:hover{color:var(--accent-bright)}
.footer-bot{border-top:1px solid var(--line-d);padding:20px 0;font-size:.78rem;color:rgba(244,239,228,.5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ── Boekdetail (boek.php) ───────────── */
.detail{padding:clamp(34px,5vw,60px) 0 clamp(44px,6vw,76px)}
.crumb{font-size:.78rem;color:var(--muted);margin-bottom:24px}
.crumb a{color:var(--accent-deep)}
.crumb a:hover{text-decoration:underline}
.detail-grid{display:grid;grid-template-columns:340px minmax(0,560px);gap:clamp(20px,2.4vw,36px);justify-content:center;align-items:start}
.detail-visual{display:flex;justify-content:flex-end;align-items:flex-start;min-width:0}
.detail-visual .floor{display:none}
.detail-visual .stage{width:320px;height:500px}
.detail-visual .flat{display:flex;justify-content:center}
.detail-visual .flat img{max-height:440px;width:auto;border-radius:3px 8px 8px 3px;box-shadow:0 26px 52px -20px rgba(8,18,32,.5)}
.detail-info .eyebrow{margin-bottom:16px}
.detail-titel{font-family:var(--font-display);font-weight:600;font-size:clamp(2.1rem,4vw,3rem);color:var(--navy);line-height:1.05}
.detail-sub{font-family:var(--font-display);font-style:italic;font-size:1.3rem;color:var(--muted);margin-top:2px}
.detail-intro{font-size:1.05rem;color:var(--ink);margin:20px 0 24px;max-width:60ch}
.detail-prijs{display:flex;align-items:baseline;gap:12px;margin-bottom:6px}
.detail-prijs .nu{font-family:var(--font-display);font-weight:700;font-size:2.2rem;color:var(--navy)}
.detail-prijs .was{font-size:1rem;color:var(--muted);text-decoration:line-through}
.detail-prijs .promo{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-deep);background:var(--accent);padding:4px 9px;border-radius:6px}
.detail-koop{font-size:.82rem;color:var(--muted);margin-bottom:20px}
.detail-acties{display:flex;gap:14px;flex-wrap:wrap}
.detail-note{margin:6px 0 18px;font-size:.95rem;color:var(--accent-deep);font-weight:500}
.specs-lijst{margin-top:28px;border-top:1px solid var(--line)}
.specs-lijst div{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.specs-lijst dt{color:var(--muted)}
.specs-lijst dd{color:var(--navy);font-weight:500;text-align:right;margin:0}
.leer{background:var(--cream-2);padding:clamp(44px,6vw,72px) 0}
.leer-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 36px;margin-top:4px;padding:0}
.leer-grid li{list-style:none;display:flex;gap:12px;font-size:.95rem;color:var(--ink);padding:6px 0}
.leer-grid li::before{content:"";flex:none;width:22px;height:22px;border-radius:50%;background:var(--blue);margin-top:1px;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/%3E%3C/svg%3E") center/14px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/%3E%3C/svg%3E") center/14px no-repeat}
.online-blok{margin-top:34px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 26px;display:flex;gap:18px;align-items:center}
.online-blok svg{width:34px;height:34px;color:var(--blue-deep);flex:none;stroke-width:1.4}
.online-blok b{color:var(--navy)}
.online-blok p{font-size:.9rem;color:var(--muted);margin-top:2px;max-width:60ch}

/* tabbladen */
.tabs-sectie{padding:0 0 clamp(48px,6vw,84px)}
.tablist{display:flex;gap:4px;border-bottom:1px solid var(--line);overflow-x:auto;scrollbar-width:none}
.tablist::-webkit-scrollbar{display:none}
.tab{appearance:none;background:none;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;padding:15px 20px;
  font-family:var(--font-sans);font-size:.95rem;font-weight:500;color:var(--muted);cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s}
.tab:hover{color:var(--navy)}
.tab[aria-selected="true"]{color:var(--navy);font-weight:600;border-bottom-color:var(--accent)}
.tab:focus-visible{outline:2px solid var(--blue);outline-offset:-2px;border-radius:6px 6px 0 0}
.tabpanel{padding-top:36px;animation:tabfade .25s ease}
.tabpanel[hidden]{display:none}
@keyframes tabfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.tabpanel h3{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--navy);margin:0 0 12px}
.tabpanel>p{max-width:70ch;margin-bottom:14px;color:var(--ink)}
.tab-lijst{margin:6px 0 20px;padding:0}
.tab-lijst li{list-style:none;display:flex;gap:10px;padding:5px 0;font-size:.94rem;color:var(--ink)}
.tab-lijst li::before{content:"";flex:none;width:20px;height:20px;border-radius:50%;background:var(--blue);margin-top:1px;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/%3E%3C/svg%3E") center/13px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/%3E%3C/svg%3E") center/13px no-repeat}
.tab-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.bestel-blok{display:flex;flex-wrap:wrap;align-items:center;gap:24px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 28px;max-width:640px}
.bestel-blok .prijs{font-family:var(--font-display);font-weight:700;font-size:2rem;color:var(--navy);line-height:1}
.bestel-blok .prijs small{display:block;font-family:var(--font-sans);font-size:.78rem;font-weight:400;color:var(--muted);margin-top:4px}
.perk-rij{display:flex;gap:22px;flex-wrap:wrap;margin-top:20px}
.perk{display:flex;align-items:center;gap:9px;font-size:.86rem;color:var(--muted)}
.perk svg{width:20px;height:20px;color:var(--blue-deep);stroke-width:1.5;flex:none}

/* flipbook (Doorbladeren) */
.flipbook-wrap{max-width:860px;margin:6px 0 0}
.flipbook-wrap iframe{width:100%;aspect-ratio:812/720;border:0;border-radius:var(--radius);background:#0a1a2f;display:block;box-shadow:var(--shadow)}
.flipbook-note{margin-top:14px;font-size:.86rem;color:var(--muted)}
.flipbook-note a{color:var(--accent-deep);font-weight:500}
.knop-uitleg{list-style:none;margin:8px 0 16px;padding:0;display:flex;flex-direction:column;gap:12px}
.knop-uitleg li{display:flex;gap:14px;align-items:center}
.knop-uitleg .kb{flex:none;width:40px;height:40px;border-radius:10px;background:var(--navy);color:var(--warm-white);display:flex;align-items:center;justify-content:center}
.knop-uitleg .kb svg{width:21px;height:21px;stroke-width:1.6}
.knop-uitleg .ku{font-size:.94rem;color:var(--ink)}
.knop-uitleg .ku strong{color:var(--navy)}

/* klikbare extra-items */
button.item,a.item{appearance:none;font:inherit;color:inherit;text-align:left;width:100%;cursor:pointer}
button.item:hover,a.item:hover{border-color:var(--blue);box-shadow:0 8px 20px -12px rgba(8,18,32,.35)}
.item .pijl{margin-left:auto;color:var(--muted);flex:none}
.item .pijl svg{width:18px;height:18px}

/* lightbox */
.lb-overlay{position:fixed;inset:0;background:rgba(8,18,32,.62);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}
.lb-box{position:relative;background:#fff;border-radius:var(--radius);max-width:560px;width:100%;max-height:90vh;overflow:auto;padding:30px;box-shadow:0 30px 80px -20px rgba(8,18,32,.6)}
.lb-box.breed{max-width:820px}
.lb-close{position:absolute;top:12px;right:14px;background:none;border:0;font-size:1.7rem;line-height:1;color:var(--muted);cursor:pointer;width:38px;height:38px;border-radius:50%}
.lb-close:hover{background:var(--cream);color:var(--navy)}
.lb-video h3{font-family:var(--font-display);font-weight:600;color:var(--navy);margin-bottom:12px;padding-right:30px}
.lb-video video{width:100%;border-radius:10px;background:#000;display:block}
.lb-video .val{margin-top:12px;font-size:.86rem;color:var(--muted)}

/* quiz-engine */
.quiz h3{font-family:var(--font-display);font-weight:600;font-size:1.35rem;color:var(--navy);margin:6px 0 14px;padding-right:24px}
.quiz-progress{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent-deep);font-weight:600}
.quiz-img{width:100%;max-height:240px;object-fit:contain;border-radius:10px;background:var(--cream-2);margin-bottom:14px}
.quiz-opties{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.quiz-optie{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;cursor:pointer;font-size:.95rem;transition:.15s}
.quiz-optie:hover{border-color:var(--blue);background:var(--cream)}
.quiz-optie input{margin-top:3px}
.quiz-optie.goed{border-color:#2c9a5f;background:#e9f7ef}
.quiz-optie.fout{border-color:#cf5a5a;background:#fbecec}
.quiz-feedback{padding:12px 14px;border-radius:10px;margin-bottom:14px;font-size:.92rem}
.quiz-feedback.ok{background:#e9f7ef;color:#1c6e43}
.quiz-feedback.nok{background:#fbecec;color:#9a2c2c}
.quiz-score{font-family:var(--font-display);font-size:1.7rem;color:var(--navy);margin:10px 0 18px}

/* Extra's — twee kolommen */
.extras{display:grid;grid-template-columns:minmax(0,300px) 1fr;gap:28px;align-items:start}
.thema-lijst{display:flex;flex-direction:column;gap:3px;border:1px solid var(--line);border-radius:var(--radius);padding:8px;background:#fff;max-height:560px;overflow:auto}
.thema-knop{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:0;border-radius:10px;padding:11px 12px;cursor:pointer;font-family:var(--font-sans);font-size:.92rem;color:var(--navy);transition:background .15s}
.thema-knop:hover{background:var(--cream)}
.thema-knop[aria-selected="true"]{background:var(--cream-2)}
.thema-knop .nr{flex:none;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:600;background:var(--blue);color:#fff}
.thema-knop.gesloten{color:var(--muted)}
.thema-knop.gesloten .nr{background:var(--cream-2);color:var(--muted)}
.thema-knop.gesloten::after{content:"";flex:none;margin-left:auto;width:14px;height:14px;background:var(--muted);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 1a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-9a2 2 0 0 0-2-2h-1V6a5 5 0 0 0-5-5m0 2a3 3 0 0 1 3 3v3H9V6a3 3 0 0 1 3-3'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 1a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-9a2 2 0 0 0-2-2h-1V6a5 5 0 0 0-5-5m0 2a3 3 0 0 1 3 3v3H9V6a3 3 0 0 1 3-3'/%3E%3C/svg%3E") center/contain no-repeat}
.thema-paneel{display:none}
.thema-paneel.actief{display:block}
.thema-paneel h4{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--navy);margin-bottom:14px}
.item-rij{display:flex;flex-direction:column;gap:10px}
.item{display:flex;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 16px}
.item-ico{flex:none;width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.item-ico svg{width:22px;height:22px;stroke-width:1.6}
.item-ico.quiz{background:#e7f1fb;color:var(--blue-deep)}
.item-ico.video{background:#fcefe0;color:var(--accent-deep)}
.item-ico.bestand{background:#eef1f4;color:var(--navy)}
.item .tekst b{display:block;font-size:.95rem;color:var(--navy)}
.item .tekst span{font-size:.82rem;color:var(--muted)}
.item .meta{margin-left:auto;font-size:.78rem;color:var(--muted);white-space:nowrap;align-self:center}
.slot-info{background:var(--cream-2);border:1px dashed rgba(17,37,63,.25);border-radius:12px;padding:22px 24px;color:var(--ink);font-size:.92rem;max-width:60ch}
.slot-info a{color:var(--accent-deep);font-weight:600}

/* prijzentabel (scholen) */
.prijstabel{width:100%;max-width:460px;border-collapse:collapse;margin:16px 0;font-size:.92rem}
.prijstabel th,.prijstabel td{padding:10px 14px;border-bottom:1px solid var(--line)}
.prijstabel thead th{background:var(--navy);color:var(--warm-white);font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}
.prijstabel tbody td:last-child{font-weight:600;color:var(--navy);text-align:right}
.prijstabel tbody tr:hover{background:var(--cream)}

/* ── Responsive ──────────────────────── */
@media(max-width:1080px){
  .detail-grid{grid-template-columns:1fr;gap:22px;max-width:640px;margin:0 auto}
  .detail-visual{order:-1;justify-content:center}
}
/* Middelgrote schermen: hero nog twee kolommen — boek schalen zodat het niet over de tekst valt. */
@media(min-width:921px) and (max-width:1120px){
  .hero-in{gap:32px}
  .stage-col .stage{transform:scale(.82);transform-origin:center}
}
@media(max-width:920px){
  nav.menu{display:none}
  .hamburger{display:flex;margin-left:auto}
  .nav-ico{display:none}
  .hero-in{grid-template-columns:1fr;min-height:auto;padding-top:28px;padding-bottom:56px;text-align:center}
  .eyebrow,.specs,.hero .cta{justify-content:center}
  .lead{margin-left:auto;margin-right:auto}
  .stage-col{order:-1;margin-bottom:8px}
  .stage{transform:scale(.82)}
  .usps{grid-template-columns:1fr 1fr;gap:20px 0}
  .usp:nth-child(2){border-right:none}
  .scholen-in{grid-template-columns:1fr;gap:32px}
  .footer-in{grid-template-columns:1fr 1fr;gap:30px}
  .detail-grid{grid-template-columns:1fr;gap:18px}
  .detail-visual{order:-1}
  .detail-visual .stage{height:460px;transform:none}
  .leer-grid{grid-template-columns:1fr}
  .extras{grid-template-columns:1fr;gap:18px}
  .thema-lijst{max-height:none}
}
@media(max-width:560px){
  .usps{grid-template-columns:1fr}
  .usp{border-right:none;border-bottom:1px solid var(--line)}
  .voordelen{grid-template-columns:1fr}
  .footer-in{grid-template-columns:1fr}
  .boek-acties{flex-direction:column}
}
@media(max-width:520px){
  .detail-visual .stage{width:300px;transform:scale(.82);transform-origin:top center}
}
@media(max-width:400px){
  .detail-visual .stage{transform:scale(.68);transform-origin:top center}
}
@media(prefers-reduced-motion:reduce){.book{transition:none!important}.scene{transition:none!important}}

/* ════════════════════════════════════════
   Webshop (bestellen.php)
   ════════════════════════════════════════ */
.shop{padding:clamp(34px,5vw,64px) 0 clamp(60px,8vw,110px)}
.knop{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;border:1px solid transparent;
  border-radius:999px;font-family:var(--font-sans);font-weight:600;font-size:.95rem;padding:14px 26px;transition:.2s;text-align:center;line-height:1.2}
.knop-primair{background:var(--navy);color:var(--cream)}
.knop-primair:hover{background:var(--accent);color:var(--navy-deep);transform:translateY(-2px)}
.knop-primair:disabled{background:var(--cream-2);color:var(--muted);cursor:not-allowed;transform:none}
.knop-licht{background:#fff;color:var(--navy);border-color:var(--line)}
.knop-licht:hover{border-color:var(--navy)}
.knop-paypal{background:var(--blue);color:#fff}
.knop-paypal:hover{background:var(--blue-deep);transform:translateY(-2px)}
.knop-vol{width:100%}

/* kop + intro */
.shop-kop{max-width:720px;margin-bottom:clamp(26px,4vw,46px)}
.shop-kop h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.1rem,4.4vw,3.1rem);color:var(--navy);line-height:1.05;margin-top:8px}
.shop-intro{font-size:1.05rem;color:var(--ink);margin-top:14px;max-width:60ch}
.shop-usp{list-style:none;display:flex;flex-wrap:wrap;gap:10px 24px;margin-top:20px;padding:0}
.shop-usp li{position:relative;padding-left:24px;font-size:.9rem;color:var(--ink)}
.shop-usp li::before{content:"";position:absolute;left:0;top:6px;width:14px;height:11px;
  background:var(--accent);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.shop-banner{background:#fdf3e3;border:1px solid var(--accent);color:var(--accent-deep);border-radius:12px;padding:14px 18px;margin-bottom:26px;font-size:.92rem}

/* formulier-grid */
.shop-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:clamp(24px,4vw,48px);align-items:start}
.shop-stap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,32px);margin-bottom:24px}
.shop-stap h2{font-family:var(--font-display);font-weight:600;font-size:1.6rem;color:var(--navy);display:flex;align-items:center;gap:14px;margin-bottom:20px}
.stap-nr{flex:none;width:34px;height:34px;border-radius:50%;background:var(--navy);color:var(--cream);display:flex;align-items:center;justify-content:center;font-family:var(--font-sans);font-size:1rem;font-weight:700}

/* boekkeuze */
.boek-keuze{display:flex;flex-direction:column;gap:14px}
.keuze-rij{display:grid;grid-template-columns:54px 1fr auto;gap:16px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:12px;transition:.2s}
.keuze-rij:hover{border-color:var(--blue)}
.keuze-cover{width:54px;height:78px;object-fit:cover;border-radius:5px;box-shadow:0 6px 16px -8px rgba(8,18,32,.5)}
.keuze-info h3{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--navy);line-height:1.1}
.keuze-info h3 span{display:block;font-size:.82rem;font-weight:400;color:var(--muted);font-family:var(--font-sans)}
.keuze-prijs{margin-top:6px;font-size:1rem;color:var(--navy)}
.keuze-prijs .oud{color:var(--muted);text-decoration:line-through;font-size:.85rem;margin-right:4px}
.keuze-prijs strong{font-family:var(--font-display);font-weight:700;font-size:1.2rem}
.stepper{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.stepper button{width:38px;height:40px;border:0;background:none;font-size:1.3rem;color:var(--navy);cursor:pointer;line-height:1;transition:background .15s}
.stepper button:hover{background:var(--cream)}
.stepper input{width:46px;height:40px;border:0;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font-family:var(--font-sans);font-size:1rem;color:var(--navy);-moz-appearance:textfield}
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.boek-keuze-noot{margin-top:14px;font-size:.84rem;color:var(--muted)}
.veld-hint{font-size:.82rem;color:var(--muted);margin:-6px 0 16px}

/* klantvelden */
.klanttype{border:0;display:flex;flex-wrap:wrap;gap:10px 22px;margin-bottom:20px;padding:0}
.klanttype legend{font-size:.82rem;color:var(--muted);margin-bottom:10px;padding:0}
.klanttype label{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;color:var(--navy);cursor:pointer}
.veld-rij{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.veld{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:6px}
.veld-vol{margin-bottom:4px}
.veld-breed{flex:3 1 0}
.veld-smal{flex:1 1 0}
.veld-label{font-size:.8rem;color:var(--muted)}
.veld input,.veld select,.veld textarea{font-family:var(--font-sans);font-size:.96rem;color:var(--ink);background:var(--cream);
  border:1px solid var(--line);border-radius:10px;padding:11px 13px;width:100%;transition:.15s}
.veld input:focus,.veld select:focus,.veld textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,146,201,.12)}
.veld textarea{resize:vertical}

/* samenvatting (sticky) */
.shop-samenvatting{position:sticky;top:94px;background:var(--navy);color:var(--warm-white);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow)}
.shop-samenvatting h2{font-family:var(--font-display);font-weight:600;font-size:1.4rem;color:var(--warm-white);margin-bottom:16px}
.sam-regels{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:10px;border-bottom:1px solid var(--line-d);padding-bottom:16px}
.sam-leeg{color:var(--muted-d);font-size:.9rem}
.sam-regel{display:flex;justify-content:space-between;gap:10px;font-size:.9rem}
.sam-regel .lbl{color:var(--warm-white)}
.sam-regel .lbl small{display:block;color:var(--muted-d);font-size:.78rem}
.sam-regel .pr{font-weight:600;white-space:nowrap}
.sam-totalen{margin:0}
.sam-totalen>div{display:flex;justify-content:space-between;font-size:.92rem;padding:5px 0;color:var(--muted-d)}
.sam-totalen .sam-totaal{border-top:1px solid var(--line-d);margin-top:6px;padding-top:12px;font-size:1.15rem;color:var(--warm-white)}
.sam-totalen .sam-totaal dd{font-family:var(--font-display);font-weight:700}
.sam-totalen dt,.sam-totalen dd{margin:0}
.sam-noot{font-size:.78rem;color:var(--muted-d);margin:14px 0 18px}
.sam-veilig{text-align:center;font-size:.78rem;color:var(--muted-d);margin-top:12px}

/* stap 2 — overzicht */
.shop-overzicht-grid{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:clamp(24px,4vw,48px);align-items:start}
.shop-bevestig{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,32px)}
.shop-bevestig h2{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--navy);margin-bottom:16px}
.shop-bevestig h3{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:24px 0 8px}
.shop-tabel{width:100%;border-collapse:collapse;font-size:.94rem}
.shop-tabel td{padding:9px 6px;border-bottom:1px solid var(--line);vertical-align:top}
.shop-tabel .num{text-align:right;white-space:nowrap}
.shop-tabel .oud{color:var(--muted);text-decoration:line-through;font-size:.82rem}
.shop-tabel tfoot td{border-bottom:0;padding-top:10px;color:var(--ink)}
.shop-tabel .totaal-rij td{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--navy);border-top:2px solid var(--navy);padding-top:14px}
.shop-tabel .korting-rij td{color:#1c6e43}
.shop-tabel .korting-rij.ongeldig td{color:var(--accent-deep)}
.badge-korting{display:inline-block;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#1c6e43;background:#e9f7ef;padding:2px 7px;border-radius:5px;margin-left:6px}
.shop-adres{font-size:.95rem;color:var(--ink);line-height:1.7}
.shop-betaal{background:var(--navy);color:var(--warm-white);border-radius:var(--radius);padding:28px 26px;box-shadow:var(--shadow);position:sticky;top:94px}
.shop-betaal h2{font-family:var(--font-display);font-weight:600;font-size:1.4rem;color:var(--warm-white);margin-bottom:20px}
.betaal-optie{display:flex;flex-direction:column;gap:8px}
.betaal-optie .knop{width:100%}
.betaal-noot{font-size:.8rem;color:var(--muted-d);text-align:center}
.betaal-of{text-align:center;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-d);margin:18px 0;position:relative}
.betaal-of::before,.betaal-of::after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--line-d)}
.betaal-of::before{left:0}.betaal-of::after{right:0}
.betaal-terug{text-align:center;margin-top:20px}
.betaal-terug a{font-size:.86rem;color:var(--muted-d)}
.betaal-terug a:hover{color:var(--warm-white)}

/* stap 3 — meldingen */
.shop-melding{max-width:660px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,4vw,40px);font-size:1.02rem}
.shop-melding p{margin-bottom:14px}
.shop-melding.shop-succes{border-color:#bfe6cf;background:#f3fbf6}
.shop-melding .extra-noot{font-size:.9rem;color:var(--muted);background:var(--cream);border-radius:10px;padding:14px 16px}
.shop-melding .knop{margin-top:8px}
.betaal-gegevens{display:grid;grid-template-columns:auto 1fr;gap:8px 20px;margin:18px 0;background:var(--cream);border-radius:12px;padding:20px 22px}
.betaal-gegevens dt{color:var(--muted);font-size:.88rem}
.betaal-gegevens dd{margin:0;color:var(--navy);font-weight:600}
.betaal-gegevens .mededeling{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.02em}
.shop-fout{max-width:620px;background:#fbecec;border:1px solid #e7b9b9;border-radius:12px;padding:22px 24px;color:#9a2c2c}
.shop-fout ul{margin:10px 0 16px 20px}

@media(max-width:980px){
  .shop-grid,.shop-overzicht-grid{grid-template-columns:1fr}
  .shop-samenvatting,.shop-betaal{position:static}
  .shop-betaal{order:-1}
}
@media(max-width:520px){
  .keuze-rij{grid-template-columns:46px 1fr;gap:12px}
  .keuze-rij .stepper{grid-column:2;justify-self:start}
  .veld-rij{flex-direction:column;gap:14px}
}

/* ════════════════════════════════════════
   Info voor scholen (scholen.php)
   ════════════════════════════════════════ */
.scholen-content{padding:clamp(48px,7vw,88px) 0}
.scholen-kolommen{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,46px);align-items:start}
.info-kaart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,34px)}
.info-kaart h2{font-family:var(--font-display);font-weight:600;font-size:1.55rem;color:var(--navy);margin-bottom:8px}
.info-kaart>p{color:var(--ink);margin-bottom:16px}
.info-kaart .prijstabel{max-width:none;margin:6px 0 14px}
.info-kaart .kt-noot{color:var(--muted);font-size:.86rem}
.stappen{list-style:none;counter-reset:s;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.stappen li{counter-increment:s;display:grid;grid-template-columns:38px 1fr;gap:15px;align-items:start}
.stappen li::before{content:counter(s);width:38px;height:38px;border-radius:50%;background:var(--navy);color:var(--cream);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}
.stappen li b{display:block;color:var(--navy);margin-bottom:2px}
.stappen li span{color:var(--ink);font-size:.95rem}
.aanvraag{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,3.4vw,40px);
  margin-top:clamp(24px,4vw,42px);display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,3vw,34px);align-items:center}
.aanvraag .ico{flex:none;width:66px;height:66px;border-radius:18px;background:var(--navy);color:var(--accent);display:flex;align-items:center;justify-content:center}
.aanvraag .ico svg{width:32px;height:32px;stroke-width:1.6}
.aanvraag h2{font-family:var(--font-display);font-weight:600;font-size:1.6rem;color:var(--navy);margin-bottom:6px}
.aanvraag p{color:var(--ink);max-width:60ch}
.scholen-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:clamp(26px,4vw,42px)}
@media(max-width:880px){
  .scholen-kolommen{grid-template-columns:1fr}
  .aanvraag{grid-template-columns:auto 1fr;gap:22px}
  .aanvraag .knop,.aanvraag .btn{grid-column:1 / -1}
}

/* ════════════════════════════════════════
   Contact (contact.php)
   ════════════════════════════════════════ */
.contact{padding:clamp(34px,5vw,64px) 0 clamp(60px,8vw,110px)}
.pagina-kop{max-width:720px;margin-bottom:clamp(24px,4vw,40px)}
.pagina-kop h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.1rem,4.4vw,3.1rem);color:var(--navy);line-height:1.05;margin-top:8px}
.pagina-intro{font-size:1.05rem;color:var(--ink);margin-top:14px;max-width:62ch}
.contact-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:clamp(24px,4vw,46px);align-items:start}
.contact-form-kaart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,34px)}
.contact-form-kaart .knop{margin-top:18px}
.contact-privacy{font-size:.82rem;color:var(--muted);margin-top:14px}
.contact-privacy a{color:var(--accent-deep);font-weight:600}
.contact-info{background:var(--navy);color:var(--warm-white);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow)}
.contact-info h2{font-family:var(--font-display);font-weight:600;font-size:1.4rem;color:var(--warm-white);margin-bottom:20px}
.contact-info dl{display:flex;flex-direction:column;gap:16px;margin:0}
.contact-info dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;color:var(--muted-d);margin-bottom:4px}
.contact-info dd{margin:0;color:var(--warm-white);font-size:.98rem}
.contact-info a{color:var(--warm-white);border-bottom:1px solid var(--line-d);transition:border-color .15s}
.contact-info a:hover{border-color:var(--accent)}
.contact-info-noot{margin-top:22px;padding-top:18px;border-top:1px solid var(--line-d);font-size:.86rem;color:var(--muted-d)}
.cf-turnstile{margin:8px 0 2px;min-height:65px}
.hp-veld{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.veld-fout{border-color:#cf5a5a!important;background:#fdf6f6!important}
.melding-ok{max-width:680px;background:#f3fbf6;border:1px solid #bfe6cf;color:#1c6e43;border-radius:var(--radius);padding:22px 24px;margin-bottom:22px}
.melding-fout{background:#fbecec;border:1px solid #e7b9b9;color:#9a2c2c;border-radius:var(--radius);padding:18px 22px;margin-bottom:22px}
.melding-fout ul{margin:8px 0 0 20px}
.code-invoer{font-family:var(--font-sans);font-size:1.2rem!important;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.veld-label .opt{color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}
@media(max-width:880px){
  .contact-grid{grid-template-columns:1fr}
  .contact-info{order:-1}
}

/* ════════════════════════════════════════
   Juridische pagina's (voorwaarden.php, privacy.php)
   ════════════════════════════════════════ */
.legal{padding:clamp(34px,5vw,64px) 0 clamp(60px,8vw,110px)}
.legal-body{max-width:760px}
.legal-body h2{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--navy);margin:34px 0 10px;scroll-margin-top:90px}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{font-size:1.02rem;font-weight:600;color:var(--navy);margin:20px 0 6px}
.legal-body p{margin-bottom:14px;color:var(--ink)}
.legal-body ul{margin:0 0 16px 22px}
.legal-body li{margin-bottom:7px;color:var(--ink)}
.legal-body a{color:var(--accent-deep);font-weight:600}
.legal-body strong{color:var(--navy)}
.legal-update{font-size:.84rem;color:var(--muted);margin-top:8px}
.legal-toc{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;margin-bottom:30px;max-width:760px}
.legal-toc h2{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 10px}
.legal-toc ol{margin:0;padding-left:20px;columns:2;column-gap:32px}
.legal-toc li{margin-bottom:6px}
.legal-toc a{color:var(--navy)}
.legal-toc a:hover{color:var(--accent-deep)}
@media(max-width:560px){.legal-toc ol{columns:1}}

/* ════════════════════════════════════════
   Boek registreren (coderegistreren.php)
   ════════════════════════════════════════ */
.reg{padding:clamp(34px,5vw,64px) 0 clamp(60px,8vw,110px)}
.reg-code-kaart{display:grid;grid-template-columns:auto 1fr;gap:clamp(18px,3vw,30px);align-items:center;
  background:var(--navy);color:var(--warm-white);border-radius:var(--radius);padding:clamp(22px,3vw,32px);box-shadow:var(--shadow);margin-bottom:24px}
.reg-code-ico{flex:none;width:66px;height:66px;border-radius:18px;background:rgba(244,239,228,.08);color:var(--accent);display:flex;align-items:center;justify-content:center}
.reg-code-ico svg{width:32px;height:32px}
.reg-code-velden .veld-label{color:var(--muted-d)}
.reg-code-velden .code-invoer{background:rgba(244,239,228,.95);border-color:transparent}
.reg-code-hint{font-size:.84rem;color:var(--muted-d);margin-top:8px}
.reg-grid{display:grid;grid-template-columns:340px 1fr;gap:clamp(20px,3vw,34px);align-items:start}
.reg-kaart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,30px)}
.reg-kaart h2{font-family:var(--font-display);font-weight:600;font-size:1.4rem;color:var(--navy);margin-bottom:4px}
.reg-kaart-sub{font-size:.9rem;color:var(--muted);margin-bottom:18px}
.reg-kaart .knop{margin-top:18px}
.reg-aanspreking{margin-bottom:16px}
.reg-aanspreking legend{margin-bottom:8px}
.geb-datum{display:flex;gap:10px}
.geb-datum select{flex:1}
.reg-aanmeld-titel{font-weight:600;color:var(--navy);margin:22px 0 12px;padding-top:18px;border-top:1px solid var(--line)}
.reg-privacy{font-size:.8rem;color:var(--muted);margin-top:16px;line-height:1.55}
.reg-privacy a{color:var(--accent-deep);font-weight:600}
.reg-hulp{max-width:760px;margin-top:26px;background:var(--cream-2);border:1px solid var(--line);border-radius:12px;padding:18px 22px;font-size:.92rem;color:var(--ink)}
.reg-hulp a{color:var(--accent-deep);font-weight:600}
.reg-ingelogd{max-width:620px}
.reg-afmeld{max-width:620px;margin-top:16px;text-align:center}
.reg-afmeld-knop{background:none;border:0;padding:0;cursor:pointer;font:inherit;font-size:.9rem;color:var(--muted);text-decoration:underline}
.reg-afmeld-knop:hover{color:var(--accent-deep)}
@media(max-width:880px){
  .reg-grid{grid-template-columns:1fr}
  .reg-code-kaart{grid-template-columns:1fr}
  .reg-code-ico{display:none}
}

/* ════════════════════════════════════════
   Account-widget (hoofding) + accountpagina
   ════════════════════════════════════════ */
.account{position:relative;display:flex}
.account-knop{display:flex;align-items:center;background:none;border:0;padding:0;margin:0;cursor:pointer;
  color:inherit;opacity:.85;transition:.2s;position:relative}
.account-knop:hover{opacity:1;color:var(--accent-bright)}
.account-knop.actief{opacity:1;color:var(--accent)}
.account-knop.actief::after{content:"";position:absolute;top:-3px;right:-3px;width:7px;height:7px;border-radius:50%;
  background:var(--accent);border:1.5px solid var(--navy)}
.account-paneel{position:absolute;top:calc(100% + 14px);right:0;width:270px;background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px -22px rgba(8,18,32,.5);padding:16px;z-index:120}
.account-paneel::before{content:"";position:absolute;top:-7px;right:16px;width:13px;height:13px;background:#fff;
  border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.account-groet{font-size:.95rem;color:var(--ink);padding:4px 6px 12px;border-bottom:1px solid var(--line);margin-bottom:8px}
.account-groet strong{color:var(--navy)}
.account-item{display:block;width:100%;text-align:left;background:none;border:0;cursor:pointer;font:inherit;
  color:var(--navy);padding:10px 8px;border-radius:8px;transition:background .15s}
.account-item:hover{background:var(--cream)}
.account-afmelden{color:var(--accent-deep)}
/* Loginbalk */
.login-form{display:flex;flex-direction:column;gap:10px}
.login-titel{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--navy)}
.login-form label{display:flex;flex-direction:column;gap:4px;font-size:.78rem;color:var(--muted)}
.login-form input{font-family:var(--font-sans);font-size:.95rem;color:var(--ink);background:var(--cream);
  border:1px solid var(--line);border-radius:9px;padding:9px 11px}
.login-form input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,146,201,.12)}
.login-form .knop{margin-top:4px}
.login-fout{background:#fbecec;color:#9a2c2c;border-radius:8px;padding:8px 10px;font-size:.85rem}
.login-reg{font-size:.82rem;color:var(--muted);margin-top:2px}
.login-reg a{color:var(--accent-deep);font-weight:600}
.login-vergeten{font-size:.82rem;margin-top:2px}
.login-vergeten a{color:var(--accent-deep);font-weight:600}
/* Afmeldknop in het mobiele menu */
.mm-afmeldform button{width:100%;text-align:left;background:none;border:0;border-top:1px solid var(--line-d);
  color:var(--warm-white);font:inherit;padding:14px 24px;cursor:pointer;text-transform:uppercase;letter-spacing:.12em;font-size:.82rem}

/* Accountpagina */
.account-pagina{padding:clamp(34px,5vw,64px) 0 clamp(60px,8vw,110px)}
.account-loginkaart{max-width:420px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,3vw,34px)}
.login-form-groot{display:flex;flex-direction:column;gap:16px}
.account-reg{margin-top:16px;font-size:.9rem;color:var(--muted)}
.account-reg a{color:var(--accent-deep);font-weight:600}
.account-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(24px,4vw,46px);align-items:start}
.account-kaart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,32px)}
.account-kaart h2{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--navy);margin-bottom:16px}
.account-kaart h3{font-size:1.02rem;font-weight:600;color:var(--navy);margin:26px 0 10px;padding-top:20px;border-top:1px solid var(--line)}
.account-gegevens{display:grid;grid-template-columns:auto 1fr;gap:10px 20px;margin:0}
.account-gegevens dt{color:var(--muted);font-size:.9rem}
.account-gegevens dd{margin:0;color:var(--navy);font-weight:600}
.account-noot{font-weight:400;color:var(--muted);font-size:.82rem}
.ww-form{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.account-afmeldform{margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.account-boeken{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0;padding:0}
.ab-item{display:flex;gap:16px;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:12px;transition:border-color .2s}
.ab-item:hover{border-color:var(--blue)}
.ab-cover{flex:none;display:block;width:56px}
.ab-cover img{width:56px;height:auto;border-radius:5px;box-shadow:0 6px 16px -8px rgba(8,18,32,.5);display:block}
.ab-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.ab-naam{font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--navy);line-height:1.15}
.ab-naam a{color:var(--navy)}
.ab-naam a:hover{color:var(--accent-deep)}
.ab-code{font-size:.78rem;color:var(--muted);letter-spacing:.04em}
.ab-online{font-size:.84rem;color:var(--accent-deep);font-weight:600;margin-top:2px}
.account-leeg{color:var(--ink);font-size:.92rem}
.account-leeg a{color:var(--accent-deep);font-weight:600}
@media(max-width:880px){.account-grid{grid-template-columns:1fr}}
/* Homepage: klikbare cover */
.boek-cover-link{display:block;text-decoration:none}
.boek-cover-link:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
/* Account: scheiding actueel/oud */
.account-scheiding{border:0;border-top:1px solid var(--line);margin:22px 0 14px}
.account-oud-titel{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 12px}
.account-boeken-oud{opacity:.9}
.account-boeken-oud .ab-naam{font-size:1rem}
.account-boeken-oud .ab-cover,.account-boeken-oud .ab-cover img{width:44px}
/* Account: uitklapbare gegevens */
.geg-details{margin-top:22px}
.geg-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;list-style:none;background:#fff;border:1px solid var(--navy);color:var(--navy);
  font-family:var(--font-sans);font-weight:600;font-size:.95rem;border-radius:999px;padding:11px 22px;transition:.2s}
.geg-toggle::-webkit-details-marker{display:none}
.geg-toggle::after{content:"▾";font-size:.8rem}
.geg-details[open] .geg-toggle::after{content:"▴"}
.geg-toggle:hover{background:var(--navy);color:var(--cream)}
.geg-form{display:flex;flex-direction:column;gap:14px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.geg-ww-titel{font-weight:600;color:var(--navy);margin-top:6px}
.geg-ww-titel .opt{font-weight:400;color:var(--muted);font-size:.85rem}
.flipbook-toegang{background:#f3fbf6;border:1px solid #bfe6cf;color:#1c6e43;border-radius:10px;padding:12px 16px;font-size:.92rem;margin:0 0 16px}
