:root{--bg:#f4f6fb;--ink:#1e293b;--muted:#64748b;--line:#94a3b8;--card:#fff;--border:#e2e8f0}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,Roboto,Arial,sans-serif;background:radial-gradient(1200px 600px at 50% -10%,#fff,var(--bg));color:var(--ink);min-height:100vh}a{color:inherit;text-decoration:none}.topbar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:14px 24px;background:#ffffffcc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar h1{font-size:17px;font-weight:700}.topbar h1 span{color:#4f46e5}.topbar .sub{font-size:12px;color:var(--muted);margin-top:2px}.controls{display:flex;gap:10px;margin-left:auto;flex-wrap:wrap}.btn,.controls{align-items:center}.btn{border:1px solid var(--border);background:#fff;color:var(--ink);padding:8px 13px;border-radius:10px;font-size:13.5px;font-weight:600;cursor:pointer;display:inline-flex;gap:7px;transition:.15s;box-shadow:0 1px 2px #0000000d}.btn:hover{border-color:#c7d2fe;background:#f5f7ff}.btn.primary{background:#4f46e5;color:#fff;border-color:#4f46e5}.btn.primary:hover{background:#4338ca}.legend{display:flex;gap:14px;flex-wrap:wrap;padding:10px 24px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--border);background:#fff}.legend i{width:11px;height:11px;border-radius:3px;display:inline-block;margin-right:6px;vertical-align:-1px}.legend b{font-weight:600;color:#334155}.scroller{overflow:auto;padding:24px;text-align:center}.stage-wrap{transform-origin:top left;margin:0 auto}.stage{position:relative}.band{position:absolute;top:0;border-radius:16px;opacity:.45}.lanehead{height:44px;border-radius:11px;font-weight:700;letter-spacing:.2px;box-shadow:0 4px 12px #0002;text-align:center;padding:0 6px}.lanehead,.master{position:absolute;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12.5px}.master{height:34px;border-radius:9px;font-weight:800;letter-spacing:1px}svg.edges{inset:0;overflow:visible;pointer-events:none}.node,svg.edges{position:absolute}.node{background:var(--card);border:1px solid var(--border);border-left:4px solid #94a3b8;border-radius:12px;padding:9px 12px 9px 13px;box-shadow:0 6px 16px #0f172a12;display:flex;flex-direction:column;justify-content:center;text-align:left;opacity:0;transform:translateY(10px) scale(.96);transition:opacity .4s,transform .4s}.node.show{opacity:1;transform:none}.node.active{box-shadow:0 0 0 3px #818cf855,0 10px 22px #0f172a22}.node .ttl{font-size:12px;font-weight:600;line-height:1.22}.node .tag{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:3px;display:flex;align-items:center;gap:5px}.node .tag .dot{font-size:11px}.t-click{border-left-color:#7c3aed;background:linear-gradient(#fff,#faf7ff)}.t-click .tag{color:#7c3aed}.t-start{border-left-color:#059669}.t-start .tag{color:#059669}.t-proc{border-left-color:#475569}.t-ci{border-left-color:#4338ca;background:linear-gradient(#fff,#f5f6ff)}.t-ci .tag{color:#4338ca}.t-dec{border-left-color:#d97706;background:linear-gradient(#fff,#fffdf7)}.t-dec .tag{color:#d97706}.t-deploy{border-left-color:#0891b2;background:linear-gradient(#fff,#f0fdff)}.t-deploy .tag{color:#0e7490}.t-doc{border-left-color:#2563eb}.t-doc .tag{color:#2563eb}.t-tag{border-left-color:#0d9488;background:linear-gradient(#fff,#f0fdfa)}.t-tag .tag{color:#0d9488}.t-warn{border-left-color:#dc2626;background:linear-gradient(#fff,#fff5f5)}.t-warn .tag{color:#dc2626}.node.clickable{cursor:pointer}.node.clickable:hover{box-shadow:0 0 0 2px #818cf855,0 10px 22px #0f172a1f;transform:translateY(-2px)}.node .tag .info{margin-left:auto;font-size:11px;opacity:0;transition:.15s}.node.clickable:hover .tag .info{opacity:.7}.node.sel{box-shadow:0 0 0 3px #4f46e5aa,0 12px 26px #0f172a26}.edge{fill:none;stroke:var(--line);stroke-width:2.2;stroke-dasharray:var(--len);stroke-dashoffset:var(--len)}.edge.drawn{stroke-dashoffset:0}.edge.flow{animation:flow 1.1s linear infinite}.edge.ret{stroke:#e0a86b;stroke-width:2;stroke-dasharray:6 7;stroke-dashoffset:0;opacity:.9}.edge.ret.flow{animation:march .8s linear infinite}.edge.sim{stroke:#10b981}.edge.nao{stroke:#f59e0b}@keyframes flow{to{stroke-dashoffset:-22}}@keyframes march{to{stroke-dashoffset:-26}}.elabel{font-size:10.5px;font-weight:700;fill:#475569;opacity:0;transition:opacity .35s}.elabel.show{opacity:1}.elabel.sim{fill:#059669}.elabel.nao{fill:#b45309}.ebg{fill:#fff;opacity:0;transition:opacity .35s}.ebg.show{opacity:.92}.home{max-width:980px;margin:0 auto;padding:48px 24px}.home-head h1{font-size:26px;font-weight:800}.home-head h1 span{color:#4f46e5}.home-head p{color:var(--muted);margin-top:8px;font-size:14px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px;margin-top:28px}.card{display:flex;flex-direction:column;gap:6px;padding:18px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 6px 16px #0f172a0d;transition:.18s}.card:hover{transform:translateY(-3px);border-color:#c7d2fe;box-shadow:0 12px 26px #0f172a18}.card-tag{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#4f46e5}.card-rf .card-tag{color:#0891b2}.card strong{font-size:16px}.card-sub{font-size:12.5px;color:var(--muted);line-height:1.4}.card-url{font-size:12px;color:#94a3b8;margin-top:4px;font-family:ui-monospace,monospace}.rf-bar{display:flex;align-items:center;gap:16px;height:56px;padding:0 20px;background:#fff;border-bottom:1px solid var(--border)}.rf-bar strong{font-size:15px}.rf-back{font-size:13px;font-weight:600;color:#4f46e5}.rf-hint{margin-left:auto;font-size:12px;color:var(--muted)}.legend-hint{margin-left:auto;color:#4f46e5;font-weight:600}.panel-backdrop{position:fixed;inset:0;background:#0f172a22;z-index:60;animation:fade .15s ease}.panel{position:fixed;top:0;right:0;height:100vh;width:360px;max-width:88vw;background:#fff;z-index:61;box-shadow:-14px 0 40px #0f172a26;border-left:5px solid #94a3b8;padding:26px 24px;display:flex;flex-direction:column;gap:14px;animation:slidein .22s cubic-bezier(.2,.7,.3,1)}.panel.t-click{border-left-color:#7c3aed}.panel.t-start{border-left-color:#059669}.panel.t-proc{border-left-color:#475569}.panel.t-ci{border-left-color:#4338ca}.panel.t-dec{border-left-color:#d97706}.panel.t-deploy{border-left-color:#0891b2}.panel.t-doc{border-left-color:#2563eb}.panel.t-tag{border-left-color:#0d9488}.panel.t-warn{border-left-color:#dc2626}.panel-close{position:absolute;top:14px;right:14px;border:none;background:#f1f5f9;width:30px;height:30px;border-radius:9px;cursor:pointer;font-size:14px;color:#475569;transition:.15s}.panel-close:hover{background:#e2e8f0}.panel-tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#64748b}.panel-tag span{font-size:16px}.panel-title{font-size:19px;font-weight:800;line-height:1.25;color:var(--ink)}.panel-desc{font-size:14.5px;line-height:1.6;color:#475569}@keyframes slidein{0%{transform:translateX(30px);opacity:.4}to{transform:none;opacity:1}}@keyframes fade{0%{opacity:0}to{opacity:1}}@media (max-width:760px){.topbar{padding:10px 14px;gap:9px}.topbar h1{font-size:15px}.topbar .sub{font-size:11px}.controls{gap:7px;width:100%}.btn{padding:7px 9px;font-size:12.5px}.legend{gap:9px;padding:8px 14px;font-size:11px}.scroller{padding:12px}}