/* ============================================================
   Communicatiehelden — Summer School — shared styles
   Design tokens (Kleurenpalet CH + Lettertypen)
   ============================================================ */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

@font-face { font-family:"Cabinet Grotesk"; src:url("assets/fonts/cabinet-grotesk-400.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Cabinet Grotesk"; src:url("assets/fonts/cabinet-grotesk-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Cabinet Grotesk"; src:url("assets/fonts/cabinet-grotesk-700.woff2") format("woff2"); font-weight:700; font-display:swap; }
@font-face { font-family:"Cabinet Grotesk"; src:url("assets/fonts/cabinet-grotesk-800.woff2") format("woff2"); font-weight:800; font-display:swap; }

:root {
  --ch-navy:#211a3f; --ch-peach:#f9a980; --ch-sky:#5eccf5; --ch-butter:#fde98f;
  --ch-indigo:#594dff; --ch-violet:#8455ed; --ch-lilac:#f8f7fc;
  --ch-sky-tint:#e8f7fd; --ch-peach-tint:#fdeadc; --ch-butter-tint:#fef8d9;
  --fg-1:#211a3f; --fg-2:#4a4467; --fg-3:#8884a0;
  --border-1:#ece9f4; --border-2:#d2cee0;
  --font-display:"Cabinet Grotesk","Inter",system-ui,sans-serif;
  --font-text:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --radius-md:10px; --radius-lg:16px; --radius-pill:9999px;
  --shadow-sm:0 1px 2px rgba(33,26,63,.06);
  --shadow-md:0 6px 18px -6px rgba(33,26,63,.12),0 2px 6px -2px rgba(33,26,63,.06);
  --shadow-pop:0 12px 32px -8px rgba(94,204,245,.35);
  --site-max:1170px; --site-padding:24px; --section-y:clamp(80px,8vw,112px);
  --ease-out:cubic-bezier(0.2,0.7,0.2,1); --dur-fast:150ms; --dur-base:250ms;
}

* { box-sizing:border-box; }
html { font-family:var(--font-text); color:var(--fg-1); background:#fff; font-size:16px; line-height:1.5; -webkit-font-smoothing:antialiased; scroll-behavior:smooth; }
body { margin:0; overflow-x:hidden; }
h1,h2,h3,h4 { font-family:var(--font-display); color:var(--fg-1); margin:0; letter-spacing:-0.01em; line-height:1.25; text-wrap:balance; }
h1 { font-size:clamp(2rem,4.2vw,4rem); font-weight:800; letter-spacing:-0.02em; line-height:1.06; }
h2 { font-size:clamp(1.75rem,3vw,2.5rem); font-weight:700; letter-spacing:-0.015em; }
h3 { font-size:1.25rem; font-weight:700; }
p { margin:0; line-height:1.65; text-wrap:pretty; }
a { color:var(--ch-indigo); text-decoration:none; transition:color var(--dur-fast); }
img { display:block; }
::selection { background:var(--ch-sky); color:var(--ch-navy); }
.eyebrow { font-size:.875rem; font-weight:600; color:var(--ch-indigo); letter-spacing:.04em; text-transform:uppercase; }
.hl { background:var(--ch-butter); color:var(--ch-navy); padding:0 .14em; border-radius:4px; }

/* ---------------- Buttons ---------------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 24px; border:0; cursor:pointer; font-family:var(--font-text); font-weight:600;
  font-size:15px; border-radius:var(--radius-pill); line-height:1; text-decoration:none; white-space:nowrap;
  transition:transform var(--dur-fast) var(--ease-out), background var(--dur-fast), box-shadow var(--dur-fast); }
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:scale(.98); }
.btn-lg { padding:16px 30px; font-size:16px; }
.btn-peach { background:var(--ch-peach); color:var(--ch-navy); }
.btn-peach:hover { background:#f79a6c; box-shadow:0 12px 26px -10px rgba(249,169,128,.7); }
.btn-sky { background:var(--ch-sky); color:var(--ch-navy); }
.btn-sky:hover { background:#4dc3ee; box-shadow:var(--shadow-pop); }
.btn-indigo { background:var(--ch-indigo); color:#fff; }
.btn-indigo:hover { background:#463cf0; box-shadow:0 12px 26px -10px rgba(89,77,255,.6); }
.btn-outline { background:#fff; color:var(--ch-navy); box-shadow:inset 0 0 0 1.5px var(--border-2); }
.btn-outline:hover { box-shadow:inset 0 0 0 1.5px var(--ch-navy); }
.btn-light { background:#fff; color:var(--ch-navy); }
.btn-light:hover { background:var(--ch-lilac); }
.btn-full { width:100%; }

/* ---------------- Layout shell ---------------- */
.wrap { max-width:var(--site-max); margin:0 auto; padding:0 var(--site-padding); }
.section { padding:var(--section-y) 0; }
.section--lilac { background:var(--ch-lilac); }
.section--navy { background:var(--ch-navy); color:#fff; }
.section--navy h2, .section--navy h3, .section--navy h4 { color:#fff; }
.section--peach { background:var(--ch-peach-tint); }
.head { max-width:760px; margin:0 auto 48px; text-align:center; display:flex; flex-direction:column; gap:12px; }
.head .eyebrow { color:var(--ch-peach); }
.head p { font-size:1.125rem; color:var(--fg-2); }
.section--navy .head p { color:rgba(255,255,255,.72); }
.section--peach .head .eyebrow { color:#b5532b; }

/* ---------------- Urgentie-balk + countdown ---------------- */
.topbar { background:var(--ch-navy); color:#fff; text-align:center; padding:11px 16px;
  font-size:14px; font-weight:600; display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap; }
.topbar [data-countdown] { color:var(--ch-butter); font-variant-numeric:tabular-nums; }
.countdown { display:flex; gap:10px; justify-content:center; }
.cd-box { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); border-radius:10px;
  padding:10px 14px; min-width:66px; text-align:center; }
.cd-num { display:block; font-family:var(--font-display); font-weight:800; font-size:1.7rem; line-height:1; color:#fff; font-variant-numeric:tabular-nums; }
.cd-lbl { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.6); margin-top:6px; }
.countdown--light .cd-box { background:var(--ch-lilac); border-color:var(--border-1); }
.countdown--light .cd-num { color:var(--ch-navy); }
.countdown--light .cd-lbl { color:var(--fg-3); }
.cd-label { font-size:13px; font-weight:600; color:var(--ch-peach); text-transform:uppercase; letter-spacing:.05em; margin-bottom:12px; }

/* ---------------- Header ---------------- */
.header { position:sticky; top:0; z-index:50; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--border-1); }
.header__bar { max-width:1240px; margin:0 auto; padding:14px var(--site-padding);
  display:flex; align-items:center; gap:20px; }
.header__logo { flex-shrink:0; display:inline-flex; align-items:center; }
.header__logo img { height:34px; width:auto; }
.header__nav { display:flex; align-items:center; gap:6px; margin-left:auto; }
.header__nav a { font-size:15px; font-weight:500; color:var(--ch-navy); padding:8px 12px; border-radius:8px; }
.header__nav a:hover { color:var(--ch-indigo); }
.header__cta { margin-left:auto; }
.header__back { font-size:14px; font-weight:600; color:var(--ch-navy); margin-left:auto; display:inline-flex; align-items:center; gap:6px; }
.header__back:hover { color:var(--ch-indigo); }

/* ---------------- Hero ---------------- */
.hero { position:relative; isolation:isolate; min-height:560px; display:flex; align-items:center;
  justify-content:center; text-align:center; color:#fff; overflow:hidden; padding:96px var(--site-padding); }
.hero__bg { position:absolute; inset:0; z-index:-2; }
.hero__bg img { width:100%; height:100%; object-fit:cover; }
.hero__bg::after { content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(33,26,63,.80) 0%, rgba(33,26,63,.72) 55%, rgba(33,26,63,.86) 100%); }
.hero__inner { position:relative; max-width:760px; display:flex; flex-direction:column; align-items:center; gap:20px; }
.hero__badge { display:inline-flex; align-items:center; gap:8px; background:rgba(94,204,245,.18);
  color:#cdeefb; border:1px solid rgba(94,204,245,.45); padding:7px 16px; border-radius:var(--radius-pill);
  font-size:14px; font-weight:600; backdrop-filter:blur(4px); }
.hero h1 { color:#fff; font-size:clamp(34px,5vw,58px); line-height:1.06; }
.hero__sub { color:rgba(255,255,255,.88); font-size:1.25rem; line-height:1.55; max-width:600px; }
.hero__teaser { display:inline-flex; align-items:center; gap:9px; color:rgba(255,255,255,.82);
  font-size:15px; font-weight:400; }
.hero__teaser b { color:var(--ch-butter); font-weight:600; }
.hero__ctas { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:6px; }
.hero__meta { display:flex; gap:28px; flex-wrap:wrap; justify-content:center; margin-top:8px; }
.hero__meta span { display:inline-flex; align-items:center; gap:8px; color:rgba(255,255,255,.9); font-size:15px; }
.hero__meta b { font-family:var(--font-display); font-weight:800; }
.stars { color:#fbbc05; letter-spacing:1px; }

/* ---------------- Checklist (recognition) ---------------- */
.checks { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; max-width:880px; margin:0 auto; }
.check { display:flex; gap:14px; align-items:flex-start; background:#fff; border:1px solid var(--border-1);
  border-radius:var(--radius-md); padding:20px 22px; }
.check::before { content:"✓"; flex-shrink:0; width:26px; height:26px; border-radius:50%;
  background:#e2dcff; color:var(--ch-indigo); font-weight:700; font-size:14px;
  display:inline-flex; align-items:center; justify-content:center; margin-top:2px; }
.check b { display:block; color:var(--ch-navy); font-size:15.5px; margin-bottom:2px; }
.check span { font-size:14.5px; color:var(--fg-2); line-height:1.5; }

/* ---------------- Course cards ---------------- */
.courses__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
.course { background:#fff; border:1px solid var(--border-1); border-radius:var(--radius-lg);
  padding:32px 30px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:14px;
  transition:transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base); }
.course:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.ico-tile { width:44px; height:44px; border-radius:12px; flex-shrink:0; display:inline-flex;
  align-items:center; justify-content:center; font-size:20px; }
.ico-tile--sky { background:var(--ch-sky-tint); color:#1f93c7; }
.ico-tile--peach { background:var(--ch-peach-tint); color:#df7a44; }
.ico-tile--butter { background:var(--ch-butter-tint); color:#c2941a; }
.ico-tile--indigo { background:#e9e7ff; color:var(--ch-indigo); }
.course h3 { font-size:1.35rem; }
.course .desc { font-size:15px; color:var(--fg-2); line-height:1.6; }
.course ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.course li { display:flex; gap:10px; align-items:flex-start; font-size:14.5px; color:var(--fg-1); }
.course li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; flex-shrink:0; }
.course__foot { margin-top:auto; padding-top:6px; }
.price { display:flex; align-items:baseline; gap:10px; margin-bottom:16px; }
.price .now { font-family:var(--font-display); font-size:2rem; font-weight:800; color:var(--ch-navy); }
.price .was { font-size:1.05rem; color:var(--fg-3); text-decoration:line-through; }
.price .save { font-size:.75rem; font-weight:700; color:var(--ch-navy); background:var(--ch-butter);
  padding:4px 10px; border-radius:var(--radius-pill); }
.vat { font-size:12.5px; color:var(--fg-3); margin-top:3px; }
.course__meta { font-size:13px; color:var(--fg-3); font-weight:600; margin-bottom:12px; }
.course__link { display:inline-block; margin-top:12px; font-size:14px; font-weight:600; color:var(--ch-indigo); }
.course__link:hover { color:var(--ch-violet); }

/* ---------------- Bundle (cross-sell) ---------------- */
.bundle { display:grid; grid-template-columns:1.5fr 1fr; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-md); margin-top:30px; border:2px solid var(--ch-indigo); }
.bundle__body { padding:38px 40px; background:#fff; }
.bundle__body .eyebrow { color:var(--ch-indigo); }
.bundle__body h3 { font-size:1.6rem; margin:10px 0 12px; }
.bundle__body > p { color:var(--fg-2); font-size:1.0625rem; line-height:1.6; }
.bundle__list { list-style:none; padding:0; margin:18px 0 0; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.bundle__list li { display:flex; gap:9px; font-size:15px; color:var(--ch-navy); font-weight:500; }
.bundle__list li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; }
.bundle__buy { padding:38px 34px; background:var(--ch-navy); color:#fff; display:flex; flex-direction:column;
  justify-content:center; align-items:center; text-align:center; }
.bundle__save { background:var(--ch-butter); color:var(--ch-navy); font-size:13px; font-weight:700; padding:5px 13px; border-radius:var(--radius-pill); margin-bottom:10px; }
.bundle__price { display:flex; align-items:baseline; gap:12px; }
.bundle__price .now { font-family:var(--font-display); font-size:3rem; font-weight:800; color:#fff; line-height:1; }
.bundle__price .was { font-size:1.25rem; color:rgba(255,255,255,.5); text-decoration:line-through; }
.bundle__note { color:rgba(255,255,255,.7); font-size:13.5px; margin:6px 0 20px; }
.bundle__buy .btn { width:100%; }
.bundle__guarantee { color:rgba(255,255,255,.6); font-size:12.5px; margin-top:14px; }
.bundle__link { color:var(--ch-sky); font-size:14px; font-weight:600; margin-top:14px; }
.bundle__link:hover { color:#fff; }

/* pakket-overzicht (4 cursussen in de bundel-salespagina) */
.pkg-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; max-width:920px; margin:0 auto; }
.pkg-card { background:#fff; border:1px solid var(--border-1); border-radius:var(--radius-lg); padding:26px 28px; box-shadow:var(--shadow-sm); }
.pkg-card .ico-tile { margin-bottom:14px; }
.pkg-card h3 { font-size:1.2rem; margin-bottom:6px; }
.pkg-card .pkg-tag { font-size:14.5px; color:var(--fg-2); line-height:1.5; margin-bottom:14px; }
.pkg-card ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:7px; }
.pkg-card li { display:flex; gap:9px; font-size:14px; color:var(--fg-1); line-height:1.4; }
.pkg-card li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; flex-shrink:0; }

/* guarantee badge (course pages / quiz) */
.guarantee { display:inline-flex; align-items:center; gap:8px; background:var(--ch-sky-tint); color:#1f7fa8;
  font-size:13.5px; font-weight:600; padding:8px 16px; border-radius:var(--radius-pill); margin:0 auto 18px; }

/* ---------------- Feature row (how it works) ---------------- */
.features__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.feature { display:flex; flex-direction:column; gap:14px; }
.feature h4 { font-size:1.125rem; font-weight:600; }
.feature p { font-size:14.5px; color:var(--fg-2); line-height:1.6; }

/* ---------------- Quote (navy) ---------------- */
.quote { text-align:center; }
.quote .stars { font-size:1.4rem; margin-bottom:20px; display:block; }
.quote blockquote { font-family:var(--font-display); font-weight:700; font-size:clamp(1.4rem,3vw,2rem);
  max-width:820px; margin:0 auto 18px; line-height:1.3; color:#fff; }
.quote .by { color:rgba(255,255,255,.7); font-weight:500; }

/* ---------------- FAQ ---------------- */
.faq { max-width:760px; margin:0 auto; }
details { border-bottom:1px solid var(--border-1); padding:22px 4px; }
summary { font-family:var(--font-display); font-weight:700; font-size:1.08rem; cursor:pointer;
  list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px; color:var(--ch-navy); }
summary::-webkit-details-marker { display:none; }
summary::after { content:"+"; color:var(--ch-indigo); font-size:1.5rem; font-weight:700; transition:transform .2s; }
details[open] summary::after { transform:rotate(45deg); }
details p { color:var(--fg-2); margin-top:14px; font-size:15px; }

/* ---------------- Final CTA ---------------- */
.cta { text-align:center; }
.cta__inner { max-width:680px; margin:0 auto; display:flex; flex-direction:column; align-items:center; gap:16px; }
.cta__inner p { color:rgba(255,255,255,.78); font-size:1.125rem; }

/* ---------------- Ingrid (maker) block ---------------- */
.maker { display:grid; grid-template-columns:0.85fr 1.15fr; gap:56px; align-items:center; max-width:1040px; margin:0 auto; }
.maker__photo { position:relative; }
.maker__photo img { width:100%; max-width:380px; border-radius:var(--radius-lg); display:block; box-shadow:var(--shadow-md); }
.maker__body .eyebrow { color:var(--ch-peach); }
.maker__body h2 { margin:10px 0 18px; }
.maker__body p { color:var(--fg-2); font-size:1.0625rem; line-height:1.7; }
.maker__body p + p { margin-top:14px; }
.maker__role { display:flex; flex-wrap:wrap; gap:8px; margin-top:22px; }
.maker__role span { background:var(--ch-lilac); border:1px solid var(--border-1); color:var(--ch-navy);
  font-size:13.5px; font-weight:500; padding:7px 14px; border-radius:var(--radius-pill); }
.maker__name { margin-top:24px; display:flex; flex-direction:column; gap:2px; }
.maker__name b { font-family:var(--font-display); font-size:1.05rem; color:var(--ch-navy); }
.maker__name span { font-size:14px; color:var(--fg-3); }

/* ---------------- Testimonials (Trustindex) ---------------- */
.ti-wrap { max-width:1040px; margin:0 auto; }

/* ---------------- Live Q&A (navy) ---------------- */
.qa-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; max-width:920px; margin:0 auto; }
.qa-card { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:var(--radius-lg);
  padding:24px 26px; transition:background var(--dur-base), transform var(--dur-base); }
.qa-card:hover { background:rgba(255,255,255,0.08); transform:translateY(-3px); }
.qa-card__when { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:12px; }
.qa-card__date { font-family:var(--font-display); font-weight:800; color:#fff; font-size:1.15rem; }
.qa-card__time { font-size:12.5px; font-weight:600; color:var(--ch-sky); background:rgba(94,204,245,0.14);
  padding:4px 11px; border-radius:var(--radius-pill); }
.qa-card__course { font-size:12px; font-weight:700; color:var(--ch-butter); text-transform:uppercase; letter-spacing:.05em; margin-bottom:6px; }
.qa-card__theme { color:#fff; font-size:1.0625rem; font-weight:600; line-height:1.4; }
.qa-note { display:flex; gap:22px; flex-wrap:wrap; justify-content:center; margin:34px auto 0; }
.qa-note span { color:rgba(255,255,255,0.82); font-size:14.5px; display:inline-flex; align-items:center; gap:8px; }
.qa-note .ic { color:var(--ch-sky); }
.qa-cta { text-align:center; margin-top:28px; }
.qa-soon { color:rgba(255,255,255,0.78); font-size:14.5px; line-height:1.55; max-width:540px; margin:0 auto;
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:var(--radius-pill); padding:12px 22px; }
.qa-soon b { color:#fff; }
.qa-soon-note { color:rgba(255,255,255,0.62); font-size:13px; margin-top:14px; }

/* ---------------- Quiz ---------------- */
.quiz { max-width:720px; margin:0 auto; background:#fff; border:1px solid var(--border-1);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-md); padding:38px 38px 32px;
  transition:max-width var(--dur-base) var(--ease-out); }
.quiz.is-result { max-width:860px; }
.quiz__progress { display:flex; gap:8px; justify-content:center; margin-bottom:26px; min-height:8px; }
.quiz__dot { width:8px; height:8px; border-radius:50%; background:var(--border-2); transition:all var(--dur-base) var(--ease-out); }
.quiz__dot.active { background:var(--ch-indigo); width:26px; border-radius:9999px; }
.quiz__step { font-size:12.5px; font-weight:600; color:var(--ch-peach); text-transform:uppercase; letter-spacing:.06em; text-align:center; margin-bottom:10px; }
.quiz__q { font-family:var(--font-display); font-weight:700; font-size:1.5rem; line-height:1.25; text-align:center; margin-bottom:26px; color:var(--ch-navy); }
.quiz__options { display:flex; flex-direction:column; gap:12px; }
.quiz__opt { text-align:left; background:var(--ch-lilac); border:1.5px solid var(--border-1); border-radius:var(--radius-md);
  padding:16px 20px; font-family:var(--font-text); font-size:15.5px; color:var(--ch-navy); cursor:pointer;
  transition:border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-fast); display:flex; align-items:center; gap:13px; line-height:1.4; }
.quiz__opt:hover { border-color:var(--ch-indigo); background:#fff; transform:translateY(-1px); }
.quiz__opt::before { content:""; width:18px; height:18px; border-radius:50%; border:2px solid var(--border-2); flex-shrink:0; transition:border-color var(--dur-fast); }
.quiz__opt:hover::before { border-color:var(--ch-indigo); border-width:5px; }
.quiz__back { margin-top:18px; text-align:center; }
.quiz__back button { background:none; border:0; color:var(--fg-3); font-size:14px; cursor:pointer; font-family:var(--font-text); }
.quiz__back button:hover { color:var(--ch-navy); }

/* quiz — insight step */
.qr__label { text-align:center; font-size:12.5px; font-weight:600; color:var(--ch-peach); text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.qr__title { text-align:center; font-family:var(--font-display); font-weight:800; font-size:1.9rem; color:var(--ch-navy); margin-bottom:8px; }
.qr__tag { text-align:center; color:var(--fg-2); font-size:1.0625rem; margin-bottom:26px; }
.qr__insight { text-align:center; color:var(--fg-2); font-size:1.0625rem; line-height:1.7; max-width:560px; margin:0 auto 26px; }
.qr__help { max-width:460px; margin:0 auto 28px; }
.qr__help h4 { font-size:13px; text-transform:uppercase; letter-spacing:.04em; color:var(--ch-navy); margin-bottom:12px; text-align:center; }
.qr__help ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; }
.qr__help li { display:flex; gap:9px; font-size:14.5px; color:var(--fg-2); line-height:1.45; }
.qr__help li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; flex-shrink:0; }
.qr__cta-row { text-align:center; }
.qr__again { text-align:center; margin-top:20px; }
.qr__again button { background:none; border:0; color:var(--ch-indigo); font-weight:600; font-size:14px; cursor:pointer; font-family:var(--font-text); }
.qr__again button:hover { color:var(--ch-violet); }
.qr__again .qr__link { vertical-align:middle; }

/* quiz — rich offer step (in-page salespage) */
.qr__reveal { animation:qrUp .42s var(--ease-out); }
@keyframes qrUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:none; } }
.qr__reveal .qr__title { font-size:2.15rem; margin-top:2px; }
.qr__lead { text-align:center; color:var(--fg-2); font-size:1.0625rem; line-height:1.7; max-width:620px; margin:0 auto 6px; }
.qr__block { margin-top:34px; }
.qr__block h4 { font-family:var(--font-display); font-size:1.2rem; color:var(--ch-navy); margin-bottom:16px; }
.qr__cols { display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.qr__list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.qr__list li { display:flex; gap:10px; font-size:15px; color:var(--fg-2); line-height:1.5; }
.qr__list li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; flex-shrink:0; }
.qr__inhoud { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.qr__inhoud li { display:flex; gap:14px; align-items:flex-start; background:var(--ch-lilac);
  border:1px solid var(--border-1); border-radius:var(--radius-md); padding:14px 18px; }
.qr__inhoud b { display:block; color:var(--ch-navy); font-size:15px; }
.qr__inhoud span { font-size:14px; color:var(--fg-2); }
.qr__inhoud .num { flex-shrink:0; width:26px; height:26px; border-radius:50%; background:#e2dcff; color:var(--ch-indigo);
  font-weight:700; font-size:13px; display:inline-flex; align-items:center; justify-content:center; font-family:var(--font-display); }
.qr__review { background:var(--ch-peach-tint); border-radius:var(--radius-md); padding:24px 26px; margin-top:34px; }
.qr__review .stars { color:var(--ch-peach); font-size:1.1rem; letter-spacing:2px; }
.qr__review p { font-style:italic; color:var(--ch-navy); margin:10px 0 12px; line-height:1.6; font-size:1.0625rem; }
.qr__review cite { font-style:normal; font-size:13px; color:var(--fg-3); }
.qr__buy { margin-top:34px; border:1.5px solid var(--ch-indigo); border-radius:var(--radius-lg);
  background:#fff; padding:26px 28px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.qr__buy-price { display:flex; flex-direction:column; gap:4px; }
.qr__buy-price .zk { align-self:flex-start; background:var(--ch-butter); color:var(--ch-navy); font-size:12px; font-weight:700; padding:4px 11px; border-radius:9999px; }
.qr__buy-price .amt { display:flex; align-items:baseline; gap:10px; }
.qr__buy-price .now { font-family:var(--font-display); font-size:2rem; font-weight:800; color:var(--ch-navy); }
.qr__buy-price .was { color:var(--fg-3); text-decoration:line-through; font-size:1.05rem; }
.qr__buy-price small { color:var(--fg-3); font-size:12.5px; }
.qr__buy-actions { display:flex; flex-direction:column; gap:8px; align-items:stretch; }
.qr__link { font-weight:600; font-size:14px; color:var(--ch-indigo); }
.qr__link:hover { color:var(--ch-violet); }

/* ============================================================
   Course pages
   ============================================================ */
.cp-hero { position:relative; isolation:isolate; overflow:hidden; color:#fff;
  background:var(--ch-navy); padding:clamp(64px,8vw,104px) var(--site-padding); }
.cp-hero::before { content:""; position:absolute; top:-140px; right:-120px; width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(94,204,245,.22), transparent 70%); z-index:-1; }
.cp-hero::after { content:""; position:absolute; bottom:-160px; left:-120px; width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle, rgba(132,85,237,.18), transparent 70%); z-index:-1; }
.cp-hero__inner { max-width:var(--site-max); margin:0 auto; display:grid; grid-template-columns:1.25fr .85fr; gap:48px; align-items:center; }
.cp-hero__pill { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18); color:#fff; padding:7px 16px; border-radius:var(--radius-pill); font-size:13.5px; font-weight:600; }
.cp-hero h1 { color:#fff; margin:18px 0 14px; font-size:clamp(2rem,4vw,3.2rem); }
.cp-hero__tag { color:var(--ch-butter); font-family:var(--font-display); font-weight:700; font-size:1.25rem; margin-bottom:14px; }
.cp-hero__sub { color:rgba(255,255,255,.85); font-size:1.125rem; line-height:1.6; max-width:560px; }
.cp-hero__ctas { display:flex; gap:14px; flex-wrap:wrap; margin-top:26px; }
.cp-hero__meta { display:flex; gap:24px; flex-wrap:wrap; margin-top:26px; }
.cp-hero__meta span { color:rgba(255,255,255,.82); font-size:14.5px; display:inline-flex; align-items:center; gap:8px; }
.cp-hero__meta b { font-family:var(--font-display); }
.cp-hero__card { background:#fff; color:var(--fg-1); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg, 0 24px 48px -16px rgba(33,26,63,.4)); padding:26px; }
.cp-hero__card .ico-tile { margin-bottom:14px; }
.cp-hero__card h3 { font-size:1.15rem; margin-bottom:14px; }
.cp-hero__card ul { list-style:none; padding:0; margin:0 0 18px; display:flex; flex-direction:column; gap:9px; }
.cp-hero__card li { display:flex; gap:9px; font-size:14px; color:var(--fg-2); }
.cp-hero__card li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; }
.cp-hero__card .price { margin-bottom:14px; }

.prose { max-width:740px; margin:0 auto; }
.prose p { font-size:1.0625rem; color:var(--fg-2); line-height:1.75; }
.prose p + p { margin-top:16px; }

/* media row (photo + text) on course pages */
.cp-media { max-width:var(--site-max); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.cp-media--rev .cp-media__img { order:2; }
.cp-media__img { border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); aspect-ratio:4/3; }
.cp-media__img img { width:100%; height:100%; object-fit:cover; object-position:center top; }
.cp-media__body .eyebrow { color:var(--ch-peach); display:block; margin-bottom:12px; }
.cp-media__body h2 { margin-bottom:18px; }
.cp-media__body p { font-size:1.0625rem; color:var(--fg-2); line-height:1.75; }
.cp-media__body p + p { margin-top:14px; }

/* full-width warm photo band */
.cp-band { height:clamp(220px,32vw,380px); overflow:hidden; }
.cp-band img { width:100%; height:100%; object-fit:cover; }

.cp-list { max-width:740px; margin:0 auto; list-style:none; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:14px 30px; }
.cp-list li { display:flex; gap:11px; font-size:1.0625rem; color:var(--fg-1); line-height:1.5; }
.cp-list li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; flex-shrink:0; }

.cp-modules { max-width:740px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.cp-module { display:flex; gap:18px; align-items:flex-start; background:#fff; border:1px solid var(--border-1);
  border-radius:var(--radius-md); padding:20px 24px; box-shadow:var(--shadow-sm); }
.cp-module .num { flex-shrink:0; width:34px; height:34px; border-radius:50%; background:#e2dcff; color:var(--ch-indigo);
  font-weight:700; font-family:var(--font-display); display:inline-flex; align-items:center; justify-content:center; }
.cp-module b { display:block; color:var(--ch-navy); font-size:1.0625rem; margin-bottom:3px; }
.cp-module span { font-size:14.5px; color:var(--fg-2); line-height:1.5; }

/* pricing / aanmelden box */
.cp-buy { max-width:620px; margin:0 auto; background:#fff; border:1px solid var(--border-1);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-md); padding:38px 34px; text-align:center; }
.cp-buy .zk { display:inline-block; background:var(--ch-butter); color:var(--ch-navy); font-size:12.5px; font-weight:700;
  padding:5px 13px; border-radius:9999px; margin-bottom:16px; }
.cp-buy__price { display:flex; align-items:baseline; justify-content:center; gap:12px; margin-bottom:6px; }
.cp-buy__price .now { font-family:var(--font-display); font-size:3rem; font-weight:800; color:var(--ch-navy); line-height:1; }
.cp-buy__price .was { font-size:1.25rem; color:var(--fg-3); text-decoration:line-through; }
.cp-buy__note { color:var(--fg-3); font-size:14px; margin-bottom:24px; }
.cp-buy ul { list-style:none; padding:0; margin:0 auto 26px; max-width:380px; text-align:left; display:flex; flex-direction:column; gap:11px; }
.cp-buy li { display:flex; gap:11px; font-size:15px; color:var(--fg-1); }
.cp-buy li::before { content:"✓"; color:var(--ch-indigo); font-weight:700; flex-shrink:0; }
.cp-buy .btn { width:100%; }
.cp-buy__guarantee { margin-top:16px; font-size:13px; color:var(--fg-3); }

/* cookie-consent banner (Meta Pixel) */
.cookiebar { position:fixed; left:16px; right:16px; bottom:16px; z-index:200; max-width:760px; margin:0 auto;
  background:var(--ch-navy); color:#fff; border-radius:var(--radius-lg);
  box-shadow:0 24px 48px -16px rgba(33,26,63,.5); padding:18px 22px;
  display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:space-between;
  animation:qrUp .35s var(--ease-out); }
.cookiebar__txt { font-size:13.5px; color:rgba(255,255,255,.85); line-height:1.5; flex:1 1 320px; }
.cookiebar__btns { display:flex; gap:10px; flex-shrink:0; }
.cookiebar .btn { padding:10px 18px; font-size:14px; }
.cookiebar .btn-outline { background:transparent; color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.3); }
.cookiebar .btn-outline:hover { box-shadow:inset 0 0 0 1.5px #fff; }
@media (max-width:560px) { .cookiebar { flex-direction:column; align-items:stretch; } .cookiebar__btns { justify-content:flex-end; } }

/* end bar (replaces footer) */
.endbar { background:var(--ch-navy); color:rgba(255,255,255,.55); text-align:center;
  padding:28px var(--site-padding); font-size:13px; }
.endbar img { height:30px; width:auto; margin:0 auto 12px; }

/* ---------------- Responsive ---------------- */
@media (max-width:940px) {
  .header__nav { display:none; }
  .courses__grid { grid-template-columns:1fr; }
  .features__grid { grid-template-columns:repeat(2,1fr); }
  .checks { grid-template-columns:1fr; }
  .maker { grid-template-columns:1fr; gap:32px; max-width:520px; text-align:center; }
  .maker__photo img { margin:0 auto; }
  .maker__role, .maker__name { justify-content:center; align-items:center; }
  .qr__cols { grid-template-columns:1fr; gap:22px; }
  .quiz { padding:28px 22px 26px; }
  .quiz.is-result { max-width:720px; }
  .quiz__q { font-size:1.3rem; }
  .cp-hero__inner { grid-template-columns:1fr; gap:34px; }
  .cp-list { grid-template-columns:1fr; }
  .cp-media { grid-template-columns:1fr; gap:28px; max-width:560px; }
  .cp-media--rev .cp-media__img { order:0; }
  .qa-grid { grid-template-columns:1fr; }
  .qa-note { gap:10px; flex-direction:column; align-items:center; }
  .bundle { grid-template-columns:1fr; }
  .bundle__list { grid-template-columns:1fr; }
  .pkg-grid { grid-template-columns:1fr; max-width:520px; }
}
@media (max-width:600px) {
  .features__grid { grid-template-columns:1fr; }
  .price .now { font-size:1.7rem; }
  .qr__buy { flex-direction:column; align-items:stretch; text-align:center; }
  .qr__buy-price .amt { justify-content:center; }
  .qr__buy-price .zk { align-self:center; }
}
