:root{--accent: #0e9f6e;--accent-700: #0b7e57;--accent-50: #e7f6f0;--bg: #f4f6f8;--surface: #ffffff;--surface-2: #f9fafb;--border: #e4e8ec;--border-strong: #d4dade;--text: #14201b;--text-2: #5b6b66;--muted: #8a9893;--s-success: #16a34a;--s-failed: #dc2626;--s-running: #2563eb;--s-queued: #94a3b8;--s-upstream: #f59e0b;--s-skipped: #cbd5e1;--s-none: #eef1f3;--radius: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 2px rgba(16, 32, 27, .06);--shadow: 0 4px 18px rgba(16, 32, 27, .08);--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}code{font-family:var(--mono);font-size:.86em}h1,h2,h3{margin:0}.muted{color:var(--muted);font-size:13px}.mono{font-family:var(--mono)}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.splash{display:grid;place-items:center;height:100vh;color:var(--text-2)}.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,box-shadow .15s,opacity .15s}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-700);border-color:var(--accent-700)}.btn--ghost{background:transparent;border-color:var(--border)}.btn--ghost:hover{background:var(--surface-2)}.btn--ghost.danger{color:var(--s-failed)}.btn--block{width:100%;justify-content:center}.btn--sm{padding:5px 10px;font-size:12.5px}.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer}.iconbtn:hover{background:var(--surface-2);color:var(--text)}.iconbtn.danger:hover{color:var(--s-failed);border-color:#f6c9c9}.link-btn{background:none;border:none;color:var(--accent-700);font-weight:600;cursor:pointer;font-size:13px;padding:4px}.link-btn:hover{text-decoration:underline}.field{display:flex;flex-direction:column;gap:6px}.field>span{font-size:13px;font-weight:600;color:var(--text-2)}.field .hint{font-size:12px;color:var(--muted);font-weight:500}input,select,textarea{font:inherit;font-size:14px;padding:9px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);width:100%}textarea{resize:vertical;min-height:64px;font-family:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.input-wrap{display:flex;align-items:center;gap:8px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:0 11px;background:var(--surface);color:var(--muted)}.input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50)}.input-wrap input{border:none;padding:9px 0;box-shadow:none}.input-wrap input:focus{box-shadow:none}.input-wrap--search{max-width:360px;flex:1}.form{display:flex;flex-direction:column;gap:16px}.form-error{background:#fdecec;color:#a11;border:1px solid #f6c9c9;padding:9px 12px;border-radius:var(--radius-sm);font-size:13px}.form-note{background:var(--accent-50);color:var(--accent-700);padding:9px 12px;border-radius:var(--radius-sm);font-size:13px}.form-grid{display:grid;gap:14px;align-items:end;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.form-grid .btn{height:40px}.checkbox-field{display:flex;align-items:center;gap:8px;height:40px;font-size:13px;font-weight:600;color:var(--text-2)}.checkbox-field input{width:auto}.auth-page{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 500px at 50% -10%,#e9f6f0,var(--bg))}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.auth-brand strong{display:block;font-size:16px}.auth-brand__sub{font-size:12.5px;color:var(--muted)}.auth-title{font-size:20px;margin-bottom:4px}.shell{display:flex;min-height:100%}.sidebar{width:248px;flex-shrink:0;background:#0f1c17;color:#cfe3da;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar__brand{display:flex;align-items:center;gap:11px;padding:20px 18px}.sidebar__logo{width:34px;height:34px;border-radius:9px;background:var(--accent);color:#fff;font-weight:800;display:grid;place-items:center;font-size:17px;flex-shrink:0}.sidebar__brand strong{color:#fff;display:block;line-height:1.1}.sidebar__sub{font-size:12px;color:#7fa595}.sidebar__nav{display:flex;flex-direction:column;gap:3px;padding:8px 12px;flex:1}.navitem{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:#b8cfc5;font-weight:600;font-size:14px}.navitem:hover{background:#ffffff0f;color:#fff}.navitem.active{background:var(--accent);color:#fff}.sidebar__foot{padding:14px;border-top:1px solid rgba(255,255,255,.08)}.sidebar__user{display:flex;align-items:center;gap:10px;margin-bottom:12px}.avatar{width:36px;height:36px;border-radius:50%;background:#21443a;color:#fff;display:grid;place-items:center;font-weight:700;text-transform:uppercase;flex-shrink:0}.sidebar__userinfo{min-width:0}.sidebar__userinfo strong{display:block;color:#fff;font-size:13.5px;overflow:hidden;text-overflow:ellipsis}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:56px;display:flex;align-items:center;gap:12px;padding:0 22px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}.topbar__menu{display:none}.topbar__spacer{flex:1}.topbar__live{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--text-2)}.topbar__live .dot{width:8px;height:8px;border-radius:50%;background:var(--s-skipped)}.topbar__live.is-live{color:var(--accent-700)}.topbar__live.is-live .dot{background:var(--s-success);animation:pulse 1.6s ease-in-out infinite}.content{padding:26px;max-width:1280px;width:100%;margin:0 auto}.page{display:flex;flex-direction:column;gap:18px}.page__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page__head-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.page__title{font-size:23px;font-weight:750;letter-spacing:-.01em}.page__sub{color:var(--muted);margin:4px 0 0;font-size:13.5px}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-2);font-weight:600;font-size:13px}.back-link:hover{color:var(--accent-700)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.seg button{border:none;background:transparent;padding:6px 14px;border-radius:6px;font-weight:600;font-size:13px;color:var(--text-2);cursor:pointer}.seg button.is-active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.meta-chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px}.chip{font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);padding:3px 9px;border-radius:999px}.chip--accent{color:var(--accent-700);background:var(--accent-50);border-color:#cbeada}.chip--mono{font-family:var(--mono)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}.card__title{font-size:15px;font-weight:700;display:inline-flex;align-items:center;gap:8px}.card__actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.card__body{padding:18px}.dagid{background:var(--surface-2);border:1px solid var(--border);padding:1px 7px;border-radius:6px;margin-left:10px;color:var(--text-2)}.row-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.row-link{cursor:pointer;transition:background .12s}.row-link:hover{background:var(--surface-2)}.row-chevron{color:var(--muted);text-align:right}.cellstack{display:flex;flex-direction:column;gap:2px}.cellstack strong{font-weight:650}.dot-flag{font-size:12.5px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.dot-flag:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--s-skipped)}.dot-flag.on{color:var(--accent-700)}.dot-flag.on:before{background:var(--s-success)}.dot-flag.off{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:650;padding:3px 9px;border-radius:999px;border:1px solid var(--border)}.badge--sm{font-size:11.5px;padding:2px 8px}.badge__dot{width:7px;height:7px;border-radius:50%;background:currentColor}.badge--success{color:var(--s-success);background:#eafaf0;border-color:#c7eed5}.badge--failed{color:var(--s-failed);background:#fdecec;border-color:#f6c9c9}.badge--running{color:var(--s-running);background:#eaf1fe;border-color:#d3e2fd}.badge--queued{color:#475569;background:#eef2f6;border-color:#dde5ec}.badge--upstream_failed{color:#b45309;background:#fef4e6;border-color:#fbe2bd}.badge--skipped{color:#64748b;background:#f1f5f9;border-color:#e2e8f0}.badge--no_status{color:var(--muted);background:var(--surface-2)}.run-grid{display:inline-flex;gap:8px;align-items:flex-start}.run-grid__labels{display:flex;flex-direction:column;gap:3px}.run-grid__corner{height:16px;font-size:10px;color:var(--muted);font-weight:700}.run-grid__rowlabel{height:14px;font-size:11px;color:var(--text-2);font-family:var(--mono);line-height:14px;white-space:nowrap}.run-grid__cols{display:flex;gap:3px;overflow-x:auto}.run-grid__col{display:flex;flex-direction:column;gap:3px;padding:2px;border:1px solid transparent;border-radius:5px;background:none;cursor:pointer}.run-grid__col:hover{background:var(--surface-2);border-color:var(--border)}.run-grid__col.is-selected{border-color:var(--accent);background:var(--accent-50)}.cell{width:14px;height:14px;border-radius:3px;display:block;background:var(--s-none);border:1px solid rgba(0,0,0,.05)}.cell--head{height:16px;border-radius:4px}.cell--success{background:var(--s-success)}.cell--failed{background:var(--s-failed)}.cell--running{background:var(--s-running);animation:pulse 1.1s ease-in-out infinite}.cell--queued{background:var(--s-queued)}.cell--upstream_failed{background:var(--s-upstream)}.cell--skipped{background:var(--s-skipped)}.cell--no_status{background:var(--s-none)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.run-grid--compact .cell{width:11px;height:11px;border-radius:2px}.run-grid--compact .cell--head{height:12px}.run-grid--compact .run-grid__col{gap:2px;padding:1px}.grid-empty{color:var(--muted);font-size:13px;padding:6px 0}.grid-legend{display:flex;gap:14px;flex-wrap:wrap}.grid-legend__item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2)}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.autotoggle{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;background:var(--surface-2)}.autotoggle strong{display:block;font-size:14px}.autotoggle .muted{font-size:12px}.config-note{margin:12px 0 0}.switch{width:46px;height:26px;border-radius:999px;border:none;cursor:pointer;background:var(--s-skipped);position:relative;transition:background .18s;flex-shrink:0}.switch.on{background:var(--accent)}.switch:disabled{opacity:.5;cursor:not-allowed}.switch__knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .18s}.switch.on .switch__knob{transform:translate(20px)}.rundetail{margin-top:18px;border-top:1px dashed var(--border);padding-top:16px}.rundetail__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.steps{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.step{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;background:var(--surface-2);transition:border-color .12s,background .12s;font:inherit;color:inherit}.step:hover{border-color:var(--border-strong)}.step.is-selected{border-color:var(--accent);background:var(--accent-50)}.step strong{font-size:13px;font-weight:600}.logs{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.logs__head{padding:8px 12px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:12px;font-weight:700;color:var(--text-2);display:flex;justify-content:space-between}.logs__body{margin:0;padding:12px;background:#0f1c17;color:#d6e7df;font-family:var(--mono);font-size:12px;line-height:1.6;max-height:360px;overflow:auto;white-space:pre-wrap;word-break:break-word}.step-editor{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px;background:var(--surface-2)}.step-editor__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.step-editor__idx{font-weight:700;color:var(--text-2);font-size:13px}.editor-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.editor-row:last-child{margin-bottom:0}.stack{display:flex;flex-direction:column;gap:14px}.role{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:capitalize}.role--admin{color:var(--accent-700);background:var(--accent-50)}.role--user{color:#475569;background:#eef2f6}.ustatus{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:capitalize}.ustatus--active{color:var(--s-success);background:#eafaf0}.ustatus--pending{color:#b45309;background:#fef4e6}.state-block{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px;color:var(--text-2);text-align:center}.state-block--error{color:var(--s-failed)}.toast-stack{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:100}.toast{display:flex;align-items:center;gap:10px;min-width:260px;max-width:380px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--muted);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:12px 14px;font-size:13.5px;animation:toast-in .18s ease-out}.toast--success{border-left-color:var(--s-success);color:var(--s-success)}.toast--error{border-left-color:var(--s-failed);color:var(--s-failed)}.toast--info{border-left-color:var(--s-running);color:var(--s-running)}.toast span{color:var(--text);flex:1}.toast__close{background:none;border:none;cursor:pointer;color:var(--muted);display:inline-flex}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}@media (max-width: 880px){.sidebar{position:fixed;left:0;top:0;z-index:30;transform:translate(-100%);transition:transform .2s}.shell--open .sidebar{transform:translate(0);box-shadow:var(--shadow)}.topbar__menu{display:inline-flex}.config-grid,.editor-row{grid-template-columns:1fr}}
