@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--bg:#0d0f12;--bg2:#131619;--bg3:#1a1d22;--bg4:#21252b;--border:#ffffff12;--border2:#ffffff1f;--text:#e8eaed;--muted:#7a8290;--dim:#4a5060;--green:#2ecc7a;--green-bg:#2ecc7a1a;--amber:#f5a623;--amber-bg:#f5a6231a;--red:#e05252;--red-bg:#e052521a;--blue:#4b9eff;--blue-bg:#4b9eff1a;--cyan:#ff6b1a;--cyan-bg:#ff6b1a1a;--font-mono:"JetBrains Mono", monospace;--font-ui:"DM Sans", sans-serif;--radius:6px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);font-family:var(--font-ui);font-size:14px}.app{grid-template-rows:52px 1fr;height:100vh;display:grid;overflow:hidden}.topbar{border-bottom:1px solid var(--border);background:var(--bg2);justify-content:space-between;align-items:center;padding:0 20px;display:flex}.topbar-left{align-items:center;gap:16px;display:flex}.logo{font-family:var(--font-mono);color:var(--cyan);letter-spacing:.08em;font-size:13px;font-weight:700}.logo span{color:var(--muted);font-weight:400}.status-dot{background:var(--dim);border-radius:50%;width:7px;height:7px;transition:all .2s;box-shadow:0 0 6px #0000}.status-dot.ok{background:var(--green);box-shadow:0 0 6px var(--green)}.status-dot.bad{background:var(--red);box-shadow:0 0 6px var(--red)}.status-label{color:var(--muted);font-size:12px}.topbar-right{align-items:center;gap:10px;display:flex}.body{grid-template-columns:220px 1fr;display:grid;overflow:hidden}.sidebar{background:var(--bg2);border-right:1px solid var(--border);padding:16px 0;overflow-y:auto}.main{grid-template-rows:auto auto 1fr;display:grid;overflow:hidden}.nav-section{font-size:10px;font-family:var(--font-mono);color:var(--dim);text-transform:uppercase;letter-spacing:.1em;margin-top:12px;padding:0 12px 8px}.nav-item{cursor:pointer;color:var(--muted);border-left:2px solid #0000;align-items:center;gap:10px;padding:9px 16px;font-size:13px;transition:all .15s;display:flex}.nav-item:hover{color:var(--text);background:var(--bg3)}.nav-item.active{color:var(--cyan);border-left-color:var(--cyan);background:#ff6b1a0f}.nav-item .icon{text-align:center;width:16px;font-size:13px}.badge-count{background:var(--amber-bg);color:var(--amber);font-size:11px;font-family:var(--font-mono);border-radius:10px;margin-left:auto;padding:1px 7px}.badge-count.red{background:var(--red-bg);color:var(--red)}.badge-count.cyan{background:var(--cyan-bg);color:var(--cyan)}.badge-count.dim{background:var(--bg3);color:var(--dim)}.metrics-bar{background:var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.metric{background:var(--bg2);padding:14px 20px}.metric-val{font-size:24px;font-family:var(--font-mono);font-weight:700;line-height:1}.metric-val.amber{color:var(--amber)}.metric-val.red{color:var(--red)}.metric-val.green{color:var(--green)}.metric-val.cyan{color:var(--cyan)}.metric-val.blue{color:var(--blue)}.metric-lbl{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:5px;font-size:11px}.subhdr{background:var(--bg3);border-bottom:1px solid var(--border);min-height:32px;font-size:12px;font-family:var(--font-mono);color:var(--muted);align-items:center;gap:12px;padding:7px 20px;display:flex}.subhdr .sep{color:var(--dim)}.subhdr .empty{color:var(--dim);font-style:italic}.content{overflow:hidden}.panel{height:100%;display:none;overflow:hidden}.panel.active{display:block}.panel-scroll{height:100%;padding:20px;overflow-y:auto}.split{grid-template-columns:340px 1fr;height:100%;display:grid;overflow:hidden}.split-list{border-right:1px solid var(--border);background:var(--bg);overflow-y:auto}.split-detail{background:var(--bg);padding:16px 20px;overflow-y:auto}.run-card{border-bottom:1px solid var(--border);cursor:pointer;padding:12px 14px;transition:background .1s}.run-card:hover{background:var(--bg2)}.run-card.selected{background:var(--bg3);border-left:3px solid var(--cyan);padding-left:11px}.run-card-row1{align-items:center;gap:8px;margin-bottom:4px;display:flex}.run-card-tarea{font-family:var(--font-mono);color:var(--text);font-size:13px;font-weight:700}.run-card-serial{font-family:var(--font-mono);color:var(--muted);font-size:11px}.run-card-row2{color:var(--muted);align-items:center;gap:8px;font-size:11px;display:flex}.run-card-step{font-family:var(--font-mono);color:var(--cyan);font-size:11px}.run-card-time{color:var(--dim);margin-left:auto}.detail-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;padding:14px 16px}.detail-card.error{border-color:#e0525266}.detail-card-title{font-size:11px;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:8px;margin-bottom:12px;display:flex}.detail-card-title:after{content:"";background:var(--border);flex:1;height:1px}.detail-header{flex-wrap:wrap;align-items:center;gap:12px 20px;display:flex}.detail-header .id-tarea{font-family:var(--font-mono);color:var(--text);font-size:18px;font-weight:700}.detail-header .serial{font-family:var(--font-mono);color:var(--muted);font-size:13px}.detail-header .ts{color:var(--dim);margin-left:auto;font-size:11px}.kv-grid{grid-template-columns:200px 1fr;gap:6px 16px;font-size:12px;display:grid}.kv-grid>.k{color:var(--muted);font-family:var(--font-mono)}.kv-grid>.v{color:var(--text);font-family:var(--font-mono);word-break:break-all}.kv-grid>.v.dim{color:var(--dim)}.tele-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 24px;font-size:12px;display:grid}.tele-grid>.k{color:var(--muted);font-family:var(--font-mono)}.tele-grid>.v{color:var(--text);font-family:var(--font-mono)}.step-list-v{flex-direction:column;gap:0;display:flex}.step-row-v{border-bottom:1px dashed var(--border);align-items:flex-start;gap:12px;padding:8px 0;display:flex}.step-row-v:last-child{border-bottom:none}.step-row-v.is-current{border-left:2px solid var(--cyan);background:#ff6b1a0a;margin:0 -16px;padding-left:16px;padding-right:16px}.step-row-v .step-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;font-size:13px;display:flex}.step-row-v .step-icon.pending{color:var(--dim)}.step-row-v .step-icon.running{color:var(--cyan);animation:1.2s linear infinite spin}.step-row-v .step-icon.success{color:var(--green)}.step-row-v .step-icon.failed{color:var(--red)}.step-row-v .step-icon.awaiting{color:var(--amber)}.step-row-v .step-icon.skipped{color:var(--dim)}.step-row-v .step-body{flex:1;min-width:0}.step-row-v .step-label{color:var(--text);font-size:13px}.step-row-v.pending .step-label{color:var(--muted)}.step-row-v .step-name{font-family:var(--font-mono);color:var(--dim);margin-top:2px;font-size:10px}.step-row-v .step-detail{color:var(--muted);font-size:11px;font-family:var(--font-mono);margin-top:4px}.step-row-v .step-error{color:var(--red);font-size:12px;font-family:var(--font-mono);background:var(--red-bg);border-radius:4px;margin-top:4px;padding:6px 8px}.step-row-v .step-time{color:var(--dim);font-size:10px;font-family:var(--font-mono);flex-shrink:0;margin-left:auto}.step-row-v .step-output-toggle{color:var(--cyan);font-size:10px;font-family:var(--font-mono);cursor:pointer;-webkit-user-select:none;user-select:none;margin-top:4px}.step-row-v .step-output-toggle:hover{text-decoration:underline}.step-row-v .step-output{margin-top:6px;display:none}.step-row-v .step-output.open{display:block}.step-row-v .step-output pre{background:var(--bg);max-height:240px;color:var(--text);border-radius:4px;padding:8px 10px;font-size:11px;line-height:1.4;overflow:auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.input-form{flex-direction:column;gap:12px;display:flex}.input-prompt{color:var(--text);font-size:13px;line-height:1.5}.input-actions{gap:10px;display:flex}.input-actions .btn{padding:10px 18px;font-size:13px}.input-comment{background:var(--bg4);border:1px solid var(--border2);color:var(--text);font-family:var(--font-ui);resize:vertical;border-radius:4px;min-height:60px;padding:8px 10px;font-size:13px}.input-comment:focus{border-color:var(--cyan);outline:none}.raw-toggle{color:var(--cyan);font-size:11px;font-family:var(--font-mono);cursor:pointer;-webkit-user-select:none;user-select:none}.raw-toggle:hover{text-decoration:underline}.raw-pre{background:var(--bg);max-height:360px;color:var(--text);border-radius:4px;margin-top:8px;padding:10px 12px;font-size:11px;line-height:1.4;display:none;overflow:auto}.raw-pre.open{display:block}.empty{text-align:center;color:var(--dim);padding:48px 16px}.empty-icon{margin-bottom:12px;font-size:32px}.empty-text{font-size:13px}.tbl-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{border-collapse:collapse;width:100%}thead th{background:var(--bg3);text-align:left;font-size:11px;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);padding:10px 14px;font-weight:500}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg3)}td{vertical-align:middle;padding:11px 14px;font-size:13px}td.row-error{padding-top:0;padding-bottom:8px}.row-error-msg{color:var(--red);font-size:11px;font-family:var(--font-mono)}.mono{font-family:var(--font-mono);font-size:12px}.dim{color:var(--muted)}.chip{font-size:11px;font-family:var(--font-mono);border:1px solid;border-radius:4px;align-items:center;padding:2px 8px;font-weight:500;display:inline-flex}.chip.green{color:var(--green);background:var(--green-bg);border-color:#2ecc7a4d}.chip.amber{color:var(--amber);background:var(--amber-bg);border-color:#f5a6234d}.chip.red{color:var(--red);background:var(--red-bg);border-color:#e052524d}.chip.blue{color:var(--blue);background:var(--blue-bg);border-color:#4b9eff4d}.chip.cyan{color:var(--cyan);background:var(--cyan-bg);border-color:#ff6b1a4d}.chip.dim{color:var(--muted);border-color:var(--border2);background:var(--bg3)}.chip .chip-x{cursor:pointer;opacity:.6;margin-left:6px;padding:0 2px;font-weight:700}.chip .chip-x:hover{opacity:1;color:var(--red)}.zones-editor{flex-direction:column;gap:4px;display:flex}tr.row-new{background:#4b9eff0d}.btn{border-radius:var(--radius);cursor:pointer;font-size:12px;font-family:var(--font-ui);border:1px solid;align-items:center;gap:6px;padding:6px 14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{filter:brightness(1.15)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{color:var(--cyan);background:#ff6b1a26;border-color:#ff6b1a66}.btn-success{background:var(--green-bg);color:var(--green);border-color:#2ecc7a66}.btn-danger{background:var(--red-bg);color:var(--red);border-color:#e052524d}.btn-ghost{background:var(--bg3);color:var(--muted);border-color:var(--border2)}.btn-sm{padding:4px 10px;font-size:11px}.log-list{font-family:var(--font-mono);font-size:12px}.log-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:7px 14px;display:flex}.log-row:last-child{border-bottom:none}.log-row:hover{background:var(--bg3)}.log-time{color:var(--dim);white-space:nowrap;flex-shrink:0;font-size:11px}.log-tag{border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:10px}.log-tag.run_created{background:var(--blue-bg);color:var(--blue)}.log-tag.run_updated{background:var(--amber-bg);color:var(--amber)}.log-tag.step{background:var(--cyan-bg);color:var(--cyan)}.log-tag.log{background:var(--bg3);color:var(--muted)}.log-msg{color:var(--text);word-break:break-word;flex:1;min-width:0}.config-section{margin-bottom:24px}.config-title{font-size:11px;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:8px;margin-bottom:12px;display:flex}.config-title:after{content:"";background:var(--border);flex:1;height:1px}.config-hint{color:var(--muted);font-size:11px;font-family:var(--font-mono);margin:4px 0 10px}.row-actions{gap:6px;display:flex}.editable-input{background:var(--bg4);border:1px solid var(--border2);color:var(--text);font-family:var(--font-mono);border-radius:4px;width:100%;padding:5px 8px;font-size:12px}.editable-input:focus{border-color:var(--cyan);outline:none}dialog.modal{background:var(--bg2);color:var(--text);border:1px solid var(--border2);border-radius:var(--radius);width:90vw;max-width:540px;padding:0;box-shadow:0 24px 60px #0009}dialog.modal::backdrop{background:#0009}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.modal-title{font-family:var(--font-mono);color:var(--cyan);font-size:13px}.modal-close{cursor:pointer;color:var(--dim);font-size:16px;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{flex-direction:column;gap:12px;padding:18px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 18px;display:flex}.modal-field{flex-direction:column;gap:4px;display:flex}.modal-field>label{color:var(--muted);font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.modal-error{color:var(--red);background:var(--red-bg);border:1px solid #e052524d;border-radius:4px;padding:8px 10px;font-size:12px}.modal-error a{color:var(--cyan);cursor:pointer;text-decoration:underline}.toasts{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);max-width:360px;padding:10px 14px;font-size:12px;animation:.25s ease-out slideIn;box-shadow:0 8px 24px #0006}.toast.amber{border-color:#f5a62366}.toast.red{border-color:#e0525266}.toast.green{border-color:#2ecc7a66}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.spacer{flex:1}.row{align-items:center;gap:8px;display:flex}.col{flex-direction:column;gap:8px;display:flex}.copyable{cursor:pointer}.copyable:hover{color:var(--cyan)}.login-shell{z-index:1;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.login-card{z-index:1;-webkit-backdrop-filter:blur(14px)saturate(140%);border-radius:var(--radius);background:#1316198c;border:1px solid #ff6b1a2e;width:100%;max-width:380px;padding:28px 28px 24px;position:relative;box-shadow:0 12px 40px #0000008c,0 0 80px #ff6b1a0f,inset 0 1px #ffffff0a}.login-logo{font-family:var(--font-mono);color:var(--cyan);letter-spacing:.08em;text-align:center;margin-bottom:4px;font-size:13px;font-weight:700}.login-logo span{color:var(--muted);font-weight:400}.login-brand{text-align:center;margin-bottom:18px}.login-brand-name{font-family:var(--font-mono);color:var(--cyan);letter-spacing:.18em;text-shadow:0 0 18px #ff6b1a59;font-size:22px;font-weight:700}.login-brand-sub{font-family:var(--font-mono);color:var(--muted);letter-spacing:.22em;text-transform:uppercase;margin-top:4px;font-size:10.5px}.login-sub{text-align:center;color:var(--muted);font-size:12px;font-family:var(--font-mono);margin-bottom:22px}.login-bg{z-index:0;background:radial-gradient(1200px 700px at 20% 30%, #ff6b1a0f, transparent 60%), radial-gradient(900px 600px at 80% 70%, #4b9eff0a, transparent 60%), var(--bg);pointer-events:none;position:fixed;inset:0;overflow:hidden}.login-bg svg.login-bg-waves,.login-bg canvas.login-bg-net{width:100%;height:100%;position:absolute;inset:0}.login-bg svg.login-bg-waves circle{fill:none;stroke:#ff6b1a8c;stroke-width:1px}@media (prefers-reduced-motion:reduce){.login-bg svg.login-bg-waves,.login-bg canvas.login-bg-net{display:none}}.login-field{margin-bottom:14px}.login-field label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-family:var(--font-mono);margin-bottom:6px;display:block}.login-field input{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-ui);padding:9px 11px;font-size:13px;transition:border-color .15s}.login-field input:focus{border-color:var(--cyan);outline:none}.login-btn{background:var(--cyan);width:100%;color:var(--bg);border-radius:var(--radius);font-family:var(--font-ui);cursor:pointer;border:none;margin-top:6px;padding:10px;font-size:13px;font-weight:600;transition:opacity .15s}.login-btn:hover:not(:disabled){opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{background:var(--red-bg);border:1px solid var(--red);border-radius:var(--radius);color:var(--red);margin-top:12px;padding:9px 11px;font-size:12px}a{text-decoration:none!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border2)}
