/* PresentTool™ Platform — Engine tab
 * Scoped binnen #view-engine zodat de rest van platform-UI niet kan lekken.
 * Donker thema is default (volgt platform); light-overrides via [data-theme="light"].
 *
 * Tokens (worden gezet door platform-shell):
 *   --pt-bg-page, --pt-surface-0, --pt-surface-1, --pt-surface-2, --pt-surface-3
 *   --pt-text, --pt-text-muted, --pt-text-subtle
 *   --pt-primary, --pt-accent-soft, --pt-border, --pt-border-strong, --pt-success
 *   --pt-mono, --pt-serif, --r-lg, --r-xl
 */

/* Tokens: engine-tab én modals (dialogs hangen op document.body) */
#view-engine,
.eng-modal.eng-ui {
  --eng-bg:          #14120E;
  --eng-surf:        #1B1916;
  --eng-surf-2:      #232220;
  --eng-surf-3:      #2C2A27;
  --eng-text:        #F2F0EB;
  --eng-text-muted:  #A09D96;
  --eng-text-subtle: #6F6C66;
  --eng-border:      rgba(242,240,235,0.10);
  --eng-border-2:    rgba(242,240,235,0.18);
  --eng-primary:     #C8956C;
  --eng-primary-soft:rgba(200,149,108,0.12);
  --eng-success:     #2D7A4F;
  --eng-success-soft:rgba(45,122,79,0.18);
  --eng-warn:        #C7942A;
  --eng-warn-soft:   rgba(199,148,42,0.18);
  --eng-danger:      #B03A2E;
  --eng-danger-soft: rgba(176,58,46,0.18);
  /* 3D-viewer podium — neutrale studio-achtergrond (dark). */
  --eng-viewer-bg:   radial-gradient(circle at 50% 38%, #2a2723 0%, #1a1814 70%);
  --eng-radius:      14px;
  --eng-radius-sm:   8px;
}
:root[data-theme="light"] #view-engine,
:root[data-theme="light"] .eng-modal.eng-ui {
  --eng-bg:          #F8F6F1;
  --eng-surf:        #FFFFFF;
  --eng-surf-2:      #FAFAF8;
  --eng-surf-3:      #F1EFEA;
  --eng-text:        #1A1A1A;
  --eng-text-muted:  #6B6B6B;
  --eng-text-subtle: #9A9A9A;
  --eng-border:      #E5E5E0;
  --eng-border-2:    #D9D8D2;
  --eng-primary:     #8B4513;
  --eng-primary-soft:rgba(139,69,19,0.10);
  /* 3D-viewer podium — lichte studio-achtergrond (light). */
  --eng-viewer-bg:   radial-gradient(circle at 50% 38%, #ffffff 0%, #ECE8E0 75%);
  --eng-success:     #2D7A4F;
  --eng-success-soft:#DCFCE7;
  --eng-warn:        #A0722A;
  --eng-warn-soft:   #FEF3C7;
  --eng-danger:      #B03A2E;
  --eng-danger-soft: #FEE2E2;
}

/* ── Wrapper ────────────────────────────────────────────────────────────── */
.eng {
  font-family: var(--pt-sans, 'Inter', sans-serif);
  color: var(--eng-text);
  background: transparent;
}
.eng-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  padding: 4px 0 14px;
  border-bottom: 1px solid var(--eng-border);
  margin-bottom: 14px;
}
.eng-head h1 {
  margin: 0;
  font-size: 22px;
  font-weight: 600;
  font-family: var(--pt-serif, Georgia, serif);
  color: var(--eng-text);
}
.eng-head .sub {
  font-size: 12px;
  color: var(--eng-text-muted);
  font-family: var(--pt-mono, monospace);
}

/* ── Tabs ───────────────────────────────────────────────────────────────── */
.eng-tabs {
  display: flex;
  gap: 2px;
  overflow-x: auto;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--eng-border);
  scrollbar-width: thin;
}
.eng-tab {
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 9px 14px;
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--eng-text-muted);
  cursor: pointer;
  white-space: nowrap;
  transition: color .12s, border-color .12s;
}
.eng-tab:hover { color: var(--eng-text); }
.eng-tab.is-active {
  color: var(--eng-primary);
  border-bottom-color: var(--eng-primary);
}

/* ── Supervisor sub-modi (Review | Rondleiding) — mockup seg-modes ─────── */
.seg-modes, .eng-submodes {
  display: inline-flex;
  gap: 4px;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2);
  border-radius: 999px;
  padding: 4px;
  margin-bottom: 20px;
}
.seg-mode, .eng-submode {
  border: none;
  background: none;
  color: var(--eng-text-muted);
  border-radius: 999px;
  padding: 8px 18px;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.seg-mode svg, .eng-submode svg { width: 16px; height: 16px; }
.seg-mode.on, .seg-mode.is-active, .eng-submode.is-active {
  background: var(--eng-primary);
  color: #14120E;
}
:root[data-theme="light"] .seg-mode.on,
:root[data-theme="light"] .seg-mode.is-active,
:root[data-theme="light"] .eng-submode.is-active { color: #fff; }
.eng-segment { display: none; }
.eng-segment.is-on { display: block; }
.eng-submodes-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.eng-submodes-row .eng-sync-indicator { margin-left: auto; }
.eng-actiongroup { display: inline-flex; gap: 6px; align-items: center; flex-wrap: wrap; }

/* ── Bronbalk onder de review-vergelijking ──────────────────────────────── */
.eng-sourcebar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 8px 0 0;
  padding: 7px 10px;
  background: var(--eng-surf-2, var(--eng-surf));
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius, 8px);
  font-size: 11.5px;
}
.eng-sourcebar .eng-src-kind {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 600; color: var(--eng-text);
  white-space: nowrap;
}
.eng-sourcebar .eng-src-kind svg { width: 13px; height: 13px; }
.eng-sourcebar .eng-src-url {
  flex: 1; min-width: 120px;
  font-family: var(--pt-mono, monospace);
  color: var(--eng-text-muted);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.eng-sourcebar .eng-src-acts { display: inline-flex; gap: 6px; }

/* ── Filter bar ─────────────────────────────────────────────────────────── */
.eng-bar {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  padding: 10px 12px;
  display: flex;
  gap: 10px 14px;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 12px;
}
.eng-filters { display: flex; flex-wrap: wrap; gap: 8px 12px; align-items: flex-end; }
.eng-actions { display: flex; gap: 6px; align-items: center; }
.eng-fld {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 10.5px; font-weight: 600;
  color: var(--eng-text-muted);
  text-transform: uppercase; letter-spacing: 0.06em;
}
.eng-fld select,
.eng-fld input[type=text] {
  padding: 6px 28px 6px 9px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  font: inherit; font-size: 13px; font-weight: 400;
  background: var(--eng-surf-2); color: var(--eng-text);
  min-width: 140px;
  text-transform: none; letter-spacing: normal;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23A09D96' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 9px center;
}
.eng-fld input[type=text] { background-image: none; padding-right: 9px; }

.eng-toggle {
  padding: 6px 11px;
  border-radius: var(--eng-radius-sm);
  border: 1px solid var(--eng-border-2);
  background: var(--eng-surf-2);
  font: inherit; font-size: 12px; font-weight: 600;
  cursor: pointer;
  color: var(--eng-text-muted);
  transition: background .1s, border-color .1s, color .1s;
  white-space: nowrap;
}
.eng-toggle.is-active {
  background: var(--eng-primary-soft);
  border-color: var(--eng-primary);
  color: var(--eng-primary);
}
.eng-toggle:hover:not(.is-active) { background: var(--eng-surf-3); color: var(--eng-text); }

.eng-btn {
  padding: 7px 13px;
  border-radius: var(--eng-radius-sm);
  font: inherit; font-size: 12.5px; font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  transition: opacity .1s, background .1s;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 6px;
}
.eng-btn-ghost { background: transparent; border-color: var(--eng-border-2); color: var(--eng-text); }
.eng-btn-ghost:hover { background: var(--eng-surf-3); }
.eng-btn-primary { background: var(--eng-primary); color: #fff; border-color: var(--eng-primary); }
.eng-btn-primary:hover { opacity: .88; }
.eng-btn-primary:disabled { opacity: .5; cursor: not-allowed; }
.eng-badge-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: rgba(255,255,255,0.25); border-radius: 999px;
  font-size: 10.5px; font-weight: 700; line-height: 1;
}

/* ── Progress bar + stats ───────────────────────────────────────────────── */
.eng-progress {
  height: 3px;
  background: var(--eng-surf-3);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 10px;
}
.eng-progress > i {
  display: block; height: 100%;
  background: var(--eng-primary);
  width: 0%;
  transition: width .35s ease;
}
.eng-stats {
  text-align: center;
  font-size: 12px;
  color: var(--eng-text-muted);
  margin-bottom: 12px;
  min-height: 18px;
}
.eng-stats .s-ok  { color: var(--eng-success); font-weight: 600; }
.eng-stats .s-?   { color: var(--eng-warn);    font-weight: 600; }
.eng-stats .s-no  { color: var(--eng-danger);  font-weight: 600; }
.eng-stats .s-op  { color: var(--eng-text);    font-weight: 600; }
.eng-stats.milestone { color: var(--eng-success); font-weight: 600; }

.eng-empty { text-align: center; padding: 48px 16px; color: var(--eng-text-muted); line-height: 1.6; }

/* ── Card ───────────────────────────────────────────────────────────────── */
.eng-card {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  overflow: hidden;
  animation: eng-in .16s ease;
}
.eng-card.is-gold { border-color: var(--eng-warn); box-shadow: 0 0 0 2px var(--eng-warn-soft); }
@keyframes eng-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.eng-card-head {
  padding: 10px 14px;
  border-bottom: 1px solid var(--eng-border);
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  align-items: center;
}
.eng-card-title {
  margin: 0; flex: 1; min-width: 180px;
  font-size: 14px; font-weight: 600;
  color: var(--eng-text);
}
.eng-card-meta {
  font-family: var(--pt-mono, monospace);
  font-size: 10.5px; color: var(--eng-text-muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 36ch;
}
.eng-card-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.eng-card-act {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  border: 1px solid var(--eng-border-2);
  border-radius: 7px;
  background: var(--eng-surf-2);
  font: inherit; font-size: 11.5px; font-weight: 600;
  color: var(--eng-text-muted);
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease, color .12s ease;
}
.eng-card-act:hover { background: var(--eng-surf-3); color: var(--eng-text); border-color: var(--eng-border); }
.eng-card-act.is-on { background: var(--eng-warn-soft); border-color: var(--eng-warn); color: var(--eng-warn); }
.eng-card-act svg { width: 14px; height: 14px; flex: 0 0 14px; }

/* Compare grid */
.eng-compare { display: grid; grid-template-columns: 1fr 1fr; }
@media (max-width: 720px) { .eng-compare { grid-template-columns: 1fr; } }
.eng-pane {
  position: relative;
  aspect-ratio: 16 / 10;
  background: var(--eng-surf-3);
  overflow: hidden;
}
.eng-pane + .eng-pane { border-left: 1px solid var(--eng-border); }
@media (max-width: 720px) {
  .eng-pane + .eng-pane { border-left: 0; border-top: 1px solid var(--eng-border); }
}
.eng-pane img, .eng-pane video {
  width: 100%; height: 100%; object-fit: contain; display: block;
}
.eng-pane model-viewer {
  width: 100%; height: 100%; display: block;
  background: var(--eng-surf-3); --poster-color: transparent;
}
.eng-pane-text { background: var(--eng-surf); display: flex; flex-direction: column; }
.eng-brief { flex: 1; padding: 14px; font-size: 12.5px; color: var(--eng-text-muted); line-height: 1.55; overflow-y: auto; }
.eng-brief p { margin: 0 0 6px; }
.eng-brief strong { color: var(--eng-text); font-weight: 600; }
.eng-brief .prompt {
  font-family: var(--pt-mono, monospace);
  font-size: 11.5px;
  padding: 7px 9px; margin-top: 6px;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: 6px;
  color: var(--eng-text);
  white-space: pre-wrap;
}
.eng-brief .tags { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 2px; }
.eng-brief .tag {
  font-size: 10.5px; padding: 1px 7px;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: 999px;
  color: var(--eng-text);
}
.eng-miss {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  color: var(--eng-text-subtle); font-size: 12px;
  text-align: center; padding: 16px;
}
.eng-tour-beats { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.eng-tour-beats li {
  padding: 8px 10px;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: 7px;
}
.eng-tour-num {
  display: inline-block;
  font-family: var(--pt-mono, monospace);
  font-size: 10.5px; letter-spacing: .04em;
  color: var(--eng-text-subtle);
  margin-right: 6px;
}
.eng-tour-narr { display: block; margin-top: 3px; font-size: 11.5px; line-height: 1.45; color: var(--eng-text-muted); }

/* Home Tour start modal */
.eng-tour-lead { margin: 0 0 14px; font-size: 13px; line-height: 1.55; color: var(--eng-text-muted); }
.eng-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 12px; margin-bottom: 14px; }
.eng-fld-wide { grid-column: 1 / -1; }
.eng-fld span { display: block; font-size: 11px; color: var(--eng-text-muted); margin-bottom: 4px; }
.eng-fld select, .eng-fld input, .eng-fld textarea {
  width: 100%; box-sizing: border-box;
  padding: 7px 9px; border-radius: 6px;
  border: 1px solid var(--eng-border);
  background: var(--eng-surf-2); color: var(--eng-text);
  font: inherit; font-size: 13px;
}
.eng-tour-scenes { border: 1px solid var(--eng-border); border-radius: 8px; padding: 10px 12px; margin: 0; }
.eng-tour-scenes legend { font-size: 11px; color: var(--eng-text-muted); padding: 0 4px; }
.eng-tour-scene {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0; font-size: 13px; cursor: pointer;
}
.eng-tour-scene.is-miss { opacity: .55; cursor: not-allowed; }
.eng-tour-anchor { margin-left: auto; font-family: var(--pt-mono, monospace); font-size: 11px; color: var(--eng-success, #6ee7a0); }
.eng-tour-anchor.is-miss { color: var(--eng-text-subtle); }
.eng-tour-cost { margin: 12px 0 0; font-size: 12px; color: var(--eng-text-muted); font-family: var(--pt-mono, monospace); }
.eng-tour-progress {
  position: absolute; bottom: 10px; left: 10px; margin: 0;
  padding: 4px 10px; border-radius: 999px;
  background: rgba(0,0,0,.55); color: #fff;
  font-size: 11px; font-family: var(--pt-mono, monospace);
}

/* ── Home Tour review-speler (supervisor test) ─────────────────────────── */
.eng-empty-acts { display: flex; gap: 8px; justify-content: center; margin-top: 14px; }
.eng-tour-demobadge {
  font-size: 9.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  background: var(--eng-warn-soft, rgba(224,169,58,.16)); color: var(--eng-warn, #E0A93A);
  padding: 2px 7px; border-radius: 5px; vertical-align: middle;
}
.eng-tour-demobadge.is-live {
  background: var(--eng-success-soft, rgba(110,231,160,.14));
  color: var(--eng-success, #6ee7a0);
  margin-left: 4px;
}
.eng-tour-layout { display: grid; grid-template-columns: minmax(0,1.7fr) minmax(220px,1fr); gap: 14px; }
@media (max-width: 880px) { .eng-tour-layout { grid-template-columns: 1fr; } }
.eng-tour-side { position: relative; padding-top: 22px; }
.eng-tour-beats--review { max-height: 420px; overflow-y: auto; }
.eng-tour-beat { display: flex; align-items: flex-start; gap: 8px; cursor: pointer; transition: border-color .15s, background .15s; }
.eng-tour-beat:hover { border-color: var(--eng-accent, #6FBE8E); }
.eng-tour-beat.is-ok { border-left: 2px solid var(--eng-success, #6ee7a0); }
.eng-tour-beat.is-busy { border-left: 2px solid var(--eng-warn, #E0A93A); }
.eng-tour-beat-body { flex: 1; min-width: 0; font-size: 12.5px; }
.eng-tour-beat-body strong { display: block; }
.eng-tour-beat-regen {
  flex: 0 0 auto; border: 1px solid var(--eng-border); background: var(--eng-surf-3);
  color: var(--eng-text-muted); border-radius: 6px; padding: 4px; cursor: pointer; line-height: 0;
}
.eng-tour-beat-regen:hover { color: var(--eng-text); border-color: var(--eng-accent, #6FBE8E); }
.eng-tour-beat-regen svg { width: 14px; height: 14px; }
.eng-tour-beat-choose {
  flex: 0 0 auto; display: inline-flex; align-items: center; gap: 5px;
  border: 1px solid var(--eng-accent, #6FBE8E); background: var(--eng-accent, #6FBE8E); color: #0c1411;
  border-radius: 6px; padding: 4px 9px; cursor: pointer; font: inherit; font-size: 11px; font-weight: 600;
}
.eng-tour-beat-choose:hover { filter: brightness(1.08); }
.eng-tour-beat-choose svg { width: 13px; height: 13px; }

.eng-tour-testmode {
  display: flex; align-items: center; gap: 8px; margin: 0 0 12px;
  padding: 8px 10px; border: 1px dashed var(--eng-border); border-radius: 8px;
  font-size: 12.5px; color: var(--eng-text); cursor: pointer;
}
.eng-tour-freetest {
  display: flex; align-items: flex-start; gap: 9px; margin: 0 0 12px;
  padding: 9px 11px; border: 1px solid var(--eng-accent, #6FBE8E); border-radius: 8px;
  background: color-mix(in srgb, var(--eng-accent, #6FBE8E) 10%, transparent);
  font-size: 12.5px; color: var(--eng-text); cursor: pointer; line-height: 1.4;
}
.eng-tour-freetest input { margin-top: 2px; flex: 0 0 auto; }
.eng-tour-freetest em { color: var(--eng-text-muted); font-style: normal; font-size: 11px; }

/* ── Cast: vaste gidsen ─────────────────────────────────────────────────────── */
.eng-cast-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 14px; margin-top: 6px; }
.eng-cast-loading { color: var(--eng-text-muted); padding: 20px; }
.eng-cast-card { margin: 0; border: 1px solid var(--eng-border); border-radius: 10px; overflow: hidden; background: var(--eng-surf-alt, rgba(255,255,255,0.02)); display: flex; flex-direction: column; }
.eng-cast-thumb { position: relative; aspect-ratio: 3/4; background: var(--eng-surf, #15171a); display: flex; align-items: center; justify-content: center; }
.eng-cast-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.eng-cast-missing { color: var(--eng-text-muted); font-size: 12px; }
.eng-cast-busy { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.55); color: #fff; font-size: 12px; }
.eng-cast-card figcaption { padding: 10px; display: flex; flex-direction: column; gap: 5px; }
.eng-cast-card figcaption strong { font-size: 13px; color: var(--eng-text); }
.eng-cast-blurb { font-size: 11px; color: var(--eng-text-muted); line-height: 1.4; }
.eng-cast-replace { display: inline-flex; align-items: center; gap: 6px; margin-top: 4px; padding: 6px 9px; border: 1px solid var(--eng-border); border-radius: 7px; cursor: pointer; font-size: 11.5px; color: var(--eng-text); width: fit-content; }
.eng-cast-replace:hover { border-color: var(--eng-accent, #6FBE8E); color: var(--eng-accent, #6FBE8E); }
.eng-cast-replace svg { width: 13px; height: 13px; }
.eng-cast-card--eigen { border-style: dashed; }
.eng-cast-card--eigen .eng-cast-thumb { background: var(--eng-surf-alt, rgba(255,255,255,0.03)); }
.eng-cast-eigen-note { display: inline-flex; align-items: flex-start; gap: 6px; margin-top: 4px; font-size: 10.5px; line-height: 1.4; color: var(--eng-text-muted); }
.eng-cast-eigen-note svg { width: 13px; height: 13px; flex-shrink: 0; margin-top: 1px; }
.eng-music-player { width: 100%; margin-top: 4px; height: 34px; }

/* ── Regie-paneel (storyboard vóór render) ─────────────────────────────────── */
.eng-regie-loading { color: var(--eng-text-muted); padding: 24px; text-align: center; }
.eng-regie { max-width: 920px; margin: 0 auto; }
.eng-regie-tourbar {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(120px, 0.5fr) minmax(0, 1fr);
  gap: 12px 16px;
  align-items: start;
  padding: 12px 14px;
  margin-bottom: 12px;
  border: 1px solid var(--eng-border);
  border-radius: 10px;
  background: var(--eng-surf-alt, rgba(255,255,255,0.02));
}
.eng-regie-tourbar__guide { display: flex; align-items: flex-start; gap: 10px; min-width: 0; }
.eng-regie-tourbar__guide img { width: 48px; height: 48px; border-radius: 8px; object-fit: cover; border: 1px solid var(--eng-border); flex: none; }
.eng-regie-tourbar__guide .eng-regie-fld { flex: 1; min-width: 0; }
.eng-regie-tourbar__tone { display: flex; flex-direction: column; justify-content: flex-start; }
.eng-regie-tourbar__settings { display: flex; flex-wrap: wrap; gap: 8px 12px; align-items: flex-end; }
.eng-regie-tourbar__settings .eng-regie-fld { flex: 1; min-width: 130px; }
.eng-regie-tourbar__foot {
  grid-column: 1 / -1;
  font-size: 11px;
  color: var(--eng-text-muted);
  line-height: 1.45;
  padding-top: 4px;
  border-top: 1px solid var(--eng-border);
  margin-top: 2px;
}
.eng-regie-tourbar__music {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 11.5px;
  color: var(--eng-text-muted);
}
.eng-regie-tourbar__music strong { color: var(--eng-text); font-size: 12px; }
.eng-regie-persona { display: flex; align-items: center; gap: 12px; min-width: 0; }
.eng-regie-persona img { width: 52px; height: 52px; border-radius: 10px; object-fit: cover; border: 1px solid var(--eng-border); }
.eng-regie-persona > div, .eng-regie-music { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.eng-regie-kicker { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--eng-text-muted); }
.eng-regie-kicker svg { width: 12px; height: 12px; }
.eng-regie-persona strong, .eng-regie-music strong { font-size: 14px; color: var(--eng-text); }
.eng-regie-blurb { font-size: 11.5px; color: var(--eng-text-muted); line-height: 1.4; }
.eng-regie-music { text-align: right; align-items: flex-end; }
.eng-regie-advice { display: flex; gap: 10px; padding: 11px 13px; border: 1px solid var(--eng-border); border-left: 3px solid var(--eng-accent, #6FBE8E); border-radius: 9px; background: rgba(111,190,142,.06); margin-bottom: 14px; }
.eng-regie-advice svg { width: 16px; height: 16px; color: var(--eng-accent, #6FBE8E); flex: none; margin-top: 2px; }
.eng-regie-advice strong { display: block; font-size: 12px; color: var(--eng-text); margin-bottom: 4px; }
.eng-regie-advice ul { margin: 0; padding-left: 16px; }
.eng-regie-advice li { font-size: 12px; color: var(--eng-text-muted); line-height: 1.5; }
.eng-regie-layout {
  display: grid;
  grid-template-columns: minmax(200px, 260px) 1fr;
  gap: 16px;
  align-items: start;
}
.eng-regie-chapters {
  position: sticky;
  top: 8px;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--eng-border, rgba(255,255,255,.08));
  background: var(--eng-surface-2, rgba(255,255,255,.03));
}
.eng-regie-chapterlist {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.eng-regie-chapteritem {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 8px;
  font-size: 12px;
}
.eng-regie-chapnum { color: var(--eng-text-muted); font-variant-numeric: tabular-nums; }
.eng-regie-chapnarr {
  display: block;
  margin-top: 3px;
  color: var(--eng-text-muted);
  line-height: 1.35;
}
.eng-regie-chapnarr.is-empty { font-style: italic; opacity: 0.75; }
.eng-regie-beats { display: flex; flex-direction: column; gap: 12px; }
.eng-regie-beat {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--eng-border);
  border-radius: 10px;
  background: var(--eng-surf-alt, rgba(255,255,255,0.02));
}
.eng-regie-thumb {
  position: relative;
  aspect-ratio: 16/9;
  background: #111;
  border-radius: 8px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.eng-regie-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.eng-regie-idx { position: absolute; top: 6px; left: 6px; font-size: 11px; font-weight: 700; color: #fff; background: rgba(0,0,0,.5); padding: 2px 6px; border-radius: 4px; }
.eng-regie-composite { position: absolute; inset: 0; background: #000; }
.eng-regie-composite img { width: 100%; height: 100%; object-fit: cover; }
.eng-regie-castbadge { position: absolute; bottom: 8px; left: 8px; display: inline-flex; align-items: center; gap: 4px; font-size: 10.5px; color: #fff; background: rgba(111,190,142,.85); padding: 3px 7px; border-radius: 6px; }
.eng-regie-castbadge svg { width: 11px; height: 11px; }
.eng-regie-body { padding: 0; display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.eng-regie-body header { display: flex; align-items: center; gap: 8px; flex-wrap: nowrap; }
.eng-regie-body header strong { font-size: 14px; color: var(--eng-text); margin: 0; flex: 1; min-width: 0; }
.eng-regie-beat-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.eng-regie-meta { margin: 0; font-size: 11px; color: var(--eng-text-muted); line-height: 1.4; }
.eng-regie-dir span { flex: 1; }
.eng-tt { cursor: help; border-bottom: 1px dotted var(--eng-text-subtle, #6F6C66); }
.eng-tt-wrap { position: relative; display: inline-flex; align-items: center; gap: 4px; }
.eng-tt-wrap[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute;
  left: 0;
  bottom: calc(100% + 6px);
  z-index: 20;
  max-width: 280px;
  padding: 8px 10px;
  font-size: 11px;
  line-height: 1.4;
  font-weight: 400;
  color: var(--eng-text);
  background: var(--eng-surf-2, #232220);
  border: 1px solid var(--eng-border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  pointer-events: none;
  text-transform: none;
  letter-spacing: normal;
}
.eng-regie-fld > span.eng-tt-wrap { text-transform: uppercase; }
.eng-regie-tag { display: inline-flex; align-items: center; gap: 4px; font-size: 10.5px; padding: 2px 8px; border-radius: 999px; border: 1px solid var(--eng-border); color: var(--eng-text-muted); }
.eng-regie-tag.is-on { color: var(--eng-accent, #6FBE8E); border-color: var(--eng-accent, #6FBE8E); }
.eng-regie-tag svg { width: 11px; height: 11px; }
.eng-regie-dir { font-size: 12px; color: var(--eng-text-muted); line-height: 1.5; margin: 0; }
.eng-regie-grid { display: flex; flex-wrap: wrap; gap: 6px 18px; margin: 0; }
.eng-regie-grid > div { display: flex; flex-direction: column; }
.eng-regie-grid dt { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: var(--eng-text-muted); }
.eng-regie-grid dd { margin: 0; font-size: 12px; color: var(--eng-text); }
.eng-regie-script { display: flex; gap: 7px; font-size: 12.5px; font-style: italic; color: var(--eng-text-muted); line-height: 1.5; margin: 0; }
.eng-regie-script svg { width: 14px; height: 14px; flex: none; margin-top: 2px; }
.eng-regie-cast { align-self: flex-start; margin-top: 2px; }
.eng-regie-cast-wrap { display: flex; flex-direction: column; gap: 8px; }
.eng-regie-cast-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.eng-regie-castnote { width: 100%; }
.eng-regie-castnote input { width: 100%; }
.eng-regie-approved { display: inline-flex; align-items: center; gap: 5px; align-self: flex-start; font-size: 11px; color: #6fbe8e; background: rgba(111,190,142,.12); border: 1px solid rgba(111,190,142,.4); padding: 3px 8px; border-radius: 6px; }
.eng-regie-approved svg { width: 12px; height: 12px; }
.eng-regie-cost { font-size: 12px; color: var(--eng-text-muted); font-variant-numeric: tabular-nums; padding-left: 8px; }

/* ── Regie-paneel: bewerkbaar ─────────────────────────────────────────────── */
.eng-regie-presetbar { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 8px; padding-bottom: 12px; margin-bottom: 12px; border-bottom: 1px solid var(--eng-border); }
.eng-regie-fld { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.eng-regie-fld > span { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: var(--eng-text-muted); display: inline-flex; align-items: center; gap: 4px; }
.eng-regie-fld > span svg { width: 12px; height: 12px; }
.eng-regie-fld select, .eng-regie-fld textarea, .eng-regie-nameinput {
  font-size: 12.5px; color: var(--eng-text); background: var(--eng-surf, #15171a);
  border: 1px solid var(--eng-border); border-radius: 7px; padding: 6px 9px; font-family: inherit;
}
.eng-regie-fld textarea { resize: vertical; line-height: 1.45; min-height: 38px; }
.eng-regie-fld select:focus, .eng-regie-fld textarea:focus, .eng-regie-nameinput:focus { outline: none; border-color: var(--eng-accent, #6FBE8E); }
.eng-regie-nameinput { min-width: 130px; align-self: flex-end; }
.eng-regie-saved { font-size: 11px; color: var(--eng-accent, #6FBE8E); margin-right: 8px; }
.eng-regie-del { color: #d98a8a; }
.eng-regie-del:hover { border-color: #d98a8a; color: #e0a0a0; }
.eng-regie-engtag {
  font-size: 10px; font-family: var(--eng-mono, monospace); padding: 2px 7px; border-radius: 999px;
  border: 1px solid rgba(111,190,142,.35); color: var(--eng-accent, #6FBE8E); background: rgba(111,190,142,.08);
  white-space: nowrap;
}
.eng-regie-beatctl { display: inline-flex; gap: 4px; margin-left: auto; }
.eng-regie-mini { width: 26px; height: 24px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--eng-border); border-radius: 6px; background: var(--eng-surf, #15171a); color: var(--eng-text-muted); cursor: pointer; }
.eng-regie-mini svg { width: 13px; height: 13px; }
.eng-regie-mini:hover:not(:disabled) { border-color: var(--eng-accent, #6FBE8E); color: var(--eng-accent, #6FBE8E); }
.eng-regie-mini:disabled { opacity: .35; cursor: default; }
.eng-regie-mini.eng-regie-del:hover:not(:disabled) { border-color: #d98a8a; color: #e0a0a0; }
.eng-regie-edit { display: none; }
.eng-regie-motion { display: flex; flex-direction: column; gap: 4px; }
.eng-regie-fldlbl { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: var(--eng-text-muted); }
.eng-regie-chips { display: flex; flex-wrap: wrap; gap: 5px; }
.eng-regie-chip { font-size: 11px; padding: 4px 9px; border: 1px solid var(--eng-border); border-radius: 999px; color: var(--eng-text-muted); cursor: pointer; user-select: none; }
.eng-regie-chip.is-on { border-color: var(--eng-accent, #6FBE8E); color: var(--eng-accent, #6FBE8E); background: rgba(111,190,142,.08); }
.eng-regie-scriptfld { width: 100%; }
.eng-regie-addrow { display: flex; align-items: flex-end; gap: 8px; padding-top: 12px; margin-top: 12px; border-top: 1px solid var(--eng-border); }
@media (max-width: 720px) {
  .eng-regie-tourbar { grid-template-columns: 1fr; }
  .eng-regie-layout { grid-template-columns: 1fr; }
  .eng-regie-chapters { position: static; }
  .eng-regie-beat { grid-template-columns: 1fr; }
  .eng-regie-beat-row { grid-template-columns: 1fr; }
}

.eng-tourp { display: flex; flex-direction: column; gap: 10px; }
.eng-tourp-screen {
  position: relative; aspect-ratio: 16/9; width: 100%;
  background: #000; border-radius: 12px; overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,.45);
}
.eng-tourp-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity 0.42s ease; }
.eng-tourp-vig { position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, rgba(0,0,0,.62) 0%, rgba(0,0,0,0) 38%, rgba(0,0,0,0) 70%, rgba(0,0,0,.28) 100%); }
.eng-tourp-presenter {
  position: absolute; top: 12px; left: 12px; z-index: 3;
  display: flex; align-items: center; gap: 9px; max-width: 62%;
  padding: 7px 12px 7px 10px; border-radius: 999px;
  background: rgba(8,10,14,.55); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.12);
}
.eng-tourp-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 9px;
  background: #6FBE8E; box-shadow: 0 0 0 0 rgba(111,190,142,.6); animation: engTourPulse 2.4s infinite; }
@keyframes engTourPulse { 0% { box-shadow: 0 0 0 0 rgba(111,190,142,.55); } 70% { box-shadow: 0 0 0 9px rgba(111,190,142,0); } 100% { box-shadow: 0 0 0 0 rgba(111,190,142,0); } }
.eng-tourp-name { margin: 0; font-size: 12px; font-weight: 700; color: #fff; }
.eng-tourp-blurb { margin: 0; font-size: 10.5px; color: rgba(255,255,255,.72); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.eng-tourp-badge {
  position: absolute; top: 14px; right: 14px; z-index: 3;
  font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  color: #fff; background: rgba(8,10,14,.5); padding: 4px 10px; border-radius: 999px;
  backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.1);
}
.eng-tourp-cap { position: absolute; left: 18px; right: 18px; bottom: 30px; z-index: 3; }
.eng-tourp-cap p {
  margin: 0; font-size: 15px; line-height: 1.45; font-weight: 500; color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,.7); transition: opacity .25s ease; max-width: 80%;
}
.eng-tourp-segs { position: absolute; left: 14px; right: 14px; bottom: 14px; z-index: 3; display: flex; gap: 5px; }
.eng-tourp-seg { flex: 1; height: 3px; border-radius: 3px; background: rgba(255,255,255,.28); overflow: hidden; }
.eng-tourp-seg i { display: block; height: 100%; width: 0%; background: #fff; transition: width .15s linear; }
.eng-tourp-play {
  position: absolute; right: 14px; top: 50%; transform: translateY(-50%); z-index: 4;
  width: 46px; height: 46px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25);
  background: rgba(8,10,14,.5); color: #fff; cursor: pointer; opacity: 0; transition: opacity .2s;
  display: flex; align-items: center; justify-content: center; backdrop-filter: blur(6px);
}
.eng-tourp-screen:hover .eng-tourp-play { opacity: 1; }
.eng-tourp-play svg { width: 20px; height: 20px; }
.eng-tourp-snd {
  position: absolute; right: 14px; bottom: 28px; z-index: 4;
  width: 32px; height: 32px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25);
  background: rgba(8,10,14,.5); color: #fff; cursor: pointer; opacity: 0; transition: opacity .2s;
  display: flex; align-items: center; justify-content: center; backdrop-filter: blur(6px);
}
.eng-tourp-screen:hover .eng-tourp-snd { opacity: 1; }
.eng-tourp-snd svg { width: 16px; height: 16px; }
.eng-tourp-rail { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.eng-tourp-chip {
  flex: 0 0 auto; display: flex; align-items: center; gap: 7px;
  padding: 7px 11px; border-radius: 8px; cursor: pointer;
  border: 1px solid var(--eng-border); background: var(--eng-surf-2); color: var(--eng-text-muted);
  font: inherit; font-size: 12px; transition: all .15s;
}
.eng-tourp-chip .n { font-family: var(--pt-mono, monospace); font-size: 10px; opacity: .7; }
.eng-tourp-chip.is-active { background: var(--eng-accent, #6FBE8E); color: #0c1411; border-color: transparent; font-weight: 600; }
.eng-tourp-chip:hover:not(.is-active) { color: var(--eng-text); border-color: var(--eng-accent, #6FBE8E); }
.eng-tag {
  position: absolute; top: 8px; left: 8px; z-index: 2;
  font-size: 9.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  background: rgba(0,0,0,0.55); color: #fff;
  padding: 3px 8px; border-radius: 4px;
  backdrop-filter: blur(4px); pointer-events: none;
}
.eng-tag-r { left: auto; right: 8px; }

.eng-cmp-pick {
  position: absolute; bottom: 8px; left: 8px; z-index: 3;
}
.eng-cmp-pick select {
  font-size: 11px;
  padding: 4px 22px 4px 8px;
  background: rgba(0,0,0,0.55); color: #fff;
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: 4px;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='8' height='5' viewBox='0 0 8 5' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L4 4L7 1' stroke='%23fff' stroke-width='1.2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 7px center;
}

/* Vision QC block */
.eng-qc {
  padding: 8px 14px;
  border-bottom: 1px solid var(--eng-border);
  background: var(--eng-surf-2);
  display: flex; flex-direction: column; gap: 5px;
}
.eng-qc-row { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.eng-qc-b {
  padding: 2px 7px; border-radius: 4px;
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  flex-shrink: 0;
}
.eng-qc-b.OK       { background: var(--eng-success-soft); color: var(--eng-success); }
.eng-qc-b.MINOR    { background: var(--eng-warn-soft);    color: var(--eng-warn); }
.eng-qc-b.FIX      { background: var(--eng-warn-soft);    color: var(--eng-warn); }
.eng-qc-b.CRITICAL { background: var(--eng-danger-soft);  color: var(--eng-danger); }
.eng-qc-b.SKIP      { background: var(--eng-surf-3);     color: var(--eng-text-muted); }
.eng-qc-score {
  font-size: 10.5px; color: var(--eng-text-muted);
  font-family: var(--pt-mono, monospace);
}
.eng-qc-src {
  font-size: 10px; color: var(--eng-text-muted);
  font-family: var(--pt-mono, monospace);
}
.eng-src-ok {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 600;
  color: #5cb88a;
  vertical-align: middle;
}
.eng-src-warn {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 600;
  color: #E07561;
  vertical-align: middle;
}
.eng-drift { display: flex; flex-wrap: wrap; gap: 4px; }
.eng-drift-chip {
  font-size: 10.5px; padding: 2px 6px;
  border-radius: 4px;
  background: var(--eng-surf-3);
  color: var(--eng-text-muted);
  border: 1px solid var(--eng-border);
  font-family: var(--pt-mono, monospace);
}
.eng-qc-plain {
  margin: 0 0 4px; font-size: 12.5px; font-weight: 600;
  line-height: 1.45;
}
.eng-qc-plain.ok      { color: #1a7f3c; }
.eng-qc-plain.minor   { color: #6b7280; }
.eng-qc-plain.bad     { color: #b42318; }
.eng-qc-plain.neutral { color: var(--eng-text-muted); }
.eng-qc-notes {
  margin: 0; font-size: 12px; font-style: italic;
  color: var(--eng-text-muted); line-height: 1.5;
}
.eng-pattern {
  margin: 8px 14px;
  padding: 8px 12px;
  background: var(--eng-warn-soft);
  border: 1px solid var(--eng-warn);
  border-radius: 8px;
  font-size: 12px;
  color: var(--eng-text);
  line-height: 1.5;
}

/* Verdict row */
.eng-verdict {
  padding: 12px 14px;
  display: flex; flex-wrap: wrap; gap: 6px;
  align-items: center;
  border-top: 1px solid var(--eng-border);
  background: var(--eng-surf-2);
}
.eng-vbtn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1.5px solid var(--eng-border-2);
  background: var(--eng-surf);
  font: inherit; font-size: 13px; font-weight: 600;
  cursor: pointer;
  color: var(--eng-text);
  user-select: none;
  transition: border-color .1s, background .1s, color .1s;
}
.eng-vbtn svg { width: 14px; height: 14px; flex: 0 0 14px; }
.eng-vbtn:hover:not(.is-active) {
  border-color: var(--eng-text-muted);
  background: var(--eng-surf-3);
}
.eng-vbtn.is-active[data-verdict="approved"] { background: var(--eng-success-soft); border-color: var(--eng-success); color: var(--eng-success); }
.eng-vbtn.is-active[data-verdict="doubt"]    { background: var(--eng-warn-soft);    border-color: var(--eng-warn);    color: var(--eng-warn); }
.eng-vbtn.is-active[data-verdict="rejected"] { background: var(--eng-danger-soft);  border-color: var(--eng-danger);  color: var(--eng-danger); }

.eng-notes-wrap { flex: 1; min-width: 160px; display: flex; flex-direction: column; gap: 5px; }
.eng-notes {
  width: 100%;
  padding: 6px 9px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  font: inherit; font-size: 12px;
  background: var(--eng-surf);
  color: var(--eng-text);
  box-sizing: border-box;
}
.eng-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.eng-chip {
  font: inherit; font-size: 11px;
  padding: 2px 8px;
  border: 1px solid var(--eng-border-2);
  border-radius: 999px;
  background: var(--eng-surf);
  color: var(--eng-text-muted);
  cursor: pointer;
}
.eng-chip:hover { background: var(--eng-surf-3); color: var(--eng-text); }

/* Navigator */
.eng-nav {
  display: flex; align-items: center; justify-content: center;
  gap: 12px; padding: 12px 0;
}
.eng-nav-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--eng-border-2);
  background: var(--eng-surf);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--eng-text); font-size: 16px; line-height: 1;
}
.eng-nav-btn:hover:not(:disabled) { background: var(--eng-surf-3); }
.eng-nav-btn:disabled { opacity: .3; cursor: not-allowed; }
.eng-nav-btn svg { width: 16px; height: 16px; }
.eng-nav-counter {
  font-size: 13px; color: var(--eng-text-muted);
  min-width: 110px; text-align: center;
}
.eng-hint { text-align: center; font-size: 11px; color: var(--eng-text-subtle); padding: 4px 0 20px; }
.eng-hint kbd {
  display: inline-block; padding: 1px 5px;
  border: 1px solid var(--eng-border-2);
  border-radius: 4px;
  font-family: var(--pt-mono, monospace);
  font-size: 10.5px;
  background: var(--eng-surf-2); color: var(--eng-text-muted);
}

/* Grid mode */
.eng-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
}
.eng-grid-item {
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf);
  overflow: hidden;
  cursor: pointer;
  transition: border-color .12s;
}
.eng-grid-item:hover { border-color: var(--eng-text-muted); }
.eng-grid-item.v-approved { border-color: var(--eng-success); }
.eng-grid-item.v-doubt    { border-color: var(--eng-warn); }
.eng-grid-item.v-rejected { border-color: var(--eng-danger); }
.eng-grid-item.is-gold    { box-shadow: 0 0 0 2px var(--eng-warn-soft); }
.eng-grid-thumb {
  aspect-ratio: 16 / 10; background: var(--eng-surf-3);
  overflow: hidden; position: relative;
}
.eng-grid-thumb img, .eng-grid-thumb video {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.eng-grid-verdict {
  position: absolute; top: 6px; right: 6px;
  width: 22px; height: 22px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #fff;
  border: 2px solid rgba(255,255,255,0.4);
}
.eng-grid-verdict.v-approved { background: var(--eng-success); }
.eng-grid-verdict.v-doubt    { background: var(--eng-warn); }
.eng-grid-verdict.v-rejected { background: var(--eng-danger); }
.eng-grid-verdict.v-pending  { background: rgba(0,0,0,0.45); border-color: transparent; }
.eng-grid-label {
  padding: 7px 10px;
  font-size: 11.5px; color: var(--eng-text);
  line-height: 1.35;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Matrix */
.eng-matrix {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  overflow: hidden;
}
.eng-matrix th, .eng-matrix td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--eng-border);
  border-right: 1px solid var(--eng-border);
  text-align: center; vertical-align: middle; white-space: nowrap;
}
.eng-matrix th {
  background: var(--eng-surf-2);
  font-weight: 600; font-size: 10.5px;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--eng-text-muted);
}
.eng-matrix th:first-child,
.eng-matrix td:first-child {
  text-align: left; font-weight: 600;
  background: var(--eng-surf-2);
  color: var(--eng-text);
}
.eng-mc { cursor: pointer; transition: background .1s; }
.eng-mc:hover { background: var(--eng-surf-3); }
.eng-mc .pct   { font-weight: 600; font-size: 14px; }
.eng-mc .count { font-size: 10px; color: var(--eng-text-muted); display: block; margin-top: 2px; }
.eng-mc.q-high { background: var(--eng-success-soft); color: var(--eng-success); }
.eng-mc.q-mid  { background: var(--eng-warn-soft);    color: var(--eng-warn); }
.eng-mc.q-low  { background: var(--eng-danger-soft);  color: var(--eng-danger); }
.eng-mc.q-none { color: var(--eng-text-subtle); }

/* Drift cards */
.eng-drift-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
}
.eng-drift-card {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  padding: 14px;
  cursor: pointer;
  transition: border-color .1s, background .1s;
}
.eng-drift-card:hover { border-color: var(--eng-primary); background: var(--eng-primary-soft); }
.eng-drift-card .tag {
  font-family: var(--pt-mono, monospace);
  font-size: 12.5px; font-weight: 600;
  color: var(--eng-text);
  margin-bottom: 4px; word-break: break-word;
}
.eng-drift-card .count { font-size: 20px; font-weight: 700; color: var(--eng-primary); }
.eng-drift-card .sub { font-size: 11px; color: var(--eng-text-muted); margin-top: 3px; }

/* Disagreement table */
.eng-dis-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  overflow: hidden;
}
.eng-dis-table th, .eng-dis-table td {
  padding: 8px 10px; text-align: left;
  border-bottom: 1px solid var(--eng-border);
  vertical-align: middle;
}
.eng-dis-table th {
  background: var(--eng-surf-2);
  font-size: 10.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--eng-text-muted);
}
.eng-dis-table tr { cursor: pointer; }
.eng-dis-table tr:hover { background: var(--eng-surf-2); }
.eng-dis-thumb { width: 80px; height: 50px; object-fit: cover; border-radius: 4px; background: var(--eng-surf-3); }

/* Stat cards */
.eng-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.eng-stat-card {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  padding: 12px 14px;
}
.eng-stat-card .label { font-size: 10.5px; font-weight: 600; color: var(--eng-text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.eng-stat-card .value { font-size: 20px; font-weight: 700; color: var(--eng-text); margin-top: 4px; }
.eng-stat-card .sub   { font-size: 11px; color: var(--eng-text-muted); margin-top: 2px; }

/* Models */
.eng-mg {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  margin-bottom: 10px;
  overflow: hidden;
}
.eng-mg-head {
  padding: 8px 14px;
  background: var(--eng-surf-2);
  border-bottom: 1px solid var(--eng-border);
  font-size: 12.5px; font-weight: 600;
  color: var(--eng-text);
}
.eng-mg-row {
  padding: 7px 14px;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px;
  border-bottom: 1px solid var(--eng-border);
  color: var(--eng-text);
}
.eng-mg-row:last-child { border-bottom: none; }
.eng-mg-name { font-family: var(--pt-mono, monospace); }
.eng-mg-role { font-size: 10.5px; color: var(--eng-text-muted); margin-left: 7px; }

/* ── Modal overlay (anchor/edit/prompt/confirm) ─────────────────────────── */
.eng-modal-backdrop {
  /* z-index 999999 = boven model-viewer, sidebar drawer, fixed-elements.
     model-viewer creëert eigen compositing-layer; alleen extreem hoge z-index
     wint betrouwbaar. */
  position: fixed; inset: 0; z-index: 999999;
  background: rgba(8, 8, 6, 0.86);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  animation: eng-fade .15s ease;
  overflow-y: auto;
}
@keyframes eng-fade { from { opacity: 0; } to { opacity: 1; } }
.eng-modal {
  background: var(--eng-surf, #1C1C1A);
  border: 1px solid var(--eng-border, #2A2A28);
  border-radius: 12px;
  max-width: 760px; width: 100%;
  max-height: calc(100vh - 32px);
  display: flex; flex-direction: column;
  box-shadow: 0 24px 80px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,255,255,0.04);
  animation: eng-slide-up .18s ease;
  /* Solid background — geen tint van wat erachter ligt */
  isolation: isolate;
  position: relative; z-index: 1;
}
:root[data-theme="light"] .eng-modal {
  background: #FFFFFF;
  border-color: #E5E5E0;
}
:root[data-theme="light"] .eng-modal-backdrop {
  background: rgba(20, 18, 14, 0.55);
}
@keyframes eng-slide-up { from { transform: translateY(8px); opacity: 0; } to { transform: none; opacity: 1; } }
.eng-modal.wide { max-width: 960px; }
@media (max-width: 640px) {
  .eng-modal-backdrop { padding: 0; align-items: stretch; }
  .eng-modal, .eng-modal.wide {
    max-width: 100%;
    max-height: 100vh;
    border-radius: 0;
    height: 100vh;
  }
}
.eng-modal-head {
  padding: 16px 20px;
  border-bottom: 1px solid var(--eng-border, #2A2A28);
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px;
  flex: 0 0 auto;
}
.eng-modal-head h3 {
  margin: 0; font-size: 16px; font-weight: 600;
  color: var(--eng-text, #F2F0EB); line-height: 1.3;
}
.eng-modal-head .sub {
  display: block; font-size: 11.5px; color: var(--eng-text-muted, #A09D96);
  font-family: var(--pt-mono, monospace); margin-top: 4px;
  word-break: break-word;
}
:root[data-theme="light"] .eng-modal-head { border-bottom-color: #E5E5E0; }
:root[data-theme="light"] .eng-modal-head h3 { color: #1A1A1A; }
:root[data-theme="light"] .eng-modal-head .sub { color: #6B6B6B; }
.eng-modal-close {
  background: transparent; border: none;
  width: 36px; height: 36px; border-radius: 8px;
  font-size: 22px; line-height: 1; color: var(--eng-text-muted, #A09D96); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 36px;
}
.eng-modal-close:hover { background: var(--eng-surf-3, #232220); color: var(--eng-text, #F2F0EB); }
:root[data-theme="light"] .eng-modal-close:hover { background: #F1EFEA; color: #1A1A1A; }
.eng-modal-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 20px;
  -webkit-overflow-scrolling: touch;
}
.eng-modal.eng-ui.wide .eng-modal-body:has(.eng-clip-v3) {
  padding: 22px 24px;
}
.eng-modal.eng-ui .eng-modal-body svg {
  flex-shrink: 0;
}
.eng-modal-foot {
  padding: 14px 20px;
  border-top: 1px solid var(--eng-border, #2A2A28);
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center; justify-content: flex-end;
  flex: 0 0 auto;
  background: var(--eng-surf, #1C1C1A);
}
:root[data-theme="light"] .eng-modal-foot {
  background: #FFFFFF;
  border-top-color: #E5E5E0;
}
@media (max-width: 600px) {
  .eng-modal-foot { padding: 12px 16px; }
  .eng-modal-foot button { flex: 1 1 auto; min-height: 44px; }
}

/* Anker modal: grid of thumbnails */
.eng-anchor-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}
.eng-anchor-thumb {
  position: relative;
  border: 2px solid var(--eng-border, #2A2A28);
  border-radius: 8px;
  background: var(--eng-surf-3, #232220);
  overflow: hidden; cursor: pointer;
  transition: border-color .14s, transform .12s, box-shadow .14s;
  aspect-ratio: 16 / 10;
}
.eng-anchor-thumb:hover {
  border-color: var(--eng-primary, #C8956C);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.30);
}
/* Geselecteerd anker: VEEL prominenter — dikke gouden rand, glow, schaal,
   check-overlay rechtsonder. Ook scroll-into-view bij selectie (in JS). */
.eng-anchor-thumb.is-selected {
  border-color: var(--eng-primary, #C8956C);
  border-width: 4px;
  box-shadow:
    0 0 0 2px rgba(200,149,108,0.35),
    0 0 30px rgba(200,149,108,0.45),
    0 10px 30px rgba(0,0,0,0.40);
  transform: translateY(-2px) scale(1.02);
  z-index: 2;
}
.eng-anchor-thumb.is-selected::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(200,149,108,0.20) 0%, rgba(200,149,108,0) 35%, rgba(200,149,108,0) 65%, rgba(200,149,108,0.20) 100%);
  pointer-events: none;
}
.eng-anchor-thumb.is-selected .eng-anchor-check {
  display: flex;
  animation: eng-check-pop .25s cubic-bezier(.34,1.56,.64,1);
}
@keyframes eng-check-pop {
  from { transform: scale(0); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}
.eng-anchor-check {
  display: none;
  position: absolute; bottom: 28px; right: 8px;
  width: 32px; height: 32px;
  background: var(--eng-primary, #C8956C);
  border-radius: 50%;
  align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,0.40), 0 0 0 3px rgba(255,255,255,0.20);
  z-index: 3;
  color: #14120E;
}
.eng-anchor-check svg { width: 16px; height: 16px; }
.eng-anchor-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.eng-anchor-badge {
  position: absolute; top: 6px;
  font-size: 9.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  padding: 3px 8px; border-radius: 4px;
  background: var(--eng-surf, #1C1C1A);
  color: var(--eng-text, #F2F0EB); border: 1px solid var(--eng-border, #2A2A28);
  box-shadow: 0 2px 6px rgba(0,0,0,0.30);
  z-index: 3;
}
.eng-anchor-badge.b-orig { left: 6px; background: rgba(160,114,42,0.95); color: #FFFFFF; border-color: rgba(224,169,58,0.8); }
.eng-anchor-badge.b-cur  { right: 6px; background: rgba(45,122,79,0.95); color: #FFFFFF; border-color: rgba(111,190,142,0.8); }
.eng-anchor-foot {
  padding: 6px 10px;
  font-size: 10.5px; color: var(--eng-text-muted, #A09D96);
  background: var(--eng-surf-2, #14120E);
  border-top: 1px solid var(--eng-border, #2A2A28);
  font-family: var(--pt-mono, monospace);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
:root[data-theme="light"] .eng-anchor-thumb { background: #F1EFEA; border-color: #D9D8D2; }
:root[data-theme="light"] .eng-anchor-thumb.is-selected { border-color: #8B4513; box-shadow: 0 0 0 2px rgba(139,69,19,0.30), 0 0 30px rgba(200,149,108,0.50), 0 10px 30px rgba(0,0,0,0.20); }
:root[data-theme="light"] .eng-anchor-foot { background: #FAFAF8; color: #6B6B6B; border-top-color: #E5E5E0; }
:root[data-theme="light"] .eng-anchor-check { background: #8B4513; color: #FFFFFF; }

/* Loading overlay binnen modal (na submit) */
.eng-modal-loading {
  position: absolute; inset: 0;
  background: rgba(8, 8, 6, 0.85);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 16px;
  z-index: 10;
  border-radius: inherit;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.eng-modal-loading .spinner {
  width: 48px; height: 48px;
  border: 3px solid rgba(200,149,108,0.20);
  border-top-color: var(--eng-primary, #C8956C);
  border-radius: 50%;
  animation: eng-spin 0.7s linear infinite;
}
@keyframes eng-spin { to { transform: rotate(360deg); } }
.eng-modal-loading .title {
  font-size: 14px; font-weight: 600; color: var(--eng-text, #F2F0EB);
}
.eng-modal-loading .sub {
  font-size: 12px; color: var(--eng-text-muted, #A09D96);
  font-family: var(--pt-mono, monospace);
  max-width: 360px; text-align: center;
  line-height: 1.5;
}
:root[data-theme="light"] .eng-modal-loading { background: rgba(255,255,255,0.92); }
:root[data-theme="light"] .eng-modal-loading .title { color: #1A1A1A; }
:root[data-theme="light"] .eng-modal-loading .sub { color: #6B6B6B; }

/* Toast: succes/error na regenerate */
.eng-toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%);
  z-index: 1000000;
  background: var(--eng-surf, #1C1C1A);
  border: 1px solid var(--eng-border, #2A2A28);
  border-radius: 10px;
  padding: 14px 20px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.50);
  font-size: 13.5px;
  color: var(--eng-text, #F2F0EB);
  display: flex; align-items: center; gap: 12px;
  max-width: calc(100vw - 32px);
  animation: eng-toast-in .25s cubic-bezier(.34,1.56,.64,1);
}
.eng-toast.is-success { border-left: 4px solid #6FBE8E; }
.eng-toast.is-error   { border-left: 4px solid #E07561; }
.eng-toast.is-fade { animation: eng-toast-out .25s ease forwards; }
.eng-toast .ico {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.eng-toast .ico svg.ic {
  width: 20px;
  height: 20px;
  flex: none;
  display: block;
}
.eng-toast.is-success .ico { color: #6FBE8E; }
.eng-toast.is-error   .ico { color: #E07561; }
.eng-toast .msg strong { display: block; font-weight: 600; margin-bottom: 1px; }
.eng-toast .msg .sub { font-size: 11.5px; color: var(--eng-text-muted, #A09D96); font-family: var(--pt-mono, monospace); }
:root[data-theme="light"] .eng-toast { background: #FFFFFF; border-color: #E5E5E0; color: #1A1A1A; box-shadow: 0 20px 40px rgba(0,0,0,0.20); }
:root[data-theme="light"] .eng-toast .msg .sub { color: #6B6B6B; }
@keyframes eng-toast-in {
  from { transform: translate(-50%, 24px); opacity: 0; }
  to   { transform: translate(-50%, 0);    opacity: 1; }
}
@keyframes eng-toast-out {
  from { transform: translate(-50%, 0); opacity: 1; }
  to   { transform: translate(-50%, 24px); opacity: 0; }
}

/* Run-progress paneel rechtsonder — blijft staan tot succeeded/failed */
.eng-prog-panel {
  position: fixed;
  right: 18px; bottom: 18px;
  z-index: 999998;
  width: 360px;
  max-width: calc(100vw - 24px);
  background: var(--eng-surf, #1B1916);
  border: 1px solid var(--eng-border, rgba(242,240,235,0.14));
  border-radius: 12px;
  box-shadow: 0 24px 48px rgba(0,0,0,0.45);
  overflow: hidden;
  font-family: var(--pt-sans, system-ui);
  animation: eng-prog-in .22s ease;
}
@keyframes eng-prog-in {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.eng-prog-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  background: linear-gradient(180deg, rgba(200,149,108,0.10), rgba(200,149,108,0.02));
  border-bottom: 1px solid var(--eng-border, rgba(242,240,235,0.10));
  font-size: 12px; font-weight: 600;
  color: var(--eng-text, #F2F0EB);
  letter-spacing: 0.02em;
}
.eng-prog-clear {
  width: 24px; height: 24px;
  background: transparent; border: none;
  border-radius: 6px;
  color: var(--eng-text-muted, #A09D96);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.eng-prog-clear svg { width: 13px; height: 13px; }
.eng-prog-clear:hover { background: var(--eng-surf-3, #2C2A27); color: var(--eng-text, #F2F0EB); }
.eng-prog-list { max-height: 60vh; overflow-y: auto; }
.eng-prog-monitor {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10.5px; font-weight: 600;
  color: var(--eng-primary, #C8956C);
  text-decoration: none;
  padding: 2px 7px;
  border: 1px solid rgba(200,149,108,0.30);
  border-radius: 999px;
  background: rgba(200,149,108,0.06);
  transition: background .12s ease;
  white-space: nowrap;
}
.eng-prog-monitor:hover { background: rgba(200,149,108,0.18); }
.eng-prog-monitor svg { width: 11px; height: 11px; }
.eng-prog-foot {
  padding: 8px 14px 10px;
  border-top: 1px solid var(--eng-border, rgba(242,240,235,0.06));
  background: var(--eng-surf-2, #232220);
  font-size: 10.5px; line-height: 1.4;
  color: var(--eng-text-subtle, #6F6C66);
}
.eng-prog-foot code { font-family: var(--pt-mono, monospace); color: var(--eng-text-muted, #A09D96); background: var(--eng-surf-3, #2C2A27); padding: 0 4px; border-radius: 3px; }
.eng-prog-foot a { color: var(--eng-primary, #C8956C); text-decoration: none; }
.eng-prog-foot a:hover { text-decoration: underline; }
:root[data-theme="light"] .eng-prog-foot { background: #FAFAF8; border-top-color: #F1EFEA; color: #9A9A9A; }
:root[data-theme="light"] .eng-prog-foot code { background: #F1EFEA; color: #6B6B6B; }

.eng-prog-row {
  display: flex; gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--eng-border, rgba(242,240,235,0.06));
  transition: background .12s ease;
}
.eng-prog-row:last-child { border-bottom: none; }
.eng-prog-meta { flex: 1; min-width: 0; }
.eng-prog-title {
  font-size: 12.5px; font-weight: 600;
  color: var(--eng-text, #F2F0EB);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  margin-bottom: 4px;
}
.eng-prog-status {
  display: flex; align-items: center; gap: 8px;
  font-size: 11.5px;
  color: var(--eng-text-muted, #A09D96);
  font-family: var(--pt-mono, monospace);
}
.eng-prog-status .dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex: 0 0 8px;
  background: var(--eng-primary, #C8956C);
}
.eng-prog-status .el {
  margin-left: auto;
  font-size: 10.5px;
  color: var(--eng-text-subtle, #6F6C66);
}
.eng-prog-row.is-busy .dot {
  background: var(--eng-primary, #C8956C);
  animation: eng-prog-pulse 1.2s ease-in-out infinite;
}
@keyframes eng-prog-pulse {
  0%, 100% { transform: scale(1); opacity: 1; box-shadow: 0 0 0 0 rgba(200,149,108,0.6); }
  50%      { transform: scale(1.25); opacity: 0.85; box-shadow: 0 0 0 6px rgba(200,149,108,0); }
}
.eng-prog-row.is-ok .dot  { background: #6FBE8E; box-shadow: 0 0 0 3px rgba(111,190,142,0.20); }
.eng-prog-row.is-err .dot { background: #E07561; box-shadow: 0 0 0 3px rgba(224,117,97,0.20); }
.eng-prog-row.is-ok  .st  { color: #6FBE8E; font-weight: 600; }
.eng-prog-row.is-err .st  { color: #E07561; font-weight: 600; }
.eng-prog-detail {
  margin-top: 5px;
  font-size: 11px;
  color: var(--eng-text-muted, #A09D96);
  font-family: var(--pt-mono, monospace);
  line-height: 1.4;
  word-break: break-word;
}
.eng-prog-actions {
  display: flex; flex-direction: column; gap: 4px;
  align-items: flex-end;
}
.eng-prog-actions .eng-prog-apply,
.eng-prog-actions .eng-prog-link {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  font: inherit; font-size: 11px; font-weight: 600;
  border-radius: 6px;
  cursor: pointer;
  text-decoration: none;
  transition: background .12s ease;
  white-space: nowrap;
}
.eng-prog-actions .eng-prog-link {
  background: var(--eng-surf-2, #232220);
  border: 1px solid var(--eng-border, rgba(242,240,235,0.14));
  color: var(--eng-text-muted, #A09D96);
}
.eng-prog-actions .eng-prog-link:hover { color: var(--eng-text, #F2F0EB); background: var(--eng-surf-3, #2C2A27); }
.eng-prog-actions .eng-prog-apply {
  background: var(--eng-primary, #C8956C);
  border: 1px solid var(--eng-primary, #C8956C);
  color: #14120E;
}
.eng-prog-actions .eng-prog-apply:hover { filter: brightness(1.08); }
.eng-prog-actions .eng-prog-link svg,
.eng-prog-actions .eng-prog-apply svg { width: 12px; height: 12px; }
.eng-prog-actions .eng-prog-x {
  width: 22px; height: 22px;
  background: transparent; border: none;
  color: var(--eng-text-subtle, #6F6C66);
  cursor: pointer;
  border-radius: 5px;
  display: inline-flex; align-items: center; justify-content: center;
}
.eng-prog-actions .eng-prog-x:hover { background: var(--eng-surf-3, #2C2A27); color: var(--eng-text, #F2F0EB); }
.eng-prog-actions .eng-prog-x svg { width: 11px; height: 11px; }

:root[data-theme="light"] .eng-prog-panel {
  background: #FFFFFF;
  border-color: #E5E5E0;
  box-shadow: 0 24px 48px rgba(0,0,0,0.18);
}
:root[data-theme="light"] .eng-prog-head { background: linear-gradient(180deg, rgba(139,69,19,0.08), rgba(139,69,19,0.00)); border-bottom-color: #E5E5E0; color: #1A1A1A; }
:root[data-theme="light"] .eng-prog-row { border-bottom-color: #F1EFEA; }
:root[data-theme="light"] .eng-prog-title { color: #1A1A1A; }
:root[data-theme="light"] .eng-prog-status { color: #6B6B6B; }
:root[data-theme="light"] .eng-prog-detail { color: #6B6B6B; }
:root[data-theme="light"] .eng-prog-clear:hover { background: #F1EFEA; color: #1A1A1A; }
:root[data-theme="light"] .eng-prog-actions .eng-prog-link { background: #FAFAF8; border-color: #E5E5E0; color: #6B6B6B; }
:root[data-theme="light"] .eng-prog-actions .eng-prog-link:hover { background: #F1EFEA; color: #1A1A1A; }
:root[data-theme="light"] .eng-prog-actions .eng-prog-x:hover { background: #F1EFEA; color: #1A1A1A; }

@media (max-width: 540px) {
  .eng-prog-panel { right: 8px; bottom: 8px; left: 8px; width: auto; }
  .eng-prog-actions { flex-direction: row; flex-wrap: wrap; }
}

/* Refreshed-badge bovenaan de kaart na een Vervang-in-kaart actie */
.eng-card.is-refreshed { box-shadow: 0 0 0 2px rgba(111,190,142,0.30), 0 12px 30px rgba(0,0,0,0.25); }
.eng-card-refreshed {
  display: inline-flex; align-items: center; gap: 5px;
  margin-left: 10px;
  padding: 3px 9px;
  background: rgba(111,190,142,0.10);
  border: 1px solid rgba(111,190,142,0.32);
  color: #6FBE8E;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0; text-transform: none;
  border-radius: 999px;
}
.eng-card-refreshed svg { width: 11px; height: 11px; }
:root[data-theme="light"] .eng-card-refreshed { background: rgba(45,122,79,0.10); color: #2D7A4F; border-color: rgba(45,122,79,0.40); }

/* Edit modal: form rows */
.eng-form {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}
@media (max-width: 720px) { .eng-form { grid-template-columns: 1fr; gap: 12px; } }
.eng-form .span-2 { grid-column: 1 / -1; }
.eng-form label {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 10.5px; font-weight: 700;
  color: var(--eng-text-muted, #6B6B6B);
  text-transform: uppercase; letter-spacing: 0.08em;
  min-width: 0;
}
.eng-form label > .lbl { display: block; }
.eng-form input,
.eng-form select,
.eng-form textarea {
  width: 100%;
  min-width: 0;
  padding: 9px 12px;
  border: 1px solid var(--eng-border-2, #2A2A28);
  border-radius: 6px;
  font: inherit; font-size: 13px; font-weight: 400; line-height: 1.4;
  background: var(--eng-surf-2, #14120E); color: var(--eng-text, #F2F0EB);
  text-transform: none; letter-spacing: normal;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
}
.eng-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23A09D96' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 32px;
}
:root[data-theme="light"] .eng-form input,
:root[data-theme="light"] .eng-form select,
:root[data-theme="light"] .eng-form textarea {
  background-color: #FAFAF8;
  border-color: #D9D8D2;
  color: #1A1A1A;
}
:root[data-theme="light"] .eng-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}
.eng-form input:focus,
.eng-form select:focus,
.eng-form textarea:focus {
  outline: none;
  border-color: var(--eng-primary, #C8956C);
  box-shadow: 0 0 0 2px rgba(200,149,108,0.18);
}
.eng-form textarea { font-family: var(--pt-mono, monospace); font-size: 12.5px; min-height: 90px; resize: vertical; }
.eng-form .row-toggle {
  flex-direction: row; align-items: center; gap: 10px; cursor: pointer;
  text-transform: none; letter-spacing: normal; font-size: 13px; color: var(--eng-text, #F2F0EB); font-weight: 500;
  padding: 8px 12px;
  background: var(--eng-surf-2, #14120E);
  border: 1px solid var(--eng-border-2, #2A2A28);
  border-radius: 6px;
}
:root[data-theme="light"] .eng-form .row-toggle {
  background: #FAFAF8;
  border-color: #D9D8D2;
  color: #1A1A1A;
}
.eng-form .row-toggle input { width: 16px; height: 16px; margin: 0; flex: 0 0 16px; }

/* Diff preview */
.eng-diff {
  margin-top: 10px;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  padding: 8px 10px;
  font-size: 12px;
  font-family: var(--pt-mono, monospace);
  color: var(--eng-text);
  max-height: 140px;
  overflow-y: auto;
}
.eng-diff .d-add { color: #22c55e; }
.eng-diff .d-rem { color: #ef4444; text-decoration: line-through; }
.eng-diff .d-key { color: var(--eng-text-muted); }

/* Prompt viewer */
.eng-prompt-view {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  padding: 12px 14px;
  font-family: var(--pt-mono, monospace);
  font-size: 12px;
  line-height: 1.55;
  white-space: pre-wrap;
  color: var(--eng-text);
}

/* Danger variant voor confirm-knop */
.eng-vbtn.is-danger {
  background: rgba(176,58,46,0.20);
  color: #E07561;
  border-color: rgba(176,58,46,0.45);
}
.eng-vbtn.is-danger:hover { background: rgba(176,58,46,0.32); }

.eng-btn-ghost.is-danger,
.eng-btn-primary.is-danger {
  background: rgba(176,58,46,0.18);
  color: #E07561;
  border-color: rgba(176,58,46,0.45);
}
.eng-btn-primary.is-danger { background: #B03A2E; color: #fff; border-color: #B03A2E; }
.eng-btn-primary.is-danger:hover { background: #9b3127; }

/* Clip stemming-chips */
.eng-stemming-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; font-size: 12px; font-weight: 500;
  background: var(--eng-surf-2); border: 1px solid var(--eng-border);
  border-radius: 999px; color: var(--eng-text-muted);
  cursor: pointer; transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
}
.eng-stemming-chip:hover {
  background: var(--eng-surf-3); color: var(--eng-text);
  border-color: var(--eng-border-strong);
}
.eng-stemming-chip.is-active {
  background: rgba(111,190,142,0.15); border-color: rgba(111,190,142,.5);
  color: #6FBE8E;
}
.eng-stemming-icon { font-size: 13px; }
.eng-stemming-bar { padding: 12px 14px; background: var(--eng-surf); border-radius: var(--eng-radius-sm); border: 1px solid var(--eng-border); }

/* Categorie-filter chips — gebruikt door life-filter, ambient-filter, stemming-filter */
.eng-cat-chip {
  display: inline-flex; align-items: center;
  padding: 3px 10px; font-size: 11px; font-weight: 500;
  background: transparent; border: 1px solid var(--eng-border);
  border-radius: 999px; color: var(--eng-text-muted);
  cursor: pointer; transition: background .12s, border-color .12s, color .12s;
  letter-spacing: .01em;
}
.eng-cat-chip:hover {
  background: var(--eng-surf-2); color: var(--eng-text);
  border-color: var(--eng-border-strong);
}
.eng-cat-chip.is-active {
  background: rgba(125,211,252,0.18); border-color: #38bdf8;
  color: #e0f2fe;
}
.eng-cat-filters { display: flex; flex-wrap: wrap; gap: 4px; }

/* Clip: gekoppelde run wijkt af van kaart-params */
.eng-params-mismatch {
  margin: 10px 0 0;
  padding: 10px 12px;
  border-radius: var(--eng-radius-sm);
  border: 1px solid rgba(224, 169, 58, 0.55);
  background: rgba(224, 169, 58, 0.12);
  font-size: 12px;
  line-height: 1.5;
  color: var(--eng-text);
}
.eng-params-mismatch strong {
  display: block;
  font-size: 12px;
  margin-bottom: 4px;
  color: #e0a93a;
}
.eng-params-mismatch span {
  display: block;
  color: var(--eng-text-muted);
  font-size: 11.5px;
  margin-bottom: 6px;
}
.eng-params-mismatch ul {
  margin: 0;
  padding-left: 18px;
}
.eng-params-mismatch code {
  font-family: var(--pt-mono, monospace);
  font-size: 11px;
}

/* Parameter picker — motion / lived-in (duidelijke selectie) */
.eng-pick {
  display: inline-flex; align-items: center; gap: 6px;
  margin: 0 6px 6px 0; padding: 6px 12px;
  background: var(--eng-surf-2); border: 2px solid var(--eng-border);
  border-radius: 999px; font-size: 11.5px; font-weight: 500;
  color: var(--eng-text-muted); cursor: pointer;
  transition: background .12s, border-color .12s, color .12s, box-shadow .12s;
}
.eng-pick input { margin: 0; width: 14px; height: 14px; accent-color: #38bdf8; flex-shrink: 0; }
.eng-pick:hover:not(.is-disabled) {
  border-color: var(--eng-border-strong); color: var(--eng-text);
}
.eng-pick.is-selected {
  background: rgba(125, 211, 252, 0.2);
  border-color: #38bdf8;
  color: #e0f2fe;
  box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.35);
}
.eng-pick.is-disabled { opacity: 0.4; cursor: not-allowed; }
.eng-pick.is-warn { border-color: rgba(176, 58, 46, 0.55); }
.eng-pick.is-mismatch { border-color: rgba(224, 169, 58, 0.55); }
.eng-pick-hint { margin-left: 4px; font-size: 10px; opacity: 0.55; font-weight: 400; }

/* Clip form — live selectie-samenvatting */
.eng-sel-summary {
  margin-bottom: 14px; padding: 12px 14px;
  background: var(--eng-surf); border: 1px solid var(--eng-border-strong);
  border-radius: var(--eng-radius-sm);
}
.eng-sel-summary-title {
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--eng-text-muted); margin-bottom: 8px;
}
.eng-sel-summary-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 6px 16px; margin: 0; }
.eng-sel-row { display: contents; }
.eng-sel-row dt { font-size: 10.5px; color: var(--eng-text-muted); margin: 0; }
.eng-sel-row dd { font-size: 12.5px; font-weight: 600; color: var(--eng-text); margin: 0 0 4px; }

/* Clip form — live tips (wat botst / kan niet / werkt) */
.eng-clip-tips { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }
.eng-clip-tip {
  font-size: 12px; line-height: 1.45;
  padding: 8px 11px 8px 30px; position: relative;
  border-radius: var(--eng-radius-sm);
  border: 1px solid var(--eng-border);
  background: var(--eng-surf-2); color: var(--eng-text);
}
.eng-clip-tip::before {
  position: absolute; left: 10px; top: 8px;
  font-size: 12px; font-weight: 700; line-height: 1.3;
}
.eng-clip-tip.is-info { border-color: rgba(56,189,248,0.40); background: rgba(56,189,248,0.08); }
.eng-clip-tip.is-info::before { content: 'i'; color: #38bdf8; }
.eng-clip-tip.is-warn { border-color: rgba(224,169,58,0.50); background: rgba(224,169,58,0.10); }
.eng-clip-tip.is-warn::before { content: '!'; color: #e0a93a; }
.eng-clip-tip.is-ok { border-color: rgba(111,190,142,0.45); background: rgba(111,190,142,0.10); }
.eng-clip-tip.is-ok::before { content: '✓'; color: #6FBE8E; }

/* Clip form — sectiekop in gewone taal */
.eng-clip-section {
  grid-column: 1 / -1;
  margin: 4px 0 -4px;
  font-size: 13px; font-weight: 700;
  color: var(--eng-text);
  text-transform: none; letter-spacing: normal;
  display: flex; align-items: baseline; gap: 8px;
}
.eng-clip-section .hint {
  font-size: 11.5px; font-weight: 400; color: var(--eng-text-muted);
}
.eng-clip-section.is-sub { margin-top: 10px; padding-top: 12px; border-top: 1px solid var(--eng-border); }

/* Form selects — duidelijke focus + geselecteerde waarde */
.eng-form select {
  border: 2px solid var(--eng-border);
  background: var(--eng-surf-2);
  color: var(--eng-text);
  font-weight: 500;
}
.eng-form select:focus {
  outline: none;
  border-color: #38bdf8;
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.25);
}
.eng-form .lbl { font-weight: 600; color: var(--eng-text); }

/* Sync indicator */
.eng-sync-indicator {
  font-size: 11px; font-weight: 500; letter-spacing: .01em;
  padding: 3px 9px; border-radius: 20px; transition: opacity .3s;
  opacity: 0; pointer-events: none;
}
.eng-sync-indicator.is-syncing {
  opacity: 1; background: rgba(111,190,255,0.12); color: #6fbeff;
  border: 1px solid rgba(111,190,255,0.25);
  animation: eng-pulse 1.2s ease-in-out infinite;
}
.eng-sync-indicator.is-synced {
  opacity: 1; background: rgba(111,190,142,0.12); color: #6fbe8e;
  border: 1px solid rgba(111,190,142,0.3);
}
.eng-sync-indicator.is-err {
  opacity: 1; background: rgba(176,58,46,0.12); color: #e07060;
  border: 1px solid rgba(176,58,46,0.3);
}
@keyframes eng-pulse {
  0%,100% { opacity: .7; } 50% { opacity: 1; }
}

/* Overlays modal rows */
.eng-overlay-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); margin-bottom: 8px; background: var(--eng-surf-alt, rgba(255,255,255,0.02));
}
.eng-overlay-row > div:first-child { flex: 1; min-width: 0; }
.eng-overlay-title { font-weight: 600; font-size: 13.5px; color: var(--eng-text); }
.eng-overlay-sub   { font-size: 12px; color: var(--eng-text-mute); margin-top: 2px; }

/* Showcase audit modal */
.eng-audit-summary {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px 16px;
  padding: 12px 14px; border-radius: var(--eng-radius-sm); margin-bottom: 12px;
  border: 1px solid var(--eng-border); font-size: 13px;
}
.eng-audit-summary.is-ok  { background: rgba(111,190,142,0.12); border-color: rgba(111,190,142,0.35); }
.eng-audit-summary.is-err { background: rgba(176,58,46,0.10); border-color: rgba(176,58,46,0.35); }
.eng-audit-health { font-weight: 700; text-transform: uppercase; font-size: 11px; letter-spacing: .06em; }
.eng-audit-h { font-size: 12px; font-weight: 600; margin: 14px 0 8px; color: var(--eng-text-muted); text-transform: uppercase; letter-spacing: .05em; }
.eng-audit-issue {
  padding: 8px 10px; border: 1px solid var(--eng-border); border-radius: var(--eng-radius-sm);
  margin-bottom: 6px; font-size: 12.5px; display: flex; flex-direction: column; gap: 2px;
}
.eng-audit-issue span.eng-audit-url { font-size: 11px; color: var(--eng-text-muted); word-break: break-all; }
.eng-audit-ok { font-size: 13px; color: var(--eng-text-muted); margin: 0; }

/* Image preview (for meshy image-mode) */
.eng-imgprev {
  margin-top: 6px;
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-3);
  width: 100%; max-height: 220px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.eng-imgprev img { max-width: 100%; max-height: 220px; object-fit: contain; }

/* Meshy image input: URL / Upload tabs + dropzone */
.eng-img-tabs {
  display: inline-flex; gap: 0;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: 8px;
  padding: 3px;
  margin-bottom: 8px;
}
.eng-img-tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px;
  background: transparent;
  border: none;
  border-radius: 6px;
  font: inherit; font-size: 12px; font-weight: 600;
  color: var(--eng-text-muted);
  cursor: pointer;
  transition: background .12s ease, color .12s ease;
}
.eng-img-tab:hover { color: var(--eng-text); }
.eng-img-tab.is-active {
  background: var(--eng-surf);
  color: var(--eng-text);
  box-shadow: 0 1px 3px rgba(0,0,0,0.10);
}
.eng-img-tab svg { width: 13px; height: 13px; }
.eng-img-pane { display: none; }
.eng-img-pane.is-active { display: block; }
.eng-img-pane input[type="text"] {
  width: 100%; box-sizing: border-box;
  padding: 8px 11px;
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: 7px;
  color: var(--eng-text); font: inherit; font-size: 13px;
  font-family: var(--pt-mono, monospace);
}

.eng-dropzone {
  position: relative;
  border: 2px dashed var(--eng-border-2);
  background: var(--eng-surf-2);
  border-radius: 8px;
  padding: 18px;
  cursor: pointer;
  transition: border-color .12s ease, background .12s ease;
}
.eng-dropzone:hover,
.eng-dropzone:focus-visible,
.eng-dropzone.is-drag {
  border-color: var(--eng-primary);
  background: var(--eng-primary-soft);
  outline: none;
}
.eng-dz-inner {
  display: flex; align-items: center; gap: 14px;
  pointer-events: none;
}
.eng-dz-inner svg { width: 28px; height: 28px; color: var(--eng-primary); flex: 0 0 28px; }
.eng-dz-inner strong { display: block; font-size: 13px; color: var(--eng-text); margin-bottom: 2px; }
.eng-dz-inner span { font-size: 11.5px; color: var(--eng-text-muted); }
.eng-dz-status {
  font-size: 11.5px;
  color: var(--eng-text-muted);
  font-family: var(--pt-mono, monospace);
  margin-top: 8px;
}
.eng-dz-status.is-err { color: #E07561; }
.eng-dz-status.is-ok  { color: #6FBE8E; }

/* Audit log */
.eng-audit-row {
  display: grid;
  grid-template-columns: 130px 60px 110px 1fr;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px solid var(--eng-border);
  font-size: 12px;
  color: var(--eng-text);
  align-items: center;
}
.eng-audit-row .ts   { color: var(--eng-text-muted); font-family: var(--pt-mono, monospace); font-size: 10.5px; }
.eng-audit-row .from { color: var(--eng-text-muted); font-size: 10.5px; text-align: right; }
.eng-audit-row .to   { font-weight: 600; }
.eng-audit-row .to.v-approved { color: var(--eng-success); }
.eng-audit-row .to.v-doubt    { color: var(--eng-warn); }
.eng-audit-row .to.v-rejected { color: var(--eng-danger); }
.eng-audit-row .to.v-pending  { color: var(--eng-text-muted); }
@media (max-width: 720px) {
  .eng-audit-row { grid-template-columns: 1fr; gap: 2px; }
  .eng-audit-row .from { text-align: left; }
}

/* ══ Mockup-pack 2026 — clip, review, tour, matrix (supervisor-2026)
   Scope .eng-ui = #view-engine .eng + .eng-modal.eng-ui (modals op body) ══ */
.eng-ui .eng-panel--card {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  padding: 20px 22px;
}
#eng-tour-segment-mount {
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: 4px 2px 8px;
}
.eng-ui .panel-h {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.eng-ui .panel-h .kick {
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--eng-text-subtle);
  font-weight: 700;
}
.eng-ui .panel-h h2 { font-size: 15px; margin: 0; font-weight: 650; }
.eng-ui .panel-h svg { color: var(--eng-primary); width: 18px; height: 18px; }
.eng-ui .eng-lead {
  color: var(--eng-text-muted);
  font-size: 13px;
  margin: 0 0 16px;
  max-width: 760px;
  line-height: 1.55;
}
.eng-ui .c2-vt-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.eng-ui .c2-vt {
  padding: 7px 13px;
  border: 1px solid var(--eng-border-2);
  border-radius: 999px;
  background: var(--eng-surf-2);
  color: var(--eng-text-muted);
  font-size: 12.5px;
  cursor: pointer;
  font: inherit;
}
.eng-ui .c2-vt.on {
  background: var(--eng-primary-soft);
  border-color: var(--eng-primary);
  color: var(--eng-primary);
  font-weight: 600;
}
.eng-ui .c2-modes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 18px;
}
.eng-ui .c2-mode-card {
  padding: 16px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius);
  background: var(--eng-surf-2);
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
}
.eng-ui .c2-mode-card.on {
  border-color: var(--eng-primary);
  background: var(--eng-primary-soft);
}
.eng-ui .c2-mode-card svg { width: 22px; height: 22px; color: var(--eng-primary); }
.eng-ui .c2-mode-card .t { font-weight: 650; font-size: 14px; margin-top: 8px; display: block; }
.eng-ui .c2-mode-card .d { font-size: 11.5px; color: var(--eng-text-muted); margin-top: 3px; display: block; line-height: 1.4; }
.eng-ui .c2-stack > * + * { margin-top: 16px; }
.eng-ui .c2-panel-inner.hide { display: none !important; }
.eng-ui .c2-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 8px;
}
.eng-ui .c2-tile {
  padding: 11px 12px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-2);
  font-size: 12.5px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  text-align: left;
  cursor: pointer;
  color: var(--eng-text);
  font: inherit;
  line-height: 1.25;
}
.eng-ui .c2-tile:hover { border-color: var(--eng-primary); }
.eng-ui .c2-tile.on {
  border-color: var(--eng-primary);
  background: var(--eng-primary-soft);
  color: var(--eng-primary);
  font-weight: 600;
}
.eng-ui .c2-badge {
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--eng-surf-3);
  color: var(--eng-text-muted);
  font-weight: 600;
  letter-spacing: .04em;
}
.eng-ui .c2-tile.on .c2-badge.enter { background: var(--eng-primary-soft); color: var(--eng-primary); }
.eng-ui .c2-tile.on .c2-badge.present { background: var(--eng-success-soft); color: var(--eng-success); }
.eng-ui .c2-group { margin-bottom: 18px; }
.eng-ui .c2-group-h {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--eng-text-subtle);
  font-weight: 700;
  margin: 0 0 9px;
}
.eng-ui .c2-group-h .ln { flex: 1; height: 1px; background: var(--eng-border); }
.eng-ui .c2-opt-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--eng-border);
}
.eng-ui .c2-swlabel {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 12.5px;
  cursor: pointer;
  user-select: none;
}
.eng-ui .c2-sw {
  width: 38px;
  height: 21px;
  border-radius: 999px;
  background: var(--eng-surf-3);
  position: relative;
  border: 1px solid var(--eng-border-2);
  flex: none;
}
.eng-ui .c2-sw::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: var(--eng-text-muted);
  transition: .15s;
}
.eng-ui .c2-swlabel.on .c2-sw {
  background: var(--eng-primary);
  border-color: var(--eng-primary);
}
.eng-ui .c2-swlabel.on .c2-sw::after { left: 19px; background: #fff; }
.eng-ui .c2-dur-seg {
  display: inline-flex;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  overflow: hidden;
}
.eng-ui .c2-dur-seg button {
  padding: 7px 13px;
  font-size: 12px;
  border: 0;
  background: var(--eng-surf-2);
  color: var(--eng-text-muted);
  cursor: pointer;
  font: inherit;
}
.eng-ui .c2-dur-seg button.on {
  background: var(--eng-primary-soft);
  color: var(--eng-primary);
  font-weight: 600;
}
.eng-ui .c2-legend {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--eng-text-muted);
  margin-top: 10px;
}
.eng-ui .c2-preview {
  background: var(--eng-bg);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  padding: 16px;
  font-family: var(--pt-mono);
  font-size: 12px;
  color: var(--eng-text-muted);
  line-height: 1.65;
  white-space: pre-wrap;
}
.eng-ui .c2-preview b { color: var(--eng-primary); font-weight: 600; }
.eng-ui .c2-preview .lock { color: var(--eng-text-subtle); }
.eng-ui .c2-note { font-size: 11.5px; color: var(--eng-text-subtle); margin-top: 10px; }
.eng-ui .c2-anchor-inp {
  width: 100%;
  box-sizing: border-box;
  padding: 8px 10px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-2);
  color: var(--eng-text);
  font-family: var(--pt-mono);
  font-size: 12px;
}

/* Review focus card */
.eng-ui .review {
  background: var(--eng-surf);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  overflow: hidden;
}
.eng-ui .review.is-gold { box-shadow: inset 0 0 0 1px var(--eng-warn); }
.eng-ui .review-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  padding: 12px 16px;
  border-bottom: 1px solid var(--eng-border);
}
.eng-ui .review-bar .rtitle {
  font-weight: 650;
  font-size: 14px;
  margin-right: auto;
  min-width: 0;
}
.eng-ui .review .card-act,
.eng-ui .review-bar .eng-card-act {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--eng-text-muted);
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  padding: 6px 10px;
  cursor: pointer;
  font: inherit;
}
.eng-ui .review .card-act:hover,
.eng-ui .review-bar .eng-card-act:hover {
  color: var(--eng-primary);
  border-color: var(--eng-primary);
}
.eng-ui .review-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.eng-ui .review-compare .source-bar,
.eng-ui .review-compare .eng-sourcebar {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-top: 1px solid var(--eng-border);
  font-size: 12px;
  color: var(--eng-text-muted);
  flex-wrap: wrap;
  margin: 0;
  border-radius: 0;
  background: var(--eng-surf-2);
}
.eng-ui .review-compare .source-bar .src-actions,
.eng-ui .review-compare .eng-sourcebar .eng-src-acts { margin-left: auto; }
.eng-ui .review-pane {
  position: relative;
  background: var(--eng-surf-3);
  aspect-ratio: 4/3;
  border-right: 1px solid var(--eng-border);
  overflow: hidden;
}
.eng-ui .review-pane:last-child { border-right: none; }
.eng-ui .review-pane img,
.eng-ui .review-pane video,
.eng-ui .review-pane model-viewer { width: 100%; height: 100%; object-fit: cover; display: block; }
.eng-ui .review-pane .eng-pane-media {
  position: relative;
  width: 100%;
  height: 100%;
}
.eng-ui .review-pane .eng-pane-media .eng-pane-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.eng-ui .review-pane .eng-pane-snd {
  position: absolute;
  right: 10px;
  bottom: 10px;
  z-index: 5;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(8,10,14,.72);
  color: #fff;
  cursor: pointer;
  opacity: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  padding: 0;
  line-height: 0;
  box-shadow: 0 2px 10px rgba(0,0,0,.35);
}
.eng-ui .review-pane .eng-pane-snd:hover {
  background: rgba(8,10,14,.88);
  border-color: rgba(255,255,255,.5);
}
.eng-ui .review-pane .eng-pane-snd:focus-visible {
  outline: 2px solid var(--eng-accent, #6FBE8E);
  outline-offset: 2px;
}
.eng-ui .review-pane .eng-pane-snd svg { width: 16px; height: 16px; }
.eng-ui .review-pane .pane-tag {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  background: rgba(20, 18, 14, .72);
  color: #F2F0EB;
  backdrop-filter: blur(6px);
  border-radius: 999px;
  padding: 5px 11px;
  font-size: 11px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  line-height: 1.2;
}
:root[data-theme="light"] .eng-ui .review-pane .pane-tag {
  background: rgba(20, 18, 14, .78);
}
.eng-ui .review-pane .pane-tag svg.ic {
  width: 13px;
  height: 13px;
  flex: none;
  color: inherit;
}
.eng-ui .review-pane .pane-tag.r { left: auto; right: 10px; }
.eng-ui .review-pane .eng-src-ok,
.eng-ui .review-pane .eng-src-warn {
  position: absolute;
  bottom: 10px;
  left: 10px;
  z-index: 2;
  font-size: 10px;
  font-weight: 600;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(20, 18, 14, .72);
  color: #F2F0EB;
  backdrop-filter: blur(6px);
}
.eng-ui .review-pane .eng-src-warn { color: #f5c6a0; }
.eng-ui .source-bar .src-kind svg.ic { color: var(--eng-primary); }
.eng-ui .eng-toggle svg.ic { width: 14px; height: 14px; }
.eng-ui .eng-actions .eng-sync-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  color: var(--eng-text-muted);
  opacity: 1;
  pointer-events: none;
  padding: 0;
  border: none;
  background: none;
  animation: none;
}
.eng-ui .eng-actions .eng-sync-indicator::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--eng-success);
  flex-shrink: 0;
}
.eng-ui .eng-actions .eng-sync-indicator.is-syncing::before {
  background: var(--eng-warn);
  animation: eng-pulse 1.2s ease-in-out infinite;
}
.eng-ui .eng-actions .eng-sync-indicator.is-err::before {
  background: var(--eng-danger);
}
.eng-ui .review-side {
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--eng-border);
  gap: 0;
}
.eng-ui .review-eyebrow {
  font-family: var(--pt-mono);
  font-size: 11px;
  color: var(--eng-text-muted);
  letter-spacing: .03em;
  margin-bottom: 8px;
}
.eng-ui .review-side .kv {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 14px;
  font-size: 12.5px;
  margin-bottom: 14px;
}
.eng-ui .review-side .kv dt { color: var(--eng-text-subtle); margin: 0; }
.eng-ui .review-side .kv dd { margin: 0; color: var(--eng-text); font-family: var(--pt-mono); }
.eng-ui .review-side .chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.eng-ui .review-side .chip {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11.5px;
  color: var(--eng-text-muted);
}
/* verdicts → see mockup vbtn block below */
.eng-ui .eng-matrix .cell.g,
.eng-ui .eng-mc.q-high { background: var(--eng-success-soft); color: var(--eng-success); }
.eng-ui .eng-matrix .cell.o,
.eng-ui .eng-mc.q-mid { background: var(--eng-warn-soft); color: var(--eng-warn); }
.eng-ui .eng-matrix .cell.r,
.eng-ui .eng-mc.q-low { background: var(--eng-danger-soft); color: var(--eng-danger); }
.eng-ui .eng-matrix td.cell,
.eng-ui .eng-matrix td .cell.eng-mc {
  font-family: var(--pt-mono);
  border-radius: 4px;
  cursor: pointer;
  padding: 4px 0;
  display: block;
}
.eng-ui .eng-matrix td .cell.eng-mc .sub {
  display: block;
  font-size: 9.5px;
  opacity: .75;
  margin-top: 2px;
}
.eng-ui .eng-matrix.align-left th,
.eng-ui .eng-matrix.align-left td { text-align: left; }
.eng-ui .eng-matrix.align-left th:nth-child(n+3),
.eng-ui .eng-matrix.align-left td:nth-child(n+3) { text-align: center; }

/* Analytical tabs 03–08 (mockup-pack) */
.eng-ui .eng-tab-lead,
.eng-ui .eng-lead.lead-tab {
  color: var(--eng-text-muted);
  font-size: 13px;
  margin: 0 0 14px;
  max-width: 760px;
  line-height: 1.55;
}
.eng-ui .eng-tab-note,
.eng-ui .note.tab-note {
  font-size: 11.5px;
  color: var(--eng-text-subtle);
  margin-top: 10px;
}
.eng-ui .drow {
  display: grid;
  align-items: center;
  gap: 14px;
  padding: 13px 14px;
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-2);
  margin-bottom: 8px;
  cursor: default;
}
.eng-ui .drow.is-click { cursor: pointer; }
.eng-ui .drow.is-click:hover { border-color: var(--eng-primary); }
.eng-ui .drow .ttl { font-weight: 600; font-size: 13px; }
.eng-ui .drow .meta { font-size: 11.5px; color: var(--eng-text-muted); }
.eng-ui .drow .num { font-family: var(--pt-mono); font-size: 13px; color: var(--eng-text); text-align: right; }
.eng-ui .drow .bar {
  height: 7px;
  border-radius: 999px;
  background: var(--eng-surf-3);
  overflow: hidden;
}
.eng-ui .drow .bar > i {
  display: block;
  height: 100%;
  background: var(--eng-primary);
  border-radius: 999px;
}
.eng-ui .tag {
  font-size: 10.5px;
  padding: 3px 8px;
  border-radius: 999px;
  font-weight: 600;
  display: inline-block;
}
.eng-ui .tag.ok { background: var(--eng-success-soft); color: var(--eng-success); }
.eng-ui .tag.warn { background: var(--eng-warn-soft); color: var(--eng-warn); }
.eng-ui .tag.bad { background: var(--eng-danger-soft); color: var(--eng-danger); }
.eng-ui .tag.busy { background: var(--eng-primary-soft); color: var(--eng-primary); }
.eng-ui .audit-log { padding: 6px 0; }
.eng-ui .audit-row {
  display: grid;
  grid-template-columns: 150px 130px 1fr;
  gap: 12px;
  font-size: 12px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--eng-border);
}
.eng-ui .audit-row:last-child { border-bottom: none; }
.eng-ui .audit-row .ts { font-family: var(--pt-mono); color: var(--eng-text-muted); }
.eng-ui .audit-row .act { color: var(--eng-text); font-weight: 600; }
.eng-ui .audit-row .det {
  font-family: var(--pt-mono);
  font-size: 10.5px;
  color: var(--eng-text-subtle);
  word-break: break-word;
}
.eng-ui .eng-costs-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  margin-bottom: 18px;
  font-size: 12.5px;
  color: var(--eng-text-muted);
}
.eng-ui .eng-costs-stats b {
  font-family: var(--pt-mono);
  color: var(--eng-text);
  font-weight: 600;
}
.eng-ui .audit-log-panel {
  padding: 6px 0 !important;
}
.eng-ui .eng-panel--card > .eng-matrix {
  margin: 0;
}
.eng-ui .eng-regie-inline { max-width: none; }
.eng-ui .eng-regie-inline-sub {
  font-size: 12px;
  color: var(--eng-text-muted);
  margin: 0 0 14px;
  font-family: var(--pt-mono);
}
.eng-ui .eng-regie-inline-foot {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 12px;
  margin-top: 8px;
  border-top: 1px solid var(--eng-border);
}
.eng-ui .tour-regie-panel .eng-regie { max-width: none; margin: 0; }
.eng-ui .tour-hint--regie { margin-bottom: 12px; }

/* Tour segment */
.eng-ui .tour-hint-bar {
  font-size: 11.5px;
  color: var(--eng-text-subtle);
  margin: 10px 0 0;
  font-family: var(--pt-mono);
}
.eng-ui .cast-strip {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
}
.eng-ui .cast-card {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  overflow: hidden;
}
.eng-ui .cast-card .cthumb {
  aspect-ratio: 3/4;
  background: var(--eng-surf-3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--eng-text-subtle);
  position: relative;
}
.eng-ui .cast-card .cthumb img { width: 100%; height: 100%; object-fit: cover; }
.eng-ui .cast-card figcaption { padding: 11px 12px; }
.eng-ui .cast-card strong { font-size: 13px; display: block; }
.eng-ui .cast-card .cblurb { font-size: 11.5px; color: var(--eng-text-muted); margin: 3px 0 9px; line-height: 1.4; }
.eng-ui .tour-list { display: flex; flex-direction: column; gap: 8px; }
.eng-ui .tour-row .tthumb {
  width: 56px;
  height: 56px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--eng-surf-3);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.eng-ui .tour-row .tthumb img,
.eng-ui .tour-row .tthumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.eng-ui .eng-tour-beat-thumb {
  width: 44px;
  height: 44px;
  border-radius: 6px;
  overflow: hidden;
  flex: 0 0 44px;
  background: var(--eng-surf-3);
}
.eng-ui .eng-tour-beat-thumb img,
.eng-ui .eng-tour-beat-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.eng-ui .tour-row {
  display: grid;
  grid-template-columns: 56px 1fr auto auto auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-2);
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  width: 100%;
}
.eng-ui .tour-row.on { border-color: var(--eng-primary); }
.eng-ui .tour-row .tt { font-size: 13.5px; font-weight: 600; }
.eng-ui .tour-row .tm { font-size: 11.5px; color: var(--eng-text-muted); }
.eng-ui .eng-tour-del {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf);
  color: var(--eng-text-muted);
  cursor: pointer;
  font: inherit;
  flex-shrink: 0;
}
.eng-ui .eng-tour-del:hover {
  border-color: var(--eng-danger);
  color: var(--eng-danger);
  background: var(--eng-danger-soft);
}
.eng-ui .eng-tour-del svg { width: 14px; height: 14px; }
.eng-regie-beat-foot {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--eng-border);
}
.eng-regie-dir-row { margin-bottom: 6px; }

/* ── Lucide sprite sizing (mockup-pack) ─────────────────────────────── */
.eng-ui svg.ic,
.eng-modal.eng-ui svg.ic {
  width: 16px;
  height: 16px;
  flex: none;
  display: inline-block;
  vertical-align: middle;
}
.eng-ui svg.ic-lg,
.eng-modal.eng-ui svg.ic-lg {
  width: 18px;
  height: 18px;
}
.eng-ui .panel-h svg.ic,
.eng-modal.eng-ui .panel-h svg.ic {
  width: 18px;
  height: 18px;
  color: var(--eng-primary);
}
.eng-ui .card-act svg,
.eng-ui .cast-replace svg {
  width: 14px;
  height: 14px;
}
.eng-ui .chip svg.ic {
  width: 13px;
  height: 13px;
  color: var(--eng-text-muted);
}
.eng-ui .vbtn svg.ic {
  width: 18px;
  height: 18px;
}
.eng-ui .eng-btn svg.ic {
  width: 16px;
  height: 16px;
}

/* Stats (mockup dots) */
.eng-ui .eng-stats {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--eng-text-muted);
  margin-bottom: 20px;
}
.eng-ui .eng-stats b {
  color: var(--eng-text);
  font-weight: 600;
  font-family: var(--pt-mono);
}
.eng-ui .eng-stats .dot-ok::before,
.eng-ui .eng-stats .dot-warn::before,
.eng-ui .eng-stats .dot-bad::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}
.eng-ui .eng-stats .dot-ok::before { background: var(--eng-success); }
.eng-ui .eng-stats .dot-warn::before { background: var(--eng-warn); }
.eng-ui .eng-stats .dot-bad::before { background: var(--eng-danger); }

/* Review card-act + verdicts (mockup 01) */
.eng-ui .review-bar .card-act {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--eng-text-muted);
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  padding: 6px 10px;
  cursor: pointer;
  font: inherit;
}
.eng-ui .review-bar .card-act:hover {
  color: var(--eng-primary);
  border-color: var(--eng-primary);
}
.eng-ui .review-bar .card-act.on {
  background: var(--eng-primary-soft);
  border-color: var(--eng-primary);
  color: var(--eng-primary);
}
.eng-ui .review-bar .card-act.is-ghost {
  background: transparent;
  border-style: dashed;
  opacity: 0.82;
}
.eng-ui .review-bar .card-act.is-ghost.is-disabled,
.eng-ui .review-bar .card-act.is-ghost:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}
.eng-ui .review-side .chips .chip {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11.5px;
  color: var(--eng-text-muted);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.eng-ui .eng-review-foot {
  padding: 12px 18px 16px;
  border-top: 1px solid var(--eng-border);
  background: var(--eng-surf);
}
.eng-ui .eng-review-foot .eng-notes-wrap { margin-top: 8px; }
.eng-ui .review-side {
  padding: 12px 16px 16px;
}
.eng-ui .review-side .verdicts { margin-top: 4px; }
.eng-ui .review-side .eng-notes-wrap { margin-top: 8px; }
.eng-ui .verdicts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-top: 0;
}
.eng-ui .verdicts .vbtn {
  border-radius: var(--eng-radius-sm);
  padding: 7px 6px 6px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--eng-border-2);
  background: var(--eng-surf-2);
  color: var(--eng-text-muted);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  cursor: pointer;
  font: inherit;
}
.eng-ui .verdicts .vbtn svg.ic {
  width: 14px;
  height: 14px;
  opacity: .85;
}
.eng-ui .verdicts .vbtn .key {
  font-family: var(--pt-mono);
  font-size: 8px;
  color: var(--eng-text-subtle);
  opacity: .75;
}
.eng-ui .verdicts .vbtn.ok.on {
  background: var(--eng-success-soft);
  border-color: var(--eng-success);
  color: var(--eng-success);
}
.eng-ui .verdicts .vbtn.doubt.on {
  background: var(--eng-warn-soft);
  border-color: var(--eng-warn);
  color: var(--eng-warn);
}
.eng-ui .verdicts .vbtn.bad.on {
  background: var(--eng-danger-soft);
  border-color: var(--eng-danger);
  color: var(--eng-danger);
}

/* Tour Director + cast (mockup) */
.eng-ui .tour-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.eng-ui .tour-hint,
.eng-ui .note {
  font-size: 11.5px;
  color: var(--eng-text-subtle);
  margin: 10px 0 0;
  font-family: var(--pt-mono);
  line-height: 1.45;
}
.eng-ui .eng-product-ladder {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0 4px;
}
.eng-ui .eng-product-ladder-col {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  padding: 10px 12px;
}
.eng-ui .eng-product-ladder-col.is-lifestyle {
  border-color: color-mix(in srgb, var(--eng-primary) 35%, var(--eng-border));
  background: color-mix(in srgb, var(--eng-primary) 6%, var(--eng-surf-2));
}
.eng-ui .eng-product-ladder-col.is-tour {
  border-color: color-mix(in srgb, var(--eng-accent) 40%, var(--eng-border));
}
.eng-ui .eng-product-ladder-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.eng-ui .eng-product-ladder-k {
  font-size: 12px;
  font-weight: 650;
  color: var(--eng-text);
}
.eng-ui .eng-product-ladder-arr {
  font-size: 11px;
  color: var(--eng-text-muted);
}
.eng-ui .eng-product-ladder-sub {
  display: block;
  margin-top: 4px;
  font-size: 10.5px;
  color: var(--eng-text-muted);
  line-height: 1.35;
}
.eng-ui .eng-product-badge {
  display: inline-flex;
  align-items: center;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 999px;
  margin-right: 8px;
  vertical-align: middle;
  border: 1px solid var(--eng-border);
  color: var(--eng-text-muted);
  background: var(--eng-surf-3);
}
.eng-ui .eng-product-badge.is-lifestyle {
  color: var(--eng-primary);
  border-color: color-mix(in srgb, var(--eng-primary) 40%, var(--eng-border));
  background: color-mix(in srgb, var(--eng-primary) 10%, var(--eng-surf-2));
}
.eng-ui .eng-product-badge.is-clip,
.eng-ui .eng-product-badge.is-mood {
  color: var(--eng-text-subtle);
}
.eng-ui .eng-occ-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}
.eng-ui .eng-occ-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: var(--eng-radius);
  border: 1px solid var(--eng-border);
  background: var(--eng-surf-2);
  cursor: pointer;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--eng-text);
}
.eng-ui .eng-occ-pill.on {
  border-color: var(--eng-primary);
  background: color-mix(in srgb, var(--eng-primary) 10%, var(--eng-surf-2));
}
.eng-ui .eng-occ-pill em {
  font-style: normal;
  font-size: 10px;
  font-weight: 600;
  color: var(--eng-text-muted);
  margin-left: 4px;
}
.eng-ui .c2-note--lifestyle-hint {
  margin-top: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--eng-primary) 8%, var(--eng-surf-2));
  border: 1px solid color-mix(in srgb, var(--eng-primary) 22%, var(--eng-border));
}
@media (max-width: 720px) {
  .eng-ui .eng-product-ladder { grid-template-columns: 1fr; }
}
.eng-ui .cast-strip {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
}
.eng-ui .cast-card {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius);
  overflow: hidden;
  margin: 0;
}
.eng-ui .cast-card .cthumb {
  aspect-ratio: 3/4;
  background: var(--eng-surf-3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--eng-text-subtle);
  position: relative;
  overflow: hidden;
}
.eng-ui .cast-card .cthumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.eng-ui .cast-card .cthumb svg.ic-lg {
  width: 38px;
  height: 38px;
  opacity: .5;
}
.eng-ui .cast-card .cthumb .pin {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  background: rgba(20, 18, 14, .72);
  color: #F2F0EB;
  border-radius: 999px;
  font-size: 10px;
  padding: 3px 8px;
  font-weight: 600;
}
.eng-ui .cast-card figcaption {
  padding: 11px 12px;
}
.eng-ui .cast-card strong {
  font-size: 13px;
  display: block;
}
.eng-ui .cast-card .cblurb {
  font-size: 11.5px;
  color: var(--eng-text-muted);
  display: block;
  margin: 3px 0 9px;
  line-height: 1.4;
}
.eng-ui .cast-card .cast-replace {
  width: 100%;
  justify-content: center;
  margin-top: 2px;
}
.eng-ui .eng-tour-review .review-bar {
  flex-wrap: wrap;
  gap: 8px;
}
.eng-ui .eng-tour-review .eng-review-foot { margin-top: 0; }
.eng-ui .eng-tour-layout { padding: 0 16px; }
.eng-ui .eng-tour-review .review-bar { padding: 12px 18px; }
.eng-ui .eng-notes {
  padding: 6px 10px;
  font-size: 11.5px;
}
.eng-ui .eng-chips { gap: 4px; }
.eng-ui .eng-chip {
  font-size: 10.5px;
  padding: 2px 7px;
}
.eng-modal.eng-ui .eng-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 12px;
  margin-bottom: 4px;
}
.eng-modal.eng-ui .eng-form-grid .eng-fld-wide { grid-column: 1 / -1; }
.eng-modal.eng-ui .eng-form-hint {
  font-size: 12px;
  color: var(--eng-text-muted);
  margin: 0;
  line-height: 1.45;
}
.eng-modal.eng-ui .eng-fld select,
.eng-modal.eng-ui .eng-fld input,
.eng-modal.eng-ui .eng-fld textarea {
  width: 100%;
  background: var(--eng-surf-2);
  color: var(--eng-text);
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  padding: 7px 10px;
  font-size: 13px;
  font-family: inherit;
}
.eng-modal.eng-ui .eng-btn-primary:disabled {
  opacity: .45;
  cursor: not-allowed;
}
.eng-modal.eng-ui .eng-btn-primary.is-danger {
  background: var(--eng-danger);
  color: #fff;
}
.eng-modal.eng-ui .modal-note {
  font-size: 12px;
  color: var(--eng-text-muted);
  margin: 0 0 14px;
  line-height: 1.55;
}
.eng-modal.eng-ui .modal-cost {
  font-family: var(--pt-mono);
  font-size: 12.5px;
  color: var(--eng-primary);
  margin: 14px 0 0;
}
.eng-modal.eng-ui .tour-scenes,
.eng-modal.eng-ui .eng-tour-scenes {
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  padding: 12px;
  margin-top: 14px;
}
.eng-modal.eng-ui .tour-scenes legend,
.eng-modal.eng-ui .eng-tour-scenes legend {
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--eng-text-subtle);
  font-weight: 700;
  padding: 0 6px;
}
.eng-modal.eng-ui .tour-scene,
.eng-modal.eng-ui .eng-tour-scene {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 6px;
  font-size: 13px;
  border-bottom: 1px solid var(--eng-border);
}
.eng-modal.eng-ui .tour-scene:last-child,
.eng-modal.eng-ui .eng-tour-scene:last-child { border-bottom: none; }
.eng-modal.eng-ui .tour-scene .anchor,
.eng-modal.eng-ui .eng-tour-anchor {
  margin-left: auto;
  font-size: 11px;
  color: var(--eng-success);
  font-family: var(--pt-mono);
}
.eng-modal.eng-ui .tour-scene.is-miss,
.eng-modal.eng-ui .eng-tour-scene.is-miss { opacity: .5; }
.eng-modal.eng-ui .checkrow {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 14px;
  font-size: 12.5px;
}
.eng-modal.eng-ui .checkrow input { margin-top: 2px; flex: 0 0 16px; }
.eng-modal.eng-ui .compare-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.eng-modal.eng-ui .compare-col {
  border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
  padding: 14px;
  background: var(--eng-surf-2);
}
.eng-modal.eng-ui .compare-col .cmedia {
  aspect-ratio: 16/10;
  background: var(--eng-surf-3);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--eng-text-subtle);
  margin-top: 10px;
}
.eng-modal.eng-ui .music-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.eng-modal.eng-ui .music-upload-panel {
  grid-column: 1 / -1;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--eng-border);
}
.eng-modal.eng-ui .compare-col .cmedia img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 6px;
}
.eng-modal.eng-ui .eng-tour-freetest {
  border: none;
  background: transparent;
  padding: 0;
  margin-top: 0;
}
.eng-modal.eng-ui .eng-regie-cost {
  font-family: var(--pt-mono);
  font-size: 11.5px;
  color: var(--eng-primary);
  margin-right: 8px;
}
.eng-modal.eng-ui .compare-col .cmedia img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.eng-modal.eng-ui .tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 12px 10px;
  border: 1px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-2);
  color: var(--eng-text-muted);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font: inherit;
  width: 100%;
}
.eng-modal.eng-ui .tile svg.ic { width: 18px; height: 18px; }
.eng-modal.eng-ui .tile.on {
  border-color: var(--eng-primary);
  background: var(--eng-primary-soft);
  color: var(--eng-primary);
}
.eng-modal.eng-ui .cast-strip.eng-cast-modal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
}
.eng-modal.eng-ui .eng-modal-close svg.ic {
  width: 16px;
  height: 16px;
}
.eng-modal.eng-ui .anchor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.eng-modal.eng-ui .anchor-thumb {
  border: 2px solid var(--eng-border-2);
  border-radius: var(--eng-radius-sm);
  overflow: hidden;
  cursor: pointer;
  background: var(--eng-surf-2);
}
.eng-modal.eng-ui .anchor-thumb.on {
  border-color: var(--eng-primary);
}
.eng-modal.eng-ui .anchor-thumb .at-media {
  aspect-ratio: 4/3;
  background: repeating-linear-gradient(45deg, var(--eng-surf-2), var(--eng-surf-2) 10px, var(--eng-surf-3) 10px, var(--eng-surf-3) 20px);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--eng-text-subtle);
  position: relative;
}
.eng-modal.eng-ui .anchor-thumb .at-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.eng-modal.eng-ui .anchor-thumb .at-media svg.ic {
  width: 24px;
  height: 24px;
  opacity: .55;
}
.eng-modal.eng-ui .anchor-thumb .at-media .cur {
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 2;
  background: var(--eng-primary);
  color: #14120E;
  border-radius: 999px;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 6px;
}
.eng-modal.eng-ui .anchor-thumb .at-cap {
  padding: 6px 8px;
  font-size: 10.5px;
  font-family: var(--pt-mono);
  color: var(--eng-text-muted);
}
.eng-ui .eng-btn {
  border-radius: var(--eng-radius-sm);
  padding: 8px 13px;
  font-size: 12.5px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid transparent;
  cursor: pointer;
  font: inherit;
}
.eng-ui .eng-btn-primary {
  background: var(--eng-primary);
  color: #14120E;
}
:root[data-theme="light"] .eng-ui .eng-btn-primary { color: #fff; }
.eng-ui .eng-btn-primary:hover { filter: brightness(1.06); }
.eng-ui .eng-btn-ghost {
  background: var(--eng-surf-2);
  border-color: var(--eng-border-2);
  color: var(--eng-text);
}
.eng-ui .eng-btn-ghost:hover {
  border-color: var(--eng-primary);
  color: var(--eng-primary);
}

@media (max-width: 900px) {
  .eng-ui .review-compare { grid-template-columns: 1fr; }
  .eng-ui .review-pane { border-right: none; border-bottom: 1px solid var(--eng-border); }
  .eng-ui .c2-modes { grid-template-columns: 1fr; }
}

/* Supervisor mobile — volledige feature-pariteit, geen verborgen tabs */
@media (max-width: 720px) {
  .eng-ui .eng-bar { flex-direction: column; align-items: stretch; }
  .eng-ui .eng-filters { flex-wrap: wrap; width: 100%; }
  .eng-ui .eng-actions { width: 100%; justify-content: flex-start; }
  .eng-ui .eng-fld { flex: 1 1 140px; min-width: 0; }
  .eng-ui .eng-fld select { width: 100%; min-width: 0; }
  .eng-ui .drow { grid-template-columns: 1fr !important; gap: 8px !important; }
  .eng-ui .drow .num { text-align: left; }
  .eng-ui .audit-row { grid-template-columns: 1fr; gap: 4px; }
  .eng-ui .eng-costs-stats { flex-direction: column; gap: 8px; }
  .eng-ui .eng-matrix { font-size: 11px; display: block; overflow-x: auto; }
  .eng-ui .eng-matrix.align-left { display: table; }
  .eng-ui .review-bar { gap: 4px; }
  .eng-ui .review-bar .rtitle { width: 100%; margin-bottom: 4px; }
  .eng-ui .review-side { padding: 14px 16px; }
  .eng-ui .verdicts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .eng-ui .verdicts .vbtn { min-height: 44px; }
  .eng-ui .tour-actions--regie { gap: 6px; }
  .eng-ui .tour-actions--regie .eng-btn { flex: 1 1 calc(50% - 6px); min-height: 40px; justify-content: center; }
  .eng-ui .eng-regie-inline-foot {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    padding-top: 14px;
    margin-top: 14px;
    border-top: 1px solid var(--eng-border);
  }
  .eng-ui .eng-regie-inline-foot .eng-btn-primary { flex: 1 1 100%; min-height: 44px; }
  .eng-ui .cast-strip { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
  .eng-ui .eng-nav { flex-wrap: wrap; justify-content: center; }
  .eng-ui .eng-nav-btn { min-width: 44px; min-height: 44px; }
}
@media (max-width: 480px) {
  .eng-tabs { margin: 0 -4px 12px; padding-bottom: 2px; }
  .eng-tab { padding: 10px 12px; font-size: 12px; }
  .eng-ui .seg-modes, .eng-ui .eng-submodes { width: 100%; justify-content: stretch; }
  .eng-ui .seg-mode, .eng-ui .eng-submode { flex: 1; justify-content: center; min-height: 40px; }
}

/* ── 3D Rondleiding tab ─────────────────────────────────────────────────── */
#view-engine .tour3d-list,
.eng-ui .tour3d-list {
  display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px;
}
#view-engine .tour3d-row,
.eng-ui .tour3d-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; background: var(--eng-surf); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); transition: border-color .15s;
}
#view-engine .tour3d-row:hover,
.eng-ui .tour3d-row:hover { border-color: var(--eng-border-2); }
#view-engine .t3thumb,
.eng-ui .t3thumb {
  width: 40px; height: 40px; flex: none; border-radius: 6px;
  background: var(--eng-surf-2); border: 1px solid var(--eng-border);
  display: flex; align-items: center; justify-content: center; color: var(--eng-text-muted);
}
#view-engine .t3thumb svg,
.eng-ui .t3thumb svg { width: 18px; height: 18px; }
#view-engine .t3meta,
.eng-ui .t3meta { flex: 1; min-width: 0; }
#view-engine .t3title,
.eng-ui .t3title { font-size: 13px; font-weight: 600; color: var(--eng-text); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#view-engine .t3sub,
.eng-ui .t3sub { font-size: 11.5px; color: var(--eng-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* extra tiny button size */
#view-engine .eng-btn-xs,
.eng-ui .eng-btn-xs { padding: 4px 8px; font-size: 11.5px; }
#view-engine .eng-btn-xs svg,
.eng-ui .eng-btn-xs svg { width: 13px; height: 13px; }

/* ── 3D Modelmaker tab ──────────────────────────────────────────────────── */
#view-engine .meshy-grid,
.eng-ui .meshy-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px;
  margin-bottom: 16px;
}
#view-engine .meshy-card,
.eng-ui .meshy-card {
  background: var(--eng-surf); border: 1.5px solid var(--eng-border);
  border-radius: var(--eng-radius); overflow: hidden; cursor: pointer;
  transition: border-color .15s, transform .1s;
}
#view-engine .meshy-card:hover,
.eng-ui .meshy-card:hover { border-color: var(--eng-border-2); transform: translateY(-2px); }
#view-engine .meshy-card.mc-approved,
.eng-ui .meshy-card.mc-approved { border-color: var(--eng-success); }
#view-engine .meshy-card.mc-rejected,
.eng-ui .meshy-card.mc-rejected { border-color: var(--eng-danger); }
#view-engine .meshy-card.mc-selected,
.eng-ui .meshy-card.mc-selected { border-color: var(--eng-primary); box-shadow: 0 0 0 3px var(--eng-primary-soft); }

#view-engine .meshy-thumb,
.eng-ui .meshy-thumb {
  width: 100%; aspect-ratio: 1; background: var(--eng-surf-2);
  display: flex; align-items: center; justify-content: center; position: relative;
  overflow: hidden;
}
#view-engine .mc-cube-wrap,
.eng-ui .mc-cube-wrap {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%; color: var(--eng-text-subtle);
}
/* GLB mini-viewer in bibliotheek-kaart */
#view-engine .mc-card-glb,
.eng-ui .mc-card-glb {
  position: absolute; inset: 0; width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 50% 40%, #2a2723 0%, #15130f 100%);
}
#view-engine .mc-card-mv,
.eng-ui .mc-card-mv {
  width: 100%; height: 100%; --poster-color: transparent;
  background: transparent; pointer-events: none;
}
/* PresentTool-watermerk in de 3D-viewer (focus + preview).
   Het logo zelf is volledig dekkend (de PNG heeft een opaak logo op een
   transparante achtergrond) — alleen de achtergrond rondom blijft transparant.
   Thema-aware: op het donkere thema (default) tonen we het logo wit zodat het
   contrast houdt; op het lichte thema gebruiken we de native merkbruine PNG. */
#view-engine .mc-viewer-brand,
.eng-ui .mc-viewer-brand {
  position: absolute; top: 10px; left: 12px; z-index: 4;
  height: 16px; width: auto; pointer-events: none;
  opacity: 1;
  filter: brightness(0) invert(1);
}
:root[data-theme="light"] #view-engine .mc-viewer-brand,
:root[data-theme="light"] .eng-ui .mc-viewer-brand {
  filter: none;
}
/* Live preview-box met model-viewer */
#view-engine .mc-preview-box.mc-preview-live,
.eng-ui .mc-preview-box.mc-preview-live {
  padding: 0; overflow: hidden; display: block;
}
#view-engine .mc-preview-box.mc-preview-live .mc-viewer-stage,
.eng-ui .mc-preview-box.mc-preview-live .mc-viewer-stage { width: 100%; height: 100%; }
#view-engine .mc-cube-wrap svg,
.eng-ui .mc-cube-wrap svg { width: 40px; height: 40px; }
#view-engine .mc-status-pill,
.eng-ui .mc-status-pill { position: absolute; bottom: 6px; right: 8px; font-size: 10px; }

#view-engine .meshy-body,
.eng-ui .meshy-body { padding: 10px 12px; }
#view-engine .meshy-title,
.eng-ui .meshy-title { font-size: 13px; font-weight: 600; margin-bottom: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#view-engine .meshy-prompt,
.eng-ui .meshy-prompt { font-size: 11.5px; color: var(--eng-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 8px; }
#view-engine .meshy-footer,
.eng-ui .meshy-footer { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

#view-engine .var-badge,
.eng-ui .var-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10.5px; font-weight: 700; padding: 2px 6px; border-radius: 4px;
  font-family: var(--pt-mono);
}
#view-engine .var-badge.textured,
.eng-ui .var-badge.textured { background: rgba(111,190,142,.15); color: #6FBE8E; }
#view-engine .var-badge.neutral,
.eng-ui .var-badge.neutral  { background: rgba(224,169,58,.12); color: #E0A93A; }

/* ── 3D Rondleiding: stats row ──────────────────────────────────────────── */
.eng-ui .t3-stats-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-bottom: 20px;
}
.eng-ui .t3stat {
  background: var(--eng-surf); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.eng-ui .t3stat-val {
  font-size: 26px; font-weight: 700; letter-spacing: -.02em;
  font-family: var(--pt-serif); font-style: italic; color: var(--eng-text);
  line-height: 1;
}
.eng-ui .t3stat-val.ok   { color: var(--eng-success); }
.eng-ui .t3stat-val.warn { color: var(--eng-warn); }
.eng-ui .t3stat-val.prim { color: var(--eng-primary); font-size: 14px; font-style: normal; font-family: var(--pt-mono); letter-spacing: .02em; }
.eng-ui .t3stat-label {
  font-size: 11px; color: var(--eng-text-muted); letter-spacing: .03em;
  text-transform: uppercase; font-weight: 600;
}

/* tour3d-row.on state */
#view-engine .tour3d-row.on,
.eng-ui .tour3d-row.on {
  border-color: var(--eng-primary);
  background: var(--eng-primary-soft);
  box-shadow: inset 4px 0 0 var(--eng-primary), 0 0 0 1px rgba(139, 69, 19, 0.12);
  cursor: pointer;
}
#view-engine .tour3d-row.on .t3title,
.eng-ui .tour3d-row.on .t3title { color: var(--eng-primary); }
#view-engine .tour3d-row.on::before,
.eng-ui .tour3d-row.on::before {
  content: '✓';
  flex: none; width: 22px; height: 22px; border-radius: 50%;
  background: var(--eng-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.eng-ui .tour3d-row { cursor: pointer; }
.eng-ui .t3actions { display: flex; gap: 6px; align-items: center; flex: none; }

/* segment hide/show */
.eng-ui .t3seg { display: none; }
.eng-ui .t3seg.on { display: block; }

/* ── 3D Rondleiding: viewer embed ───────────────────────────────────────── */
.eng-ui .viewer-embed {
  background: var(--eng-surf-2); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius); overflow: hidden; position: relative;
}
.eng-ui .viewer-embed-topbar {
  background: var(--eng-surf-3); border-bottom: 1px solid var(--eng-border);
  padding: 8px 14px; display: flex; align-items: center; gap: 10px;
}
.eng-ui .ve-dots { display: flex; gap: 5px; }
.eng-ui .ve-dot  { width: 10px; height: 10px; border-radius: 50%; background: var(--eng-border-2); flex: none; }
.eng-ui .ve-dot.red   { background: #B03A2E; }
.eng-ui .ve-dot.amber { background: #C7942A; }
.eng-ui .ve-dot.green { background: #2D7A4F; }
.eng-ui .ve-url {
  flex: 1; background: var(--eng-surf-2); border: 1px solid var(--eng-border);
  border-radius: 6px; padding: 4px 10px; font-size: 12px; font-family: var(--pt-mono);
  color: var(--eng-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.eng-ui .viewer-embed-screen {
  width: 100%; height: 320px; display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 16px; color: var(--eng-text-muted);
  position: relative; overflow: hidden; background: #0A0906;
}
.eng-ui .viewer-embed-screen .overlay-content {
  position: relative; z-index: 1; display: flex; flex-direction: column;
  align-items: center; gap: 12px; text-align: center; padding: 20px;
}
.eng-ui .viewer-embed-screen .vt-logo-sm {
  font-size: 12px; font-weight: 700; letter-spacing: .08em;
  color: rgba(242,240,235,.45); text-transform: uppercase;
}
.eng-ui .viewer-embed-screen h3 {
  font-family: var(--pt-serif); font-style: italic; font-size: 22px;
  color: #F2F0EB; margin: 0;
}
.eng-ui .viewer-embed-screen p {
  font-size: 13px; color: rgba(242,240,235,.6); max-width: 360px; margin: 0;
}
.eng-ui .ve-bg-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: .32; pointer-events: none;
}
.eng-ui .ve-iframe {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
  background: #0A0906;
}
.eng-ui .viewer-nav-bar {
  background: rgba(10,9,6,.75); backdrop-filter: blur(8px);
  border-top: 1px solid rgba(242,240,235,.08);
  padding: 10px 16px; display: flex; align-items: center; gap: 10px;
}
.eng-ui .scene-thumbs { display: flex; gap: 6px; overflow-x: auto; padding: 2px 0; }
.eng-ui .scene-chip,
#view-engine .scene-chip {
  flex: 0 0 auto; padding: 6px 12px; border-radius: 8px; cursor: pointer;
  background: rgba(10, 9, 6, 0.85); border: 1px solid rgba(242, 240, 235, 0.18);
  color: rgba(242, 240, 235, 0.92); font-size: 11.5px; font-weight: 600;
  white-space: nowrap; transition: border-color .15s, background .15s;
}
.eng-ui .scene-chip:hover,
#view-engine .scene-chip:hover { border-color: rgba(242, 240, 235, 0.35); }
.eng-ui .scene-chip.on,
#view-engine .scene-chip.on {
  border-color: var(--eng-primary); background: var(--eng-primary-soft); color: var(--eng-text);
}
.eng-ui .ve-scene-empty,
#view-engine .ve-scene-empty {
  font-size: 11px; color: var(--eng-text-muted); padding: 4px 2px;
}
.eng-ui .scene-thumb {
  width: 48px; height: 34px; border-radius: 4px; flex: none;
  background: var(--eng-surf-3); border: 2px solid transparent; cursor: pointer;
  transition: border-color .15s;
}
.eng-ui .scene-thumb.on { border-color: var(--eng-primary); }
.eng-ui .vn-play {
  background: var(--eng-primary); border: none; border-radius: 50%;
  width: 32px; height: 32px; display: flex; align-items: center;
  justify-content: center; color: #fff; cursor: pointer; flex: none;
}
.eng-ui .vn-play svg { width: 14px; height: 14px; }

/* ── 3D Rondleiding: beheer – scene selector ────────────────────────────── */
.eng-ui .scene-selector {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px;
  margin-bottom: 16px;
}
.eng-ui .scene-card {
  border: 2px solid var(--eng-border); border-radius: var(--eng-radius-sm);
  overflow: hidden; cursor: pointer; transition: border-color .15s, transform .15s;
  background: var(--eng-surf);
}
.eng-ui .scene-card:hover { border-color: var(--eng-border-2); transform: translateY(-1px); }
.eng-ui .scene-card.on    { border-color: var(--eng-primary); }
.eng-ui .scene-card-img   {
  height: 80px; background: var(--eng-surf-2);
  display: flex; align-items: center; justify-content: center; color: var(--eng-text-subtle);
}
.eng-ui .scene-card-img svg { width: 22px; height: 22px; }
.eng-ui .scene-card-cap { padding: 8px 10px; font-size: 12px; font-weight: 500; }
.eng-ui .scene-card-sub { font-size: 11px; color: var(--eng-text-muted); margin-top: 2px; }

/* ── 3D Rondleiding: CDN publish rows ──────────────────────────────────── */
.eng-ui .publish-row {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  background: var(--eng-surf); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); margin-bottom: 6px;
}
.eng-ui .publish-row svg { width: 15px; height: 15px; flex: none; }
.eng-ui .pub-url { flex: 1; font-family: var(--pt-mono); font-size: 11.5px; color: var(--eng-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.eng-ui .pub-status { font-size: 11px; color: var(--eng-text-muted); flex: none; }

/* ── 3D Modelmaker: stats row ───────────────────────────────────────────── */
.eng-ui .m3-stats-row {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px;
  margin-bottom: 20px;
}
.eng-ui .m3stat {
  background: var(--eng-surf); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); padding: 12px 14px;
}
.eng-ui .m3val {
  font-size: 22px; font-weight: 700; font-family: var(--pt-serif);
  font-style: italic; letter-spacing: -.02em; color: var(--eng-text); line-height: 1;
}
.eng-ui .m3val.ok   { color: var(--eng-success); }
.eng-ui .m3val.warn { color: var(--eng-warn); }
.eng-ui .m3val.bad  { color: var(--eng-danger); }
.eng-ui .m3val.prim { color: var(--eng-primary); font-size: 15px; font-style: normal; font-family: var(--pt-mono); }
.eng-ui .m3label {
  font-size: 11px; color: var(--eng-text-muted); text-transform: uppercase;
  letter-spacing: .04em; font-weight: 600; margin-top: 4px;
}

/* Segment show/hide */
.eng-ui .mseg { display: none; }
.eng-ui .mseg.on { display: block; }

/* ── Input mode strip (Tekst / Afbeelding) ──────────────────────────────── */
.eng-ui .input-mode-strip {
  display: flex; gap: 0; border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); overflow: hidden; width: fit-content;
  margin-bottom: 14px;
}
.eng-ui .input-mode-btn {
  padding: 8px 16px; font-size: 13px; font-weight: 500; background: transparent;
  border: none; color: var(--eng-text-muted); cursor: pointer; transition: all .15s;
  display: flex; align-items: center; gap: 7px;
}
.eng-ui .input-mode-btn svg { width: 14px; height: 14px; }
.eng-ui .input-mode-btn.on {
  background: var(--eng-primary-soft); color: var(--eng-primary); font-weight: 600;
}
.eng-ui .input-mode-btn + .input-mode-btn { border-left: 1px solid var(--eng-border); }

/* ── Prompt box ─────────────────────────────────────────────────────────── */
.eng-ui .mc-label {
  font-size: 11px; letter-spacing: .04em; text-transform: uppercase;
  color: var(--eng-text-subtle); font-weight: 600; display: block; margin-bottom: 8px;
}
.eng-ui .mc-prompt-box {
  width: 100%; padding: 10px 12px; background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2); border-radius: var(--eng-radius-sm);
  color: var(--eng-text); font-family: var(--pt-sans); font-size: 13.5px;
  resize: vertical; min-height: 80px; transition: border-color .15s; box-sizing: border-box;
}
.eng-ui .mc-prompt-box:focus { outline: none; border-color: var(--eng-primary); }

/* ── Dropzone ───────────────────────────────────────────────────────────── */
.eng-ui .mc-dropzone {
  border: 1.5px dashed var(--eng-border-2); border-radius: var(--eng-radius-sm);
  padding: 28px 20px; display: flex; flex-direction: column; align-items: center;
  gap: 8px; color: var(--eng-text-muted); cursor: pointer; transition: all .15s;
  background: var(--eng-surf-2); text-align: center;
}
.eng-ui .mc-dropzone:hover { border-color: var(--eng-primary); color: var(--eng-text); }
.eng-ui .mc-dropzone svg { width: 24px; height: 24px; }
.eng-ui .dropzone-lbl { font-size: 13.5px; font-weight: 500; }
.eng-ui .dropzone-sub { font-size: 11.5px; }

/* ── Quality tiles ──────────────────────────────────────────────────────── */
.eng-ui .mc-quality-tiles { display: flex; gap: 10px; margin-bottom: 14px; }
.eng-ui .qtile {
  flex: 1; padding: 12px 14px; border: 1.5px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); cursor: pointer; transition: all .15s;
  background: var(--eng-surf);
}
.eng-ui .qtile:hover { border-color: var(--eng-border-2); }
.eng-ui .qtile.on { border-color: var(--eng-primary); background: var(--eng-primary-soft); }
.eng-ui .qtile-title { font-size: 13px; font-weight: 600; margin-bottom: 3px; }
.eng-ui .qtile-sub   { font-size: 11.5px; color: var(--eng-text-muted); line-height: 1.4; }
.eng-ui .qtile-cost  { font-size: 11.5px; font-family: var(--pt-mono); color: var(--eng-primary); margin-top: 6px; }

/* ── Dual render toggle ─────────────────────────────────────────────────── */
.eng-ui .mc-dual-toggle {
  display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px;
  background: var(--eng-surf); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); margin-bottom: 0; cursor: pointer;
  transition: border-color .15s;
}
.eng-ui .mc-dual-toggle:hover { border-color: var(--eng-border-2); }
.eng-ui .mc-dual-toggle .toggle-pill {
  width: 36px; height: 20px; border-radius: 999px; background: var(--eng-primary);
  position: relative; flex: none; margin-top: 2px; transition: background .15s;
}
.eng-ui .mc-dual-toggle .toggle-pill::after {
  content: ''; position: absolute; top: 3px; right: 3px; width: 14px; height: 14px;
  border-radius: 50%; background: #fff; transition: right .15s, left .15s;
}
.eng-ui .mc-dual-toggle .toggle-pill.off { background: var(--eng-border-2); }
.eng-ui .mc-dual-toggle .toggle-pill.off::after { right: auto; left: 3px; }
.eng-ui .mc-dual-toggle .toggle-text strong { font-size: 13px; font-weight: 600; display: block; margin-bottom: 2px; }
.eng-ui .mc-dual-toggle .toggle-text span   { font-size: 12px; color: var(--eng-text-muted); }

/* ── Rotating box animation + preview box ───────────────────────────────── */
@keyframes eng-rotate-box {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes eng-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.eng-ui .mc-rotating-box {
  width: 72px; height: 72px; border: 1.5px solid var(--eng-primary);
  border-radius: 8px; background: var(--eng-primary-soft);
  display: flex; align-items: center; justify-content: center;
  animation: eng-rotate-box 8s linear infinite;
}
.eng-ui .mc-rotating-box-lg {
  width: 80px; height: 80px; border: 2px solid var(--eng-primary);
  border-radius: 10px; background: var(--eng-primary-soft);
  display: flex; align-items: center; justify-content: center;
  animation: eng-rotate-box 8s linear infinite;
}
.eng-ui .mc-spin-icon {
  color: var(--eng-primary); animation: eng-spin 1.5s linear infinite;
}
.eng-ui .mc-spin-icon svg { width: 28px; height: 28px; }
.eng-ui .meshy-status-overlay {
  position: absolute; bottom: 6px; right: 8px;
  font-size: 10.5px; font-family: var(--pt-mono); color: var(--eng-text-muted);
  background: var(--eng-surf); border-radius: 4px; padding: 2px 6px;
  pointer-events: none;
}
.eng-ui .mc-preview-box {
  height: 280px; background: var(--eng-surf-2); border-radius: var(--eng-radius-sm);
  border: 1px solid var(--eng-border); display: flex; align-items: center;
  justify-content: center; flex-direction: column; gap: 12px;
  color: var(--eng-text-muted);
}

/* ── Meshy list view (recent runs in Nieuw segment) ─────────────────────── */
.eng-ui .meshy-list-view { display: flex; flex-direction: column; gap: 6px; }
.eng-ui .meshy-list-row {
  display: flex; align-items: center; gap: 10px; padding: 9px 12px;
  background: var(--eng-surf); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm);
}
.eng-ui .mlthumb {
  width: 40px; height: 40px; border-radius: 6px; flex: none;
  background: var(--eng-surf-2); border: 1px solid var(--eng-border);
  display: flex; align-items: center; justify-content: center; color: var(--eng-text-muted);
}
.eng-ui .mlthumb svg { width: 18px; height: 18px; }

/* ── Meshy card variant: is-bad ─────────────────────────────────────────── */
.eng-ui .meshy-card.is-bad { border-color: var(--eng-danger); }

/* ── Meshy focus panel ─────────────────────────────────────────────────── */
.eng-tabs-sep {
  width: 1px;
  height: 22px;
  background: var(--eng-border);
  margin: 0 4px;
  align-self: center;
  flex-shrink: 0;
}
.eng-tabs { flex-wrap: wrap; }
.eng-tab--wf { font-size: 12.5px; }
.eng-wf-submodes-row { margin-bottom: 12px; }
.eng-wf-submodes-row .eng-submodes { margin-bottom: 0; }

  margin-bottom: 10px;
  border-radius: var(--eng-radius-sm);
  overflow: hidden;
  min-height: 320px;
  background: var(--eng-viewer-bg);
}
.eng-ui .mc-focus-viewer-wrap model-viewer {
  width: 100%;
  height: 320px;
  display: block;
  background: transparent;
}
.eng-ui .mc-focus-placeholder {
  height: 320px; background: var(--eng-viewer-bg); border: 1px solid var(--eng-border);
  border-radius: var(--eng-radius-sm); display: flex; align-items: center;
  justify-content: center; flex-direction: column; gap: 12px;
  color: var(--eng-text-muted);
}

/* ── 3D-viewer podium: variant-toggle + drag-hint ("handje") ───────────────
   Alles op CSS-vars zodat light/dark automatisch meeschakelt. */
.eng-ui .mc-viewer-stage {
  position: relative;
  width: 100%;
  height: 320px;
  border-radius: var(--eng-radius-sm);
  overflow: hidden;
  background: var(--eng-viewer-bg);
}
.eng-ui .mc-viewer-mv {
  width: 100%;
  height: 100%;
  display: block;
  background: transparent;
  cursor: grab;
  --poster-color: transparent;
}
.eng-ui .mc-viewer-mv:active { cursor: grabbing; }

/* Variant-toggle (textured / neutral) — glas-pill, leesbaar op elke achtergrond. */
.eng-ui .mc-viewer-toggle {
  position: absolute;
  top: 10px; right: 10px;
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--eng-surf) 78%, transparent);
  border: 1px solid var(--eng-border-2);
  box-shadow: 0 2px 10px rgba(0,0,0,0.18);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 3;
}
.eng-ui .mc-vt-btn {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--eng-text-muted);
  font: 600 11.5px/1 inherit;
  letter-spacing: 0.01em;
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
  white-space: nowrap;
}
.eng-ui .mc-vt-btn:hover { color: var(--eng-text); }
.eng-ui .mc-vt-btn.on {
  background: var(--eng-primary);
  color: #fff;
  box-shadow: 0 1px 4px color-mix(in srgb, var(--eng-primary) 45%, transparent);
}
:root[data-theme="light"] .eng-ui .mc-vt-btn.on { color: #fff; }

/* Drag-hint met handje — onderaan gecentreerd, fade-out na interactie. */
.eng-ui .mc-viewer-hint {
  position: absolute;
  left: 50%;
  bottom: 12px;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--eng-text);
  background: color-mix(in srgb, var(--eng-surf) 82%, transparent);
  border: 1px solid var(--eng-border-2);
  box-shadow: 0 2px 10px rgba(0,0,0,0.16);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  pointer-events: none;
  opacity: 1;
  transition: opacity 0.4s ease, transform 0.4s ease;
  z-index: 2;
}
.eng-ui .mc-viewer-hint.is-hidden {
  opacity: 0;
  transform: translateX(-50%) translateY(6px);
}
.eng-ui .mc-vh-ico {
  display: inline-flex;
  color: var(--eng-primary);
  animation: mc-hand-wiggle 1.8s ease-in-out infinite;
}
@keyframes mc-hand-wiggle {
  0%, 100% { transform: translateX(-3px) rotate(-6deg); }
  50%      { transform: translateX(3px) rotate(6deg); }
}
@media (prefers-reduced-motion: reduce) {
  .eng-ui .mc-vh-ico { animation: none; }
}

/* Foutstaat in het podium (verlopen/onbereikbare GLB). */
.eng-ui .mc-viewer-error {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
  background: var(--eng-viewer-bg);
  z-index: 4;
}
.eng-ui .mc-ve-msg { font-size: 12.5px; font-weight: 600; color: var(--eng-danger); }
.eng-ui .mc-ve-link { font-size: 12px; }
.eng-ui .mc-focus-meta {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.eng-ui .mc-focus-meta .review-eyebrow {
  margin-bottom: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.eng-ui .mc-focus-meta .kv {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 12px;
  font-size: 12px;
  margin: 0 0 12px;
}
.eng-ui .mc-focus-meta .kv dt {
  color: var(--eng-text-subtle);
  margin: 0;
  font-size: 11.5px;
  font-weight: 500;
  white-space: nowrap;
  align-self: baseline;
}
.eng-ui .mc-focus-meta .kv dd {
  margin: 0;
  color: var(--eng-text);
  font-family: var(--pt-mono);
  font-size: 11.5px;
  line-height: 1.45;
  word-break: break-word;
  align-self: baseline;
}
.eng-ui .mc-focus-meta .chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 14px;
}
.eng-ui .mc-focus-meta .chip {
  background: var(--eng-surf-2);
  border: 1px solid var(--eng-border-2);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  color: var(--eng-text-muted);
}
.eng-ui .mc-focus-meta .verdicts { margin-top: 0; }
.eng-ui .mc-dropzone.is-drag { border-color: var(--eng-primary); background: var(--eng-primary-soft); }
.eng-ui .mc-focus-meta .mc-focus-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

/* ── Responsive adjustments for new components ──────────────────────────── */
@media (max-width: 768px) {
  .eng-ui .t3-stats-row { grid-template-columns: repeat(2, 1fr); }
  .eng-ui .m3-stats-row { grid-template-columns: repeat(3, 1fr); }
  .eng-ui .mc-quality-tiles { flex-direction: column; }
  .eng-ui #mseg-nieuw > div[style*="grid-template-columns:1fr 1fr"] { display: flex; flex-direction: column; }

  /* 3D Rondleiding mobile */
  .eng-ui .viewer-embed-screen { height: 220px; }
  .eng-ui .viewer-nav-bar { padding: 8px 10px; gap: 6px; flex-wrap: wrap; }
  .eng-ui .scene-thumbs { gap: 4px; max-width: calc(100vw - 120px); }
  .eng-ui .scene-thumb { width: 38px; height: 26px; }
  .eng-ui .viewer-embed-screen h3 { font-size: 17px; }
  .eng-ui .scene-selector { grid-template-columns: repeat(2, 1fr); }
  .eng-ui .t3stat-val.prim { font-size: 11px; }

  /* 3D Modelmaker mobile: two-column focus */
  .eng-ui #eng-mc-focus-inner > div[style*="grid-template-columns:1fr 1fr"] { display: flex; flex-direction: column; }
}

@media (max-width: 480px) {
  .eng-ui .t3-stats-row { grid-template-columns: repeat(2, 1fr); }
  .eng-ui .m3-stats-row { grid-template-columns: repeat(2, 1fr); }
  .eng-ui .input-mode-strip { width: 100%; }
  .eng-ui .input-mode-btn { flex: 1; justify-content: center; }
  .eng-ui .viewer-embed-screen { height: 180px; }
  .eng-ui .viewer-embed-screen p { display: none; }
}

/* Leefbeeld: kies sfeerbeeld-modal */
.eng-ui .eng-pick-sfeer-list { display: flex; flex-direction: column; gap: 8px; max-height: 420px; overflow: auto; }
.eng-ui .eng-pick-sfeer-row {
  display: flex; align-items: center; gap: 12px; width: 100%; padding: 8px 10px;
  border: 1px solid var(--eng-border); border-radius: var(--eng-radius-sm);
  background: var(--eng-surf-2); cursor: pointer; text-align: left;
}
.eng-ui .eng-pick-sfeer-row:hover { border-color: var(--eng-primary); background: var(--eng-surf); }
.eng-ui .eng-pick-sfeer-thumb { width: 72px; height: 48px; flex-shrink: 0; border-radius: 6px; overflow: hidden; background: #1a1814; display: flex; align-items: center; justify-content: center; }
.eng-ui .eng-pick-sfeer-thumb img { width: 100%; height: 100%; object-fit: cover; }
.eng-ui .eng-pick-sfeer-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; font-size: 12px; }
.eng-ui .eng-pick-sfeer-meta strong { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.eng-ui .eng-pick-sfeer-meta span { color: var(--eng-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
