/* ── Workflow: SVG-редактор блок-схемы (Фаза 4) ──────────────────
   Палитра PRD: тёплая бумага + Future Dusk; типы блоков различаются
   тинтами в пределах палитры. Плоский стиль, тонкие границы. */

.wf-wrap { display: flex; flex-direction: column; height: calc(100vh - 150px); min-height: 420px; }

.wf-toolbar {
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
    padding: 10px 16px;
    background: var(--paper-surface);
    border: 0.5px solid var(--paper-border);
    border-radius: 12px 12px 0 0;
}
.wf-tools-left { display: flex; gap: 8px; flex-wrap: wrap; }
.wf-tools-right { display: flex; align-items: center; gap: 8px; margin-left: auto; }

.wf-add, .wf-btn {
    font-size: 13px; font-weight: 500;
    padding: 6px 12px; border-radius: 8px;
    border: 0.5px solid var(--paper-border);
    background: var(--paper-bg); color: var(--ink);
    cursor: pointer; transition: background 0.12s;
}
.wf-add:hover, .wf-btn:hover { background: var(--dusk-tint); }
.wf-btn--primary { background: var(--dusk); color: #fff; border-color: var(--dusk); }
.wf-btn--primary:hover { background: var(--dusk-deep); }
/* Точки-метки типов на кнопках добавления */
.wf-add::before {
    content: ''; display: inline-block; width: 8px; height: 8px;
    border-radius: 2px; margin-right: 6px; vertical-align: 1px;
}
.wf-add--action::before      { background: var(--dusk); }
.wf-add--condition::before   { background: var(--dusk-mid); }
.wf-add--event::before       { background: var(--dusk-deep); }
.wf-add--responsible::before { background: var(--status-progress); }

.wf-status { font-size: 12px; color: var(--ink-muted); min-width: 90px; text-align: right; }

/* Breadcrumbs декомпозиции */
.wf-crumbs { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; font-size: 13px; }
.wf-crumb {
    border: none; background: none; cursor: pointer;
    color: var(--dusk); font-size: 13px; padding: 2px 6px; border-radius: 6px;
}
.wf-crumb:hover { background: var(--dusk-tint); }
.wf-crumb.is-current { color: var(--ink); font-weight: 500; cursor: default; }
.wf-crumb-sep { color: var(--ink-muted); }

/* Холст */
.wf-canvas-wrap {
    position: relative; flex: 1; overflow: auto;
    background: var(--paper-bg);
    border: 0.5px solid var(--paper-border); border-top: none;
    border-radius: 0 0 12px 12px;
    background-image: radial-gradient(var(--paper-border) 0.5px, transparent 0.5px);
    background-size: 22px 22px;
}
.wf-canvas { display: block; }

.wf-empty {
    position: absolute; inset: 0; display: none;
    align-items: center; justify-content: center;
    color: var(--ink-muted); font-size: 14px; text-align: center; padding: 20px;
    pointer-events: none;
}

/* Рёбра */
.wf-edge { fill: none; stroke: var(--dusk); stroke-width: 1.5; cursor: pointer; }
.wf-edge:hover { stroke: var(--dusk-deep); stroke-width: 2.5; }

/* Узлы */
.wf-node { cursor: grab; }
.wf-node:active { cursor: grabbing; }
.wf-node-box {
    fill: var(--paper-surface);
    stroke: var(--dusk); stroke-width: 1;
}
.wf-node--condition .wf-node-box { fill: var(--paper-fill); stroke: var(--dusk-mid); stroke-dasharray: 4 3; }
.wf-node--event .wf-node-box      { fill: var(--dusk-tint); stroke: var(--dusk); }
.wf-node--responsible .wf-node-box{ fill: var(--status-progress-soft); stroke: var(--dusk-mid); }
.wf-node.is-edge-src .wf-node-box { stroke: var(--dusk-deep); stroke-width: 2; }

.wf-node-type  { font-size: 10px; fill: var(--ink-muted); font-weight: 500; }
.wf-node-label { font-size: 13px; fill: var(--ink); font-weight: 500; }

.wf-node-handle { fill: var(--dusk); stroke: var(--paper-surface); stroke-width: 1.5; cursor: crosshair; opacity: 0; }
.wf-node:hover .wf-node-handle { opacity: 1; }

.wf-node-dive { cursor: pointer; opacity: 0; }
.wf-node-dive circle { fill: var(--paper-bg); stroke: var(--dusk); stroke-width: 1; }
.wf-node-dive text { font-size: 11px; fill: var(--dusk); text-anchor: middle; }
.wf-node:hover .wf-node-dive { opacity: 1; }
.wf-node-dive:hover circle { fill: var(--dusk-tint); }

.wf-node-haschild { fill: var(--dusk); }

.wf-node-del { cursor: pointer; opacity: 0; }
.wf-node-del text { font-size: 12px; fill: var(--status-failed); text-anchor: middle; }
.wf-node:hover .wf-node-del { opacity: 1; }

/* Поповер шаблонов */
.wf-tpl-pop {
    position: absolute; right: 24px; top: 70px; z-index: 50;
    width: 320px; max-height: 60vh; overflow: auto;
    background: var(--paper-surface);
    border: 0.5px solid var(--paper-border); border-radius: 12px;
    padding: 12px; box-shadow: 0 8px 24px rgba(46,42,36,0.14);
}
.wf-tpl-pop-head { font-size: 14px; font-weight: 500; color: var(--ink); margin-bottom: 8px; }
.wf-tpl-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.wf-tpl-item {
    display: flex; justify-content: space-between; align-items: center; gap: 8px;
    padding: 8px 10px; border-radius: 8px; cursor: pointer;
    border: 0.5px solid var(--paper-border); background: var(--paper-bg); color: var(--ink);
    font-size: 13px; text-align: left;
}
.wf-tpl-item:hover { background: var(--dusk-tint); }
.wf-tpl-name { font-weight: 500; }
.wf-tpl-by { font-size: 11px; color: var(--ink-muted); }
.wf-tpl-empty { font-size: 13px; color: var(--ink-muted); padding: 8px; }

/* ===== Workflow: таксономия блоков + валидация (батч «правильная логика») ===== */
/* Формы — реальные SVG-элементы (ellipse/polygon/rect) из render(); здесь
   только цвет обводки по типу. rx НЕ задаём: на <ellipse> CSS-rx переопределяет
   радиус и ломает форму. */
.wf-node--start  .wf-node-box { stroke: var(--status-done, #5E8A6B); stroke-width: 2; }
.wf-node--end    .wf-node-box { stroke: var(--dusk-deep, #353659); stroke-width: 2.5; }
.wf-node--event  .wf-node-box { stroke: var(--dusk-mid, #6E709C); }
.wf-node--gateway .wf-node-box { stroke: var(--dusk-mid, #6E709C); }
.wf-node--subprocess .wf-node-box { stroke-width: 2; }
/* Центрированный текст для круга/ромба. */
.wf-node-label--center { text-anchor: middle; }

/* Подсветка ошибок валидации */
.wf-node.is-invalid .wf-node-box {
    stroke: var(--status-failed, #B5573C) !important;
    stroke-width: 2.5 !important;
}
.wf-edge.is-invalid { stroke: var(--status-failed, #B5573C) !important; stroke-width: 2.5 !important; }

/* Подпись ветви шлюза на ребре */
.wf-edge-label {
    fill: var(--ink-muted, #7A7363);
    font-size: 11px;
    text-anchor: middle;
    paint-order: stroke;
    stroke: var(--paper-bg, #F3ECDF);
    stroke-width: 3px;
}

/* Панель валидации */
.wf-validation {
    margin: 8px 12px 0;
    padding: 10px 12px;
    border-radius: var(--radius-md, 10px);
    border: 1px solid var(--paper-border, #DDD3C0);
    background: var(--paper-surface, #FAF5EB);
    font-size: var(--text-sm, 13px);
}
.wf-validation.is-ok   { border-color: var(--status-done, #5E8A6B); color: var(--status-done, #5E8A6B); }
.wf-validation.is-bad  { border-color: var(--status-failed, #B5573C); }
.wf-validation-head    { font-weight: 500; margin-bottom: 4px; color: var(--ink, #2E2A24); }
.wf-validation.is-bad .wf-validation-head { color: var(--status-failed, #B5573C); }
.wf-validation-list    { margin: 0; padding-left: 18px; color: var(--ink-muted, #7A7363); }
.wf-validation-list li { margin: 2px 0; }

/* Цветные точки новых типов блоков в тулбаре (event уже определён выше). */
.wf-add--start::before      { background: var(--status-done, #5E8A6B); }
.wf-add--task::before       { background: var(--dusk, #4E5180); }
.wf-add--gateway::before    { background: var(--dusk-mid, #6E709C); }
.wf-add--subprocess::before { background: var(--dusk-deep, #353659); }
.wf-add--end::before        { background: var(--ink-muted, #7A7363); }

/* ===== Workflow: панель свойств узла + выбор ===== */
.wf-node.is-selected .wf-node-box {
    stroke: var(--dusk, #4E5180);
    stroke-width: 2.5;
    filter: drop-shadow(0 1px 4px rgba(78,81,128,.25));
}
.wf-props {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 280px;
    max-width: calc(100% - 24px);
    background: var(--paper-surface, #FAF5EB);
    border: 1px solid var(--paper-border, #DDD3C0);
    border-radius: var(--radius-md, 10px);
    box-shadow: 0 8px 24px rgba(46,42,36,.14);
    padding: 12px 14px 14px;
    z-index: 20;
    font-size: var(--text-sm, 13px);
}
.wf-props-head {
    font-weight: 500;
    color: var(--ink, #2E2A24);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.wf-props-type { color: var(--dusk, #4E5180); font-weight: 500; }
.wf-props-x {
    margin-left: auto;
    border: none;
    background: none;
    color: var(--ink-muted, #7A7363);
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    padding: 2px 4px;
}
.wf-props-x:hover { color: var(--status-failed, #B5573C); }
.wf-props-field { display: block; margin-bottom: 10px; }
.wf-props-field > span {
    display: block;
    font-size: var(--text-xs, 12px);
    color: var(--ink-muted, #7A7363);
    margin-bottom: 3px;
}
.wf-props-field input,
.wf-props-field select,
.wf-props-field textarea {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid var(--paper-border, #DDD3C0);
    border-radius: var(--radius-sm, 6px);
    background: var(--paper-bg, #F3ECDF);
    color: var(--ink, #2E2A24);
    font: inherit;
    padding: 6px 8px;
}
.wf-props-field input:focus,
.wf-props-field select:focus,
.wf-props-field textarea:focus {
    outline: none;
    border-color: var(--dusk, #4E5180);
    box-shadow: 0 0 0 2px var(--dusk-tint, #E4E3EF);
}
.wf-props-field textarea { resize: vertical; }
@media (max-width: 560px) {
    .wf-props { position: static; width: auto; margin: 8px 12px 0; box-shadow: none; }
}

/* Undo/redo кнопки-иконки */
.wf-btn--icon { padding: 6px 10px; font-size: 15px; line-height: 1; }
.wf-btn--icon:disabled { opacity: .4; cursor: default; }
.wf-btn--icon:disabled:hover { background: var(--paper-bg, #F3ECDF); }

/* ===== Workflow: мини-карта ===== */
.wf-minimap {
    position: absolute;
    bottom: 12px;
    right: 12px;
    width: 180px;
    height: 105px;
    background: var(--paper-surface, #FAF5EB);
    border: 1px solid var(--paper-border, #DDD3C0);
    border-radius: var(--radius-sm, 6px);
    box-shadow: 0 4px 12px rgba(46,42,36,.12);
    overflow: hidden;
    z-index: 15;
    opacity: .92;
}
.wf-minimap:hover { opacity: 1; }
.wf-minimap svg { display: block; width: 100%; height: 100%; cursor: pointer; }
.wf-mini-node { fill: var(--dusk-mid, #6E709C); stroke: none; opacity: .85; }
.wf-mini-node.wf-node--start { fill: var(--status-done, #5E8A6B); }
.wf-mini-node.wf-node--end   { fill: var(--dusk-deep, #353659); }
.wf-mini-node.wf-node--gateway { fill: var(--dusk, #4E5180); }
.wf-mini-view-rect {
    fill: var(--dusk, #4E5180);
    fill-opacity: .12;
    stroke: var(--dusk, #4E5180);
    stroke-width: 14;
}
@media (max-width: 560px) { .wf-minimap { display: none !important; } }
