@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--bg:#080812;--bg-2:#0e0e1c;--surface:#13132a;--surface-2:#1a1a35;--border:#8a5cf626;--border-hover:#8a5cf666;--purple:#8b5cf6;--indigo:#6366f1;--cyan:#22d3ee;--grad:linear-gradient(135deg, #8b5cf6 0%, #6366f1 50%, #22d3ee 100%);--grad-subtle:linear-gradient(135deg, #8b5cf61f 0%, #6366f114 100%);--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--text-1:#f0f0ff;--text-2:#a0a0c0;--text-3:#606080;--step-pending:#3a3a5c;--step-running:#f59e0b;--step-complete:#10b981;--step-error:#ef4444;--sidebar-w:240px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--shadow-card:0 4px 24px #0006, 0 1px 4px #0000004d;--shadow-glow:0 0 40px #8b5cf633;--shadow-glow-sm:0 0 20px #8b5cf626}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif;overflow-x:hidden}h1,h2,h3,h4,h5{font-family:Space Grotesk,sans-serif;font-weight:700;line-height:1.2}h1{font-size:clamp(1.8rem,4vw,2.8rem)}h2{font-size:clamp(1.3rem,3vw,1.8rem)}h3{font-size:1.1rem}p{color:var(--text-2);line-height:1.7}.app-shell{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-2);border-right:1px solid var(--border);flex-direction:column;height:100vh;padding:1.5rem 0;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;margin-bottom:1rem;padding:0 1.25rem 1.5rem;display:flex}.sidebar-logo-icon{background:var(--grad);width:36px;height:36px;box-shadow:var(--shadow-glow-sm);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.sidebar-logo-text{background:var(--grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:700}.nav-section{margin-bottom:.5rem;padding:0 .75rem}.nav-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:.25rem;padding:0 .5rem;font-size:.65rem;font-weight:600}.nav-item{color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:.65rem;width:100%;margin-bottom:2px;padding:.6rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover,.nav-item.active{background:var(--grad-subtle);color:var(--text-1)}.nav-item.active{border:1px solid var(--border);color:#c4b5fd}.nav-item svg{opacity:.8;flex-shrink:0;width:16px;height:16px}.main-content{flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}.page-header{background:var(--bg-2);border-bottom:1px solid var(--border);z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 2rem;display:flex;position:sticky;top:0}.page-header h1{font-size:1.3rem}.page-body{flex:1;width:100%;max-width:1300px;padding:2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:1.5rem;transition:border-color .2s,box-shadow .2s}.card:hover{border-color:var(--border-hover)}.card-glass{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);background:#13132a99;border:1px solid #8a5cf633}.card-gradient{background:var(--grad-subtle);border:1px solid var(--border);border-radius:var(--radius-lg)}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--grad);color:#fff;box-shadow:0 4px 16px #8b5cf659}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #8b5cf680}.btn-secondary{background:var(--surface-2);color:var(--text-1);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--border-hover);background:var(--surface)}.btn-ghost{color:var(--text-2);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text-1)}.btn-danger{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-sm{border-radius:8px;padding:.4rem .85rem;font-size:.8rem}.btn-lg{border-radius:12px;padding:.85rem 1.75rem;font-size:1rem}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-pending{color:#888;background:#3a3a5c99;border:1px solid #3a3a5c}.badge-running{color:#fbbf24;background:#f59e0b26;border:1px solid #f59e0b4d}.badge-completed{color:#34d399;background:#10b98126;border:1px solid #10b9814d}.badge-failed{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.badge-draft{color:#a5b4fc;background:#6366f126;border:1px solid #6366f14d}.badge-scheduled{color:#67e8f9;background:#22d3ee1f;border:1px solid #22d3ee40}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--text-2);letter-spacing:.03em;font-size:.8rem;font-weight:600}.form-hint{color:var(--text-3);font-size:.75rem}.input,.select,textarea{background:var(--bg-2);border:1px solid var(--border);color:var(--text-1);border-radius:10px;outline:none;width:100%;padding:.65rem 1rem;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,textarea:focus{border-color:var(--purple);box-shadow:0 0 0 3px #8b5cf626}.input::placeholder,textarea::placeholder{color:var(--text-3)}.select{appearance:none;cursor:pointer}textarea{resize:vertical;min-height:100px}.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s;overflow:hidden}.step-card.running{border-color:#f59e0b66;box-shadow:0 0 20px #f59e0b1a}.step-card.completed{border-color:#10b9814d}.step-card.failed{border-color:#ef444466;box-shadow:0 0 20px #ef44441a}.step-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.step-num{background:var(--surface-2);border:1px solid var(--border);width:32px;height:32px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.step-num.running{color:#fbbf24;background:#f59e0b33;border-color:#f59e0b}.step-num.completed{color:#34d399;background:#10b98133;border-color:#10b981}.step-num.failed{color:#f87171;background:#ef444433;border-color:#ef4444}.step-body{border-top:1px solid var(--border);padding:0 1.25rem 1.25rem}.progress-bar{background:var(--surface-2);border-radius:999px;height:4px;overflow:hidden}.progress-fill{background:var(--grad);border-radius:999px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-day{aspect-ratio:1.2;background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:2px;min-height:80px;padding:.4rem;font-size:.7rem;transition:all .15s;display:flex;overflow:hidden}.calendar-day:hover{border-color:var(--border-hover)}.calendar-day.today{border-color:var(--purple);box-shadow:0 0 12px #8b5cf633}.calendar-day.other-month{opacity:.35}.calendar-day-num{color:var(--text-2);font-size:.75rem;font-weight:600}.today .calendar-day-num{background:var(--grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.calendar-event{truncate:ellipsis;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:5px;padding:2px 5px;font-size:.62rem;font-weight:600;overflow:hidden}.calendar-event.completed{color:#34d399;background:#10b98133}.calendar-event.running{color:#fbbf24;background:#f59e0b33}.calendar-event.pending{color:#a5b4fc;background:#6366f133}.calendar-event.scheduled{color:#67e8f9;background:#22d3ee26}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:flex-start;gap:1rem;padding:1.5rem;display:flex}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;display:flex}.stat-value{font-family:Space Grotesk,sans-serif;font-size:1.8rem;font-weight:700;line-height:1}.stat-label{color:var(--text-3);margin-top:.25rem;font-size:.78rem;font-weight:500}.wizard-steps{align-items:center;gap:0;margin-bottom:2rem;display:flex}.wizard-step{flex:1;align-items:center;gap:.5rem;display:flex}.wizard-step-circle{border:2px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.wizard-step.active .wizard-step-circle{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow-sm);border-color:#0000}.wizard-step.done .wizard-step-circle{color:#34d399;background:#10b98133;border-color:#10b981}.wizard-step-line{background:var(--border);flex:1;height:2px;margin:0 .25rem;transition:background .3s}.wizard-step.done+.wizard-step .wizard-step-line,.wizard-step.done .wizard-step-line{background:#10b98166}.tag-input{background:var(--bg-2);border:1px solid var(--border);cursor:text;border-radius:10px;flex-wrap:wrap;gap:.4rem;min-height:48px;padding:.5rem;transition:border-color .15s,box-shadow .15s;display:flex}.tag-input:focus-within{border-color:var(--purple);box-shadow:0 0 0 3px #8b5cf626}.tag{color:#c4b5fd;background:#8b5cf633;border:1px solid #8b5cf666;border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.8rem;font-weight:500;display:inline-flex}.tag-remove{cursor:pointer;opacity:.7;font-size:.75rem}.tag-remove:hover{opacity:1}.tag-input-inner{color:var(--text-1);background:0 0;border:none;outline:none;flex:1;min-width:120px;font-family:inherit;font-size:.875rem}.code-block{background:var(--bg);border:1px solid var(--border);color:#c4b5fd;white-space:pre-wrap;word-break:break-all;border-radius:10px;max-height:300px;padding:1rem;font-family:JetBrains Mono,monospace;font-size:.78rem;overflow:auto}.divider{background:var(--border);height:1px;margin:1.5rem 0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #8b5cf633}50%{box-shadow:0 0 40px #8b5cf680}}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.spinner{border:2px solid #8b5cf64d;border-top-color:var(--purple);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.animate-slide-up{animation:.4s both slide-up}.animate-fade-in{animation:.3s both fade-in}.skeleton{background:linear-gradient(90deg, var(--surface) 0%, var(--surface-2) 50%, var(--surface) 100%);background-size:200%;border-radius:8px;animation:1.5s linear infinite shimmer}.alert{border-radius:var(--radius);border:1px solid;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;font-size:.875rem;display:flex}.alert-info{color:#93c5fd;background:#3b82f61a;border-color:#3b82f64d}.alert-success{color:#6ee7b7;background:#10b9811a;border-color:#10b9814d}.alert-warning{color:#fcd34d;background:#f59e0b1a;border-color:#f59e0b4d}.alert-error{color:#fca5a5;background:#ef44441a;border-color:#ef44444d}.grid-2{grid-template-columns:repeat(2,1fr);gap:1.25rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.text-muted{color:var(--text-2)}.text-faint{color:var(--text-3)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-mono{font-family:JetBrains Mono,monospace}.text-grad{background:var(--grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.article-preview{color:var(--text-1);font-size:.9rem;line-height:1.8}.article-preview h2{color:var(--text-1);margin:1.5rem 0 .75rem;font-size:1.2rem}.article-preview h3{color:var(--text-1);margin:1.2rem 0 .5rem;font-size:1rem}.article-preview p{color:var(--text-2);margin-bottom:.75rem}.article-preview a{color:#c4b5fd;-webkit-text-decoration:underline #c4b5fd4d;text-decoration:underline #c4b5fd4d}.article-preview ul,.article-preview ol{margin-bottom:.75rem;padding-left:1.5rem}.article-preview li{color:var(--text-2);margin-bottom:.35rem}.article-preview strong{color:var(--text-1);font-weight:600}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@media (max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-body{padding:1rem}}
