:root{--accent: #d71920;--accent-dark: #a91117;--ink: #171923;--muted: #667085;--subtle: #f6f7f9;--panel: #ffffff;--line: #d9dee7;--line-strong: #b8c0cc;--success: #16794c;--warning: #9a5b00;--danger: #b42318;--info: #175cd3}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#eef1f5;color:var(--ink)}button,input,select,textarea{font:inherit}button{border:1px solid transparent;border-radius:8px;cursor:pointer;min-height:34px}button:disabled{cursor:not-allowed;opacity:.55}header{background:#111827;color:#fff;padding:13px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid #273244;box-shadow:0 2px 8px #11182724}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-logo{width:46px;height:46px;border-radius:8px;object-fit:cover;background:#fff;border:1px solid rgba(255,255,255,.22);box-shadow:0 1px 3px #00000038;flex:0 0 auto}header .t{font-weight:800;font-size:18px;letter-spacing:0}header .s{font-size:12px;color:#cbd5e1;margin-top:2px;max-width:620px}.header-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}header button{background:#1f2937;color:#fff;border-color:#374151;padding:8px 12px;font-size:13px;font-weight:700}header button:hover{background:#273244;border-color:#4b5563}.wrap{display:flex;align-items:flex-start;gap:16px;padding:16px}.workspace{flex:1;min-width:0;max-width:1680px}.sidenav{flex:0 0 220px;position:sticky;top:16px;align-self:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:18px;box-shadow:0 1px 2px #1018280a}.sidenav-links{display:flex;flex-direction:column;gap:4px}.sidenav-foot{display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--line);padding-top:10px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;border:1px solid transparent;color:#344054;font-size:14px;font-weight:600;padding:9px 11px;border-radius:8px;text-decoration:none}.nav-item:hover{background:var(--subtle)}.nav-item.active{background:#fef2f2;color:var(--accent-dark);border-color:#f6caca}.nav-item.subtle{color:var(--muted);font-weight:600;font-size:13px}.nav-glyph{width:18px;text-align:center;font-size:15px;opacity:.85}.nav-item.active .nav-glyph{opacity:1}.control-page{max-width:1180px;margin:0 auto}.control-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.control-head-actions{display:flex;gap:8px;flex:0 0 auto}.control-head h1{margin:0;font-size:24px;line-height:1.2}.control-head p{margin:5px 0 0;color:var(--muted);font-size:14px}.count-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.count-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:14px;box-shadow:0 1px 2px #1018280a}.count-card span{display:block;color:var(--muted);font-size:12px;font-weight:700}.count-card strong{display:block;font-size:28px;margin-top:4px}.edit-page{display:grid;grid-template-columns:minmax(560px,1fr) minmax(340px,420px);gap:16px;align-items:start}.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:10px}.card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:14px;margin-bottom:14px;box-shadow:0 1px 2px #1018280a}.card h3{margin:0 0 9px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#475467}.small{font-size:12px;color:var(--muted);margin:0 0 10px;line-height:1.45}code{background:#f2f4f7;border:1px solid #e4e7ec;border-radius:6px;padding:1px 5px;font-size:12px}label{display:block;font-size:12px;color:#475467;margin:9px 0 4px}input,select,textarea{width:100%;padding:8px 10px;border:1px solid var(--line-strong);border-radius:8px;font-size:13px;background:#fff;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--info);box-shadow:0 0 0 3px #175cd31f}textarea{resize:vertical;min-height:52px;line-height:1.4}.row{display:flex;gap:8px;align-items:center}.row.end{justify-content:flex-end;margin-top:8px}.notice{background:#fff7ed;color:#7c2d12;border:1px solid #fed7aa;border-radius:8px;padding:9px 11px;font-size:13px;margin-bottom:14px}.health{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px}.status-grid{display:grid;grid-template-columns:repeat(3,82px);gap:8px}.status-grid div{border:1px solid var(--line);border-radius:8px;padding:8px;background:var(--subtle);text-align:center}.status-grid strong{display:block;font-size:20px}.status-grid span{display:block;color:var(--muted);font-size:11px}.issues{grid-column:1 / -1;display:grid;gap:6px}.issue{border-radius:8px;padding:7px 9px;font-size:12px;border:1px solid}.issue.err{color:var(--danger);background:#fff5f4;border-color:#fecdca}.issue.warn{color:var(--warning);background:#fffaeb;border-color:#fedf89}.import-card textarea{min-height:160px}.prompt-block{padding:16px 0;border-bottom:1px solid var(--border, #e5e7eb)}.prompt-block:last-child{border-bottom:none}.prompt-block .section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.prompt-textarea{width:100%;min-height:220px;margin-top:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;line-height:1.5;white-space:pre-wrap}.role-badge{padding:4px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:600;text-transform:capitalize;align-self:center}.role-badge.ro{background:#fffaeb;color:#9a6700}.history-table{width:100%;border-collapse:collapse;font-size:13px}.history-table th,.history-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border, #e5e7eb);vertical-align:top}.history-table th{color:#6b7280;font-weight:600}.history-table .nowrap{white-space:nowrap}.pill{padding:2px 8px;border-radius:999px;background:#f3f4f6;font-size:12px;text-transform:capitalize;white-space:nowrap}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.filter-bar .filter-search{flex:1 1 240px;min-width:200px}.filter-bar select{width:auto;min-width:130px;flex:0 0 auto}.pill.type-flow{background:#eef4ff;color:#1d4ed8}.pill.type-prompt{background:#f3eefb;color:#6f42c1}.pill.type-role{background:#fff3e0;color:#9a5b00}.pill.type-config{background:#f0f4f8;color:#475467}.pill.act-create{background:#ecfdf3;color:var(--success)}.pill.act-update{background:#eff8ff;color:#175cd3}.pill.act-delete{background:#fff5f4;color:var(--danger)}.pill.act-enable{background:#ecfdf3;color:var(--success)}.pill.act-disable{background:#f2f4f7;color:#475467}.pill.act-role_grant{background:#fff3e0;color:#9a5b00}.pill.act-publish{background:#f3eefb;color:#6f42c1}.role-form{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.role-form input{flex:1 1 260px;min-width:200px}.role-form select{width:auto;min-width:130px;flex:0 0 auto}.history-table td select{width:auto;min-width:120px}.pill.role-superadmin{background:#fef2f2;color:var(--accent-dark)}.pill.role-admin{background:#eff8ff;color:#175cd3}.pill.role-viewer{background:#f2f4f7;color:#475467}.history-table tr.clickable{cursor:pointer}.history-table tr.clickable:hover td{background:#fbfcfe}.history-table .mono{font:12px ui-monospace,SFMono-Regular,Menlo,monospace;color:#475467}.expand-hint{color:var(--muted);font-size:11px}.diff-row td{background:#f8fafc;padding:10px 14px}.diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.diff-h{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;margin-bottom:4px}.diff-pre{background:#fff;color:var(--ink);border:1px solid var(--line);padding:8px 10px;border-radius:6px;font-size:12px;line-height:1.5;white-space:pre-wrap;overflow-wrap:anywhere;max-height:320px;margin:0}.diff-lines{background:#fff;border:1px solid var(--line);border-radius:6px;font:12px/1.55 ui-monospace,SFMono-Regular,Menlo,monospace;max-height:360px;overflow:auto;padding:4px 0}.dl{display:flex;gap:8px;padding:0 10px;white-space:pre-wrap;overflow-wrap:anywhere}.dl-sign{flex:0 0 12px;text-align:center;color:#98a2b3;-webkit-user-select:none;user-select:none}.dl-text{flex:1;min-width:0}.dl-same{color:#475467}.dl-add{background:#e6f4ea;color:#066043}.dl-add .dl-sign{color:#1a7f37}.dl-del{background:#fdeceb;color:#a3201a}.dl-del .dl-sign{color:var(--danger)}.control-list{min-height:420px}.control-row{display:grid;grid-template-columns:minmax(0,1fr) 132px auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:8px;padding:10px;margin-bottom:8px;background:#fff}.flow-main{border:none;background:transparent;min-height:0;padding:0;text-align:left;color:var(--ink)}.flow-main strong{display:block;font-size:14px;line-height:1.3;overflow-wrap:anywhere}.flow-main span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.switch-toggle{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:128px;padding:6px 9px;background:#fff;border:1px solid var(--line-strong);color:#344054}.switch-toggle .switch-track{width:38px;height:22px;border-radius:999px;background:#98a2b3;position:relative;flex:0 0 auto;transition:background .16s ease}.switch-toggle .switch-thumb{width:18px;height:18px;border-radius:999px;background:#fff;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #10182838;transition:transform .16s ease}.switch-toggle.on{border-color:#abefc6;color:var(--success);background:#ecfdf3}.switch-toggle.on .switch-track{background:var(--success)}.switch-toggle.on .switch-thumb{transform:translate(16px)}.switch-toggle.off{background:#fff}.switch-label{font-size:13px;font-weight:800}.editor-stack{min-width:0}.selected-bar{background:#fff;border:1px solid var(--line);border-radius:8px;padding:13px 14px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.edit-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.selected-bar h2{margin:0;font-size:18px;line-height:1.25}.selected-bar p{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.issues-card{background:#fff}.state{border-radius:8px;padding:5px 8px;font-size:12px;font-weight:700;white-space:nowrap}.ready-dot{color:var(--success);background:#ecfdf3;border:1px solid #abefc6}.blocked-dot{color:var(--danger);background:#fff5f4;border:1px solid #fecdca}.switch{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line-strong);border-radius:8px;padding:6px 9px;margin:0;color:#344054;background:#fff;min-width:82px}.switch.large{min-width:108px;padding:8px 12px}.switch input{width:16px;height:16px;margin:0}.switch span{font-size:13px;font-weight:700}.step{--step-color: #175cd3;border:1px solid #c9d6ea;border-radius:8px;padding:12px 12px 12px 18px;margin-bottom:14px;background:#fff;box-shadow:0 0 0 1px #175cd30a,0 8px 22px #175cd314,0 2px 6px #1018280f;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease;position:relative;overflow:hidden}.step:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;background:var(--step-color)}.step:hover{border-color:#9fb8df;box-shadow:0 0 0 1px #175cd31a,0 12px 28px #175cd321,0 4px 10px #10182814;transform:translateY(-1px)}.step.is-dragging{opacity:.58}.step.is-drag-over{border-color:var(--step-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--step-color) 28%,transparent),0 14px 30px #1018281f}.step-message{--step-color: #c2410c}.step-collect{--step-color: #175cd3}.step-gate{--step-color: #b42318}.step-decision{--step-color: #6941c6}.step-check{--step-color: #0e7490}.step-include{--step-color: #16794c}.step .hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.step-title{display:flex;align-items:center;gap:8px;min-width:0}.drag-handle{width:22px;height:24px;border:1px solid var(--line-strong);border-radius:6px;display:inline-flex;align-items:center;justify-content:center;color:#667085;background:#fff;font-weight:800;letter-spacing:-2px;cursor:grab;-webkit-user-select:none;user-select:none;flex:0 0 auto}.drag-handle:active{cursor:grabbing}.step-number{background:#f2f4f7;color:#344054;border:1px solid #d0d5dd;border-radius:999px;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;flex:0 0 auto}.step-help{color:var(--muted);font-size:12px;line-height:1.35}.step-actions{display:flex;gap:6px;flex:0 0 auto}.badge{font-size:11px;font-weight:700;padding:3px 7px;border-radius:999px;color:#fff;text-transform:uppercase;letter-spacing:.02em}.b-message{background:#c2410c}.b-collect{background:#175cd3}.b-gate{background:#b42318}.b-decision{background:#6941c6}.b-check{background:#0e7490}.b-include{background:#16794c}.iconbtn{background:#fff;border-color:var(--line-strong);color:#344054;padding:5px 8px;font-size:12px}.iconbtn:hover{background:#f2f4f7}.ghost{background:#fff;border-color:var(--line-strong);color:#344054;padding:5px 9px;font-size:12px}.ghost:hover{background:#f2f4f7}.ghost.danger{color:var(--danger)}.add-step-panel{margin-top:14px;border:1px dashed #9fb8df;background:#f4f8fd;border-radius:8px;padding:12px;display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,42%);gap:12px;align-items:center}.add-step-copy strong{display:block;color:var(--ink);font-size:14px}.add-step-copy span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.add-step-controls{display:flex;gap:8px}.add-step-controls select{flex:1}.addbtn{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:8px;padding:8px 14px;font-size:13px}.addbtn:hover{background:var(--accent-dark);border-color:var(--accent-dark)}.addbtn.sm{padding:6px 11px}.secondary{background:#fff;border:1px solid var(--line-strong);color:#344054;padding:8px 12px}.tooldesc{font-size:12px;color:var(--muted);margin-top:5px;line-height:1.35}.group-preview{margin-top:8px;border:1px solid #d1fadf;background:#f6fef9;border-radius:8px;padding:9px}.group-preview ol{margin:8px 0 0 20px;padding:0;color:#344054;font-size:12px}.group-preview li{margin:3px 0}.hatch{border-top:1px solid var(--line);padding-top:10px;margin-bottom:10px}.hatch:first-of-type{border-top:none;padding-top:0}.checkrow{display:inline-flex;align-items:center;gap:7px;margin:2px 14px 8px 0;font-size:13px}.checkrow input{width:auto}.ready{border-radius:8px;padding:8px 10px;font-size:13px;font-weight:700;margin-bottom:10px}.ready.ok{background:#ecfdf3;color:var(--success);border:1px solid #abefc6}.ready.bad{background:#fff5f4;color:var(--danger);border:1px solid #fecdca}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.summary-grid div{background:var(--subtle);border:1px solid var(--line);border-radius:8px;padding:8px}.summary-grid span{display:block;color:var(--muted);font-size:11px}.summary-grid strong{display:block;margin-top:2px;font-size:13px;overflow-wrap:anywhere}.outline{margin:0;padding:0 0 0 18px;color:#344054;font-size:12px;line-height:1.45}.outline li{margin:4px 0;overflow-wrap:anywhere}pre{background:#101828;color:#d1fadf;padding:12px;border-radius:8px;overflow:auto;font-size:11.5px;max-height:62vh;margin:0}.journey-panel{position:sticky;top:12px;max-height:calc(100vh - 92px);overflow:auto}.journey-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.live-pill{border-radius:8px;padding:6px 10px;font-size:12px;font-weight:800;white-space:nowrap}.live-pill.on{background:#ecfdf3;color:var(--success);border:1px solid #abefc6}.live-pill.off{background:#f2f4f7;color:#475467;border:1px solid #d0d5dd}.journey-map{margin-top:14px;display:grid;gap:0}.map-node{display:grid;grid-template-columns:36px minmax(0,1fr);gap:10px;position:relative;padding-bottom:12px}.map-node:after{content:"";position:absolute;left:17px;top:36px;bottom:0;width:2px;background:#d0d5dd}.map-node:last-child:after{display:none}.map-icon{width:36px;height:36px;border-radius:8px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;z-index:1}.map-card{border:1px solid var(--line);background:#fbfcfe;border-radius:8px;padding:9px 10px;min-width:0}.map-type{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:800}.map-card strong{display:block;margin-top:3px;font-size:13px}.map-card p{margin:5px 0 0;color:#475467;font-size:12px;line-height:1.4;overflow-wrap:anywhere}.m-message{background:#475467}.m-collect{background:#175cd3}.m-gate{background:#b42318}.m-decision{background:#6941c6}.m-check{background:#0e7490}.m-include{background:#16794c}.empty-state{border:1px dashed var(--line-strong);color:var(--muted);background:#fbfcfe;border-radius:8px;padding:14px;font-size:13px}@media (max-width: 980px){header{align-items:flex-start;flex-direction:column}.header-actions{justify-content:flex-start}.wrap{flex-direction:column}.sidenav{position:static;flex:1 1 auto;width:100%;flex-direction:row;flex-wrap:wrap;gap:8px}.sidenav-links,.sidenav-foot{flex-direction:row;flex-wrap:wrap;border:none;padding:0}.nav-item{width:auto}.diff-grid,.edit-page{grid-template-columns:1fr}.count-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.control-row{grid-template-columns:1fr}.col.json{position:static}.journey-panel,.flow-list{position:static;max-height:none}.health{grid-template-columns:1fr}.status-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.wrap{padding:10px}.row{flex-direction:column;align-items:stretch}.row.end{align-items:stretch}.step .hd{flex-direction:column}.step-title{align-items:flex-start;flex-wrap:wrap}.step-actions{flex-wrap:wrap}.add-step-panel{grid-template-columns:1fr}.add-step-controls{flex-direction:column}.summary-grid,.count-grid{grid-template-columns:1fr}.control-head,.section-head,.selected-bar{flex-direction:column}.edit-actions{flex-wrap:wrap}}.toolparams{margin:6px 0 2px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.tp-label{font-size:12px;color:#57606a;font-weight:600}.tp-chip{font:12px/1.4 ui-monospace,SFMono-Regular,Menlo,monospace;background:#eef1f4;color:#444d56;border:1px solid #d0d7de;border-radius:6px;padding:1px 7px;cursor:help}.tp-chip.tp-req{background:#fff1e5;color:#9a4f00;border-color:#f0c39a;font-weight:600}.tp-hint{flex-basis:100%;font-size:11.5px;color:#6e7781;margin-top:3px}.bundle-band{border:1.5px dashed #b08cd6;border-radius:10px;background:#b08cd60f;padding:8px 8px 4px;margin:10px 0}.bundle-band-hd{display:flex;align-items:center;justify-content:space-between;padding:0 4px 6px}.bundle-band-title{font-size:12px;font-weight:700;color:#6f42c1;letter-spacing:.2px}.bundle-band .step{margin:6px 0}.bundle-select{color:#6f42c1;border-color:#d6c2ec;font-weight:600}.bundle-band.detected{border-style:dashed;border-color:#8aa9c9;background:#8aa9c90d}.bundle-band.detected .bundle-band-title{color:#3d6593;font-weight:600}.bundle-band-hd{cursor:pointer;-webkit-user-select:none;user-select:none}.bundle-band.collapsed{padding-bottom:8px}.band-chevron{display:inline-block;width:14px;color:#6f42c1;font-size:11px}.bundle-band.detected .band-chevron{color:#3d6593}.band-count{font-weight:500;color:#8b949e;font-size:11.5px}.band-preview{display:flex;flex-wrap:wrap;gap:5px;padding:2px 4px 2px 18px}.bp-chip{font:11px/1.5 ui-monospace,SFMono-Regular,Menlo,monospace;background:#fff;color:#57606a;border:1px solid #e1e4e8;border-radius:5px;padding:0 6px}.bundle-band-hd{display:flex;align-items:center;gap:8px}.bundle-band-hd .drag-handle{flex:0 0 auto}.bundle-band-title{flex:1;display:flex;align-items:center;gap:3px}.bundle-band.collapsed{padding:0}.bundle-band.collapsed .bundle-band-hd{padding:10px 12px}.bundle-band.open .bundle-band-hd{padding:4px 4px 8px}.bundle-band.is-drag-over{box-shadow:0 0 0 2px #6f42c1 inset}.tool-devname{font:11px/1.4 ui-monospace,SFMono-Regular,Menlo,monospace;color:#a0a8b0;margin-top:4px}.toolpicker{position:relative}.tp-trigger{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid #d0d7de;border-radius:8px;background:#fff;font-size:13px;cursor:pointer}.tp-trigger:hover{border-color:#b08cd6}.tp-placeholder{color:#8b949e}.tp-caret{color:#8b949e;font-size:11px}.tp-panel{z-index:1000;background:#fff;border:1px solid #d0d7de;border-radius:8px;box-shadow:0 10px 30px #0003;overflow:hidden}.tp-search{width:100%;border:none;border-bottom:1px solid #eaecef;padding:9px 11px;font-size:13px;outline:none}.tp-list{max-height:280px;overflow-y:auto;padding:4px 0}.tp-empty{padding:12px;color:#8b949e;font-size:12.5px}.tp-group-hd{padding:6px 11px 3px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#6f42c1;position:sticky;top:0;background:#fff}.tp-group-n{color:#b0b8c0;font-weight:500}.tp-opt{display:flex;align-items:baseline;gap:8px;width:100%;text-align:left;padding:6px 11px;border:none;background:none;cursor:pointer}.tp-opt:hover{background:#f3eefb}.tp-opt.sel{background:#efe7fb}.tp-opt-label{font-size:13px;color:#24292f}.tp-opt-dev{font:11px ui-monospace,SFMono-Regular,Menlo,monospace;color:#a0a8b0;margin-left:auto}.branch-badge{font-size:11px;font-weight:600;color:#9a5b00;background:#fff3e0;border:1px solid #f0c98a;border-radius:20px;padding:1px 9px;white-space:nowrap;cursor:help}.step.is-branch{border-left:3px solid #e9a23b}
