:root{
  /* ===== HUISSTIJL: pas deze kleuren aan naar je eigen branding ===== */
  --accent:#0e6b66;        /* hoofdkleur (knoppen, koppen) */
  --accent-soft:#e3f1f0;   /* lichte tint van de hoofdkleur */
  --warm:#c96f2e;          /* accentkleur (voortgang, highlights) */
  --warm-soft:#faeede;
  --ink:#22302f;           /* tekstkleur */
  --muted:#5d6b6a;
  --bg:#f6f7f6;
  --card:#ffffff;
  --good:#1d7a3c; --good-soft:#e4f3e9;
  --bad:#b3372f;  --bad-soft:#fbe9e7;
  --radius:14px;
  --shadow:0 1px 3px rgba(34,48,47,.08), 0 4px 16px rgba(34,48,47,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:17px;line-height:1.6}
button{font:inherit;cursor:pointer}
textarea,input[type=text],input[type=email],input[type=password],select{font:inherit;color:var(--ink);width:100%;border:1.5px solid #c8d2d1;border-radius:10px;padding:10px 12px;background:#fff}
textarea:focus,input:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}
textarea{resize:vertical;min-height:64px}

header.top{position:sticky;top:0;z-index:30;background:var(--card);box-shadow:var(--shadow)}
.top-inner{max-width:860px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;gap:12px}
.brand{font-weight:700;color:var(--accent);font-size:15px;letter-spacing:.2px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbtn{background:var(--accent-soft);color:var(--accent);border:none;border-radius:999px;padding:7px 14px;font-weight:600;font-size:14px}
.topbtn:hover{filter:brightness(.96)}
.progress-track{height:5px;background:#e4e8e7}
.progress-fill{height:100%;background:var(--warm);width:0%;transition:width .4s}

main{max-width:860px;margin:0 auto;padding:22px 16px 130px}
.screen{animation:fadein .35s}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.kicker{font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--warm);margin:0 0 6px}
h1{font-size:30px;line-height:1.2;margin:0 0 14px;color:var(--accent)}
h2{font-size:22px;margin:26px 0 10px;color:var(--accent)}
h3{font-size:17px;margin:18px 0 8px}
p{margin:0 0 12px}
.lead{font-size:19px}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin:0 0 16px}
.card .label{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 8px}
.mailcard{background:#fffdf7;border:1px solid #ece5d2;border-radius:var(--radius);padding:16px 18px;margin:0 0 16px;font-size:16.5px}
.note{background:var(--accent-soft);border-radius:var(--radius);padding:14px 18px;margin:14px 0;font-size:16px}
.note b{color:var(--accent)}
.insight{background:var(--warm-soft);border-left:4px solid var(--warm);border-radius:0 var(--radius) var(--radius) 0;padding:14px 18px;margin:14px 0}
.gelukt{background:var(--good-soft);border-radius:10px;padding:10px 14px;margin:12px 0;font-size:15px}
.muted{color:var(--muted);font-size:15px}
.small{font-size:14px;color:var(--muted)}

.opt{display:block;width:100%;text-align:left;background:var(--card);border:1.5px solid #c8d2d1;border-radius:10px;padding:11px 14px;margin:8px 0;transition:.15s}
.opt:hover{border-color:var(--accent)}
.opt.sel{border-color:var(--accent);background:var(--accent-soft)}
.opt.good{border-color:var(--good);background:var(--good-soft)}
.opt.bad{border-color:var(--bad);background:var(--bad-soft)}
.opt:disabled{cursor:default;opacity:.92}

.sentence{cursor:pointer;border-radius:6px;padding:1px 3px;transition:.15s}
.sentence:hover{background:var(--accent-soft)}
.sentence.good{background:var(--good-soft);outline:2px solid var(--good)}
.sentence.bad{background:var(--bad-soft);outline:2px solid var(--bad)}
.sentence.lock{cursor:default}
.sentence.lock:hover{background:inherit}
.sentence.good.lock:hover{background:var(--good-soft)}

.feedback{border-radius:10px;padding:12px 16px;margin:10px 0;display:none}
.feedback.show{display:block;animation:fadein .3s}
.feedback.ok{background:var(--good-soft);border:1px solid #bfdfc9}
.feedback.err{background:var(--bad-soft);border:1px solid #ecc6c2}

.btn{background:var(--accent);color:#fff;border:none;border-radius:999px;padding:11px 22px;font-weight:600;font-size:16px}
.btn:hover{filter:brightness(1.08)}
.btn:disabled{background:#b9c4c3;cursor:not-allowed}
.btn.ghost{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}
.btn.small{padding:7px 16px;font-size:14px}

.checkrow{display:flex;gap:10px;align-items:flex-start;margin:8px 0;background:var(--card);border:1.5px solid #c8d2d1;border-radius:10px;padding:10px 14px;cursor:pointer}
.checkrow input{width:auto;margin-top:5px}
.checkrow.good{border-color:var(--good);background:var(--good-soft)}
.checkrow.bad{border-color:var(--bad);background:var(--bad-soft)}

.namechips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.chip{border:1.5px solid #c8d2d1;background:var(--card);border-radius:999px;padding:7px 15px;font-size:15px}
.chip.sel{border-color:var(--accent);background:var(--accent-soft);font-weight:600}
.chip.good{border-color:var(--good);background:var(--good-soft);font-weight:600}
.chip.bad{border-color:var(--bad);background:var(--bad-soft)}

.vraagblok{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px;margin:0 0 16px}
.vraagblok .qnum{display:inline-block;background:var(--accent);color:#fff;border-radius:999px;font-size:13px;font-weight:700;padding:2px 10px;margin-bottom:8px}

table.vergelijk{width:100%;border-collapse:collapse;margin:10px 0;font-size:15.5px}
table.vergelijk th,table.vergelijk td{border:1px solid #d8dedd;padding:8px 10px;text-align:left;vertical-align:top}
table.vergelijk th{background:var(--accent-soft);color:var(--accent)}

.tickrow{display:flex;gap:10px;align-items:flex-start;background:var(--card);border:1.5px solid #c8d2d1;border-radius:10px;padding:10px 14px;margin:8px 0}
.tickrow .txt{flex:1}
.tickbtns{display:flex;gap:6px;flex-shrink:0}
.tick{border:1.5px solid #c8d2d1;background:#fff;border-radius:8px;width:42px;height:38px;font-size:17px}
.tick.sel{border-color:var(--accent);background:var(--accent-soft)}
.tickrow.good{border-color:var(--good);background:var(--good-soft)}
.tickrow.bad{border-color:var(--bad);background:var(--bad-soft)}

.verboden{color:var(--bad);font-size:14.5px;font-weight:600;display:none;margin-top:6px}
.verboden.show{display:block}

.preview{background:#f2f5f4;border:1.5px dashed #aebcbb;border-radius:10px;padding:14px 16px;margin:10px 0;white-space:pre-wrap;font-size:15.5px}

.kaartfab{position:fixed;right:18px;bottom:84px;z-index:40;background:var(--warm);color:#fff;border:none;border-radius:999px;padding:12px 20px;font-weight:700;font-size:15px;box-shadow:var(--shadow)}
.panel{position:fixed;top:0;right:0;height:100%;width:min(440px,100%);background:var(--card);z-index:60;box-shadow:-8px 0 30px rgba(0,0,0,.18);transform:translateX(105%);transition:transform .3s;overflow-y:auto;padding:20px 22px 40px}
.panel.open{transform:none}
.panel h2{margin-top:18px;font-size:18px}
.panel table{font-size:14px}
.overlay{position:fixed;inset:0;background:rgba(20,30,29,.35);z-index:50;display:none}
.overlay.show{display:block}
.sluit{float:right;background:var(--accent-soft);border:none;border-radius:999px;width:36px;height:36px;font-size:17px;color:var(--accent)}

nav.bottom{position:fixed;bottom:0;left:0;right:0;background:var(--card);box-shadow:0 -2px 12px rgba(34,48,47,.1);z-index:30}
.bottom-inner{max-width:860px;margin:0 auto;padding:12px 16px;display:flex;gap:10px;align-items:center}
.bottom-inner .stap{flex:1;text-align:center;font-size:14px;color:var(--muted)}
.navhint{font-size:13.5px;color:var(--warm);font-weight:600;text-align:center;padding:0 16px 8px;display:none;max-width:860px;margin:0 auto}
.navhint.show{display:block}

.menu{position:fixed;top:0;left:0;height:100%;width:min(380px,100%);background:var(--card);z-index:60;box-shadow:8px 0 30px rgba(0,0,0,.18);transform:translateX(-105%);transition:transform .3s;overflow-y:auto;padding:20px 22px 40px}
.menu.open{transform:none}
.menu .groep{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:18px 0 6px}
.menu button.item{display:block;width:100%;text-align:left;background:none;border:none;padding:9px 10px;border-radius:8px;font-size:15px;color:var(--ink)}
.menu button.item:hover{background:var(--accent-soft)}
.menu button.item.huidig{background:var(--accent-soft);font-weight:700;color:var(--accent)}
.menu button.item:disabled{color:#aab6b5;cursor:not-allowed}
.menu button.item .vink{color:var(--good);font-weight:700}

.stapkop{display:flex;align-items:center;gap:10px;margin:22px 0 8px}
.stapkop .bol{background:var(--accent);color:#fff;border-radius:999px;min-width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.stapkop .bol.dicht{background:#b9c4c3}
.stapkop h3{margin:0}
.stapinhoud{border-left:2px solid #d8dedd;margin-left:14px;padding:4px 0 8px 24px}
.stapinhoud.dicht{display:none}

.cast{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0}
.cast span{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:6px 14px;font-weight:600;font-size:15px}

/* ===== Login (testfase) ===== */
.loginwrap{position:fixed;inset:0;background:var(--bg);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto}
.logincard{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 28px;max-width:440px;width:100%;margin:auto}
.logincard h1{font-size:24px}
.logincard label{display:block;font-size:14px;font-weight:600;margin:14px 0 4px;color:var(--muted)}
.loginfout{color:var(--bad);font-size:14.5px;font-weight:600;margin-top:10px;display:none}
.loginfout.show{display:block}
.loginterug{display:inline-block;margin:0 0 14px;font-size:14px;color:var(--muted);text-decoration:none}
.loginterug:hover{color:var(--accent);text-decoration:underline}
.loginreset{margin-top:10px;padding:10px 12px;border-radius:12px;background:var(--accent-soft);color:var(--ink);font-size:14px;line-height:1.45}

/* ===== Feedback (testfase) ===== */
.fbfab{position:fixed;left:18px;bottom:84px;z-index:40;background:var(--accent);color:#fff;border:none;border-radius:999px;padding:12px 18px;font-weight:700;font-size:15px;box-shadow:var(--shadow)}
.fbpanel{position:fixed;left:18px;bottom:142px;z-index:70;background:var(--card);border-radius:var(--radius);box-shadow:0 8px 30px rgba(0,0,0,.25);padding:18px 20px;width:min(380px,calc(100% - 36px));display:none}
.fbpanel.open{display:block;animation:fadein .25s}
.fbpanel h2{margin:0 0 6px;font-size:18px}

@media(max-width:640px){
  body{font-size:16px}
  h1{font-size:25px}
  .kaartfab{bottom:76px;right:12px;padding:10px 16px}
  .fbfab{bottom:76px;left:12px;padding:10px 14px}
  .fbpanel{left:12px;bottom:130px}
}
@media print{
  header.top,nav.bottom,.kaartfab,.fbfab,.fbpanel,.loginwrap,.btn{display:none!important}
  body{background:#fff}
}

/* ===== Deel-banners en overgangen ===== */
.deelbanner{display:flex;align-items:center;gap:14px;background:var(--accent-soft);border-radius:var(--radius);padding:12px 18px;margin:0 0 18px;flex-wrap:wrap}
.deelbanner .dbnum{font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--warm);white-space:nowrap}
.deelbanner .dbnaam{font-weight:700;color:var(--accent);flex:1;min-width:140px}
.deelbanner .dbdots{display:flex;gap:5px}
.deelbanner .dot{width:10px;height:10px;border-radius:99px;background:#cfdedd}
.deelbanner .dot.aan{background:var(--warm)}
.deelbanner.af{background:var(--good-soft)}
.deelbanner.af .dbnum{color:var(--good)}
.deelbanner.af .dot.aan{background:var(--good)}

/* ===== Inklapbare bron-kopie (geen scrollen bij vervolgvragen) ===== */
details.bron{background:#f2f5f4;border:1.5px dashed #aebcbb;border-radius:10px;padding:10px 16px;margin:12px 0}
details.bron summary{cursor:pointer;font-weight:600;color:var(--accent);font-size:15px}
details.bron .card,details.bron .mailcard{box-shadow:none;border:1px solid #dde4e3;margin-top:10px}

/* ===== Hulpkaart-uitlegscherm ===== */
.toolkaart{display:flex;gap:14px;align-items:flex-start;width:100%;text-align:left;background:var(--card);border:1.5px solid #c8d2d1;border-radius:var(--radius);padding:14px 16px;margin:0 0 10px;transition:.15s}
.toolkaart:hover{border-color:var(--accent)}
.toolkaart .ticoon{font-size:22px;line-height:1.2}
.toolkaart .ttxt{flex:1;display:block}
.toolkaart .tuitleg{display:none;margin-top:6px;color:var(--muted);font-size:15px}
.toolkaart.open{border-color:var(--accent);background:var(--accent-soft)}
.toolkaart.open .tuitleg{display:block}

/* ===== Plek-visualisatie (oefening 4) ===== */
svg.plekviz{width:100%;height:auto;margin:4px 0 10px;font-family:inherit}

/* ===== Koppel-oefening (hulpkaartscherm) ===== */
.matchkaart{display:block;width:100%;text-align:left;background:var(--card);border:1.5px solid #c8d2d1;border-radius:10px;padding:11px 14px;margin:8px 0;transition:.15s;font-size:15.5px}
.matchkaart:hover{border-color:var(--accent)}
.matchkaart.good{border-color:var(--good);background:var(--good-soft);cursor:default}

/* ===== AI-meekijker ===== */
.aifb{background:var(--accent-soft);border-left:4px solid var(--accent);border-radius:0 10px 10px 0;padding:12px 16px;margin:10px 0;font-size:15.5px}
.aiknop{margin-top:8px}
