/* Конструктор «Квантовые поля» — оформление 1-в-1 с интерфейсом Битрикс24 (тема Air).
   Токены сняты с портала: text #424956, accent #0075ff, success #1bce7b,
   base-20 #dfe0e3, base-30 #d5d7db, base-70 #828b95, секция #f6fafb, системный шрифт. */
:root {
    --b-accent: #0075ff;
    --b-accent-d: #0068e0;
    --b-primary: #2fc6f6;
    --b-success: #1bce7b;
    --b-success-d: #16b56c;
    --b-text: #424956;
    --b-muted: #828b95;
    --b-muted-l: #a8adb4;
    --b-line: #dfe0e3;
    --b-line-s: #d5d7db;
    --b-bg: #eef2f5;
    --b-section: #f6fafb;
    --b-danger: #f1533f;
    --b-r: 6px;
    --b-font: system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body {
    margin: 0; padding: 0;
    font-family: var(--b-font);
    font-size: 14px; color: var(--b-text); background: #fff;
    -webkit-font-smoothing: antialiased;
}
.zdf-loading, .zdf-error { padding: 24px; color: var(--b-muted); }
.zdf-error { color: var(--b-danger); }
.zdf-muted { color: var(--b-muted); }
.zdf-uf { font-size: 11px; color: var(--b-muted-l); }

/* layout */
.zdf-layout { display: flex; min-height: 340px; }
.zdf-sidebar {
    width: 232px; flex: 0 0 232px;
    background: #fff; border-right: 1px solid var(--b-line);
    padding: 10px 0;
}
.zdf-brand {
    font-weight: 600; font-size: 15px; color: var(--b-text);
    padding: 4px 20px 12px; display: flex; align-items: center; gap: 8px;
}
.zdf-logo { width: 22px; height: 22px; flex: 0 0 auto; display: block; border-radius: 6px; }
.zdf-nav__item {
    padding: 9px 20px; cursor: pointer; color: var(--b-text);
    border-left: 3px solid transparent; line-height: 1.3;
    transition: background-color .12s, color .12s;
}
.zdf-nav__item:hover { background: var(--b-section); }
.zdf-nav__item.active { background: #eef5ff; border-left-color: var(--b-accent); color: var(--b-accent); font-weight: 600; }
.zdf-nav__sep { padding: 14px 20px 5px; font-size: 11px; text-transform: uppercase; color: var(--b-muted-l); letter-spacing: .04em; }
.zdf-content { flex: 1; padding: 22px 26px; min-width: 0; background: #fff; }

/* head */
.zdf-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; gap: 12px; }
.zdf-head h1 { font-size: 21px; font-weight: 600; margin: 0; color: var(--b-text); }
.zdf-head__btns { display: flex; gap: 10px; align-items: center; }

/* buttons — стиль кнопок Битрикс24 */
.zdf-btn {
    border: 1px solid var(--b-line-s); background: #fff; color: var(--b-text);
    padding: 8px 17px; border-radius: var(--b-r); cursor: pointer;
    font-size: 14px; font-family: inherit; line-height: 1.3;
    transition: background-color .12s, border-color .12s, color .12s;
}
.zdf-btn:hover { background: var(--b-section); border-color: var(--b-muted-l); }
.zdf-btn--primary { background: var(--b-accent); border-color: var(--b-accent); color: #fff; }
.zdf-btn--primary:hover { background: var(--b-accent-d); border-color: var(--b-accent-d); }
.zdf-btn--success { background: var(--b-success); border-color: var(--b-success); color: #fff; }
.zdf-btn--success:hover { background: var(--b-success-d); border-color: var(--b-success-d); }
.zdf-btn--sm { padding: 6px 12px; font-size: 13px; }
.zdf-btn:disabled { opacity: .55; cursor: default; }
.zdf-btn-icon { border: none; background: none; cursor: pointer; font-size: 15px; padding: 5px 7px; border-radius: 4px; color: var(--b-muted); transition: background-color .12s, color .12s; }
.zdf-btn-icon:hover { background: var(--b-section); color: var(--b-text); }
.zdf-btn-icon--danger:hover { color: var(--b-danger); background: #fdeceb; }
.zdf-btn-icon svg { display: block; }

/* table */
.zdf-table { width: 100%; border-collapse: collapse; }
.zdf-table th { text-align: left; font-size: 11px; font-weight: 600; color: var(--b-muted-l); text-transform: uppercase; letter-spacing: .03em; padding: 8px 12px; border-bottom: 1px solid var(--b-line); }
.zdf-table td { padding: 12px; border-bottom: 1px solid var(--b-line); vertical-align: middle; }
.zdf-table tr:hover td { background: var(--b-section); }
.zdf-actions { text-align: right; white-space: nowrap; }
.zdf-tag { font-size: 11px; background: var(--b-section); border: 1px solid var(--b-line); border-radius: 4px; padding: 1px 6px; color: var(--b-muted); }
.zdf-empty-state { padding: 48px 24px; text-align: center; color: var(--b-muted); background: var(--b-section); border: 1px solid var(--b-line); border-radius: 10px; }

/* card (контейнер «Квантовое поле») */
.zdf-card { background: #fff; border: 1px solid var(--b-line); border-radius: 10px; padding: 18px 20px; margin-bottom: 16px; }
.zdf-card__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 4px; }
.zdf-card__title { font-size: 16px; font-weight: 600; color: var(--b-text); display: flex; align-items: center; gap: 8px; }
.zdf-card__sub { font-size: 13px; color: var(--b-muted); margin-bottom: 14px; }

/* accordion — сворачиваемые «Квантовые поля» */
.zdf-acc { border: 1px solid var(--b-line); border-radius: 10px; margin-bottom: 12px; background: #fff; overflow: hidden; }
.zdf-acc__head { display: flex; align-items: center; gap: 10px; padding: 14px 16px; cursor: pointer; user-select: none; transition: background-color .12s ease; }
.zdf-acc__head:hover { background: var(--b-section); }
.zdf-acc__chevron { flex: 0 0 auto; width: 7px; height: 7px; margin: 0 2px; border-right: 2px solid var(--b-muted); border-bottom: 2px solid var(--b-muted); transform: rotate(-45deg); transition: transform .15s ease; }
.zdf-acc.is-open .zdf-acc__chevron { transform: rotate(45deg); }
.zdf-acc__title { flex: 1; font-size: 15px; font-weight: 600; color: var(--b-text); }
.zdf-acc__count { font-size: 12px; color: var(--b-muted); white-space: nowrap; }
/* плавное разворачивание (как в Битриксе): анимируем высоту строки grid 0fr -> 1fr */
.zdf-acc__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .26s ease; }
.zdf-acc.is-open .zdf-acc__body { grid-template-rows: 1fr; }
.zdf-acc__inner { overflow: hidden; min-height: 0; }
.zdf-acc__pad { padding: 6px 16px 16px; border-top: 1px solid var(--b-line); }
.zdf-acc__foot { display: flex; justify-content: flex-end; gap: 10px; margin-top: 14px; }

/* modal */
.zdf-modal { position: fixed; inset: 0; background: rgba(33,47,71,.4); display: flex; align-items: flex-start; justify-content: center; z-index: 1000; overflow: auto; padding: 28px; animation: zdf-fade .15s ease; }
.zdf-modal__box { background: #fff; width: 760px; max-width: 100%; border-radius: 12px; box-shadow: 0 16px 56px rgba(33,47,71,.28); animation: zdf-pop .16s ease; }
.zdf-modal__box--sm { width: 460px; }
@keyframes zdf-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes zdf-pop { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.zdf-modal__head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--b-line); }
.zdf-modal__head h2 { margin: 0; font-size: 17px; font-weight: 600; }
.zdf-modal__close { border: none; background: none; font-size: 18px; cursor: pointer; color: var(--b-muted); padding: 4px 8px; border-radius: 4px; }
.zdf-modal__close:hover { background: var(--b-section); }
.zdf-modal__body { padding: 20px 22px; max-height: 72vh; overflow: auto; }
.zdf-modal__foot { display: flex; justify-content: flex-end; gap: 10px; padding: 14px 22px; border-top: 1px solid var(--b-line); }

/* form */
.zdf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.zdf-f { display: flex; flex-direction: column; gap: 6px; font-size: 13px; }
.zdf-f > span { color: var(--b-muted); }
.zdf-f--row { flex-direction: row; align-items: center; gap: 8px; }
.zdf-f input[type=text], .zdf-f input:not([type]), .zdf-f select {
    border: 1px solid var(--b-line-s); border-radius: var(--b-r);
    padding: 9px 11px; font-size: 14px; width: 100%; font-family: inherit;
    color: var(--b-text); background: #fff; outline: none;
    transition: border-color .12s, box-shadow .12s;
}
.zdf-f input:focus, .zdf-f select:focus { border-color: var(--b-primary); box-shadow: 0 0 0 2px rgba(47,198,246,.2); }
.zdf-section { border-top: 1px solid var(--b-line); margin-top: 18px; padding-top: 16px; }
.zdf-section__title { font-weight: 600; margin-bottom: 10px; }
.zdf-hint { font-size: 13px; color: var(--b-muted); margin-bottom: 14px; line-height: 1.5; }

/* values editor */
.zdf-val-row { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; }
.zdf-val-row input.ze-v-label { flex: 1; border: 1px solid var(--b-line-s); border-radius: var(--b-r); padding: 8px 11px; font-family: inherit; font-size: 14px; outline: none; }
.zdf-val-row input.ze-v-label:focus { border-color: var(--b-primary); box-shadow: 0 0 0 2px rgba(47,198,246,.2); }
.zdf-val-row input.ze-v-color { width: 40px; height: 36px; border: 1px solid var(--b-line-s); border-radius: var(--b-r); padding: 2px; }

/* rules — «Если [поле] = [значение] → показать [поле]» */
.zdf-rule {
    position: relative;
    border: 1px solid var(--b-line);
    border-radius: 10px;
    padding: 14px;
    margin-bottom: 14px;
    background: var(--b-section);
}
.zdf-rule__kw { font-size: 12px; color: var(--b-muted); white-space: nowrap; flex: 1 1 100%; }
.zdf-rule__kw--then { color: var(--b-success-d); font-weight: 600; }
.zdf-rule__src {
    display: flex; align-items: center; gap: 10px;
    background: #fff; border: 1px solid var(--b-line);
    border-left: 3px solid var(--b-accent);
    border-radius: 8px; padding: 9px 11px;
}
.zdf-rule__field { flex: 1; min-width: 0; }
.zdf-rule__src .ze-r-del { margin-left: auto; flex: 0 0 auto; }
.zdf-rule__cond {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    margin: 8px 0 8px 24px; position: relative;
    background: #eef1f5; border-radius: 18px; padding: 7px 13px;
}
.zdf-rule__cond::before, .zdf-rule__then::before {
    content: ''; position: absolute; left: -14px; top: -10px; height: 24px;
    width: 12px; border-left: 2px solid var(--b-line-s); border-bottom: 2px solid var(--b-line-s);
    border-bottom-left-radius: 8px;
}
.zdf-rule__then {
    margin-left: 24px; position: relative;
    background: #fff; border: 1px solid var(--b-line);
    border-left: 3px solid var(--b-success);
    border-radius: 8px; padding: 9px 11px;
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.zdf-rule select, .zdf-rule input[type=text], .zdf-rule input:not([type]) {
    border: 1px solid var(--b-line-s); border-radius: var(--b-r); padding: 7px 9px;
    font-size: 13px; background: #fff; font-family: inherit; color: var(--b-text); outline: none;
}
.zdf-rule select:focus, .zdf-rule input:focus { border-color: var(--b-primary); box-shadow: 0 0 0 2px rgba(47,198,246,.2); }
.zdf-rule .ze-r-pval-wrap { display: inline-flex; flex: 1; min-width: 120px; }
.zdf-rule .ze-r-pval { width: 100%; }
.zdf-rule__eq { font-size: 13px; color: var(--b-text); white-space: nowrap; }
.zdf-rules-empty { padding: 18px; border: 1px dashed var(--b-line-s); border-radius: 8px; text-align: center; color: var(--b-muted); }

/* --- Блочный редактор зависимостей: условие → несколько полей (стиль как в референсе) --- */
.zb-block { background: #f4f6f9; border: 1px solid var(--b-line); border-radius: 12px; padding: 14px; margin-bottom: 16px; }
.zb-sub { background: #fff; border: 1px solid var(--b-line); border-radius: 10px; padding: 12px; }
.zb-sub__title { font-size: 13px; font-weight: 600; color: var(--b-success-d); margin: 0 0 10px; }
.zb-lbl { display: block; font-size: 12px; color: var(--b-muted); margin-bottom: 5px; }
.zb-row { display: flex; align-items: center; gap: 8px; }
.zb-cond { margin-top: 10px; }
.zb-eq { flex: 0 0 auto; font-size: 13px; color: var(--b-text); }
.zb-handle { flex: 0 0 auto; color: #c2c8d0; cursor: grab; font-size: 14px; line-height: 1; user-select: none; }
.zb-conn { width: 2px; height: 14px; background: var(--b-line-s); margin-left: 26px; }
.zb-tgt { margin-bottom: 12px; }
.zb-tgt:last-of-type { margin-bottom: 8px; }
.zb-foot { display: flex; justify-content: flex-end; gap: 10px; margin-top: 10px; }
.zb-sub > .zq-dd { width: 100%; }
.zb-cond .ze-r-pval-wrap { display: inline-flex; flex: 1; min-width: 120px; }
.zb-cond .ze-r-pval-wrap .zq-dd { width: 100%; }
.zb-tgt .zb-row .zq-dd { flex: 1; min-width: 0; }
.zb-tgt .zdf-rule__vals { margin: 8px 0 0 22px; }

/* Кастомный селект в редакторе зависимостей — как выпадающие списки Битрикс24 (меню в портале body) */
.zq-dd { display: inline-flex; align-items: center; gap: 6px; flex: 1; min-width: 0; min-height: 34px; padding: 6px 10px; border: 1px solid var(--b-line-s); border-radius: var(--b-r); background: #fff; color: var(--b-text); font-size: 13px; line-height: 18px; cursor: pointer; outline: none; transition: border-color .12s, box-shadow .12s; }
.zq-dd:hover { border-color: var(--b-muted-l); }
.zq-dd.is-open, .zq-dd:focus { border-color: var(--b-primary); box-shadow: 0 0 0 2px rgba(47, 198, 246, .2); }
.zq-dd-lbl { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.zq-dd-ph { color: var(--b-muted-l); }
.zq-dd-arr { flex: 0 0 auto; width: 6px; height: 6px; margin: -2px 2px 0 0; border-right: 1.5px solid var(--b-muted); border-bottom: 1.5px solid var(--b-muted); transform: rotate(45deg); transition: transform .15s ease; }
.zq-dd.is-open .zq-dd-arr { transform: rotate(-135deg); margin-top: 2px; }
.zq-dd-menu { position: absolute; z-index: 1500; background: #fff; border: 1px solid var(--b-line-s); border-radius: var(--b-r); box-shadow: 0 8px 24px rgba(33, 47, 71, .16); max-height: 260px; overflow-y: auto; padding: 4px 0; }
.zq-dd-opt { padding: 7px 12px; font-size: 13px; color: var(--b-text); cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.zq-dd-opt:hover { background: #eef6ff; }
.zq-dd-opt.is-sel { background: #e3f1ff; }
/* поиск в меню + мульти-селект (много значений → компактно, с прокруткой) */
.zq-dd-menu--search { max-height: none; overflow: visible; }
.zq-dd-menu--search .zq-dd-list { max-height: 220px; overflow-y: auto; padding: 4px 0; }
.zq-dd-search { padding: 7px 8px; border-bottom: 1px solid var(--b-line); background: #fff; position: sticky; top: 0; border-radius: var(--b-r) var(--b-r) 0 0; }
.zq-dd-q { width: 100%; box-sizing: border-box; padding: 6px 9px; border: 1px solid var(--b-line-s); border-radius: var(--b-r); font-size: 13px; outline: none; color: var(--b-text); }
.zq-dd-q:focus { border-color: var(--b-primary); box-shadow: 0 0 0 2px rgba(47, 198, 246, .2); }
.zq-dd-tools { display: flex; gap: 6px; padding: 6px 8px; border-bottom: 1px solid var(--b-line); }
.zq-dd-tools button { flex: 1; font-size: 12px; padding: 4px 6px; border: 1px solid var(--b-line-s); background: #fff; border-radius: 4px; cursor: pointer; color: var(--b-muted); }
.zq-dd-tools button:hover { background: var(--b-section); color: var(--b-text); }
.zq-mdd-menu { max-height: none; overflow: visible; }
.zq-mdd-menu .zq-dd-list { max-height: 220px; overflow-y: auto; padding: 4px 0; }
.zq-mdd-opt { display: flex; align-items: center; gap: 8px; }
.zq-mdd-opt input { width: 15px; height: 15px; margin: 0; accent-color: var(--b-accent); flex: 0 0 auto; cursor: pointer; }
.zq-mdd-opt span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Раздел «Переиспользуемые блоки» + бейдж «блок» в карточке */
.zq-blocks-sep { display: flex; align-items: baseline; gap: 10px; margin: 30px 0 12px; padding-top: 18px; border-top: 1px solid var(--b-line); flex-wrap: wrap; }
.zq-blocks-sep h2 { font-size: 16px; font-weight: 600; margin: 0; color: var(--b-text); }
.zq-blocks-sep .zdf-muted { font-size: 12px; }
.zq-blocks-empty { border: 1px dashed var(--b-line-s); border-radius: 10px; padding: 16px 18px; color: var(--b-muted); font-size: 13px; }
.zq-blocks-empty b { color: var(--b-accent); }
.zdf-acc--block { border-left: 3px solid var(--b-accent); }
.zdf-acc__badge { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: #fff; background: var(--b-accent); border-radius: 4px; padding: 2px 7px; margin-right: 8px; flex: 0 0 auto; }

/* Узел-ссылка на переиспользуемый блок (в дереве) + кнопка «+ блок» + строка в списке */
.zt-blockref { border: 1.5px dashed var(--b-accent) !important; background: #f5f9ff !important; }
.zt-blockref--missing { border-color: var(--b-danger) !important; background: #fdeceb !important; }
.zt-blockref--missing .zt-blockref__icon, .zt-blockref--missing .zt-blockref__name { background: var(--b-danger); color: #fff; }
.zt-blockref--missing .zt-blockref__name { background: none; color: var(--b-danger); }
.zt-blockref__head { display: flex; align-items: center; gap: 8px; }
.zt-blockref__icon { width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; background: var(--b-accent); color: #fff; border-radius: 6px; font-size: 13px; flex: 0 0 auto; }
.zt-blockref__name { font-weight: 600; color: var(--b-accent); font-size: 14px; }
.zt-blockref__meta { font-size: 11px; color: var(--b-muted); margin: 7px 0 8px; }
.zt-blockref__preview { font-size: 12px; color: var(--b-text); background: #fff; border: 1px solid var(--b-line); border-radius: 8px; padding: 9px 11px; line-height: 1.6; }
.zr-addblock { border-style: dashed !important; color: var(--b-accent) !important; border-color: var(--b-accent) !important; }
.zr-addblock:hover { background: #eef5ff !important; }
.zr-refrow { display: flex; align-items: center; gap: 8px; margin-top: 8px; padding: 7px 10px; border: 1px dashed var(--b-accent); border-radius: 8px; background: #f5f9ff; }
.zr-refrow .zt-blockref__icon { width: 20px; height: 20px; font-size: 12px; }
.zr-refrow__name { flex: 1; font-size: 13px; font-weight: 600; color: var(--b-accent); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.zr-refrow .zr-refopen { color: var(--b-accent); }

/* Оператор условия (равно / заполнено / не заполнено) — компактный выпадающий список */
.zr-op { flex: 0 0 auto; width: auto; min-width: 116px; }

/* «связь потеряна» — узел потерял родителя при правке (липкий родитель) */
.zt-node--broken { border-color: var(--b-danger) !important; }
.zt-broken { font-size: 11px; color: var(--b-danger); background: #fdeceb; border: 1px solid #f6c9c2; border-radius: 6px; padding: 4px 8px; margin-bottom: 8px; }

/* перетаскивание узла дерева в другой блок (смена родителя) */
.zt-drag { position: absolute; top: 8px; right: 10px; color: #c2c8d0; cursor: grab; font-size: 15px; line-height: 1; user-select: none; padding: 2px 4px; }
.zt-drag:hover { color: var(--b-muted); }
.zt-drag:active { cursor: grabbing; }
.zt-node.zt-dragging { opacity: .45; }
.zt-node.zt-dropok { outline: 2px dashed var(--b-success); outline-offset: 2px; background: #eafaf1 !important; }
/* тот же дропдаун внутри формы (модал создания/редактирования поля) — на всю ширину */
.zdf-f .zq-dd { width: 100%; }
.zq-dd--ro { background: var(--b-section); border-color: var(--b-line); cursor: default; }
.zq-dd--ro .zq-dd-lbl { color: var(--b-muted); }

/* Каскад (зависимые значения) в карточке «Квантового поля» */
.zq-casc { margin-top: 16px; padding-top: 14px; border-top: 1px dashed var(--b-line-s); }
.zq-casc__title { font-size: 12px; font-weight: 600; color: var(--b-muted-l); text-transform: uppercase; letter-spacing: .03em; margin-bottom: 10px; }
.zq-casc__row { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border: 1px solid var(--b-line); border-radius: 8px; margin-bottom: 8px; background: #fff; }
.zq-casc__name { font-weight: 600; color: var(--b-text); }
.zq-casc__from { font-size: 12px; color: var(--b-muted); }
.zq-casc__row .zdf-btn-icon { margin-left: auto; flex: 0 0 auto; }
.zq-casc__add { margin-top: 4px; max-width: 460px; }

/* Каскад в строке правила: чекбоксы значений целевого поля */
.zdf-rule__vals { margin: 10px 0 0 24px; position: relative; display: flex; align-items: flex-start; gap: 10px; flex-wrap: wrap; background: #fff; border: 1px solid var(--b-line); border-radius: 8px; padding: 9px 11px; }
.zdf-rule__checks { display: flex; flex-wrap: wrap; gap: 6px 16px; }
.zdf-vchk { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--b-text); cursor: pointer; }
.zdf-vchk input { width: 15px; height: 15px; margin: 0; accent-color: var(--b-accent); cursor: pointer; flex: 0 0 auto; }

/* toast */
.zdf-toast { position: fixed; bottom: 22px; left: 50%; transform: translate(-50%, 20px); background: #2b3441; color: #fff; padding: 11px 20px; border-radius: 8px; opacity: 0; transition: all .25s; z-index: 2000; font-size: 14px; box-shadow: 0 8px 24px rgba(33,47,71,.25); }
.zdf-toast.show { opacity: 1; transform: translate(-50%, 0); }
.zdf-toast--err { background: var(--b-danger); }

/* «Созданные поля» — отдельный экран, поля сгруппированы по сущности */
.zq-cgroup { margin-bottom: 22px; }
.zq-cgroup__title { font-size: 11px; font-weight: 600; color: var(--b-muted-l); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 10px; }
.zq-cfield { display: flex; align-items: center; gap: 10px; padding: 11px 14px; border: 1px solid var(--b-line); border-radius: 8px; margin-bottom: 8px; background: #fff; transition: border-color .12s; }
.zq-cfield:hover { border-color: var(--b-line-s); }
.zq-cfield__name { font-weight: 600; color: var(--b-text); }
.zq-cfield__type { font-size: 11px; background: var(--b-section); border: 1px solid var(--b-line); border-radius: 4px; padding: 1px 7px; color: var(--b-muted); white-space: nowrap; }
.zq-cfield__code { font-size: 11px; color: var(--b-muted-l); }
.zq-cfield__vals { font-size: 12px; color: var(--b-muted); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.zq-cfield__act { margin-left: auto; display: flex; gap: 2px; flex: 0 0 auto; }

/* пункт меню «Созданные поля» (с иконкой) */
.zdf-nav__item--view { display: flex; align-items: center; gap: 8px; }
.zdf-nav__ico { display: inline-flex; color: var(--b-muted); flex: 0 0 auto; }
.zdf-nav__item--view.active .zdf-nav__ico { color: var(--b-accent); }

/* футер со ссылкой на сайт + лого */
.zq-footer { display: flex; align-items: center; gap: 8px; margin-top: 30px; padding-top: 16px; border-top: 1px solid var(--b-line); color: var(--b-muted); font-size: 12px; }
.zq-footer img { width: 16px; height: 16px; border-radius: 4px; flex: 0 0 auto; }
.zq-footer a { color: var(--b-accent); text-decoration: none; }
.zq-footer a:hover { text-decoration: underline; }

/* ---------- Древовидный редактор зависимостей (ветки каскада) ---------- */
/* переключатель вида Дерево / Список */
.zq-treebar { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.zq-treebar__sp { flex: 1 1 auto; }
.zq-viewtog { display: inline-flex; margin-bottom: 14px; border: 1px solid var(--b-line-s); border-radius: var(--b-r); overflow: hidden; }
.zq-treebar .zq-viewtog { margin-bottom: 0; }
.zq-vt { border: none; background: #fff; color: var(--b-muted); padding: 7px 16px; font-size: 13px; cursor: pointer; transition: background-color .12s, color .12s; }
.zq-vt + .zq-vt { border-left: 1px solid var(--b-line-s); }
.zq-vt:hover { background: var(--b-section); }
.zq-vt.active { background: var(--b-accent); color: #fff; cursor: default; }

/* контейнер с горизонтальной прокруткой для широких/глубоких деревьев */
.zt-wrap { overflow: auto; padding: 6px 2px 12px; }
.zt-tree { display: inline-block; min-width: 100%; }
.zt-tree ul { display: flex; gap: 22px; list-style: none; margin: 0; padding: 26px 0 0; position: relative; justify-content: center; }
.zt-tree > ul { padding-top: 4px; }
.zt-tree li { display: flex; flex-direction: column; align-items: center; position: relative; padding: 26px 0 0; }
/* соединители (классический org-chart на ::before/::after) */
.zt-tree li::before, .zt-tree li::after { content: ''; position: absolute; top: 0; height: 26px; width: 50%; border-top: 2px solid var(--b-line-s); }
.zt-tree li::before { right: 50%; }
.zt-tree li::after { left: 50%; }
.zt-tree li:only-child::before, .zt-tree li:only-child::after { display: none; }
.zt-tree li:first-child::before { border: 0; }
.zt-tree li:last-child::after { border: 0; }
.zt-tree li:last-child::before { border-right: 2px solid var(--b-line-s); }
.zt-tree ul ul::before { content: ''; position: absolute; top: 0; left: 50%; width: 2px; height: 26px; background: var(--b-line-s); }
/* корни (верхний уровень) — без линии сверху, между собой не соединяются */
.zt-tree > ul > li::before, .zt-tree > ul > li::after { display: none; }

/* узел дерева = тот же блок, но белый, фиксированной ширины */
.zt-node { width: 320px; margin: 0 !important; background: #fff !important; box-shadow: 0 1px 3px rgba(33, 47, 71, .07); position: relative; z-index: 1; text-align: left; }
.zt-node--root { border-left: 3px solid var(--b-accent); }
.zt-node .zt-cap { font-size: 12px; color: var(--b-muted); margin-bottom: 5px; }
.zt-node > .zr-src { width: 100%; margin-bottom: 8px; }
.zt-eqrow { display: flex; align-items: center; gap: 8px; margin: 0 0 4px; }
.zt-eqrow .zb-eq { flex: 0 0 auto; }
.zt-eqrow .ze-r-pval-wrap { display: inline-flex; flex: 1; min-width: 0; }
.zt-eqrow .ze-r-pval-wrap .zq-dd { width: 100%; }
.zt-eqrow .zr-val-inp { flex: 1; min-width: 0; }
.zt-then { border-top: 1px dashed var(--b-line); margin-top: 10px; padding-top: 10px; }
.zt-then .zb-sub__title { margin-bottom: 8px; }
.zt-then .zdf-rule__vals { margin: 8px 0 0; }
.zt-foot { display: flex; justify-content: space-between; gap: 8px; margin-top: 12px; }

/* install page */
.zdf-install { display: flex; align-items: center; justify-content: center; height: 100vh; background: var(--b-bg); }
.zdf-install__box { background: #fff; padding: 40px 48px; border-radius: 12px; text-align: center; box-shadow: 0 8px 30px rgba(33,47,71,.12); }
.zdf-install__icon { width: 56px; height: 56px; line-height: 56px; border-radius: 50%; background: var(--b-success); color: #fff; font-size: 30px; margin: 0 auto 16px; }

/* флажок «обязательное» у поля вывода в блоке */
.zb-req { display:inline-flex; align-items:center; gap:6px; font-size:12px; color:var(--b-muted); margin:8px 0 0 22px; cursor:pointer; }
.zb-req input { width:15px; height:15px; margin:0; accent-color:var(--b-danger); cursor:pointer; flex:0 0 auto; }

/* сворачивание узла дерева: шеврон + компактный вид */
.zt-collapse { position: absolute; top: 7px; left: 7px; display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border: 1px solid var(--b-line-s); border-radius: 6px; background: #fff; color: var(--b-muted); cursor: pointer; font-size: 11px; line-height: 1; user-select: none; z-index: 3; }
.zt-collapse:hover { color: var(--b-accent); border-color: var(--b-accent); background: #f3fbfd; }
.zt-node { padding-left: 32px; }
.zt-node--collapsed { display: flex; align-items: center; gap: 8px; padding: 9px 12px 9px 34px; }
.zt-node-sum { font-size: 13px; color: var(--b-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Конструктор условий: группы И/ИЛИ */
.zc-builder { background:#fff; border:1px solid var(--b-line); border-radius:8px; padding:10px; margin-top:6px; }
.zc-top { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--b-muted); margin-bottom:8px; }
.zc-optoggle { min-width:54px; padding:4px 10px; border:1px solid var(--b-line-s); border-radius:var(--b-r); background:#fff; font-size:13px; font-weight:700; color:var(--b-accent); cursor:pointer; }
.zc-optoggle:hover { background:var(--b-section); }
.zc-group { border:1px solid var(--b-line); border-left:3px solid var(--b-accent); border-radius:8px; padding:9px 10px; margin:6px 0; background:#f8fafc; }
.zc-group__head { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--b-muted); margin-bottom:6px; }
.zc-group__head .zdf-btn-icon { margin-left:auto; }
.zc-cond { display:flex; flex-wrap:wrap; align-items:center; gap:6px; margin:6px 0; }
.zc-cond .zq-dd { flex:1 1 96px; min-width:88px; }
.zc-cond .zc-cmp { flex:0 0 auto; min-width:92px; }
.zc-cond .zc-field { flex:1 1 220px; min-width:0; }
.zc-val-inp { flex:1 1 96px; min-width:88px; padding:6px 10px; border:1px solid var(--b-line-s); border-radius:var(--b-r); font-size:13px; font-family:inherit; }
.zc-noval { flex:1; font-size:12px; }
.zc-joiner { font-size:12px; font-weight:700; color:var(--b-accent); letter-spacing:.04em; margin:2px 0 2px 6px; }
.zc-addgroup { border-style:dashed !important; color:var(--b-accent) !important; border-color:var(--b-accent) !important; margin-top:4px; }

/* сворачивание блоков в списочном виде */
.zb-block { position: relative; }
.zb-block:not(.zt-node) { padding-left: 32px; }
.zb-block--collapsed { display: flex; align-items: center; gap: 8px; }
.zb-block--collapsed:not(.zt-node) { padding: 11px 14px 11px 34px; }
/* Жёсткая блокировка стадии — чекбокс в карточке контейнера */
.zq-blockstage { display: flex; align-items: flex-start; gap: 8px; margin: 10px 0 4px; padding: 9px 11px; border: 1px solid var(--b-line-s); border-radius: var(--b-r); background: #fff7f7; cursor: pointer; font-size: 12.5px; color: var(--b-text); line-height: 1.35; }
.zq-blockstage input { margin-top: 1px; flex: 0 0 auto; }
