:root{--fw-bg:#0b0e14;--fw-surface-1:#13181f;--fw-surface-2:#1a2030;--fw-surface-3:#222a3c;--fw-border:#1e2a3a;--fw-border-strong:#2e3d52;--fw-ink:#f0f4f8;--fw-ink-muted:#8a99ac;--fw-ink-faint:#6b7a8d;--fw-accent:#3ecfff;--fw-accent-dim:#3ecfff1f;--fw-ok:#22c55e;--fw-warn:#f9cb42;--fw-danger:#e24b4a;--fw-danger-text:#f0716f;--fw-info:#4a9de2;--fw-special:#b08cf9;--fw-stream:#3ecfff;--fw-shift:#ffb454;--fw-load:#5ce0a1;--fw-accent-dim2:#3ecfff33;--fw-accent-soft:#3ecfff40;--fw-row-hover:#3ecfff0d;--fw-row-border:#1e2a3a80;--fw-font-ui:"DM Sans", system-ui, sans-serif;--fw-font-mono:"DM Mono", ui-monospace, monospace;--fw-text-display:22px;--fw-text-display-lh:28px;--fw-text-title:16px;--fw-text-title-lh:22px;--fw-text-body:14px;--fw-text-body-lh:20px;--fw-text-body-sm:13px;--fw-text-body-sm-lh:18px;--fw-text-caption:12px;--fw-text-caption-lh:16px;--fw-text-micro:11px;--fw-text-micro-lh:14px;--fw-text-overline:11px;--fw-text-overline-lh:14px;--fw-space-1:4px;--fw-space-2:8px;--fw-space-3:12px;--fw-space-4:16px;--fw-space-5:24px;--fw-space-6:32px;--fw-radius-sm:4px;--fw-radius-md:6px;--fw-radius-lg:8px;--fw-radius-pill:999px;--fw-shadow-menu:0 8px 24px #00000073;--fw-shadow-modal:0 12px 40px #0000008c;--fw-pulse:1.6s ease-out;--fw-fast:.12s ease;--fw-body:14px;--fw-body-lh:20px;--fw-row-h:36px;--fw-feed-row-h:34px;--fw-control-pad:6px 12px}:root[data-density=compact]{--fw-body:13px;--fw-body-lh:18px;--fw-row-h:28px;--fw-feed-row-h:28px;--fw-control-pad:4px 8px}:root[data-theme=light]{--fw-bg:#f2f5f9;--fw-surface-1:#fff;--fw-surface-2:#eaeff5;--fw-surface-3:#dee6ef;--fw-border:#d8e0ea;--fw-border-strong:#aebccc;--fw-ink:#18212e;--fw-ink-muted:#54657a;--fw-ink-faint:#8a99ac;--fw-accent:#0a6e8f;--fw-accent-dim:#0a6e8f1a;--fw-ok:#0e6f36;--fw-warn:#8a5c00;--fw-danger:#c73b34;--fw-danger-text:#b3362f;--fw-info:#1a63a8;--fw-special:#7140c8;--fw-stream:#0a6e8f;--fw-shift:#915408;--fw-load:#11713f;--fw-accent-dim2:#0a6e8f2e;--fw-accent-soft:#0a6e8f4d;--fw-row-hover:#0a6e8f0f;--fw-row-border:#aebccc80;--fw-shadow-menu:0 8px 24px #141e2d26;--fw-shadow-modal:0 12px 40px #141e2d38}:root{--bg:var(--fw-bg);--surface:var(--fw-surface-1);--surface-2:var(--fw-surface-2);--border:var(--fw-border);--text:var(--fw-ink);--muted:var(--fw-ink-muted);--accent:var(--fw-accent);--green:var(--fw-ok);--amber:var(--fw-warn);--red:var(--fw-danger);--cyan:var(--fw-accent);--font-ui:var(--fw-font-ui);--font-mono:var(--fw-font-mono)}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:var(--fw-body);line-height:var(--fw-body-lh);margin:0}#root{min-height:100vh}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.mono{font-family:var(--font-mono)}.muted{color:var(--muted)}.pad{padding:8px}.accent{color:var(--accent)}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex:none;align-items:center;gap:14px;padding:8px 16px;display:flex}.brand{letter-spacing:.02em;font-size:16px;font-weight:700}.org{font-family:var(--font-mono);color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:11px}.org-switcher{align-items:center;gap:2px;display:inline-flex;position:relative}.org-link{color:var(--text);cursor:pointer;text-decoration:none}.org-link:hover{border-color:var(--accent);color:var(--accent)}.org-caret{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;padding:3px 5px;font-size:11px}.org-caret:hover{border-color:var(--accent);color:var(--accent)}.org-menu{background:var(--surface);border:1px solid var(--border);z-index:40;border-radius:6px;min-width:220px;padding:4px;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 24px #00000073}.org-menu-item{cursor:pointer;border-radius:4px;justify-content:space-between;align-items:center;gap:10px;padding:6px 8px;font-size:12px;display:flex}.org-menu-item:hover{background:var(--surface-2)}.org-menu-active .org-menu-name{color:var(--accent);font-weight:600}.org-menu-id{font-size:12px}.tz-picker{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;padding:2px 7px;font-size:12px}.tz-picker:hover{border-color:var(--accent);color:var(--accent)}.pills{align-items:center;gap:2px;margin-left:8px;display:flex}.pill-link-wrap{align-items:center;gap:2px;display:inline-flex}.pill-link{color:var(--muted);padding:0 3px;font-size:12px}.pill{border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:default;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.pill-dot{background:var(--fw-ink-faint);border-radius:50%;flex:none;width:7px;height:7px}.pill-green{color:var(--text)}.pill-green .pill-dot{background:var(--green)}.pill-amber{color:var(--text)}.pill-amber .pill-dot{background:var(--amber)}.pill-red{color:var(--text);border-color:var(--red)}.pill-red .pill-dot{background:var(--red)}.pill-unknown .pill-dot{background:var(--fw-ink-faint)}.topbar-right{align-items:center;gap:12px;margin-left:auto;display:flex}.ws-state{letter-spacing:.06em;color:var(--muted);align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.ws-live .pill-dot{background:var(--green);animation:2s ease-in-out infinite blink}.ws-live{color:var(--green)}.ws-reconnecting{color:var(--amber)}.ws-reconnecting .pill-dot{background:var(--amber)}.ws-connecting .pill-dot{background:var(--fw-ink-faint)}@keyframes blink{50%{opacity:.4}}.latency{font-family:var(--font-mono);color:var(--accent);text-align:right;min-width:64px;font-size:12px}.kpis{background:var(--border);border-bottom:1px solid var(--border);flex:none;gap:1px;display:flex}.kpi{background:var(--surface);flex-direction:column;flex:1;gap:2px;padding:8px 16px;display:flex}.kpi-value{font-variant-numeric:tabular-nums;font-size:20px;font-weight:700;line-height:1.2}.kpi-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:12px}.kpi-spark{justify-content:flex-end;align-items:flex-start}.sparkline{display:block}.main{flex:1;min-height:0;display:flex;position:relative}.content{flex:1;min-width:0;padding:14px;overflow-y:auto}.livefeed{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex:none;width:320px;padding-bottom:6px;display:flex;overflow:hidden}.rail-head{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px 6px;display:flex}.rail-title{letter-spacing:.14em;color:var(--accent);font-size:11px;font-weight:700}.rail-dot{border-radius:50%;width:7px;height:7px}.rail-dot.ws-live{background:var(--green);animation:2s ease-in-out infinite blink}.rail-dot.ws-reconnecting{background:var(--amber)}.rail-dot.ws-connecting{background:var(--fw-ink-faint)}.rail-paused{color:var(--amber);letter-spacing:.04em;font-size:12px}.feed-empty{color:var(--muted);padding:16px 12px;font-size:12px}.feed-row{cursor:pointer;border-bottom:1px solid #1e2a3a80;align-items:center;gap:8px;min-height:30px;padding:5px 12px;display:flex}.feed-row:hover{background:var(--surface-2)}.feed-row.fresh{animation:1.6s ease-out flashpulse}@keyframes flashpulse{0%{background:#3ecfff38}to{background:0 0}}.feed-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;overflow:hidden}.feed-time{font-family:var(--font-mono);color:var(--muted);flex:none;font-size:12px}.replay-row .feed-label{color:var(--cyan)}.feed-gap,.feed-system{border-left:2px solid var(--amber);cursor:default;background:#f9cb4212}.gap-icon{color:var(--amber);flex:none}.gap-text{color:var(--amber);flex:1;font-size:11px}.entity-glyph{font-family:var(--font-mono);border:1px solid;border-radius:4px;flex:none;padding:1px 4px;font-size:12px;font-weight:500;line-height:1.4}.entity-glyph.lg{padding:3px 6px;font-size:12px}.badge{font-family:var(--font-mono);letter-spacing:.05em;border-radius:3px;flex:none;padding:2px 6px;font-size:11px;font-weight:500;line-height:1.4}.badge-create{color:var(--green);background:#22c55e1f}.badge-update{color:var(--amber);background:#f9cb421f}.badge-delete{color:var(--red);background:#e24b4a24}.badge-replay{color:var(--cyan);background:#3ecfff1f}.badge-gap{color:var(--amber);background:#f9cb4229}.badge-other{color:var(--muted);background:var(--surface-2)}.burst-pill{background:var(--surface-2);border-left:2px solid var(--accent);font-weight:600}.burst-pill.replay-row{border-left-color:var(--cyan)}.burst-arrow{color:var(--accent);flex:none;font-size:12px}.burst-count{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--accent);flex:none}.burst-caret{color:var(--muted);flex:none}.burst-rows{border-left:2px solid var(--border);margin-left:10px}.burst-rows .feed-row{padding-left:10px}.burst-more{color:var(--muted);padding:4px 12px;font-size:12px}.grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;display:grid}.card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.card:hover{border-color:var(--accent)}.card.pulse{animation:1.4s ease-out cardpulse}@keyframes cardpulse{0%{border-color:var(--entity-color,var(--accent));box-shadow:0 0 14px -2px var(--entity-color,var(--accent))}to{border-color:var(--border);box-shadow:none}}.card-head{align-items:center;gap:8px;display:flex}.card-name{flex:1;font-size:14px;font-weight:600}.card-count{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:18px;font-weight:500;animation:.35s ease-out tickup}@keyframes tickup{0%{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.card-foot{color:var(--muted);justify-content:space-between;font-size:12px;display:flex}.card-inactive{cursor:default;border-style:dashed}.card-inactive .card-name{color:var(--muted)}.card-empty{color:var(--muted);letter-spacing:.03em;padding:10px 0 14px;font-size:11px}.object-page{flex-direction:column;gap:12px;height:100%;display:flex}.object-head{align-items:center;gap:12px;display:flex}.object-head h2{margin:0;font-size:16px}.back-btn,.mini-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:12px;font-family:var(--font-ui);border-radius:5px;padding:5px 10px}.back-btn:hover,.mini-btn:hover{border-color:var(--accent)}.mini-btn{margin-left:auto;padding:2px 8px;font-size:12px}.mini-btn:disabled{opacity:.5;cursor:default}.link-btn{color:var(--accent);cursor:pointer;font:inherit;background:0 0;border:none;padding:0}.link-btn:hover{text-decoration:underline}.wf-table tr.row-selected{background:var(--surface-2)}.wf-table tr.row-selected td:first-child{box-shadow:inset 2px 0 0 var(--accent)}.wf-table tr.row-selected>td{border-bottom-color:#0000}.conn-table{width:100%}.conn-table>tbody>tr>td{overflow-wrap:anywhere}.conn-expander-row>td{background:var(--fw-surface-2);border-bottom:1px solid var(--fw-border);padding:0}.conn-detail{gap:var(--fw-space-4);padding:var(--fw-space-3) var(--fw-space-4) var(--fw-space-4);animation:conn-expand var(--fw-fast);white-space:normal;display:grid}@keyframes conn-expand{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.conn-detail-head{justify-content:space-between;align-items:baseline;gap:var(--fw-space-3);display:flex}.conn-detail-name{font-size:var(--fw-text-title);font-weight:600}.conn-detail-id{font-size:var(--fw-text-caption)}.conn-detail-cols{gap:var(--fw-space-5);grid-template-columns:minmax(220px,300px) minmax(0,1fr);align-items:start;display:grid}.conn-detail-meta{align-self:start}.conn-detail-tables{gap:var(--fw-space-5);grid-template-columns:repeat(auto-fit,minmax(min(100%,440px),1fr));align-items:start;min-width:0;display:grid}.conn-detail-panel{gap:var(--fw-space-3);align-content:start;min-width:0;display:grid}.conn-detail-field{gap:var(--fw-space-1);display:grid}.conn-detail-label{font-size:var(--fw-text-overline);letter-spacing:.05em;text-transform:uppercase;color:var(--fw-ink-muted);font-weight:600}.conn-detail-instance{font-size:var(--fw-text-caption);overflow-wrap:anywhere;white-space:normal}.conn-detail-line{font-size:var(--fw-text-body-sm)}.filter{color:var(--muted);font-size:12px}select{background:var(--surface-2);color:var(--text);border:1px solid var(--border);font-family:var(--font-ui);border-radius:5px;padding:4px 8px;font-size:12px}.count{color:var(--muted);margin-left:auto;font-size:11px}.table-wrap{border:1px solid var(--border);border-radius:8px;overflow-y:auto}table{border-collapse:collapse;background:var(--surface);width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:1px solid var(--border);background:var(--surface);z-index:1;padding:8px 12px;font-size:12px;position:sticky;top:0}td{white-space:nowrap;border-bottom:1px solid #1e2a3a80;padding:6px 12px;font-size:12px}td.fields{text-overflow:ellipsis;max-width:320px;color:var(--muted);overflow:hidden}tbody tr{cursor:pointer}tbody tr:hover{background:var(--surface-2)}.empty{color:var(--muted);text-align:center;padding:32px}.drawer{background:var(--surface);border-left:1px solid var(--border);z-index:10;flex-direction:column;width:440px;max-width:90vw;display:flex;position:absolute;top:0;bottom:0;right:0;box-shadow:-12px 0 28px #00000073}.drawer-head{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 14px;display:flex}.drawer-title{flex:1;min-width:0}.drawer-title h2{text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:14px;overflow:hidden}.drawer-title .mono{font-size:12px}.close-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:20px}.close-btn:hover{color:var(--text)}.drawer-meta{border-bottom:1px solid var(--border);margin:0;padding:10px 14px}.kv{grid-template-columns:110px 1fr;gap:4px 10px;font-size:12px;display:grid}.kv dt{color:var(--muted);text-overflow:ellipsis;overflow:hidden}.kv dd{word-break:break-all;margin:0}.replay-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-ui);background:#3ecfff1a;border-radius:6px;margin:10px 14px 0;padding:7px}.replay-btn:hover:not(:disabled){background:#3ecfff33}.replay-btn:disabled{opacity:.45;cursor:default}.drawer-body{flex:1;padding:12px 14px;overflow-y:auto}.tl-event{border:1px solid var(--border);background:var(--surface-2);border-radius:7px;margin-bottom:10px;padding:9px 11px}.tl-event.fresh{animation:1.6s ease-out flashpulse}.tl-head{align-items:center;gap:8px;margin-bottom:7px;font-size:11px;display:flex}.tl-id{font-size:12px}.diff{grid-template-columns:130px 1fr;margin:0 0 6px}.diff dd{font-family:var(--font-mono);font-size:11px}.diff-old{color:var(--muted);text-decoration:line-through}.diff-arrow{color:var(--muted)}.diff-new{color:var(--text)}.raw summary{cursor:pointer;color:var(--muted);letter-spacing:.04em;font-size:12px}.raw summary:hover{color:var(--accent)}.raw pre{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);border-radius:5px;max-height:260px;padding:8px;font-size:12px;overflow-x:auto}.kafka-coords{color:var(--accent);padding:6px 0 2px;font-size:12px}.echo-row{opacity:.45}.echo-row:hover{opacity:.85}.echo-icon{color:var(--muted);flex-shrink:0;font-size:12px}.echo-chip{font-family:var(--font-mono);color:var(--muted);border:1px solid var(--border);white-space:nowrap;border-radius:3px;margin-left:6px;padding:1px 5px;font-size:12px}.push-form{border:1px solid var(--border);background:var(--surface-2);border-radius:7px;margin:10px 14px 0;padding:8px 11px;font-size:12px}.push-form summary{cursor:pointer;color:var(--accent);letter-spacing:.02em;font-size:11px;font-weight:600}.push-form summary:hover{color:var(--text)}.push-row{gap:6px;margin-top:8px;display:flex}.push-row input{background:var(--bg);border:1px solid var(--border);min-width:0;color:var(--text);border-radius:5px;flex:1;padding:5px 7px;font-size:11px}.push-row input:focus{border-color:var(--accent);outline:none}.push-row .mini-btn{margin-left:0}.push-actions{align-items:center;gap:8px;margin-top:8px;display:flex}.push-actions .mini-btn{margin-left:0}.push-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-ui);background:#3ecfff1a;border-radius:5px;margin-left:auto;padding:4px 12px}.push-btn:hover:not(:disabled){background:#3ecfff33}.push-btn:disabled{opacity:.45;cursor:default}.push-hint{margin-top:8px;font-size:12px}.push-hint .mono{font-size:12px}.modal-backdrop{z-index:90;background:#0b0e14b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;width:380px;padding:18px 20px;box-shadow:0 10px 34px #0009}.modal h3{margin:0 0 8px;font-size:14px}.modal p{color:var(--muted);margin:0;font-size:12px;line-height:1.5}.modal p strong{color:var(--text);font-weight:600}.modal p .mono{font-size:11px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.toast{background:var(--surface-2);border:1px solid var(--accent);color:var(--text);z-index:100;border-radius:7px;padding:9px 18px;font-size:12px;position:fixed;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 6px 22px #00000080}.toast.error{border-color:var(--red)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}::-webkit-scrollbar-track{background:0 0}.topbar-nav{gap:2px;margin-left:12px;display:flex}.nav-tab{color:var(--muted);font-family:var(--font-ui);letter-spacing:.04em;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;padding:4px 12px;font-size:12px;font-weight:600;transition:color .15s,border-color .15s}.nav-tab:hover{color:var(--text);border-color:var(--border)}.nav-tab-active{color:var(--accent);border-color:var(--accent);background:#3ecfff12}.mapper-main{flex:1;overflow:hidden}.mapper-view{flex-direction:column;height:100%;display:flex;overflow:hidden}.pipeline-list{flex-direction:column;gap:12px;height:100%;padding:16px;display:flex;overflow-y:auto}.pipeline-list-head{align-items:center;gap:10px;display:flex}.pipeline-list-empty,.pipeline-empty-title{height:100%;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:14px;display:flex}.pipeline-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;display:grid}.pipeline-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.pipeline-card:hover{border-color:var(--accent)}.pipeline-card-head{align-items:center;gap:8px;display:flex}.pipeline-card-name{flex:1;font-size:14px;font-weight:600}.status-dot{background:var(--fw-ink-faint);border-radius:50%;flex:none;width:8px;height:8px}.status-dot.status-on{background:var(--green)}.pipeline-card-meta,.pipeline-card-steps{color:var(--muted);font-size:12px}.pipeline-card-meta .mono{color:var(--text)}.pipeline-card-steps .mono{color:var(--accent)}.pipeline-card-actions{opacity:0;gap:6px;margin-top:4px;transition:opacity .12s;display:flex}.pipeline-card:hover .pipeline-card-actions{opacity:1}.pipeline-card-actions .mini-btn{margin-left:0}.delete-mini-btn:hover{border-color:var(--red);color:var(--red)}.mapper-editor{flex-direction:column;height:100%;display:flex;overflow:hidden}.mapper-editor-head{background:var(--surface);border-bottom:1px solid var(--border);flex:none;align-items:center;gap:12px;padding:8px 14px;display:flex}.pipeline-header{flex-wrap:wrap;flex:1;align-items:center;gap:12px;min-width:0;display:flex}.pipeline-header-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.pipeline-name{cursor:pointer;border-bottom:1px dashed #0000;font-size:14px;font-weight:700}.pipeline-name:hover{border-bottom-color:var(--accent);color:var(--accent)}.pipeline-name-input{background:var(--bg);border:1px solid var(--accent);color:var(--text);font-size:14px;font-weight:700;font-family:var(--font-ui);border-radius:5px;padding:3px 8px}.pipeline-name-input:focus{outline:none}.pipeline-meta-badge{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:2px 8px;font-size:11px}.pipeline-arrow{font-size:12px}.pipeline-steps{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.step-chip{align-items:center;gap:3px;font-size:12px;display:inline-flex}.step-sep{font-size:11px}.pipeline-header-right{align-items:center;gap:8px;margin-left:auto;display:flex}.toggle-label{cursor:pointer;align-items:center;gap:6px;font-size:12px;display:inline-flex}.toggle-btn{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;border-radius:999px;width:34px;height:18px;padding:0;transition:background .2s,border-color .2s;position:relative}.toggle-btn.toggle-on{border-color:var(--accent);background:#3ecfff2e}.toggle-btn:disabled{opacity:.5;cursor:default}.toggle-knob{background:var(--fw-ink-faint);border-radius:50%;width:12px;height:12px;transition:transform .2s,background .2s;position:absolute;top:2px;left:2px}.toggle-btn.toggle-on .toggle-knob{background:var(--accent);transform:translate(16px)}.mapper-panes{flex:1;min-height:0;display:flex;overflow:hidden}.pane{border-right:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.pane:last-child{border-right:none}.src-pane{flex:none;width:240px}.dest-pane{border-left:1px solid var(--border);border-right:none;flex:none;width:220px}.pane-head{border-bottom:1px solid var(--border);flex:none;align-items:center;gap:8px;padding:8px 12px 6px;display:flex}.pane-title{letter-spacing:.12em;text-transform:uppercase;font-size:11px;font-weight:700}.pane-entity{color:var(--muted);font-size:11px}.pane-search{border-bottom:1px solid var(--border);flex:none;padding:6px 8px}.search-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:5px;padding:4px 7px;font-size:11px}.search-input:focus{border-color:var(--accent);outline:none}.pane-body{flex:1;overflow-y:auto}.pane-empty{color:var(--muted);padding:14px 12px;font-size:12px}.dest-step-tabs{border-bottom:1px solid var(--border);background:var(--border);flex:none;gap:1px;display:flex}.step-tab{background:var(--surface);color:var(--muted);font-family:var(--font-ui);cursor:pointer;border:none;flex:1;padding:5px 4px;font-size:11px;font-weight:600}.step-tab:hover{color:var(--text)}.step-tab-active{color:var(--accent);background:var(--surface-2)}.field-row{cursor:pointer;border-bottom:1px solid #1e2a3a66;align-items:center;gap:6px;min-height:28px;padding:5px 10px;display:flex}.field-row:hover{background:var(--surface-2)}.field-row.field-armed{background:#3ecfff1a}.field-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:11px;overflow:hidden}.field-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;overflow:hidden}.pane-rel-divider{color:var(--accent);letter-spacing:.06em;border-top:1px solid var(--border);text-transform:uppercase;margin-top:2px;padding:4px 10px 2px;font-size:12px}.type-badge{font-family:var(--font-mono);white-space:nowrap;opacity:.85;border:1px solid;border-radius:3px;flex:none;padding:1px 4px;font-size:11px;font-weight:500;line-height:1.4}.mapping-center{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.mapping-head{border-bottom:1px solid var(--border);flex:none;align-items:center;gap:8px;padding:8px 12px 6px;display:flex}.arm-hint{border-bottom:1px solid var(--border);background:#3ecfff0f;flex:none;padding:6px 12px;font-size:11px}.mapping-list{flex:1;overflow-y:auto}.mapping-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;height:100%;padding:32px;display:flex}.mapping-empty-title{color:var(--muted);font-size:14px;font-weight:600}.mapping-empty-hint{color:var(--muted);max-width:260px;font-size:12px;line-height:1.5}.mapping-row{border-bottom:1px solid #1e2a3a80;grid-template-columns:1fr auto 1fr auto auto;align-items:center;gap:8px;padding:7px 10px;font-size:12px;display:grid}.mapping-row.mapping-row-warn{border-left:2px solid var(--amber)}.mapping-row-warn{grid-template-rows:auto auto}.mapping-warn-msg{color:var(--amber);grid-column:1/-1;padding-top:2px;font-size:12px}.mapping-src,.mapping-dest{align-items:center;gap:5px;min-width:0;display:flex;overflow:hidden}.mapping-path{text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.mapping-dest-obj{font-size:12px}.mapping-arrow{color:var(--muted);flex:none;font-size:12px}.mapping-transform{align-items:flex-start;gap:4px;display:flex}.transform-editor{flex-wrap:wrap;align-items:flex-start;gap:4px;display:flex}.transform-select{background:var(--surface-2);color:var(--text);border:1px solid var(--border);font-family:var(--font-mono);border-radius:4px;padding:2px 5px;font-size:12px}.transform-input{background:var(--bg);color:var(--text);border:1px solid var(--border);font-size:11px;font-family:var(--font-ui);border-radius:4px;width:100px;min-width:0;padding:2px 6px}.transform-input:focus{border-color:var(--accent);outline:none}.concat-editor{flex-direction:column;gap:4px;display:flex}.concat-parts{flex-direction:column;gap:3px;display:flex}.concat-part{align-items:center;gap:3px;display:flex}.concat-kind{background:var(--surface-2);color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:2px 4px;font-size:12px}.concat-footer{align-items:center;gap:8px;display:flex}.concat-sep-label{color:var(--muted);align-items:center;gap:4px;font-size:12px;display:flex}.sep-input{width:40px}.icon-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;flex:none;padding:0 3px;font-size:16px;line-height:1}.icon-btn:hover{color:var(--text)}.delete-btn:hover{color:var(--red)}.error-text{color:var(--fw-danger-text)}.trigger-row{border-left:2px solid var(--amber);background:#f9cb420a}.trigger-row:hover{background:#f9cb421a}.trigger-glyph{color:var(--amber);flex:none;font-size:14px}.cond-builder{border-bottom:1px solid var(--border);background:var(--surface);flex:none;padding:6px 12px 8px}.cond-head{align-items:center;gap:8px;padding-bottom:6px;display:flex}.cond-logic{letter-spacing:.1em;text-transform:uppercase;font-size:11px}.cond-add-btn{margin-right:auto}.cond-empty{padding:2px 0;font-size:11px}.cond-rows{flex-direction:column;gap:4px;display:flex}.cond-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.cond-num{font-family:var(--font-mono);min-width:14px;font-size:12px}.cond-select{background:var(--surface-2);color:var(--text);border:1px solid var(--border);font-size:11px;font-family:var(--font-ui);border-radius:4px;padding:3px 6px}.cond-select:focus{border-color:var(--accent);outline:none}.cond-field-select{min-width:160px}.cond-op-select{min-width:100px}.cond-val-select{min-width:130px}.cond-val-input{background:var(--bg);color:var(--text);border:1px solid var(--border);font-size:11px;font-family:var(--font-ui);border-radius:4px;min-width:120px;padding:3px 7px}.cond-val-input:focus{border-color:var(--accent);outline:none}.cond-no-val{min-width:80px;font-size:12px}.cond-more-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;padding:2px 6px;font-size:12px}.cond-more-btn:hover{color:var(--text);border-color:var(--accent)}.test-pipeline-btn{color:var(--amber);border-color:var(--amber)}.test-pipeline-btn:hover{background:#f9cb421a}.test-modal{flex-direction:column;width:720px;max-width:95vw;max-height:80vh;display:flex}.test-modal-head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.test-modal-head h3{flex:1;margin:0;font-size:14px}.test-search-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.test-search-input{flex:1}.test-search-hint{flex:none;font-size:11px}.test-results{border:1px solid var(--border);border-radius:6px;max-height:160px;margin-bottom:8px;overflow-y:auto}.test-result-row{cursor:pointer;border-bottom:1px solid #1e2a3a66;align-items:center;gap:10px;padding:6px 10px;display:flex}.test-result-row:hover{background:var(--surface-2)}.test-result-id{color:var(--muted);min-width:120px;font-size:12px}.test-result-name{flex:1;font-size:12px}.test-result-view{max-height:400px;margin-top:10px;overflow-y:auto}.test-result-head{margin-bottom:10px;font-size:12px}.test-record-name{font-weight:600}.test-step{border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden}.test-step-head{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:7px 10px;font-size:12px;display:flex}.test-step-from{font-size:11px}.test-step-body{background:var(--border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.test-col{background:var(--surface-2);padding:8px 10px}.test-col-head{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;font-size:11px}.test-src-row{align-items:baseline;gap:6px;padding:2px 0;font-size:11px;display:flex}.test-src-key{text-overflow:ellipsis;white-space:nowrap;min-width:100px;font-size:12px;overflow:hidden}.test-src-val{word-break:break-all;font-size:11px}.te-step-err-badge{color:var(--red);background:#e24b4a24;border-radius:3px;padding:1px 5px;font-size:12px}.te-detail{flex-direction:column;height:100%;display:flex}.te-detail-head{border-bottom:1px solid var(--border);flex:none;align-items:center;gap:10px;padding:10px 14px;display:flex}.te-detail-title{flex:1;font-size:14px;font-weight:600}.te-status-badge{font-family:var(--font-mono);border:1px solid;border-radius:3px;padding:2px 6px;font-size:12px}.te-detail-body{flex:1;padding:14px;overflow-y:auto}.te-meta{margin-bottom:14px}.te-section-head{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:14px 0 6px;font-size:11px}.te-error-block{background:#e24b4a14;border:1px solid #e24b4a4d;border-radius:6px;margin-bottom:12px;padding:8px 10px}.te-error-label{color:var(--fw-danger-text);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:11px}.te-error-pre{font-family:var(--font-mono);color:var(--fw-danger-text);white-space:pre-wrap;word-break:break-word;margin:0;font-size:11px}.te-steps{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.te-step{border:1px solid var(--border);background:var(--surface-2);border-radius:6px;padding:8px 10px}.te-step.te-step-fail{border-color:#e24b4a66}.te-step-head{align-items:center;gap:8px;margin-bottom:6px;font-size:12px;display:flex}.te-step-num{font-size:12px}.te-step-obj{font-weight:600}.te-step-action,.te-step-ext{font-size:12px}.te-step-error{color:var(--fw-danger-text);white-space:pre-wrap;word-break:break-word;margin-top:4px;font-size:12px}.te-json-block{margin-top:6px}.te-redispatch-row{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px;padding-top:14px;display:flex}.dlq-view{flex-direction:column;height:100%;padding:16px;display:flex}.dlq-head{align-items:center;gap:10px;margin-bottom:14px;display:flex}.dlq-subtitle{flex:1;font-size:11px}.dlq-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:200px;display:flex}.dlq-empty-icon{color:var(--green);font-size:28px}.dlq-empty-title{font-size:14px;font-weight:600}.dlq-list{flex-direction:column;gap:10px;display:flex;overflow-y:auto}.dlq-row{border:1px solid var(--border);background:var(--surface);border-left:3px solid var(--red);border-radius:7px;padding:10px 12px}.dlq-row-head{align-items:center;gap:8px;margin-bottom:6px;font-size:11px;display:flex}.dlq-offset{flex:1;font-size:12px}.dlq-meta{margin-bottom:4px;font-size:12px}.dlq-step{margin-bottom:8px;font-size:11px}.dlq-error{margin-bottom:8px}.dlq-error-label{text-transform:uppercase;letter-spacing:.08em;color:var(--fw-danger-text);margin-bottom:3px;font-size:11px}.dlq-error-pre{font-family:var(--font-mono);color:var(--fw-danger-text);white-space:pre-wrap;word-break:break-word;background:#e24b4a12;border:1px solid #e24b4a33;border-radius:4px;max-height:100px;margin:0;padding:6px 8px;font-size:11px;overflow-y:auto}.dlq-actions{align-items:center;gap:10px;display:flex}.dlq-retry-btn{padding:5px 12px;font-size:11px}.dlq-row-resolved{border-left-color:var(--green);opacity:.8}.dlq-resolved-badge{color:var(--green);background:#22c55e1f;border:1px solid #22c55e4d;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:12px;font-weight:600}.dlq-kind{letter-spacing:.06em;text-transform:uppercase;border:1px solid;border-radius:4px;flex:none;padding:1px 6px;font-size:11px;font-weight:700}.dlq-actions .push-btn{margin-left:0}.fail-panel{background:#e24b4a0d;border:1px solid #e24b4a59;border-radius:7px;margin:10px 0;padding:10px 12px}.fail-panel-head{align-items:center;gap:10px;font-size:11px;display:flex}.fail-attempts{margin-left:auto;font-size:12px}.fail-hint{margin-top:4px;font-size:12px}.fail-sub-head{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:10px;font-size:12px;font-weight:700}.fail-table{border-collapse:collapse;width:100%;margin-top:6px;font-size:11px}.fail-table th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);padding:3px 8px 3px 0;font-size:11px;font-weight:600}.fail-table td{vertical-align:top;word-break:break-word;border-bottom:1px solid #1e2a3a80;padding:4px 8px 4px 0}.fail-offending td{background:#e24b4a17}.fail-offending td:first-child{color:var(--fw-danger-text);font-weight:600}.fail-flag{font-size:12px}.fail-fix-row{align-items:center;gap:10px;margin-top:10px;display:flex}.fail-fix-row .push-btn{margin-left:0}.fix-pushed-banner{color:var(--green);background:#22c55e14;border:1px solid #22c55e4d;border-radius:5px;margin-top:10px;padding:7px 10px;font-size:11px}.cond-warning{color:var(--amber);background:#f9cb4212;border:1px solid #f9cb4259;border-radius:5px;margin:10px 0;padding:7px 10px;font-size:11px;line-height:1.5}.modal-overlay{z-index:60;background:#04060ab8;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-modal,.fix-modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;width:min(560px,92vw);max-height:80vh;padding:14px 16px;overflow:auto;box-shadow:0 12px 40px #0000008c}.confirm-title{letter-spacing:.04em;text-transform:uppercase;color:var(--accent);font-size:12px;font-weight:700}.confirm-target{margin-top:4px;font-size:11px}.confirm-table{border-collapse:collapse;width:100%;margin-top:10px;font-size:11px}.confirm-table th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);padding:3px 8px 3px 0;font-size:11px;font-weight:600}.confirm-table td{font-family:var(--font-mono);word-break:break-word;border-bottom:1px solid #1e2a3a80;padding:5px 8px 5px 0}.confirm-note{margin-top:8px;font-size:12px}.confirm-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.confirm-actions .mini-btn,.confirm-actions .push-btn{margin-left:0}.push-form-bare{background:0 0;border:none;margin:8px 0 0;padding:0}.retry-primary{background:#3ecfff29;font-weight:700}.wf-status{letter-spacing:.04em;text-transform:uppercase;border:1px solid;border-radius:3px;padding:1px 6px;font-size:12px;font-weight:700}.wf-table{border-collapse:collapse;width:100%;font-size:12px}.wf-table th{text-align:left;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);padding:4px 10px 4px 0;font-size:11px;font-weight:600}.wf-table td{border-bottom:1px solid #1e2a3a80;padding:7px 10px 7px 0}.wf-row{cursor:pointer}.wf-row:hover td{background:#3ecfff0d}.wf-detail-grid{grid-template-columns:110px 1fr;gap:6px 12px;margin:12px 0;font-size:12px;display:grid}.wf-section{margin-top:12px}.wf-approvers{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.wf-approver-chip{background:#0a1018b3;border:1px solid;border-radius:12px;padding:2px 9px;font-size:11px}.wf-struck{opacity:.8;text-decoration:line-through}.wf-audit{border-collapse:collapse;width:100%;margin-top:6px;font-size:11px}.wf-audit td{vertical-align:top;border-bottom:1px solid #1e2a3a80;padding:4px 10px 4px 0}.wf-audit-ts{white-space:nowrap;width:70px}.wf-audit-event{white-space:nowrap;width:140px;color:var(--accent)}.wf-audit-detail{word-break:break-word}.wf-context{margin-top:12px}.wf-context-pre{border:1px solid var(--border);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;background:#0a1018b3;border-radius:4px;max-height:420px;margin:6px 0 0;padding:10px;font-size:11px;line-height:1.5;overflow:auto}.validation-panel{border:1px solid var(--border);background:var(--surface);border-radius:6px;margin:0 14px 10px;padding:8px 12px;font-size:12px}.validation-panel.validation-clean{align-items:baseline;gap:10px;display:flex}.validation-panel.validation-has-error{border-left:3px solid var(--red)}.validation-panel.validation-has-warn{border-left:3px solid var(--amber)}.validation-ok{color:var(--green);font-weight:600}.validation-summary{align-items:baseline;gap:12px;margin-bottom:6px;display:flex}.validation-count-err{color:var(--fw-danger-text);font-weight:600}.validation-count-warn{color:var(--amber);font-weight:600}.validation-gate-hint{font-size:11px}.validation-issues{flex-direction:column;gap:3px;display:flex}.validation-issue{align-items:baseline;gap:8px;padding:2px 0;display:flex}.validation-dot{border-radius:50%;flex:none;align-self:center;width:6px;height:6px}.validation-dot-error{background:var(--red)}.validation-dot-warn{background:var(--amber)}.validation-target{color:var(--text);flex:none}.validation-msg{color:var(--muted)}.preview-note{border-bottom:1px solid #1e2a3a80;margin-bottom:8px;padding:4px 0 10px;font-size:11px}@media (prefers-reduced-motion:reduce){.feed-row.fresh,.tl-event.fresh,.card.pulse,.ws-live .pill-dot,.rail-dot.ws-live{animation:none}}.shell{grid-template-rows:48px 1fr;grid-template-columns:216px 1fr;height:100vh;display:grid;overflow:hidden}svg.ic{fill:none;stroke:currentColor;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex:none;width:16px;height:16px}.shell .topbar{align-items:center;gap:var(--fw-space-4);padding:0 var(--fw-space-4);background:var(--fw-surface-1);border-bottom:1px solid var(--fw-border);grid-column:1/3;display:flex}.shell .brand{width:184px;color:var(--fw-accent);align-items:center;gap:10px;font-weight:700;display:flex}.brand-word{font-size:var(--fw-text-title);letter-spacing:.14em;color:var(--fw-ink);font-weight:700}.org-filter{display:inline-flex;position:relative}.shell .org{align-items:center;gap:var(--fw-space-2);background:var(--fw-surface-2);border:1px solid var(--fw-border);border-radius:var(--fw-radius-md);padding:var(--fw-control-pad);font-size:var(--fw-body);color:var(--fw-ink);cursor:pointer;font-family:var(--fw-font-ui);display:inline-flex}.shell .org:hover{border-color:var(--fw-accent)}.org .caret{color:var(--fw-ink-muted);font-size:11px}.org-label{letter-spacing:.08em;text-transform:uppercase;color:var(--fw-ink-muted);font-size:11px;font-weight:600;line-height:14px}.shell .org.org-all{background:var(--fw-accent);border-color:var(--fw-accent);color:var(--fw-bg);font-weight:700}.org.org-all .org-label,.org.org-all .caret{color:var(--fw-bg);opacity:.75}.org-menu-item{text-align:left;width:100%;font-family:var(--fw-font-ui);color:var(--fw-ink);background:0 0;border:none}.org-menu-rule{border-top:1px solid var(--fw-border);margin:4px 2px}.shell .topbar-right{align-items:center;gap:var(--fw-space-2);margin-left:auto;display:flex}.iconbtn{border:1px solid var(--fw-border);border-radius:var(--fw-radius-md);width:28px;height:28px;color:var(--fw-ink-muted);cursor:pointer;background:0 0;place-items:center;padding:0;display:grid}.iconbtn:hover{border-color:var(--fw-accent);color:var(--fw-accent)}.statusdot{border-radius:var(--fw-radius-md);cursor:pointer;background:0 0;border:none;place-items:center;width:28px;height:28px;padding:0;display:grid}.statusdot:hover{background:var(--fw-surface-2)}.statusdot .sd{background:var(--fw-ok);border-radius:50%;width:10px;height:10px;animation:2.4s ease-in-out infinite breathe}.statusdot .sd.sd-warn{background:var(--fw-warn);animation:none}.statusdot .sd.sd-danger{background:var(--fw-danger);animation:none}@keyframes breathe{50%{opacity:.45}}@media (prefers-reduced-motion:reduce){.statusdot .sd{animation:none}}.rail{background:var(--fw-surface-1);border-right:1px solid var(--fw-border);padding:var(--fw-space-4) var(--fw-space-3);gap:var(--fw-space-2);flex-direction:column;grid-area:2/1;display:flex;overflow-y:auto}.rail-section{letter-spacing:.08em;text-transform:uppercase;color:var(--fw-ink-muted);padding:var(--fw-space-2) var(--fw-space-2) var(--fw-space-1);font-size:11px;font-weight:600;line-height:14px}.rail-link{border-radius:var(--fw-radius-md);color:var(--fw-ink);font-size:var(--fw-body);border:1px solid #0000;align-items:center;gap:10px;padding:7px 10px;text-decoration:none;display:flex}.rail-link:hover{background:var(--fw-surface-2)}.rail-link[aria-current=page]{background:var(--fw-accent-dim);color:var(--fw-accent);border-color:var(--fw-accent-soft)}.rail-link .ic{color:var(--fw-ink-faint)}.rail-link[aria-current=page] .ic{color:var(--fw-accent)}.rail-rule{border:none;border-top:1px solid var(--fw-border);margin:var(--fw-space-2) var(--fw-space-1);width:auto}.switcher{background:var(--fw-border);border:1px solid var(--fw-border);border-radius:var(--fw-radius-md);margin:0 var(--fw-space-1);grid-template-columns:1fr 1fr 1fr;gap:2px;display:grid;overflow:hidden}.switcher button{background:var(--fw-surface-1);color:var(--fw-ink-muted);font-family:var(--fw-font-ui);cursor:pointer;border:none;padding:7px 0;font-size:12px;font-weight:600}.switcher button:hover{color:var(--fw-ink);background:var(--fw-surface-2)}.switcher button[aria-pressed=true]{background:var(--fw-surface-3)}.switcher button[data-product=stream][aria-pressed=true]{color:var(--fw-stream);box-shadow:inset 0 -2px 0 var(--fw-stream)}.switcher button[data-product=shift][aria-pressed=true]{color:var(--fw-shift);box-shadow:inset 0 -2px 0 var(--fw-shift)}.switcher button[data-product=load][aria-pressed=true]{color:var(--fw-load);box-shadow:inset 0 -2px 0 var(--fw-load)}.rail-foot-note{padding:var(--fw-space-2) var(--fw-space-3);color:var(--fw-ink-muted);font-size:var(--fw-text-caption);line-height:var(--fw-text-caption-lh);font-style:italic}.rail-foot{padding:var(--fw-space-2);color:var(--fw-ink-faint);letter-spacing:.04em;margin-top:auto;font-size:11px;line-height:14px}.shell-canvas{background:var(--fw-bg);flex-direction:column;grid-area:2/2;min-width:0;min-height:0;display:flex;overflow:hidden}.activity-main .livefeed{border-right:none;flex:1;width:auto}.canvas-pad{padding:var(--fw-space-5);flex:1;overflow-y:auto}.page-head{align-items:baseline;gap:var(--fw-space-3);margin-bottom:var(--fw-space-2);display:flex}.page-title{font-size:var(--fw-text-display);line-height:var(--fw-text-display-lh);margin:0;font-weight:600}.page-sub{color:var(--fw-ink-muted);font-size:var(--fw-body)}.placeholder-card{max-width:720px}.placeholder-card p{margin:0 0 var(--fw-space-3)}.placeholder-badge{margin-bottom:var(--fw-space-3);letter-spacing:.08em;text-transform:uppercase;color:var(--fw-special);border:1px solid color-mix(in srgb, var(--fw-special) 45%, transparent);border-radius:var(--fw-radius-sm);padding:2px 8px;font-size:11px;font-weight:600;line-height:14px;display:inline-block}.placeholder-actions{align-items:center;gap:var(--fw-space-3);margin-top:var(--fw-space-2);flex-wrap:wrap;display:flex}.btn{background:var(--fw-surface-2);border:1px solid var(--fw-border);color:var(--fw-ink);border-radius:var(--fw-radius-md);padding:var(--fw-control-pad);font-size:var(--fw-body);font-family:var(--fw-font-ui);cursor:pointer}.btn:hover{border-color:var(--fw-accent)}.btn-primary{background:var(--fw-accent-dim);border-color:var(--fw-accent);color:var(--fw-accent);font-weight:600}.btn-primary:hover{background:var(--fw-accent-dim2)}.login-page{background:var(--fw-bg);padding:var(--fw-space-4);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-card{gap:var(--fw-space-3);width:100%;max-width:360px;padding:var(--fw-space-6);background:var(--fw-surface-1);border:1px solid var(--fw-border);border-radius:var(--fw-radius-lg);box-shadow:var(--fw-shadow-modal);flex-direction:column;display:flex}.login-brand{align-items:center;gap:var(--fw-space-2);color:var(--fw-accent);display:flex}.login-word{letter-spacing:.04em;color:var(--fw-ink);font-size:20px;font-weight:700}.login-sub{margin:0 0 var(--fw-space-2);color:var(--fw-ink-muted);font-size:var(--fw-text-body-sm)}.login-field{gap:var(--fw-space-1);flex-direction:column;display:flex}.login-label{font-size:var(--fw-text-overline);letter-spacing:.05em;text-transform:uppercase;color:var(--fw-ink-muted)}.login-input{background:var(--fw-surface-2);border:1px solid var(--fw-border);color:var(--fw-ink);border-radius:var(--fw-radius-md);font-size:var(--fw-text-body);font-family:var(--fw-font-ui);padding:8px 12px}.login-input:focus{border-color:var(--fw-accent);background:var(--fw-surface-3);outline:none}.login-error{background:color-mix(in srgb, var(--fw-danger) 12%, transparent);border:1px solid color-mix(in srgb, var(--fw-danger) 45%, transparent);color:var(--fw-danger-text);font-size:var(--fw-text-body-sm);border-radius:var(--fw-radius-sm);padding:6px 10px}.login-submit{margin-top:var(--fw-space-2);justify-content:center;padding:9px 12px}.login-submit:disabled{opacity:.6;cursor:default}.login-foot{margin:var(--fw-space-2) 0 0;text-align:center;font-size:var(--fw-text-caption);color:var(--fw-ink-faint)}.usermenu{display:inline-flex;position:relative}.usermenu-btn{border-radius:var(--fw-radius-pill);background:var(--fw-surface-2);border:1px solid var(--fw-border-strong);width:26px;height:26px;color:var(--fw-ink);cursor:pointer;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex}.usermenu-btn:hover{border-color:var(--fw-accent);color:var(--fw-accent)}.usermenu-pop{z-index:50;background:var(--fw-surface-2);border:1px solid var(--fw-border);border-radius:var(--fw-radius-md);min-width:200px;box-shadow:var(--fw-shadow-menu);padding:var(--fw-space-2);position:absolute;top:calc(100% + 8px);right:0}.usermenu-id{padding:var(--fw-space-1) var(--fw-space-2);flex-direction:column;gap:2px;display:flex}.usermenu-name{font-size:var(--fw-text-body-sm);color:var(--fw-ink);font-weight:600}.usermenu-email{font-size:var(--fw-text-caption)}.usermenu-signout{text-align:left;cursor:pointer;width:100%;color:var(--fw-ink);font-size:var(--fw-text-body-sm);font-family:var(--fw-font-ui);padding:var(--fw-space-2);border-radius:var(--fw-radius-sm);background:0 0;border:none}.usermenu-signout:hover{background:var(--fw-row-hover);color:var(--fw-accent)}.runs-filters{align-items:center;gap:var(--fw-space-2);margin:var(--fw-space-3) 0;flex-wrap:wrap;display:flex}.runs-filters .mini-btn{margin-left:auto}.chip-filter{background:var(--fw-surface-2);border:1px solid var(--fw-border);color:var(--fw-ink-muted);font-size:12px;font-family:var(--fw-font-ui);cursor:pointer;text-transform:capitalize;border-radius:12px;padding:2px 12px}.chip-filter:hover{border-color:var(--fw-accent)}.chip-filter-active{background:var(--fw-accent-dim);border-color:var(--fw-accent);color:var(--fw-accent);font-weight:600}.runs-row{cursor:pointer}.runs-row:hover td{background:color-mix(in srgb, var(--fw-accent) 6%, transparent)}.runs-row:focus-visible{outline:2px solid var(--fw-accent);outline-offset:-2px}.hist-filters{align-items:flex-end;gap:var(--fw-space-3);margin:var(--fw-space-3) 0;flex-wrap:wrap;display:flex}.hist-filter{flex-direction:column;gap:3px;display:flex}.hist-filter-label{letter-spacing:.05em;text-transform:uppercase;color:var(--fw-ink-muted);font-size:11px}.hist-filter select{background:var(--fw-surface-2);border:1px solid var(--fw-border);color:var(--fw-ink);border-radius:var(--fw-radius-sm);font-size:12px;font-family:var(--fw-font-ui);padding:4px 8px}.hist-filters .mini-btn{margin-left:auto}.hist-card{cursor:default;max-width:none}.hist-card:hover{border-color:var(--fw-border)}.hist-count{margin-bottom:var(--fw-space-2);font-size:12px}.hist-allorgs{color:var(--fw-accent);font-weight:600}.hist-product{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border:1px solid;border-radius:12px;padding:1px 8px;font-size:11px}.hist-when{white-space:nowrap}.hist-detail{text-overflow:ellipsis;white-space:nowrap;max-width:420px;overflow:hidden}.hist-source .link-btn{font-size:12px}
