/* ─── Bet Configs v3 styles ─────────────────────────────────────────
   3-pane drilldown + overview table + groups designer.
   Dark Dracula-ish theme, orange accents, mono for IDs.
   ────────────────────────────────────────────────────────────────── */

:root {
  --bcv3-bg-0: #0f0f13;
  --bcv3-bg-1: #15151a;
  --bcv3-bg-2: #1d1d22;
  --bcv3-bg-3: #2a2a32;
  --bcv3-border: #2a2a32;
  --bcv3-border-2: #3a3a42;
  --bcv3-text-1: #e5e5e5;
  --bcv3-text-2: #999;
  --bcv3-text-3: #666;
  --bcv3-accent: #f59e0b;        /* amber */
  --bcv3-accent-hi: #fbbf24;
  --bcv3-success: #4ade80;
  --bcv3-danger:  #ff5870;
  --bcv3-info:    #6a9cff;
  --bcv3-mono: 'Fira Code','SF Mono',Menlo,Consolas,monospace;
}

.bcv3-shell {
  height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bcv3-bg-0);
  color: var(--bcv3-text-1);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 13px;
}

/* ─── Header ───────────────────────────────────────────────────── */
.bcv3-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 16px;
  background: var(--bcv3-bg-1);
  border-bottom: 1px solid var(--bcv3-border);
  flex-shrink: 0;
}
.bcv3-menu-btn {
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-1);
  border-radius: 4px;
  width: 30px;
  height: 30px;
  font-size: 18px;
  cursor: pointer;
}
.bcv3-menu-btn:hover { border-color: var(--bcv3-accent); }
.bcv3-title { font-size: 14px; font-weight: 600; }
.bcv3-badge-new {
  background: var(--bcv3-accent);
  color: #1a1206;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
}
.bcv3-spacer { flex: 1; }
.bcv3-toggle-btn {
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-2);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
}
.bcv3-toggle-btn:hover {
  border-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
}
.bcv3-kbd-hints {
  display: inline-flex;
  gap: 3px;
  margin-right: 8px;
  cursor: help;
}
.bcv3-kbd-hints kbd {
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-2);
  padding: 1px 6px;
  border-radius: 3px;
  font-family: var(--bcv3-mono);
  font-size: 10px;
  line-height: 1.4;
}

/* Tab strip */
.bcv3-tabs {
  display: flex;
  gap: 0;
  background: var(--bcv3-bg-2);
  border-radius: 6px;
  padding: 2px;
}
.bcv3-tab {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  background: transparent;
  border: none;
  color: var(--bcv3-text-2);
  font-size: 12px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.12s;
}
.bcv3-tab:hover { color: var(--bcv3-text-1); }
.bcv3-tab-active {
  background: var(--bcv3-bg-3);
  color: var(--bcv3-text-1);
}
.bcv3-tab-dot { color: var(--bcv3-accent); }

/* ─── Body layouts ─────────────────────────────────────────────── */
.bcv3-body {
  flex: 1;
  overflow: hidden;
  display: flex;
  min-height: 0;
}
.bcv3-configurator { gap: 0; }

/* Pane shared */
.bcv3-tree-pane,
.bcv3-markets-pane,
.bcv3-editor-pane {
  background: var(--bcv3-bg-1);
  border-right: 1px solid var(--bcv3-border);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

/* ─── Tree pane (LEFT) ─────────────────────────────────────────── */
.bcv3-tree-pane { width: 320px; flex-shrink: 0; }
.bcv3-tree-head {
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-bottom: 1px solid var(--bcv3-border);
  background: var(--bcv3-bg-2);
}
.bcv3-tree-head > span {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
  font-weight: 600;
}
.bcv3-tree-search {
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
}

/* Konteksti bar */
.bcv3-context-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  font-size: 11px;
}
.bcv3-context-label {
  color: var(--bcv3-text-2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
  font-size: 10px;
}
.bcv3-context-set-btn {
  flex: 1;
  background: var(--bcv3-bg-3);
  border: 1px dashed var(--bcv3-border-2);
  color: var(--bcv3-text-2);
  padding: 4px 8px;
  font-size: 11px;
  border-radius: 4px;
  cursor: pointer;
  text-align: left;
}
.bcv3-context-set-btn:hover {
  border-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
}
/* Inline Hirarkija search input */
.bcv3-context-inline-input {
  flex: 1;
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 4px 8px;
  font-size: 11px;
  border-radius: 4px;
}
.bcv3-context-inline-input:focus {
  outline: none;
  border-color: var(--bcv3-accent);
}
.bcv3-context-inline-input::placeholder {
  color: var(--bcv3-text-3);
  font-style: italic;
}
.bcv3-context-results {
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 160px;
  overflow-y: auto;
  border: 1px solid var(--bcv3-border);
  border-radius: 4px;
  padding: 4px;
  background: var(--bcv3-bg-0);
  margin-top: 4px;
}
.bcv3-context-result-row {
  padding: 4px 6px;
}
.bcv3-context-chip {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(245,158,11,0.15);
  border: 1px solid var(--bcv3-accent);
  color: var(--bcv3-accent);
  padding: 3px 4px 3px 6px;
  border-radius: 4px;
  font-weight: 600;
}
.bcv3-context-name {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bcv3-context-clear {
  background: transparent;
  border: none;
  color: var(--bcv3-accent);
  width: 18px;
  height: 18px;
  font-size: 14px;
  cursor: pointer;
  border-radius: 50%;
  line-height: 1;
  padding: 0;
}
.bcv3-context-clear:hover {
  background: var(--bcv3-danger);
  color: white;
}
.bcv3-tree-search:focus {
  outline: none;
  border-color: var(--bcv3-accent);
}
.bcv3-tree-body {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
}
.bcv3-tree-branch {}
.bcv3-tree-node {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px 5px 6px;
  cursor: pointer;
  font-size: 12px;
  color: var(--bcv3-text-1);
  border-left: 2px solid transparent;
}
.bcv3-tree-node:hover {
  background: var(--bcv3-bg-2);
}
.bcv3-tree-node-selected {
  background: rgba(245,158,11,0.10);
  border-left-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-tree-arrow {
  font-size: 10px;
  color: var(--bcv3-text-2);
  width: 12px;
  display: inline-flex;
  justify-content: center;
}
.bcv3-tree-label { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bcv3-tree-meta { font-size: 10px; color: var(--bcv3-text-3); }
.bcv3-tree-loading-child,
.bcv3-tree-empty-child {
  padding: 4px 12px 4px 36px;
  font-size: 11px;
  color: var(--bcv3-text-3);
  font-style: italic;
}
/* P21.v3.simpler — clickable team chips inside match row */
.bcv3-tree-match-node {
  align-items: baseline;
}
.bcv3-team-chip {
  color: var(--bcv3-text-1);
  padding: 1px 6px;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.1s;
  border: 1px solid transparent;
}
.bcv3-team-chip:hover {
  background: rgba(245,158,11,0.15);
  border-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
}
.bcv3-team-chip-active {
  background: rgba(245,158,11,0.20);
  border-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-tree-vs {
  display: inline-block;
  margin: 0 4px;
  padding: 0 4px;
  color: var(--bcv3-text-3);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
  opacity: 0.55;
  border-radius: 3px;
}
.bcv3-tree-match-node:hover .bcv3-tree-vs {
  background: rgba(245,158,11,0.10);
  color: var(--bcv3-accent);
  opacity: 1;
}
.bcv3-tree-match-node {
  font-size: 11px;
  line-height: 1.4;
  flex-wrap: nowrap;
  overflow: hidden;
}
.bcv3-team-chip {
  font-size: 10.5px;
  white-space: nowrap;
  max-width: 110px;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0 4px;
}

.bcv3-tree-subheader {
  padding: 4px 12px;
  font-size: 10px;
  color: var(--bcv3-accent);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
  background: rgba(245,158,11,0.04);
  margin-top: 2px;
}

/* User finder */
.bcv3-userfinder {
  border-top: 2px solid var(--bcv3-border);
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--bcv3-bg-0);
}
.bcv3-userfinder-head {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
  font-weight: 600;
  margin-bottom: 6px;
}
.bcv3-userfinder-input {
  width: 100%;
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 5px 10px;
  border-radius: 4px;
  font-size: 12px;
}
.bcv3-userfinder-input:focus { outline: none; border-color: var(--bcv3-accent); }
.bcv3-userfinder-list {
  margin-top: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-height: 240px;
  overflow-y: auto;
}
.bcv3-userfinder-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border);
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.bcv3-userfinder-row:hover {
  border-color: var(--bcv3-accent);
  background: rgba(245,158,11,0.05);
}
.bcv3-userfinder-active {
  border-color: var(--bcv3-accent);
  background: rgba(245,158,11,0.12);
}
.bcv3-userfinder-kind {
  display: inline-flex;
  width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
  background: var(--bcv3-bg-3);
  color: var(--bcv3-accent);
  font-size: 10px;
  font-weight: 700;
  border-radius: 50%;
  flex-shrink: 0;
}
.bcv3-userfinder-name {
  flex: 1;
  color: var(--bcv3-text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bcv3-userfinder-parent {
  font-size: 10px;
  color: var(--bcv3-text-3);
  font-style: italic;
}

/* Currency tabs in editor */
.bcv3-currency-tabs {
  display: flex;
  gap: 2px;
  padding: 8px 14px;
  background: var(--bcv3-bg-1);
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-currency-tab {
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-2);
  padding: 4px 14px;
  border-radius: 4px;
  font-size: 11px;
  font-family: var(--bcv3-mono);
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.12s;
}
.bcv3-currency-tab:hover {
  border-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
}
/* 2026-05-16 — make the ACTIVE currency tab unmistakable. When a default
   group auto-snaps the tab (EUR group → EUR), it must be obvious at a glance
   which currency's parameters are loaded. Strong fill + glow + lift + an
   accent underline, and a brief pulse each time it becomes active. */
.bcv3-currency-active {
  background: var(--bcv3-accent);
  color: #1a1206;
  border-color: var(--bcv3-accent);
  font-size: 12px;
  padding: 5px 18px;
  transform: translateY(-1px) scale(1.06);
  box-shadow: 0 0 0 2px var(--bcv3-accent), 0 4px 14px -2px var(--bcv3-accent);
  position: relative;
  z-index: 1;
  animation: bcv3-ccy-pop 0.34s ease-out;
}
.bcv3-currency-active::after {
  content: "";
  position: absolute;
  left: 14%; right: 14%; bottom: -7px;
  height: 3px;
  border-radius: 3px;
  background: var(--bcv3-accent);
  box-shadow: 0 0 8px var(--bcv3-accent);
}
@keyframes bcv3-ccy-pop {
  0%   { transform: translateY(-1px) scale(0.9);  box-shadow: 0 0 0 0 var(--bcv3-accent); }
  55%  { transform: translateY(-1px) scale(1.13); }
  100% { transform: translateY(-1px) scale(1.06); }
}

/* ─── Markets pane (MIDDLE) ────────────────────────────────────── */
.bcv3-markets-pane { width: 360px; flex-shrink: 0; }
.bcv3-markets-head {
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--bcv3-border);
  background: var(--bcv3-bg-2);
  font-size: 12px;
}
.bcv3-markets-head > span:first-child { color: var(--bcv3-text-2); }
.bcv3-markets-head strong { color: var(--bcv3-accent); }
.bcv3-channel-tabs { display: flex; gap: 2px; }
.bcv3-channel-tab {
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-2);
  padding: 3px 8px;
  font-size: 10px;
  border-radius: 4px;
  cursor: pointer;
}
.bcv3-channel-tab:hover { color: var(--bcv3-text-1); }
.bcv3-channel-active {
  background: var(--bcv3-accent);
  color: #1a1206;
  border-color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-markets-search-row {
  padding: 8px 12px;
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-markets-search {
  width: 100%;
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
}
.bcv3-markets-search:focus { outline: none; border-color: var(--bcv3-accent); }

.bcv3-all-markets {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: rgba(245,158,11,0.08);
  border-bottom: 1px solid var(--bcv3-border);
  cursor: pointer;
  font-weight: 600;
}
.bcv3-all-markets:hover { background: rgba(245,158,11,0.15); }
.bcv3-all-markets.bcv3-market-selected {
  background: rgba(245,158,11,0.20);
}
.bcv3-market-badge {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: bold;
}
.bcv3-badge-all { color: var(--bcv3-accent); }
.bcv3-market-name { flex: 1; font-size: 12px; }
.bcv3-market-sub { font-size: 10px; color: var(--bcv3-text-3); }

.bcv3-markets-groups { flex: 1; overflow-y: auto; }
.bcv3-market-group-head {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: var(--bcv3-bg-2);
  cursor: pointer;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
  position: sticky;
  top: 0;
  z-index: 1;
}
.bcv3-market-group-head:hover { color: var(--bcv3-text-1); }
.bcv3-market-group-name { flex: 1; }
.bcv3-market-group-count { color: var(--bcv3-text-3); }

.bcv3-market-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  cursor: pointer;
  font-size: 12px;
  border-left: 2px solid transparent;
}
.bcv3-market-row:hover { background: var(--bcv3-bg-2); }
.bcv3-market-row.bcv3-market-selected {
  background: rgba(245,158,11,0.12);
  border-left-color: var(--bcv3-accent);
  color: var(--bcv3-accent);
}
.bcv3-market-has-override .bcv3-market-badge { color: var(--bcv3-accent); }
.bcv3-market-id {
  font-family: var(--bcv3-mono);
  font-size: 10px;
  color: var(--bcv3-text-3);
}
.bcv3-market-admin {
  font-size: 10px;
  color: var(--bcv3-accent);
  background: rgba(245,158,11,0.10);
  padding: 1px 5px;
  border-radius: 8px;
  font-family: var(--bcv3-mono);
}

/* ─── Editor pane (RIGHT) ─────────────────────────────────────── */
.bcv3-editor-pane { flex: 1; min-width: 380px; }
.bcv3-editor-head {
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--bcv3-border);
  background: var(--bcv3-bg-2);
  flex-shrink: 0;
}
.bcv3-editor-target { flex: 1; font-size: 12px; }
.bcv3-editor-label { color: var(--bcv3-text-2); }
.bcv3-editor-target strong { color: var(--bcv3-accent); }
.bcv3-editor-sep { color: var(--bcv3-text-3); margin: 0 6px; }
.bcv3-editor-cell { color: var(--bcv3-text-1); }
.bcv3-editor-hir {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
}
.bcv3-editor-hir-global {
  background: var(--bcv3-bg-3);
  color: var(--bcv3-text-2) !important;
  border: 1px dashed var(--bcv3-border-2);
}
.bcv3-editor-hir-user {
  background: rgba(245,158,11,0.15);
  color: var(--bcv3-accent) !important;
  border: 1px solid var(--bcv3-accent);
}
.bcv3-editor-hir .bcv3-userfinder-kind {
  background: var(--bcv3-accent);
  color: #1a1206;
  width: 16px;
  height: 16px;
  font-size: 9px;
}
.bcv3-editor-clear {
  background: transparent;
  border: 1px solid var(--bcv3-danger);
  color: var(--bcv3-danger);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
}
.bcv3-editor-clear:disabled { opacity: 0.4; cursor: not-allowed; }
.bcv3-editor-clear:hover:not(:disabled) {
  background: rgba(255,88,112,0.15);
}

.bcv3-effective-chain {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--bcv3-bg-1);
  border-bottom: 1px solid var(--bcv3-border);
  font-size: 11px;
}
.bcv3-effective-label {
  color: var(--bcv3-text-2);
  font-weight: 600;
}
.bcv3-effective-source {
  background: var(--bcv3-bg-3);
  padding: 2px 8px;
  border-radius: 10px;
  display: inline-flex;
  gap: 4px;
  align-items: center;
}
.bcv3-source-type { color: var(--bcv3-text-2); font-size: 10px; }
.bcv3-source-id { color: var(--bcv3-accent); font-family: var(--bcv3-mono); font-size: 10px; }
.bcv3-source-ms { color: var(--bcv3-info); font-size: 10px; font-family: var(--bcv3-mono); }

.bcv3-editor-form {
  flex: 1;
  overflow-y: auto;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.bcv3-form-section {
  border: 1px solid var(--bcv3-border);
  border-radius: 6px;
  padding: 10px 12px 8px;
  margin: 0;
}
.bcv3-form-section-title {
  padding: 0 6px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-form-field {
  display: grid;
  grid-template-columns: 1fr 1fr 24px;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px dashed var(--bcv3-border);
}
.bcv3-form-field:last-child { border-bottom: none; }
.bcv3-field-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--bcv3-text-1);
  flex-wrap: wrap;
}
/* 2026-05-15: tooltip ? icon + inline default-value hint */
.bcv3-field-help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  font-size: 10px;
  font-weight: 600;
  color: var(--bcv3-text-2);
  cursor: help;
  user-select: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.bcv3-field-help:hover {
  background: rgba(96,165,250,0.15);
  border-color: rgba(96,165,250,0.45);
  color: #60a5fa;
}
.bcv3-field-default-hint {
  font-size: 10px;
  color: var(--bcv3-text-3, #7a8294);
  font-style: italic;
  margin-left: auto;
  padding-left: 8px;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
}
/* T7 (codex round 3): non-blocking help popover */
.bcv3-help-popover {
  position: absolute;
  z-index: 9999;
  width: 320px;
  background: var(--bcv3-bg-elev, #1a1f2c);
  border: 1px solid rgba(96, 165, 250, 0.45);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(96,165,250,0.15);
  padding: 12px 14px 14px;
  color: var(--bcv3-text-1, #e6edf6);
  animation: bcv3-pop-in 0.15s ease-out;
}
@keyframes bcv3-pop-in {
  from { opacity: 0; transform: translateY(-4px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.bcv3-help-popover-close {
  position: absolute;
  top: 4px;
  right: 6px;
  width: 22px;
  height: 22px;
  border: none;
  background: transparent;
  color: var(--bcv3-text-2, #99a3b8);
  font-size: 18px;
  line-height: 22px;
  cursor: pointer;
  border-radius: 4px;
}
.bcv3-help-popover-close:hover {
  background: rgba(255,88,112,0.15);
  color: #ff5870;
}
.bcv3-help-popover-title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 6px;
  padding-right: 24px;
  color: #60a5fa;
}
.bcv3-help-popover-body {
  font-size: 12px;
  line-height: 1.45;
  color: var(--bcv3-text-1, #e6edf6);
}
.bcv3-field-badge {
  font-size: 10px;
  padding: 1px 5px;
  border-radius: 8px;
}
.bcv3-badge-explicit {
  background: rgba(245,158,11,0.20);
  color: var(--bcv3-accent);
}
.bcv3-badge-inherited {
  background: rgba(106,156,255,0.15);
  color: var(--bcv3-info);
}
.bcv3-field-input {
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 5px 8px;
  border-radius: 4px;
  font-size: 12px;
  font-family: var(--bcv3-mono);
}
.bcv3-field-input:focus { outline: none; border-color: var(--bcv3-accent); }
.bcv3-field-explicit {
  border-color: var(--bcv3-accent);
  background: rgba(245,158,11,0.04);
  font-weight: 600;
}
.bcv3-field-inherited {
  color: var(--bcv3-text-3);
  font-style: italic;
  background: var(--bcv3-bg-1);
}
.bcv3-field-bool {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--bcv3-text-2);
}
.bcv3-field-clear {
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-danger);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 12px;
  line-height: 1;
  padding: 0;
}
.bcv3-field-clear:hover { border-color: var(--bcv3-danger); background: rgba(255,88,112,0.10); }

.bcv3-editor-foot {
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-top: 1px solid var(--bcv3-border);
  background: var(--bcv3-bg-2);
  flex-shrink: 0;
}
.bcv3-editor-reason {
  flex: 1;
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
}
.bcv3-editor-cancel,
.bcv3-editor-save {
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-1);
  padding: 6px 14px;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
}
.bcv3-editor-save {
  background: var(--bcv3-accent);
  color: #1a1206;
  border-color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-editor-save:hover:not(:disabled) { filter: brightness(1.1); }
.bcv3-editor-save:disabled,
.bcv3-editor-cancel:disabled { opacity: 0.5; cursor: not-allowed; }

/* ─── Overview tab ─────────────────────────────────────────────── */
.bcv3-overview {
  flex-direction: column;
  padding: 12px 16px;
  overflow-y: auto;
  gap: 12px;
}
.bcv3-overview-head {
  display: flex;
  align-items: center;
  gap: 12px;
}
.bcv3-overview-head > span:first-child {
  font-size: 14px;
  font-weight: 600;
  flex: 1;
}
.bcv3-overview-filters {
  display: flex;
  gap: 8px;
}
.bcv3-overview-search {
  flex: 1;
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
}
.bcv3-overview-filter-select {
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
}
.bcv3-overview-count {
  font-size: 11px;
  color: var(--bcv3-text-2);
}
.bcv3-overview-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bcv3-bg-1);
  font-size: 12px;
}
.bcv3-overview-table th {
  background: var(--bcv3-bg-2);
  color: var(--bcv3-text-2);
  padding: 8px;
  text-align: left;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--bcv3-border);
  position: sticky;
  top: 0;
}
.bcv3-overview-table td {
  padding: 8px;
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-scope-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--bcv3-bg-3);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.bcv3-scope-global { background: rgba(245,158,11,0.20); color: var(--bcv3-accent); }
.bcv3-scope-sport  { background: rgba(106,156,255,0.15); color: var(--bcv3-info); }
.bcv3-scope-country { background: rgba(74,222,128,0.10); color: #6cd197; }
.bcv3-scope-tournament { background: rgba(74,222,128,0.15); color: var(--bcv3-success); }
.bcv3-scope-team   { background: rgba(166,108,255,0.15); color: #a66cff; }
.bcv3-scope-player { background: rgba(255,88,112,0.15);  color: var(--bcv3-danger); }
.bcv3-overview-btn {
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-1);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
  margin-right: 4px;
}
.bcv3-overview-btn:hover { border-color: var(--bcv3-accent); }
.bcv3-overview-btn-danger:hover {
  border-color: var(--bcv3-danger);
  color: var(--bcv3-danger);
}

/* ─── Dizajno tab (Phase F — group designer mirroring Configurator) ─── */
.bcv3-designer-shell {
  flex-direction: column;
  min-height: 0;
}
.bcv3-designer-3pane {
  flex: 1;
  display: flex;
  min-height: 0;
  overflow: hidden;
}
.bcv3-designer-top-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bcv3-bg-2);
  border-bottom: 1px solid var(--bcv3-border);
  flex-shrink: 0;
}
.bcv3-designer-name-input {
  flex: 1;
  min-width: 220px;
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  font-size: 13px;
  font-weight: 600;
  border-radius: 4px;
}
.bcv3-designer-name-input:focus { outline: none; border-color: var(--bcv3-accent); }
.bcv3-designer-tag {
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-1);
  padding: 5px 8px;
  border-radius: 4px;
  font-size: 11px;
}
.bcv3-designer-status {
  padding: 3px 8px;
  border-radius: 10px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.bcv3-designer-status-new   { background: var(--bcv3-bg-3); color: var(--bcv3-text-2); }
.bcv3-designer-status-draft { background: rgba(106,156,255,0.15); color: var(--bcv3-info); }
.bcv3-designer-status-applied { background: rgba(74,222,128,0.15); color: var(--bcv3-success); }
.bcv3-designer-status-archived { background: var(--bcv3-bg-3); color: var(--bcv3-text-3); }

.bcv3-btn-secondary-amber {
  background: transparent;
  color: var(--bcv3-accent);
  border: 1px solid var(--bcv3-accent);
}
.bcv3-btn-secondary-amber:hover { background: rgba(245,158,11,0.10); }

/* Step guide banner */
.bcv3-designer-guide {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: linear-gradient(90deg, rgba(245,158,11,0.08), rgba(245,158,11,0.02));
  border-bottom: 1px solid var(--bcv3-border);
  position: relative;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.bcv3-designer-step-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px 4px 4px;
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border-2);
  border-radius: 16px;
  font-size: 11px;
  color: var(--bcv3-text-2);
  cursor: help;
  transition: all 0.15s;
}
.bcv3-designer-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: var(--bcv3-bg-3);
  color: var(--bcv3-text-2);
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
}
.bcv3-designer-step-done {
  background: rgba(74,222,128,0.12);
  border-color: var(--bcv3-success);
  color: var(--bcv3-success);
}
.bcv3-designer-step-done .bcv3-designer-step-num {
  background: var(--bcv3-success);
  color: #0a2010;
}
.bcv3-designer-guide-close {
  position: absolute;
  top: 8px;
  right: 12px;
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-3);
  width: 22px;
  height: 22px;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}
.bcv3-designer-guide-close:hover { border-color: var(--bcv3-text-1); color: var(--bcv3-text-1); }
.bcv3-designer-guide-collapsed {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 14px;
  background: var(--bcv3-bg-1);
  border-bottom: 1px solid var(--bcv3-border);
  font-size: 10px;
  color: var(--bcv3-text-3);
  flex-shrink: 0;
}
.bcv3-designer-guide-toggle {
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-accent);
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 10px;
  cursor: pointer;
}

/* P21.v3.cb — Proper CSS-drawn checkboxes (no unicode chars)
   Three states: empty, checked (amber + drawn tick), indeterminate (amber + dash).
   Click target = full 18×18 square. Hover lifts border + glow. */
.bcv3-cb {
  position: relative;
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  background: var(--bcv3-bg-0);
  border: 2px solid var(--bcv3-border-2);
  border-radius: 4px;
  cursor: pointer;
  flex-shrink: 0;
  transition: all 0.15s ease;
  vertical-align: middle;
  box-sizing: border-box;
}
.bcv3-cb:hover {
  border-color: var(--bcv3-accent);
  background: rgba(245,158,11,0.10);
  box-shadow: 0 0 0 3px rgba(245,158,11,0.10);
}
/* Checked: amber fill + drawn tick (rotated border) */
.bcv3-cb-on {
  background: var(--bcv3-accent);
  border-color: var(--bcv3-accent);
}
.bcv3-cb-on::after {
  content: "";
  position: absolute;
  left: 4px;
  top: -1px;
  width: 5px;
  height: 10px;
  border: solid #1a1206;
  border-width: 0 2.5px 2.5px 0;
  transform: rotate(45deg);
  pointer-events: none;
}
.bcv3-cb-on:hover {
  background: var(--bcv3-accent-hi);
  border-color: var(--bcv3-accent-hi);
  box-shadow: 0 0 0 3px rgba(245,158,11,0.25);
}
/* Indeterminate: amber semi-fill + horizontal dash */
.bcv3-cb-ind {
  background: rgba(245,158,11,0.18);
  border-color: var(--bcv3-accent);
}
.bcv3-cb-ind::after {
  content: "";
  position: absolute;
  left: 2px;
  right: 2px;
  top: 50%;
  height: 2.5px;
  background: var(--bcv3-accent);
  border-radius: 2px;
  transform: translateY(-50%);
  pointer-events: none;
}
.bcv3-cb-ind:hover {
  background: rgba(245,158,11,0.30);
}
.bcv3-cb:focus-visible {
  outline: 2px solid var(--bcv3-accent);
  outline-offset: 1px;
}
/* Designer tree checkboxes — legacy class kept hidden to avoid layout regression */
.bcv3-designer-checkbox { display: none; }
.bcv3-designer-node-indeterminate .bcv3-tree-label {
  color: var(--bcv3-accent);
  opacity: 0.85;
}

/* Member chip strip below tree head */
.bcv3-designer-member-strip {
  padding: 8px 12px;
  background: var(--bcv3-bg-1);
  border-bottom: 1px solid var(--bcv3-border);
  max-height: 130px;
  overflow-y: auto;
}
.bcv3-designer-member-strip-head {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
  font-weight: 600;
  margin-bottom: 6px;
}
.bcv3-designer-member-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.bcv3-designer-member-chip {
  display: inline-flex;
  align-items: center;
  background: rgba(245,158,11,0.10);
  border: 1px solid var(--bcv3-accent);
  border-radius: 10px;
  font-size: 10px;
  overflow: hidden;
}
.bcv3-designer-member-chip-label {
  padding: 2px 8px;
  color: var(--bcv3-accent);
  cursor: pointer;
  max-width: 140px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bcv3-designer-member-chip-label:hover {
  background: rgba(245,158,11,0.20);
}
.bcv3-designer-member-chip-x {
  background: transparent;
  border: none;
  border-left: 1px solid rgba(245,158,11,0.4);
  color: var(--bcv3-accent);
  width: 18px;
  height: 100%;
  cursor: pointer;
  font-size: 12px;
  line-height: 1;
  padding: 0;
}
.bcv3-designer-member-chip-x:hover {
  background: var(--bcv3-danger);
  color: white;
}

/* Empty state in editor */
.bcv3-designer-empty-state {
  padding: 40px 30px;
  text-align: center;
  color: var(--bcv3-text-2);
  max-width: 380px;
  margin: 60px auto;
}
.bcv3-designer-empty-state h3 {
  color: var(--bcv3-accent);
  margin: 16px 0 12px;
  font-size: 16px;
}
.bcv3-designer-empty-state p {
  margin: 4px 0;
  font-size: 13px;
  line-height: 1.7;
}
.bcv3-designer-empty-icon {
  font-size: 48px;
  opacity: 0.7;
}

/* Warning chip in editor when current cell isn't in group */
.bcv3-designer-warn-not-member {
  display: inline-block;
  padding: 1px 8px;
  background: rgba(255,88,112,0.10);
  border: 1px solid var(--bcv3-danger);
  color: var(--bcv3-danger);
  border-radius: 10px;
  font-size: 10px;
  margin-left: 6px;
  cursor: help;
}
.bcv3-designer-node-checked {
  background: rgba(245,158,11,0.05);
}
.bcv3-designer-node-checked .bcv3-tree-label {
  color: var(--bcv3-accent);
  font-weight: 600;
}

/* Designer group-wide filters block in editor */
.bcv3-designer-filters {
  background: rgba(106,156,255,0.06);
  border: 1px solid rgba(106,156,255,0.20);
  border-radius: 6px;
  padding: 10px 12px;
  margin: 10px 14px;
}
.bcv3-designer-filters-head {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-info);
  font-weight: 600;
  margin-bottom: 8px;
}
.bcv3-designer-filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-size: 12px;
}
.bcv3-designer-filter-lbl {
  min-width: 80px;
  color: var(--bcv3-text-2);
  font-size: 11px;
}

/* Designer footer stats */
.bcv3-designer-footer {
  display: flex;
  gap: 24px;
  padding: 8px 16px;
  background: var(--bcv3-bg-2);
  border-top: 1px solid var(--bcv3-border);
  font-size: 11px;
  color: var(--bcv3-text-2);
  flex-shrink: 0;
}
.bcv3-designer-stat strong {
  color: var(--bcv3-accent);
  font-size: 14px;
  margin-right: 4px;
}

/* ─── Groups tab (Phase D) ────────────────────────────────────── */
.bcv3-groups {
  flex-direction: column;
  padding: 16px;
  overflow-y: auto;
  gap: 16px;
}
.bcv3-groups-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.bcv3-groups-head > span:first-child {
  font-size: 14px;
  font-weight: 600;
}
.bcv3-groups-section-head {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
  margin: 16px 0 8px;
  font-weight: 600;
}
.bcv3-groups-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.bcv3-group-card {
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border);
  border-radius: 8px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.bcv3-group-card-system {
  border-color: rgba(245,158,11,0.3);
  background: linear-gradient(135deg, var(--bcv3-bg-2), rgba(245,158,11,0.05));
}
.bcv3-group-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
}
.bcv3-group-card-desc {
  font-size: 11px;
  color: var(--bcv3-text-2);
  line-height: 1.4;
}
.bcv3-group-card-stats {
  display: flex;
  gap: 16px;
  padding: 8px 0;
  border-top: 1px solid var(--bcv3-border);
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-group-card-stats > div {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.bcv3-group-card-stats strong { font-size: 16px; color: var(--bcv3-accent); }
.bcv3-group-card-stats span { font-size: 10px; color: var(--bcv3-text-2); text-transform: uppercase; letter-spacing: 0.5px; }
.bcv3-group-card-actions {
  display: flex;
  gap: 6px;
}

/* Group designer */
.bcv3-designer {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.bcv3-designer-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-designer-head h2 {
  margin: 0;
  font-size: 16px;
  color: var(--bcv3-accent);
}
.bcv3-designer-steps {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--bcv3-text-2);
}
.bcv3-designer-step-active {
  color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-designer-step-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 900px;
}
.bcv3-designer-form-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.bcv3-designer-label {
  width: 100px;
  font-size: 12px;
  color: var(--bcv3-text-2);
}
.bcv3-designer-input {
  flex: 1;
  background: var(--bcv3-bg-0);
  border: 1px solid var(--bcv3-border);
  color: var(--bcv3-text-1);
  padding: 8px 12px;
  border-radius: 4px;
  font-size: 13px;
}
.bcv3-designer-input:focus { outline: none; border-color: var(--bcv3-accent); }
.bcv3-designer-section-title {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-accent);
  font-weight: 600;
  padding-top: 8px;
}
.bcv3-designer-hint {
  font-size: 12px;
  color: var(--bcv3-text-2);
  margin: 0;
  padding: 0 0 8px;
}
.bcv3-designer-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px;
  background: var(--bcv3-bg-1);
  border: 1px dashed var(--bcv3-border-2);
  border-radius: 6px;
  min-height: 48px;
}
.bcv3-designer-empty-chips {
  padding: 12px;
  color: var(--bcv3-text-3);
  font-style: italic;
  font-size: 12px;
  text-align: center;
  background: var(--bcv3-bg-1);
  border: 1px dashed var(--bcv3-border-2);
  border-radius: 6px;
}
.bcv3-designer-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  border-radius: 14px;
  padding: 4px 4px 4px 8px;
  font-size: 11px;
}
.bcv3-chip-type {
  background: rgba(245,158,11,0.15);
  color: var(--bcv3-accent);
  padding: 1px 6px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 9px;
  font-weight: 700;
}
.bcv3-chip-label {
  color: var(--bcv3-text-1);
}
.bcv3-chip-remove {
  background: transparent;
  border: none;
  color: var(--bcv3-text-3);
  font-size: 14px;
  cursor: pointer;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  line-height: 1;
}
.bcv3-chip-remove:hover {
  background: var(--bcv3-danger);
  color: white;
}
.bcv3-designer-adders {
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  border-radius: 6px;
  padding: 10px;
}
.bcv3-designer-adder-hint {
  font-size: 11px;
  color: var(--bcv3-text-2);
  margin-bottom: 8px;
}
.bcv3-designer-sports-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 6px;
}
.bcv3-designer-sport-btn {
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-1);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
  text-align: left;
}
.bcv3-designer-sport-btn:hover {
  border-color: var(--bcv3-accent);
  background: rgba(245,158,11,0.06);
}

/* Coverage preview */
.bcv3-coverage-stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  padding: 12px;
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  border-radius: 6px;
}
.bcv3-coverage-stat {
  text-align: center;
  padding: 8px;
  background: var(--bcv3-bg-2);
  border-radius: 4px;
}
.bcv3-coverage-num {
  font-size: 22px;
  font-weight: 700;
  color: var(--bcv3-accent);
}
.bcv3-coverage-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
  margin-top: 2px;
}
.bcv3-coverage-samples {
  margin-top: 8px;
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  border-radius: 6px;
}
.bcv3-coverage-samples summary {
  padding: 8px 12px;
  font-size: 11px;
  cursor: pointer;
  color: var(--bcv3-text-2);
}
.bcv3-coverage-sample-list {
  padding: 8px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-top: 1px solid var(--bcv3-border);
  font-size: 11px;
}
.bcv3-coverage-sample {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.bcv3-text-2 { color: var(--bcv3-text-2); }
.bcv3-designer-foot {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 0;
  border-top: 1px solid var(--bcv3-border);
  margin-top: 8px;
}
.bcv3-designer-rules {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 600px;
  overflow-y: auto;
}

/* ─── Misc utility ─────────────────────────────────────────────── */
.bcv3-loading,
.bcv3-empty {
  padding: 30px 20px;
  text-align: center;
  color: var(--bcv3-text-2);
  font-size: 12px;
}
.bcv3-error {
  padding: 20px;
  background: rgba(255,88,112,0.10);
  border: 1px solid var(--bcv3-danger);
  color: var(--bcv3-danger);
  border-radius: 6px;
  margin: 12px;
  font-size: 12px;
}
.bcv3-btn {
  background: var(--bcv3-accent);
  color: #1a1206;
  border: 1px solid var(--bcv3-accent);
  padding: 6px 14px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}
.bcv3-btn:hover { filter: brightness(1.1); }

/* ─── Modal layer (Diff + Preset) ──────────────────────────────── */
.bcv3-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.bcv3-modal {
  background: var(--bcv3-bg-1);
  border: 1px solid var(--bcv3-border);
  border-radius: 8px;
  width: 100%;
  max-width: 720px;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
}
.bcv3-modal-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--bcv3-bg-2);
  border-bottom: 1px solid var(--bcv3-border);
  border-radius: 8px 8px 0 0;
}
.bcv3-modal-title {
  font-weight: 600;
  font-size: 14px;
  color: var(--bcv3-accent);
}
.bcv3-modal-sub {
  flex: 1;
  font-size: 11px;
  color: var(--bcv3-text-2);
}
.bcv3-modal-close {
  background: transparent;
  border: 1px solid var(--bcv3-border-2);
  color: var(--bcv3-text-1);
  width: 28px;
  height: 28px;
  border-radius: 4px;
  font-size: 16px;
  cursor: pointer;
}
.bcv3-modal-close:hover { color: var(--bcv3-danger); border-color: var(--bcv3-danger); }
.bcv3-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
}
.bcv3-modal-foot {
  padding: 10px 16px;
  border-top: 1px solid var(--bcv3-border);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

/* Diff table */
.bcv3-diff-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.bcv3-diff-table th,
.bcv3-diff-table td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--bcv3-border);
  text-align: left;
}
.bcv3-diff-table th {
  background: var(--bcv3-bg-2);
  color: var(--bcv3-text-2);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.bcv3-diff-key { font-family: var(--bcv3-mono); font-size: 11px; color: var(--bcv3-text-1); }
.bcv3-diff-parent { color: var(--bcv3-text-3); }
.bcv3-diff-explicit { color: var(--bcv3-accent); font-weight: 600; }
.bcv3-diff-status { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; }
.bcv3-diff-row-changed { background: rgba(245,158,11,0.05); }
.bcv3-diff-row-added_by_override { background: rgba(74,222,128,0.05); }
.bcv3-diff-row-added_by_override .bcv3-diff-status { color: var(--bcv3-success); }
.bcv3-diff-row-changed .bcv3-diff-status { color: var(--bcv3-accent); }

/* P21.v3.info — Group Info detail modal */
.bcv3-group-info-modal {
  max-width: 920px;
  max-height: 88vh;
}
.bcv3-group-info-modal .bcv3-modal-head {
  background: linear-gradient(180deg, rgba(245,158,11,0.10), var(--bcv3-bg-2));
}
.bcv3-group-info-body {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.bcv3-gi-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.bcv3-gi-stat {
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border);
  border-radius: 6px;
  padding: 10px 12px;
  text-align: center;
}
.bcv3-gi-stat-icon { font-size: 18px; opacity: 0.7; }
.bcv3-gi-stat-val {
  font-size: 22px;
  font-weight: 700;
  color: var(--bcv3-accent);
  margin: 2px 0;
}
.bcv3-gi-stat-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-text-2);
}
.bcv3-gi-section h4 {
  margin: 0 0 8px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--bcv3-accent);
  font-weight: 600;
}
.bcv3-gi-kvs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.bcv3-gi-kv {
  display: flex;
  justify-content: space-between;
  padding: 6px 10px;
  background: var(--bcv3-bg-2);
  border-radius: 4px;
  font-size: 12px;
}
.bcv3-gi-kv-k { color: var(--bcv3-text-2); }
.bcv3-gi-kv-v { color: var(--bcv3-text-1); font-weight: 600; }
.bcv3-gi-member-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.bcv3-gi-member {
  display: inline-block;
  padding: 4px 10px;
  background: var(--bcv3-bg-3);
  border: 1px solid var(--bcv3-border-2);
  border-radius: 12px;
  font-size: 11px;
}
.bcv3-gi-applied-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}
.bcv3-gi-applied-table th {
  text-align: left;
  padding: 6px 8px;
  background: var(--bcv3-bg-2);
  color: var(--bcv3-text-2);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-gi-applied-table td {
  padding: 6px 8px;
  border-bottom: 1px solid var(--bcv3-border);
}
.bcv3-gi-row-inactive { opacity: 0.45; }

.bcv3-gi-affected {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.bcv3-gi-affected-summary {
  font-size: 11px;
  color: var(--bcv3-text-2);
}
.bcv3-gi-affected-count {
  color: var(--bcv3-accent);
  font-weight: 700;
  font-size: 14px;
  margin-right: 6px;
}
.bcv3-gi-affected-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 200px;
  overflow-y: auto;
}
.bcv3-gi-affected-user {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border-2);
  border-radius: 10px;
  font-size: 11px;
}
.bcv3-gi-affected-manager {
  background: rgba(106,156,255,0.10);
  border-color: rgba(106,156,255,0.4);
}
.bcv3-gi-affected-manager .bcv3-userfinder-kind {
  background: var(--bcv3-info);
}
.bcv3-gi-affected-player {
  background: rgba(245,158,11,0.06);
  border-color: rgba(245,158,11,0.3);
}
.bcv3-gi-affected-more {
  font-size: 10px;
  color: var(--bcv3-text-3);
  font-style: italic;
}

/* Preset list */
.bcv3-preset-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.bcv3-preset-item {
  padding: 12px 14px;
  background: var(--bcv3-bg-2);
  border: 1px solid var(--bcv3-border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.12s;
}
.bcv3-preset-item:hover {
  border-color: var(--bcv3-accent);
  background: rgba(245,158,11,0.06);
}
.bcv3-preset-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--bcv3-text-1);
  margin-bottom: 4px;
}
.bcv3-preset-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  color: var(--bcv3-text-2);
}
.bcv3-preset-tag {
  background: rgba(245,158,11,0.15);
  color: var(--bcv3-accent);
  padding: 1px 6px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
}
.bcv3-preset-ccy {
  background: var(--bcv3-bg-3);
  color: var(--bcv3-text-1);
  padding: 1px 6px;
  border-radius: 8px;
  font-family: var(--bcv3-mono);
}

/* Responsive — tablet collapses tree to overlay */
@media (max-width: 900px) {
  .bcv3-tree-pane { width: 240px; }
  .bcv3-markets-pane { width: 300px; }
}
@media (max-width: 720px) {
  .bcv3-configurator { flex-direction: column; }
  .bcv3-tree-pane,
  .bcv3-markets-pane,
  .bcv3-editor-pane {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--bcv3-border);
  }
}

/* ── Phase 4 (rework 2026-05-15) — full-page group Detaje + actor mgmt ── */
.bcv3-group-page { display:flex; flex-direction:column; min-height:100%; }
.bcv3-gp-bar { display:flex; align-items:center; gap:10px; padding:12px 16px;
  border-bottom:1px solid var(--bcv3-border); position:sticky; top:0;
  background:var(--bcv3-bg, #14151a); z-index:5; }
.bcv3-gp-back { background:transparent; border:1px solid var(--bcv3-border);
  color:inherit; padding:6px 12px; border-radius:6px; cursor:pointer; font-size:13px; }
.bcv3-gp-back:hover { background:rgba(255,255,255,.06); }
.bcv3-gp-title { font-size:17px; font-weight:600; }
.bcv3-spacer { flex:1; }
.bcv3-gp-body { padding:18px 20px; flex:1; }
.bcv3-gp-divider { height:1px; background:var(--bcv3-border); margin:22px 0; }
.bcv3-gp-section-title { font-size:14px; font-weight:600; text-transform:uppercase;
  letter-spacing:.04em; opacity:.8; margin-bottom:12px; }
.bcv3-gp-empty { opacity:.55; font-size:13px; padding:10px 0; }
.bcv3-gp-actor-list { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.bcv3-gp-actor-row, .bcv3-gp-search-row { display:flex; align-items:center; gap:12px;
  padding:9px 12px; border:1px solid var(--bcv3-border); border-radius:7px; }
.bcv3-gp-search-row { cursor:pointer; }
.bcv3-gp-search-row:hover { background:rgba(255,255,255,.05); }
.bcv3-gp-actor-type { font-size:10px; font-weight:700; padding:2px 7px; border-radius:4px;
  letter-spacing:.05em; }
.bcv3-gp-actor-type-player { background:#1d3a5f; color:#7db8ff; }
.bcv3-gp-actor-type-manager { background:#4a2d5e; color:#d39bff; }
.bcv3-gp-actor-type-shop { background:#2d4a35; color:#86e0a3; }
.bcv3-gp-actor-type-everyone { background:#5e4a2d; color:#ffce8a; }
.bcv3-gp-actor-name { font-weight:600; }
.bcv3-gp-actor-meta { opacity:.5; font-size:12px; }
.bcv3-gp-actor-row .bcv3-overview-btn-danger { margin-left:auto; }

/* 2026-05-16 — Detajet: parameters-set-per-player list view */
.bcv3-gp-applied { display:flex; flex-direction:column; gap:10px; }
.bcv3-gp-applied-card {
  background:var(--bcv3-bg-2); border:1px solid var(--bcv3-border);
  border-radius:8px; padding:12px 14px;
}
.bcv3-gp-applied-head { display:flex; align-items:center; gap:9px; margin-bottom:9px; }
.bcv3-gp-applied-where { opacity:.6; font-size:12px; }
.bcv3-gp-applied-count {
  font-size:11px; opacity:.65; font-family:var(--bcv3-mono);
  margin-right:8px;
}
.bcv3-gp-edit-params {
  background:var(--bcv3-accent); color:#1a1206; font-weight:700;
  border:none; padding:4px 14px; border-radius:5px; cursor:pointer;
  font-size:12px;
}
.bcv3-gp-edit-params:hover { background:var(--bcv3-accent-hi); }
.bcv3-gp-paramgrid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:5px 14px;
}
.bcv3-gp-param {
  display:flex; justify-content:space-between; gap:8px;
  font-size:12px; padding:3px 0; border-bottom:1px dotted var(--bcv3-border);
}
.bcv3-gp-param-k { opacity:.62; font-family:var(--bcv3-mono); }
.bcv3-gp-param-v { font-weight:600; color:var(--bcv3-accent-hi); }

/* 2026-05-16 — tree colour box: green = system default group, yellow = custom */
.bcv3-tree-box {
  display:inline-block; width:10px; height:10px; border-radius:3px;
  margin:0 7px 0 1px; flex-shrink:0; vertical-align:middle;
  box-shadow:0 0 0 1px rgba(0,0,0,.35);
}
.bcv3-tree-box-green  { background:#34d399; box-shadow:0 0 6px rgba(52,211,153,.6), 0 0 0 1px rgba(0,0,0,.35); }
.bcv3-tree-box-yellow { background:var(--bcv3-accent); box-shadow:0 0 6px rgba(245,158,11,.5), 0 0 0 1px rgba(0,0,0,.35); }

/* 2026-05-16 — Overview polish: phase pill + source-group cell */
.bcv3-phase-pill {
  display:inline-block; font-size:10px; font-weight:700; letter-spacing:.5px;
  padding:2px 8px; border-radius:5px; font-family:var(--bcv3-mono);
}
.bcv3-phase-prematch { background:#1d3a5f; color:#7db8ff; }
.bcv3-phase-live     { background:#5e2d2d; color:#ff9b9b; }
.bcv3-phase-both     { background:var(--bcv3-bg-3); color:var(--bcv3-text-2); }
.bcv3-src-grp { display:inline-flex; align-items:center; gap:6px; font-size:12px; }
.bcv3-src-grp .bcv3-tree-box { margin:0; }
.bcv3-src-direct { opacity:.45; font-size:12px; font-style:italic; }
.bcv3-aud { font-size:11px; font-weight:700; padding:2px 8px; border-radius:5px; font-family:var(--bcv3-mono); }
.bcv3-aud-all  { background:#5e4a2d; color:#ffce8a; }
.bcv3-aud-user { background:#1d3a5f; color:#7db8ff; }
.bcv3-overview-head-txt { display:flex; flex-direction:column; gap:3px; }
.bcv3-overview-sub { font-size:12px; opacity:.6; line-height:1.5; max-width:760px; }

/* 2026-05-16 — default-currency explainer line in the tree */
.bcv3-defccy-help {
  display:flex; align-items:center; gap:7px;
  font-size:11px; opacity:.75; padding:5px 10px 7px 22px;
  border-bottom:1px dashed var(--bcv3-border);
}
.bcv3-defccy-q {
  display:inline-flex; align-items:center; justify-content:center;
  width:15px; height:15px; border-radius:50%; cursor:pointer;
  background:var(--bcv3-bg-3); border:1px solid var(--bcv3-border-2);
  color:var(--bcv3-accent-hi); font-weight:700; font-size:10px;
}
.bcv3-defccy-q:hover { background:var(--bcv3-accent); color:#1a1206; }

/* ═══ 2026-05-16 Detajet redesign (d2) ═══════════════════════════════ */
.bcv3-d2-wrap { display:flex; flex-direction:column; gap:18px; padding:4px 2px 24px; }
.bcv3-d2 { display:flex; flex-direction:column; gap:18px; }

/* Identity hero */
.bcv3-d2-hero {
  display:flex; align-items:center; gap:18px;
  background:linear-gradient(135deg, rgba(245,158,11,.10), rgba(245,158,11,.02));
  border:1px solid var(--bcv3-border);
  border-left:3px solid var(--bcv3-accent);
  border-radius:12px; padding:18px 22px;
}
.bcv3-d2-hero-ic {
  width:54px; height:54px; flex-shrink:0; display:flex; align-items:center;
  justify-content:center; font-size:26px; border-radius:12px;
  background:var(--bcv3-bg-3); border:1px solid var(--bcv3-border);
}
.bcv3-d2-hero-main { flex:1; min-width:0; }
.bcv3-d2-hero-name {
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  font-size:20px; font-weight:700; letter-spacing:.2px;
}
.bcv3-d2-hero-sub { opacity:.6; font-size:13px; margin-top:5px; }
.bcv3-d2-ccy {
  font-size:11px; font-weight:700; font-family:var(--bcv3-mono);
  background:var(--bcv3-accent); color:#1a1206; padding:2px 9px; border-radius:5px;
}
.bcv3-d2-status {
  font-size:10px; font-weight:700; letter-spacing:.6px;
  padding:3px 9px; border-radius:5px; border:1px solid var(--bcv3-border);
}
.bcv3-d2-status-applied  { background:#16351f; color:#86e0a3; border-color:#1f5130; }
.bcv3-d2-status-draft    { background:#2d2a1c; color:#e0c886; border-color:#514a1f; }
.bcv3-d2-status-archived { background:#2a2a2e; color:#9a9aa3; }
.bcv3-d2-hero-stats { display:flex; gap:10px; flex-shrink:0; }
.bcv3-d2-stat {
  text-align:center; min-width:88px; padding:10px 14px;
  background:var(--bcv3-bg-2); border:1px solid var(--bcv3-border); border-radius:10px;
}
.bcv3-d2-stat strong { display:block; font-size:22px; color:var(--bcv3-accent-hi); line-height:1.1; }
.bcv3-d2-stat span   { font-size:10.5px; opacity:.6; text-transform:uppercase; letter-spacing:.4px; }

/* Cards */
.bcv3-d2-card {
  background:var(--bcv3-bg-2); border:1px solid var(--bcv3-border);
  border-radius:12px; padding:16px 18px;
}
.bcv3-d2-card-h {
  display:flex; align-items:center; gap:9px;
  font-size:14px; font-weight:700; letter-spacing:.3px;
  padding-bottom:12px; margin-bottom:14px; border-bottom:1px solid var(--bcv3-border);
}
.bcv3-d2-card-ic { font-size:17px; }
.bcv3-d2-pill {
  font-size:11px; font-weight:700; font-family:var(--bcv3-mono);
  background:var(--bcv3-bg-3); color:var(--bcv3-accent-hi);
  padding:3px 11px; border-radius:20px; border:1px solid var(--bcv3-border);
}
.bcv3-d2-note { opacity:.55; font-size:13px; line-height:1.55; padding:6px 0; }
.bcv3-d2-hint {
  font-size:12px; opacity:.6; line-height:1.5;
  margin:-6px 0 14px; padding:8px 12px; border-radius:7px;
  background:var(--bcv3-bg-1); border:1px dashed var(--bcv3-border);
}

/* Scope chips */
.bcv3-d2-chips { display:flex; flex-wrap:wrap; gap:8px; }
.bcv3-d2-chip {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12.5px; font-weight:600;
  background:var(--bcv3-bg-3); border:1px solid var(--bcv3-border);
  padding:6px 12px; border-radius:8px;
}
.bcv3-d2-chip-ic { font-size:13px; opacity:.9; }
.bcv3-d2-chip-tournament { border-color:#3a4d2f; }
.bcv3-d2-chip-sport      { border-color:#2f3d4d; }
.bcv3-d2-chip-country    { border-color:#4d3a2f; }
.bcv3-d2-chip-team       { border-color:#3a2f4d; }

/* Per-player applied card inside the d2 card */
.bcv3-d2-card.bcv3-gp-applied .bcv3-gp-applied-card {
  background:var(--bcv3-bg-1); border-color:var(--bcv3-border);
}
.bcv3-d2-card.bcv3-gp-applied .bcv3-gp-applied-card + .bcv3-gp-applied-card { margin-top:10px; }

/* Cleaner top bar */
.bcv3-gp-bar {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px; background:var(--bcv3-bg-2);
  border-bottom:1px solid var(--bcv3-border); position:sticky; top:0; z-index:5;
}
.bcv3-gp-title { font-size:16px; font-weight:700; }
.bcv3-gp-back {
  background:var(--bcv3-bg-3); border:1px solid var(--bcv3-border);
  color:var(--bcv3-text-2); padding:6px 14px; border-radius:7px; cursor:pointer;
  font-size:13px; transition:all .12s;
}
.bcv3-gp-back:hover { border-color:var(--bcv3-accent); color:var(--bcv3-accent); }
.bcv3-gp-body { padding:20px 22px; overflow-y:auto; }
.bcv3-gp-add-actor { margin-top:8px; }
.bcv3-gp-actor-search { width:100%; padding:9px 12px; border-radius:7px;
  border:1px solid var(--bcv3-border); background:rgba(255,255,255,.04);
  color:inherit; font-size:13px; }
.bcv3-gp-search-results { margin-top:8px; display:flex; flex-direction:column;
  gap:5px; max-height:320px; overflow:auto; }
.bcv3-gp-add-plus { margin-left:auto; font-size:12px; opacity:.7; }

/* ── U5 toast + UA auto badge (2026-05-15) ── */
#bcv3ToastHost { position:fixed; right:18px; bottom:18px; z-index:99999;
  display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.bcv3-toast { background:#1f8b4c; color:#fff; padding:11px 16px; border-radius:8px;
  font-size:13px; font-weight:600; box-shadow:0 6px 20px rgba(0,0,0,.4);
  opacity:0; transform:translateY(12px); transition:opacity .28s, transform .28s;
  max-width:380px; }
.bcv3-toast.bcv3-toast-in { opacity:1; transform:translateY(0); }
.bcv3-toast-err { background:#b3382f; }
.bcv3-tag-auto { background:#2563eb !important; color:#fff !important; }
.bcv3-group-card-auto { border-left:3px solid #2563eb; }

/* ── NEW MODEL (2026-05-16) — groups in tree + bundle-only designer ── */
.bcv3-groups-tree { margin-top:10px; border-top:1px solid var(--bcv3-border); padding-top:8px; }
.bcv3-designer-2pane { display:flex; gap:14px; flex:1; min-height:0; }
.bcv3-designer-2pane > * { flex:1; min-width:0; overflow:auto; }
.bcv3-designer-2pane .bcv3-designer-member-strip { flex:0 0 320px; }
.bcv3-designer-bundle .bcv3-designer-stat-hint { opacity:.6; font-style:italic; font-weight:400; }

/* ── DRAG-AND-DROP designer (2026-05-16) ── */
.bcv3-designer-draggable { cursor: grab; }
.bcv3-designer-draggable:active { cursor: grabbing; }
.bcv3-designer-draggable .bcv3-tree-label::before { content:"⠿ "; opacity:.35; font-size:11px; }
.bcv3-dragging { opacity:.45; outline:1px dashed var(--bcv3-accent,#2563eb); }
.bcv3-designer-dropzone {
  border:2px dashed var(--bcv3-border,#3a3d44); border-radius:10px;
  transition:border-color .15s, background .15s; min-height:140px; }
.bcv3-designer-dropzone.bcv3-drop-hot {
  border-color:#2563eb; background:rgba(37,99,235,.10); }
.bcv3-designer-dropzone-empty {
  white-space:pre-line; text-align:center; opacity:.5; font-size:13px;
  padding:34px 16px; line-height:1.7; }
.bcv3-designer-member-strip-head { font-weight:600; font-size:13px;
  padding:10px 12px; opacity:.85; }

/* ── DUAL-PANEL designer (2026-05-16) ── */
.bcv3-designer-dual { display:flex; gap:14px; flex:1; min-height:0; padding:0 4px; }
.bcv3-designer-panel { flex:1; min-width:0; display:flex; flex-direction:column;
  border:1px solid var(--bcv3-border,#3a3d44); border-radius:10px; overflow:hidden; }
.bcv3-designer-panel-head { font-size:12px; font-weight:700; letter-spacing:.04em;
  padding:9px 12px; background:rgba(255,255,255,.04);
  border-bottom:1px solid var(--bcv3-border,#3a3d44); text-transform:uppercase; opacity:.85; }
.bcv3-designer-panel-src .bcv3-tree-pane { border:0; flex:1; overflow:auto; }
.bcv3-designer-panel-grp { }
.bcv3-grouptree { flex:1; overflow:auto; border:2px dashed var(--bcv3-border,#3a3d44);
  border-top:0; border-radius:0 0 10px 10px; transition:border-color .15s, background .15s; }
.bcv3-grouptree.bcv3-drop-hot { border-color:#2563eb; background:rgba(37,99,235,.10); }
.bcv3-grouptree-head { display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; font-weight:600; font-size:13px;
  border-bottom:1px solid var(--bcv3-border,#3a3d44); }
.bcv3-grouptree-clear { background:transparent; border:1px solid var(--bcv3-border,#3a3d44);
  color:#e0796f; font-size:11px; padding:3px 9px; border-radius:6px; cursor:pointer; }
.bcv3-grouptree-clear:hover { background:rgba(224,121,111,.12); }
.bcv3-grouptree-sect { padding:6px 0; }
.bcv3-grouptree-sect-head { font-size:11px; font-weight:700; opacity:.6;
  text-transform:uppercase; letter-spacing:.05em; padding:6px 12px; }
.bcv3-grouptree-node { display:flex; align-items:center; justify-content:space-between;
  padding:6px 12px 6px 24px; border-radius:6px; }
.bcv3-grouptree-node:hover { background:rgba(255,255,255,.05); }
.bcv3-grouptree-node-lbl { cursor:pointer; font-size:13px; }
.bcv3-grouptree-node-x { background:transparent; border:0; color:#e0796f;
  font-size:16px; cursor:pointer; line-height:1; padding:0 6px; }
