.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 20% 30%,rgba(0,212,255,.15) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(124,58,237,.15) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(59,130,246,.1) 0%,transparent 50%);z-index:-2;animation:backgroundRotate 20s ease infinite}@keyframes backgroundRotate{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}}.login-container:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(0,212,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,.03) 1px,transparent 1px);background-size:50px 50px;z-index:-1;animation:gridMove 20s linear infinite}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.login-card{width:100%;max-width:420px;padding:3rem 2.5rem;border-radius:28px;background:#0f0f17b3;-webkit-backdrop-filter:blur(40px) saturate(200%);backdrop-filter:blur(40px) saturate(200%);border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 80px #000c,0 0 60px #00d4ff26,inset 0 1px #ffffff1a;position:relative;overflow:hidden;transition:transform .4s cubic-bezier(.4,0,.2,1)}.login-card:hover{transform:translateY(-4px)}.login-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.8),rgba(124,58,237,.8),rgba(0,212,255,.8),transparent);animation:shimmerBorder 3s ease infinite}@keyframes shimmerBorder{0%{transform:translate(-100%)}to{transform:translate(100%)}}.login-card:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(0,212,255,.1) 0%,transparent 70%);animation:particleFloat 8s ease-in-out infinite;pointer-events:none}@keyframes particleFloat{0%,to{transform:translate(0) scale(1);opacity:.3}50%{transform:translate(20px,-20px) scale(1.2);opacity:.6}}.glass{background:#0f0f1799;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.1)}.login-header{text-align:center;margin-bottom:2.5rem;position:relative}.login-logo-image{height:65px;width:auto;margin:0 auto 1.5rem;display:block;filter:drop-shadow(0 0 30px rgba(0,212,255,.6));animation:logoFloat 5s ease-in-out infinite;transition:transform .3s ease}.login-logo-image:hover{transform:scale(1.1) rotate(5deg)}@keyframes logoFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-12px) scale(1.05)}}.login-app-name{font-size:2.75rem;font-weight:900;margin:.75rem 0;line-height:1.1;letter-spacing:-.04em;position:relative;display:inline-block}.login-app-name:after{content:"";position:absolute;bottom:-6px;left:0;width:100%;height:3px;background:linear-gradient(90deg,#00d4ffcc,#7c3aedcc);border-radius:2px;opacity:.6}.login-app-name-primary{display:inline-block;background:linear-gradient(135deg,#00d4ff,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.login-app-name-secondary{display:inline-block;color:#fff;font-weight:900;text-shadow:0 0 15px rgba(124,58,237,.9),0 0 30px rgba(124,58,237,.5),0 0 45px rgba(124,58,237,.3);margin-left:.5rem;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.login-subtitle{color:#ffffffb3;font-size:.875rem;margin-top:.75rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;text-shadow:0 2px 10px rgba(0,0,0,.5)}.login-form{display:flex;flex-direction:column;gap:1.75rem}.form-group{display:flex;flex-direction:column;gap:.875rem;position:relative}.form-group label{color:#fffffff2;font-weight:600;font-size:.95rem;letter-spacing:.05em;text-transform:uppercase;margin-left:.25rem}.login-input{padding:1.125rem 1.5rem;border-radius:16px;border:2px solid rgba(255,255,255,.1);color:#fffffff2;font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);background:#14141e99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 2px 4px #0000004d,0 1px #ffffff0d}.login-input:focus{outline:none;border-color:#00d4ffcc;background:#191923cc;box-shadow:0 0 0 4px #00d4ff26,0 0 20px #00d4ff4d,inset 0 2px 4px #0000004d;transform:translateY(-1px)}.login-input::placeholder{color:#fff6;font-weight:400}.password-input-wrapper{position:relative;width:100%}.password-input-wrapper .login-input{width:100%;padding-right:3.5rem}.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff9;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;border-radius:8px;width:36px;height:36px;z-index:10}.password-toggle:hover{color:#00d4ff;background:#00d4ff26;transform:translateY(-50%) scale(1.1)}.password-toggle:active{transform:translateY(-50%) scale(.95)}.login-button{padding:1.25rem 2rem;background:linear-gradient(135deg,#00d4ff,#3b82f6,#7c3aed);border:none;border-radius:16px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.75rem;box-shadow:0 8px 24px #00d4ff66,0 0 40px #00d4ff33,inset 0 1px #fff3;margin-top:1rem;letter-spacing:.1em;text-transform:uppercase;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s ease}.login-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 32px #00d4ff80,0 0 60px #00d4ff4d,inset 0 1px #ffffff4d}.login-button:hover:not(:disabled):before{left:100%}.login-button:active:not(:disabled){transform:translateY(-1px)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{animation:spin 1s linear infinite}.login-footer{margin-top:2rem;text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);position:relative}.login-footer:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:60px;height:2px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.8),transparent)}.login-footer p{color:#ffffff80;font-size:.85rem;font-weight:500;letter-spacing:.05em}.error-message{display:flex;align-items:center;gap:.875rem;padding:1.125rem 1.5rem;background:#ef444433;border:2px solid rgba(239,68,68,.4);border-radius:16px;color:#ff6b6b;font-size:.9rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #ef444433,inset 0 1px #ffffff1a;animation:errorShake .5s ease}@keyframes errorShake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@media (max-width: 640px){.login-card{padding:3rem 2rem;border-radius:24px}.login-app-name{font-size:2.5rem}.login-logo-image{height:60px}}.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%}.vision-automation-container{display:flex;height:calc(100vh - 120px);background:var(--bg-glass);border-radius:24px;border:1px solid rgba(255,255,255,.08);overflow:hidden;position:relative;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #0006;margin:1rem}.automation-palette{width:240px;background:#0f0f17f2;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;z-index:100;transition:all .3s ease}.palette-header{padding:1.5rem;display:flex;align-items:center;gap:.75rem;font-family:Inter,sans-serif;font-weight:700;font-size:.95rem;color:var(--text-primary);border-bottom:1px solid rgba(255,255,255,.05);letter-spacing:.02em}.palette-body{flex:1;overflow-y:auto;padding:1rem}.palette-group{margin-bottom:2rem;display:flex;flex-direction:column;gap:.75rem}.palette-group label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-tertiary);margin-bottom:.5rem;font-weight:700;padding-left:.25rem}.palette-btn{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:12px;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:grab;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.palette-btn:hover{background:#ffffff14;border-color:#00d4ff4d;color:var(--text-primary);transform:translate(4px);box-shadow:0 4px 12px #0003}.palette-btn:active{cursor:grabbing}.palette-footer{padding:1.25rem;background:#0a0a0fcc;border-top:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:.75rem}.vision-store-btn,.load-pipeline-btn,.save-pipeline-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:.75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--text-secondary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease}.vision-store-btn{background:#7c3aed1a;border-color:#7c3aed4d;color:#a78bfa}.vision-store-btn:hover{background:#7c3aed33;border-color:#7c3aed99;color:#fff;box-shadow:0 0 15px #7c3aed33}.load-pipeline-btn:hover,.save-pipeline-btn:hover{background:#ffffff1a;color:#fff;border-color:#fff3}.run-global-btn{width:100%;padding:.875rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:10px;color:#6ee7b7;font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:.6rem;cursor:pointer;transition:all .3s ease}.run-global-btn:hover{background:#10b98140;border-color:#10b98199;box-shadow:0 0 20px #10b98133;transform:translateY(-1px)}.run-global-btn.active{background:#ef444426;border-color:#ef44444d;color:#fca5a5;animation:pulse-red 2s infinite}@keyframes pulse-red{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.automation-workspace{flex:1;position:relative;display:flex;flex-direction:column;overflow:hidden}.workspace-header-bar{height:60px;background:#0f0f17cc;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;z-index:10}.canvas-info{display:flex;align-items:center;gap:1rem}.toggle-sidebar-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);border-radius:8px;padding:6px;cursor:pointer;display:flex;align-items:center;transition:all .2s}.toggle-sidebar-btn:hover{background:#ffffff1a;color:#fff}.tenant-badge{background:#00d4ff1a;color:#00d4ff;font-size:.7rem;padding:4px 10px;border-radius:6px;border:1px solid rgba(0,212,255,.2);text-transform:uppercase;font-weight:700;letter-spacing:.05em}.pipeline-title-editable{display:flex;align-items:center;font-size:.9rem;color:var(--text-secondary)}.title-label{margin-right:8px;font-weight:500;opacity:.7}.pipeline-name-display{color:#fff;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;transition:all .2s}.pipeline-name-display:hover{background:#ffffff14}.pipeline-name-input{background:#0006;border:1px solid #00d4ff;border-radius:6px;color:#fff;font-weight:600;font-size:.9rem;padding:4px 10px;outline:none;min-width:250px}.node-box{width:240px;background:#191923;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 10px 40px #00000080;transition:all .3s ease;overflow:hidden}.node-box:hover{border-color:#fff3;transform:translateY(-2px);box-shadow:0 15px 50px #0009}.node-box.selected{border-color:#00d4ff;box-shadow:0 0 0 2px #00d4ff4d,0 15px 50px #0009}.node-header{padding:.8rem 1rem;background:linear-gradient(180deg,#ffffff0d,#ffffff05);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:.75rem}.node-header svg{opacity:.9}.node-name{flex:1;font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-delete{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex}.node-delete:hover{background:#ef44441a;color:#ef4444}.node-content{padding:1rem;position:relative}.node-image-preview-wrapper{display:block;position:relative;border-radius:8px;overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.1);margin-bottom:.75rem}.node-tiny-preview{width:100%;height:80px;object-fit:cover;display:block;transition:transform .3s}.node-image-preview-wrapper:hover .node-tiny-preview{transform:scale(1.05)}.node-image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;gap:6px;color:#fff;font-size:.75rem;font-weight:600;opacity:0;transition:opacity .2s}.node-image-preview-wrapper:hover .node-image-overlay{opacity:1}.node-quick-upload{width:100%;height:80px;border:2px dashed rgba(255,255,255,.1);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-secondary);font-size:.75rem;cursor:pointer;background:#0003;transition:all .2s}.node-quick-upload:hover{border-color:#00d4ff80;background:#00d4ff0d;color:#00d4ff}.node-service-label{font-size:.65rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:700;letter-spacing:.05em;margin-top:.25rem}.node-status-bar{padding:.6rem 1rem;background:#0000004d;display:flex;align-items:center;justify-content:space-between}.node-play-small{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.node-play-small:hover{background:#10b9811a;border-color:#10b98166;color:#10b981}.status-dot-small{width:8px;height:8px;border-radius:50%;background:#333;box-shadow:inset 0 1px 2px #00000080}.status-dot-small.idle{background:#555}.status-dot-small.running{background:#00d4ff;box-shadow:0 0 10px #00d4ff;animation:pulse 1s infinite}.status-dot-small.completed{background:#10b981;box-shadow:0 0 8px #10b981}.status-dot-small.failed{background:#ef4444;box-shadow:0 0 8px #ef4444}.node-inspector{position:absolute;top:1.5rem;right:1.5rem;width:320px;max-height:calc(100vh - 180px);z-index:50;animation:slideInRight .3s cubic-bezier(.4,0,.2,1)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.inspector-card{background:#14141ed9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;box-shadow:0 20px 60px #0009;display:flex;flex-direction:column;overflow:hidden}.inspector-header{padding:1.25rem;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:.75rem;color:#fff;font-weight:700;font-size:.95rem}.inspector-header svg{color:#00d4ff}.inspector-header span{flex:1}.inspector-header button{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:50%;transition:all .2s}.inspector-header button:hover{background:#ffffff1a;color:#fff}.inspector-body{padding:1.25rem;overflow-y:auto;max-height:70vh;display:flex;flex-direction:column;gap:1.25rem}.inspector-section{display:flex;flex-direction:column;gap:.5rem}.inspector-section label{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-left:2px}.inspector-section input[type=text],.inspector-section textarea,.inspector-section select{width:100%;padding:.75rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.9rem;transition:all .2s;font-family:inherit}.inspector-section input:focus,.inspector-section textarea:focus,.inspector-section select:focus{outline:none;border-color:#00d4ff;background:#00000080;box-shadow:0 0 0 3px #00d4ff1a}.inspector-section textarea{min-height:80px;resize:vertical;line-height:1.5}.toggle-group{display:flex;background:#0000004d;padding:4px;border-radius:10px;border:1px solid rgba(255,255,255,.05)}.toggle-group button{flex:1;padding:6px;border:none;background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.toggle-group button.active{background:#ffffff1a;color:#fff;box-shadow:0 2px 8px #0003}.format-group{display:flex;flex-wrap:wrap;gap:8px}.format-group button{padding:6px 12px;font-size:.75rem;font-weight:600;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);cursor:pointer}.format-group button.active{background:#00d4ff26;border-color:#00d4ff;color:#00d4ff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#191923;width:500px;max-width:90vw;border-radius:24px;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 100px #000000b3;overflow:hidden;animation:scaleIn .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.pipeline-list{max-height:400px;overflow-y:auto;padding:1rem}.pipeline-item{padding:1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:12px;margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.pipeline-item:hover{background:#00d4ff0d;border-color:#00d4ff4d;transform:scale(1.01)}.p-name{font-weight:600;font-size:.95rem;color:#fff;display:block}.p-id{font-size:.7rem;color:var(--text-tertiary);font-family:monospace}.log-viewer-modal{width:800px;height:600px;display:flex;flex-direction:column}.log-viewer-content{flex:1;background:#0a0a0f;padding:1.5rem;margin:0;overflow-y:auto;font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;color:#ccc}.log-line{border-bottom:1px solid rgba(255,255,255,.05);padding:4px 0;white-space:pre-wrap;word-break:break-all}.react-flow__handle{width:10px;height:10px;background:#00d4ff;border:2px solid #191923;transition:all .2s}.react-flow__handle:hover{background:#fff;transform:scale(1.3);box-shadow:0 0 10px #00d4ff}.react-flow__edge-path{stroke:#555;stroke-width:2;transition:all .3s}.react-flow__edge.selected .react-flow__edge-path{stroke:#00d4ff;stroke-width:3}.react-flow__controls{box-shadow:0 8px 20px #0006;background:#14141ee6;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:4px}.react-flow__controls-button{background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.05);fill:#fff;color:#fff}.react-flow__controls-button:hover{background:#ffffff1a}.react-flow__controls-button svg{fill:currentColor}.edge-device-selector{margin-top:8px;padding:10px;background:#0003;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.edge-device-dropdown{width:100%;padding:8px;background:#0006;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.85rem}.camera-stream-player{position:relative;width:100%;background:#000;border-radius:8px;overflow:hidden;aspect-ratio:16 / 9}.stream-video{width:100%;height:100%;object-fit:contain;display:block}.stream-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000c;color:#fff;z-index:10}.loading-spinner{animation:spin 1s linear infinite;margin-bottom:10px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stream-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:10px;display:flex;gap:8px;opacity:0;transition:opacity .3s}.camera-stream-player:hover .stream-controls{opacity:1}.control-btn{background:#fff3;border:none;color:#fff;padding:8px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.control-btn:hover{background:#ffffff4d}.control-btn:active{background:#fff6}.camera-stream-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;background:#f5f5f5;border-radius:8px;color:#666;min-height:200px}.error-icon{color:#e74c3c;margin-bottom:10px}.camera-stream-error p{margin:0;text-align:center}.camera-management-container{padding:2rem;max-width:1400px;margin:0 auto;color:#ffffffe6}.camera-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header-title{display:flex;align-items:center;gap:12px}.header-title h2{margin:0;font-size:1.75rem;font-weight:600;color:#fff}.add-camera-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#00d4ff,#09c);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.add-camera-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00d4ff4d}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#00d4ff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state h3{margin:1rem 0 .5rem;color:#ffffffb3}.empty-state p{color:#ffffff80;margin-bottom:1.5rem}.cameras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.camera-card{background:#19192399;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.camera-card:hover{border-color:#00d4ff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.camera-card.disabled{opacity:.6}.camera-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.05)}.camera-status{display:flex;align-items:center;gap:6px;font-size:.875rem}.status-enabled{color:#10b981}.status-disabled{color:#ef4444}.camera-actions{display:flex;gap:8px}.icon-btn{background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:6px;color:#fff9;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:#ffffff0d;color:#fff;border-color:#fff3}.delete-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.camera-card-body{display:flex;flex-direction:column;gap:.75rem}.camera-name{margin:0;font-size:1.125rem;font-weight:600;color:#fff}.camera-description{margin:0;color:#fff9;font-size:.875rem;line-height:1.5}.camera-info{display:flex;flex-direction:column;gap:6px}.info-item{display:flex;align-items:center;gap:8px;color:#ffffffb3;font-size:.875rem}.camera-url{margin-top:.5rem;padding:.75rem;background:#0000004d;border-radius:6px}.camera-url label{display:block;font-size:.75rem;color:#ffffff80;margin-bottom:4px}.camera-url code{display:block;font-family:JetBrains Mono,monospace;font-size:.75rem;color:#00d4ff;word-break:break-all}.camera-meta{display:flex;flex-direction:column;gap:4px;margin-top:.5rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05);font-size:.75rem;color:#fff6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#191923;border:1px solid rgba(255,255,255,.1);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-bottom:1px solid rgba(255,255,255,.05)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.close-btn{background:transparent;border:none;color:#fff6;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-btn:hover{color:#fff}.camera-form{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#fffc}.required{color:#ef4444}.form-group input,.form-group textarea{padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#00d4ff;box-shadow:0 0 0 3px #00d4ff1a}.form-group input.error,.form-group textarea.error{border-color:#ef4444}.error-message{font-size:.75rem;color:#ef4444}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.05)}.cancel-btn,.save-btn{padding:10px 20px;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.cancel-btn{background:transparent;color:#fff9;border:1px solid rgba(255,255,255,.1)}.cancel-btn:hover{background:#ffffff0d;color:#fff}.save-btn{background:linear-gradient(135deg,#00d4ff,#09c);color:#fff}.save-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00d4ff4d}.toast-notification{position:fixed;bottom:2rem;right:2rem;display:flex;align-items:center;gap:10px;padding:12px 20px;background:#191923;border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:2000;animation:slideIn .3s ease-out}.toast-notification.success{border-color:#10b9814d}.toast-notification.error{border-color:#ef44444d}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.camera-edge-device{margin-top:.75rem;padding:.75rem;background:#0003;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.edge-device-attached{display:flex;justify-content:space-between;align-items:center;gap:1rem}.edge-device-info{display:flex;align-items:center;gap:8px;flex:1}.edge-device-info svg{color:#00d4ff;flex-shrink:0}.device-name{font-size:.875rem;color:#fffc;font-weight:500}.device-health{font-size:.75rem;padding:2px 6px;border-radius:4px;font-weight:600}.device-health.health-healthy{color:#10b981;background:#10b9811a}.device-health.health-unhealthy{color:#f59e0b;background:#f59e0b1a}.device-health.health-unknown{color:#fff6;background:#ffffff0d}.edge-device-actions{display:flex;gap:6px}.push-config-btn{color:#00d4ff}.push-config-btn:hover{background:#00d4ff1a;border-color:#00d4ff4d}.detach-btn{color:#ffffff80}.detach-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.edge-device-not-attached{display:flex;justify-content:space-between;align-items:center;gap:1rem}.not-attached-label{font-size:.875rem;color:#ffffff80;font-style:italic}.attach-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:6px;color:#00d4ff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.attach-btn:hover:not(:disabled){background:#00d4ff33;border-color:#00d4ff80}.attach-btn:disabled{opacity:.5;cursor:not-allowed}.device-select{padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:.875rem;transition:all .2s}.device-select:focus{outline:none;border-color:#00d4ff;box-shadow:0 0 0 3px #00d4ff1a}.device-loading,.device-empty{padding:.75rem;font-size:.875rem;color:#ffffff80;font-style:italic;text-align:center}.form-hint{font-size:.75rem;color:#fff6;margin-top:4px}.form-group label{display:flex;align-items:center;gap:6px}.form-group label svg{color:#00d4ff}.camera-stream-section{margin-top:1rem;margin-bottom:1rem;border-top:1px solid rgba(255,255,255,.1);padding-top:1rem}.stream-btn{color:#ffffffb3}.stream-btn:hover{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.stream-btn.active{background:#22c55e33;border-color:#22c55e80;color:#22c55e}@media (max-width: 768px){.cameras-grid,.form-row{grid-template-columns:1fr}.camera-management-header{flex-direction:column;align-items:flex-start;gap:1rem}.edge-device-attached,.edge-device-not-attached{flex-direction:column;align-items:flex-start}.edge-device-actions{width:100%;justify-content:flex-end}}.sidebar-groups{width:260px;background:#0a0a0ff2;-webkit-backdrop-filter:blur(40px) saturate(200%);backdrop-filter:blur(40px) saturate(200%);border-right:1px solid rgba(255,255,255,.08);padding:1.5rem .75rem;display:flex;flex-direction:column;gap:1rem;overflow-y:auto;flex-shrink:0;box-shadow:4px 0 24px #0006;z-index:50}.group-button{display:flex;align-items:center;gap:.875rem;padding:.875rem 1.25rem;background:transparent;border:none;border-radius:12px;color:#a1a1aa;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:left;width:100%;position:relative;overflow:hidden}.group-button:hover{background:#ffffff0d;color:#fff;transform:translate(4px)}.group-button.active{background:linear-gradient(90deg,#00d4ff1a,#00d4ff05);color:#fff;font-weight:700;box-shadow:inset 2px 0 #00d4ff}.group-button svg{opacity:.7;transition:opacity .2s}.group-button:hover svg,.group-button.active svg{opacity:1;filter:drop-shadow(0 0 8px rgba(255,255,255,.3))}.group-label{flex:1;letter-spacing:.02em}.sidebar-subgroup{display:flex;flex-direction:column;gap:.25rem;margin-top:-.5rem;margin-bottom:.5rem;padding-left:1rem;position:relative;animation:slideDown .3s cubic-bezier(.16,1,.3,1);transform-origin:top}.sidebar-subgroup:before{content:"";position:absolute;top:0;left:1.5rem;bottom:0;width:1px;background:linear-gradient(180deg,#ffffff1a,#ffffff05)}@keyframes slideDown{0%{opacity:0;transform:scaleY(.95) translateY(-5px)}to{opacity:1;transform:scaleY(1) translateY(0)}}.subgroup-button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem .75rem 1.5rem;background:transparent;border:none;border-radius:8px;color:#71717a;font-size:.85rem;cursor:pointer;transition:all .2s;text-align:left;width:100%;position:relative}.subgroup-button:hover{color:#fff;background:#ffffff08}.subgroup-button.active{color:#00d4ff;background:#00d4ff14;font-weight:600}.subgroup-button svg{width:16px;height:16px;opacity:.8}.subgroup-button.active svg{opacity:1;filter:drop-shadow(0 0 6px rgba(0,212,255,.4))}.app-layout{display:flex;flex:1;height:100vh;overflow:hidden}.main-content-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow-y:auto;height:100%}.app-main{padding:0;max-width:none;height:100%}.content-wrapper{padding:2rem 3rem;max-width:1600px;margin:0 auto;width:100%;height:100%}:root{--primary-cyan: #00d4ff;--primary-teal: #00b8d4;--accent-purple: #7c3aed;--accent-blue: #3b82f6;--success-green: #10b981;--warning-amber: #f59e0b;--error-red: #ef4444;--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-tertiary: #1a1a24;--bg-glass: rgba(26, 26, 36, .8);--bg-card: rgba(17, 17, 24, .6);--text-primary: #ffffff;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--border-color: rgba(0, 212, 255, .15);--border-hover: rgba(0, 212, 255, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--glow-cyan: 0 0 20px rgba(0, 212, 255, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;line-height:1.6}#root{min-height:100vh}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%,rgba(0,212,255,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(124,58,237,.08) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(59,130,246,.06) 0%,transparent 50%),linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 50%,var(--bg-primary) 100%);background-size:200% 200%;animation:gradientShift 20s ease infinite;z-index:-2}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}body:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(0,212,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none;z-index:-1;animation:gridPulse 8s ease-in-out infinite}@keyframes gridPulse{0%,to{opacity:.3}50%{opacity:.6}}h1,h2,h3,h4,h5,h6{font-weight:700;letter-spacing:-.02em;line-height:1.2}code{font-family:Fira Code,Courier New,monospace;font-size:.9em}html{scroll-behavior:smooth}::selection{background:#00d4ff4d;color:var(--text-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#00d4ff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00d4ff80}
