:root{
  --bg:#f4f5f7; --card:#fff; --ink:#111827; --muted:#6b7280; --line:#e5e7eb;
  --accent:#111827; --accent-h:#374151; --ok:#2f9e44; --err:#e03131;
  --radius:14px; --shadow:0 1px 3px rgba(16,24,40,.06),0 1px 2px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
body{margin:0;font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink)}
a{color:inherit;text-decoration:none}

/* Topbar */
.topbar{display:flex;align-items:center;gap:22px;background:#fff;border-bottom:1px solid var(--line);
  padding:0 20px;height:58px;position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:9px;font-size:17px;color:var(--accent)}
.brand span{color:var(--ink);font-weight:500}.brand b{font-weight:700}
.topbar nav{display:flex;gap:4px;margin-left:8px}
.topbar nav a{display:flex;align-items:center;gap:7px;padding:8px 13px;border-radius:9px;color:var(--muted);font-weight:500}
.topbar nav a:hover{background:#f3f4f6;color:var(--ink)}
.topbar nav a.on{background:#111827;color:#fff}
.topbar .event{margin-left:auto;color:var(--muted);font-size:13px}
.topbar .uitlog{display:flex;align-items:center;padding:8px;border-radius:8px;color:var(--muted)}
.topbar .uitlog:hover{background:#f3f4f6;color:var(--err)}

main{max-width:1080px;margin:0 auto;padding:26px 20px 60px}

h1{font-size:22px;margin:0 0 4px}
.sub{color:var(--muted);margin:0 0 22px}

/* Kaarten */
.grid{display:grid;gap:16px}
.cards{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.stat{display:flex;flex-direction:column;gap:2px}
.stat .n{font-size:30px;font-weight:700;line-height:1}
.stat .l{color:var(--muted);font-size:13px}
.stat .bar{height:6px;border-radius:4px;margin-top:8px;background:#eee;overflow:hidden}
.stat .bar>span{display:block;height:100%}

/* Tabel */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-top:18px}
.panel .head{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line)}
.panel .head h2{font-size:15px;margin:0}
.panel .head .r{margin-left:auto;display:flex;gap:8px}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--muted);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:#fafafa}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;color:var(--muted)}

/* Categorie-badge */
.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}

/* Knoppen */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#fff;color:var(--ink);
  padding:8px 14px;border-radius:9px;font-weight:600;font-size:14px;cursor:pointer}
.btn:hover{background:#f7f7f8}
.btn.pri{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.pri:hover{background:var(--accent-h)}
.btn.sm{padding:5px 10px;font-size:13px}
.btn svg{width:16px;height:16px}

/* Formulier */
form.stack{display:grid;gap:14px;max-width:520px}
label{display:block;font-weight:600;font-size:13px;margin-bottom:5px}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid #cbd5e1;border-color:var(--accent)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hint{color:var(--muted);font-size:12.5px;margin-top:4px}

/* Zebra-banner */
.zbanner{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:11px;margin:0 0 20px;font-size:14px}
.zbanner svg{flex:0 0 auto}
.zbanner div{flex:1}
.zbanner.ok{background:#ecfdf3;border:1px solid #abefc6;color:#067647}
.zbanner.warn{background:#fffaeb;border:1px solid #fedf89;color:#b54708}
.zbanner.info{background:#f8fafc;border:1px solid var(--line);color:var(--muted)}
.zbanner .btn{flex:0 0 auto}

/* Uur-grafiek (dashboard) */
.uurchart{display:flex;align-items:flex-end;gap:6px;height:150px;overflow-x:auto;padding-top:6px}
.uurchart .ub{flex:1;min-width:26px;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}
.uurchart .ub-bar{width:70%;background:var(--accent);border-radius:5px 5px 0 0;min-height:4px;transition:.2s}
.uurchart .ub:hover .ub-bar{background:var(--accent-h)}
.uurchart .ub-n{font-size:11px;font-weight:700;margin-top:4px;color:var(--ink)}
.uurchart .ub-h{font-size:11px;color:var(--muted)}

/* Personenformulier */
.pform fieldset{border:1px solid var(--line);border-radius:12px;padding:14px 16px 16px;margin:0 0 14px}
.pform legend{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 6px}
.pform .fg{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}
.pform textarea{resize:vertical}
.mslider{margin:10px 0}
.mslider label{display:flex;justify-content:space-between;font-weight:600;font-size:13.5px;margin-bottom:4px}
.mslider label b{font-weight:700}
.mslider input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}
.dagcheck{display:flex;flex-wrap:wrap;gap:8px}
.dagcheck .dc{display:inline-flex;align-items:center;gap:6px;font-weight:500;background:#f7f8fa;border:1px solid var(--line);
  border-radius:8px;padding:7px 12px;cursor:pointer;margin:0}
.dagcheck .dc input{width:auto;margin:0}

/* Polsbandje-preview (zoals het echte Sunrise-bandje): kleur = fysieke band, opdruk zwart. */
.wristband{width:760px;max-width:100%;height:110px;border-radius:8px;box-shadow:0 5px 20px rgba(0,0,0,.16);
  display:flex;align-items:center;gap:14px;padding:0 16px;overflow:hidden;color:#111;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.wristband .w-logo{flex:0 0 auto;width:56px;display:flex;align-items:center;justify-content:center}
.wristband .w-logo img{max-width:56px;max-height:56px;object-fit:contain;mix-blend-mode:multiply}
.wristband .w-body{flex:1;min-width:0;text-align:center;display:flex;flex-direction:column;justify-content:center}
.wristband .w-pers{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wristband .w-reeks{font-size:40px;font-weight:800;letter-spacing:.12em;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.wristband .w-onder{font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;opacity:.85;margin-top:2px}
.wristband .w-qr{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;background:#fff;border-radius:7px;padding:6px 8px}
.wristband .w-qr .qrbox{width:92px;height:92px}
.wristband .w-qr .qrbox svg{width:100%;height:100%;display:block}
.wristband .w-qr .bcbox{width:140px;height:42px}
.wristband .w-qr .bcbox svg{width:100%;height:100%;display:block}
.wristband .w-qr .code{font-family:ui-monospace,monospace;font-size:9px;color:#111;letter-spacing:.06em;margin-top:2px}
.wb-hint{max-width:760px;margin:14px auto 0;color:var(--muted);font-size:12.5px;text-align:center}

/* Scanpost */
.scan-wrap{max-width:640px;margin:0 auto;text-align:center}
.scan-input{font-size:22px;text-align:center;letter-spacing:.1em;padding:16px}
.scan-res{margin-top:22px;border-radius:18px;padding:34px 24px;color:#fff;min-height:200px;display:flex;
  flex-direction:column;justify-content:center;align-items:center;gap:6px;transition:.15s}
.scan-res.idle{background:#e9ecef;color:#868e96}
.scan-res.ok{background:var(--ok)}
.scan-res.err{background:var(--err)}
.scan-res .big{font-size:38px;font-weight:800;line-height:1.1}
.scan-res .mid{font-size:20px;font-weight:600;opacity:.95}
.scan-res .small{font-size:15px;opacity:.9}
.scan-res .icon{width:56px;height:56px}
.counters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:22px}
.counters .c{background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-size:13px;box-shadow:var(--shadow)}
.counters .c b{font-size:18px;display:block}

/* Zoek-overlay */
.modal{position:fixed;inset:0;background:rgba(17,24,39,.55);z-index:50;align-items:flex-start;justify-content:center}
.modal-box{background:#fff;border-radius:14px;width:min(560px,92vw);margin-top:8vh;padding:18px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.modal-box #zoekveld{font-size:17px;padding:12px}
.zoekres{margin-top:12px;max-height:52vh;overflow:auto;display:flex;flex-direction:column;gap:6px}
.zr-item{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;
  background:#fff;border:1px solid var(--line);border-radius:9px;padding:11px 13px;cursor:pointer;font:inherit}
.zr-item:hover{background:#f7f8fa;border-color:#cbd5e1}
.zr-leeg{color:var(--muted);text-align:center;padding:18px}

.flash{background:#ecfdf3;border:1px solid #abefc6;color:#067647;padding:11px 15px;border-radius:10px;margin-bottom:16px;font-weight:600}
.empty{padding:40px;text-align:center;color:var(--muted)}

@media print{
  .topbar,.panel .head,.btn,.no-print{display:none!important}
  body{background:#fff}
  main{padding:0}
}

/* Inklapbaar "Persoon toevoegen" */
details.toevoegpanel>summary{cursor:pointer;list-style:none;user-select:none}
details.toevoegpanel>summary::-webkit-details-marker{display:none}
details.toevoegpanel>summary .tog::before{content:"＋";font-weight:800;margin-right:8px;color:var(--muted)}
details.toevoegpanel[open]>summary .tog::before{content:"－"}
