.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}.view-toggle{display:flex;background:#0000004d;border-radius:12px;padding:4px;border:1px solid rgba(255,255,255,.08);margin-right:1rem}.view-toggle-btn{background:transparent;border:none;font-size:.85rem;font-weight:500;color:var(--text-secondary);padding:6px 16px;cursor:pointer;border-radius:8px;display:flex;align-items:center;gap:8px;transition:all .3s ease}.view-toggle-btn:hover{color:#fff;background:#ffffff0d}.view-toggle-btn.active{background:linear-gradient(135deg,#8b5cf633,#8b5cf61a);color:#c4b5fd;border:1px solid rgba(139,92,246,.2);box-shadow:0 4px 12px #8b5cf61a}.dashboard-container{flex:1;padding:2rem 3rem;overflow-y:auto;background:radial-gradient(circle at top right,#14141e,#0a0a0f);width:100%}.dashboard-header{margin-bottom:2.5rem;display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:1.5rem}.dashboard-header-content h2{font-size:2rem;font-weight:600;margin-bottom:.5rem;background:linear-gradient(90deg,#fff,#a5b4fc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}.dashboard-header-content p{color:var(--text-secondary);font-size:1rem;max-width:600px;line-height:1.5}.refresh-btn{padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.85rem;transition:all .2s}.refresh-btn:hover{background:#ffffff1a;color:#fff;border-color:#fff3;transform:translateY(-1px)}.pipelines-list-container{flex:1;padding:2rem 3rem;overflow-y:auto;background:radial-gradient(circle at top right,#14141e,#0a0a0f);width:100%}.pipelines-list-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:1.5rem}.pipelines-list-header-content h2{font-size:2rem;font-weight:600;margin-bottom:.5rem;background:linear-gradient(90deg,#fff,#a5b4fc);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}.pipelines-list-header-content p{color:var(--text-secondary);font-size:1rem;max-width:560px;line-height:1.5}.pipelines-list-header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.pipelines-search-wrap{position:relative;display:flex;align-items:center}.pipelines-search-icon{position:absolute;left:12px;color:var(--text-tertiary);pointer-events:none}.pipelines-search-input{padding:8px 16px 8px 40px;background:#00000059;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.9rem;width:260px;transition:all .2s}.pipelines-search-input::placeholder{color:var(--text-tertiary)}.pipelines-search-input:focus{outline:none;border-color:#00d4ff66;box-shadow:0 0 0 2px #00d4ff1a}.pipelines-list-content{min-height:200px}.pipelines-empty{text-align:center;padding:4rem 2rem;color:var(--text-tertiary);font-style:italic;font-size:1rem}.pipelines-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.pipeline-card{background:#1e1e2880;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:1.25rem;transition:all .2s;display:flex;flex-direction:column;gap:1rem}.pipeline-card:hover{border-color:#ffffff1f;box-shadow:0 12px 32px #00000040}.pipeline-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.pipeline-card-name{font-weight:600;font-size:1.1rem;color:#fff;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pipeline-card-status{flex-shrink:0;padding:4px 10px;border-radius:8px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.pipeline-card-status.running{background:#00d4ff26;color:#00d4ff;border:1px solid rgba(0,212,255,.3)}.pipeline-card-status.stopped{background:#ffffff0f;color:var(--text-tertiary);border:1px solid rgba(255,255,255,.08)}.pipeline-card-status.failed,.pipeline-card-status.error{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.pipeline-card-details{display:flex;flex-direction:column;gap:6px}.pipeline-card-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.pipeline-card-label{color:var(--text-tertiary);font-weight:500}.pipeline-card-value{color:var(--text-secondary);font-weight:500}.pipeline-card-id{font-family:JetBrains Mono,monospace;font-size:.75rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffff80}.pipeline-card-nodes-preview{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.pipeline-card-node-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#ffffff0d;border-radius:6px;font-size:.7rem;color:var(--text-secondary);border:1px solid rgba(255,255,255,.06)}.pipeline-card-node-tag svg{flex-shrink:0;opacity:.8}.pipeline-card-node-more{font-size:.7rem;color:var(--text-tertiary);padding:2px 6px}.pipeline-card-actions{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.pipeline-card-actions .p-action-btn{padding:6px 10px;font-size:.75rem;display:inline-flex;align-items:center;gap:4px}.pipeline-card-actions .load-btn{margin-right:auto}.pipeline-table-container{background:#1e1e2866;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.05);overflow:hidden;box-shadow:0 20px 40px #0003}.pipeline-table{width:100%;border-collapse:separate;border-spacing:0}.pipeline-table th{text-align:left;padding:1.25rem 1.5rem;font-size:.75rem;text-transform:uppercase;font-weight:600;color:var(--text-tertiary);letter-spacing:.08em;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.08)}.pipeline-table td{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-secondary);vertical-align:middle;transition:background .2s}.pipeline-table tr:last-child td{border-bottom:none}.pipeline-table tbody tr:hover td{background:#ffffff08}.pipeline-name-cell{display:flex;flex-direction:column;gap:4px}.pipeline-name-text{font-weight:600;font-size:1rem;color:#fff}.pipeline-id-text{font-size:.75rem;font-family:JetBrains Mono,monospace;color:#ffffff4d}.table-node-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.node-badge{font-size:.75rem;padding:4px 10px;background:#0000004d;border-radius:6px;color:var(--text-secondary);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:6px}.node-badge-more{font-size:.7rem;padding:4px 8px;background:#ffffff0d;border-radius:6px;color:var(--text-tertiary)}.actions-cell{display:flex;gap:.75rem;justify-content:flex-end}.p-action-btn{width:34px;height:34px;border-radius:8px}.play-btn:hover{box-shadow:0 0 12px #10b9814d}.stop-btn:hover{box-shadow:0 0 12px #ef44444d}.node-box{width:200px;background:#191923;border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 8px 24px #00000080;transition:all .3s ease;overflow:hidden}.node-box:hover{border-color:#fff3;transform:translateY(-2px);box-shadow:0 12px 32px #0009}.node-box.selected{border-color:#00d4ff;box-shadow:0 0 0 2px #00d4ff4d,0 12px 32px #0009}.node-header{padding:.65rem .85rem;background:linear-gradient(180deg,#ffffff0d,#ffffff05);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:.6rem}.node-header svg{opacity:.9;width:16px;height:16px}.node-name{flex:1;font-size:.8125rem;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:3px;border-radius:4px;transition:all .2s;display:flex}.node-delete:hover{background:#ef44441a;color:#ef4444}.node-delete svg{width:14px;height:14px}.node-content{padding:.75rem;position:relative}.node-image-preview-wrapper{display:block;position:relative;border-radius:6px;overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.1);margin-bottom:.6rem}.node-tiny-preview{width:100%;height:60px;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:5px;color:#fff;font-size:.7rem;font-weight:600;opacity:0;transition:opacity .2s}.node-image-preview-wrapper:hover .node-image-overlay{opacity:1}.node-quick-upload{width:100%;height:60px;border:2px dashed rgba(255,255,255,.1);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-secondary);font-size:.7rem;cursor:pointer;background:#0003;transition:all .2s}.node-quick-upload:hover{border-color:#00d4ff80;background:#00d4ff0d;color:#00d4ff}.node-quick-upload svg{width:18px;height:18px}.node-service-label{font-size:.625rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:700;letter-spacing:.05em;margin-top:.2rem}.node-status-bar{padding:.5rem .75rem;background:#0000004d;display:flex;align-items:center;justify-content:space-between}.node-play-small{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:5px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.node-play-small svg{width:12px;height:12px}.node-play-small:hover{background:#10b9811a;border-color:#10b98166;color:#10b981}.status-dot-small{width:7px;height:7px;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:#00d4ff;transform:scale(1.3);box-shadow:0 0 15px #00d4ffcc}.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}.react-flow__minimap{background:#0f0f17f2!important;border:1px solid rgba(0,212,255,.3)!important;border-radius:16px!important;box-shadow:0 8px 32px #0009,0 0 0 1px #00d4ff1a!important;-webkit-backdrop-filter:blur(20px)!important;backdrop-filter:blur(20px)!important;overflow:hidden!important;width:280px!important;height:auto!important;min-height:200px!important;max-height:400px!important}.react-flow__minimap:before{content:"Pipeline Overview";display:block;padding:.75rem 1rem;background:linear-gradient(135deg,#00d4ff26,#7c3aed1a);border-bottom:1px solid rgba(0,212,255,.2);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary-cyan)}.react-flow__minimap-mask{fill:#00d4ff1a!important;stroke:var(--primary-cyan)!important;stroke-width:2!important}.react-flow__minimap-node{fill:#ffffff26!important;stroke:#ffffff4d!important;stroke-width:1!important}.pipeline-stats-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.8) 30%,rgba(0,0,0,.95) 100%);padding:1rem;border-top:1px solid rgba(0,212,255,.2);z-index:10}.pipeline-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.625rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-value{font-size:1.125rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.375rem}.stat-value.success{color:var(--success-green)}.stat-value.error{color:var(--error-red)}.stat-value.running{color:var(--primary-cyan);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.7}}.execution-progress{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05)}.progress-label{font-size:.625rem;color:var(--text-secondary);margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center}.progress-bar-container{height:6px;background:#0006;border-radius:3px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-cyan),var(--accent-purple));border-radius:3px;transition:width .3s ease;box-shadow:0 0 10px #00d4ff80}.progress-bar-fill.animated{animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.minimap-actions{display:flex;gap:.5rem;margin-top:.75rem}.minimap-action-btn{flex:1;padding:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.375rem}.minimap-action-btn:hover{background:#00d4ff1a;border-color:var(--primary-cyan);color:var(--primary-cyan)}.minimap-action-btn svg{width:12px;height:12px}.minimap-node-list{max-height:120px;overflow-y:auto;margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05)}.minimap-node-item{display:flex;align-items:center;gap:.5rem;padding:.375rem 0;font-size:.7rem;color:var(--text-secondary)}.minimap-node-status{width:6px;height:6px;border-radius:50%;flex-shrink:0}.minimap-node-status.idle{background:#555}.minimap-node-status.running{background:#00d4ff;box-shadow:0 0 8px #00d4ff;animation:pulse 1s infinite}.minimap-node-status.completed{background:#10b981;box-shadow:0 0 6px #10b981}.minimap-node-status.failed{background:#ef4444;box-shadow:0 0 6px #ef4444}.minimap-node-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.minimap-node-time{font-size:.625rem;color:var(--text-tertiary);font-family:JetBrains Mono,monospace}.p-meta{display:flex;align-items:center;gap:.75rem;margin-top:4px}.status-badge{font-size:.65rem;padding:2px 8px;border-radius:10px;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.status-badge.running{background:#00d4ff26;color:#00d4ff;border:1px solid rgba(0,212,255,.3);box-shadow:0 0 10px #00d4ff1a;animation:pulse-badge 2s infinite}.status-badge.stopped{background:#ffffff0d;color:var(--text-tertiary);border:1px solid rgba(255,255,255,.1)}.status-badge.error{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}@keyframes pulse-badge{0%{box-shadow:0 0 #00d4ff66}70%{box-shadow:0 0 0 4px #00d4ff00}to{box-shadow:0 0 #00d4ff00}}.p-actions{display:flex;align-items:center;gap:.5rem}.p-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-secondary);cursor:pointer;transition:all .2s}.p-action-btn:hover{background:#ffffff1a;color:#fff;transform:translateY(-1px)}.load-btn:hover{background:#8b5cf626;border-color:#8b5cf666;color:#c4b5fd}.play-btn:hover{background:#10b98126;border-color:#10b98166;color:#10b981}.stop-btn{background:#ef44441a;border-color:#ef444433;color:#fca5a5}.stop-btn:hover{background:#ef444433;border-color:#ef444480;color:#ef4444}.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}.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}.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-group{display:flex;align-items:center;gap:1rem}.camera-status{display:flex;align-items:center;gap:6px;font-size:.875rem}.camera-online-status{display:flex;align-items:center;gap:6px;font-size:.875rem;font-weight:500}.camera-online-status .status-indicator{width:8px;height:8px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.camera-online-status.status-online .status-indicator{background-color:#10b981;box-shadow:0 0 8px #10b98199}.camera-online-status.status-offline .status-indicator{background-color:#ef4444;box-shadow:0 0 8px #ef444499}.camera-online-status.status-stale .status-indicator{background-color:#f59e0b;box-shadow:0 0 8px #f59e0b99}.camera-online-status.status-unknown .status-indicator{background-color:#6b7280;box-shadow:0 0 8px #6b728099}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.camera-status-details{margin:1rem 0;padding:.75rem;background:#0003;border-radius:8px;border-left:3px solid rgba(0,212,255,.3)}.status-detail-item{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;font-size:.875rem}.status-detail-item:last-child{margin-bottom:0}.status-label{color:#fff9;font-weight:500;min-width:100px}.status-value{color:#ffffffe6;text-align:right}.status-code{color:#00d4ffe6;font-size:.8rem;word-break:break-all;text-align:right;background:#00d4ff1a;padding:2px 6px;border-radius:4px}.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-section-divider{margin:1.5rem 0 1rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.form-section-divider h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#fff}.form-section-divider .form-hint{margin-top:0;color:#ffffff80}.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}}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#0a0a0ff2;-webkit-backdrop-filter:blur(40px) saturate(200%);backdrop-filter:blur(40px) saturate(200%);border-bottom:1px solid rgba(0,212,255,.15);box-shadow:0 4px 24px #0000004d;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:1rem}.logo{width:48px;height:48px;filter:drop-shadow(0 0 12px rgba(0,212,255,.4))}.header-text{display:flex;flex-direction:column;gap:.25rem}.app-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0}.eye-text{background:linear-gradient(135deg,var(--primary-cyan),var(--accent-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{font-size:.75rem;color:var(--text-secondary);margin:0;letter-spacing:.05em;text-transform:uppercase}.header-right{display:flex;align-items:center;gap:1rem}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:20px;font-size:.875rem;color:var(--success-green)}.status-dot{width:8px;height:8px;background:var(--success-green);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.header-icon-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.header-icon-button:hover{background:#00d4ff1a;border-color:var(--primary-cyan);color:var(--primary-cyan);transform:translateY(-2px)}.logout-button{padding:.5rem 1.5rem;background:linear-gradient(135deg,var(--error-red),#dc2626);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.logout-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.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:calc(100vh - 80px);overflow:hidden}.main-content-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);overflow-y:auto;height:100%}.app-main{flex:1;padding:2rem;overflow-y:auto}.content-wrapper{padding:2rem 3rem;max-width:1600px;margin:0 auto;width:100%}.tab-content{padding:2rem;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tab-header{margin-bottom:2rem}.tab-header h2{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--primary-cyan),var(--accent-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.card,.analysis-card,.device-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-md);transition:all .3s}.card:hover,.device-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg),var(--glow-cyan);transform:translateY(-2px)}.card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.card-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.card-header svg{color:var(--primary-cyan)}.btn,.primary-button,.secondary-button{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;gap:.5rem;justify-content:center}.primary-button,.btn-primary{background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));color:#fff;box-shadow:0 4px 12px #00d4ff4d}.primary-button:hover,.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00d4ff66}.primary-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-button,.btn-secondary{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-primary)}.secondary-button:hover,.btn-secondary:hover{background:#ffffff1a;border-color:var(--primary-cyan)}.btn-danger{background:linear-gradient(135deg,var(--error-red),#dc2626);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.icon-button{width:36px;height:36px;padding:0;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}.icon-button:hover{background:#00d4ff1a;border-color:var(--primary-cyan);color:var(--primary-cyan)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.875rem}.form-input,.form-select,.form-textarea,input[type=text],input[type=email],input[type=password],select,textarea{width:100%;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-size:.875rem;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus,input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-cyan);background:#ffffff14;box-shadow:0 0 0 3px #00d4ff1a}textarea{resize:vertical;min-height:100px}.dropzone{border:2px dashed var(--border-color);border-radius:12px;padding:3rem 2rem;text-align:center;background:#ffffff05;transition:all .3s;cursor:pointer}.dropzone:hover,.dropzone.dragover{border-color:var(--primary-cyan);background:#00d4ff0d}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.dropzone-icon{color:var(--primary-cyan)}.dropzone-text{color:var(--text-secondary);font-size:.875rem}.image-preview{position:relative;border-radius:12px;overflow:hidden;background:#0000004d}.image-preview img{width:100%;height:auto;display:block}.remove-image-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-image-btn:hover{background:var(--error-red);transform:scale(1.1)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{font-size:1.5rem;margin:0}.modal-close{width:32px;height:32px;background:#ffffff0d;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:#ef444433;color:var(--error-red)}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.toast{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-lg);z-index:2000;animation:slideInRight .3s;display:flex;align-items:center;gap:1rem;min-width:300px}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.success{border-color:var(--success-green);background:#10b9811a}.toast.error{border-color:var(--error-red);background:#ef44441a}.toast.info{border-color:var(--primary-cyan);background:#00d4ff1a}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--primary-cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem}.device-card{background:linear-gradient(135deg,#111118e6,#1a1a24cc);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;padding:0;box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative}.device-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-cyan),var(--accent-purple));opacity:0;transition:opacity .3s}.device-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg),0 0 30px #00d4ff26;transform:translateY(-4px)}.device-card:hover:before{opacity:1}.device-card-header{padding:1.5rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.device-info h3{font-size:1.25rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.device-id{font-size:.75rem;color:var(--text-tertiary);font-family:JetBrains Mono,monospace;margin:0;padding:.25rem .5rem;background:#00d4ff0d;border-radius:4px;display:inline-block}.device-header-badges{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.architecture-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid}.architecture-amd64{background:linear-gradient(135deg,#3b82f626,#2563eb1a);color:#60a5fa;border-color:#3b82f64d}.architecture-arm64{background:linear-gradient(135deg,#10b98126,#0596691a);color:#34d399;border-color:#10b9814d}.health-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;border:1px solid}.health-badge.health-healthy{background:linear-gradient(135deg,#10b98126,#0596691a);color:var(--success-green);border-color:#10b9814d;box-shadow:0 0 20px #10b98133}.health-badge.health-unhealthy{background:linear-gradient(135deg,#ef444426,#dc26261a);color:var(--error-red);border-color:#ef44444d;box-shadow:0 0 20px #ef444433}.health-badge.health-unknown{background:linear-gradient(135deg,#a1a1aa26,#71717a1a);color:var(--text-secondary);border-color:#a1a1aa4d}.device-card-body{padding:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.device-detail{display:flex;flex-direction:column;gap:.375rem}.detail-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:flex;align-items:center;gap:.375rem}.detail-label svg{opacity:.7}.detail-value{font-size:.9375rem;color:var(--text-primary);font-weight:500}.secure-channel-active{color:var(--success-green);font-family:JetBrains Mono,monospace;font-weight:600}.configure-secure-channel-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#7c3aed26,#6d28d91a);border:1px solid rgba(124,58,237,.3);border-radius:6px;color:var(--accent-purple);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.configure-secure-channel-btn:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed40,#6d28d926);border-color:#7c3aed80;transform:translateY(-1px)}.configure-secure-channel-btn:disabled{opacity:.5;cursor:not-allowed}.device-card-actions{padding:1rem 1.5rem;background:#00000026;border-top:1px solid rgba(255,255,255,.05);display:flex;gap:.75rem;justify-content:flex-end}.device-delete-btn,.device-view-btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;border:1px solid}.device-view-btn{background:#00d4ff1a;border-color:#00d4ff4d;color:var(--primary-cyan)}.device-view-btn:hover{background:#00d4ff33;border-color:var(--primary-cyan);transform:translateY(-1px)}.device-delete-btn{background:#ef44441a;border-color:#ef44444d;color:var(--error-red)}.device-delete-btn:hover{background:#ef444433;border-color:var(--error-red);transform:translateY(-1px)}.device-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.device-info h3{font-size:1.125rem;margin:0 0 .5rem;color:var(--text-primary)}.device-status{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.device-status.online{background:#10b9811a;color:var(--success-green);border:1px solid rgba(16,185,129,.3)}.device-status.offline{background:#ef44441a;color:var(--error-red);border:1px solid rgba(239,68,68,.3)}.device-actions{display:flex;gap:.5rem}.app-footer{padding:1.5rem 2rem;background:#0a0a0ff2;border-top:1px solid rgba(255,255,255,.08);text-align:center;color:var(--text-secondary);font-size:.875rem}.text-center{text-align:center}.text-muted{color:var(--text-secondary)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.upload-section{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem}.file-input{display:none}.dropzone-label{cursor:pointer;display:block}.upload-icon{color:var(--primary-cyan);opacity:.7}.dropzone-hint{font-size:.75rem;color:var(--text-tertiary);margin-top:.5rem}.preview-image{max-width:100%;border-radius:8px;margin-bottom:1rem}.preview-text{font-size:.875rem;color:var(--text-secondary);text-align:center}.remove-image-button{position:absolute;top:1rem;right:1rem;width:36px;height:36px;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.remove-image-button:hover{background:var(--error-red);transform:scale(1.1)}.model-selection-section{display:flex;flex-direction:column;gap:.5rem}.model-label{font-weight:600;color:var(--text-primary);font-size:.875rem}.model-select{width:100%;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s}.model-select:focus{outline:none;border-color:var(--primary-cyan);background:#ffffff14;box-shadow:0 0 0 3px #00d4ff1a}.model-hint{font-size:.75rem;color:var(--text-tertiary);margin:0}.prompt-section{display:flex;flex-direction:column;gap:.5rem}.prompt-label{font-weight:600;color:var(--text-primary);font-size:.875rem}.prompt-textarea{width:100%;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-size:.875rem;resize:vertical;min-height:100px;font-family:inherit;transition:all .2s}.prompt-textarea:focus{outline:none;border-color:var(--primary-cyan);background:#ffffff14;box-shadow:0 0 0 3px #00d4ff1a}.analyze-button{padding:1rem 2rem;background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));border:none;border-radius:8px;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #00d4ff4d}.analyze-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00d4ff66}.analyze-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:var(--error-red);margin-top:1rem}.result-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;margin-top:2rem;box-shadow:var(--shadow-md)}.result-card h3{font-size:1.25rem;margin:0 0 1rem;color:var(--text-primary)}.result-content{color:var(--text-secondary);line-height:1.6}.result-content p{margin:0 0 1rem;white-space:pre-wrap}.result-meta{display:flex;gap:1.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);font-size:.875rem;color:var(--text-tertiary)}.result-meta span{display:flex;align-items:center;gap:.5rem}.result-summary{font-size:1rem;margin-bottom:1rem}.barcode-list{display:flex;flex-direction:column;gap:1rem}.barcode-item{padding:1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px}.barcode-type,.barcode-data,.barcode-position{margin-bottom:.5rem;font-size:.875rem}.barcode-data code{background:#00d4ff1a;padding:.25rem .5rem;border-radius:4px;color:var(--primary-cyan)}.tab-header-actions{display:flex;gap:1rem;align-items:center}.view-mode-toggle{display:flex;gap:.5rem;background:#ffffff0d;padding:.25rem;border-radius:8px}.view-mode-btn{padding:.5rem 1rem;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.view-mode-btn:hover{color:var(--text-primary);background:#ffffff0d}.view-mode-btn.active{background:var(--primary-cyan);color:#fff}.add-device-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));border:none;border-radius:8px;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 4px 12px #00d4ff4d}.add-device-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00d4ff66}.refresh-button{padding:.75rem 1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.refresh-button:hover:not(:disabled){background:#ffffff1a;border-color:var(--primary-cyan);color:var(--primary-cyan)}.refresh-button:disabled{opacity:.5;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.devices-table-container{margin-top:1.5rem;overflow-x:auto;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1rem}.devices-table{width:100%;border-collapse:collapse;font-size:.875rem}.devices-table thead{background:#ffffff08;border-bottom:2px solid var(--border-color)}.devices-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);white-space:nowrap}.devices-table tbody tr{border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s;cursor:pointer}.devices-table tbody tr:hover{background:#00d4ff0d}.devices-table td{padding:1rem;color:var(--text-secondary);vertical-align:middle}.devices-table .device-name-cell{font-weight:600;color:var(--text-primary)}.devices-table .health-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.devices-table .health-badge.healthy{background:#10b9811a;color:var(--success-green);border:1px solid rgba(16,185,129,.3)}.devices-table .health-badge.unhealthy{background:#ef44441a;color:var(--error-red);border:1px solid rgba(239,68,68,.3)}.devices-table .health-badge.unknown{background:#a1a1aa1a;color:var(--text-secondary);border:1px solid rgba(161,161,170,.3)}.devices-table .tailscale-status{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.devices-table .tailscale-status.connected{background:#10b9811a;color:var(--success-green);border:1px solid rgba(16,185,129,.3)}.devices-table .tailscale-status.disconnected{background:#ef44441a;color:var(--error-red);border:1px solid rgba(239,68,68,.3)}.devices-table .tailscale-status.unconfigured{background:#f59e0b1a;color:var(--warning-amber);border:1px solid rgba(245,158,11,.3)}.devices-table .table-actions{display:flex;gap:.5rem}.devices-table .table-action-btn{width:32px;height:32px;padding:0;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}.devices-table .table-action-btn:hover{background:#00d4ff1a;border-color:var(--primary-cyan);color:var(--primary-cyan)}.devices-table .table-action-btn.danger:hover{background:#ef44441a;border-color:var(--error-red);color:var(--error-red)}.empty-state,.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.empty-state svg,.loading-state svg,.error-state svg{color:var(--text-tertiary);margin-bottom:1.5rem;opacity:.5}.empty-state h3{font-size:1.5rem;margin:0 0 .5rem;color:var(--text-primary)}.empty-state p,.loading-state p,.error-state p{font-size:1rem;margin:0;max-width:500px}.retry-button{margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.retry-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00d4ff66}.sidebar-group-container{margin-bottom:.5rem}.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}.device-details-modal{max-width:1000px!important;width:95%!important;background:#0f0f19fa!important;border:1px solid rgba(0,212,255,.2)!important;box-shadow:0 25px 50px -12px #00000080,0 0 40px #00d4ff1a!important}.device-info-section{background:#ffffff08;border-radius:12px;padding:1.5rem;margin-bottom:2rem;border:1px solid rgba(255,255,255,.05)}.services-section h4{font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary);display:flex!important;align-items:center;gap:.75rem}.services-table-container{overflow-x:auto;border-radius:12px;background:#0003;border:1px solid rgba(255,255,255,.05);margin-top:1rem}.services-table{width:100%;border-collapse:separate;border-spacing:0}.services-table th{background:#ffffff0d;padding:1.25rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);border-bottom:1px solid rgba(255,255,255,.1)}.services-table td{padding:1.25rem 1rem;vertical-align:middle;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-secondary)}.service-row:hover{background:#00d4ff08}.service-name-cell{min-width:220px}.service-name-primary{font-weight:600;color:var(--text-primary);margin-bottom:.4rem;font-size:.95rem}.service-container-id-small{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--text-tertiary);background:#ffffff0a;padding:2px 8px;border-radius:4px;display:inline-block;border:1px solid rgba(255,255,255,.05)}.service-image-cell{max-width:250px}.service-image-text{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--primary-cyan);background:#00d4ff0d;padding:4px 10px;border-radius:6px;word-break:break-all;border:1px solid rgba(0,212,255,.1)}.service-status-badge{display:inline-flex;align-items:center;padding:.35rem .85rem;border-radius:20px;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}.service-status-badge.status-running{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3);box-shadow:0 0 15px #10b9811a}.service-status-badge.status-running:before{content:"";width:6px;height:6px;background:#10b981;border-radius:50%;margin-right:6px;box-shadow:0 0 8px #10b981;animation:pulse 2s infinite}.service-status-badge.status-exited,.service-status-badge.status-stopped{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.service-resources-cell{min-width:160px}.resource-stats{display:flex;flex-direction:column;gap:.6rem}.resource-stat-item{display:flex;align-items:center;gap:.6rem;font-size:.8rem}.resource-stat-item svg{color:var(--text-tertiary);opacity:.7}.resource-stat-value{color:var(--text-primary);font-weight:500}.resource-stat-percent{color:var(--text-tertiary);font-size:.7rem;font-weight:400}.ports-list{display:flex;flex-wrap:wrap;gap:.5rem}.port-badge{background:#a855f71a;color:#c084fc;border:1px solid rgba(168,85,247,.2);padding:2px 10px;border-radius:6px;font-size:.75rem;font-family:JetBrains Mono,monospace}.service-actions-group{display:flex;gap:.5rem;justify-content:flex-end}.service-action-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.service-action-btn:hover{background:#ffffff1f;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.service-action-btn.action-stop:hover{background:#f59e0b33!important;color:#fbbf24!important;border-color:#f59e0b66!important}.service-action-btn.action-start:hover{background:#10b98133!important;color:#34d399!important;border-color:#10b98166!important}.service-action-btn.action-restart:hover{background:#3b82f633!important;color:#60a5fa!important;border-color:#3b82f666!important}.service-action-btn.action-redeploy:hover{background:#8b5cf633!important;color:#a78bfa!important;border-color:#8b5cf666!important}.service-action-btn.action-delete:hover{background:#ef444433!important;color:#f87171!important;border-color:#ef444466!important}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}.device-details-header{display:flex!important;align-items:center;gap:1rem}.device-details-header h3{margin:0;font-size:1.5rem;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.4rem}.info-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);font-weight:700}.info-value{font-size:1rem;color:var(--text-primary);font-weight:500}.device-details-body{padding:2rem!important}.services-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;margin-top:2.5rem}.services-header h4{margin:0}.data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-top:1.5rem}.data-card{background:linear-gradient(135deg,#111118e6,#1a1a24cc);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;padding:0;box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative}.data-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-cyan),var(--accent-purple));opacity:0;transition:opacity .3s}.data-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg),0 0 30px #00d4ff26;transform:translateY(-4px)}.data-card:hover:before{opacity:1}.data-card-header{padding:1.5rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.data-card-title{flex:1}.data-card-title h3{font-size:1.25rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary)}.data-card-subtitle{font-size:.75rem;color:var(--text-tertiary);font-family:JetBrains Mono,monospace;margin:0;padding:.25rem .5rem;background:#00d4ff0d;border-radius:4px;display:inline-block}.data-card-badges{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.data-card-body{padding:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.data-card-body.single-column{grid-template-columns:1fr}.data-field{display:flex;flex-direction:column;gap:.375rem}.data-field-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:flex;align-items:center;gap:.375rem}.data-field-label svg{opacity:.7}.data-field-value{font-size:.9375rem;color:var(--text-primary);font-weight:500}.data-card-footer{padding:1rem 1.5rem;background:#00000026;border-top:1px solid rgba(255,255,255,.05);display:flex;gap:.75rem;justify-content:flex-end}.data-table-container{margin-top:1.5rem;overflow-x:auto;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1rem}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{background:#ffffff08;border-bottom:2px solid var(--border-color)}.data-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);white-space:nowrap;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.data-table tbody tr{border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s;cursor:pointer}.data-table tbody tr:hover{background:#00d4ff0d}.data-table td{padding:1rem;color:var(--text-secondary);vertical-align:middle}.data-table .primary-cell{font-weight:600;color:var(--text-primary)}.data-table .mono-cell{font-family:JetBrains Mono,monospace;font-size:.8125rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;border:1px solid;white-space:nowrap}.status-badge.success{background:linear-gradient(135deg,#10b98126,#0596691a);color:var(--success-green);border-color:#10b9814d;box-shadow:0 0 20px #10b98133}.status-badge.error{background:linear-gradient(135deg,#ef444426,#dc26261a);color:var(--error-red);border-color:#ef44444d;box-shadow:0 0 20px #ef444433}.status-badge.warning{background:linear-gradient(135deg,#f59e0b26,#d977061a);color:var(--warning-amber);border-color:#f59e0b4d;box-shadow:0 0 20px #f59e0b33}.status-badge.info{background:linear-gradient(135deg,#3b82f626,#2563eb1a);color:#60a5fa;border-color:#3b82f64d}.status-badge.neutral{background:linear-gradient(135deg,#a1a1aa26,#71717a1a);color:var(--text-secondary);border-color:#a1a1aa4d}.status-badge.small{padding:.25rem .75rem;font-size:.75rem;border-radius:6px}.pill-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid}.pill-badge.primary{background:linear-gradient(135deg,#00d4ff26,#00b8d41a);color:var(--primary-cyan);border-color:#00d4ff4d}.pill-badge.secondary{background:linear-gradient(135deg,#7c3aed26,#6d28d91a);color:var(--accent-purple);border-color:#7c3aed4d}.action-button{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;border:1px solid}.action-button.primary{background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));border-color:transparent;color:#fff;box-shadow:0 4px 12px #00d4ff4d}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00d4ff66}.action-button.secondary{background:#00d4ff1a;border-color:#00d4ff4d;color:var(--primary-cyan)}.action-button.secondary:hover{background:#00d4ff33;border-color:var(--primary-cyan);transform:translateY(-1px)}.action-button.danger{background:#ef44441a;border-color:#ef44444d;color:var(--error-red)}.action-button.danger:hover{background:#ef444433;border-color:var(--error-red);transform:translateY(-1px)}.action-button.ghost{background:#ffffff0d;border-color:#ffffff1a;color:var(--text-primary)}.action-button.ghost:hover{background:#ffffff1a;border-color:#fff3}.action-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.icon-action-button{width:36px;height:36px;padding:0;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}.icon-action-button:hover{background:#00d4ff1a;border-color:var(--primary-cyan);color:var(--primary-cyan)}.icon-action-button.danger:hover{background:#ef44441a;border-color:var(--error-red);color:var(--error-red)}.metrics-row{display:flex;gap:1rem;margin-top:1rem}.metric-card{flex:1;padding:1rem;background:#0003;border:1px solid rgba(255,255,255,.05);border-radius:8px;display:flex;flex-direction:column;gap:.5rem}.metric-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.metric-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.metric-icon{color:var(--primary-cyan);opacity:.7}: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}
