:root {
  --bg: #14172e;
  --paneel: #1f2347;
  --paneel-rand: #313869;
  --tekst: #eef0fb;
  --zacht: #a7adcf;
  --accent: #ffd166;
  --accent-tekst: #1b1f3b;
  --goed: #3ddc97;
  --fout: #ff6b6b;
  --radius: 14px;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--tekst);
  line-height: 1.5;
}
header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--paneel-rand);
}
header h1 { font-size: 1.25rem; margin: 0; }
footer { padding: 16px 18px; text-align: center; }

main { max-width: 640px; margin: 0 auto; padding: 18px; }
h2 { margin-top: 0; }

.scherm {
  background: var(--paneel);
  border: 1px solid var(--paneel-rand);
  border-radius: var(--radius);
  padding: 20px;
}

label { display: block; margin: 12px 0; font-weight: 600; color: var(--zacht); }
label input[type="text"], label input[type="number"], input[type="file"] {
  display: block; width: 100%; margin-top: 6px;
  padding: 12px; font-size: 1rem;
  border-radius: 10px; border: 1px solid var(--paneel-rand);
  background: var(--bg); color: var(--tekst);
}
.check { font-weight: 500; color: var(--tekst); }
.check input { margin-right: 8px; }

.knoppen { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.knop {
  appearance: none; cursor: pointer;
  background: var(--accent); color: var(--accent-tekst);
  border: 0; border-radius: 12px; padding: 14px 20px;
  font-size: 1rem; font-weight: 700;
}
.knop:hover { filter: brightness(1.05); }
.knop:disabled { opacity: .5; cursor: not-allowed; }
.knop.secundair { background: transparent; color: var(--tekst); border: 1px solid var(--paneel-rand); }
.knop.klein { padding: 8px 12px; font-size: .9rem; }
.mt { margin-top: 10px; }
.deelinfo code { word-break: break-all; }

.hint, .meta { color: var(--zacht); font-size: .9rem; }
.fout { color: var(--fout); }
.badge { background: var(--paneel); border: 1px solid var(--paneel-rand); border-radius: 999px; padding: 4px 12px; font-size: .85rem; color: var(--zacht); }
code { background: var(--bg); padding: 2px 6px; border-radius: 6px; }

fieldset { border: 1px solid var(--paneel-rand); border-radius: 12px; margin: 14px 0; }
legend { padding: 0 8px; color: var(--zacht); }
.lijst { list-style: none; padding: 0; margin: 0; }
.lijst h4 { margin: 12px 0 4px; color: var(--accent); font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; }
.lijst li { padding: 8px 12px; background: var(--bg); border-radius: 8px; margin: 6px 0; }

.deelinfo { background: var(--bg); border: 1px dashed var(--paneel-rand); border-radius: 10px; padding: 12px; margin-bottom: 16px; }
.qr { background: #fff; padding: 12px; border-radius: 12px; display: inline-block; margin: 10px 0; }
.qr svg { width: 220px; height: 220px; display: block; }

.timer { font-size: 1.6rem; font-weight: 800; color: var(--accent); margin: 8px 0; }

.opties { list-style: decimal; padding-left: 1.2em; }
.opties li { padding: 10px 12px; margin: 8px 0; background: var(--bg); border-radius: 10px; border: 1px solid var(--paneel-rand); }
.opties li.goed { border-color: var(--goed); box-shadow: 0 0 0 1px var(--goed) inset; }
.opties li.fout { border-color: var(--fout); box-shadow: 0 0 0 1px var(--fout) inset; }
.uitleg { color: var(--zacht); font-size: .9rem; margin-top: 6px; }

.opties-knoppen { display: grid; gap: 12px; margin: 16px 0; }
.optie {
  text-align: left; cursor: pointer;
  background: var(--bg); color: var(--tekst);
  border: 1px solid var(--paneel-rand); border-radius: 12px;
  padding: 16px; font-size: 1.05rem;
}
.optie:hover:not(:disabled) { border-color: var(--accent); }
.optie:disabled { opacity: .7; cursor: default; }
.optie.gekozen { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent) inset; }

.scorebord { list-style: none; padding: 0; counter-reset: rang; }
.scorebord li {
  counter-increment: rang;
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px; margin: 6px 0; background: var(--bg); border-radius: 10px;
}
.scorebord li::before { content: counter(rang) "."; color: var(--zacht); margin-right: 10px; }
.scorebord .pt { font-weight: 800; color: var(--accent); }
.scorebord.groot li { font-size: 1.15rem; padding: 14px 18px; }
