.landing{min-height:100vh;background:var(--primary-bg);background-color:#0a0a0a;overflow-x:hidden;position:relative}.landing-bg{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;opacity:.5}.glow-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s ease-in-out infinite}.orb-1{width:600px;height:600px;background:radial-gradient(circle,#df3e53 0%,transparent 70%);top:-200px;right:-100px;animation-delay:0s}.orb-2{width:500px;height:500px;background:radial-gradient(circle,#3b82f6 0%,transparent 70%);bottom:-200px;left:-100px;animation-delay:-7s}.orb-3{width:400px;height:400px;background:radial-gradient(circle,#8b5cf6 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08)}.landing-nav .container{max-width:1400px;margin:0 auto;padding:0 2rem;height:70px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.5rem}.logo-icon{font-size:1.5rem}.logo h1{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-primary)}.version-badge{font-size:.65rem;font-weight:600;padding:.2rem .5rem;background:linear-gradient(135deg,#df3e53,#ff6b6b);color:#fff;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.nav-links{display:flex;align-items:center;gap:2rem;flex-shrink:0}.nav-link{color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:color .2s;display:flex;align-items:center;text-decoration:none;white-space:nowrap}.nav-link:hover{color:var(--text-primary)}.nav-link svg{fill:currentColor}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;text-decoration:none}.btn-primary{background:linear-gradient(135deg,#df3e53,#ff6b6b);color:#fff;box-shadow:0 4px 16px #df3e534d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #df3e5366}.btn-secondary{background:#ffffff0d;color:var(--text-primary);border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn-lg{padding:1rem 2rem;font-size:1rem}.glow-button{position:relative;overflow:hidden}.glow-button:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(135deg,#df3e53,#ff6b6b,#df3e53);border-radius:10px;opacity:0;z-index:-1;transition:opacity .3s;animation:glow-rotate 3s linear infinite}.glow-button:hover:before{opacity:1}@keyframes glow-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero{min-height:100vh;display:flex;align-items:center;padding:120px 2rem 80px;position:relative;z-index:1}.hero .container{max-width:1400px;margin:0 auto;width:100%}.hero-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center}.hero-content{max-width:600px}.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#df3e531a;border:1px solid rgba(223,62,83,.3);border-radius:9999px;font-size:.85rem;font-weight:500;color:#df3e53;margin-bottom:1.5rem}.pulse-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.hero-title{font-size:4rem;font-weight:800;line-height:1.1;margin:0 0 1.5rem;color:var(--text-primary)}.hero-title .text-accent{background:linear-gradient(135deg,#df3e53,#ff8a80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.typing-cursor{color:#df3e53;animation:blink 1s step-end infinite;font-weight:400}@keyframes blink{50%{opacity:0}}.hero-subtitle{font-size:1.25rem;line-height:1.7;color:var(--text-secondary);margin-bottom:2rem}.hero-actions{display:flex;gap:1rem;margin-bottom:3rem}.hero-stats{display:flex;align-items:center;gap:2rem}.stat{text-align:center}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.85rem;color:var(--text-tertiary)}.stat-divider{width:1px;height:40px;background:#ffffff1a}.hero-visual{position:relative}.dashboard-preview{background:#14141ee6;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d;transform:perspective(1000px) rotateY(-5deg) rotateX(5deg);transition:transform .5s}.dashboard-preview:hover{transform:perspective(1000px) rotateY(-2deg) rotateX(2deg)}.preview-header{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}.preview-nav{display:flex;align-items:center;gap:1.5rem}.preview-logo{font-weight:700;font-size:.9rem;color:var(--text-primary)}.preview-tabs{display:flex;gap:1rem}.preview-tabs span{font-size:.75rem;color:var(--text-tertiary);cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s}.preview-tabs span.active{color:var(--text-primary);background:#ffffff1a}.preview-content{display:flex;min-height:300px}.preview-sidebar{width:200px;border-right:1px solid rgba(255,255,255,.08);padding:1rem;display:flex;flex-direction:column;gap:.5rem}.preview-node{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .2s}.preview-node:hover,.preview-node.active{background:#ffffff0d;color:var(--text-primary)}.preview-node .node-icon{font-size:1rem}.preview-node .status{width:6px;height:6px;border-radius:50%;margin-left:auto}.preview-node .status.running{background:#22c55e;box-shadow:0 0 8px #22c55e80}.preview-node .status.pending{background:#f59e0b;box-shadow:0 0 8px #f59e0b80}.preview-canvas{flex:1;padding:1.5rem;position:relative;background:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:20px 20px}.canvas-node{position:absolute;padding:.75rem 1rem;background:#1e1e2de6;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:.75rem;animation:node-float 3s ease-in-out infinite}.canvas-node .node-header{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.canvas-node .node-stats{color:var(--text-tertiary);font-size:.65rem}.canvas-node.node-1{top:20%;left:15%;animation-delay:0s}.canvas-node.node-2{top:35%;right:20%;animation-delay:-1s}.canvas-node.node-3{bottom:25%;left:35%;animation-delay:-2s}@keyframes node-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.connection-line{position:absolute;width:200px;height:100px;top:25%;left:30%;overflow:visible}.animated-path{stroke-dasharray:200;stroke-dashoffset:200;animation:draw-line 2s ease-in-out infinite}@keyframes draw-line{0%{stroke-dashoffset:200}50%{stroke-dashoffset:0}to{stroke-dashoffset:-200}}.terminal-preview{background:#0a0a0ff2;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;margin-top:1rem}.terminal-header{padding:.75rem 1rem;display:flex;align-items:center;gap:1rem;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.08)}.terminal-dots{display:flex;gap:6px}.terminal-dots .dot{width:12px;height:12px;border-radius:50%}.dot.red{background:#ff5f56}.dot.yellow{background:#ffbd2e}.dot.green{background:#27c93f}.terminal-title{font-size:.75rem;color:var(--text-tertiary)}.terminal-body{padding:1rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;line-height:1.8;height:280px;min-height:280px;overflow-y:auto}.terminal-line{opacity:0;animation:terminal-line-in .3s ease-out forwards}.terminal-line.command{color:var(--text-primary)}.terminal-line.output{color:var(--text-tertiary);padding-left:1rem}.terminal-line.success{color:#22c55e}.terminal-line.info{color:#3b82f6;padding-left:1rem}@keyframes terminal-line-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.terminal-cursor{color:#22c55e;animation:blink 1s step-end infinite}.features{padding:120px 2rem;position:relative;z-index:1}.features .container{max-width:1400px;margin:0 auto}.section-header{text-align:center;margin-bottom:4rem}.section-tag{display:inline-block;padding:.5rem 1rem;background:#df3e531a;border:1px solid rgba(223,62,83,.2);border-radius:9999px;font-size:.85rem;font-weight:600;color:#df3e53;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.section-header h2{font-size:3rem;font-weight:800;margin:0 0 1rem;color:var(--text-primary)}.section-header p{font-size:1.2rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.feature-card{background:#14141e99;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:2rem;position:relative;overflow:hidden;transition:all .3s}.feature-card:hover{border-color:#df3e534d;transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.feature-card.featured{grid-column:span 2;grid-row:span 2}.feature-glow{position:absolute;top:0;right:0;width:200px;height:200px;background:radial-gradient(circle,rgba(223,62,83,.15) 0%,transparent 70%);pointer-events:none}.feature-icon-wrapper{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;background:linear-gradient(135deg,#df3e5333,#df3e530d);border:1px solid rgba(223,62,83,.3)}.feature-icon-wrapper svg{width:24px;height:24px;stroke:#df3e53}.feature-icon-wrapper.purple{background:linear-gradient(135deg,#8b5cf633,#8b5cf60d);border-color:#8b5cf64d}.feature-icon-wrapper.purple svg{stroke:#8b5cf6}.feature-icon-wrapper.green{background:linear-gradient(135deg,#22c55e33,#22c55e0d);border-color:#22c55e4d}.feature-icon-wrapper.green svg{stroke:#22c55e}.feature-icon-wrapper.orange{background:linear-gradient(135deg,#f9731633,#f973160d);border-color:#f973164d}.feature-icon-wrapper.orange svg{stroke:#f97316}.feature-icon-wrapper.pink{background:linear-gradient(135deg,#ec489933,#ec48990d);border-color:#ec48994d}.feature-icon-wrapper.pink svg{stroke:#ec4899}.feature-icon-wrapper.blue{background:linear-gradient(135deg,#3b82f633,#3b82f60d);border-color:#3b82f64d}.feature-icon-wrapper.blue svg{stroke:#3b82f6}.feature-card h3{font-size:1.25rem;font-weight:700;margin:0 0 .75rem;color:var(--text-primary)}.feature-card p{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0}.feature-preview{margin-top:1.5rem}.how-it-works{padding:120px 2rem;position:relative;z-index:1}.how-it-works .container{max-width:1200px;margin:0 auto}.workflow-timeline{margin-top:4rem;display:flex;flex-direction:column;gap:0}.workflow-step{display:flex;gap:2rem}.step-indicator{display:flex;flex-direction:column;align-items:center;width:80px;flex-shrink:0}.step-number{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,#df3e53,#ff6b6b);color:#fff;font-size:1.25rem;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #df3e534d}.step-line{flex:1;width:2px;background:linear-gradient(180deg,#df3e53,#df3e531a);margin:.5rem 0;min-height:60px}.step-content{flex:1;padding-bottom:3rem}.step-icon{width:56px;height:56px;border-radius:12px;background:#df3e531a;border:1px solid rgba(223,62,83,.2);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.step-icon svg{width:24px;height:24px;stroke:#df3e53}.step-icon.purple{background:#8b5cf61a;border-color:#8b5cf633}.step-icon.purple svg{stroke:#8b5cf6}.step-icon.green{background:#22c55e1a;border-color:#22c55e33}.step-icon.green svg{stroke:#22c55e}.step-icon.orange{background:#f973161a;border-color:#f9731633}.step-icon.orange svg{stroke:#f97316}.step-content h3{font-size:1.5rem;font-weight:700;margin:0 0 .75rem;color:var(--text-primary)}.step-content p{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin:0;max-width:400px}.cta-section{padding:120px 2rem;position:relative;z-index:1}.cta-section .container{max-width:1200px;margin:0 auto}.cta-card{background:linear-gradient(135deg,#df3e531a,#8b5cf61a);border:1px solid rgba(223,62,83,.2);border-radius:24px;padding:4rem;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:4rem}.cta-glow{position:absolute;top:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(223,62,83,.2) 0%,transparent 70%);pointer-events:none}.cta-content{position:relative;z-index:1;max-width:500px}.cta-content h2{font-size:2.5rem;font-weight:800;margin:0 0 1rem;color:var(--text-primary)}.cta-content p{font-size:1.1rem;color:var(--text-secondary);margin:0 0 2rem;line-height:1.6}.cta-actions{display:flex;align-items:center;gap:1rem}.cta-note{font-size:.85rem;color:var(--text-tertiary)}.cta-visual{position:relative;width:300px;height:200px}.floating-cards{position:relative;width:100%;height:100%}.floating-card{position:absolute;padding:.75rem 1.25rem;background:#14141ee6;border:1px solid rgba(255,255,255,.15);border-radius:10px;font-size:.9rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;animation:card-float 4s ease-in-out infinite;box-shadow:0 8px 24px #0000004d}.floating-card span{font-size:1.1rem}.floating-card.card-1{top:0;left:0;animation-delay:0s}.floating-card.card-2{top:50%;right:0;animation-delay:-1.3s}.floating-card.card-3{bottom:0;left:30%;animation-delay:-2.6s}@keyframes card-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.landing-footer{padding:80px 2rem 40px;border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:1}.landing-footer .container{max-width:1400px;margin:0 auto}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;margin-bottom:4rem}.footer-brand{max-width:300px}.footer-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.footer-logo .logo-icon{font-size:1.5rem}.footer-logo h4{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-primary)}.footer-brand p{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0 0 1.5rem}.social-links{display:flex;gap:.75rem}.social-link{width:40px;height:40px;border-radius:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.social-link:hover{background:#df3e531a;border-color:#df3e534d;color:#df3e53}.social-link svg{fill:currentColor}.footer-links-group h5{font-size:.85rem;font-weight:700;color:var(--text-primary);margin:0 0 1.5rem;text-transform:uppercase;letter-spacing:.05em}.footer-links-group ul{list-style:none;padding:0;margin:0}.footer-links-group li{margin-bottom:.75rem}.footer-links-group a{font-size:.95rem;color:var(--text-secondary);text-decoration:none;transition:color .2s}.footer-links-group a:hover{color:var(--text-primary)}.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08)}.footer-bottom p{margin:0;font-size:.9rem;color:var(--text-tertiary)}.footer-legal{display:flex;gap:2rem}.footer-legal a{font-size:.9rem;color:var(--text-tertiary);text-decoration:none;transition:color .2s}.footer-legal a:hover{color:var(--text-primary)}@media (max-width: 1200px){.hero-layout{grid-template-columns:1fr;gap:3rem;text-align:center}.hero-content{max-width:100%}.hero-actions,.hero-stats{justify-content:center}.dashboard-preview{transform:none}.features-grid{grid-template-columns:repeat(2,1fr)}.feature-card.featured{grid-column:span 2;grid-row:span 1}.footer-grid{grid-template-columns:1fr 1fr;gap:3rem}}@media (max-width: 900px){.nav-links .nav-link:not(:last-child):not(.github-link){display:none}.nav-links{gap:1.5rem}}@media (max-width: 768px){.landing-nav .container{padding:0 1rem;height:60px}.nav-links{gap:.75rem}.nav-link:not(.github-link):not(.btn){display:none}.nav-link.github-link svg{width:18px;height:18px}.logo h1,.logo-icon{font-size:1.25rem}.version-badge{font-size:.55rem;padding:.15rem .4rem}.btn.btn-primary{padding:.6rem 1rem;font-size:.85rem}.hero{padding:100px 1.5rem 60px}.hero-title{font-size:2.5rem;word-wrap:break-word;overflow-wrap:break-word}.hero-subtitle{font-size:1rem;line-height:1.6}.hero-actions{flex-direction:column;gap:.75rem}.hero-actions .btn{width:100%;justify-content:center}.hero-stats{flex-wrap:wrap;gap:1.5rem}.preview-sidebar{display:none}.section-header h2{font-size:2rem}.features-grid{grid-template-columns:1fr}.feature-card.featured{grid-column:span 1}.workflow-step{flex-direction:column;gap:1rem}.step-indicator{flex-direction:row;width:100%}.step-line{width:100%;height:2px;min-height:auto;margin:0 .5rem}.cta-card{flex-direction:column;text-align:center;padding:3rem 2rem}.cta-visual{display:none}.cta-actions{flex-direction:column}.footer-grid{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero{padding:80px 1rem 40px}.landing-nav .container{height:56px}.logo h1{font-size:1.1rem}.btn.btn-primary{padding:.5rem .9rem;font-size:.8rem}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);background-color:#0a0a0a;padding:2rem;position:relative;overflow:hidden}.auth-bg{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.auth-bg .grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;opacity:.5}.auth-bg .glow-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s ease-in-out infinite}.auth-bg .orb-1{width:500px;height:500px;background:radial-gradient(circle,#df3e53 0%,transparent 70%);top:-150px;right:-100px;animation-delay:0s}.auth-bg .orb-2{width:400px;height:400px;background:radial-gradient(circle,#3b82f6 0%,transparent 70%);bottom:-150px;left:-100px;animation-delay:-7s}.auth-bg .orb-3{width:300px;height:300px;background:radial-gradient(circle,#8b5cf6 0%,transparent 70%);top:50%;left:30%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-10px) scale(1.02)}}.back-home{position:fixed;top:2rem;left:2rem;display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;z-index:100;padding:.75rem 1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s}.back-home:hover{color:var(--text-primary);background:#ffffff14;border-color:#ffffff26;transform:translate(-4px)}.back-home svg{transition:transform .2s}.back-home:hover svg{transform:translate(-4px)}.auth-container{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1100px;width:100%;position:relative;z-index:2}.auth-card{background:#121218cc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:3rem;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:2.5rem}.auth-logo{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.auth-logo .logo-icon{font-size:1.75rem}.auth-logo .logo-text{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.auth-logo .version-badge{font-size:.65rem;font-weight:600;padding:.2rem .5rem;background:linear-gradient(135deg,#df3e53,#ff6b6b);color:#fff;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.auth-header h2{font-size:1.75rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary)}.auth-header p{color:var(--text-secondary);font-size:.95rem;margin:0}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:var(--text-primary);font-size:.9rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none;transition:color .2s;z-index:1}.form-group input{width:100%;padding:.875rem 1rem .875rem 3rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text-primary);font-size:.95rem;transition:all .2s;box-sizing:border-box}.form-group input::placeholder{color:var(--text-tertiary)}.form-group input:focus{outline:none;border-color:#df3e53;background:#ffffff0d;box-shadow:0 0 0 3px #df3e5326}.form-group input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:#df3e53}.form-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#ef4444;display:flex;align-items:center;gap:.75rem;font-size:.9rem;animation:shake .4s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.btn-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#df3e53,#ff6b6b);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #df3e534d;position:relative;overflow:hidden}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #df3e5366}.btn-submit:active:not(:disabled){transform:translateY(0)}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.btn-submit svg{transition:transform .2s}.btn-submit:hover:not(:disabled) svg{transform:translate(4px)}.glow-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.glow-button:hover:before{left:100%}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.auth-footer{text-align:center;padding-top:2rem;margin-top:1.5rem;border-top:1px solid rgba(255,255,255,.08)}.invite-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#df3e531a;border:1px solid rgba(223,62,83,.3);border-radius:9999px;font-size:.85rem;font-weight:500;color:#df3e53}.footer-text{color:var(--text-tertiary);font-size:.85rem;margin-top:.75rem}.auth-features{display:flex;flex-direction:column;justify-content:center;animation:slideUp .6s ease-out .15s both}.auth-features h3{font-size:1.5rem;font-weight:700;margin:0 0 2rem;color:var(--text-primary)}.feature-list{display:flex;flex-direction:column;gap:1.5rem}.feature-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px;transition:all .2s}.feature-item:hover{background:#ffffff0d;border-color:#df3e534d;transform:translate(8px)}.feature-icon{font-size:1.5rem;line-height:1}.feature-content h4{font-size:1rem;font-weight:600;margin:0 0 .25rem;color:var(--text-primary)}.feature-content p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}@media (max-width: 900px){.auth-container{grid-template-columns:1fr;max-width:480px}.auth-features{display:none}.back-home{top:1rem;left:1rem;padding:.5rem .75rem;font-size:.85rem}}@media (max-width: 480px){.auth-page{padding:4rem 1rem 1rem}.auth-card{padding:2rem 1.5rem}.auth-header h2{font-size:1.5rem}.form-group input{padding:.75rem .875rem .75rem 2.75rem}.btn-submit{padding:.875rem 1.25rem}}.header,.railway-header{display:flex;flex-direction:column;background:#0a0a0fd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(223,62,83,.15);z-index:100;box-shadow:0 4px 24px #0000004d}.header-top{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 24px;gap:24px}.header-left{display:flex;align-items:center;gap:16px;min-width:0}.logo-section{display:flex;align-items:center;gap:8px}.logo{font-size:24px;line-height:1}.logo-text{font-size:18px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.back-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border:1px solid var(--border-color);color:var(--text-primary);font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.back-button:hover{background:var(--hover-bg);border-color:var(--border-color-hover)}.back-button:active{transform:scale(.98)}.divider,.header-divider{display:inline-block;width:1px;height:28px;background:var(--border-color);opacity:.5;margin:0 4px;color:var(--text-tertiary);font-size:16px}.project-dropdown,.env-dropdown{position:relative}.dropdown-trigger{display:flex;align-items:center;gap:6px;padding:6px 10px;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.dropdown-trigger:hover{background:var(--hover-bg);border-color:var(--border-color)}.env-trigger{gap:8px}.env-dot{width:8px;height:8px;border-radius:50%}.env-dot.env-production{background:#10b981}.env-dot.env-staging{background:#f59e0b}.env-dot.env-development{background:#3b82f6}.env-name{text-transform:capitalize;font-size:13px}.dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;min-width:160px;background:var(--dropdown-bg, var(--secondary-bg));border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;overflow:hidden;z-index:200;animation:slideDown .2s ease}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:transparent;border:none;color:var(--text-primary);font-size:13px;text-align:left;cursor:pointer;transition:all .15s ease}.dropdown-item:hover{background:var(--hover-bg)}.dropdown-item.active{background:var(--accent-light);color:var(--accent-color)}.header-tabs{display:flex;align-items:center;gap:4px;margin:0 auto}.header-tab{padding:8px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:6px;text-transform:capitalize}.header-tab:hover{color:var(--text-primary);background:#df3e531a}.header-tab.active{color:#df3e53;background:#df3e5326;border-bottom:2px solid #df3e53}.header-toolbar{display:flex;align-items:center;gap:4px;margin-right:12px;padding-right:12px;border-right:1px solid var(--border-color)}.toolbar-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:16px}.toolbar-icon:hover{background:#df3e531a;color:#df3e53}.toolbar-icon.active{background:#df3e5326;color:#df3e53}.toolbar-icon .icon{font-size:16px}.notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid var(--header-bg)}.header-icon-btn{position:relative}.project-info{display:flex;align-items:center;gap:12px;min-width:0}.project-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.environment-badge{display:inline-flex;padding:4px 10px;background:var(--env-badge-bg);border:1px solid var(--env-badge-border);border-radius:4px;font-size:11px;font-weight:500;color:var(--env-badge-text);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.header-right{display:flex;align-items:center;gap:12px;margin-left:auto}.header-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .2s ease}.header-icon-btn:hover{background:#df3e5326;border-color:#df3e534d;color:#df3e53}.user-menu{position:relative}.user-avatar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:linear-gradient(135deg,#df3e5333,#ff6b6b1a);border:1px solid rgba(223,62,83,.3);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:18px}.user-avatar-btn:hover{background:linear-gradient(135deg,#df3e534d,#ff6b6b33);border-color:#df3e5380;transform:scale(1.02)}.avatar{display:inline-flex;align-items:center;justify-content:center}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;min-width:200px;background:#0f0f14f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(223,62,83,.2);border-radius:12px;box-shadow:0 8px 32px #00000080,0 0 0 1px #ffffff0d;overflow:hidden;z-index:200;animation:slideDown .2s ease}.user-info{padding:12px 14px;border-bottom:1px solid var(--border-color)}.user-name{font-size:14px;font-weight:600;color:var(--text-primary)}.user-email{font-size:12px;color:var(--text-secondary);margin-top:2px}.menu-item{display:block;width:100%;padding:10px 14px;background:transparent;border:none;color:var(--text-primary);font-size:13px;text-align:left;cursor:pointer;transition:all .15s ease}.menu-item:hover{background:var(--hover-bg);color:var(--text-primary)}.menu-divider{height:1px;background:var(--border-color);margin:6px 0}.menu-item.logout{color:#ef4444}.menu-item.logout:hover{background:#ef44441a}.menu-item.admin-link{color:#df3e53;font-weight:500}.menu-item.admin-link:hover{background:#df3e531a}.header-tabs{display:flex;height:48px;background:var(--tabs-bg);border-top:1px solid var(--border-color);overflow-x:auto;overflow-y:hidden}.tabs-container{display:flex;gap:0;padding:0 24px;align-items:center}.tab{position:relative;padding:12px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:color .2s ease;white-space:nowrap;text-transform:capitalize}.tab:hover,.tab.active{color:var(--text-primary)}.tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent-color);animation:slideIn .2s ease}@keyframes slideIn{0%{width:0}to{width:100%}}.sync-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--accent-light);border:1px solid var(--accent-color);color:var(--accent-color);font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease}.sync-button:hover{background:var(--accent-color);color:#fff}.sync-button:disabled{opacity:.6;cursor:not-allowed}.sync-button.syncing svg{animation:spin 1s linear infinite}.tools-dropdown-container{position:relative}.tools-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease}.tools-trigger:hover{background:var(--hover-bg);border-color:var(--border-color-hover);color:var(--text-primary)}.tools-trigger.active{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.tools-trigger .chevron{transition:transform .2s ease}.tools-trigger.active .chevron{transform:rotate(180deg)}.tools-dropdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199}.tools-dropdown{position:absolute;top:100%;right:0;margin-top:8px;width:320px;background:var(--dropdown-bg, var(--secondary-bg));border:1px solid var(--border-color);border-radius:12px;box-shadow:0 16px 48px #0006;z-index:200;animation:slideDown .2s ease;overflow:hidden}.tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:8px}.tool-grid-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.tool-grid-item:hover{background:var(--hover-bg);border-color:var(--border-color);color:var(--text-primary)}.tool-grid-item.active{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.tool-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--hover-bg);border-radius:10px;transition:all .2s ease}.tool-grid-item:hover .tool-icon{background:var(--accent-light)}.tool-grid-item.active .tool-icon{background:var(--accent-color);color:#fff}.tool-label{font-size:12px;font-weight:500;text-align:center}.tool-shortcut{font-size:10px;color:var(--text-tertiary);padding:2px 6px;background:var(--hover-bg);border-radius:4px}@media (max-width: 768px){.header-top{padding:0 16px;gap:12px;height:56px}.logo-text{font-size:16px}.project-name{font-size:13px}.environment-badge{display:none}.header-icon-btn,.user-avatar-btn{width:32px;height:32px}.tabs-container{padding:0 16px}.tab{padding:10px 12px;font-size:12px}}@media (max-width: 480px){.project-info,.divider{display:none}.header-tabs{font-size:12px}.tab{padding:10px 8px}}.draggable-panel{position:fixed;z-index:1000;background:#121218f2;border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 8px 32px #0006,0 0 0 1px #ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s ease,width .2s ease}.draggable-panel.dragging{box-shadow:0 12px 48px #0009,0 0 0 2px #5865f24d;cursor:grabbing;-webkit-user-select:none;user-select:none}.draggable-panel.minimized,.draggable-panel.collapsed{height:auto!important;max-height:none!important}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.06);cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0}.panel-header:active{cursor:grabbing}.panel-header-left{display:flex;align-items:center;gap:10px}.panel-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#5865f226;border-radius:6px;color:var(--accent-color)}.panel-icon svg{width:16px;height:16px}.panel-title{font-size:13px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.panel-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.panel-status-dot.active{animation:pulse-status 2s ease-in-out infinite}.panel-status-dot.loading{animation:pulse-status .8s ease-in-out infinite}@keyframes pulse-status{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.panel-actions{display:flex;align-items:center;gap:4px}.panel-action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:transparent;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.panel-action-btn:hover{background:#ffffff14;color:var(--text-primary)}.panel-action-btn.close:hover{background:#ef444426;color:#ef4444}.panel-minimized-status{padding:8px 14px;display:flex;align-items:center;gap:8px}.status-indicator{font-size:11px;font-weight:500;padding:4px 10px;border-radius:100px;text-transform:capitalize}.status-indicator.active{background:#10b98126;color:#10b981}.status-indicator.loading{background:#f59e0b26;color:#f59e0b}.status-indicator.error{background:#ef444426;color:#ef4444}.status-indicator.idle{background:#6b728026;color:#9ca3af}.panel-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.panel-content>*{flex:1;overflow-y:auto}@media (max-width: 768px){.draggable-panel{left:10px!important;right:10px!important;width:auto!important;max-width:none!important}}.ai-questionnaire{padding:20px;color:var(--text-primary);min-height:350px;display:flex;flex-direction:column}.aiq-setup{display:flex;flex-direction:column;gap:20px}.aiq-intro{text-align:center;padding:20px}.aiq-intro-icon{font-size:48px;margin-bottom:12px}.aiq-intro h3{margin:0 0 8px;font-size:20px;font-weight:600}.aiq-intro p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.5}.aiq-form{display:flex;flex-direction:column;gap:16px}.aiq-form .form-group{display:flex;flex-direction:column;gap:8px}.aiq-form label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.project-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.type-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .2s ease}.type-btn:hover{background:#ffffff0f;border-color:#ffffff1f}.type-btn.active{background:#5865f226;border-color:var(--accent-color)}.type-icon{font-size:20px}.type-label{font-size:10px;color:var(--text-secondary);text-align:center}.type-btn.active .type-label{color:var(--text-primary)}.aiq-textarea{width:100%;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;color:var(--text-primary);resize:vertical;min-height:100px;font-family:inherit;line-height:1.5;transition:all .2s ease}.aiq-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #5865f233}.aiq-textarea::placeholder{color:var(--text-tertiary)}.aiq-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:13px}.aiq-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#5865f2,#4752c4);border:none;border-radius:10px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #5865f24d}.aiq-generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #5865f266}.aiq-generate-btn:disabled{opacity:.5;cursor:not-allowed}.aiq-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center}.aiq-spinner{width:48px;height:48px;border:3px solid rgba(88,101,242,.2);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}.aiq-loading p{margin:0;font-size:16px;font-weight:500;color:var(--text-primary)}.aiq-loading-detail{font-size:13px;color:var(--text-secondary)}.aiq-ready{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.aiq-ready-icon{font-size:48px}.aiq-ready h3{margin:0;font-size:20px}.aiq-ready p{margin:0;color:var(--text-secondary)}.aiq-start-btn{margin-top:16px;padding:12px 28px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #10b9814d}.aiq-start-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.aiq-answering{display:flex;flex-direction:column;gap:20px}.aiq-progress{display:flex;align-items:center;gap:12px}.progress-bar{flex:1;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#5865f2,#10b981);border-radius:3px;transition:width .3s ease}.progress-text{font-size:12px;color:var(--text-secondary);font-weight:500;white-space:nowrap}.aiq-category{display:inline-block;padding:4px 10px;background:#5865f226;border-radius:12px;font-size:11px;font-weight:600;color:var(--accent-color);text-transform:uppercase;letter-spacing:.5px;width:fit-content}.aiq-question{display:flex;align-items:flex-start;gap:8px}.aiq-question h3{margin:0;font-size:18px;font-weight:500;line-height:1.4}.required-badge{flex-shrink:0;padding:2px 6px;background:#ef444426;border-radius:4px;font-size:10px;color:#ef4444;text-transform:uppercase}.aiq-answer{margin-top:8px}.aiq-input{width:100%;padding:14px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:15px;color:var(--text-primary);transition:all .2s ease}.aiq-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #5865f233}.aiq-options{display:flex;flex-direction:column;gap:8px}.aiq-option{padding:12px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;color:var(--text-secondary);text-align:left;cursor:pointer;transition:all .2s ease}.aiq-option:hover{background:#ffffff0f;border-color:#ffffff26}.aiq-option.selected{background:#5865f226;border-color:var(--accent-color);color:var(--text-primary)}.aiq-boolean{display:flex;gap:12px}.aiq-bool-btn{flex:1;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.aiq-bool-btn:hover{background:#ffffff0f}.aiq-bool-btn.selected.yes{background:#10b98126;border-color:#10b981;color:#10b981}.aiq-bool-btn.selected.no{background:#ef444426;border-color:#ef4444;color:#ef4444}.aiq-nav{display:flex;justify-content:space-between;margin-top:12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.05)}.aiq-nav-btn{padding:10px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.aiq-nav-btn:hover:not(:disabled){background:#ffffff14;color:var(--text-primary)}.aiq-nav-btn:disabled{opacity:.4;cursor:not-allowed}.aiq-nav-btn.primary{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.aiq-nav-btn.primary:hover{background:#4752c4}.aiq-nav-btn.submit{background:linear-gradient(135deg,#10b981,#059669);border-color:transparent;color:#fff}.aiq-nav-btn.submit:hover{box-shadow:0 4px 12px #10b9814d}.aiq-complete{display:flex;flex-direction:column;gap:16px}.aiq-complete-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.complete-icon{font-size:32px}.aiq-complete-header h3{margin:0;font-size:20px}.complexity-badge{display:inline-block;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;width:fit-content}.complexity-badge.low{background:#10b98126;color:#10b981}.complexity-badge.medium{background:#f59e0b26;color:#f59e0b}.complexity-badge.high{background:#ef444426;color:#ef4444}.aiq-section{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:16px}.aiq-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary)}.tech-stack{display:flex;flex-wrap:wrap;gap:8px}.tech-badge{padding:4px 10px;background:#5865f226;border-radius:6px;font-size:12px;font-weight:500;color:var(--accent-color)}.suggested-nodes{display:flex;flex-direction:column;gap:10px}.suggested-node{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;background:#ffffff08;border-radius:8px}.node-name{font-weight:600;color:var(--text-primary)}.node-type{padding:2px 6px;background:#10b98126;border-radius:4px;font-size:10px;color:#10b981;text-transform:uppercase}.node-desc{width:100%;margin:4px 0 0;font-size:12px;color:var(--text-secondary)}.recommendations{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.recommendations li{font-size:13px;color:var(--text-secondary);line-height:1.4}.aiq-done-btn{margin-top:8px;padding:12px 24px;background:var(--accent-color);border:none;border-radius:8px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;align-self:flex-end}.aiq-done-btn:hover{background:#4752c4}.aiq-error-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.aiq-error-state h3{margin:0;font-size:18px;color:#ef4444}.aiq-error-state p{margin:0;color:var(--text-secondary)}.aiq-retry-btn{margin-top:12px;padding:10px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.aiq-retry-btn:hover{background:#ffffff14}.aiq-followup{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;text-align:center;padding:20px}.aiq-followup-header{display:flex;flex-direction:column;align-items:center;gap:8px}.followup-icon{font-size:48px}.aiq-followup-header h3{margin:0;font-size:20px;font-weight:600}.aiq-followup-header p{margin:0;color:var(--text-secondary);font-size:14px}.aiq-understanding{width:100%;max-width:400px;background:#ffffff08;border-radius:12px;padding:16px}.confidence-bar{position:relative;height:24px;background:#ffffff1a;border-radius:12px;overflow:hidden;margin-bottom:12px}.confidence-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#10b981);border-radius:12px;transition:width .5s ease}.confidence-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.gaps-list{text-align:left;font-size:13px}.gaps-list strong{color:var(--text-secondary)}.gaps-list ul{margin:8px 0 0;padding-left:20px;color:var(--text-primary)}.gaps-list li{margin:4px 0}.aiq-hint{margin-top:8px;padding:8px 12px;background:#6366f11a;border-radius:6px;font-size:12px;color:var(--text-secondary)}.aiq-options.multiselect{flex-wrap:wrap}.aiq-options.multiselect .aiq-option{flex:0 0 auto}.project-summary{margin:0;font-size:14px;line-height:1.6;color:var(--text-primary)}.features-list{margin:8px 0 0;padding-left:20px}.features-list li{margin:6px 0;font-size:14px}.architecture-desc{margin:0;font-size:14px;line-height:1.6;color:var(--text-secondary)}.final-confidence{margin-top:8px;padding:4px 12px;background:linear-gradient(90deg,#10b98133,#6366f133);border-radius:20px;font-size:12px;font-weight:600;color:#10b981}.questions-summary{background:#ffffff08;border-radius:8px;padding:12px 16px}.questions-summary h4{margin:0;font-size:14px}.rounds-info{margin:4px 0 0;font-size:12px;color:var(--text-secondary)}.error-actions{display:flex;gap:12px;margin-top:12px}.aiq-retry-btn.secondary{background:transparent;border-color:#6366f180;color:#6366f1}.aiq-retry-btn.secondary:hover{background:#6366f11a}.team-dashboard{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#0f0f1a,#0a0a0f);color:#fff}.dashboard-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:32px 40px}.team-header{margin-bottom:32px}.team-info{display:flex;align-items:center;gap:20px;margin-bottom:24px}.team-avatar{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;box-shadow:0 8px 32px #6366f14d}.team-details h1{font-size:28px;font-weight:700;margin-bottom:4px}.team-subtitle{font-size:14px;color:#ffffff80}.team-subtitle strong{color:#818cf8}.leader-badge{margin-left:12px;padding:3px 10px;background:#6366f126;border:1px solid rgba(99,102,241,.3);border-radius:20px;font-size:11px;font-weight:600;color:#a78bfa}.stats-row{display:flex;gap:16px}.stat-mini{flex:1;padding:20px 24px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;display:flex;flex-direction:column;gap:4px;transition:all .2s ease}.stat-mini:hover{background:#ffffff0d;border-color:#ffffff1a}.stat-mini-value{font-size:32px;font-weight:700;color:#fff}.stat-mini-label{font-size:13px;color:#ffffff80}.dashboard-tabs{display:flex;gap:8px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.tab{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:1px solid transparent;border-radius:8px;color:#ffffff80;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.tab:hover{background:#ffffff0d;color:#fffc}.tab.active{background:#6366f11a;border-color:#6366f14d;color:#818cf8}.tab svg{opacity:.7}.tab.active svg{opacity:1}.dashboard-content{flex:1}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;color:#fff9}.spinner{width:40px;height:40px;border:3px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.error-icon,.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.error-state h2,.empty-state h3{font-size:18px;font-weight:600;margin-bottom:8px;color:#fff}.error-state p,.empty-state p{font-size:14px;margin-bottom:24px}.section-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px}.search-box{position:relative;flex:1;max-width:400px}.search-box svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#fff6}.search-box input{width:100%;padding:12px 12px 12px 42px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px}.search-box input:focus{outline:none;border-color:#6366f1;background:#6366f10d}.search-box input::placeholder{color:#fff6}.filter-select{padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px;cursor:pointer}.filter-select:focus{outline:none;border-color:#6366f1}.btn-primary{display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px #6366f166}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary-large{padding:16px 32px;font-size:15px}.btn-secondary{padding:12px 20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fffc;font-size:14px;cursor:pointer}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.project-card{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:24px;cursor:pointer;transition:all .2s ease}.project-card:hover{background:#ffffff0a;border-color:#ffffff1f;transform:translateY(-2px)}.project-card.deployed{border-color:#22c55e4d}.project-card.deployed:hover{border-color:#22c55e80}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.project-icon{width:44px;height:44px;border-radius:12px;background:#6366f11a;display:flex;align-items:center;justify-content:center;color:#818cf8}.project-card-actions{display:flex;gap:8px;opacity:0;transition:opacity .2s ease}.project-card:hover .project-card-actions{opacity:1}.delete-project-btn{width:32px;height:32px;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ef4444;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.delete-project-btn:hover{background:#ef444433;border-color:#ef444466;transform:scale(1.05)}.project-badges{display:flex;gap:8px}.badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}.badge.deployed{background:#22c55e26;color:#22c55e}.badge.status-active{background:#3b82f626;color:#60a5fa}.badge.status-pending{background:#fbbf2426;color:#fbbf24}.badge.status-archived{background:#6b728026;color:#9ca3af}.project-name{font-size:18px;font-weight:600;margin-bottom:8px;color:#fff}.project-desc{font-size:13px;color:#ffffff80;line-height:1.5;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-stats{display:flex;gap:16px}.project-stats .stat{display:flex;align-items:center;gap:6px;font-size:12px;color:#fff6}.project-stats .stat svg{opacity:.6}.create-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;background:transparent;border:2px dashed rgba(255,255,255,.1);border-radius:16px;color:#fff6;cursor:pointer;transition:all .2s ease}.create-card:hover{border-color:#6366f166;color:#818cf8;background:#6366f10d}.create-icon{font-size:32px;opacity:.5}.create-card:hover .create-icon{opacity:1}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-header h2{font-size:18px;font-weight:600;color:#fff}.count{font-size:13px;color:#fff6}.members-list{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden}.member-row{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.04)}.member-row:last-child{border-bottom:none}.member-row:hover{background:#ffffff05}.member-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff}.member-info{flex:1;display:flex;flex-direction:column;gap:2px}.member-name{font-size:14px;font-weight:500;color:#fff}.member-role,.member-activity{font-size:12px;color:#fff6}.activity-list{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden}.activity-row{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.04)}.activity-row:last-child{border-bottom:none}.activity-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;background:#6366f11a}.activity-icon.create{background:#22c55e1a}.activity-icon.update{background:#3b82f61a}.activity-icon.delete{background:#ef44441a}.activity-info{flex:1;display:flex;flex-direction:column;gap:2px}.activity-text{font-size:14px;color:#fffc}.activity-text strong{color:#fff}.activity-meta,.activity-time{font-size:12px;color:#fff6}.modal-content{background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px;width:100%;max-width:480px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{font-size:20px;font-weight:600;color:#fff}.btn-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#fff6;font-size:18px;cursor:pointer;border-radius:8px}.btn-close:hover{background:#ffffff1a;color:#fff}.form-group label{display:block;font-size:13px;color:#ffffffb3;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#6366f1}.form-group input::placeholder,.form-group textarea::placeholder{color:#fff6}@media (max-width: 1024px){.stats-row{flex-wrap:wrap}.stat-mini{flex:1 1 calc(50% - 8px);min-width:150px}}@media (max-width: 768px){.dashboard-main{padding:20px}.team-info{flex-direction:column;text-align:center}.stats-row{flex-direction:column}.stat-mini{flex:1 1 100%}.section-toolbar{flex-direction:column}.search-box{max-width:100%;width:100%}.projects-grid{grid-template-columns:1fr}.dashboard-tabs{overflow-x:auto;flex-wrap:nowrap}.tab{white-space:nowrap;min-width:fit-content}}.planning-generation-modal{text-align:center;max-width:500px}.planning-generation-modal .modal-header{justify-content:center}.planning-generation-modal .modal-header h2{font-size:24px}.planning-generation-content{padding:20px 0}.loading-spinner-large{width:60px;height:60px;border:4px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;margin:0 auto 24px;animation:spin 1s linear infinite}.generation-status{font-size:16px;color:#fff;margin-bottom:12px}.generation-status strong{color:#6366f1}.generation-details{font-size:14px;color:#fff9;margin-bottom:8px}.generation-note{font-size:13px;color:#fff6;font-style:italic}.error-icon{font-size:48px;margin-bottom:16px}.error-message{font-size:14px;color:#f87171;margin-bottom:12px;word-break:break-word;max-height:120px;overflow-y:auto;padding:12px;background:#f871711a;border-radius:8px}.error-hint{font-size:13px;color:#ffffff80;margin-bottom:24px}.planning-generation-content .modal-actions{justify-content:center}.service-node{position:relative;width:260px;min-height:100px;padding:12px 14px;background:#121218d9;border:1px solid rgba(255,255,255,.08);border-radius:8px;cursor:grab;transition:box-shadow var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast);-webkit-user-select:none;user-select:none;box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff08;display:flex;flex-direction:column;gap:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.service-node.main-node{width:300px;min-height:150px;padding:16px 18px;gap:12px;border-radius:12px;box-shadow:0 4px 16px #0006,0 0 0 1px #5865f226,inset 0 1px #ffffff0d}.service-node.main-node .node-icon{width:40px;height:40px;min-width:40px;font-size:16px}.service-node.main-node .node-label{font-size:15px}.service-node.main-node .node-type-label{font-size:11px}.service-node.main-node .node-status{padding:8px 12px}.service-node.main-node .status-label{font-size:12px}.service-node.main-node .metric-value{font-size:14px}.service-node:active{cursor:grabbing}.service-node:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--node-accent, var(--accent-color));opacity:0;transition:opacity var(--transition-fast);border-radius:8px 8px 0 0}.service-node:hover{background:#191923e6;border-color:#ffffff1f;box-shadow:0 4px 16px #0006,inset 0 1px #ffffff0d}.service-node.node-running{border-left:3px solid #10b981}.service-node.node-stopped{border-left:3px solid #4b5563}.service-node.node-error{border-left:3px solid #ef4444}.service-node.node-starting,.service-node.node-stopping{border-left:3px solid #f59e0b}.service-node.planning-node{border-left:3px solid var(--accent-color);background:linear-gradient(135deg,#121218d9,#5865f214)}.service-node.planning-node:before{background:linear-gradient(90deg,var(--accent-color),transparent);opacity:.5}.service-node.view-parent-node{width:280px;padding:14px 16px;border-width:2px;border-color:#5865f280;box-shadow:0 0 0 3px #5865f21a,0 4px 20px #0006;background:linear-gradient(135deg,#16161ef2,#5865f21a)}.service-node.view-parent-node:before{opacity:1;height:3px}.service-node.view-parent-node .node-icon{width:36px;height:36px;font-size:16px}.service-node.view-parent-node .node-label{font-size:14px}.node-header{display:flex;align-items:center;gap:10px}.node-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;border-radius:6px;font-size:11px;font-weight:700;font-family:var(--font-mono);letter-spacing:-.5px}.node-title{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.node-label{font-size:13px;font-weight:600;margin:0;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-type-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;opacity:.7}.node-status{display:flex;flex-direction:column;gap:4px;padding:6px 10px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:6px}.status-indicator{display:flex;align-items:center;gap:6px}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-dot.running{background:#10b981;box-shadow:0 0 6px #10b98180;animation:pulse-green 2s ease-in-out infinite}.status-dot.stopped{background:#4b5563}.status-dot.error{background:#ef4444;box-shadow:0 0 6px #ef444480;animation:pulse-red 1s ease-in-out infinite}.status-dot.starting,.status-dot.stopping{background:#f59e0b;animation:pulse-yellow .5s ease-in-out infinite}@keyframes pulse-green{0%,to{opacity:1;box-shadow:0 0 8px #10b98180}50%{opacity:.7;box-shadow:0 0 12px #10b981cc}}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.6}}@keyframes pulse-yellow{0%,to{opacity:1}50%{opacity:.5}}.status-label{font-size:11px;font-weight:600;color:var(--text-primary)}.status-running .status-label{color:#10b981}.status-error .status-label{color:#ef4444}.last-update{font-size:10px;color:var(--text-tertiary)}.node-accuracy{display:flex;flex-direction:column;gap:4px}.accuracy-bar{width:100%;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.accuracy-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),#10b981);border-radius:2px;transition:width .5s ease}.accuracy-label{font-size:10px;color:var(--text-secondary);font-weight:500}.node-file-info{display:flex;flex-direction:column;gap:2px;padding:6px 10px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:6px}.file-name{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);word-break:break-all}.file-description{font-size:11px;color:var(--text-tertiary)}.node-ports{position:relative;height:0}.port{position:absolute;width:12px;height:12px;background:var(--node-accent, var(--accent-color));border:2px solid var(--secondary-bg);border-radius:50%;transition:all var(--transition-fast);cursor:crosshair;opacity:0}.service-node:hover .port{opacity:1}.port-in{left:-22px;top:-60px}.port-out{right:-22px;top:-60px}.port:hover{width:16px;height:16px;box-shadow:0 0 12px var(--node-accent, var(--accent-color));border-width:1.5px;opacity:1}.node-actions{display:flex;gap:8px;opacity:0;transition:opacity var(--transition-fast);padding-top:8px;border-top:1px solid var(--border-color)}.service-node:hover .node-actions{opacity:1}.node-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.node-action-btn:hover{background:var(--hover-bg);border-color:var(--border-color-hover);color:var(--text-primary)}.service-node.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px #5865f24d,var(--shadow-lg)}.service-node.dragging{opacity:.9;cursor:grabbing;z-index:100}.node-metrics{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:#ffffff05;border:1px solid var(--border-color);border-radius:8px}.metric-item{display:flex;justify-content:space-between;align-items:center;gap:8px}.metric-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:12px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.metric-usage{display:flex;flex-direction:column;gap:6px;margin-top:4px;padding-top:8px;border-top:1px solid var(--border-color)}.usage-bar{display:flex;align-items:center;gap:8px}.usage-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;width:28px;flex-shrink:0}.usage-track{flex:1;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.usage-fill{height:100%;border-radius:2px;transition:width .3s ease}.usage-fill.low{background:linear-gradient(90deg,#10b981,#34d399)}.usage-fill.medium{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.usage-fill.high{background:linear-gradient(90deg,#ef4444,#f87171)}.usage-value{font-size:10px;font-weight:600;color:var(--text-secondary);font-family:var(--font-mono);width:32px;text-align:right;flex-shrink:0}.deployed-badge{display:flex;align-items:center;gap:4px;padding:3px 8px;background:linear-gradient(135deg,#10b98133,#0596694d);border:1px solid rgba(16,185,129,.4);border-radius:12px;font-size:10px;font-weight:600;color:#10b981;text-transform:uppercase;letter-spacing:.5px;margin-left:auto;flex-shrink:0;animation:deployedPulse 3s ease-in-out infinite;cursor:help}.deployed-badge .deployed-icon{font-size:11px;animation:rocketBounce 2s ease-in-out infinite}.deployed-badge .deployed-text{line-height:1}@keyframes deployedPulse{0%,to{box-shadow:0 0 #10b9814d}50%{box-shadow:0 0 8px 2px #10b98133}}@keyframes rocketBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.service-node.deployed-node{border-color:#10b9814d;box-shadow:0 4px 16px #0006,0 0 0 1px #10b98126,inset 0 1px #ffffff0d}.service-node.deployed-node:before{background:linear-gradient(90deg,#10b981,#06d6a0,transparent);opacity:.8}.service-node.deployed-node:after{content:"";position:absolute;top:-2px;right:-2px;width:10px;height:10px;background:#10b981;border-radius:50%;box-shadow:0 0 8px #10b98199;animation:liveIndicator 2s ease-in-out infinite}@keyframes liveIndicator{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.9)}}.service-node:not(.deployed-node):not(:hover):before{opacity:.3}.service-node.node-focused{animation:nodeFocus .5s ease;box-shadow:0 0 0 3px #5865f266,0 4px 20px #00000080}@keyframes nodeFocus{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.context-menu{position:fixed;z-index:1000;min-width:200px;max-width:280px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;padding:6px 0;box-shadow:0 8px 32px #0006;animation:contextMenuIn .15s ease-out}@keyframes contextMenuIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:transparent;border:none;color:var(--text-primary);font-size:13px;font-weight:500;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.context-menu-item:hover{background:var(--hover-bg)}.context-menu-item:active{background:var(--accent-light)}.context-menu-item.disabled{opacity:.5;cursor:not-allowed}.context-menu-item.disabled:hover{background:transparent}.context-menu-item.danger{color:#ef4444}.context-menu-item.danger:hover{background:#ef44441a}.menu-item-icon{font-size:14px;width:20px;display:flex;align-items:center;justify-content:center}.menu-item-label{flex:1}.menu-item-shortcut{font-size:11px;color:var(--text-tertiary);font-family:var(--font-mono)}.context-menu-divider{height:1px;background:var(--border-color);margin:6px 0}.side-panel{position:fixed;top:56px;right:0;width:520px;height:calc(100vh - 56px);background:linear-gradient(180deg,#121218fa,#0c0c10fc);border-left:1px solid rgba(88,101,242,.15);display:flex;flex-direction:column;z-index:100;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-12px 0 40px #00000080,-4px 0 20px #5865f214;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.side-panel.open{transform:translate(0)}.side-panel.open{animation:slideInPanel .4s cubic-bezier(.34,1.56,.64,1)}@keyframes slideInPanel{0%{transform:translate(100%);opacity:.5}to{transform:translate(0);opacity:1}}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--tertiary-bg)}.panel-title{margin:0;font-size:15px;font-weight:600;color:var(--text-primary)}.panel-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.panel-close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.panel-content{flex:1;overflow-y:auto;padding:16px 20px}.panel-empty{text-align:center;padding:40px 20px;color:var(--text-tertiary);font-size:14px}.panel-placeholder{padding:20px;color:var(--text-secondary)}.node-editor{display:flex;flex-direction:column;gap:20px}.editor-section{display:flex;flex-direction:column;gap:8px}.section-label{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.editor-input{padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.editor-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #5865f233}.editor-textarea{padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;resize:vertical;min-height:80px;font-family:inherit;transition:all var(--transition-fast)}.editor-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #5865f233}.readonly-value{padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:14px}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500}.status-badge .status-dot{width:8px;height:8px;border-radius:50%}.status-badge.status-running{background:#10b9811a;color:#10b981}.status-badge.status-running .status-dot{background:#10b981;animation:pulse 2s infinite}.status-badge.status-stopped{background:#6b72801a;color:#6b7280}.status-badge.status-stopped .status-dot{background:#6b7280}.status-badge.status-error{background:#ef44441a;color:#ef4444}.status-badge.status-error .status-dot{background:#ef4444}.status-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);background:transparent;color:var(--text-primary)}.action-btn:hover{background:var(--hover-bg)}.action-btn.success{border-color:#10b981;color:#10b981}.action-btn.success:hover{background:#10b9811a}.action-btn.danger{border-color:#ef4444;color:#ef4444}.action-btn.danger:hover{background:#ef44441a}.action-btn.warning{border-color:#f59e0b;color:#f59e0b}.action-btn.warning:hover{background:#f59e0b1a}.action-btn.primary{border-color:var(--accent-color);color:var(--accent-color)}.action-btn.primary:hover{background:#5865f21a}.accuracy-display{display:flex;align-items:center;gap:12px}.accuracy-bar{flex:1;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.accuracy-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),#10b981);border-radius:4px;transition:width .5s ease}.accuracy-value{font-size:14px;font-weight:600;color:var(--text-primary)}.editor-actions{padding-top:16px;border-top:1px solid var(--border-color)}.save-btn{width:100%;padding:12px;background:var(--accent-color);border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;gap:12px;padding:12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px}.activity-item.status-success{border-left:3px solid #10b981}.activity-item.status-error{border-left:3px solid #ef4444}.activity-item.status-in_progress{border-left:3px solid #f59e0b}.activity-icon{font-size:16px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.activity-content{flex:1;min-width:0}.activity-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.activity-description{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.activity-node{font-size:11px;color:var(--accent-color);font-weight:500}.activity-time{font-size:11px;color:var(--text-tertiary);margin-top:4px}.search-panel{display:flex;flex-direction:column;gap:16px}.search-input-wrapper{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px}.search-icon{color:var(--text-tertiary);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:14px}.search-input:focus{outline:none}.search-input::placeholder{color:var(--text-tertiary)}.search-hint{text-align:center;color:var(--text-tertiary);font-size:13px;padding:20px}.questionnaire-panel{display:flex;flex-direction:column;gap:16px}.questionnaire-loading{padding:40px;text-align:center;color:var(--text-secondary)}.questionnaire-header{display:flex;justify-content:space-between;align-items:center}.questionnaire-header h4{margin:0;font-size:14px;color:var(--text-primary)}.questionnaire-count{font-size:12px;padding:4px 8px;background:#5865f226;color:var(--accent-color);border-radius:4px;font-weight:500}.questionnaire-description{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.questionnaire-list{display:flex;flex-direction:column;gap:12px}.questionnaire-item{padding:16px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all var(--transition-fast)}.questionnaire-item:hover{background:var(--hover-bg);border-color:var(--border-color-hover)}.questionnaire-item.selected{border-color:var(--accent-color);background:#5865f20d}.q-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.q-name{font-size:14px;font-weight:500;color:var(--text-primary)}.q-badge{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:500}.q-badge.complete{background:#10b98126;color:#10b981}.q-badge.in-progress{background:#f5a62326;color:#f5a623}.q-badge.not-started{background:#ffffff1a;color:var(--text-secondary)}.q-progress{margin-bottom:10px}.q-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-secondary)}.q-continue-btn,.q-start-btn{padding:4px 10px;font-size:11px;border:none;border-radius:4px;cursor:pointer;transition:all var(--transition-fast)}.q-continue-btn{background:#f5a62326;color:#f5a623}.q-start-btn{background:#5865f226;color:var(--accent-color)}.q-continue-btn:hover,.q-start-btn:hover{opacity:.8}.questionnaire-actions{display:flex;justify-content:center;margin-top:8px}.refresh-btn{padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.refresh-btn:hover{background:var(--hover-bg);border-color:var(--border-color-hover);color:var(--text-primary)}.completion-badge{font-size:12px;padding:4px 8px;background:#10b9811a;color:#10b981;border-radius:4px;font-weight:500}.questionnaire-questions{display:flex;flex-direction:column;gap:8px}.question-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.question-item:hover{background:var(--hover-bg)}.question-item.answered{opacity:.7}.question-item.current{border-color:var(--accent-color);background:#5865f20d}.q-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent-light);color:var(--accent-color);border-radius:50%;font-size:12px;font-weight:600}.q-text{flex:1;font-size:13px;color:var(--text-primary)}.q-status{width:20px;text-align:center;color:#10b981}.monitoring-panel{display:flex;flex-direction:column;gap:12px}.metric-card{padding:14px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px}.metric-label{font-size:12px;color:var(--text-tertiary);margin-bottom:4px}.metric-value{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.metric-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.metric-fill{height:100%;background:var(--accent-color)}.settings-panel{display:flex;flex-direction:column;gap:20px}.settings-section h4{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.env-var{display:flex;justify-content:space-between;padding:8px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;margin-bottom:8px}.env-key{font-family:var(--font-mono);font-size:13px;color:var(--accent-color)}.env-value{font-family:var(--font-mono);font-size:13px;color:var(--text-secondary)}.add-env-btn,.add-doc-btn{width:100%;padding:10px;background:transparent;border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.add-env-btn:hover,.add-doc-btn:hover{background:var(--hover-bg);border-color:var(--border-color-hover);color:var(--text-primary)}.settings-input{width:100%;padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px}.settings-toggles{display:flex;flex-direction:column;gap:8px}.toggle-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.toggle-item:hover{background:var(--hover-bg);border-color:var(--border-color-hover)}.toggle-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-color);cursor:pointer}.toggle-item span{font-size:13px;color:var(--text-primary)}.settings-field{margin-bottom:12px}.settings-field label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.settings-field select,.settings-field input[type=number]{width:100%;padding:8px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:13px}.settings-field select:focus,.settings-field input:focus{outline:none;border-color:var(--accent-color)}.team-access-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.team-member{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px}.member-info{display:flex;align-items:center;gap:10px}.member-name{font-size:13px;font-weight:500;color:var(--text-primary)}.member-role{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500;text-transform:capitalize}.member-role.owner{background:#f5a62326;color:#f5a623}.member-role.admin{background:#5865f226;color:var(--accent-color)}.member-role.viewer{background:#ffffff1a;color:var(--text-secondary)}.member-permissions{display:flex;gap:12px}.member-permissions label{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary)}.member-permissions input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent-color)}.add-member-btn{width:100%;padding:10px;background:transparent;border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.add-member-btn:hover{background:var(--hover-bg);border-color:var(--accent-color);color:var(--text-primary)}.settings-input:focus{outline:none;border-color:var(--accent-color)}.documentation-panel{display:flex;flex-direction:column;gap:8px}.doc-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.doc-item:hover{background:var(--hover-bg)}.doc-icon{font-size:16px}.doc-name{font-size:13px;color:var(--text-primary)}.agent-status-panel{display:flex;flex-direction:column;gap:16px}.agent-status-header{display:flex;align-items:center;gap:10px;padding:12px;background:#10b9811a;border-radius:8px}.agent-status-dot{width:10px;height:10px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}.agent-status-dot.active{box-shadow:0 0 8px #10b98180}.agent-status-text{font-size:14px;font-weight:600;color:#10b981}.agent-current-task{padding:14px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px}.task-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.task-description{font-size:14px;color:var(--text-primary);margin-bottom:12px}.task-progress{display:flex;align-items:center;gap:10px}.task-progress .progress-bar{flex:1}.progress-text{font-size:12px;font-weight:600;color:var(--accent-color)}.agent-history{display:flex;flex-direction:column;gap:8px}.history-item{font-size:13px;padding:8px 12px;border-radius:6px;background:var(--primary-bg)}.history-item.completed{color:#10b981}.history-item.in-progress{color:#f59e0b;background:#f59e0b1a}.history-item.pending{color:var(--text-tertiary)}.deploy-panel{display:flex;flex-direction:column;gap:16px}.deploy-status{display:flex;align-items:center;gap:12px;padding:16px;background:#10b9811a;border-radius:8px}.deploy-status-icon{font-size:24px}.deploy-status-text{font-size:16px;font-weight:600;color:#10b981}.deploy-options{display:flex;flex-direction:column;gap:10px}.deploy-option{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-primary);cursor:pointer}.deploy-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-color)}.deploy-btn{width:100%;padding:14px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.deploy-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #10b98166}.last-deploy{text-align:center;font-size:12px;color:var(--text-tertiary)}.code-editor-section{display:flex;flex-direction:column;flex:1;min-height:0;margin-top:16px;border-top:1px solid var(--border-color);padding-top:16px}.code-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.code-editor-header h4{margin:0;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.file-path-badge{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#5865f21a;border-radius:4px;font-size:11px;color:var(--accent-color);font-family:JetBrains Mono,Fira Code,monospace}.file-path-badge svg{width:12px;height:12px}.code-editor-toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-bottom:none;border-radius:8px 8px 0 0}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid transparent;border-radius:4px;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.toolbar-btn:hover{background:var(--hover-bg);border-color:var(--border-color);color:var(--text-primary)}.toolbar-btn.active{background:var(--accent-color);color:#fff}.toolbar-btn svg{width:16px;height:16px}.toolbar-divider{width:1px;height:20px;background:var(--border-color);margin:0 4px}.code-editor-wrapper{position:relative;flex:1;min-height:200px;max-height:400px;display:flex;border:1px solid var(--border-color);border-radius:0 0 8px 8px;overflow:hidden;background:#1a1b26}.line-numbers{display:flex;flex-direction:column;padding:12px 0;background:#0003;border-right:1px solid var(--border-color);-webkit-user-select:none;user-select:none;min-width:45px}.line-number{padding:0 12px;font-size:12px;font-family:JetBrains Mono,Fira Code,monospace;color:var(--text-tertiary);text-align:right;line-height:1.6}.line-number.active{color:var(--accent-color);background:#5865f21a}.code-textarea{flex:1;padding:12px;background:transparent;border:none;color:#c0caf5;font-size:13px;font-family:JetBrains Mono,Fira Code,monospace;line-height:1.6;resize:none;overflow:auto;outline:none;white-space:pre;-moz-tab-size:2;tab-size:2}.code-textarea::placeholder{color:var(--text-tertiary)}.code-textarea::-webkit-scrollbar{width:8px;height:8px}.code-textarea::-webkit-scrollbar-track{background:transparent}.code-textarea::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.code-textarea::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.code-editor-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--primary-bg);border:1px solid var(--border-color);border-top:none;border-radius:0 0 8px 8px;margin-top:-1px}.code-stats{display:flex;align-items:center;gap:16px;font-size:11px;color:var(--text-tertiary)}.code-stat{display:flex;align-items:center;gap:4px}.save-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(135deg,var(--accent-color),#7c3aed);border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5865f266}.save-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.save-btn svg{width:14px;height:14px}.file-tree-section{margin-top:16px;border-top:1px solid var(--border-color);padding-top:16px}.file-tree-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.file-tree-header h4{margin:0;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.file-tree-container{background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;max-height:300px;overflow-y:auto}.file-tree-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:all .15s ease;border-bottom:1px solid var(--border-color)}.file-tree-item:last-child{border-bottom:none}.file-tree-item:hover{background:var(--hover-bg)}.file-tree-item.active{background:#5865f21a;border-left:2px solid var(--accent-color)}.file-tree-item.folder{font-weight:500}.file-tree-icon{width:16px;height:16px;color:var(--text-tertiary)}.file-tree-icon.folder-icon{color:#f59e0b}.file-tree-icon.file-icon{color:var(--accent-color)}.file-tree-name{flex:1;font-size:13px;color:var(--text-primary);font-family:JetBrains Mono,Fira Code,monospace}.file-tree-item.folder .file-tree-name{font-family:inherit}.no-code-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background:var(--primary-bg);border:1px dashed var(--border-color);border-radius:8px;text-align:center}.no-code-content svg{width:48px;height:48px;color:var(--text-tertiary);margin-bottom:12px}.no-code-content p{margin:0;font-size:13px;color:var(--text-tertiary)}.file-explorer-panel{display:flex;flex-direction:column;height:100%;gap:12px}.file-explorer-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#5865f214;border-radius:8px;border:1px solid rgba(88,101,242,.15)}.node-type-badge{padding:4px 10px;background:#5865f233;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;color:#5865f2}.node-name{font-size:14px;font-weight:500;color:var(--text-primary)}.file-explorer-container{display:flex;flex-direction:column;flex:1;gap:12px;overflow:hidden}.file-tree-pane{flex:0 0 auto;max-height:250px;overflow-y:auto;background:#0f0f1699;border-radius:8px;border:1px solid rgba(255,255,255,.06);padding:8px 0}.file-tree-item{display:flex;align-items:center;gap:6px;padding:6px 12px;cursor:pointer;transition:all .15s ease;font-size:13px;color:var(--text-secondary)}.file-tree-item:hover{background:#5865f21a;color:var(--text-primary)}.file-tree-item.selected{background:#5865f233;color:var(--text-primary)}.tree-arrow{font-size:10px;width:12px;color:var(--text-tertiary)}.file-icon{font-size:14px}.file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-tree-empty{padding:20px;text-align:center;color:var(--text-tertiary);font-size:13px}.file-content-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#0f0f16cc;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.file-content-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#5865f20d;border-bottom:1px solid rgba(255,255,255,.06)}.file-path{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-language{font-size:11px;padding:2px 8px;background:#5865f226;border-radius:4px;color:#7c8af2}.file-content-editor{flex:1;overflow:auto;padding:12px}.file-content-editor pre{margin:0;padding:0;background:transparent}.file-content-editor code{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.file-explorer-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:12px;color:var(--text-secondary)}.loading-spinner{font-size:32px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.file-explorer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:12px;text-align:center;padding:20px}.error-icon{font-size:48px}.error-hint{font-size:12px;color:var(--text-tertiary);max-width:280px}.tab-content{flex:1;padding:24px;background:var(--primary-bg);overflow-y:auto}.tab-header{margin-bottom:24px}.tab-header h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.tab-header p{font-size:14px;color:var(--text-secondary);margin:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.metric-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px}.metric-icon{font-size:28px}.metric-info{display:flex;flex-direction:column}.metric-value{font-size:24px;font-weight:600;color:var(--text-primary)}.metric-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.charts-section{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.chart-card{padding:20px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px}.chart-card h3{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 16px}.usage-bar{position:relative;height:24px;background:var(--tertiary-bg);border-radius:12px;overflow:hidden}.usage-fill{height:100%;border-radius:12px;transition:width .3s ease}.usage-fill.cpu{background:linear-gradient(90deg,#5865f2,#7289da)}.usage-fill.memory{background:linear-gradient(90deg,#57f287,#43b581)}.usage-text{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;font-weight:600;color:var(--text-primary)}.services-status{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px}.services-status h3{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 16px}.service-list{display:flex;flex-direction:column;gap:8px}.service-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--primary-bg);border-radius:8px}.service-item .status-dot{width:10px;height:10px;border-radius:50%}.service-item.healthy .status-dot{background:#57f287;box-shadow:0 0 8px #57f28780}.service-item.warning .status-dot{background:#fee75c;box-shadow:0 0 8px #fee75c80}.service-item.error .status-dot{background:#ed4245;box-shadow:0 0 8px #ed424580}.service-name{flex:1;font-size:14px;color:var(--text-primary)}.service-status{font-size:12px;color:var(--text-secondary)}.logs-toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.logs-search{flex:1;min-width:200px;padding:10px 16px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px}.logs-search:focus{outline:none;border-color:var(--accent-color)}.logs-filter{padding:10px 16px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer}.logs-btn{padding:10px 16px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.logs-btn:hover{background:var(--tertiary-bg);border-color:var(--border-color-hover)}.logs-container{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;font-family:var(--font-mono);font-size:13px;max-height:500px;overflow-y:auto}.log-entry{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border-color);transition:background .15s ease}.log-entry:hover{background:var(--tertiary-bg)}.log-entry:last-child{border-bottom:none}.log-timestamp{color:var(--text-secondary);flex-shrink:0}.log-level{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;flex-shrink:0}.log-level.info{background:#5865f233;color:var(--accent-color)}.log-level.warn{background:#fee75c33;color:#fee75c}.log-level.error{background:#ed424533;color:#ed4245}.log-service{color:var(--text-secondary);flex-shrink:0}.log-message{color:var(--text-primary);flex:1;word-break:break-word}.logs-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;color:var(--text-secondary);font-size:13px}.load-more-btn{padding:8px 16px;background:var(--accent-color);border:none;border-radius:6px;color:#fff;font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.load-more-btn:hover{background:var(--accent-hover)}.share-section{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin-bottom:16px}.share-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.share-section p{font-size:13px;color:var(--text-secondary);margin:0 0 16px}.export-options{display:flex;gap:16px;margin-bottom:16px}.radio-option,.checkbox-option{display:flex;align-items:center;gap:8px;cursor:pointer}.radio-option input,.checkbox-option input{accent-color:var(--accent-color)}.radio-option span,.checkbox-option span{font-size:14px;color:var(--text-primary)}.export-btn{padding:12px 24px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.export-btn:hover{background:var(--tertiary-bg);border-color:var(--accent-color)}.export-btn.primary{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.export-btn.primary:hover{background:var(--accent-hover)}.quick-actions{display:flex;gap:12px;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:var(--tertiary-bg);border-color:var(--accent-color)}.settings-tab-full .settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:24px}.settings-card{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:12px;padding:24px}.settings-card h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 14px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-color)}.form-group textarea{resize:vertical;min-height:80px}.toggle-list{display:flex;flex-direction:column;gap:12px}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;cursor:pointer}.toggle-row span{font-size:14px;color:var(--text-primary)}.toggle-row input{width:18px;height:18px;accent-color:var(--accent-color)}.danger-text{font-size:13px;color:var(--text-secondary);margin:0 0 16px}.danger-actions{display:flex;gap:12px}.danger-btn{padding:10px 20px;background:transparent;border:1px solid rgba(237,66,69,.5);border-radius:8px;color:#ed4245;font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.danger-btn:hover{background:#ed42451a;border-color:#ed4245}.danger-btn.delete{background:#ed42451a}.danger-btn.delete:hover{background:#ed424533}.settings-footer{display:flex;justify-content:flex-end;align-items:center;gap:16px;margin-top:24px}.save-btn{padding:12px 32px;background:var(--accent-color);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.save-btn:hover{background:var(--accent-hover)}.save-btn.has-changes{animation:pulse-save 2s infinite}.save-btn:disabled{opacity:.6;cursor:not-allowed}@keyframes pulse-save{0%,to{box-shadow:0 0 #5865f266}50%{box-shadow:0 0 0 8px #5865f200}}.save-message{font-size:13px;padding:8px 16px;border-radius:6px}.save-message.success{color:#57f287;background:#57f2871a}.save-message.error{color:#ed4245;background:#ed42451a}.live-badge,.streaming-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:#ed4245;padding:2px 8px;background:#ed42451a;border-radius:12px;margin-left:8px;animation:pulse-live 1.5s infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.5}}.tab-header-actions{display:flex;align-items:center;justify-content:space-between}.tab-header-actions p{margin:0}.live-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.live-toggle:hover{background:var(--hover-bg)}.live-toggle.active{border-color:#ed4245;color:#ed4245}.logs-btn.active{background:#ed42451a;border-color:#ed4245;color:#ed4245}.logs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text-secondary);gap:16px}.auto-scroll-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);cursor:pointer}.auto-scroll-toggle input{cursor:pointer}.copy-feedback{padding:8px 16px;background:#57f2871a;color:#57f287;border-radius:6px;font-size:13px;margin-bottom:12px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.copilot-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.copilot-quick-actions{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.05);overflow-x:auto;flex-shrink:0}.copilot-quick-actions::-webkit-scrollbar{display:none}.quick-action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:20px;color:#ffffffb3;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s ease}.quick-action-btn:hover{background:#df3e531a;border-color:#df3e534d;color:#fff;transform:translateY(-1px)}.quick-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.qa-icon{font-size:14px}.copilot-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.copilot-messages::-webkit-scrollbar{width:6px}.copilot-messages::-webkit-scrollbar-track{background:transparent}.copilot-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.copilot-messages::-webkit-scrollbar-thumb:hover{background:#fff3}.message{display:flex;gap:10px;max-width:90%}.message-user{align-self:flex-end;flex-direction:row-reverse}.message-assistant,.message-system{align-self:flex-start}.message-avatar{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#df3e53,#ff6b6b);border-radius:8px;flex-shrink:0}.message-avatar svg{color:#fff}.message-content{padding:12px 16px;border-radius:12px;font-size:13px;line-height:1.6}.message-user .message-content{background:linear-gradient(135deg,#df3e53,#c43a4c);color:#fff;border-bottom-right-radius:4px}.message-assistant .message-content,.message-system .message-content{background:#ffffff0d;color:#ffffffe6;border:1px solid rgba(255,255,255,.08);border-bottom-left-radius:4px}.message-content p{margin:0;white-space:pre-wrap}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background:#df3e5399;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.copilot-input{display:flex;gap:8px;padding:16px;border-top:1px solid rgba(255,255,255,.08);background:#0003;flex-shrink:0}.copilot-input textarea{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 16px;color:#fff;font-size:13px;font-family:inherit;resize:none;min-height:44px;max-height:120px;transition:all .2s ease}.copilot-input textarea:focus{outline:none;border-color:#df3e5366;background:#ffffff14;box-shadow:0 0 20px #df3e531a}.copilot-input textarea::placeholder{color:#fff6}.copilot-input button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#df3e53,#c43a4c);border:none;border-radius:12px;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.copilot-input button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 20px #df3e5366}.copilot-input button:disabled{opacity:.5;cursor:not-allowed;transform:none}.questionnaire-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.questionnaire-progress{padding:12px 16px;background:#0003;flex-shrink:0}.questionnaire-progress-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.questionnaire-progress-bar:before{content:"";display:block;height:100%;background:linear-gradient(90deg,#df3e53,#ff6b6b);border-radius:2px;transition:width .3s ease}.questionnaire-question{flex:1;padding:20px 16px;overflow-y:auto}.questionnaire-question::-webkit-scrollbar{width:6px}.questionnaire-question::-webkit-scrollbar-track{background:transparent}.questionnaire-question::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.questionnaire-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#fff}.questionnaire-description{margin:0 0 16px;color:#fff9;font-size:13px;line-height:1.5}.questionnaire-input-wrapper{display:flex;flex-direction:column;gap:12px}.questionnaire-input,.questionnaire-select,.questionnaire-textarea{width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;font-family:inherit;color:#fff;transition:all .2s ease;box-sizing:border-box}.questionnaire-input:focus,.questionnaire-select:focus,.questionnaire-textarea:focus{outline:none;border-color:#df3e5380;background:#ffffff14;box-shadow:0 0 20px #df3e5326}.questionnaire-input::placeholder,.questionnaire-textarea::placeholder{color:#fff6}.questionnaire-input:disabled,.questionnaire-select:disabled,.questionnaire-textarea:disabled{opacity:.5;cursor:not-allowed}.questionnaire-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.questionnaire-select option{background:#1a1a2e;color:#fff}.questionnaire-textarea{resize:vertical;min-height:100px;max-height:200px}.questionnaire-radio-group,.questionnaire-checkbox-group{display:flex;flex-direction:column;gap:8px}.questionnaire-radio,.questionnaire-checkbox{display:flex;align-items:flex-start;gap:12px;padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .2s ease}.questionnaire-radio:hover,.questionnaire-checkbox:hover{background:#df3e5314;border-color:#df3e5333}.questionnaire-radio input,.questionnaire-checkbox input{margin-top:2px;cursor:pointer;accent-color:#df3e53;flex-shrink:0;width:16px;height:16px}.questionnaire-radio span,.questionnaire-checkbox span{font-weight:500;color:#ffffffe6;font-size:14px}.questionnaire-radio small,.questionnaire-checkbox small{display:block;color:#ffffff80;font-size:12px;margin-top:4px}.questionnaire-boolean-group{display:flex;gap:12px}.questionnaire-boolean-btn{flex:1;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;color:#fffc}.questionnaire-boolean-btn:hover:not(:disabled){background:#df3e531a;border-color:#df3e534d}.questionnaire-boolean-btn.active{background:linear-gradient(135deg,#df3e53,#c43a4c);color:#fff;border-color:transparent;box-shadow:0 4px 15px #df3e534d}.questionnaire-boolean-btn:disabled{opacity:.5;cursor:not-allowed}.questionnaire-error{padding:10px 14px;background:#f4433626;border-left:3px solid #f44336;border-radius:6px;color:#ff8a80;font-size:13px;margin-top:12px;animation:slideDown .2s ease-out}.questionnaire-footer{padding:16px;background:#0003;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:12px;justify-content:space-between;flex-shrink:0}.questionnaire-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px;justify-content:center}.questionnaire-btn:disabled{opacity:.5;cursor:not-allowed}.questionnaire-btn svg{flex-shrink:0}.questionnaire-btn-secondary{background:#ffffff0d;color:#ffffffb3;border:1px solid rgba(255,255,255,.1)}.questionnaire-btn-secondary:hover:not(:disabled){background:#ffffff1a;color:#fff}.questionnaire-btn-primary{background:linear-gradient(135deg,#df3e53,#c43a4c);color:#fff}.questionnaire-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #df3e5366}.questionnaire-btn-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.questionnaire-btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #4caf5066}.deploy-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.deploy-modal{width:520px;max-width:95vw;max-height:85vh;background:linear-gradient(135deg,#12121a,#1a1a28);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff0d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.deploy-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:linear-gradient(135deg,#10b98126,#10b9810d);border-bottom:1px solid rgba(255,255,255,.08)}.deploy-header-info h2{display:flex;align-items:center;gap:10px;margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.deploy-icon{font-size:22px}.deploy-node-name{margin:4px 0 0;font-size:13px;color:var(--text-secondary)}.deploy-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.deploy-close-btn:hover{background:#ef444433;border-color:#ef44444d;color:#ef4444}.deploy-current-status{display:flex;align-items:center;gap:12px;padding:12px 24px;background:#10b9811a;border-bottom:1px solid rgba(16,185,129,.2)}.status-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#10b98133;border-radius:12px;font-size:12px;font-weight:600;color:#10b981}.status-indicator .status-dot{width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.deploy-url{font-size:13px;color:var(--accent-color);text-decoration:none}.deploy-url:hover{text-decoration:underline}.deploy-status-banner{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#5865f21a;border-bottom:1px solid rgba(255,255,255,.05)}.deploy-status-banner.deploying{background:#5865f226}.deploy-status-banner.success{background:#10b98126}.deploy-status-banner.error{background:#ef444426}.deploy-spinner{width:18px;height:18px;border:2px solid rgba(88,101,242,.3);border-top-color:#5865f2;border-radius:50%;animation:spin .8s linear infinite}.status-icon{font-size:18px}.status-message{flex:1;font-size:13px;color:var(--text-primary)}.deploy-url-link{font-size:13px;color:#10b981;text-decoration:none;font-weight:500}.deploy-url-link:hover{text-decoration:underline}.deploy-form{padding:20px 24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;max-height:400px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.deploy-input{padding:10px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:14px;color:var(--text-primary);font-family:var(--font-mono);transition:all .2s ease}.deploy-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #5865f233}.deploy-input::placeholder{color:var(--text-tertiary)}.environment-selector{display:flex;gap:10px}.env-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.env-btn:hover{background:#ffffff0f;border-color:#ffffff26}.env-btn.active{border-color:var(--accent-color);background:#5865f226;color:var(--text-primary)}.env-btn.active.production{border-color:#10b981;background:#10b98126}.env-btn.active.staging{border-color:#f59e0b;background:#f59e0b26}.env-btn.active.development{border-color:#5865f2;background:#5865f226}.advanced-toggle{display:flex;align-items:center;gap:8px;padding:8px 0;background:none;border:none;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:color .2s ease}.advanced-toggle:hover{color:var(--text-primary)}.advanced-options{display:flex;flex-direction:column;gap:14px;padding-top:8px;border-top:1px solid rgba(255,255,255,.05)}.add-env-btn{padding:2px 8px;background:#5865f233;border:none;border-radius:4px;font-size:11px;color:var(--accent-color);cursor:pointer;transition:background .2s ease}.add-env-btn:hover{background:#5865f24d}.env-var-row{display:flex;align-items:center;gap:8px}.env-key{flex:0 0 120px}.env-equals{color:var(--text-tertiary);font-family:var(--font-mono)}.env-value{flex:1}.remove-env-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:6px;color:#ef4444;cursor:pointer;font-size:12px;transition:all .2s ease}.remove-env-btn:hover{background:#ef444433}.deploy-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;background:#0003;border-top:1px solid rgba(255,255,255,.05)}.deploy-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.deploy-btn.primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.deploy-btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #10b98166}.deploy-btn.secondary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary)}.deploy-btn.secondary:hover{background:#ffffff14;color:var(--text-primary)}.deploy-btn.danger{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#ef4444}.deploy-btn.danger:hover{background:#ef444440}.collaborative-cursors{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000;overflow:visible}.user-cursor{position:absolute;pointer-events:none;transition:left .05s linear,top .05s linear;z-index:1001}.cursor-pointer{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));transform:rotate(-6deg)}.cursor-label{position:absolute;top:16px;left:12px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;box-shadow:0 2px 8px #0000004d;animation:cursorLabelFadeIn .2s ease}@keyframes cursorLabelFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.presence-indicator{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#14141ecc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:24px;box-shadow:0 4px 16px #0003}.presence-avatars{display:flex;align-items:center}.presence-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;border:2px solid rgba(15,15,22,1);margin-left:-8px;transition:transform .2s ease}.presence-avatar:first-child{margin-left:0}.presence-avatar:hover{transform:scale(1.15);z-index:10!important}.presence-more{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fffc;background:#ffffff1a;border:2px solid rgba(15,15,22,1);margin-left:-8px}.presence-count{font-size:12px;color:#fff9;font-weight:500}.user-cursor{animation:cursorAppear .3s ease}@keyframes cursorAppear{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.user-cursor.clicking:after{content:"";position:absolute;top:0;left:0;width:20px;height:20px;border-radius:50%;background:var(--cursor-color);opacity:0;animation:cursorClick .4s ease-out}@keyframes cursorClick{0%{opacity:.5;transform:scale(1)}to{opacity:0;transform:scale(3)}}.port-management-content{display:flex;flex-direction:column;gap:16px;padding:4px;height:100%;overflow:hidden}.port-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;transition:all .2s ease}.stat-card:hover{background:#ffffff0d;border-color:#ffffff1a}.stat-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px}.stat-icon.active{background:#10b98126;color:#10b981}.stat-icon.available{background:#3b82f626;color:#3b82f6}.stat-info{display:flex;flex-direction:column;gap:2px}.stat-number{font-size:20px;font-weight:700;color:#fff;line-height:1}.stat-label{font-size:11px;color:#ffffff80;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.port-usage-section{padding:14px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px}.usage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.usage-title{font-size:12px;font-weight:600;color:#fffc}.usage-range{font-size:11px;color:#fff6;font-family:SF Mono,Consolas,monospace}.usage-bar-container{height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.usage-bar-fill{height:100%;border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1)}.usage-details{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:#ffffff80}.port-filter-tabs{display:flex;gap:6px;padding:4px;background:#ffffff08;border-radius:8px}.filter-tab{flex:1;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:#ffffff80;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-tab:hover{background:#ffffff0d;color:#fffc}.filter-tab.active{background:#df3e5326;color:#df3e53}.port-error-message{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#ef4444;font-size:12px}.port-error-message span{flex:1}.port-error-message button{background:none;border:none;color:#ef4444;font-size:16px;cursor:pointer;padding:0;line-height:1;opacity:.7}.port-error-message button:hover{opacity:1}.port-list-container{flex:1;overflow-y:auto;min-height:0}.port-list-container::-webkit-scrollbar{width:5px}.port-list-container::-webkit-scrollbar-track{background:transparent}.port-list-container::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.port-list-container::-webkit-scrollbar-thumb:hover{background:#ffffff26}.port-loading-state,.port-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#fff6;gap:12px}.loading-spinner{width:28px;height:28px;border:2px solid rgba(255,255,255,.1);border-top-color:#df3e53;border-radius:50%;animation:spin 1s linear infinite}.port-empty-state svg{opacity:.3}.port-empty-state p{margin:0;font-size:13px}.port-items{display:flex;flex-direction:column;gap:6px}.port-item-card{display:flex;flex-direction:column;gap:8px;padding:12px 14px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:8px;transition:all .2s ease}.port-item-card:hover{background:#ffffff0a;border-color:#ffffff14}.port-item-card.status-active{border-left:2px solid #10b981}.port-item-card.status-inactive{border-left:2px solid rgba(255,255,255,.2);opacity:.7}.port-item-card.status-reserved{border-left:2px solid #f59e0b}.port-item-main{display:flex;align-items:center;gap:10px}.port-status-dot{font-size:10px;line-height:1}.port-status-dot.active{color:#10b981}.port-status-dot.inactive{color:#ffffff4d}.port-status-dot.reserved{color:#f59e0b}.port-number-display{font-size:14px;font-weight:700;color:#fff;font-family:SF Mono,Consolas,monospace;min-width:45px}.port-service-name{font-size:12px;color:#ffffffb3;font-weight:500;flex:1}.port-item-meta{display:flex;justify-content:space-between;align-items:center;padding-left:20px}.port-project-name{font-size:11px;color:#fff6}.port-date{font-size:10px;color:#ffffff4d;font-family:SF Mono,Consolas,monospace}.port-footer{padding-top:12px;border-top:1px solid rgba(255,255,255,.06)}.refresh-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;color:#fff9;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.refresh-btn:hover:not(:disabled){background:#ffffff0f;color:#ffffffe6}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn svg{transition:transform .3s ease}.refresh-btn:hover:not(:disabled) svg{transform:rotate(180deg)}.notification-bell-container{position:relative}.notification-bell-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;position:relative}.notification-bell-btn:hover{background:#ffffff0f;border-color:#ffffff1f;color:var(--text-primary)}.notification-bell-btn.active{background:#df3e531a;border-color:#df3e534d;color:#df3e53}.notification-bell-btn.has-notifications:after{content:"";position:absolute;top:6px;right:6px;width:8px;height:8px;background:#df3e53;border-radius:50%;animation:pulse 2s ease-in-out infinite}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:linear-gradient(135deg,#df3e53,#ff6b6b);border-radius:9px;font-size:10px;font-weight:600;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #df3e5366}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:#121218fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 16px 40px #00000080;z-index:1000;overflow:hidden;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.notification-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.clear-all-btn{padding:4px 10px;background:transparent;border:none;font-size:12px;color:var(--text-tertiary);cursor:pointer;transition:color .2s}.clear-all-btn:hover{color:#df3e53}.notification-list{max-height:380px;overflow-y:auto}.notification-list::-webkit-scrollbar{width:4px}.notification-list::-webkit-scrollbar-track{background:transparent}.notification-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-tertiary)}.notification-empty svg{opacity:.3;margin-bottom:12px}.notification-empty p{margin:0;font-size:13px}.notification-item{display:flex;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s ease;border-bottom:1px solid rgba(255,255,255,.03)}.notification-item:hover{background:#ffffff08}.notification-item:last-child{border-bottom:none}.notification-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:#ffffff0d}.notification-icon.success{background:#22c55e26;color:#22c55e}.notification-icon.error{background:#ef444426;color:#ef4444}.notification-icon.pending{background:#f59e0b26;color:#f59e0b}.notification-icon.in_progress{background:#3b82f626;color:#3b82f6}.notification-content{flex:1;min-width:0}.notification-title{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-desc{font-size:12px;color:var(--text-secondary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-tertiary)}.node-name{padding:2px 6px;background:#ffffff0d;border-radius:4px}.notification-footer{padding:10px 16px;border-top:1px solid rgba(255,255,255,.08)}.view-all-btn{width:100%;padding:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.view-all-btn:hover{background:#ffffff0f;color:var(--text-primary)}.notification-item.status-error{border-left:2px solid #ef4444}.notification-item.status-success{border-left:2px solid #22c55e}.notification-item.status-pending{border-left:2px solid #f59e0b}.notification-item.status-in_progress{border-left:2px solid #3b82f6}.deployment-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.deployment-modal.carousel-style{background:linear-gradient(180deg,#1a1a2e,#16162a);border:1px solid rgba(99,102,241,.2);border-radius:24px;width:380px;padding:40px 32px;display:flex;flex-direction:column;align-items:center;gap:24px;box-shadow:0 24px 48px #00000080,0 0 80px #6366f11a}.carousel-container{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;padding:20px 0}.carousel-step{display:flex;align-items:center;gap:12px;transition:all .4s cubic-bezier(.4,0,.2,1);width:100%;justify-content:center}.carousel-step.prev-step{opacity:.25;transform:scale(.85) translateY(-8px);filter:blur(1px)}.carousel-step.prev-step .carousel-name{font-size:14px;color:#ffffff80}.carousel-step.prev-step .carousel-icon{width:24px;height:24px;font-size:12px;background:#22c55e33;color:#22c55e}.carousel-step.current-step{opacity:1;transform:scale(1);flex-direction:column;gap:16px;padding:24px;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:16px}.current-step-icon-wrapper{position:relative}.carousel-step.current-step .carousel-icon{width:64px;height:64px;font-size:24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #6366f166}.carousel-step.current-step .carousel-icon.completed,.carousel-step.current-step .carousel-icon.success-icon{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 8px 24px #22c55e66}.carousel-step.current-step.failed .carousel-icon{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 8px 24px #ef444466}.current-step-info{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.carousel-step.current-step .carousel-name{font-size:18px;font-weight:600;color:#fff}.carousel-message{font-size:13px;color:#ffffff80}.carousel-progress{width:120px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin-top:8px}.carousel-progress-bar{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);transition:width .3s ease}.carousel-step.next-step{opacity:.25;transform:scale(.85) translateY(8px);filter:blur(1px)}.carousel-step.next-step .carousel-name{font-size:14px;color:#ffffff80}.carousel-step.next-step .carousel-icon{width:24px;height:24px;font-size:12px;background:#ffffff1a;color:#fff6}.carousel-icon{border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.carousel-placeholder{height:24px}.spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.step-counter{display:flex;align-items:baseline;gap:4px;color:#fff9;font-size:14px}.step-current{font-size:24px;font-weight:700;color:#6366f1}.step-divider{color:#ffffff4d}.step-total{font-size:16px;font-weight:500}.step-label{margin-left:4px;color:#fff6}.step-dots{display:flex;gap:8px;justify-content:center}.step-dot{width:8px;height:8px;border-radius:50%;background:#ffffff26;transition:all .3s ease}.step-dot.completed,.step-dot.skipped{background:#22c55e}.step-dot.running,.step-dot.active{background:#6366f1;box-shadow:0 0 8px #6366f199;animation:pulse 1.5s ease-in-out infinite}.step-dot.failed{background:#ef4444}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.live-files-compact{width:100%;max-height:80px;overflow-y:auto;background:#0000004d;border-radius:8px;padding:8px;font-family:Monaco,Menlo,Consolas,monospace;font-size:11px}.file-item-compact{display:flex;align-items:center;gap:6px;padding:2px 4px;opacity:.7;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:.7;transform:translate(0)}}.file-item-compact.created{color:#22c55e}.file-item-compact.modified{color:#f59e0b}.file-item-compact.deleted{color:#ef4444}.file-action-icon{font-weight:700;width:12px;text-align:center}.file-path-compact{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deployment-error-compact{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:100%}.deployment-error-compact .error-icon{color:#ef4444;font-size:16px}.deployment-error-compact .error-text{font-size:13px;color:#fca5a5}.deployment-actions-compact{display:flex;gap:12px;justify-content:center;width:100%}.deployment-actions-compact button{padding:10px 24px;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary-compact{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;flex:1}.btn-primary-compact:hover{transform:translateY(-2px);box-shadow:0 4px 16px #6366f166}.btn-secondary-compact{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#ffffffb3}.btn-secondary-compact:hover{background:#ffffff1f;color:#fff}.btn-cancel-compact{background:transparent;border:1px solid rgba(239,68,68,.3);color:#f87171}.btn-cancel-compact:hover{background:#ef44441a}.btn-retry-compact{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#22c55e;flex:1}.btn-retry-compact:hover{background:#22c55e40}.confirmation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.confirmation-modal{background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px;max-width:450px;width:90%;text-align:center;animation:slideIn .3s ease}.confirmation-icon{font-size:48px;margin-bottom:16px}.confirmation-title{font-size:20px;font-weight:600;color:#fff;margin:0 0 12px}.confirmation-message{font-size:14px;color:#ffffffb3;margin:0 0 20px;line-height:1.5}.confirmation-details{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;margin-bottom:24px;text-align:left}.detail-item{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:#fffc;padding:4px 0}.detail-bullet{color:#6366f1;font-weight:700}.confirmation-actions{display:flex;gap:12px;justify-content:center}.confirmation-actions button{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px}.confirmation-actions .btn-cancel{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff}.confirmation-actions .btn-cancel:hover{background:#ffffff26}.confirmation-actions .btn-confirm{border:none;color:#fff}.confirmation-actions .btn-confirm.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.confirmation-actions .btn-confirm.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.confirmation-actions .btn-confirm.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.confirmation-actions .btn-confirm.danger:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.confirmation-actions .btn-confirm.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.confirmation-actions .btn-confirm.success:hover{transform:translateY(-1px);box-shadow:0 4px 12px #22c55e66}.canvas-parallax-bg{position:absolute;top:-200px;right:-200px;bottom:-200px;left:-200px;background:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0;transition:transform .05s ease-out}.canvas-parallax-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(88,101,242,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(88,101,242,.02) 1px,transparent 1px);background-size:180px 180px;pointer-events:none}.canvas-view-page{display:flex;flex-direction:column;width:100%;height:100vh;background:linear-gradient(135deg,#08080c,#0e0e14,#0a0a10);color:var(--text-primary);overflow:hidden;position:relative}.canvas-glow-orb{position:fixed;border-radius:50%;filter:blur(100px);opacity:.25;pointer-events:none;z-index:0}.canvas-glow-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(223,62,83,.4) 0%,transparent 70%);top:-200px;right:-150px;animation:floatOrb1 30s ease-in-out infinite}.canvas-glow-orb-2{width:600px;height:600px;background:radial-gradient(circle,rgba(88,101,242,.3) 0%,transparent 70%);bottom:-250px;left:-200px;animation:floatOrb2 35s ease-in-out infinite}@keyframes floatOrb1{0%,to{transform:translate(0) scale(1);opacity:.4}50%{transform:translate(-30px,20px) scale(1.1);opacity:.5}}@keyframes floatOrb2{0%,to{transform:translate(0) scale(1);opacity:.3}50%{transform:translate(40px,-30px) scale(1.15);opacity:.45}}.canvas-layout{display:flex;flex:1;overflow:hidden;position:relative;z-index:1}.canvas-sidebar{display:flex;flex-direction:column;align-items:center;width:56px;background:transparent;border-right:none;padding:12px 8px;gap:8px;position:relative;z-index:10}.sidebar-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#14141eb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:12px;color:var(--text-secondary);font-size:18px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000004d,inset 0 1px #ffffff0d}.sidebar-btn:hover{background:#1e1e2dd9;border-color:#df3e534d;color:var(--text-primary);transform:translateY(-2px);box-shadow:0 6px 20px #0006,0 0 20px #df3e5326,inset 0 1px #ffffff14}.sidebar-btn:active{transform:scale(.95) translateY(0)}.sidebar-btn.active{background:#df3e5333;border-color:#df3e5380;color:#df3e53;box-shadow:0 4px 12px #0000004d,0 0 20px #df3e5333,inset 0 1px #ffffff14}.sidebar-divider{width:32px;height:1px;background:#ffffff1a;margin:4px 0}.zoom-indicator{font-size:11px;color:var(--text-tertiary);text-align:center;padding:4px 0;margin-top:auto}.canvas-main{display:flex;flex-direction:column;flex:1;overflow:hidden;position:relative}.canvas-toolbar{display:flex;align-items:center;justify-content:space-between;height:52px;background:#0a0a0fd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(223,62,83,.15);padding:0 20px;gap:16px;box-shadow:0 2px 16px #0003}.toolbar-left{display:flex;align-items:center;gap:16px;flex:1}.toolbar-right{display:flex;gap:12px}.breadcrumb-nav{display:flex;align-items:center;gap:8px}.breadcrumb-item{background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all var(--transition-fast)}.breadcrumb-item:hover{color:var(--text-primary);background:var(--hover-bg)}.breadcrumb-item.current{color:var(--text-primary);cursor:default}.breadcrumb-item.current:hover{background:none}.breadcrumb-separator{color:var(--text-tertiary);font-size:14px}.toolbar-btn.back-btn{background:#ffffff14;border-color:#ffffff26}.toolbar-btn.back-btn:hover{background:#df3e5326;border-color:#df3e5366;color:#df3e53}.toolbar-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.toolbar-btn:hover{background:#df3e5326;border-color:#df3e534d;color:#df3e53}.toolbar-btn:active{transform:scale(.95)}.toolbar-btn span{font-size:14px;font-weight:600}.sync-btn{color:var(--text-secondary)}.sync-btn:hover{color:#22c55e;border-color:#22c55e4d;background:#22c55e1a}.layout-btn{color:var(--text-secondary)}.layout-btn.active{color:#df3e53;border-color:#df3e5366;background:#df3e5326}.layout-btn svg{width:14px;height:14px}.create-btn{background:linear-gradient(135deg,#df3e53,#c93547);border-color:transparent;color:#fff;box-shadow:0 4px 15px #df3e534d}.create-btn:hover{background:linear-gradient(135deg,#e85a6b,#df3e53);border-color:transparent;transform:translateY(-1px);box-shadow:0 6px 20px #df3e5366}.canvas-container{flex:1;display:flex;position:relative;overflow:hidden;background:transparent;cursor:grab}.canvas-container:active{cursor:grabbing}.canvas-fixed-grid{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}.canvas-fixed-dots{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.08) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;z-index:0}.canvas-background{position:absolute;top:0;left:0;pointer-events:none;z-index:0}.canvas-transform-layer{position:absolute;top:0;left:0;width:100%;height:100%;transform-origin:0 0;will-change:transform;z-index:1}.canvas-connections{z-index:1}.nodes-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10}.canvas-view-transitioning{pointer-events:none}.canvas-view-transitioning .nodes-container{transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s ease}.node-wrapper{transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,filter .3s ease}.node-wrapper.focused{z-index:100}.node-wrapper.focused .service-node{transform:scale(1.15);box-shadow:0 0 40px #5865f266;border-color:var(--accent-color)}.node-wrapper.fading-out{opacity:0;transform:scale(.7);filter:blur(6px);pointer-events:none}.node-wrapper.hidden-for-fade{opacity:0;transform:scale(.5);filter:blur(8px)}.node-wrapper.fade-in{animation:nodeAppear .4s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes nodeAppear{0%{opacity:0;transform:scale(.5);filter:blur(8px)}50%{opacity:.7;filter:blur(2px)}to{opacity:1;transform:scale(1);filter:blur(0)}}.node-wrapper.view-parent{z-index:50}.node-wrapper.child-node{opacity:0;transform:scale(.8)}.node-wrapper.child-node.visible{opacity:1;transform:scale(1)}.parent-node-indicator{position:fixed;top:120px;left:80px;z-index:50;display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-lg)}.parent-node-indicator:hover{background:var(--tertiary-bg);border-color:var(--accent-color)}.parent-node-indicator .parent-icon{font-size:24px}.parent-node-indicator .parent-info h4{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.parent-node-indicator .parent-info span{font-size:12px;color:var(--text-secondary)}.child-view-back-btn{position:fixed;top:120px;left:80px;z-index:50;display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.child-view-back-btn:hover{background:var(--tertiary-bg);border-color:var(--accent-color)}.child-view-back-btn span{font-size:18px}.service-node{position:absolute;width:280px;padding:16px;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;cursor:move;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:12px}.service-node:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-color),transparent);opacity:0;transition:opacity var(--transition-fast);border-radius:8px 8px 0 0}.service-node:hover{background:var(--tertiary-bg);border-color:var(--border-color-hover);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.service-node:hover:before{opacity:1}.service-node.running{border-left:4px solid #10b981}.service-node.stopped{border-left:4px solid #f59e0b}.service-node.error{border-left:4px solid #ef4444}.node-header{display:flex;align-items:center;gap:12px}.node-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;background:var(--accent-light);border-radius:6px;color:var(--accent-color);font-size:16px;font-weight:600}.node-label{font-size:14px;font-weight:600;margin:0;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.node-status{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:6px}.status-dot{flex-shrink:0;color:#10b981;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.status-text{font-size:12px;font-weight:500;color:#10b981}.node-ports{position:relative;height:20px}.port{position:absolute;width:12px;height:12px;background:var(--accent-color);border:2px solid var(--secondary-bg);border-radius:50%;transition:all var(--transition-fast);cursor:crosshair}.port-in{left:-26px;top:50%;transform:translateY(-50%)}.port-out{right:-26px;top:50%;transform:translateY(-50%)}.port:hover{width:16px;height:16px;box-shadow:0 0 12px #5865f2cc;border-width:1.5px}.canvas-activity{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;height:240px;max-height:50vh;background:rgba(var(--secondary-bg-rgb, 18, 18, 18),.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.08);border-radius:16px 16px 0 0;z-index:50;transition:height .3s ease,transform .3s ease}.activity-header{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.activity-header:hover{background:#ffffff08}.activity-header h3{margin:0;font-size:13px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.activity-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;background:var(--accent-color);color:#fff;font-size:10px;font-weight:600;border-radius:9px}.activity-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;align-content:start}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--tertiary-bg);border-radius:8px;border:1px solid var(--border-color);transition:all var(--transition-fast)}.activity-item:hover{background:var(--hover-bg);border-color:var(--border-color-hover)}.activity-item.activity-success{border-left:3px solid #10b981}.activity-item.activity-error{border-left:3px solid #ef4444}.activity-item.activity-pending{border-left:3px solid #f59e0b}.activity-item.activity-in_progress{border-left:3px solid #3b82f6}.activity-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;background:var(--accent-light);border-radius:6px;font-size:14px}.activity-details{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.activity-title{margin:0;font-size:13px;font-weight:600;color:var(--text-primary)}.activity-description{margin:0;font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-time{font-size:11px;color:var(--text-tertiary)}.canvas-main.panel-open{transition:all .3s ease}.canvas-activity.hidden{transform:translateY(100%);pointer-events:none}.canvas-activity{transition:height .3s ease,transform .3s ease}.canvas-activity.collapsed{height:44px}.canvas-activity.collapsed .activity-header h3{display:block}.canvas-activity.collapsed .activity-content{display:none}.collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.collapse-btn:hover{background:#ffffff1a;border-color:#ffffff26;color:var(--text-primary)}.canvas-activity .collapse-btn svg{transition:transform .3s ease}.canvas-activity.collapsed .collapse-btn svg{transform:rotate(180deg)}.activity-header-controls{display:flex;align-items:center;gap:8px}.canvas-connections{position:absolute;top:0;left:0;pointer-events:none;z-index:1}.connection-line{filter:url(#glow)}.node-count,.connection-count{font-size:13px;color:var(--text-secondary);font-weight:500}.connection-count{margin-left:16px;padding-left:16px;border-left:1px solid var(--border-color)}.breadcrumb-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;margin-left:16px;background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.breadcrumb-btn:hover{background:var(--hover-bg);border-color:var(--border-color-hover);color:var(--text-primary)}.canvas-main.activity-collapsed{flex:1}.nodes-container [data-node-id].dragging{transition:none!important;z-index:100}.nodes-container [data-node-id].dragging .service-node{box-shadow:var(--shadow-xl);transform:scale(1.02)}@media (max-width: 1024px){.canvas-activity{width:250px}.service-node{width:240px}}@media (max-width: 768px){.canvas-layout{flex-direction:column}.canvas-sidebar{flex-direction:row;width:100%;height:48px;border-right:none;border-bottom:1px solid var(--border-color);justify-content:flex-start;padding:8px 12px;gap:8px}.canvas-activity{display:none}.service-node{width:200px;padding:12px}.node-label{font-size:13px}.toolbar-btn{padding:6px 12px;font-size:12px}}@media (max-width: 480px){.canvas-sidebar{justify-content:center}.service-node{width:160px;padding:10px}.node-icon{width:32px;height:32px;font-size:14px}.node-label{font-size:12px}.toolbar-btn{padding:6px 10px;font-size:11px}.toolbar-btn span{display:none}}.drawing-canvas{background:transparent;touch-action:none}.drawing-canvas:hover{cursor:crosshair}.canvas-container.drawing-mode{position:relative}.canvas-container.drawing-mode:after{content:"Drawing Mode";position:absolute;top:12px;left:50%;transform:translate(-50%);padding:6px 12px;background:#5865f2e6;color:#fff;font-size:12px;font-weight:500;border-radius:6px;z-index:1001;pointer-events:none}.connection-line{cursor:pointer;transition:filter .2s ease}.connection-line:hover,.connection-line.hovered{filter:drop-shadow(0 0 8px rgba(88,101,242,.6))}.connection-flow-line{stroke-dasharray:12 8;animation:connectionFlow 1.5s linear infinite}@keyframes connectionFlow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20}}.connection-glow{animation:connectionPulse 2.5s ease-in-out infinite}@keyframes connectionPulse{0%,to{stroke-opacity:.15;stroke-width:6}50%{stroke-opacity:.3;stroke-width:10}}.connection-endpoint{animation:endpointPulse 2s ease-in-out infinite}@keyframes endpointPulse{0%,to{r:4;opacity:.8}50%{r:6;opacity:1}}.connection-particle{fill:currentColor;opacity:.9}.connection-particle-animate{offset-path:path(attr(data-path));animation:particleFlow 3s linear infinite}@keyframes particleFlow{0%{offset-distance:0%;opacity:0}10%{opacity:1}90%{opacity:1}to{offset-distance:100%;opacity:0}}.connection-depends{--connection-color: #5865f2}.connection-child{--connection-color: #10b981}.connection-calls{--connection-color: #8b5cf6}.connection-connects{--connection-color: #f59e0b}.connection-label{pointer-events:none;animation:labelFadeIn .2s ease}@keyframes labelFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.pending-connection{pointer-events:none}.canvas-container.connection-mode:after{content:"Click a node to start connection";position:absolute;top:12px;left:50%;transform:translate(-50%);padding:6px 12px;background:#df3e53e6;color:#fff;font-size:12px;font-weight:500;border-radius:6px;z-index:1001;pointer-events:none}.presence-indicator{margin-left:16px;padding-left:16px;border-left:1px solid var(--border-color)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.modal-container{background:linear-gradient(160deg,#14141cfa,#0c0c12fa);border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 24px 48px #00000080;max-width:700px;width:90%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;animation:slideIn .25s ease}.modal-container.ai-questionnaire-modal{max-width:600px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.05)}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:none;border-radius:8px;font-size:20px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.modal-close:hover{background:#ffffff1a;color:var(--text-primary)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-deploy-btn{position:fixed;bottom:32px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:14px 28px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:50px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 20px #22c55e66,0 0 40px #22c55e33,inset 0 1px #fff3;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100;animation:deployBtnPulse 3s ease-in-out infinite}.floating-deploy-btn:hover{transform:translate(-50%) translateY(-3px) scale(1.02);background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 8px 30px #22c55e80,0 0 60px #22c55e4d,inset 0 1px #ffffff40}.floating-deploy-btn:active{transform:translate(-50%) translateY(-1px) scale(.98)}.floating-deploy-btn svg{flex-shrink:0}.floating-deploy-btn span{white-space:nowrap}@keyframes deployBtnPulse{0%,to{box-shadow:0 4px 20px #22c55e66,0 0 40px #22c55e33,inset 0 1px #fff3}50%{box-shadow:0 4px 25px #22c55e80,0 0 50px #22c55e4d,inset 0 1px #fff3}}.admin-auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f23,#1a1a2e,#16213e);padding:20px}.admin-auth-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:40px;width:100%;max-width:400px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.admin-auth-header{text-align:center;margin-bottom:32px}.admin-logo{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff}.admin-auth-header h1{color:#fff;font-size:24px;font-weight:600;margin-bottom:8px}.admin-auth-header p{color:#fff9;font-size:14px}.logged-in-as{margin-top:12px;padding:8px 12px;background:#6366f11a;border-radius:8px;font-size:13px}.logged-in-as strong{color:#818cf8}.admin-auth-field{margin-bottom:20px}.admin-auth-field label{display:block;color:#ffffffb3;font-size:13px;margin-bottom:8px}.admin-auth-field input{width:100%;padding:14px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:15px;transition:all .2s ease}.admin-auth-field input:focus{outline:none;border-color:#6366f1;background:#6366f10d}.admin-auth-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#f87171;font-size:14px;margin-bottom:20px}.admin-auth-button{width:100%;padding:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.admin-auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #6366f166}.admin-auth-button:disabled{opacity:.6;cursor:not-allowed}.admin-auth-back{width:100%;padding:12px;background:transparent;border:none;color:#ffffff80;font-size:14px;cursor:pointer;margin-top:16px;transition:color .2s ease}.admin-auth-back:hover{color:#fffc}.admin-panel{display:flex;min-height:100vh;background:#0f0f23}.admin-sidebar{width:260px;background:#ffffff05;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column}.admin-sidebar-header{padding:20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.06)}.admin-brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:600;font-size:16px}.admin-brand svg{color:#818cf8}.admin-logout{padding:8px;background:transparent;border:none;color:#fff6;cursor:pointer;border-radius:6px;transition:all .2s ease}.admin-logout:hover{background:#ef44441a;color:#f87171}.admin-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:8px;color:#fff9;font-size:14px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.admin-nav-item:hover{background:#ffffff0d;color:#ffffffe6}.admin-nav-item.active{background:#6366f126;color:#818cf8}.admin-nav-item svg{flex-shrink:0}.admin-nav-item span:first-of-type:not(.nav-badge){flex:1}.nav-badge{padding:2px 8px;background:#ffffff1a;border-radius:12px;font-size:12px;font-weight:500}.admin-nav-item.active .nav-badge{background:#6366f14d}.admin-sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.06)}.admin-user-info{display:flex;flex-direction:column;gap:2px}.admin-user-name{color:#fff;font-weight:500;font-size:14px}.admin-user-role{color:#fff6;font-size:12px}.admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-header h1{color:#fff;font-size:22px;font-weight:600}.admin-header-actions{display:flex;gap:12px}.admin-content{flex:1;padding:24px 32px;overflow-y:auto}.admin-loading,.admin-error{display:flex;align-items:center;justify-content:center;height:200px;color:#ffffff80;font-size:15px}.admin-error{color:#f87171}.btn-primary{padding:10px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6366f166}.btn-secondary{padding:10px 20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fffc;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#ffffff1a;color:#fff}.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}.btn-warning{background:#fbbf241a;border:1px solid rgba(251,191,36,.2);color:#fbbf24}.btn-warning:hover{background:#fbbf2433}.btn-danger{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#f87171}.btn-danger:hover{background:#ef444433}.btn-icon{padding:4px 6px;background:transparent;border:none;cursor:pointer;font-size:12px;opacity:.6;transition:opacity .2s ease}.btn-icon:hover{opacity:1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;background:#6366f11a}.stat-icon.users{background:#3b82f61a}.stat-icon.teams{background:#10b9811a}.stat-icon.projects{background:#fbbf241a}.stat-icon.admins{background:#8b5cf61a}.stat-icon.active{background:#22c55e1a}.stat-icon.logins{background:#ec48991a}.stat-info{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:28px;font-weight:700;color:#fff}.stat-label{font-size:13px;color:#ffffff80}.overview-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:24px}.overview-section{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:20px}.overview-section h3{color:#fff;font-size:15px;font-weight:600;margin-bottom:16px}.mini-table{display:flex;flex-direction:column;gap:8px}.mini-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#ffffff05;border-radius:8px}.mini-row .user-name,.mini-row .team-name{color:#fff;font-weight:500;font-size:14px}.mini-row .user-team,.mini-row .team-stats{color:#fff6;font-size:13px;margin-left:auto}.badge{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase}.badge.admin{background:#8b5cf626;color:#a78bfa}.badge.leader{background:#3b82f626;color:#60a5fa}.badge.member{background:#ffffff0d;color:#ffffff80}.admin-table-container{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:14px 16px;background:#ffffff05;color:#ffffff80;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-table td{padding:14px 16px;color:#fffc;font-size:14px;border-bottom:1px solid rgba(255,255,255,.04)}.admin-table tbody tr:hover{background:#ffffff05}.admin-table tbody tr:last-child td{border-bottom:none}.team-cell{display:flex;flex-direction:column;gap:2px}.team-cell strong{color:#fff}.team-slug{font-size:12px;color:#fff6}.token-cell{display:flex;align-items:center;gap:4px}.token-cell code{font-family:monospace;font-size:12px;background:#ffffff0d;padding:4px 8px;border-radius:4px}.token-cell code.hidden,.no-token{color:#ffffff4d}.role-badges{display:flex;gap:6px}.action-buttons{display:flex;gap:6px;flex-wrap:wrap}.status-badge{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.active{background:#22c55e26;color:#22c55e}.status-badge.pending{background:#fbbf2426;color:#fbbf24}.status-badge.archived{background:#6b728026;color:#9ca3af}.deployed-yes{color:#22c55e}.deployed-no{color:#fff6}.project-cell{display:flex;flex-direction:column;gap:2px}.project-cell strong{color:#fff}.project-desc{font-size:12px;color:#fff6}.audit-table .timestamp{font-size:12px;color:#ffffff80;white-space:nowrap}.action-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600}.action-badge.user,.action-badge.create{background:#22c55e26;color:#22c55e}.action-badge.update,.action-badge.token{background:#3b82f626;color:#60a5fa}.action-badge.delete{background:#ef444426;color:#f87171}.action-badge.admin{background:#8b5cf626;color:#a78bfa}.resource-type{font-size:11px;color:#fff6;text-transform:uppercase;display:block}.resource-id{font-family:monospace;font-size:11px;color:#ffffff80}.details{font-family:monospace;font-size:11px;color:#fff6;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#1a1a2e;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px;width:100%;max-width:450px}.modal-content h2{color:#fff;font-size:20px;font-weight:600;margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;color:#ffffffb3;font-size:13px;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f1}.form-group textarea{min-height:80px;resize:vertical}.form-group.checkbox label{display:flex;align-items:center;gap:10px;cursor:pointer}.form-group.checkbox input{width:auto}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}@media (max-width: 1024px){.admin-sidebar{width:220px}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.admin-panel{flex-direction:column}.admin-sidebar{width:100%;order:2;border-right:none;border-top:1px solid rgba(255,255,255,.06)}.admin-nav{flex-direction:row;overflow-x:auto}.admin-nav-item{flex-direction:column;padding:12px;min-width:80px;text-align:center;gap:6px}.admin-nav-item span{font-size:11px}.nav-badge,.admin-sidebar-footer{display:none}.admin-main{order:1}.stats-grid{grid-template-columns:1fr}.admin-table-container{overflow-x:auto}.admin-table{min-width:800px}}.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-bg) 0%,var(--secondary-bg) 100%);background-color:#0a0a0a;padding:2rem;position:relative;overflow:hidden}.not-found-container{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:1000px;width:100%;position:relative;z-index:2;align-items:center}.not-found-content{animation:slideIn .5s ease-out}.not-found-title{font-size:6rem;font-weight:800;background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-hover) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;line-height:1}.not-found-heading{font-size:2rem;margin:1rem 0;color:var(--text-primary)}.not-found-text{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.not-found-actions{display:flex;gap:1rem;flex-wrap:wrap}.not-found-actions .btn{padding:.875rem 2rem;font-size:1rem}.not-found-decoration{position:relative;height:300px;display:flex;align-items:center;justify-content:center}.decoration-circle{position:absolute;width:200px;height:200px;border:2px solid var(--accent-dim);border-radius:50%;animation:rotate 20s linear infinite}.decoration-circle:before{content:"";position:absolute;width:10px;height:10px;background:var(--accent-color);border-radius:50%;top:10px;left:50%;transform:translate(-50%)}.decoration-square{position:absolute;width:150px;height:150px;border:2px solid rgba(59,130,246,.3);transform:rotate(45deg);animation:rotate 30s linear infinite reverse}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.decoration-square{animation:rotate 30s linear infinite reverse}@media (max-width: 768px){.not-found-container{grid-template-columns:1fr;gap:2rem}.not-found-title{font-size:4rem}.not-found-heading{font-size:1.5rem}.not-found-decoration{display:none}.not-found-actions{flex-direction:column}.not-found-actions .btn{width:100%}}html{scroll-behavior:smooth}:root{--primary-bg: #0a0a0a;--secondary-bg: #121212;--tertiary-bg: #1a1a1a;--primary-bg-rgb: 10, 10, 10;--secondary-bg-rgb: 18, 18, 18;--tertiary-bg-rgb: 26, 26, 26;--header-bg-rgb: 15, 15, 15;--surface: #1f1f1f;--surface-light: #2a2a2a;--surface-lighter: #333333;--header-bg: #0f0f0f;--tabs-bg: #0f0f0f;--dropdown-bg: #161616;--border-color: #2a2a2a;--border-color-hover: #3a3a3a;--border-subtle: #1a1a1a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-tertiary: #707070;--text-muted: #505050;--accent-color: #5865f2;--accent-hover: #4752d4;--accent-light: rgba(88, 101, 242, .1);--success-color: #10b981;--success-light: rgba(16, 185, 129, .1);--warning-color: #f59e0b;--warning-light: rgba(245, 158, 11, .1);--error-color: #ef4444;--error-light: rgba(239, 68, 68, .1);--env-badge-bg: rgba(16, 185, 129, .08);--env-badge-border: rgba(16, 185, 129, .2);--env-badge-text: #10b981;--avatar-bg: rgba(88, 101, 242, .1);--avatar-bg-hover: rgba(88, 101, 242, .15);--hover-bg: rgba(255, 255, 255, .05);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 8px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .6);--shadow-xl: 0 12px 24px rgba(0, 0, 0, .7);--shadow-2xl: 0 20px 40px rgba(0, 0, 0, .8);--gradient-accent: linear-gradient( 135deg, var(--accent-color), var(--accent-hover) );--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--primary-bg);background-color:#0a0a0a;color:var(--text-primary);line-height:1.6;letter-spacing:-.02em;min-height:100vh;margin:0;padding:0}#root{background:var(--primary-bg);background-color:#0a0a0a;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;letter-spacing:-.02em;line-height:1.2}h1{font-size:32px}h2{font-size:24px}h3{font-size:18px}h4{font-size:16px}h5{font-size:14px}h6{font-size:12px}p{color:var(--text-secondary);font-size:14px;line-height:1.6}button{font-family:inherit;cursor:pointer;border:none;background:transparent}a{color:var(--accent-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}input,textarea,select{font-family:inherit;font-size:14px;color:var(--text-primary);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;transition:all var(--transition-fast)}input:hover,textarea:hover,select:hover{border-color:var(--border-color-hover);background:var(--tertiary-bg)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-color);background:var(--tertiary-bg);box-shadow:0 0 0 3px #5865f21a}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-light);border-radius:4px;transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--surface-lighter)}.container{max-width:1400px;margin:0 auto;padding:0 24px}.text-center{text-align:center}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.p-6{padding:24px}.p-8{padding:32px}.m-2{margin:8px}.m-3{margin:12px}.m-4{margin:16px}.m-6{margin:24px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}*{transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}button,a,input{transition:all var(--transition-base)}body{background:var(--primary-bg);color:var(--text-primary)}@media (max-width: 1024px){.container{padding:0 16px}h1{font-size:28px}h2{font-size:20px}}@media (max-width: 768px){body{font-size:14px}h1{font-size:24px}h2{font-size:18px}.container{padding:0 12px}}@media (max-width: 480px){h1{font-size:20px}h2{font-size:16px}body{font-size:13px}}.react-flow{background:#0a0a0a!important}.react-flow__pane,.react-flow__container,.react-flow__viewport,.react-flow__renderer{background:transparent!important}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{background-color:var(--secondary-bg, #121212)!important;border-color:var(--border-color, #2a2a2a)!important;color:var(--text-primary, #ffffff)!important}.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 4px 12px #00000080!important}.react-flow__node-default.selectable.selected,.react-flow__node-input.selectable.selected,.react-flow__node-output.selectable.selected,.react-flow__node-group.selectable.selected{box-shadow:0 0 0 2px var(--accent-color, #5865f2)!important}.react-flow__edge-textbg{fill:var(--secondary-bg, #121212)!important}.react-flow__edge-text{fill:var(--text-primary, #ffffff)!important}.react-flow__edge-path,.react-flow__connection-path{stroke:var(--border-color, #2a2a2a)!important}.react-flow__edge.selected .react-flow__edge-path{stroke:var(--accent-color, #5865f2)!important}.react-flow__handle{background:var(--accent-color, #5865f2)!important;border-color:var(--secondary-bg, #121212)!important}.react-flow__controls{box-shadow:0 0 4px #00000080!important}.react-flow__controls-button{background:var(--secondary-bg, #121212)!important;border-bottom-color:var(--border-color, #2a2a2a)!important;fill:var(--text-primary, #ffffff)!important}.react-flow__controls-button:hover{background:var(--tertiary-bg, #1a1a1a)!important}.react-flow__controls-button svg{fill:var(--text-primary, #ffffff)!important}.react-flow__minimap{background-color:var(--secondary-bg, #121212)!important}.react-flow__nodesselection-rect,.react-flow__selection{background:#5865f21a!important;border-color:var(--accent-color, #5865f2)!important}.react-flow__attribution{background:var(--secondary-bg, #121212)!important}.react-flow__attribution a{color:var(--text-tertiary, #707070)!important}.perf-low *{animation-duration:0s!important;animation-delay:0s!important;transition-duration:0s!important}.perf-low .canvas-parallax-bg,.perf-low .canvas-glow-orb{display:none!important}.perf-low .service-node,.perf-low .sidebar-btn{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.perf-medium .canvas-glow-orb{animation:none!important;opacity:.15!important}.perf-medium .service-node{backdrop-filter:blur(4px)!important;-webkit-backdrop-filter:blur(4px)!important}.perf-medium .canvas-parallax-bg{transition:none!important}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.canvas-glow-orb,.canvas-parallax-bg:before{animation:none!important}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;background:var(--primary-bg);background-color:#0a0a0a;color:var(--text-primary);min-height:100vh}.dashboard{display:flex;flex-direction:column;width:100%;height:100vh;background:var(--primary-bg);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-hover) 100%);color:#000;box-shadow:var(--shadow-md);height:64px}.app-header h1{font-size:1.5em;font-weight:700;margin:0;color:#000}.header-status{display:flex;align-items:center;gap:12px}.status-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0003;border-radius:4px;font-size:.9em;font-weight:500;color:#000}.status-indicator.connected{background:#10b98166}.status-indicator.disconnected{background:#ef444466}.main-layout{display:flex;flex:1;overflow:hidden}.sidebar{width:350px;background:var(--secondary-bg);border-right:1px solid var(--border-color);overflow-y:auto;box-shadow:var(--shadow-md)}.canvas-area{flex:1;display:flex;overflow:hidden;background:var(--primary-bg);position:relative}@media (max-width: 1024px){.sidebar{width:280px}}@media (max-width: 768px){.main-layout{flex-direction:column}.sidebar{width:100%;height:250px;max-height:40vh;border-right:none;border-bottom:1px solid #e0e0e0}.canvas-area{flex:1;height:60vh}.app-header{padding:12px 16px;height:56px}.app-header h1{font-size:1.2em}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;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:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation: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;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.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{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.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{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.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 rgba(0,89,220,.8)}.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{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.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{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.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-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}html,body,#root{background-color:#0a0a0a;color:#fff;min-height:100vh;margin:0;padding:0}
