body{color:#e0e0e0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0f;font-family:Inter,system-ui,-apple-system,sans-serif}#root{min-height:100vh}.landing{color:#e0e0e0;background:#0a0a0f;min-height:100vh;font-family:Inter,system-ui,sans-serif}.landing-nav{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1.5rem 4rem;display:flex}.logo{color:#fff;letter-spacing:-.5px;font-size:1.5rem;font-weight:700}.nav-links{align-items:center;gap:.5rem;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#6c5ce7;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:background .2s}.btn-primary:hover{background:#5a4bd1}.btn-secondary{color:#a0a0b0;padding:.6rem 1rem;font-weight:500;text-decoration:none;transition:color .2s}.btn-secondary:hover{color:#fff}.btn-ghost{color:#a0a0b0;border:1px solid #2a2a3a;border-radius:8px;padding:.6rem 1.5rem;font-weight:500;text-decoration:none;transition:all .2s}.btn-ghost:hover{color:#fff;border-color:#6c5ce7}.btn-large{padding:.9rem 2.5rem;font-size:1.05rem}.hero{text-align:center;max-width:880px;margin:0 auto;padding:6rem 2rem 5rem}.tagline{color:#a29bfe;letter-spacing:.3px;background:#6c5ce71f;border:1px solid #6c5ce74d;border-radius:20px;margin-bottom:1.75rem;padding:.4rem .9rem;font-size:.8rem;font-weight:500;display:inline-block}.hero h1{color:#fff;letter-spacing:-1.5px;margin-bottom:1.5rem;font-size:3.8rem;font-weight:800;line-height:1.1}.gradient-text{background:linear-gradient(135deg,#6c5ce7,#a29bfe,#74b9ff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.subtitle{color:#8888a0;max-width:620px;margin:0 auto 2.5rem;font-size:1.15rem;line-height:1.7}.hero-actions{justify-content:center;gap:.75rem;margin-bottom:2rem;display:flex}.hero-meta{color:#555;flex-wrap:wrap;justify-content:center;gap:.5rem;font-size:.85rem;display:flex}.dot{color:#333}.section-heading{color:#fff;text-align:center;letter-spacing:-.5px;margin-bottom:3rem;font-size:2rem;font-weight:700}.pain-points{border-top:1px solid #14141e;max-width:1100px;margin:0 auto;padding:5rem 2rem}.pains{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.pain-item{background:#0e0e16;border:1px solid #1a1a2a;border-radius:12px;padding:1.75rem}.pain-icon{margin-bottom:.75rem;font-size:1.75rem}.pain-item h4{color:#e0e0e0;margin-bottom:.5rem;font-size:1.05rem;font-weight:600}.pain-item p{color:#6e6e88;font-size:.92rem;line-height:1.6}.how{border-top:1px solid #14141e;max-width:1000px;margin:0 auto;padding:5rem 2rem}.how-steps{flex-direction:column;gap:2rem;display:flex}.how-step{background:#0e0e16;border:1px solid #1a1a2a;border-radius:14px;padding:2rem 2.25rem;transition:border-color .2s;position:relative}.how-step:hover{border-color:#2a2a3a}.step-num{color:#6c5ce7;letter-spacing:1px;margin-bottom:.5rem;font-family:Menlo,monospace;font-size:.85rem;font-weight:600}.how-step h3{color:#fff;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.how-step p{color:#8888a0;font-size:.96rem;line-height:1.7}.features{border-top:1px solid #14141e;max-width:1100px;margin:0 auto;padding:5rem 2rem}.features-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.feature-card{background:#0e0e16;border:1px solid #1a1a2a;border-radius:12px;padding:1.75rem;transition:border-color .2s}.feature-card:hover{border-color:#6c5ce7}.feature-icon{margin-bottom:.75rem;font-size:1.6rem}.feature-card h3{color:#fff;margin-bottom:.4rem;font-size:1.05rem;font-weight:600}.feature-card p{color:#6e6e88;font-size:.9rem;line-height:1.6}.feature-card code{color:#a29bfe;background:#1a1625;border-radius:4px;padding:.1rem .35rem;font-family:Menlo,monospace;font-size:.82rem}.dev-note{border-top:1px solid #14141e;max-width:760px;margin:0 auto;padding:5rem 2rem}.dev-note-body{background:#0e0e16;border:1px solid #1a1a2a;border-left:3px solid #6c5ce7;border-radius:10px;padding:2rem 2.25rem}.dev-note-body p{color:#9090a8;margin-bottom:1rem;font-size:.98rem;line-height:1.75}.dev-note-body p:last-child{margin-bottom:0}.signed{font-style:italic;color:#666!important;margin-top:.5rem!important}.cta{text-align:center;border-top:1px solid #14141e;max-width:700px;margin:0 auto;padding:5rem 2rem 6rem}.cta h2{color:#fff;letter-spacing:-.5px;margin-bottom:2rem;font-size:2rem;font-weight:700;line-height:1.3}.landing-footer{border-top:1px solid #14141e;max-width:1100px;margin:0 auto;padding:3rem 2rem 2rem}.footer-cols{grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem;display:grid}.footer-logo{color:#fff;margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.footer-tag{color:#555;max-width:320px;font-size:.88rem;line-height:1.6}.footer-col-title{color:#888;text-transform:uppercase;letter-spacing:1px;margin-bottom:.75rem;font-size:.75rem;font-weight:600}.landing-footer a{color:#6e6e88;padding:.25rem 0;font-size:.9rem;text-decoration:none;transition:color .2s;display:block}.landing-footer a:hover{color:#fff}.footer-bottom{color:#444;border-top:1px solid #14141e;flex-wrap:wrap;align-items:center;gap:.6rem;padding-top:1.5rem;font-size:.82rem;display:flex}.footer-sep{color:#222}.cryo-link{text-decoration:none;transition:color .2s;color:#a29bfe!important;padding:0!important;display:inline!important}.cryo-link:hover{color:#fff!important}@media (width<=900px){.pains,.features-grid,.footer-cols{grid-template-columns:1fr 1fr}}@media (width<=640px){.landing-nav{padding:1rem 1.5rem}.hero{padding:4rem 1.5rem 3rem}.hero h1{font-size:2.3rem}.subtitle{font-size:1rem}.section-heading{font-size:1.6rem}.pains,.features-grid{grid-template-columns:1fr}.how-step{padding:1.5rem}.footer-cols{grid-template-columns:1fr;gap:2rem}.hero-actions{flex-direction:column;align-items:stretch}}.auth-page{background:#0a0a0f;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:#12121a;border:1px solid #1e1e2e;border-radius:16px;width:100%;max-width:400px;padding:2.5rem}.auth-logo{text-align:center;color:#fff;letter-spacing:-.5px;margin-bottom:2rem;font-size:1.5rem;font-weight:700;text-decoration:none;display:block}.auth-card h2{color:#fff;text-align:center;margin-bottom:1.5rem;font-size:1.4rem;font-weight:600}.auth-error{color:#e74c3c;background:#2d1520;border:1px solid #e74c3c;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.form-group{margin-bottom:1.2rem}.form-group label{color:#8888a0;margin-bottom:.4rem;font-size:.85rem;font-weight:500;display:block}.form-group input{color:#e0e0e0;box-sizing:border-box;background:#0a0a0f;border:1px solid #2a2a3a;border-radius:8px;outline:none;width:100%;padding:.7rem 1rem;font-size:.95rem;transition:border-color .2s}.form-group input:focus{border-color:#6c5ce7}.form-group input::placeholder{color:#444460}.btn-full{width:100%;margin-top:.5rem;padding:.75rem;font-size:1rem}.divider{align-items:center;gap:1rem;margin:1.5rem 0;display:flex}.divider:before,.divider:after{content:"";background:#2a2a3a;flex:1;height:1px}.divider span{color:#555;font-size:.85rem}.btn-google{color:#333;cursor:pointer;background:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:.75rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:background .2s;display:flex}.btn-google:hover{background:#f0f0f0}.auth-switch{text-align:center;color:#666;margin-top:1.5rem;font-size:.9rem}.auth-switch a{color:#6c5ce7;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.app-nav{background:#0a0a0f;border-bottom:1px solid #1a1a2a;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.nav-left{align-items:center;gap:1.5rem;display:flex}.breadcrumbs{color:#8888a0;align-items:center;font-size:.9rem;display:flex}.crumb a{color:#8888a0;text-decoration:none;transition:color .2s}.crumb a:hover,.crumb span:not(.separator){color:#fff}.separator{color:#444;margin:0 .5rem}.nav-right{align-items:center;gap:1rem;display:flex}.dashboard{color:#e0e0e0;background:#0a0a0f;min-height:100vh}.dash-nav{border-bottom:1px solid #1a1a2a;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.dash-nav-right{align-items:center;gap:1rem;display:flex}.user-name{color:#8888a0;font-size:.9rem}.dash-main{max-width:900px;margin:0 auto;padding:2rem}.dash-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.dash-header h1{color:#fff;font-size:1.8rem;font-weight:700}.create-form{background:#12121a;border:1px solid #1e1e2e;border-radius:12px;flex-direction:column;gap:.75rem;margin-bottom:2rem;padding:1.5rem;display:flex}.create-form input{color:#e0e0e0;background:#0a0a0f;border:1px solid #2a2a3a;border-radius:8px;outline:none;padding:.7rem 1rem;font-size:.95rem}.create-form input:focus{border-color:#6c5ce7}.create-actions{gap:.75rem;display:flex}.empty-state{text-align:center;color:#555;padding:4rem 2rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.project-card{color:inherit;background:#12121a;border:1px solid #1e1e2e;border-radius:12px;padding:1.5rem;text-decoration:none;transition:border-color .2s}.project-card:hover{border-color:#6c5ce7}.project-card h3{color:#fff;margin-bottom:.5rem;font-size:1.1rem}.project-card p{color:#7070888;margin-bottom:.75rem;font-size:.9rem}.project-date{color:#444;font-size:.8rem}.fg-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0;overflow-y:auto}.fg-modal{background:#0e0e16;border:1px solid #2a2a3a;border-radius:14px;flex-direction:column;width:100%;max-width:900px;max-height:90vh;display:flex;overflow:hidden}.fg-header{border-bottom:1px solid #1a1a2a;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.75rem 2rem 1.25rem;display:flex}.fg-header h2{color:#fff;margin-bottom:.4rem;font-size:1.4rem;font-weight:700}.fg-sub{color:#8888a0;max-width:640px;font-size:.9rem;line-height:1.55}.fg-close{color:#555;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.8rem;line-height:1;transition:color .2s}.fg-close:hover{color:#fff}.fg-quick{border-bottom:1px solid #1a1a2a;grid-template-columns:repeat(3,1fr);gap:.75rem;padding:1.5rem 2rem;display:grid}.fg-quick-card{background:#12121a;border:1px solid #1e1e2e;border-radius:8px;padding:1rem}.fg-quick-card h4{color:#a29bfe;margin-bottom:.4rem;font-size:.85rem;font-weight:600}.fg-quick-card p{color:#7a7a90;font-size:.85rem;line-height:1.5}.fg-quick-card code{color:#a29bfe;background:#1a1625;border-radius:3px;padding:.05rem .35rem;font-family:Menlo,monospace;font-size:.78rem}.fg-prompt-header{justify-content:space-between;align-items:center;padding:1.25rem 2rem .75rem;display:flex}.fg-prompt-header h3{color:#fff;font-size:1rem;font-weight:600}.fg-copy{color:#fff;cursor:pointer;background:#6c5ce7;border:none;border-radius:6px;padding:.45rem 1rem;font-size:.85rem;font-weight:500;transition:background .2s}.fg-copy:hover{background:#5a4bd1}.fg-prompt{background:#050508;border:1px solid #1a1a2a;border-radius:8px;flex:1;min-height:0;max-height:50vh;margin:0 2rem 2rem;padding:1.25rem;overflow:auto}.fg-prompt code{color:#c0c0d0;white-space:pre-wrap;word-break:break-word;font-family:Menlo,Consolas,monospace;font-size:.8rem;line-height:1.6}@media (width<=700px){.fg-quick{grid-template-columns:1fr}.fg-backdrop{padding:.5rem}.fg-header,.fg-prompt{padding-left:1rem;padding-right:1rem}.fg-prompt{margin-left:1rem;margin-right:1rem}}.react-flow{direction:ltr}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1px;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background:#1a192b;border:1px solid #fff;border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-top{top:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{top:50%;right:-4px;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{background:#ffffff80;margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{color:#222;text-align:center;background-color:#fff;border:1px solid #1a192b;border-radius:3px;width:150px;padding:10px;font-size:12px}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{box-sizing:content-box;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fefefe;border:none;border-bottom:1px solid #eee;justify-content:center;align-items:center;width:16px;height:16px;padding:5px;display:flex}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;width:4px;height:4px;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.sn{width:100%;height:100%;font-family:Inter,system-ui,sans-serif;transition:transform .15s,filter .15s;animation:.32s cubic-bezier(.25,.9,.3,1) nodeFadeIn;position:relative}.sn:hover{z-index:5;filter:drop-shadow(0 10px 24px color-mix(in srgb, var(--sn-accent,#6c5ce7) 55%, transparent));transform:scale(1.04)}@supports not (filter:drop-shadow(0 0 0 color-mix(in srgb, white 50%, transparent))){.sn:hover{filter:drop-shadow(0 10px 24px #6c5ce780)}}@keyframes nodeFadeIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.sn-fill{background:var(--sn-bg,#12121a);outline-offset:0;outline:0 solid #0000;transition:box-shadow .2s,outline .15s;position:absolute;inset:0;box-shadow:0 4px 12px #0000004d}.sn:hover .sn-fill{outline:2px solid var(--sn-accent,#6c5ce7);outline-offset:-2px}.sn-rect:hover .sn-fill,.sn-cylinder:hover .sn-fill,.sn-pipe:hover .sn-fill,.sn-pipeline-header:hover .sn-fill{outline:2px solid var(--sn-accent,#6c5ce7)}.sn-content{z-index:1;box-sizing:border-box;text-align:center;color:#fff;flex-direction:column;justify-content:center;align-items:center;gap:3px;width:100%;min-width:0;height:100%;padding:10px 14px;display:flex;position:relative;overflow:hidden}.sn-rect .sn-fill{border:1.5px solid var(--sn-border,#2a2a3d);border-radius:11px}.sn-parallelogram .sn-fill{clip-path:polygon(14% 0%,100% 0%,86% 100%,0% 100%)}.sn-diamond .sn-fill{clip-path:polygon(50% 3%,97% 50%,50% 97%,3% 50%)}.sn-hexagon .sn-fill{clip-path:polygon(8% 0%,92% 0%,100% 50%,92% 100%,8% 100%,0% 50%)}.sn-trapezoid .sn-fill{clip-path:polygon(8% 0%,92% 0%,100% 100%,0% 100%)}.sn-pipe .sn-fill{border:1.5px solid var(--sn-border,#2a2a3d);border-radius:999px}.sn-cylinder .sn-fill{border:1.5px solid var(--sn-border,#2a2a3d);border-radius:50%/18%}.sn-cylinder .sn-cyl-top{border:1.5px solid var(--sn-border,#2a2a3d);z-index:0;background:linear-gradient(#ffffff0d 0%,#0000 100%);border-radius:50%/100%;height:20%;position:absolute;top:-1.5px;left:-1.5px;right:-1.5px}.sn-cylinder .sn-content{padding-top:22px}.sn-head{justify-content:center;align-items:center;gap:6px;margin-bottom:1px;display:flex}.sn-chip{letter-spacing:1px;text-transform:uppercase;border-radius:4px;padding:2px 7px;font-size:9px;font-weight:700;line-height:1.2}.sn-shared-badge{color:#a29bfe;letter-spacing:.3px;background:#a29bfe33;border-radius:3px;padding:1px 5px;font-size:9px;font-weight:700}.sn-label{color:#fff;text-overflow:ellipsis;white-space:nowrap;text-align:center;width:100%;font-size:13px;font-weight:600;line-height:1.25;overflow:hidden}.sn-sub{color:#ffffff80;letter-spacing:.3px;text-transform:uppercase;margin-top:4px;font-size:10.5px;font-weight:500}.sn-badges{flex-wrap:wrap;justify-content:center;gap:4px;margin-top:3px;display:flex}.sn-badge{background:#ffffff14;border-radius:4px;padding:2px 5px;font-size:11px;line-height:1}@keyframes entryPulse{0%,to{box-shadow:0 0 0 0 color-mix(in srgb, var(--sn-accent,#6c5ce7) 55%, transparent), 0 0 22px color-mix(in srgb, var(--sn-accent,#6c5ce7) 40%, transparent), 0 6px 18px #00000073;opacity:1}50%{box-shadow:0 0 0 9px transparent, 0 0 10px color-mix(in srgb, var(--sn-accent,#6c5ce7) 18%, transparent), 0 6px 18px #00000073;opacity:.94}}.sn-entry .sn-fill{filter:drop-shadow(0 0 18px color-mix(in srgb, var(--sn-accent) 60%, transparent));border-width:2.5px;animation:2.8s ease-in-out infinite entryPulse}@supports not (filter:drop-shadow(0 0 0 color-mix(in srgb, white 50%, transparent))){.sn-entry .sn-fill{filter:none}}.sn-shared .sn-fill{filter:drop-shadow(0 0 8px #a29bfe80)}.sn-pipeline-header .sn-fill{border:1.5px solid var(--sn-border,#2a2a3d);border-radius:11px}.sn-pipeline-header .sn-content{text-align:center;align-items:center}.sn-header-trigger{letter-spacing:1.5px;font-size:9.5px;font-weight:700}.sn-header-label{color:#fff;text-overflow:ellipsis;overflow-wrap:anywhere;word-break:break-all;-webkit-line-clamp:3;-webkit-box-orient:vertical;max-width:100%;margin-top:3px;font-size:11.5px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.sn-header-sub{color:#ffffff80;text-overflow:ellipsis;white-space:nowrap;margin-top:3px;font-family:Menlo,Consolas,monospace;font-size:10px;overflow:hidden}.sn-expand-toggle{z-index:3;color:#ffffffb3;cursor:pointer;opacity:.45;pointer-events:all;background:#ffffff14;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:15px;font-weight:600;line-height:1;transition:all .15s;display:flex;position:absolute;top:6px;right:8px}.sn:hover .sn-expand-toggle,.sn-expand-toggle:focus-visible{opacity:1;outline:none}.sn-expand-toggle:hover{background:var(--sn-accent,#6c5ce7);color:#fff;border-color:var(--sn-accent,#6c5ce7);opacity:1;transform:scale(1.1)}.react-flow__node:has(.sn-expanded){z-index:50!important}.sn-desc-panel{z-index:100;text-align:left;cursor:default;background:linear-gradient(#14141e 0%,#0c0c14 100%);border:1.5px solid;border-radius:10px;width:300px;max-width:90vw;padding:12px 14px;font-family:Inter,system-ui,sans-serif;animation:.18s ease-out panelIn;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 18px 40px #000000b3,0 0 0 1px #ffffff08}@keyframes panelIn{0%{opacity:0;transform:translate(-50%)translateY(-4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.sn-desc-section{margin-bottom:10px}.sn-desc-section:last-child{margin-bottom:0}.sn-desc-section-title{letter-spacing:1px;text-transform:uppercase;color:#ffffff73;margin-bottom:4px;font-size:9.5px;font-weight:700}.sn-desc-text{color:#ffffffd9;font-size:12px;line-height:1.55}.sn-desc-code{color:#a29bfe;word-break:break-word;background:#6c5ce714;border-radius:5px;padding:4px 8px;font-family:Menlo,Consolas,monospace;font-size:11px;line-height:1.45;display:block}.sn-desc-behaviors{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.sn-desc-behaviors li{color:#ffffffbf;align-items:center;gap:7px;font-size:11.5px;line-height:1.4;display:flex}.sn-desc-icon{text-align:center;flex-shrink:0;width:16px;font-size:12px}.react-flow[data-low-detail=true] .sn-chip,.react-flow[data-low-detail=true] .sn-sub,.react-flow[data-low-detail=true] .sn-badges,.react-flow[data-low-detail=true] .sn-header-sub{opacity:0;transition:opacity .2s}.react-flow .sn-chip,.react-flow .sn-sub,.react-flow .sn-badges,.react-flow .sn-header-sub{transition:opacity .2s}.pv-root{background:#0a0a0f;flex:1;min-height:0;display:flex}.pv-picker{background:#0d0d14;border-right:1px solid #1a1a2a;flex-direction:column;flex-shrink:0;width:280px;transition:width .22s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:visible}.pv-picker.collapsed{width:44px}.pv-collapse-toggle{color:#888;cursor:pointer;z-index:20;background:#12121c;border:1px solid #2a2a3d;border-radius:4px;justify-content:center;align-items:center;width:22px;height:44px;padding:0;font-size:10px;transition:all .15s;display:flex;position:absolute;top:50%;right:-11px;transform:translateY(-50%)}.pv-collapse-toggle:hover{color:#fff;background:#6c5ce7;border-color:#6c5ce7}.pv-rail{flex-direction:column;align-items:center;gap:.75rem;height:100%;padding:.75rem .35rem;display:flex}.pv-rail-expand{color:#a29bfe;cursor:pointer;background:0 0;border:1px solid #2a2a3d;border-radius:7px;justify-content:center;align-items:center;width:32px;height:32px;margin-bottom:.5rem;font-size:1rem;transition:all .15s;display:flex}.pv-rail-expand:hover{background:#6c5ce71f;border-color:#6c5ce7}.pv-rail-stat{color:#a29bfe;-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;display:flex}.pv-rail-stat.dim{color:#555}.pv-rail-num{font-family:Menlo,Consolas,monospace;font-size:1.1rem;font-weight:700;line-height:1}.pv-rail-lbl{text-transform:uppercase;letter-spacing:1px;color:#fff6;margin-top:3px;font-size:.6rem;font-weight:600}.pv-search{border-bottom:1px solid #1a1a2a;padding:.65rem .8rem .5rem}.pv-search input{color:#e0e0e0;box-sizing:border-box;background:#12121c;border:1px solid #2a2a3d;border-radius:7px;outline:none;width:100%;padding:.55rem .8rem;font-size:.85rem;transition:border-color .18s}.pv-search input:focus{border-color:#6c5ce7}.pv-trigger-filters{border-bottom:1px solid #1a1a2a;flex-wrap:wrap;gap:.3rem;padding:.5rem .8rem;display:flex}.pv-trigger-chip{color:#6e6e88;cursor:pointer;background:0 0;border:1px solid #2a2a3d;border-radius:16px;align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.75rem;font-weight:600;transition:all .18s;display:inline-flex}.pv-trigger-chip.active{background:#ffffff0a}.pv-trigger-chip .trigger-icon{font-size:.75rem}.pv-trigger-chip .trigger-count{color:#ffffff8c;background:#ffffff14;border-radius:8px;padding:.05rem .4rem;font-family:Menlo,Consolas,monospace;font-size:.65rem}.pv-bulk{border-bottom:1px solid #1a1a2a;gap:.35rem;padding:.5rem .8rem;display:flex}.pv-bulk-btn{color:#a29bfe;cursor:pointer;background:#6c5ce71f;border:1px solid #6c5ce74d;border-radius:7px;flex:1;padding:.5rem;font-size:.8rem;font-weight:500;transition:all .18s}.pv-bulk-btn:hover{color:#fff;background:#6c5ce7;border-color:#6c5ce7}.pv-bulk-btn.ghost{color:#888;background:0 0;border-color:#2a2a3d}.pv-bulk-btn.ghost:hover{color:#ff7a68;background:#e74c3c14;border-color:#e74c3c66}.pv-list{flex:1;padding:.5rem 0;overflow-y:auto}.pv-list::-webkit-scrollbar{width:6px}.pv-list::-webkit-scrollbar-thumb{background:#2a2a3d;border-radius:3px}.pv-empty-list{color:#555;text-align:center;padding:1.5rem 1rem;font-size:.85rem}.pv-item{cursor:pointer;border-left:3px solid #0000;padding:.55rem .8rem .55rem .65rem;transition:background .15s,border-color .15s}.pv-item:hover{background:#15151f}.pv-item.selected{background:#6c5ce714}.pv-item-head{align-items:center;gap:.45rem;margin-bottom:.2rem;display:flex}.pv-item-icon{font-size:.85rem}.pv-item-label{color:#e6e6f0;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:600;overflow:hidden}.pv-item-trigger{letter-spacing:.3px;margin-bottom:.25rem;font-family:Menlo,Consolas,monospace;font-size:.72rem}.pv-item-context{color:#6e6e88;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.25rem;font-size:.72rem;overflow:hidden}.pv-item-stats{color:#444;font-family:Menlo,Consolas,monospace;font-size:.68rem}.pv-canvas-wrap{flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.pv-service-rail{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0c0c12b3;border-bottom:1px solid #20202e;flex-wrap:wrap;gap:8px;padding:10px 16px;display:flex}.pv-svc-chip{letter-spacing:.2px;cursor:pointer;color:#c6c6da;background:0 0;border:1px solid;border-radius:999px;align-items:center;gap:8px;padding:5px 12px 5px 10px;font-size:12px;font-weight:600;transition:background .15s,transform .1s,border-color .15s;display:inline-flex}.pv-svc-chip:hover{transform:translateY(-1px)}.pv-svc-chip.all{font-weight:700}.pv-svc-dot{border-radius:50%;width:8px;height:8px;box-shadow:0 0 6px}.pv-svc-name{white-space:nowrap}.pv-svc-count{opacity:.85;padding-left:2px;font-size:11px;font-weight:500}.pv-lane-label{color:#d6d6ea;background:#0a0a10bf;border:1px solid;border-radius:10px;align-items:center;gap:10px;max-width:100%;padding:5px 12px;font-size:12px;display:inline-flex}.pv-lane-chip{letter-spacing:1.4px;background:#ffffff05;border:1px solid;border-radius:999px;padding:2px 7px;font-size:9px;font-weight:800}.pv-lane-name{color:#fff;font-size:13px;font-weight:700}.pv-lane-count{opacity:.55;font-size:11px;font-weight:500}.pv-empty{color:#6e6e88;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.75rem;padding:3rem 2rem;display:flex}.pv-empty-icon{opacity:.4;margin-bottom:.5rem;font-size:3rem}.pv-empty h3{color:#e0e0e0;margin-bottom:.3rem;font-size:1.3rem;font-weight:700}.pv-empty p{color:#8888a0;max-width:480px;margin-bottom:1rem;font-size:.95rem;line-height:1.65}.pv-show-all{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c5ce7 0%,#a29bfe 100%);border:none;border-radius:9px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .18s}.pv-show-all:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6c5ce766}.pl-header{text-align:left;flex-direction:column;gap:3px;font-family:Inter,system-ui,sans-serif;display:flex}.pl-header-trigger{letter-spacing:1.5px;font-size:9.5px;font-weight:700}.pl-header-label{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.pl-header-context{color:#ffffff80;text-overflow:ellipsis;white-space:nowrap;font-family:Menlo,Consolas,monospace;font-size:10px;overflow:hidden}.pl-node{text-align:left;font-family:Inter,system-ui,sans-serif}.pl-node-chip{letter-spacing:1px;text-transform:uppercase;border-radius:4px;margin-bottom:4px;padding:2px 6px;font-size:9px;font-weight:700;display:inline-block}.pl-node-label{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;line-height:1.2;overflow:hidden}.pl-node-sub{color:#ffffff80;letter-spacing:.3px;text-transform:uppercase;margin-top:4px;font-size:10.5px;font-weight:500}.pl-node-badges{gap:4px;margin-top:6px;display:flex}.pl-badge{background:#ffffff14;border-radius:4px;padding:2px 5px;font-size:11px}.pl-shared-badge{color:#a29bfe;letter-spacing:.3px;background:#a29bfe33;border-radius:3px;margin-left:6px;padding:1px 5px;font-size:9px;font-weight:700}.react-flow__node.pv-decorative .react-flow__handle{display:none!important}.react-flow__node.pv-decorative{pointer-events:none;box-shadow:none!important}.pv-flow-region{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.pv-canvas-toolbar{z-index:10;gap:6px;display:flex;position:absolute;top:12px;left:12px}.pv-tool-btn{color:#a0a0b8;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#12121ceb;border:1px solid #2a2a3d;border-radius:7px;padding:6px 12px;font-size:.78rem;font-weight:500;transition:all .18s}.pv-tool-btn:hover{color:#fff;background:#1e1b32f2;border-color:#6c5ce7}.pv-tool-btn.active{color:#fdcb6e;background:#2c210ad9;border-color:#fdcb6e66}.pv-help-hint{color:#ffffff4d;pointer-events:none;text-align:center;font-size:.72rem;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}@media (width<=1000px){.pv-picker{width:260px}}.dbv-root{background:#0a0a0f;width:100%;height:100%;position:relative}.dbv-empty{color:#888;text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:40px;display:flex}.dbv-empty-icon{opacity:.5;margin-bottom:12px;font-size:48px}.dbv-empty h3{color:#d0d0e0;margin:0 0 8px;font-size:16px;font-weight:600}.dbv-empty p{opacity:.7;max-width:420px;font-size:13px;line-height:1.5}.dbv-db-label{font:12px var(--vscode-font-family,system-ui);color:#e6f6ee;background:#0a0a10bf;border:1px solid #55efc466;border-radius:8px;align-items:center;gap:10px;padding:5px 12px;display:inline-flex}.dbv-db-chip{letter-spacing:1.4px;color:#55efc4;border:1px solid #55efc466;border-radius:999px;padding:1px 7px;font-size:9px;font-weight:800}.dbv-db-name{font-size:13px;font-weight:700}.dbv-db-count{opacity:.55;font-size:11px}.dbv-tbl{color:#e6e6ff;text-align:left;flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.dbv-tbl-header{background:linear-gradient(135deg,#55efc433 0%,#55efc40d 100%);border-bottom:1px solid #55efc44d;justify-content:space-between;align-items:center;height:38px;padding:0 12px;display:flex}.dbv-tbl-name{letter-spacing:.2px;color:#aef3d8;font-size:13px;font-weight:700}.dbv-tbl-usage{opacity:.85;gap:6px;font-size:10px;display:flex}.dbv-usage-w{color:#ffb572}.dbv-usage-r{color:#74b9ff}.dbv-tbl-cols{flex:1;padding:12px 0;overflow:hidden}.dbv-col{justify-content:space-between;align-items:center;height:22px;padding:2px 12px;font-size:11px;line-height:1.5;display:flex}.dbv-col+.dbv-col{border-top:1px solid #ffffff0a}.dbv-col-name{font-family:var(--vscode-editor-font-family,"Menlo", monospace);color:#d6d6ee;align-items:center;gap:5px;display:inline-flex}.dbv-col-pk{color:#ffd966;letter-spacing:.5px;border:1px solid #ffd96680;border-radius:3px;padding:0 4px;font-size:8px;font-weight:800}.dbv-col-uq{color:#c2b0ff;letter-spacing:.5px;border:1px solid #c2b0ff80;border-radius:3px;padding:0 4px;font-size:8px;font-weight:800}.dbv-col-nn{color:#999;letter-spacing:.5px;border:1px solid #9996;border-radius:3px;padding:0 4px;font-size:8px;font-weight:800}.dbv-col-type{font-family:var(--vscode-editor-font-family,"Menlo", monospace);color:#8ad8ee;opacity:.85;font-size:10px}:root{--bg:#0a0a0f;--bg-elev1:#0e0e16;--bg-elev2:#12121c;--bg-elev3:#18182a;--border:#1e1e2e;--border-strong:#2a2a3d;--border-active:#6c5ce7;--text:#d6d6e0;--text-muted:#8a8aa3;--text-dim:#5a5a72;--accent:#6c5ce7;--accent-soft:#6c5ce71f;--accent-glow:#6c5ce759}.workspace{background:var(--bg);height:100vh;color:var(--text);flex-direction:column;display:flex;overflow:hidden}.ws-body{flex:1;min-height:0;display:flex}.ws-btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:.55rem 1.1rem;font-size:.85rem;font-weight:600;transition:all .18s}.ws-btn-primary:hover{box-shadow:0 4px 12px var(--accent-glow);background:#7d6ff0;transform:translateY(-1px)}.ws-btn-primary:disabled{opacity:.6;cursor:default}.ws-btn-ghost{color:var(--text-muted);border:1px solid var(--border-strong);cursor:pointer;background:0 0;border-radius:7px;padding:.55rem 1rem;font-size:.85rem;transition:all .18s}.ws-btn-ghost:hover{color:var(--text);border-color:var(--text-dim)}.ws-main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex}.ws-toolbar{background:var(--bg-elev1);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.9rem 1.75rem;display:flex}.ws-stats{color:var(--text-muted);gap:1.5rem;font-size:.82rem;font-weight:500;display:flex}.ws-stats span{align-items:center;gap:.35rem;display:inline-flex}.ws-stats .stat-num{color:#fff;font-variant-numeric:tabular-nums;font-weight:700}.ws-toolbar-actions{align-items:center;gap:.75rem;display:flex}.ws-tabs{background:var(--bg-elev2,#ffffff0a);border:1px solid var(--border);border-radius:10px;gap:4px;padding:3px;display:inline-flex}.ws-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;padding:.45rem .95rem;font-size:.82rem;font-weight:600;transition:all .16s;display:inline-flex}.ws-tab:hover:not(:disabled):not(.active){color:var(--text);background:#ffffff0a}.ws-tab.active{color:#cfc7ff;background:#8b7dff2e;box-shadow:inset 0 0 0 1px #8b7dff73}.ws-tab:disabled{opacity:.4;cursor:not-allowed}.ws-reset-btn{color:#ff7a68;cursor:pointer;background:0 0;border:1px solid #e74c3c59;border-radius:9px;align-items:center;gap:.4rem;padding:.55rem .9rem;font-size:.85rem;font-weight:500;transition:all .18s;display:inline-flex}.ws-reset-btn:hover{color:#ff9080;background:#e74c3c1f;border-color:#ff7a68}.ws-import-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c5ce7 0%,#a29bfe 100%);border:none;border-radius:9px;align-items:center;gap:.5rem;padding:.55rem 1.1rem;font-size:.88rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 10px #6c5ce74d}.ws-import-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 18px #6c5ce780}.ws-import-btn:disabled{opacity:.6;cursor:default;transform:none}.ws-import-btn code{background:#ffffff2e;border-radius:4px;padding:.1rem .4rem;font-family:Menlo,Consolas,monospace;font-size:.78rem;font-weight:500}.ws-toast{background:var(--accent);color:#fff;z-index:100;border-radius:10px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;animation:.25s toastIn;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #6c5ce766}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.ws-error{color:#ff7a68;background:#e74c3c1a;border-bottom:1px solid #e74c3c66;align-items:center;gap:.5rem;padding:.65rem 1.75rem;font-size:.88rem;display:flex}.ws-empty-diagram{color:var(--text-dim);text-align:center;border:2px dashed #0000;border-radius:16px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.85rem;margin:2rem;padding:3rem 2rem;transition:background .2s,border-color .2s;display:flex}.ws-empty-diagram.drag-over{background:var(--accent-soft);border-color:var(--accent)}.ws-empty-diagram h3{color:var(--text);margin-bottom:.35rem;font-size:1.3rem;font-weight:700}.ws-empty-diagram p{max-width:460px;color:var(--text-muted);margin-bottom:1rem;font-size:.95rem;line-height:1.65}.ws-empty-diagram code{color:#a29bfe;background:var(--accent-soft);border-radius:4px;padding:.1rem .45rem;font-family:Menlo,Consolas,monospace;font-size:.88em}.ws-empty-actions{gap:.75rem;margin-top:.5rem;display:flex}.empty-icon{opacity:.3;margin-bottom:.5rem;font-size:3.5rem}.react-flow__controls{overflow:hidden;background:var(--bg-elev2)!important;border:1px solid var(--border)!important;border-radius:8px!important;box-shadow:0 4px 12px #0000004d!important}.react-flow__controls button{background:var(--bg-elev2)!important;border-bottom:1px solid var(--border)!important;color:var(--text-muted)!important;fill:var(--text-muted)!important;width:32px!important;height:32px!important}.react-flow__controls button:hover{background:var(--accent-soft)!important;color:#a29bfe!important;fill:#a29bfe!important}.react-flow__minimap{border:1px solid var(--border)!important;border-radius:8px!important;box-shadow:0 4px 12px #0006!important}.react-flow__attribution{opacity:.4;color:var(--text-dim)!important;background:0 0!important}.react-flow__edge-path{transition:stroke-width .15s}.react-flow__edge:hover .react-flow__edge-path{stroke-width:3px!important}@media (width<=900px){.ws-stats{display:none}}*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;-webkit-font-smoothing:antialiased;background:#0a0a0f;font-family:Inter,system-ui,-apple-system,sans-serif}a{color:inherit}.logo{color:#fff;letter-spacing:-.5px;font-size:1.5rem;font-weight:700;text-decoration:none}
