.layout{display:flex;min-height:100vh;min-height:100dvh;background:var(--bg-deep)}.layout.outlook{--sidebar-width: 200px;--outlook-row-height: 30px;--mobile-topbar-height: 48px}.sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;height:100vh;height:100dvh;overflow-y:auto;z-index:10}.layout.outlook .sidebar{position:sticky;top:0;align-self:flex-start;flex-shrink:0}.sidebar-header{padding:.65rem .85rem;border-bottom:1px solid var(--border-color)}.sidebar-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.sidebar-toggle,.sidebar-close-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:1.65rem;height:1.65rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;font-size:1rem;line-height:1;padding:0}.sidebar-toggle:hover,.sidebar-close-btn:hover{border-color:var(--primary);color:var(--primary)}.sidebar-close-btn{display:none}.sidebar-logo{display:flex;align-items:center;gap:.55rem;min-width:0}.sidebar-logo-image{width:22px;height:22px;border-radius:6px;box-shadow:0 0 10px var(--primary-glow)}.sidebar-logo-title{margin:0;font-size:.88rem;font-family:var(--font-display);font-weight:600;color:var(--text-primary)}.sidebar-logo-subtitle{font-size:.62rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.layout--sidebar-collapsed .sidebar{width:3.5rem}.layout--sidebar-collapsed .sidebar-logo-text,.layout--sidebar-collapsed .sidebar-section-title,.layout--sidebar-collapsed .nav-item-label,.layout--sidebar-collapsed .sidebar-logout-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.layout--sidebar-collapsed .sidebar-header-top{flex-direction:column;align-items:center}.layout--sidebar-collapsed .nav-item{justify-content:center;padding-left:.45rem;padding-right:.45rem}.sidebar-section{padding:.25rem 0 .1rem}.sidebar-section-title{padding:.3rem .85rem .15rem;font-family:var(--font-display);font-size:.64rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.sidebar-sections{flex:1;overflow-y:auto;padding-bottom:.35rem}.sidebar-nav{padding:0}.nav-item{display:flex;align-items:center;gap:.45rem;width:100%;padding:.38rem .85rem;color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.84rem;font-family:var(--font-sans);background:transparent;border:none;border-radius:0;text-align:left;cursor:pointer;transition:background .2s,color .2s}.nav-item-icon{flex-shrink:0;width:1rem;text-align:center;font-size:.9rem;line-height:1}.nav-item:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.nav-item.active{background:var(--primary-dim);color:var(--primary);border-left:3px solid var(--primary);padding-left:calc(.85rem - 3px)}.sidebar-footer{padding:.55rem .65rem;border-top:1px solid var(--border-color)}.sidebar-logout-btn{width:100%;padding:.4rem .65rem;font-size:.82rem}.main-content{flex:1;min-width:0;min-height:100vh;min-height:100dvh;background:var(--bg-deep)}.layout.outlook .main-content{margin-left:0;padding:0;display:flex;flex-direction:column}.devops-page-scroll{flex:1;overflow:auto;padding:.55rem .65rem;-webkit-overflow-scrolling:touch}.mobile-top-bar,.mobile-drawer-backdrop{display:none}@media (max-width: 1024px){.layout.outlook{flex-direction:row;min-height:100dvh}.layout.outlook .sidebar{position:fixed;top:0;left:0;width:min(86vw,280px);height:100dvh;max-height:none;z-index:100;transform:translate(-105%);transition:transform .22s ease;box-shadow:var(--shadow-lg);padding-bottom:env(safe-area-inset-bottom,0)}.layout.outlook.layout--mobile-nav-open .sidebar{transform:translate(0)}.layout--sidebar-collapsed .sidebar{width:min(86vw,280px)}.sidebar-toggle{display:none}.sidebar-close-btn{display:inline-flex}.layout.outlook .sidebar-header{padding:.75rem .85rem}.mobile-drawer-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;border:none;padding:0;margin:0;background:#0000008c;cursor:pointer}.layout.outlook .main-content{flex:1;margin-left:0;padding:0;min-width:0;min-height:100dvh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-top-bar{display:grid;grid-template-columns:40px minmax(0,1fr) 40px;align-items:center;gap:.35rem;min-height:var(--mobile-topbar-height);padding:.3rem .5rem;padding-top:max(.3rem,env(safe-area-inset-top,0));border-bottom:1px solid var(--border-color);background:var(--bg-card);position:sticky;top:0;z-index:20;flex-shrink:0}.mobile-top-bar-title{min-width:0;text-align:center}.mobile-top-bar-title h1{margin:0;font-family:var(--font-display);font-size:.88rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-top-bar-sub{display:block;font-size:.66rem;color:var(--text-muted);line-height:1.2}.mobile-icon-btn{width:36px;height:36px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-primary);font-size:1rem;line-height:1;display:grid;place-items:center;cursor:pointer;padding:0}.mobile-icon-btn:active{background:var(--primary-dim);border-color:var(--primary)}.devops-page-scroll{flex:1;min-height:0;padding:.45rem;padding-bottom:calc(.45rem + env(safe-area-inset-bottom,0px))}}body.devops-nav-open{overflow:hidden}.loading-center{min-height:40vh;display:flex;align-items:center;justify-content:center}.loading-spinner{width:2rem;height:2rem;border:2px solid var(--bg-elevated);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}.access-denied{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;text-align:center;color:var(--text-secondary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.login-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem;position:relative;overflow:hidden;background:var(--bg-deep)}.login-container:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 45% at 50% -15%,var(--primary-dim) 0%,transparent 55%),radial-gradient(ellipse 55% 35% at 100% 45%,var(--accent-dim) 0%,transparent 50%),radial-gradient(ellipse 45% 28% at 0% 75%,var(--primary-dim) 0%,transparent 50%);pointer-events:none;z-index:0}.login-container:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(13,148,136,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(13,148,136,.04) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;z-index:0}.login-bg-orb{position:fixed;border-radius:50%;filter:blur(90px);opacity:.3;animation:login-float 10s ease-in-out infinite;z-index:0}.login-bg-orb-1{width:320px;height:320px;background:var(--primary-dim);top:18%;left:22%}.login-bg-orb-2{width:240px;height:240px;background:var(--accent-dim);bottom:22%;right:18%;animation-delay:-4s}@keyframes login-float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(15px,-12px) scale(1.04)}}.login-card{position:relative;z-index:2;background:linear-gradient(165deg,var(--bg-card) 0%,var(--bg-primary) 100%);border:1px solid var(--border-color);border-radius:1rem;box-shadow:0 25px 50px #0006,0 0 0 1px #ffffff08;padding:2rem 1.75rem;width:100%;max-width:400px;animation:login-card-in .5s ease-out}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);border-radius:1rem 1rem 0 0;opacity:.7}@keyframes login-card-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:1.5rem}.login-header img{width:48px;height:48px;margin-bottom:.85rem;border-radius:10px;box-shadow:0 0 16px var(--primary-glow)}.login-header h1{margin:0 0 .4rem;font-family:var(--font-display);font-size:1.55rem;font-weight:700;color:var(--text-primary)}.login-header h1 .highlight{background:linear-gradient(135deg,var(--primary) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{margin:0;font-size:.9rem;color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-family:var(--font-display);font-weight:600;font-size:.75rem;letter-spacing:.05em;color:var(--text-secondary)}.login-button{padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:var(--bg-deep);border:none;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.85rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:transform .2s,box-shadow .2s;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 20px var(--primary-glow);width:100%}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 28px var(--primary-glow)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-otp-hint{margin:0;color:var(--text-muted);font-size:.88rem}.login-link-button{margin-top:.15rem;background:none;border:none;color:var(--primary);cursor:pointer;font-size:.88rem;padding:0;font-family:var(--font-sans);width:100%;text-align:center}.login-link-button:hover{color:var(--gold)}.login-forgot{text-align:center;font-size:.85rem}.login-forgot a{color:var(--text-muted)}.login-forgot a:hover{color:var(--primary)}.alert{padding:.75rem .85rem;border-radius:var(--radius-sm);font-size:.88rem}.alert-error{background:var(--error-dim);color:var(--error);border:1px solid rgba(248,113,113,.35)}.login-verifying-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#070609d9;color:var(--text-secondary)}.login-verifying-spinner{width:2rem;height:2rem;border:2px solid var(--bg-elevated);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.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%}.ui-stack{display:flex;flex-direction:column;gap:var(--ui-stack-gap, 1rem)}.ui-stack--horizontal{flex-direction:row;flex-wrap:wrap;align-items:center}.ui-box{min-width:0}.ui-box--h1{font-family:var(--font-display);font-size:1.875rem;font-weight:600;color:var(--text-primary)}.ui-box--h2{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--text-primary)}.ui-box--small{font-size:.8rem}.ui-box--strong{font-weight:600}.ui-box--key-label{font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.25rem}.ui-box--text-secondary{color:var(--text-secondary)}.ui-box--text-error{color:var(--error)}.ui-box--text-success{color:var(--success)}.ui-box--text-warning{color:var(--warning)}.ui-box--text-info{color:var(--primary)}.ui-box--p{font-size:.9rem;line-height:1.55}.ui-box--code{font-family:var(--font-mono);font-size:.85rem;background:var(--bg-deep);padding:.15rem .35rem;border-radius:var(--radius-sm)}.ui-box--center{text-align:center}.ui-box--float-right{margin-left:auto}.ui-container{width:100%;max-width:100%}.ui-container-inner{padding:.65rem}.ui-page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.ui-page-header h1,.ui-page-header h2{margin:0;font-family:var(--font-display);font-weight:600;color:var(--text-primary)}.ui-page-header h1{font-size:1.5rem}.ui-page-header h2{font-size:1.15rem}.ui-page-header-counter{font-size:.85rem;color:var(--text-secondary);font-weight:400}.ui-page-header-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-family:var(--font-display);font-size:.85rem;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .15s;white-space:nowrap}.ui-btn:disabled{opacity:.6;cursor:not-allowed}.ui-btn--primary{padding:.45rem .85rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:var(--bg-deep);border:none;font-family:var(--font-display);font-size:.78rem;letter-spacing:.04em;box-shadow:0 0 12px var(--primary-glow)}.ui-btn--primary:hover:not(:disabled){transform:translateY(-1px)}.ui-btn--normal,.ui-btn--secondary{padding:.4rem .75rem;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color);font-family:var(--font-sans)}.ui-btn--normal:hover:not(:disabled),.ui-btn--secondary:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.ui-btn--link{padding:.25rem .5rem;background:transparent;color:var(--primary);border:none;font-weight:500}.ui-btn--link:hover:not(:disabled){color:var(--gold)}.ui-btn--icon{padding:.35rem;min-width:2rem;min-height:2rem;background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary)}.ui-btn-spinner{width:.85rem;height:.85rem;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:ui-spin .65s linear infinite}@keyframes ui-spin{to{transform:rotate(360deg)}}.ui-alert{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid var(--border-color)}.ui-alert--success{background:var(--success-dim);border-color:#10b98159;color:var(--success)}.ui-alert--error{background:var(--error-dim);border-color:#f8717159;color:var(--error)}.ui-alert--warning{background:var(--warning-dim);border-color:#fbbf2459;color:var(--warning)}.ui-alert--info{background:var(--primary-dim);border-color:#0d948859;color:var(--primary)}.ui-alert-dismiss{background:none;border:none;color:inherit;cursor:pointer;font-size:1.1rem;line-height:1;opacity:.75;padding:0}.ui-alert-dismiss:hover{opacity:1}.ui-form-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.ui-form-field label{font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary)}.ui-form-field-desc{font-size:.8rem;color:var(--text-muted);margin-top:-.15rem}.ui-input,.ui-textarea,.ui-select{width:100%;padding:.55rem .75rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font-sans);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.ui-input:focus,.ui-textarea:focus,.ui-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.ui-textarea{min-height:5rem;resize:vertical}.ui-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000bf}.ui-modal{width:100%;max-width:32rem;max-height:min(90vh,720px);display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.ui-modal--large{max-width:48rem}.ui-modal-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary)}.ui-modal-body{padding:1.25rem;overflow-y:auto;flex:1}.ui-modal-footer{padding:.85rem 1.25rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.5rem}.ui-table-wrap{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 20px #00000040}.ui-table-toolbar{display:flex;flex-direction:column;gap:.5rem;padding:.65rem 1rem;border-bottom:1px solid var(--border-color)}.ui-table-toolbar-title{min-width:0}.ui-table-toolbar-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.ui-table-toolbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;flex:1 1 auto;min-width:0}.ui-table-selection-bar .selection-action-bar{margin:0;padding:0;background:transparent;border:none;border-radius:0;gap:.4rem}.ui-table-selection-bar .selection-action-bar-meta{min-width:auto}.ui-table-selection-bar .selection-action-bar-actions{justify-content:flex-start;flex:0 1 auto}.ui-table-filter{flex:1 1 12rem;max-width:20rem;min-width:min(100%,12rem)}.ui-table-scroll{overflow-x:auto;max-height:calc(100vh - 200px);-webkit-overflow-scrolling:touch}.ui-table{width:100%;border-collapse:collapse;min-width:640px}.ui-table--compact td,.ui-table--compact th{padding:.45rem .75rem;font-size:.85rem}.ui-table thead{background:var(--bg-elevated);position:sticky;top:0;z-index:2}.ui-table th{padding:.65rem .85rem;text-align:left;font-family:var(--font-display);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.ui-table td{padding:.65rem .85rem;border-top:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle;font-family:var(--font-sans)}.ui-table tbody tr:hover{background:var(--bg-elevated)}.ui-table tbody tr.ui-table-row--selected{background:#f59e0b14}.ui-table-empty,.ui-table-loading{padding:2.5rem 1rem;text-align:center;color:var(--text-secondary)}.ui-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem}.ui-status-dot{width:.45rem;height:.45rem;border-radius:50%;flex-shrink:0}.ui-status--success .ui-status-dot{background:var(--success)}.ui-status--error .ui-status-dot{background:var(--error)}.ui-status--warning .ui-status-dot{background:var(--warning)}.ui-status--info .ui-status-dot,.ui-status--stopped .ui-status-dot{background:var(--text-muted)}.ui-status--success{color:var(--success)}.ui-status--error{color:var(--error)}.ui-status--warning{color:var(--warning)}.ui-status--info,.ui-status--stopped{color:var(--text-secondary)}.ui-spinner{width:1.5rem;height:1.5rem;border:2px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:ui-spin .65s linear infinite}.ui-spinner--center{margin:2rem auto}.ui-tabs{display:flex;flex-direction:column;gap:1rem}.ui-tabs-nav{display:flex;flex-wrap:wrap;gap:.35rem;padding:.35rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius)}.ui-tab{flex:1 1 auto;min-width:8rem;padding:.55rem 1rem;font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:color .15s,background .15s,border-color .15s}.ui-tab:hover{color:var(--text-primary);background:#ffffff0a}.ui-tab--active{color:var(--gold);background:#f59e0b14;border-color:#f59e0b59}.ui-pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem}.ui-progress{height:.45rem;background:var(--bg-elevated);border-radius:999px;overflow:hidden}.ui-progress-fill{height:100%;border-radius:999px;transition:width .3s}.ui-progress--success .ui-progress-fill{background:var(--success)}.ui-progress--warning .ui-progress-fill{background:var(--warning)}.ui-progress--error .ui-progress-fill{background:var(--error)}.ui-column-layout{display:grid;gap:1rem}.ui-column-layout--2{grid-template-columns:repeat(2,minmax(0,1fr))}.ui-column-layout--3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 1024px){.ui-column-layout--2,.ui-column-layout--3{grid-template-columns:1fr}.ui-table-wrap{border-radius:var(--radius-sm)}.ui-table-toolbar{padding:.5rem .65rem;gap:.4rem}.ui-table-toolbar-row{flex-direction:column;align-items:stretch}.ui-table-toolbar-actions{width:100%}.ui-table-filter{flex:1 1 100%;max-width:none;width:100%}.ui-table-scroll{max-height:none;overflow-x:auto;-webkit-overflow-scrolling:touch}.ui-table{min-width:520px}.ui-table--compact td,.ui-table--compact th{padding:.38rem .55rem;font-size:.8rem}.ui-table th{padding:.45rem .55rem;font-size:.62rem;white-space:nowrap}.ui-input,.ui-textarea,.ui-select{font-size:16px}}.ui-segmented{display:inline-flex;padding:.2rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);gap:.15rem}.ui-segmented-btn{padding:.4rem .75rem;font-family:var(--font-sans);font-size:.85rem;font-weight:600;color:var(--text-secondary);background:transparent;border:none;border-radius:calc(var(--radius-sm) - 2px);cursor:pointer}.ui-segmented-btn--active{color:var(--gold);background:#f59e0b1a}.ui-popover-wrap{position:relative;display:inline-block}.ui-popover-trigger{background:none;border:none;color:var(--primary);cursor:pointer;font:inherit;padding:0;text-decoration:underline}.ui-popover{position:absolute;z-index:100;min-width:10rem;padding:.65rem .85rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);font-size:.85rem}.ui-token-group{display:flex;flex-wrap:wrap;gap:.35rem}.ui-token{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:999px;font-size:.8rem;color:var(--text-primary)}.ui-token-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;line-height:1;padding:0}.ui-toggle{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.ui-toggle input{position:absolute;opacity:0;width:0;height:0}.ui-toggle-track{width:2.25rem;height:1.2rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:999px;position:relative;transition:background .2s,border-color .2s}.ui-toggle input:checked+.ui-toggle-track{background:var(--primary-dim);border-color:var(--primary)}.ui-toggle-thumb{position:absolute;top:2px;left:2px;width:.85rem;height:.85rem;background:var(--text-secondary);border-radius:50%;transition:transform .2s,background .2s}.ui-toggle input:checked+.ui-toggle-track .ui-toggle-thumb{transform:translate(1rem);background:var(--primary)}.ui-toggle input:disabled~.ui-toggle-track,.ui-toggle input:disabled~.ui-toggle-label{opacity:.5;cursor:not-allowed}.ui-expandable{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card)}.ui-expandable-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.65rem .85rem;background:none;border:none;color:var(--text-primary);font-family:var(--font-display);font-size:.8rem;font-weight:600;cursor:pointer;text-align:left}.ui-expandable-body{padding:0 .85rem .85rem}.ui-text-content{font-size:.9rem;line-height:1.55;color:var(--text-primary)}.ui-text-content pre{font-family:var(--font-mono);font-size:.8rem;background:var(--bg-deep);padding:.75rem;border-radius:var(--radius-sm);overflow-x:auto}.dashboard-container{width:100%;height:100%}.devops-layout .react-flow{background-color:#ffffff0a}.react-flow__node{font-family:var(--font-sans);background:#252538!important}.react-flow__edge-path{stroke-width:2}.react-flow__edge.animated .react-flow__edge-path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}@keyframes dashdraw{to{stroke-dashoffset:-10}}.devops-layout .react-flow__edge-label{font-size:.75rem;font-weight:500;background:#1a1a2ef2;color:#ffffffe6;padding:2px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.react-flow__node-default{border-radius:8px;padding:0;font-size:.875rem}.devops-layout .react-flow__node-default{background:#252538!important;border:1px solid rgba(255,255,255,.15);color:#fffffff2}.devops-layout .react-flow__handle{width:8px;height:8px;background:#d97757;border:2px solid rgba(26,26,26,.95)}.react-flow__handle-top{top:-4px}.react-flow__handle-bottom{bottom:-4px}.react-flow__handle-left{left:-4px}.react-flow__handle-right{right:-4px}.devops-layout .react-flow__controls{box-shadow:0 2px 12px #0000004d;border-radius:8px;overflow:hidden}.devops-layout .react-flow__controls-button{background:#ffffff14;border-bottom:1px solid rgba(255,255,255,.1);color:#ffffffe6}.devops-layout .react-flow__controls-button:hover{background:#ffffff24}.devops-layout .react-flow__minimap{background:#1a1a2ee6;border:1px solid rgba(255,255,255,.15);border-radius:8px}@media (min-width: 1920px){.dashboard-container{padding:2rem}.react-flow{min-height:700px}}@media (min-width: 1024px) and (max-width: 1919px){.dashboard-container{padding:1.5rem}.react-flow{min-height:600px}}@media (min-width: 768px) and (max-width: 1023px){.dashboard-container{padding:1rem}.react-flow{min-height:500px}.react-flow__controls{transform:scale(.9);transform-origin:bottom right}.react-flow__minimap{transform:scale(.75);transform-origin:bottom left}}@media (max-width: 767px){.dashboard-container{padding:.75rem}.react-flow{min-height:400px}.react-flow__controls{transform:scale(.85);transform-origin:bottom right}.react-flow__minimap{transform:scale(.7);transform-origin:bottom left}.react-flow__node{font-size:.8rem}}@media (max-width: 480px){.dashboard-container{padding:.5rem}.react-flow{min-height:300px}.react-flow__controls{transform:scale(.75)}.react-flow__minimap{transform:scale(.6)}.react-flow__node{font-size:.75rem}.react-flow__edge-label{font-size:.625rem}}@media (max-width: 320px){.react-flow{min-height:250px}.react-flow__controls{transform:scale(.65)}.react-flow__minimap{transform:scale(.5)}}@media (orientation: landscape) and (max-height: 600px){.react-flow{min-height:calc(100vh - 150px)}}.devops-layout .dashboard-graph-container{width:100%;min-height:400px;height:calc(100vh - 280px);max-height:calc(100vh - 200px);border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff08;-webkit-overflow-scrolling:touch;position:relative;overflow:hidden}.devops-layout .dashboard-graph-container .react-flow{width:100%;height:100%}.dashboard-mermaid-wrap{overflow:auto;max-width:100%;padding:.5rem 0}.dashboard-mermaid-wrap svg{max-width:100%;height:auto}.dashboard-legend{padding:.75rem 0}.dashboard-legend-grid{flex-wrap:wrap;gap:1rem}.dashboard-header-actions{flex-wrap:wrap;gap:.5rem}.dashboard-last-update{flex-shrink:0}@media (max-width: 767px){.dashboard-graph-container{min-height:300px;height:calc(100vh - 320px);max-height:calc(100vh - 260px)}.dashboard-graph-container .react-flow{width:100%;height:100%}.dashboard-header-actions{flex-direction:column;align-items:stretch;width:100%}.dashboard-header-actions>*{width:100%}.dashboard-header-actions button{min-height:44px;justify-content:center}.dashboard-legend-grid{flex-direction:column;gap:.75rem}}@media (max-width: 480px){.dashboard-graph-container{min-height:250px;height:calc(100vh - 340px);max-height:calc(100vh - 280px)}.dashboard-graph-container .react-flow{width:100%;height:100%}}.dashboard-node-install-build-actions{overflow:visible}.dashboard-node-install-build-actions .dashboard-node-install-build-btn{padding:2px 6px!important;font-weight:600!important;line-height:1.2!important;font-size:.85rem!important;min-height:28px;min-width:auto}.dashboard-node-install-build-actions .dashboard-node-install-build-btn *{white-space:nowrap!important}.service-list-skeleton{width:100%}.service-list-skeleton-block{background:#ffffff17;border-radius:8px;position:relative;overflow:hidden}.service-list-skeleton-block:after{content:"";position:absolute;top:0;left:-160px;height:100%;width:160px;background:linear-gradient(90deg,#fff0,#ffffff24,#fff0);animation:service-list-skeleton-shimmer 1.25s infinite}@keyframes service-list-skeleton-shimmer{0%{transform:translate(0)}to{transform:translate(360px)}}@media (prefers-reduced-motion: reduce){.service-list-skeleton-block:after{animation:none}}.service-list-skeleton-line{display:block}.service-list-skeleton-line--muted{background:#ffffff12}.service-list-skeleton--cards{display:flex;flex-direction:column;gap:.75rem}.service-list-skeleton-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem}.service-list-skeleton-card-body{display:flex;flex-direction:column;min-width:0}.service-list-skeleton-card-meta{display:flex;gap:.75rem}.service-list-skeleton-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.service-list-skeleton-button{height:36px;width:86px;border-radius:10px}.service-list-skeleton--table{width:100%;min-width:820px}.service-list-skeleton--table[data-variant=frontend]{min-width:980px}.service-list-skeleton--table[data-variant=backend]{min-width:960px}.service-list-skeleton--table[data-variant=nginx]{min-width:820px}.service-list-skeleton--table[data-variant=docker]{min-width:980px}.service-list-skeleton-table-header-row,.service-list-skeleton-table-row{display:grid;column-gap:16px;align-items:center;padding:10px 16px}.service-list-skeleton-table-header-row{padding-top:16px;padding-bottom:12px}.service-list-skeleton-table-row{border-bottom:1px solid rgba(255,255,255,.06)}.service-list-skeleton-table-row:last-child{border-bottom:none}.service-list-skeleton--table[data-variant=frontend]{--sl-cols: 2.1fr 1.3fr .95fr 1.7fr 2.4fr}.service-list-skeleton--table[data-variant=backend]{--sl-cols: 2.1fr 1.4fr .95fr .85fr 2.7fr}.service-list-skeleton--table[data-variant=nginx]{--sl-cols: 1.8fr 1.4fr .75fr .75fr 2.2fr}.service-list-skeleton--table[data-variant=docker]{--sl-cols: 2fr 1.1fr 1.2fr 1.1fr 2.3fr}.service-list-skeleton-table-header-row,.service-list-skeleton-table-row{grid-template-columns:var(--sl-cols)}.service-list-skeleton-table-cell{min-width:0}.service-list-skeleton-actions-row{display:flex;gap:10px;flex-wrap:wrap}.selection-action-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem;padding:.65rem .85rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius)}.selection-action-bar-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;min-width:10rem}.selection-action-bar-count{font-size:.85rem;color:var(--text-muted)}.selection-action-bar-count--active{color:var(--gold);font-weight:600}.selection-action-bar-queue{font-size:.8rem;color:var(--primary)}.selection-action-bar-actions{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;justify-content:flex-end;flex:1 1 auto}@media (max-width: 768px){.selection-action-bar{flex-direction:column;align-items:stretch}.selection-action-bar-actions{justify-content:flex-start}}.backends-service{padding:clamp(1rem,.75rem + 1.25vw,2rem);max-width:1400px;margin:0 auto;width:100%;min-height:100%;box-sizing:border-box}.status-badge,.enabled-badge{padding:clamp(.25rem,.2rem + .25vw,.375rem) clamp(.5rem,.4rem + .5vw,.75rem);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.025em}@media (max-width: 768px){.backends-service{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.services-grid{grid-template-columns:1fr;gap:1rem}.service-card{padding:1rem}.service-header{flex-direction:column}.badges{flex-direction:row;margin-top:.5rem;align-items:flex-start;flex-wrap:wrap}.service-actions{flex-direction:column}.action-btn{width:100%}}@media (max-width: 480px){.backends-service{padding:.75rem}.page-header h1{font-size:var(--text-xl)}.service-card,.service-info{padding:.75rem}}.backends-service-page{width:100%;max-width:100%;min-height:0;box-sizing:border-box;padding:0 max(.75rem,env(safe-area-inset-right)) 0 max(.75rem,env(safe-area-inset-left))}.backends-service-page .ui-container,.backends-service-page .ui-box{max-width:100%!important}@media (max-width: 767px){.backends-service-page .ui-page-header{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:.75rem!important}.backends-service-page .ui-page-header [class*=heading],.backends-service-page .backends-service-page-header{flex-shrink:0!important}.backends-service-page .backends-service-header-actions,.backends-service-page .ui-page-header [class*=actions]{display:flex!important;flex-wrap:wrap!important;justify-content:flex-start!important;width:100%!important;max-width:100%!important}}.backends-service-mobile{width:100%;max-width:100%;padding-bottom:1rem}.backends-service-mobile-filter{margin-bottom:1rem;min-width:0}.backends-service-mobile-filter .ui-input{max-width:100%!important}.backends-service-mobile-cards{display:flex;flex-direction:column;gap:.75rem;width:100%;min-width:0}.backends-service-mobile-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem;width:100%;box-sizing:border-box;min-width:0}.backends-service-mobile-card-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.backends-service-mobile-card-name{font-weight:700;font-size:1rem;color:var(--text-primary);word-break:break-word}.backends-service-mobile-card-desc{font-size:.875rem;color:var(--text-secondary));word-break:break-word}.backends-service-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;margin-bottom:.75rem;font-size:.8125rem;color:var(--text-secondary))}.backends-service-mobile-card-meta-item{color:var(--text-secondary))}.backends-service-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;min-width:0}.backends-service-mobile-card-actions .ui-btn,.backends-service-mobile-card-actions button{flex-shrink:0;min-height:36px;white-space:nowrap}.frontend-services-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;margin-bottom:.75rem;font-size:.8125rem;color:var(--text-secondary))}.frontend-services-mobile-card-actions .ui-btn,.frontend-services-mobile-card-actions button{flex-shrink:0;min-height:36px;white-space:nowrap}@media (max-width: 767px){.backends-service-mobile-card-actions .ui-btn,.backends-service-mobile-card-actions button{min-height:44px;min-width:44px}}@media (max-width: 480px){.backends-service-page{padding-left:max(.5rem,env(safe-area-inset-left));padding-right:max(.5rem,env(safe-area-inset-right))}.backends-service-mobile{padding-bottom:.75rem}.backends-service-mobile-filter{margin-bottom:.75rem}.backends-service-mobile-cards{gap:.5rem}.backends-service-mobile-card{padding:.75rem}.backends-service-mobile-card-name{font-size:.9375rem}.backends-service-mobile-card-desc,.backends-service-mobile-card-meta,.backends-service-mobile-card-meta-item{font-size:.8125rem}.backends-service-mobile-card-meta{gap:.375rem .75rem;margin-bottom:.5rem}.backends-service-mobile-card-actions{gap:.375rem}.backends-service-mobile-card-actions .ui-btn,.backends-service-mobile-card-actions button{min-height:44px;padding-left:.5rem;padding-right:.5rem}}.backends-config-header,.backends-delete-header{display:block}@media (max-width: 767px){.backends-service-page .backends-config-header [class*=actions],.backends-service-page .backends-delete-header [class*=actions]{float:none!important;display:flex!important;flex-wrap:wrap!important;gap:.5rem!important;width:100%!important;max-width:100%!important;margin-top:.5rem!important}.backends-service-page .backends-config-header [class*=actions] button,.backends-service-page .backends-delete-header [class*=actions] button{min-width:44px;min-height:44px}}@media (max-width: 480px){.backends-service-page .backends-config-header [class*=actions],.backends-service-page .backends-delete-header [class*=actions]{flex-direction:column;align-items:stretch}.backends-service-page .backends-config-header [class*=actions] button,.backends-service-page .backends-delete-header [class*=actions] button{width:100%}}@media (max-width: 767px){.backends-service-page .ui-modal-overlay{max-width:calc(100vw - 1.5rem)!important;max-height:calc(100vh - 2rem)!important}.backends-service-page .ui-modal-overlay .ui-box{max-width:100%!important}}@media (max-width: 320px){.backends-service-page{padding-left:max(.375rem,env(safe-area-inset-left));padding-right:max(.375rem,env(safe-area-inset-right))}.backends-service-mobile-card{padding:.5rem}.backends-service-mobile-card-name{font-size:.875rem}}.frontend-services{padding:clamp(1rem,.75rem + 1.25vw,2rem);max-width:1400px;margin:0 auto;width:100%;min-height:100%;box-sizing:border-box}.service-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s}.service-card:hover{box-shadow:0 4px 6px #0000001a}.status-badge,.enabled-badge,.type-badge{padding:clamp(.25rem,.2rem + .25vw,.375rem) clamp(.5rem,.4rem + .5vw,.75rem);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-badge.running{background:#d1fae5;color:#065f46}.enabled-badge.enabled{background:#dbeafe;color:#1e40af}.enabled-badge.disabled{background:#f3f4f6;color:#6b7280}.type-badge.vite{background:#fef3c7;color:#92400e}.type-badge.flutter{background:#e0e7ff;color:#3730a3}.service-info{margin:1rem 0;padding:1rem;background:#f9fafb;border-radius:.375rem}.info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.info-value{color:#1a202c;font-size:var(--text-sm);font-family:var(--font-mono)}.url-link{background:none;border:none;color:#2563eb;font-size:.875rem;font-family:var(--font-mono);cursor:pointer;text-decoration:underline;padding:0}.url-link:hover{color:#1d4ed8}.action-btn.enable{background:var(--color-info);color:#fff}.action-btn.enable:hover:not(:disabled){background:var(--color-info-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.logs{background:var(--color-warning);color:#fff}.action-btn.logs:hover:not(:disabled){background:var(--color-warning-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.open-url{background:var(--color-purple);color:#fff;flex:0 0 auto;min-width:80px}.action-btn.open-url:hover:not(:disabled){background:var(--color-purple-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}@media (max-width: 768px){.frontend-services{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.services-grid{grid-template-columns:1fr;gap:1rem}.service-card{padding:1rem}.service-header{flex-direction:column}.badges{flex-direction:row;margin-top:.5rem;align-items:flex-start;flex-wrap:wrap}.service-actions{flex-direction:column}.action-btn{width:100%}.action-btn.open-url{flex:1 1 100%}}@media (max-width: 480px){.frontend-services{padding:.75rem}.page-header h1{font-size:var(--text-xl)}.service-card,.service-info{padding:.75rem}}.frontend-services-page{width:100%;max-width:100%;min-height:0;box-sizing:border-box;padding:0 max(.75rem,env(safe-area-inset-right)) 0 max(.75rem,env(safe-area-inset-left))}.frontend-services-page .ui-container,.frontend-services-page .ui-box{max-width:100%!important}@media (max-width: 767px){.frontend-services-page .ui-page-header{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:.75rem!important}.frontend-services-page .ui-page-header [class*=heading],.frontend-services-page .frontend-services-page-header{flex-shrink:0!important}.frontend-services-page .frontend-services-header-actions,.frontend-services-page .ui-page-header [class*=actions]{display:flex!important;flex-wrap:wrap!important;justify-content:flex-start!important;width:100%!important;max-width:100%!important}}@media (max-width: 767px){.frontend-services-page .frontend-detail-header-actions,.frontend-services-page [class*=frontend-detail-header] [class*=actions]{float:none!important;display:flex!important;flex-wrap:wrap!important;gap:.5rem!important;width:100%!important;max-width:100%!important}}.frontend-services-live-summary{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border-color));background:var(--bg-card));font-size:var(--text-sm, .875rem);color:var(--text-secondary)}.frontend-services-live-summary-item strong{color:var(--text-primary);font-weight:600}.frontend-services-live-summary-hint{opacity:.85}.frontend-services-mobile{width:100%;max-width:100%;padding-bottom:1rem}.frontend-services-mobile-filter{margin-bottom:1rem;min-width:0}.frontend-services-mobile-filter .ui-input{max-width:100%!important}.frontend-services-mobile-cards{display:flex;flex-direction:column;gap:.75rem;width:100%;min-width:0}.frontend-services-mobile-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem;width:100%;box-sizing:border-box;min-width:0}.frontend-services-mobile-card-name{font-weight:700;font-size:1rem;color:var(--text-primary);word-break:break-word}.frontend-services-mobile-card-type{text-transform:capitalize}.frontend-services-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;min-width:0}.frontend-services-mobile-card-actions .ui-btn,.frontend-services-mobile-card-actions button{flex-shrink:0;min-height:36px}@media (max-width: 1200px){.frontend-services-page .action-buttons-cell{white-space:normal!important}.frontend-services-page .ui-table td:last-child .ui-stack{flex-wrap:wrap!important;row-gap:.35rem!important}}.node-modules-page{padding:var(--space-m, 16px)}.node-modules-page code{font-size:.9em}.node-modules-page .frontend-services-mobile{width:100%}.node-modules-page .frontend-services-mobile-filter{margin-bottom:1rem}.node-modules-page .frontend-services-mobile-cards{display:flex;flex-direction:column;gap:.75rem}.node-modules-page .frontend-services-mobile-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem}.node-modules-page .frontend-services-mobile-card-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.node-modules-page .frontend-services-mobile-card-name{font-weight:700}.node-modules-page .frontend-services-mobile-card-desc{font-size:.875rem;color:var(--text-secondary))}.node-modules-page .frontend-services-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;font-size:.8125rem;color:var(--text-secondary))}.node-modules-page .frontend-services-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.5rem}.databases-tables-modal-content{background:var(--mitverse-bg-card, #1f1f1f)!important;background-color:var(--mitverse-bg-card, #1f1f1f)!important;margin:-1rem -1rem 0;padding:1rem;min-height:12rem;border-radius:0 0 8px 8px}.frontend-services-mobile{width:100%}.frontend-services-mobile-filter{margin-bottom:1rem}.databases{padding:clamp(1rem,.75rem + 1.25vw,2rem);max-width:1600px;margin:0 auto;width:100%;min-height:100%;box-sizing:border-box}.page-header h1{margin:0;color:#1a202c;font-size:2rem}.refresh-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:background .2s}.refresh-btn:hover:not(:disabled){background:#5568d3}.message{padding:1rem;border-radius:.375rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;padding:0;margin-left:1rem;line-height:1}.loading,.error{text-align:center;padding:2rem;font-size:1.125rem}.error{color:#991b1b;background:#fee2e2;border-radius:.375rem}.databases-container{display:grid;grid-template-columns:1fr;gap:2rem}.databases-list h2{margin:0 0 1.5rem;color:#1a202c;font-size:1.5rem}.database-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,350px),1fr));gap:clamp(1rem,.75rem + 1.25vw,1.5rem);width:100%}.database-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s}.database-card:hover{box-shadow:0 4px 6px #0000001a}.database-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.database-header h3{margin:0;color:#1a202c;font-size:1.125rem;font-family:var(--font-mono)}.protected-badge{padding:.25rem .75rem;background:#fef3c7;color:#92400e;border-radius:.25rem;font-size:.75rem;font-weight:500}.database-info{margin:1rem 0;padding:1rem;background:#f9fafb;border-radius:.375rem}.info-label{font-weight:500;color:#6b7280;font-size:.875rem}.info-value{color:#1a202c;font-size:.875rem;font-family:var(--font-mono)}.database-actions{display:flex;gap:.75rem;margin-top:1rem}.action-btn{flex:1;padding:.75rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.action-btn.info{background:#3b82f6;color:#fff}.action-btn.info:hover:not(:disabled){background:#2563eb}.action-btn.danger{background:#ef4444;color:#fff}.action-btn.danger:hover:not(:disabled){background:#dc2626}.action-btn:disabled{opacity:.6;cursor:not-allowed}.drop-confirm{margin-top:1rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.375rem}.drop-confirm p{margin:0 0 .5rem;color:#991b1b}.drop-confirm .warning{font-weight:600;color:#dc2626}.confirm-actions{display:flex;gap:.75rem;margin-top:1rem}.confirm-btn{flex:1;padding:.75rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.confirm-btn.danger{background:#dc2626;color:#fff}.confirm-btn.danger:hover:not(:disabled){background:#b91c1c}.confirm-btn.cancel{background:#6b7280;color:#fff}.confirm-btn.cancel:hover:not(:disabled){background:#4b5563}.confirm-btn:disabled{opacity:.6;cursor:not-allowed}.database-details{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;position:sticky;top:2rem;max-height:calc(100vh - 4rem);overflow-y:auto}.details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.details-header h2{margin:0;color:#1a202c;font-size:1.25rem}.close-details-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;line-height:1;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem}.close-details-btn:hover{background:#f3f4f6;color:#1a202c}.details-content{display:flex;flex-direction:column;gap:1rem}.detail-item{display:flex;justify-content:space-between;padding:.75rem;background:#f9fafb;border-radius:.375rem}.detail-label{font-weight:500;color:#6b7280;font-size:.875rem}.detail-value{color:#1a202c;font-size:.875rem;font-family:var(--font-mono);font-weight:500}@media (min-width: 1200px){.databases-container{grid-template-columns:2fr 1fr}}@media (max-width: 1024px){.database-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr))}}@media (max-width: 768px){.databases{padding:1rem}.database-grid{grid-template-columns:1fr;gap:1rem}.databases-container{grid-template-columns:1fr}.database-card{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.database-actions{flex-direction:column}.action-btn{width:100%}.database-details{position:static;max-height:none}}@media (max-width: 480px){.databases{padding:.75rem}.page-header h1{font-size:var(--text-xl)}.database-card,.database-info{padding:.75rem}}.docker-services{padding:clamp(1rem,.75rem + 1.25vw,2rem);max-width:1400px;margin:0 auto;width:100%;min-height:100%;box-sizing:border-box}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{margin:0;color:#1a202c;font-size:var(--text-2xl);font-weight:700}.refresh-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:clamp(.625rem,.5rem + .625vw,.75rem) clamp(1rem,.875rem + .625vw,1.25rem);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;box-shadow:var(--shadow-sm)}.refresh-btn:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.message{padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm)}.message.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;padding:0;margin-left:1rem;line-height:1;transition:opacity var(--transition-fast)}.close-btn:hover{opacity:.7}.loading,.error,.empty{text-align:center;padding:2rem;font-size:var(--text-lg)}.error{color:#991b1b;background:#fee2e2;border-radius:var(--radius-md)}.empty{color:#6b7280}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,350px),1fr));gap:clamp(1rem,.75rem + 1.25vw,1.5rem);width:100%}.service-card{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.service-card:hover{box-shadow:var(--shadow-md)}.service-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.service-header h2{margin:0 0 .5rem;color:#1a202c;font-size:var(--text-xl);font-weight:600}.service-description{margin:0;color:#6b7280;font-size:var(--text-sm);line-height:1.5}.badges{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.status-badge{padding:clamp(.25rem,.2rem + .25vw,.375rem) clamp(.5rem,.4rem + .5vw,.75rem);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-badge.running.healthy{background:#d1fae5;color:#065f46}.status-badge.running{background:#fef3c7;color:#92400e}.status-badge.stopped{background:#fee2e2;color:#991b1b}.service-info{margin:1rem 0;padding:1rem;background:#f9fafb;border-radius:var(--radius-md)}.info-item{display:flex;justify-content:space-between;margin-bottom:.5rem}.info-item:last-child{margin-bottom:0}.info-label{font-weight:500;color:#6b7280;font-size:var(--text-sm)}.info-value{color:#1a202c;font-size:var(--text-sm);font-family:var(--font-mono);text-align:right;word-break:break-all}.service-actions{display:flex;gap:clamp(.5rem,.4rem + .5vw,.75rem);margin-top:1rem;flex-wrap:wrap}.action-btn{flex:1;min-width:fit-content;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:clamp(.625rem,.5rem + .625vw,.75rem) clamp(.875rem,.75rem + .625vw,1rem);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.action-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.action-btn:hover:not(:disabled):before{width:300px;height:300px}.action-btn:active:not(:disabled){transform:scale(.98)}.action-btn.start{background:var(--color-success);color:#fff}.action-btn.start:hover:not(:disabled){background:var(--color-success-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.stop{background:var(--color-danger);color:#fff}.action-btn.stop:hover:not(:disabled){background:var(--color-danger-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.restart{background:var(--color-info);color:#fff}.action-btn.restart:hover:not(:disabled){background:var(--color-info-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.enable{background:var(--color-success);color:#fff}.action-btn.enable:hover:not(:disabled){background:var(--color-success-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn.disable{background:var(--color-secondary);color:#fff}.action-btn.disable:hover:not(:disabled){background:var(--color-secondary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-btn:disabled:before{display:none}@media (max-width: 1024px){.services-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr))}}@media (max-width: 768px){.docker-services{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.services-grid{grid-template-columns:1fr;gap:1rem}.service-card{padding:1rem}.service-header{flex-direction:column}.badges{flex-direction:row;margin-top:.5rem;align-items:flex-start;flex-wrap:wrap}.service-actions{flex-direction:column}.action-btn{width:100%}}@media (max-width: 480px){.docker-services{padding:.75rem}.page-header h1{font-size:var(--text-xl)}.service-card,.service-info{padding:.75rem}}.docker-services-page{width:100%;max-width:100%;min-height:0;box-sizing:border-box;padding:0 max(.75rem,env(safe-area-inset-right)) 0 max(.75rem,env(safe-area-inset-left))}.docker-services-page .ui-container,.docker-services-page .ui-box{max-width:100%!important}.docker-services-page .frontend-services-mobile{width:100%;max-width:100%;padding-bottom:1rem}.docker-services-page .frontend-services-mobile-filter{margin-bottom:1rem;min-width:0}.docker-services-page .frontend-services-mobile-cards{display:flex;flex-direction:column;gap:.75rem;width:100%;min-width:0}.docker-services-page .frontend-services-mobile-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem;width:100%;box-sizing:border-box;min-width:0}.docker-services-page .frontend-services-mobile-card-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.docker-services-page .frontend-services-mobile-card-name{font-weight:700;font-size:1rem;color:var(--text-primary);word-break:break-word}.docker-services-page .frontend-services-mobile-card-desc{font-size:.875rem;color:var(--text-secondary));word-break:break-word}.docker-services-page .frontend-services-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;font-size:.8125rem;color:var(--text-secondary))}.docker-services-page .frontend-services-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;min-width:0}.docker-services-page .frontend-services-mobile-card-actions .ui-btn,.docker-services-page .frontend-services-mobile-card-actions button{flex-shrink:0;min-height:36px}@media (max-width: 767px){.docker-services-page .ui-page-header{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:.75rem!important}.docker-services-page .ui-page-header [class*=heading],.docker-services-page .docker-services-page-header{flex-shrink:0!important}.docker-services-page .docker-services-header-actions,.docker-services-page .ui-page-header [class*=actions]{display:flex!important;flex-wrap:wrap!important;justify-content:flex-start!important;width:100%!important;max-width:100%!important}}@media (max-width: 1200px){.docker-services-page .action-buttons-cell{white-space:normal!important}.docker-services-page .ui-table td:last-child .ui-stack{flex-wrap:wrap!important;row-gap:.35rem!important}}.nginx-services-page .frontend-services-mobile{width:100%}.nginx-services-page .frontend-services-mobile-filter{margin-bottom:1rem}.nginx-services-page .frontend-services-mobile-cards{display:flex;flex-direction:column;gap:.75rem}.nginx-services-page .frontend-services-mobile-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem}.nginx-services-page .frontend-services-mobile-card-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.nginx-services-page .frontend-services-mobile-card-name{font-weight:700}.nginx-services-page .frontend-services-mobile-card-desc{font-size:.875rem;color:var(--text-secondary))}.nginx-services-page .frontend-services-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;font-size:.8125rem;color:var(--text-secondary))}.nginx-services-page .frontend-services-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.5rem}.git-repos-page{padding:clamp(1rem,.75rem + 1.25vw,2rem);max-width:1400px;margin:0 auto;width:100%;min-height:100%;box-sizing:border-box}.git-repos-page .portfolio-card{margin-bottom:1.5rem;border:1px solid var(--color-border-divider-default, #e5e7eb);border-radius:8px;overflow:hidden}.git-repos-page .portfolio-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem;background:transparent;border-bottom:1px solid var(--color-border-divider-default, #e5e7eb)}.git-repos-page .portfolio-title{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1.125rem}.git-repos-page .portfolio-badges{display:flex;align-items:center;gap:.5rem}.git-repos-page .provider-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:capitalize}.git-repos-page .provider-badge.github{background:#f3f4f6;color:#1f2937}.git-repos-page .provider-badge.gitlab{background:#fef3c7;color:#92400e}.git-repos-page .provider-badge.bitbucket{background:#dbeafe;color:#1e40af}.git-repos-page .repos-section{padding:1rem 1.25rem}.git-repos-page .repo-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--color-border-divider-default, #e5e7eb)}.git-repos-page .repo-row:last-child{border-bottom:none}.git-repos-page .repo-info{flex:1;min-width:0}.git-repos-page .repo-name-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.git-repos-page .repo-name{font-weight:500;font-family:var(--font-sans, inherit)}.git-repos-page .repo-status-badges{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.git-repos-page .repo-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;line-height:1.3;white-space:nowrap}.git-repos-page .repo-badge-ahead{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.git-repos-page .repo-badge-behind{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.git-repos-page .repo-badge-dirty{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;max-width:min(100%,22rem);overflow:hidden;text-overflow:ellipsis}.git-repos-page .repo-meta{font-size:.875rem;color:var(--color-text-body-secondary, #6b7280);margin-top:.25rem}.git-repos-page .repo-push-btn-wrap{display:inline-flex}.git-repos-page .repo-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.git-repos-page .empty-repos{color:var(--color-text-body-secondary, #6b7280);padding:1.5rem;text-align:center}@media (max-width: 768px){.git-repos-page .portfolio-header,.git-repos-page .repo-row{flex-direction:column;align-items:flex-start}.git-repos-page .repo-actions{width:100%}}.firewall-section{border:1px solid var(--color-border-divider-default, #e9ebed);border-radius:8px}.firewall-section+.firewall-section{margin-top:0}.frontend-services-mobile-card-desc{font-size:.875rem;color:var(--text-secondary))}.frontend-services-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.5rem}.firewall-list-toolbar{margin-bottom:.5rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--bg-card)}.top-process-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;width:100%}.top-process-card{border:1px solid var(--border-color));border-radius:10px;padding:1rem;background:var(--bg-card));display:flex;flex-direction:column;gap:.75rem;min-width:0}.top-process-card-header{display:flex;flex-direction:column;gap:.35rem}.top-process-card-name{font-size:1.05rem;font-weight:700;word-break:break-all}.top-process-card-metrics{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.top-process-metric{display:flex;flex-direction:column;gap:.15rem}.top-process-metric-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.top-process-metric-value{font-weight:600;font-size:.95rem}.top-process-card-actions{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.top-process-instances{list-style:none;margin:0;padding:0;border-top:1px solid var(--border-color));padding-top:.75rem;display:flex;flex-direction:column;gap:.65rem}.top-process-instance-row{font-size:.8125rem}.top-process-instance-meta{display:flex;flex-wrap:wrap;gap:.5rem .75rem;color:var(--text-secondary)}.top-process-instance-cmd{margin-top:.25rem;word-break:break-all;opacity:.85;font-family:var(--font-mono);font-size:.75rem}.top-process-instance-actions{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.35rem}@media (max-width: 640px){.top-process-cards-grid{grid-template-columns:1fr}}.frontend-services-mobile-cards{display:flex;flex-direction:column;gap:.75rem}.frontend-services-mobile-card{background:var(--bg-card));border:1px solid var(--border-color));border-radius:8px;padding:1rem}.frontend-services-mobile-card-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.frontend-services-mobile-card-name{font-weight:700}.frontend-services-mobile-card-desc{font-size:.875rem;color:var(--text-secondary));word-break:break-word}.frontend-services-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:.75rem;font-size:.8125rem;color:var(--text-secondary))}.app{width:100%;height:100vh;display:flex;overflow:hidden}:root{--bg-deep: #070609;--bg-primary: #0e0c10;--bg-card: #141219;--bg-elevated: #1a1721;--bg-input: rgba(7, 6, 9, .7);--primary: #0d9488;--primary-hover: #0f766e;--primary-glow: rgba(13, 148, 136, .35);--primary-dim: rgba(13, 148, 136, .12);--accent: #d97706;--accent-dim: rgba(217, 119, 6, .15);--gold: #f59e0b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: rgba(148, 163, 184, .12);--border-focus: rgba(13, 148, 136, .5);--success: #10b981;--success-dim: rgba(16, 185, 129, .15);--error: #f87171;--error-dim: rgba(248, 113, 113, .15);--warning: #fbbf24;--warning-dim: rgba(251, 191, 36, .15);--card-bg: var(--bg-card);--radius: .5rem;--radius-sm: .25rem;--shadow-lg: 0 25px 50px -12px rgba(0, 0, 0, .5);--sidebar-width: 220px;--outlook-row-height: 32px;--mobile-topbar-height: 48px;--font-sans: "Rajdhani", system-ui, sans-serif;--font-display: "Orbitron", sans-serif;--font-mono: "Monaco", "Menlo", "Ubuntu Mono", "Consolas", monospace}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{min-height:100%}body{font-family:var(--font-sans);line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--bg-deep);min-width:320px;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{color:var(--gold)}button{font-family:var(--font-display)}input,textarea,select{font-family:var(--font-sans)}code,pre,kbd,samp{font-family:var(--font-mono)}body:has(.mitbar-root) .layout.outlook{padding-bottom:calc(4.5rem + env(safe-area-inset-bottom,0px))}.input,.select-input,textarea.input{padding:.55rem .75rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font-sans);color:var(--text-primary);transition:border-color .2s,box-shadow .2s;width:100%}.input::placeholder,textarea.input::placeholder{color:var(--text-muted)}.input:focus,.select-input:focus,textarea.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}select.select-input{cursor:pointer}.btn-primary{padding:.5rem .9rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:var(--bg-deep);border:none;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 0 14px var(--primary-glow);display:inline-flex;align-items:center;justify-content:center;gap:.35rem}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 22px var(--primary-glow)}.btn-secondary{padding:.45rem .75rem;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-weight:500;font-family:var(--font-sans);font-size:.85rem;transition:background .2s,border-color .2s,color .2s;display:inline-flex;align-items:center;justify-content:center;gap:.35rem}.btn-secondary:hover:not(:disabled){background:var(--bg-card);border-color:var(--primary);color:var(--primary)}.btn-primary:disabled,.btn-secondary:disabled,.nav-item:disabled{opacity:.65;cursor:not-allowed;transform:none}.btn-sm{padding:.3rem .55rem;font-size:.75rem}.devops-page{max-width:100%;width:100%}.page-panel{margin-bottom:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:0 4px 20px #00000040}.frontend-services-mobile,.frontend-services-mobile-cards{display:flex;flex-direction:column;gap:.75rem}.frontend-services-mobile-filter{margin-bottom:.5rem}.frontend-services-mobile-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:.85rem 1rem}.frontend-services-mobile-card--selected{border-color:#f59e0b73;background:#f59e0b0f}.frontend-services-mobile-card-select{display:inline-flex;align-items:center;margin-right:.5rem}.frontend-services-mobile-card-header{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.frontend-services-mobile-card-name{font-weight:600;color:var(--text-primary)}.frontend-services-mobile-card-desc{font-size:.85rem;color:var(--text-secondary)}.frontend-services-mobile-card-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:.8rem;color:var(--text-secondary);margin-bottom:.65rem}.frontend-services-mobile-card-actions{display:flex;flex-wrap:wrap;gap:.35rem}button,a,[role=button],input[type=submit],input[type=button]{touch-action:manipulation}#root{min-height:100vh;min-height:100dvh;width:100%;overflow-x:hidden}@media (max-width: 767px){input[type=text],input[type=password],input[type=email],input[type=search]{font-size:16px!important}}
