/* ============================================================
   AIpraatplaat — live-modus (docentkant)
   Deelnemersrechten · interactieve tools · pushen · brillen
   Vensters lenen de stijl van het hotspot-venster.
   ============================================================ */

/* ---- geplaatste interactieve-tool iconen op de plaat ----
   Verankerd aan de illustratie: center-positie (left/top = midden) + schaal,
   gezet vanuit JS. Cirkelvorm, geen titel. */
.tool-icon {
  position: absolute; z-index: 8;
  width: 46px; height: 46px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--accent, var(--plaat-sky, #c5d6e2));
  border: none;
  /* zelfde contour-/schaduwstijl als de stickynotes, maar cirkelvormig */
  box-shadow: 0 10px 22px rgba(33,30,26,0.20), 0 2px 5px rgba(33,30,26,0.12);
  cursor: pointer; user-select: none; touch-action: none; color: var(--ink);
  transform: translate(-50%, -50%);
  transition: box-shadow var(--dur-fast,140ms) var(--ease-soft);
}
.tool-icon:hover { box-shadow: 0 0 0 4px rgba(255,255,255,0.5), 0 12px 26px rgba(33,30,26,0.28); }
.tool-icon.dragging { transition: none; }
.tool-icon .ti-badge { display: grid; place-items: center; pointer-events: none; }
.tool-icon .ti-badge svg { width: 23px; height: 23px; }
.tool-icon .ti-lock {
  position: absolute; right: -3px; bottom: -3px; display: none;
  width: 19px; height: 19px; padding: 2.5px; border-radius: 50%;
  background: var(--paper, #faf6ef); border: 1.5px solid var(--ink, #2b2722); color: var(--ink);
}
.tool-icon .ti-lock svg { width: 100%; height: 100%; }
.tool-icon.locked { border: 1.5px dashed var(--ink, #2b2722); }
.tool-icon.locked .ti-lock { display: block; }
.tool-icon.pushed { box-shadow: 0 0 0 3px rgba(217,119,87,0.35), 0 8px 20px rgba(33,30,26,0.24); }

/* verplaatsen = zwevend hangertje met pinpoint (zelfde cue als bij plaatsen) */
.tool-icon .ti-pin {
  position: absolute; left: 50%; top: 50%; width: 23px; height: 31px;
  transform-origin: bottom center; transform: translate(-50%, -100%) scale(0.55);
  opacity: 0; pointer-events: none; z-index: 12;
  filter: drop-shadow(0 5px 9px rgba(33,30,26,0.30));
  transition: opacity var(--dur-fast,140ms) var(--ease-soft), transform var(--dur-base,240ms) var(--ease-soft);
}
.tool-icon .ti-pin svg { width: 100%; height: 100%; display: block; }
.tool-icon.dragging .ti-pin { opacity: 1; transform: translate(-50%, -100%) scale(1); }
.tool-icon.dragging { box-shadow: 0 0 0 4px rgba(255,255,255,0.5), 0 18px 34px rgba(33,30,26,0.30); }

/* ============ VENSTER (hotspot-stijl) ============ */
.hwin-layer {
  position: absolute; inset: 0; z-index: 120; display: none;
  align-items: center; justify-content: center;
  padding: clamp(14px,3.5vh,40px) clamp(14px,3vw,44px);
}
.hwin-layer.open { display: flex; }
.hwin-back { position: absolute; inset: 0; background: rgba(33,30,26,0.34); backdrop-filter: blur(3px); opacity: 0; transition: opacity var(--dur-base,240ms) var(--ease-soft); }
.hwin-layer.open .hwin-back { opacity: 1; }
.hwin {
  position: relative; display: flex; flex-direction: column;
  width: min(1040px, 100%); height: min(680px, 100%);
  background: var(--paper, #faf6ef); border-radius: var(--r-2xl, 22px);
  border: 1px solid rgba(43,39,34,0.10);
  box-shadow: 0 40px 100px rgba(33,30,26,0.30), 0 6px 18px rgba(33,30,26,0.12);
  overflow: hidden;
  transform: translateY(12px) scale(0.985); opacity: 0;
  transition: transform var(--dur-base,240ms) var(--ease-soft), opacity var(--dur-base,240ms) var(--ease-soft);
}
.hwin-layer.open .hwin { transform: none; opacity: 1; }
.hwin.small { width: min(720px, 100%); height: min(560px, 100%); }

.hwin-top { flex: 0 0 auto; display: flex; align-items: center; gap: 16px; padding: 16px 16px 16px 26px; border-bottom: 1px solid var(--line-soft, rgba(43,39,34,.08)); }

/* getinte kop per interactietool — eigen zachte kleur + icoonchip */
.hwin-top.tinted {
  padding-left: 18px;
  background: color-mix(in srgb, var(--tool-accent, #c5d6e2) 34%, var(--paper, #faf6ef));
  border-bottom-color: color-mix(in srgb, var(--tool-accent, #c5d6e2) 55%, transparent);
}
.hwin-ic {
  flex: 0 0 auto; width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center;
  background: var(--tool-accent, #c5d6e2); color: var(--ink, #2b2722);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.35), 0 2px 6px rgba(33,30,26,0.10);
}
.hwin-ic svg { width: 25px; height: 25px; }
.hwin-top.tinted .hwin-eyebrow { color: color-mix(in srgb, var(--ink, #2b2722) 62%, transparent); }
.hwin-titles { flex: 1 1 auto; min-width: 0; }
.hwin-eyebrow { font-size: 11px; letter-spacing: 0.09em; text-transform: uppercase; color: var(--ink-muted); margin: 0 0 3px; font-weight: 600; }
.hwin-title { margin: 0; font-family: var(--font-serif); font-weight: 400; font-size: clamp(20px,2vw,27px); line-height: 1.1; letter-spacing: -0.02em; color: var(--ink); }
.hwin-title .it { font-style: italic; color: var(--accent-coral-hex,#d97757); }
.hwin-top-actions { flex: 0 0 auto; display: flex; align-items: center; gap: 8px; }
.hwin-close { width: 40px; height: 40px; display: grid; place-items: center; border-radius: var(--r-md,12px); border: 1px solid rgba(43,39,34,0.10); background: transparent; color: var(--ink-soft); cursor: pointer; transition: background var(--dur-fast,140ms) var(--ease-soft), color var(--dur-fast,140ms) var(--ease-soft); }
.hwin-close:hover { background: rgba(43,39,34,0.05); color: var(--ink); }
.hwin-close svg { width: 18px; height: 18px; }

.hwin-main { flex: 1 1 auto; min-height: 0; display: flex; }
.hwin-fig { flex: 1 1 auto; min-width: 0; display: flex; align-items: center; justify-content: center; padding: clamp(10px,1.4vw,22px); background: var(--plaat-sky, #c5d6e2); }
.hwin-fig.zone-green { background: var(--plaat-sage, #cdd9be); }
.hwin-fig.zone-cream { background: var(--plaat-cream, #f0e3c4); }
.hwin-fig.zone-lilac { background: var(--plaat-lilac, #d9d0e6); }
.hwin-side { flex: 0 0 clamp(320px, 36%, 420px); display: flex; flex-direction: column; min-height: 0; border-left: 1px solid var(--line-soft, rgba(43,39,34,.08)); background: rgba(255,253,249,0.5); }
.hwin-scroll { flex: 1 1 auto; overflow-y: auto; padding: 18px 20px; }
.hwin-scroll::-webkit-scrollbar { width: 9px; }
.hwin-scroll::-webkit-scrollbar-thumb { background: rgba(43,39,34,0.16); border-radius: 99px; border: 2px solid var(--paper,#faf6ef); }
.hwin-full { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 22px 26px; }

.hwin-foot { flex: 0 0 auto; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 13px 20px; border-top: 1px solid var(--line-soft, rgba(43,39,34,.08)); background: rgba(245,236,219,0.45); }
.hwin-foot .spacer { flex: 1 1 auto; }

/* "Schets" placeholder voor afbeelding */
.sketch-ph { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: var(--ink-soft); width: 100%; height: 100%; }
.sketch-ph svg { width: 54px; height: 54px; opacity: 0.55; }
.sketch-ph span { font-family: var(--font-serif); font-style: italic; font-size: 26px; color: var(--ink-soft); }

/* ---- knoppen ---- */
.hbtn {
  appearance: none; cursor: pointer; border-radius: var(--r-pill, 999px);
  font-family: var(--font-sans); font-size: 13.5px; font-weight: 600;
  padding: 9px 16px; display: inline-flex; align-items: center; gap: 7px;
  border: 1px solid rgba(43,39,34,0.14); background: var(--paper,#faf6ef); color: var(--ink-soft);
  transition: transform var(--dur-fast,140ms) var(--ease-soft), border-color var(--dur-fast,140ms) var(--ease-soft), background var(--dur-fast,140ms) var(--ease-soft), color var(--dur-fast,140ms) var(--ease-soft);
}
.hbtn svg { width: 16px; height: 16px; }
.hbtn:hover { border-color: var(--ink); color: var(--ink); transform: translateY(-1px); }
.hbtn.primary { background: var(--accent-coral-hex,#d97757); border-color: var(--accent-coral-hex,#d97757); color: #fff; }
.hbtn.primary:hover { color: #fff; }
.hbtn.danger:hover { border-color: #b4502f; color: #b4502f; }
.hbtn.primary.danger { background: #b4502f; border-color: #b4502f; color: #fff; }
.hbtn.primary.danger:hover { background: #9d4429; border-color: #9d4429; color: #fff; }
.hbtn.ghost { background: transparent; }

/* ---- toggle (lock/unlock) ---- */
.lockbar { display: flex; align-items: center; gap: 12px; padding: 13px 14px; border-radius: var(--r-lg, 14px); background: var(--paper, #faf6ef); border: 1px solid rgba(43,39,34,0.10); margin-bottom: 9px; }
.lockbar.sub { margin-left: 22px; background: rgba(245,236,219,0.5); }
.lockbar .lb-icon { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; background: rgba(43,39,34,0.05); color: var(--ink-soft); }
.lockbar .lb-icon svg { width: 17px; height: 17px; }
.lockbar .lb-label { flex: 1 1 auto; min-width: 0; }
.lockbar .lb-label .t { font-size: 14.5px; font-weight: 600; color: var(--ink); }
.lockbar .lb-label .s { font-size: 12px; color: var(--ink-muted); margin-top: 1px; }
.lockbar.locked { background: rgba(180,80,47,0.06); border-color: rgba(180,80,47,0.22); }
.lockbar.locked .lb-icon { background: rgba(180,80,47,0.12); color: #b4502f; }

/* ============ DEELNEMERSRECHTEN — template van een hotspotvenster ============ */
.perm-wrap { position: relative; flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 20px clamp(18px,2.4vw,34px) 28px; }
.perm-intro { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 18px; }
.perm-lead { margin: 0; max-width: 60ch; font-size: 14.5px; line-height: 1.55; color: var(--ink-soft); }
.perm-lead b { color: var(--ink); }
.perm-legend { display: flex; gap: 14px; flex-wrap: wrap; flex: 0 0 auto; }
.perm-legend .pl { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--ink-soft); }
.perm-legend .pl i { width: 11px; height: 11px; border-radius: 3px; }
.perm-legend .pl.on i { background: var(--accent-green, #4f7a4e); }
.perm-legend .pl.off i { background: rgba(43,39,34,0.28); }
.perm-legend .pl.hide i { background: repeating-linear-gradient(45deg, rgba(43,39,34,0.22) 0 3px, transparent 3px 6px); border: 1px solid rgba(43,39,34,0.2); }

/* het template-paneel zelf — echoot het hotspotvenster */
.perm-template {
  border: 1px solid rgba(43,39,34,0.12); border-radius: var(--r-2xl, 22px);
  background: var(--paper, #faf6ef); box-shadow: 0 10px 30px rgba(33,30,26,0.10);
  overflow: hidden;
}
.pt-tag { display: block; font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-muted); margin-bottom: 5px; font-weight: 700; }

/* gedeelde "veld"-look: een te vergrendelen onderdeel */
.pt-field { position: relative; background: rgba(245,236,219,0.4); border: 1px dashed rgba(43,39,34,0.2); border-radius: var(--r-lg, 14px); padding: 10px 13px; transition: background var(--dur-fast,140ms) var(--ease-soft), border-color var(--dur-fast,140ms) var(--ease-soft); }
.pt-field.locked { background: rgba(180,80,47,0.06); border-color: rgba(180,80,47,0.28); }
.pt-fieldbtn { display: flex; align-items: center; gap: 12px; text-align: left; cursor: pointer; font: inherit; }
.pt-fieldbtn .pt-tag { flex: 0 0 auto; margin: 0; }
.pt-fieldbtn .pt-fmain { flex: 1 1 auto; min-width: 0; display: flex; align-items: center; gap: 10px; }
.pt-fieldbtn > svg { flex: 0 0 auto; width: 18px; height: 18px; color: var(--ink-muted); }
.pt-fsub { font-size: 12.5px; color: var(--ink-soft); }
.zpill { display: inline-flex; align-items: center; padding: 4px 12px; border-radius: var(--r-pill,999px); background: var(--plaat-sage,#cdd9be); font-size: 11px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-soft); }
.pt-ftitle { font-family: var(--font-serif); font-size: 19px; color: var(--ink); }

.pt-bar { display: grid; grid-template-columns: 0.95fr 1fr 1fr; gap: 10px; padding: 14px; border-bottom: 1px solid var(--line-soft, rgba(43,39,34,.08)); }
/* master-schuif: alle scènes in één keer open / dicht */
.pt-allscenes { display: flex; align-items: center; gap: 10px; }
.pt-allscenes .pt-tag { flex: 0 0 auto; margin: 0; }
.pt-allstate { flex: 1 1 auto; font-size: 12.5px; color: var(--ink-soft); }
.pt-subrow { display: flex; align-items: center; gap: 14px; margin: 14px 14px 0; }
.pt-subrow .pt-tag { margin: 0; flex: 0 0 auto; }
.pt-subpills { flex: 1 1 auto; display: flex; gap: 6px; }
.pt-subpills .subpill { font-family: var(--font-serif); font-style: italic; font-size: 15px; color: var(--accent-coral-hex,#d97757); background: rgba(43,39,34,0.045); border-radius: var(--r-pill,999px); padding: 3px 12px; }
.pt-subrow .pt-state { flex: 0 0 auto; font-size: 12.5px; color: var(--ink-soft); }

.pt-body { display: grid; grid-template-columns: 1fr 1.15fr; gap: 14px; padding: 14px; }
.pt-figure { border-radius: var(--r-lg,14px); background: var(--plaat-cream,#f0e3c4); display: grid; place-items: center; min-height: 200px; }
.pt-figure .sketch-ph svg { width: 40px; height: 40px; }
.pt-figure .sketch-ph span { font-size: 18px; }
.pt-side { display: flex; flex-direction: column; gap: 8px; }
.pt-side-head { margin-bottom: 2px; }
.pt-acc-row { display: flex; align-items: center; gap: 11px; padding: 11px 13px; border-radius: var(--r-lg,12px); background: var(--paper,#faf6ef); border: 1px solid rgba(43,39,34,0.10); transition: background var(--dur-fast,140ms) var(--ease-soft), border-color var(--dur-fast,140ms) var(--ease-soft), opacity var(--dur-fast,140ms) var(--ease-soft); }
.pt-acc-row.inv { background: var(--plaat-cream,#f0e3c4); border-color: rgba(200,150,80,0.30); }
.pt-acc-row .pa-ic { flex: 0 0 auto; width: 18px; height: 18px; display: grid; place-items: center; color: var(--ink-muted); }
.pt-acc-row .pa-ic svg { width: 17px; height: 17px; }
.pt-acc-row .pa-label { flex: 1 1 auto; font-size: 14px; font-weight: 600; color: var(--ink); }
.pt-acc-row.locked { background: rgba(180,80,47,0.06); border-color: rgba(180,80,47,0.24); }
.pt-acc-row.locked .pa-label { color: var(--ink-soft); }

.pt-foot { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; padding: 14px; border-top: 1px solid var(--line-soft, rgba(43,39,34,.08)); background: rgba(245,236,219,0.45); }
.pt-foot .pt-tag { margin: 0; flex: 0 0 auto; }
.pt-pills { flex: 1 1 auto; display: flex; gap: 8px; flex-wrap: wrap; transition: opacity var(--dur-fast,140ms) var(--ease-soft); }
.lex-pill.mini { font-size: 12px; padding: 4px 11px; pointer-events: none; }
.pt-foot.hide .pt-pills { opacity: 0.28; }
.pt-foot.locked .pt-pills { opacity: 0.6; }
.pt-seg { flex: 0 0 auto; }

/* dropdown voor zones / scènetitels */
.pt-drop { position: absolute; z-index: 30; width: min(340px, 84%); background: var(--paper,#faf6ef); border: 1px solid rgba(43,39,34,0.14); border-radius: var(--r-lg,16px); box-shadow: 0 18px 50px rgba(33,30,26,0.26); padding: 7px; }
.pt-drop-h { font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-muted); font-weight: 700; padding: 7px 9px 8px; }
.pt-drop-row { display: flex; align-items: center; gap: 12px; padding: 9px 10px; border-radius: 11px; transition: background var(--dur-fast,140ms) var(--ease-soft); }
.pt-drop-row:hover { background: rgba(43,39,34,0.04); }
.pt-drop-row .pdr-body { flex: 1 1 auto; min-width: 0; }
.pt-drop-row .pdr-l { font-size: 14px; font-weight: 600; color: var(--ink); }
.pt-drop-row .pdr-s { font-size: 12px; color: var(--ink-muted); margin-top: 1px; }
.pt-drop-row.disabled { opacity: 0.55; }
.pt-drop-row .pdr-tag { flex: 0 0 auto; font-size: 11px; font-weight: 600; color: #b4502f; background: rgba(180,80,47,0.12); border-radius: var(--r-pill,999px); padding: 3px 10px; }

@media (max-width: 760px) {
  .pt-bar, .pt-body { grid-template-columns: 1fr; }
  .perm-intro { flex-direction: column; gap: 10px; }
}

.toggle { flex: 0 0 auto; width: 46px; height: 27px; border-radius: 999px; border: none; cursor: pointer; background: var(--accent-green, #4f7a4e); position: relative; transition: background var(--dur-base,240ms) var(--ease-soft); }
.toggle::after { content: ""; position: absolute; top: 3px; left: 3px; width: 21px; height: 21px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,0.25); transition: transform var(--dur-fast,140ms) var(--ease-soft); }
.toggle.off { background: rgba(43,39,34,0.22); }
.toggle.off::after { transform: translateX(0); }
.toggle.on::after { transform: translateX(19px); }
/* deels open/dicht: 'aangepast' — knop in het midden, coral */
.toggle.partial { background: var(--accent-coral-hex, #d97757); }
.toggle.partial::after { transform: translateX(9.5px); }
.pt-allscenes.mixed .pt-allstate { color: var(--accent-coral-hex, #d97757); font-weight: 600; }

.section-h { display: flex; align-items: baseline; justify-content: space-between; margin: 4px 0 12px; }
.section-h h4 { margin: 0; font-family: var(--font-sans); font-size: 13px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-soft); }
.section-h + .section-h { margin-top: 20px; }
/* hernoembare naam van een eigen perspectiefbril-groep */
.section-h h4 .pg-name-ed { text-transform: none; letter-spacing: 0; color: var(--ink); border-bottom: 1px dashed rgba(43,39,34,0.32); outline: none; cursor: text; padding: 0 1px; }
.section-h h4 .pg-name-ed:hover { border-bottom-color: var(--accent-coral-hex, #d97757); }
.section-h h4 .pg-name-ed:focus { border-bottom-style: solid; border-bottom-color: var(--accent-coral-hex, #d97757); }
.hwin-scroll .grp + .grp { margin-top: 22px; }
.mini-tab-lock { display: flex; align-items: center; gap: 9px; padding: 9px 12px; border-radius: 11px; background: var(--paper,#faf6ef); border: 1px solid rgba(43,39,34,0.08); margin-bottom: 7px; }
.mini-tab-lock .mt-sn { font-family: var(--font-serif); font-style: italic; color: var(--accent-coral-hex,#d97757); font-size: 15px; }
.mini-tab-lock .mt-label { flex: 1 1 auto; font-size: 13.5px; color: var(--ink-soft); }
.mini-tab-lock .mt-lock { width: 30px; height: 30px; border: none; background: transparent; border-radius: 8px; cursor: pointer; color: var(--ink-muted); display: grid; place-items: center; }
.mini-tab-lock .mt-lock:hover { background: rgba(43,39,34,0.06); }
.mini-tab-lock.locked { background: rgba(180,80,47,0.06); }
.mini-tab-lock.locked .mt-lock { color: #b4502f; }
.mini-tab-lock .mt-lock svg { width: 16px; height: 16px; }

/* ---- woordwolk ---- */
.wcloud { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 6px 16px; padding: 14px; height: 100%; align-content: center; }
.wcloud span { font-family: var(--font-serif); line-height: 1; color: var(--ink); }
.wcloud span.c1 { color: var(--accent-coral-hex,#d97757); }
.wcloud span.c2 { color: #3f6f93; }
.wcloud span.c3 { color: #5f7a4e; }
.wcloud span.c4 { color: #7a5f9e; }

/* ---- poll ---- */
.poll-list { display: flex; flex-direction: column; gap: 14px; max-width: 560px; margin: 0 auto; width: 100%; }
.poll-row .pr-top { display: flex; justify-content: space-between; font-size: 15px; color: var(--ink); margin-bottom: 6px; }
.poll-row .pr-top .pct { font-family: var(--font-mono); color: var(--ink-soft); }
.poll-bar { height: 16px; border-radius: 999px; background: rgba(43,39,34,0.08); overflow: hidden; }
.poll-bar i { display: block; height: 100%; border-radius: 999px; background: var(--accent-coral-hex,#d97757); transition: width 500ms var(--ease-soft); }
.poll-row:nth-child(2) .poll-bar i { background: #3f6f93; }
.poll-row:nth-child(3) .poll-bar i { background: #5f7a4e; }
.poll-row:nth-child(4) .poll-bar i { background: #7a5f9e; }

/* ---- kort antwoord grid ---- */
.ans-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 12px; }
.ans-card { background: var(--paper,#faf6ef); border: 1px solid rgba(43,39,34,0.10); border-radius: var(--r-lg,14px); padding: 13px 15px; box-shadow: var(--shadow-soft, 0 8px 24px rgba(43,39,34,.06)); position: relative; }
.ans-card .ac-txt { font-size: 14.5px; line-height: 1.45; color: var(--ink); padding-right: 22px; }
.ans-card .ac-by { font-size: 11.5px; color: var(--ink-muted); margin-top: 8px; display: flex; align-items: center; gap: 7px; }
.ans-card .ac-del { position: absolute; top: 7px; right: 7px; width: 26px; height: 26px; display: grid; place-items: center; border: none; background: transparent; color: var(--ink-muted); cursor: pointer; border-radius: 7px; opacity: 0.55; transition: opacity 140ms ease, background 140ms ease, color 140ms ease; }
.ans-card:hover .ac-del, .ans-card .ac-del:focus-visible { opacity: 1; }
.ans-card .ac-del:hover { background: rgba(180,80,47,0.14); color: #b4502f; }
.ans-card .ac-del svg { width: 15px; height: 15px; }

.refresh-note { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--ink-muted); }
.refresh-note select { font-family: var(--font-sans); font-size: 12.5px; color: var(--ink-soft); border: 1px solid rgba(43,39,34,0.14); border-radius: 8px; padding: 3px 6px; background: var(--paper,#faf6ef); }

.empty-hint { color: var(--ink-muted); font-size: 14px; text-align: center; padding: 30px; font-style: italic; }

/* ---- push lijst ---- */
.push-list { display: flex; flex-direction: column; gap: 10px; }
.push-item { display: flex; align-items: center; gap: 12px; padding: 13px 15px; border-radius: var(--r-lg,14px); border: 1px solid rgba(43,39,34,0.10); background: var(--paper,#faf6ef); }
.push-item .pi-ic { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; background: rgba(43,39,34,0.05); color: var(--ink-soft); flex: 0 0 auto; }
.push-item .pi-ic svg { width: 18px; height: 18px; }
.push-item .pi-label { flex: 1 1 auto; }
.push-item .pi-label .t { font-size: 14.5px; font-weight: 600; color: var(--ink); }
.push-item .pi-label .s { font-size: 12px; color: var(--ink-muted); }
.seg { display: inline-flex; padding: 3px; background: rgba(43,39,34,0.06); border-radius: 999px; gap: 2px; }
.seg button { border: none; background: transparent; cursor: pointer; font-family: var(--font-sans); font-size: 12px; font-weight: 600; color: var(--ink-muted); padding: 6px 11px; border-radius: 999px; transition: all var(--dur-fast,140ms) var(--ease-soft); white-space: nowrap; }
.seg button.sel { background: var(--paper,#faf6ef); color: var(--ink); box-shadow: 0 1px 3px rgba(43,39,34,.12); }
.push-banner { margin: 0 0 16px; padding: 12px 15px; border-radius: var(--r-lg,14px); background: rgba(217,119,87,0.10); border: 1px solid rgba(217,119,87,0.28); font-size: 13.5px; line-height: 1.5; color: var(--ink-soft); }
.push-banner b { color: var(--ink); }

/* ---- perspectiefbrillen ---- */
.persp-wrap { display: flex; min-height: 0; height: 100%; }
.persp-left { flex: 0 0 230px; border-right: 1px solid var(--line-soft, rgba(43,39,34,.08)); display: flex; flex-direction: column; min-height: 0; }
.persp-groups { flex: 1 1 auto; overflow-y: auto; padding: 12px; }
.pg-item { display: flex; align-items: center; gap: 9px; width: 100%; text-align: left; padding: 11px 13px; border-radius: 11px; border: 1px solid transparent; background: transparent; cursor: pointer; margin-bottom: 5px; font-family: var(--font-sans); font-size: 14px; color: var(--ink-soft); transition: background var(--dur-fast,140ms) var(--ease-soft); }
.pg-item:hover { background: rgba(43,39,34,0.04); }
.pg-item.sel { background: var(--paper,#faf6ef); border-color: rgba(43,39,34,0.12); color: var(--ink); font-weight: 600; box-shadow: 0 1px 3px rgba(43,39,34,.08); }
.pg-item .pg-ct { margin-left: auto; font-size: 12px; color: var(--ink-muted); font-family: var(--font-mono); }
.persp-left-foot { flex: 0 0 auto; padding: 12px; border-top: 1px solid var(--line-soft, rgba(43,39,34,.08)); }

.persp-right { flex: 1 1 auto; display: flex; flex-direction: column; min-height: 0; }
.persp-right-scroll { flex: 1 1 auto; overflow-y: auto; padding: 18px 22px; }
.glass-row { display: flex; align-items: flex-start; gap: 12px; padding: 13px; border-radius: var(--r-lg,14px); border: 1px solid rgba(43,39,34,0.10); background: var(--paper,#faf6ef); margin-bottom: 10px; }
.glass-row.disabled { opacity: 0.5; }
.glass-row .gr-lens { flex: 0 0 auto; width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-family: var(--font-serif); font-style: italic; font-size: 17px; }
.glass-row .gr-body { flex: 1 1 auto; min-width: 0; }
.glass-row .gr-name { font-size: 15px; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
.glass-row .gr-text { font-size: 13.5px; line-height: 1.45; color: var(--ink-soft); border: 1px dashed transparent; border-radius: 7px; padding: 2px 4px; margin: -2px -4px; cursor: text; }
.glass-row .gr-text:hover { border-color: rgba(43,39,34,0.18); }
.glass-row .gr-text:focus { outline: none; border-color: var(--accent-coral-hex,#d97757); border-style: solid; background: #fff; }
.glass-row .gr-acts { flex: 0 0 auto; display: flex; gap: 4px; }
.gr-mini { width: 30px; height: 30px; border: none; background: transparent; border-radius: 8px; cursor: pointer; color: var(--ink-muted); display: grid; place-items: center; }
.gr-mini:hover { background: rgba(43,39,34,0.07); color: var(--ink); }
.gr-mini svg { width: 16px; height: 16px; }

.assign-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 10px; }
.assign-card { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 12px; border: 1px solid rgba(43,39,34,0.10); background: var(--paper,#faf6ef); }
.assign-card .ac-lens { width: 30px; height: 30px; border-radius: 50%; flex: 0 0 auto; display: grid; place-items: center; color:#fff; font-family: var(--font-serif); font-style: italic; font-size: 14px; }
.assign-card .ac-who { font-size: 13px; color: var(--ink); font-weight: 600; }
.assign-card .ac-glass { font-size: 11.5px; color: var(--ink-muted); }
.persp-right-foot { flex: 0 0 auto; padding: 13px 22px; border-top: 1px solid var(--line-soft, rgba(43,39,34,.08)); display: flex; gap: 10px; align-items: center; background: rgba(245,236,219,0.45); flex-wrap: wrap; row-gap: 10px; }
/* verdeelwijze: alle deelnemers óf de set beperkt (N×) uitdelen */
.persp-mode { flex: 1 1 100%; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.persp-step { display: inline-flex; align-items: center; gap: 6px; }
.ps-arrow {
  width: 26px; height: 26px; display: grid; place-items: center;
  border: 1px solid rgba(43,39,34,0.18); border-radius: 8px;
  background: var(--paper, #faf6ef); color: var(--ink-soft, #4a433a); cursor: pointer;
}
.ps-arrow svg { width: 14px; height: 14px; }
.ps-arrow:hover:not(:disabled) { border-color: var(--ink, #2b2722); color: var(--ink, #2b2722); }
.ps-arrow:disabled { opacity: 0.35; cursor: default; }
.ps-val { min-width: 34px; text-align: center; font-weight: 800; font-size: 14px; color: var(--ink, #2b2722); font-variant-numeric: tabular-nums; }

/* ============ ITEMOVERZICHT ============ */
.iov-list { display: flex; flex-direction: column; gap: 10px; }
.iov-row {
  display: flex; align-items: center; gap: 13px; padding: 11px 14px;
  border: 1px solid rgba(43,39,34,0.10); border-radius: 14px; background: rgba(255,253,249,0.7);
}
.iov-ic { flex: 0 0 auto; width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; color: var(--ink, #2b2722); }
.iov-ic svg { width: 19px; height: 19px; }
.iov-body { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.iov-t { font-weight: 700; font-size: 14px; color: var(--ink, #2b2722); }
.iov-s { font-size: 12.5px; color: var(--ink-muted, #7a7064); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 460px; }
.iov-where {
  flex: 0 0 auto; display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 600; color: var(--ink-soft, #4a433a);
  background: rgba(43,39,34,0.06); border-radius: 999px; padding: 5px 11px; max-width: 220px;
}
.iov-where svg { width: 14px; height: 14px; flex: 0 0 auto; }
.iov-where span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.iov-where.iov-none { color: var(--ink-muted, #7a7064); background: transparent; border: 1px dashed rgba(43,39,34,0.25); }
.iov-acts { flex: 0 0 auto; display: flex; gap: 7px; }
.iov-acts .hbtn { padding: 6px 12px; font-size: 12.5px; }

/* groen "actief"-bolletje in de groepenlijst (snel zien of er iets aanstaat) */
.pg-item .pg-dot { flex: 0 0 auto; width: 8px; height: 8px; border-radius: 50%; background: var(--accent-green, #4f7a4e); box-shadow: 0 0 0 3px rgba(79,122,78,0.18); }

/* "Opnieuw verdelen" licht op zodra een actieve bril is gewijzigd */
.hbtn.needs-redo { animation: redoPulse 1.8s var(--ease-soft, ease-in-out) infinite; }
@keyframes redoPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(217,119,87,0); } 50% { box-shadow: 0 0 0 6px rgba(217,119,87,0.22); } }
@media (prefers-reduced-motion: reduce) { .hbtn.needs-redo { animation: none; box-shadow: 0 0 0 4px rgba(217,119,87,0.26); } }

/* inventaris-teller knippert kort bij toevoegen van een item */
.acc-inv .inv-ct.bump { animation: ctBump 0.6s var(--ease-soft, ease); }
@keyframes ctBump { 0% { transform: scale(1); } 35% { transform: scale(1.32); } 100% { transform: scale(1); } }

.text-input { width: 100%; font-family: var(--font-sans); font-size: 14px; color: var(--ink); border: 1px solid rgba(43,39,34,0.16); border-radius: 10px; padding: 9px 12px; background: var(--paper,#faf6ef); }
.text-input:focus { outline: none; border-color: var(--accent-coral-hex,#d97757); }
.lead-p { font-size: 14.5px; line-height: 1.55; color: var(--ink-soft); margin: 0 0 16px; }

/* ============ INVENTARIS (als uitklapmenu in het hotspot-venster) ============ */
.lp-main { position: relative; }

/* het inventaris-uitklapmenu krijgt een eigen pilvorm + kleur, los van de
   tekst-uitklapmenu's. Het aantal (inv-ct) staat in de kop en blijft dus ook
   zichtbaar wanneer het menu is ingeklapt. */
.acc-inv {
  border-bottom: none; margin: 12px 14px 16px; overflow: hidden;
  border-radius: var(--r-lg, 16px);
  background: var(--plaat-cream, #f0e3c4);
  border: 1px solid rgba(200,150,80,0.30);
}
.acc-inv > .acc-head { padding: 13px 15px; color: var(--ink); font-weight: 700; }
.acc-inv > .acc-head:hover { background: rgba(200,150,80,0.12); }
.acc-inv .inv-head-ic { flex: 0 0 auto; width: 22px; height: 22px; display: grid; place-items: center; color: #b07a2e; }
.acc-inv .inv-head-ic svg { width: 18px; height: 18px; }
.acc-inv .lbl { flex: 1 1 auto; }
.acc-inv .inv-ct {
  flex: 0 0 auto; font-family: var(--font-mono); font-size: 12px; font-weight: 600;
  color: #fff; background: var(--accent-coral-hex, #d97757);
  border-radius: 999px; padding: 2px 9px; min-width: 23px; text-align: center;
}
.acc-inv > .acc-head .chev { color: #b07a2e; }
.acc-inv.open > .acc-head .chev { color: var(--accent-coral-hex, #d97757); }
.acc-inv .acc-inner { padding: 2px 14px 14px; }

.inv-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.inv-cell {
  position: relative; aspect-ratio: 1 / 1; border-radius: var(--r-md, 12px); cursor: pointer;
  display: grid; place-items: center; padding: 0;
  background: var(--paper, #faf6ef); border: 1px solid rgba(43,39,34,0.12);
  box-shadow: inset 0 1px 2px rgba(43,39,34,0.05);
  transition: transform var(--dur-fast,140ms) var(--ease-soft), border-color var(--dur-fast,140ms) var(--ease-soft), box-shadow var(--dur-fast,140ms) var(--ease-soft);
}
.inv-cell.filled:hover { transform: translateY(-2px); box-shadow: 0 6px 14px rgba(33,30,26,0.16); border-color: rgba(43,39,34,0.2); }
.inv-cell.empty { background: rgba(43,39,34,0.025); border-style: dashed; box-shadow: none; }
.inv-cell.empty:hover { border-color: var(--accent-coral-hex,#d97757); background: rgba(217,119,87,0.06); }
.inv-cell .inv-ic { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: var(--ink); }
.inv-cell .inv-ic svg { width: 20px; height: 20px; }
.inv-cell .inv-plus { font-family: var(--font-serif); font-size: 24px; color: var(--ink-muted); line-height: 1; }

/* uitgeklapt item — vult de venster-inhoud */
.lp-inv-expand {
  position: absolute; inset: 0; z-index: 8; display: none; flex-direction: column;
  background: var(--paper, #faf6ef);
}
.lp-inv-expand.show { display: flex; }
.inv-expand-bar { flex: 0 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 12px 16px 12px 22px; border-bottom: 1px solid var(--line-soft, rgba(43,39,34,.08)); }
.inv-expand-label { font-family: var(--font-serif); font-size: 19px; color: var(--ink); }
.inv-expand-acts { display: flex; align-items: center; gap: 6px; }
.inv-kbd { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 10px; border: 1px solid rgba(43,39,34,0.12); background: transparent; color: var(--ink-soft); cursor: pointer; transition: background var(--dur-fast,140ms) var(--ease-soft), color var(--dur-fast,140ms) var(--ease-soft); }
.inv-kbd:hover { background: rgba(43,39,34,0.05); color: var(--ink); }
.inv-kbd svg { width: 18px; height: 18px; }
.inv-back { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 10px; border: 1px solid rgba(43,39,34,0.12); background: transparent; color: var(--ink-soft); cursor: pointer; }
.inv-back:hover { background: rgba(43,39,34,0.05); color: var(--ink); }
.inv-back svg { width: 17px; height: 17px; }
.inv-del { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 10px; border: 1px solid rgba(43,39,34,0.12); background: transparent; color: var(--ink-soft); cursor: pointer; transition: background .15s, color .15s, border-color .15s; }
.inv-del:hover { background: rgba(217,119,87,0.1); color: var(--accent-coral-hex, #d97757); border-color: rgba(217,119,87,0.4); }
.inv-del svg { width: 18px; height: 18px; }
.inv-push { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 10px; border: 1px solid rgba(43,39,34,0.12); background: transparent; color: var(--ink-soft); cursor: pointer; transition: background 140ms, color 140ms, border-color 140ms; }
.inv-push:hover { background: rgba(43,39,34,0.05); color: var(--ink); }
.inv-push svg { width: 18px; height: 18px; }
.inv-push.is-pushed { background: var(--accent-coral-hex,#d97757); border-color: var(--accent-coral-hex,#d97757); color: #fff; }
.inv-push.is-pushed:hover { background: var(--accent-coral-hex,#d97757); color: #fff; }
.inv-push.is-dim { opacity: 0.4; cursor: default; }
.inv-push.is-dim:hover { background: transparent; color: var(--ink-soft); }
.hbtn.dim { opacity: 0.45; cursor: default; }
/* verwijder-bevestiging — overlay binnen het uitgeklapte item */
.inv-confirm { position: absolute; inset: 0; z-index: 12; display: none; align-items: center; justify-content: center; padding: 24px; background: rgba(43,39,34,0.28); backdrop-filter: blur(2px); }
.inv-confirm.show { display: flex; }
.inv-confirm-box { width: 100%; max-width: 340px; background: var(--paper, #faf6ef); border-radius: 16px; box-shadow: var(--shadow-soft, 0 8px 24px rgba(43,39,34,.12)); padding: 24px 24px 18px; text-align: center; }
.inv-confirm-q { font-family: var(--font-serif); font-size: 19px; line-height: 1.4; color: var(--ink); margin: 0 0 20px; text-wrap: pretty; }
.inv-confirm-q strong { font-weight: 500; font-style: italic; }
.inv-confirm-btns { display: flex; gap: 10px; }
.inv-confirm-btns button { flex: 1 1 0; font-family: var(--font-sans); font-size: 15px; font-weight: 600; padding: 11px 14px; border-radius: 11px; cursor: pointer; transition: background .15s, color .15s, border-color .15s; }
.inv-cf-no { border: 1.5px solid var(--ink, #2b2722); background: transparent; color: var(--ink); }
.inv-cf-no:hover { background: rgba(43,39,34,0.06); }
.inv-cf-yes { border: 1.5px solid var(--accent-coral-hex, #d97757); background: var(--accent-coral-hex, #d97757); color: #fff; }
.inv-cf-yes:hover { background: #c8643f; border-color: #c8643f; }
.inv-expand-body { flex: 1 1 auto; min-height: 0; overflow: auto; padding: 20px 24px; }
.inv-note { position: relative; width: 100%; height: 100%; min-height: 280px; border-radius: 8px; box-shadow: 0 10px 24px rgba(33,30,26,0.14); }
.inv-note textarea, .inv-note .inv-note-ed { width: 100%; height: 100%; border: none; background: transparent; resize: none; outline: none; padding: 22px; font-family: var(--font-hand, "Caveat", cursive); font-size: 27px; line-height: 1.2; color: #2b2722; }
.inv-note .inv-note-ed { overflow: auto; white-space: pre-wrap; word-break: break-word; }
.inv-note .inv-note-ed:empty:before { content: attr(data-placeholder); color: rgba(43,39,34,0.34); pointer-events: none; }
.inv-note-del { position: absolute; top: 10px; right: 10px; width: 30px; height: 30px; border: none; background: rgba(0,0,0,0.06); border-radius: 8px; cursor: pointer; color: rgba(43,39,34,0.6); display: grid; place-items: center; }
.inv-note-del:hover { background: rgba(180,80,47,0.16); color: #b4502f; }
.inv-note-del svg { width: 16px; height: 16px; }

/* ---- uitgeklapte link in de inventaris ---- */
.inv-link { display: flex; flex-direction: column; gap: 10px; align-items: flex-start; }
.inv-link-title { font-weight: 700; font-size: 17px; color: var(--ink, #2b2722); word-break: break-word; }
.inv-link-host { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; color: var(--ink-muted, rgba(43,39,34,0.62)); word-break: break-all; }
.inv-link-host svg { width: 15px; height: 15px; flex: 0 0 auto; }
.inv-link-open { display: inline-flex; align-items: center; gap: 8px; margin-top: 6px; padding: 9px 16px; border: none; border-radius: var(--r-sm, 8px); background: var(--accent-coral-hex, #d97757); color: #fff; font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; }
.inv-link-open svg { width: 17px; height: 17px; }
.inv-link-open:hover { filter: brightness(0.94); }

@media (max-width: 900px) { .inv-picker { width: 240px; } }

/* ---- + : kies-popover voor de inventaris ---- */
.inv-picker {
  position: absolute; z-index: 205; width: 270px;
  background: var(--paper, #faf6ef); border: 1px solid rgba(43,39,34,0.12);
  border-radius: var(--r-lg, 16px); box-shadow: 0 18px 50px rgba(33,30,26,0.28);
  padding: 8px; opacity: 0; transform: translateY(6px) scale(0.98); pointer-events: none;
  transition: opacity var(--dur-fast,140ms) var(--ease-soft), transform var(--dur-fast,140ms) var(--ease-soft);
  max-height: min(56vh, 430px); overflow-y: auto; overscroll-behavior: contain; scrollbar-width: thin;
}
.inv-picker.show { opacity: 1; transform: none; pointer-events: auto; }
.ip-head { display: flex; align-items: center; gap: 8px; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-muted); padding: 8px 8px 7px; }
.ip-back { width: 26px; height: 26px; border: none; background: transparent; border-radius: 7px; cursor: pointer; color: var(--ink-soft); display: grid; place-items: center; margin: -4px 0 -4px -4px; }
.ip-back:hover { background: rgba(43,39,34,0.07); }
.ip-back svg { width: 16px; height: 16px; }
.ip-opt { display: flex; align-items: center; gap: 11px; width: 100%; text-align: left; padding: 9px 10px; border: none; background: transparent; border-radius: 11px; cursor: pointer; transition: background var(--dur-fast,140ms) var(--ease-soft); }
.ip-opt:hover { background: rgba(43,39,34,0.05); }
.ip-ic { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: var(--ink); }
.ip-ic svg { width: 19px; height: 19px; }
.ip-text { display: flex; flex-direction: column; min-width: 0; }
.ip-l { font-family: var(--font-sans); font-size: 14.5px; font-weight: 600; color: var(--ink); }
.ip-s { font-size: 12px; color: var(--ink-muted); }
.ip-sep { height: 1px; background: var(--line-soft, rgba(43,39,34,.08)); margin: 6px 8px; }
.ip-empty { font-size: 13px; line-height: 1.5; color: var(--ink-muted); padding: 4px 12px 12px; font-style: italic; }

/* ---- bewerkbare tool-velden (toetsenbord-doel) ---- */
.tool-q { width: 100%; font-family: var(--font-sans); border: 1px solid rgba(43,39,34,0.16); border-radius: 10px; padding: 8px 11px; background: var(--paper, #faf6ef); color: var(--ink); }
.tool-q:focus { outline: none; border-color: var(--accent-coral-hex, #d97757); }
input.lead-p.tool-q { font-weight: 600; margin: 0 0 16px; }
.tool-addrow { display: flex; gap: 8px; margin-top: 14px; align-items: center; }
.tool-addrow .tool-q { flex: 1 1 auto; }

/* placeholder voor vraagvelden — schuin, lichtgrijs/transparant */
.tool-q::placeholder, .text-input::placeholder { font-style: italic; color: rgba(43,39,34,0.32); }

/* woordwolk — antwoorden standaard afgedekt */
.cloud-cover {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
  width: 100%; min-height: 230px; cursor: pointer; text-align: center;
  border: 1.5px dashed rgba(43,39,34,0.20); border-radius: var(--r-xl, 18px);
  background: rgba(245,236,219,0.5); color: var(--ink-soft);
  transition: background var(--dur-fast,140ms) var(--ease-soft), border-color var(--dur-fast,140ms) var(--ease-soft);
}
.cloud-cover:hover { background: rgba(217,119,87,0.07); border-color: var(--accent-coral-hex,#d97757); }
.cloud-cover .cc-eye { width: 60px; height: 60px; color: var(--ink-muted); }
.cloud-cover .cc-eye svg { width: 100%; height: 100%; }
.cloud-cover:hover .cc-eye { color: var(--accent-coral-hex,#d97757); }
.cloud-cover .cc-count { font-family: var(--font-serif); font-size: 26px; color: var(--ink); }
.cloud-cover .cc-hint { font-size: 13px; color: var(--ink-muted); }

/* poll — samenstellen */
.poll-setup { display: flex; flex-direction: column; gap: 9px; max-width: 560px; margin: 0 auto; width: 100%; }
.poll-opt-row { display: flex; align-items: center; gap: 10px; }
.poll-opt-row .po-idx { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; font-family: var(--font-serif); font-style: italic; font-size: 15px; color: var(--accent-coral-hex,#d97757); background: rgba(43,39,34,0.045); }
.poll-opt-row .text-input { flex: 1 1 auto; }
.poll-opt-row .po-del { flex: 0 0 auto; width: 34px; height: 34px; border: 1px solid rgba(43,39,34,0.12); background: transparent; border-radius: 9px; cursor: pointer; color: var(--ink-muted); display: grid; place-items: center; transition: background .15s, color .15s, border-color .15s; }
.poll-opt-row .po-del:hover { background: rgba(217,119,87,0.1); color: var(--accent-coral-hex,#d97757); border-color: rgba(217,119,87,0.4); }
.poll-opt-row .po-del:disabled { opacity: 0.3; cursor: default; }
.poll-opt-row .po-del:disabled:hover { background: transparent; color: var(--ink-muted); border-color: rgba(43,39,34,0.12); }
.poll-opt-row .po-del svg { width: 16px; height: 16px; }

/* poll — gecombineerde balk bij precies 2 antwoorden */
.poll-split-wrap { max-width: 560px; margin: 0 auto; width: 100%; }
.poll-split-wrap .ps-top { display: flex; justify-content: space-between; gap: 12px; font-size: 15px; color: var(--ink); margin-bottom: 7px; }
.poll-split-wrap .ps-top .ps-r { color: var(--ink-soft); text-align: right; }
.poll-split { display: flex; height: 30px; border-radius: 999px; overflow: hidden; background: rgba(43,39,34,0.08); }
.poll-split i { display: block; height: 100%; transition: width 500ms var(--ease-soft); }
.poll-split-wrap .ps-bottom { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 12px; color: var(--ink-muted); margin-top: 6px; }

/* ---- perspectiefbril in de inventaris ---- */
.lens-entry { padding: 2px 2px 4px; }
.lens-active { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 600; color: #6b5a8a; background: rgba(122,95,158,0.13); border-radius: 999px; padding: 5px 12px; margin-bottom: 14px; }
.lens-active .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent-green, #4f7a4e); }
.lens-list { display: flex; flex-direction: column; gap: 9px; }
.lens-item { display: flex; align-items: flex-start; gap: 11px; padding: 11px 12px; border-radius: var(--r-lg, 14px); border: 1px solid rgba(43,39,34,0.10); background: var(--paper, #faf6ef); }
.lens-item.off { opacity: 0.5; }
.lens-item .li-lens { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-family: var(--font-serif); font-style: italic; font-size: 16px; }
.lens-item .li-name { font-size: 14.5px; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.lens-item .li-text { font-size: 13px; line-height: 1.45; color: var(--ink-soft); }
.lens-note-l { display: block; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-muted); margin: 16px 0 6px; }
.lens-note { width: 100%; resize: vertical; }
.lens-foot { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-top: 16px; }
.lens-assign { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 10px; margin-top: 14px; }

.big-layer { position: absolute; inset: 0; z-index: 140; display: none; align-items: center; justify-content: center; background: var(--paper, #faf6ef); }
.big-layer.open { display: flex; }
.big-layer .big-close { position: absolute; top: 22px; right: 22px; }
.big-layer .big-inner { width: min(1200px, 92%); height: 82%; display: flex; flex-direction: column; }
.big-layer .big-title { font-family: var(--font-serif); font-size: 32px; color: var(--ink); margin: 0 0 6px; }
.big-layer .big-sub { font-size: 14px; color: var(--ink-muted); margin: 0 0 24px; }
.big-layer .big-foot { margin-top: 18px; border-top: 1px solid var(--line-soft, rgba(43,39,34,.1)); background: transparent; border-radius: var(--r-lg, 14px); padding: 14px 4px 0; }

/* ---- waarschuwingsvenster (verwijderen e.d.) ---- */
.tconfirm-layer { position: absolute; inset: 0; z-index: 320; display: none; align-items: center; justify-content: center; padding: 24px; }
.tconfirm-layer.open { display: flex; }
.tconfirm-back { position: absolute; inset: 0; background: rgba(33,30,26,0.42); backdrop-filter: blur(3px); }
.tconfirm-card {
  position: relative; width: min(420px, 100%);
  background: var(--paper, #faf6ef); border-radius: var(--r-2xl, 20px);
  box-shadow: 0 30px 80px rgba(33,30,26,0.38); padding: 26px 26px 22px;
  transform: translateY(10px) scale(0.98); opacity: 0;
  transition: transform var(--dur-base, 220ms) var(--ease-soft), opacity var(--dur-base, 220ms) var(--ease-soft);
}
.tconfirm-layer.open .tconfirm-card { transform: none; opacity: 1; }
.tconfirm-eyebrow { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent-coral-hex, #d97757); font-weight: 700; margin: 0 0 8px; }
.tconfirm-title { font-family: var(--font-serif, "Newsreader", Georgia, serif); font-weight: 400; font-size: 25px; line-height: 1.15; color: var(--ink); margin: 0 0 10px; }
.tconfirm-body { font-size: 14.5px; line-height: 1.55; color: var(--ink-soft, #5c574e); margin: 0 0 22px; text-wrap: pretty; }
.tconfirm-acts { display: flex; justify-content: flex-end; gap: 10px; }

/* ---- deelnemers beheren (verwijderen / op 'alleen kijken' zetten) ---- */
.pmanage-bulk { margin: 0 0 12px; display: flex; }
.pmanage-bulk .hbtn { width: auto; }
.pmanage-list { display: flex; flex-direction: column; gap: 8px; }
.pmanage-row {
  display: flex; align-items: center; gap: 13px; padding: 11px 13px;
  background: var(--paper, #faf6ef); border: 1px solid rgba(43,39,34,0.10);
  border-radius: var(--r-lg, 14px);
}
.pmanage-row.is-inactive { background: rgba(43,39,34,0.035); }
.pmanage-av {
  flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
}
.pmanage-row.is-inactive .pmanage-av { opacity: 0.5; filter: grayscale(0.5); }
.pmanage-who { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.pmw-name { font-weight: 600; font-size: 14.5px; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pmw-state { font-size: 12px; color: var(--ink-muted, #7a7064); }
.pmanage-row.is-inactive .pmw-state { color: var(--accent-coral-hex, #d97757); }
.pmanage-acts { flex: 0 0 auto; display: flex; gap: 7px; }

/* deelnemerstelling in de live-balk is klikbaar (opent het beheerpaneel) */
.live-badge .lb-count {
  cursor: pointer; border: none; background: transparent;
  font-family: var(--font-sans, "Manrope", system-ui, sans-serif);
  border-radius: 7px; transition: background var(--dur-fast,140ms) var(--ease-soft);
}
.live-badge .lb-count:hover { background: rgba(43,39,34,0.07); color: var(--ink); }
