.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.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__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.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:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{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:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.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.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@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;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.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-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.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:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.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-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.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:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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:var(--xy-resize-background-color, var(--xy-resize-background-color-default));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%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}:root{--ok-bg: #f4f6f8;--ok-sidebar: #111827;--ok-sidebar-2: #1f2937;--ok-card: #ffffff;--ok-ink: #161616;--ok-muted: #525252;--ok-line: #dde1e6;--ok-accent: #0f62fe;--ok-ok: #166534;--ok-warn: #b45309;--ok-err: #b91c1c;--ok-soft: #fbfcfe;--ok-soft-2: #f8fbff;--ok-table-head: #f8fafc;--ok-table-column-line: #edf0f4;--ok-input-bg: #ffffff;--ok-button-bg: #e5e7eb;--ok-button-hover: #f3f4f6;--ok-button-ink: #111827;--ok-danger-soft: #fff1f2;--ok-danger-line: #fecdd3;--ok-warn-soft: #fffbeb;--ok-warn-line: #fde68a;--ok-ok-soft: #f0fdf4;--ok-ok-line: #bbf7d0;--ok-accent-soft: #eff6ff;--ok-accent-line: #bfdbfe;--ok-accent-ink: #0f3d99;--ok-login-bg: linear-gradient(135deg, #111827 0%, #253243 52%, #f4f6f8 52%);--ok-focus-line: #93c5fd;--ok-switch-bg: #e5e7eb;--ok-switch-knob: #ffffff}:root[data-theme=dark]{--ok-bg: #0b1118;--ok-sidebar: #07111d;--ok-sidebar-2: #0f1b28;--ok-card: #111b26;--ok-ink: #e6edf5;--ok-muted: #9aa8b8;--ok-line: #263447;--ok-accent: #5b9dff;--ok-ok: #80d996;--ok-warn: #f0b95b;--ok-err: #ff8f8f;--ok-soft: #0f1924;--ok-soft-2: #102033;--ok-table-head: #162232;--ok-table-column-line: #1d2a3a;--ok-input-bg: #0c1621;--ok-button-bg: #1c2a3b;--ok-button-hover: #25364a;--ok-button-ink: #e6edf5;--ok-danger-soft: #351820;--ok-danger-line: #7f2c3a;--ok-warn-soft: #312411;--ok-warn-line: #74501d;--ok-ok-soft: #102819;--ok-ok-line: #245a37;--ok-accent-soft: #10243f;--ok-accent-line: #2d5f9d;--ok-accent-ink: #b8d5ff;--ok-login-bg: linear-gradient(135deg, #050b12 0%, #111f2d 54%, #0b1118 54%);--ok-focus-line: #5b9dff;--ok-switch-bg: #243245;--ok-switch-knob: #dbe7f5;color-scheme:dark}:root[data-theme=dark] .ok-infra-rack-body{border-color:#334155;background:#182334}:root[data-theme=dark] .ok-infra-rack-unit{border-top-color:#2f4054;background:transparent;box-shadow:none}:root[data-theme=dark] .ok-infra-rack-unit:hover{background:#17345a}*{box-sizing:border-box}body{margin:0;font-family:Noto Sans KR,Segoe UI,sans-serif;font-size:13px;line-height:1.4;color:var(--ok-ink);background:var(--ok-bg)}.ok-login{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--ok-login-bg)}.ok-login-panel{width:min(420px,100%);background:var(--ok-card);border:1px solid var(--ok-line);border-radius:8px;padding:22px;box-shadow:0 18px 48px #1118272e}.ok-login-panel h1{margin:0 0 4px;font-size:20px}.ok-login-panel p{margin:0 0 18px;color:var(--ok-muted)}.ok-layout{min-height:100vh;display:grid;grid-template-columns:200px minmax(0,1fr)}.ok-layout.is-sidebar-collapsed{grid-template-columns:40px minmax(0,1fr)}.ok-sidebar{position:sticky;top:0;height:100vh;overflow:visible;display:flex;flex-direction:column;padding:14px 12px;background:linear-gradient(180deg,var(--ok-sidebar),var(--ok-sidebar-2));border-right:1px solid #2a3441}.ok-sidebar.is-collapsed{padding:8px 4px}.ok-sidebar-body{min-height:100%;overflow:auto;display:flex;flex-direction:column}.ok-sidebar.is-collapsed .ok-sidebar-body{display:none}.ok-sidebar-toggle{position:absolute;top:2px;right:2px;z-index:10;width:24px;height:24px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);border-left-color:#ffffff1a;border-radius:999px;background:linear-gradient(180deg,var(--ok-sidebar-2),var(--ok-sidebar));color:#d1d5db;cursor:pointer;font-weight:900;line-height:1;box-shadow:0 4px 12px #0000003d}.ok-sidebar-toggle:hover{color:#fff;border-color:#ffffff4d;background:linear-gradient(180deg,#273244,#1f2937)}.ok-sidebar-toggle span{display:block;font-size:16px;line-height:1;transform:translateY(-1px)}.ok-sidebar.is-collapsed .ok-sidebar-toggle{right:4px}.ok-sidebar-collapsed-marks{display:grid;justify-items:center;gap:8px;margin:28px auto 0}.ok-sidebar-collapsed-logo{width:28px;height:28px;overflow:hidden;border-radius:6px}.ok-sidebar-collapsed-logo img{display:block;width:98px;max-width:none;height:auto}.ok-sidebar-collapsed-netapp{width:25px;height:22px;display:block;overflow:hidden;border-radius:3px;opacity:.98;transform:translateY(-6px)}.ok-sidebar-collapsed-netapp img{display:block;width:27px;max-width:none;height:auto;transform:translate(-1px);transform-origin:left top}.ok-collapsed-theme-button{position:absolute;left:50%;bottom:12px;width:18px;height:18px;padding:0;transform:translate(-50%);border:1px solid rgba(255,255,255,.32);border-radius:999px;background:transparent;cursor:pointer;box-shadow:0 2px 8px #0000003d;overflow:hidden}.ok-collapsed-theme-button span{display:block;width:100%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#0f172a 0,#0f172a 50%,#f8fafc 50%,#f8fafc)}.ok-collapsed-theme-button.is-light span{transform:rotate(180deg)}.ok-collapsed-theme-button:hover{border-color:#ffffff85;box-shadow:0 0 0 2px #ffffff1f,0 4px 12px #0000004d}.ok-brand{display:grid;justify-items:center;gap:6px;color:#fff;margin-bottom:14px;text-align:center}.ok-brand img{width:136px;max-width:100%;height:auto;display:block}.ok-brand strong{display:block;font-size:12px}.ok-brand span,.ok-sidebar-footer{color:#a7b0bf;font-size:12px}.ok-main-nav,.ok-subnav{display:grid;gap:5px}.ok-main-nav button,.ok-subnav button{text-align:left;border:0;border-radius:6px;padding:8px;cursor:pointer}.ok-main-nav button{color:#d1d5db;background:transparent}.ok-main-nav button.is-active,.ok-main-nav button:hover{color:#fff;background:#ffffff1a}.ok-main-nav button:disabled,.ok-main-nav button.is-license-locked{color:#7f8da3;cursor:not-allowed;opacity:.58;background:transparent}.ok-main-nav button:disabled:hover,.ok-main-nav button.is-license-locked:hover{color:#7f8da3;background:transparent}.ok-license-lock-note{padding:7px 8px;border:1px solid rgba(240,185,91,.32);border-radius:6px;background:#f0b95b1a;color:#f8d48a;font-size:12px;font-weight:800}.ok-nav-group{display:grid;gap:4px}.ok-nav-children{display:grid;gap:2px;padding-left:0;margin-left:0}.ok-nav-children button{min-height:28px;padding:5px 8px;font-size:12px;color:#a7b0bf;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-nav-folder{display:grid;gap:2px}.ok-nav-folder-row{display:grid;grid-template-columns:18px minmax(0,1fr);gap:1px;align-items:center}.ok-nav-folder-row .ok-nav-expander{min-height:24px;padding:0;display:grid;place-items:center;text-align:center;font-weight:800;color:#a7b0bf}.ok-nav-folder-row .ok-nav-expander span{display:block;font-size:16px;line-height:1;transform:translateY(-1px);transition:transform .14s ease}.ok-nav-folder-row .ok-nav-expander.is-expanded span{transform:rotate(90deg) translateY(-1px)}.ok-nav-folder-row .ok-nav-folder-link{min-width:0}.ok-nav-dashboard-link{padding-left:27px!important}.ok-nav-folder-items{display:grid;gap:2px;padding-left:10px}.ok-nav-folder-items button{min-height:24px;color:#cbd5e1}.ok-nav-children button.is-active,.ok-nav-folder-link.is-active{color:#fff;background:#ffffff24}.ok-sidebar-footer{margin-top:auto;display:grid;gap:8px}.ok-build-info{display:grid;gap:4px;padding:8px 0;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}.ok-build-info span{display:block;color:#a7b0bf;font-size:11px;line-height:1.35;overflow-wrap:anywhere}.ok-footer-actions{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.ok-theme-toggle{min-height:32px;display:grid;grid-template-columns:1fr 1fr;gap:2px;align-items:center;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:#ffffff14;padding:2px;color:#d1d5db;cursor:pointer}.ok-theme-toggle span{display:grid;place-items:center;min-height:26px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:0}.ok-theme-toggle span.is-active{background:#fff;color:#111827;box-shadow:0 1px 4px #0000002e}.ok-content{min-width:0;width:100%;padding:9px}.ok-page-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}.ok-page-head h2{margin:0;font-size:18px}.ok-page-head p,.ok-muted{margin:2px 0 0;color:var(--ok-muted)}.ok-vo-page{display:grid;gap:8px;min-width:0}.ok-vo-page.is-dashboard{gap:0}.ok-vo-head{margin-bottom:0}.ok-vo-tabs{display:inline-flex;align-items:center;gap:3px;padding:3px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-card)}.ok-vo-tabs button{min-height:24px;border:0;border-radius:4px;padding:3px 10px;background:transparent;color:var(--ok-muted);font-size:12px;font-weight:700;letter-spacing:0;cursor:pointer}.ok-vo-tabs button:hover{color:var(--ok-ink);background:var(--ok-soft)}.ok-vo-tabs button.is-active{color:var(--ok-accent-ink);background:var(--ok-accent-soft)}.ok-card{background:var(--ok-card);border:1px solid var(--ok-line);border-radius:8px;padding:12px;margin-bottom:12px;box-shadow:0 1px 2px #1018280d;min-width:0}.ok-card.subtle{background:var(--ok-table-head);box-shadow:none}.ok-topology-page{display:grid;gap:8px;min-width:0}.ok-topology-head{margin-bottom:0}.ok-topology-toolbar{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr)) auto;gap:8px;align-items:end;margin-bottom:0}.ok-topology-toolbar label{margin-bottom:0}.ok-topology-check{min-height:34px;display:flex;align-items:center;gap:6px;color:var(--ok-ink);font-weight:700}.ok-topology-check input{margin:0}.ok-topology-warnings{display:grid;gap:4px;margin-bottom:0;color:var(--ok-warn);background:var(--ok-warn-soft);border-color:var(--ok-warn-line)}.ok-topology-warnings span{overflow-wrap:anywhere}.ok-topology-stats{min-height:36px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:0;padding:7px 10px}.ok-topology-stats span{display:inline-flex;align-items:baseline;gap:4px;padding:3px 7px;border:1px solid var(--ok-line);border-radius:999px;background:var(--ok-soft);color:var(--ok-muted);font-size:12px}.ok-topology-stats strong{color:var(--ok-ink)}.ok-topology-stats em{margin-left:auto;color:var(--ok-muted);font-style:normal;font-size:12px}.ok-topology-shell{min-height:calc(100vh - 230px);display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:8px}.ok-topology-flow{min-height:700px;overflow:hidden;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card)}.ok-topology-flow .react-flow{background:color-mix(in srgb,var(--ok-soft) 72%,var(--ok-card))}.ok-topology-flow .react-flow__edges{z-index:1}.ok-topology-flow .react-flow__nodes{z-index:2}.ok-topology-flow .react-flow__edge-path{stroke-width:1.8}.ok-topology-flow .react-flow__attribution{display:none}.ok-topology-flow .react-flow__controls-button{background:var(--ok-card);border-color:var(--ok-line);color:var(--ok-ink)}.ok-topology-flow .react-flow__minimap{background:var(--ok-card);border:1px solid var(--ok-line);border-radius:6px}.ok-topology-node-card{position:relative;height:80px;min-height:80px;display:grid;gap:2px;align-content:center;padding:6px 8px;border:1px solid var(--ok-line);border-left:4px solid var(--ok-muted);border-radius:7px;background:var(--ok-card);box-shadow:0 3px 10px #0f172a17;cursor:grab}.react-flow__node.dragging .ok-topology-node-card{cursor:grabbing}.ok-topology-node-card.has-port-handles{min-height:118px;padding-top:24px;padding-bottom:24px}.ok-topology-node-body{display:grid;gap:2px;align-content:center;min-width:0}.ok-topology-node-card.is-ok{border-left-color:var(--ok-ok)}.ok-topology-node-card.is-warning{border-left-color:var(--ok-warn);background:var(--ok-warn-soft)}.ok-topology-node-card.is-problem{border-left-color:var(--ok-err);background:var(--ok-danger-soft);box-shadow:0 0 0 1px var(--ok-danger-line),0 0 18px #b91c1c2e}.ok-topology-node-card.is-highlight-active{--ok-widget-threshold-color: var(--ok-err);border-color:var(--ok-widget-threshold-color);border-left-color:var(--ok-widget-threshold-color);animation:ok-rack-card-highlight-pulse 2.1s ease-in-out infinite}.ok-topology-node-card.is-path-highlight{border-color:var(--ok-accent);border-left-color:var(--ok-accent);background:color-mix(in srgb,var(--ok-accent) 12%,var(--ok-card));box-shadow:0 0 0 1px color-mix(in srgb,var(--ok-accent) 46%,transparent),0 0 22px color-mix(in srgb,var(--ok-accent) 22%,transparent)}.ok-topology-node-card.is-problem.is-path-highlight{border-color:var(--ok-danger-line);border-left-color:var(--ok-err);background:var(--ok-danger-soft);box-shadow:0 0 0 1px var(--ok-danger-line),0 0 18px #b91c1c2e,0 0 0 3px color-mix(in srgb,var(--ok-accent) 24%,transparent)}.ok-topology-node-card.is-highlight-active.is-path-highlight{animation-name:ok-rack-card-highlight-pulse}.ok-topology-disk-group-card,.ok-topology-volume-group-card{height:100%;min-height:0;align-content:start;gap:8px;padding:8px 10px}.ok-topology-disk-group-card{border-left-color:#2563eb}.ok-topology-volume-group-card{border-left-color:#7c3aed}.ok-topology-disk-group-card.is-warning,.ok-topology-volume-group-card.is-warning{background:color-mix(in srgb,var(--ok-warn-soft) 54%,var(--ok-card))}.ok-topology-disk-group-card.is-problem,.ok-topology-volume-group-card.is-problem{background:color-mix(in srgb,var(--ok-danger-soft) 50%,var(--ok-card))}.ok-topology-disk-group-head{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.ok-topology-disk-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:4px}.ok-topology-disk-tile{min-width:0;min-height:22px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-soft);color:var(--ok-muted);font-size:9px;font-weight:800;line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.ok-topology-disk-tile.is-ok{color:var(--ok-ok);background:var(--ok-ok-soft);border-color:var(--ok-ok-line)}.ok-topology-disk-tile.is-warning{color:var(--ok-warn);background:var(--ok-warn-soft);border-color:var(--ok-warn-line)}.ok-topology-disk-tile.is-problem{color:var(--ok-err);background:var(--ok-danger-soft);border-color:var(--ok-danger-line)}.ok-topology-disk-tile.is-highlight-active{--ok-widget-threshold-color: #7f0000;animation:ok-infra-device-highlight-blink 1.05s steps(1,end) infinite}.ok-topology-disk-tile.is-selected.is-highlight-active{border-color:var(--ok-accent)}.ok-topology-disk-tile.is-selected{color:var(--ok-accent);background:color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card));border-color:var(--ok-accent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-accent) 42%,transparent),0 0 12px color-mix(in srgb,var(--ok-accent) 26%,transparent)}.ok-topology-flow .react-flow__edge.ok-topology-path-edge .react-flow__edge-path{stroke:var(--ok-accent);stroke-width:3}.ok-topology-flow .react-flow__edge.ok-topology-path-edge .react-flow__edge-textbg{fill:color-mix(in srgb,var(--ok-accent) 12%,var(--ok-card))}.ok-topology-handle{width:8px;height:8px;border:1px solid var(--ok-accent-line);background:var(--ok-card)}.ok-topology-plain-handle{opacity:0;pointer-events:none}.ok-topology-port-marker{position:absolute;z-index:2;transform:translate(-50%);display:grid;justify-items:center;gap:2px;min-width:24px;pointer-events:auto;cursor:pointer}.ok-topology-port-marker.is-top{top:5px}.ok-topology-port-marker.is-bottom{bottom:5px}.ok-topology-port-marker.is-connected:before{content:"";position:absolute;left:50%;width:2px;height:9px;transform:translate(-50%);border-radius:999px;background:var(--ok-ok);pointer-events:none}.ok-topology-port-marker.is-top.is-connected:before{top:-7px}.ok-topology-port-marker.is-bottom.is-connected:before{bottom:-7px}.ok-topology-port-marker .ok-topology-port-handle{position:relative;left:auto;right:auto;top:auto;bottom:auto;transform:none;pointer-events:auto}.ok-topology-port-marker .ok-topology-port-handle-stack{position:relative;width:8px;height:8px;display:block}.ok-topology-port-marker .ok-topology-port-handle-stack .ok-topology-port-handle{position:absolute;top:0;right:0;bottom:0;left:0;transform:none}.ok-topology-port-label{max-width:32px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-muted);font-size:8px;font-weight:900;line-height:1}.ok-topology-port-marker.is-connected .ok-topology-port-label{color:var(--ok-ok)}.ok-topology-port-marker.is-connected .ok-topology-port-handle{box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-ok) 26%,transparent),0 0 7px color-mix(in srgb,var(--ok-ok) 34%,transparent)}.ok-topology-port-handle.is-ok{border-color:var(--ok-ok-line);background:var(--ok-ok)}.ok-topology-port-handle.is-warning{border-color:var(--ok-warn-line);background:var(--ok-warn)}.ok-topology-port-handle.is-problem{border-color:var(--ok-danger-line);background:var(--ok-err)}.ok-topology-port-handle.is-highlight-active{--ok-widget-threshold-color: var(--ok-err);animation:ok-topology-port-highlight-blink 1.05s steps(1,end) infinite}.ok-topology-node-type{color:var(--ok-muted);font-size:9px;font-weight:800;text-transform:uppercase}.ok-topology-node-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-ink);font-size:12px;font-weight:800}.ok-topology-status{width:fit-content;display:inline-flex;align-items:center;min-height:16px;padding:0 5px;border:1px solid var(--ok-line);border-radius:999px;color:var(--ok-muted);background:var(--ok-soft);font-size:10px;font-weight:800}.ok-topology-status.is-ok{color:var(--ok-ok);background:var(--ok-ok-soft);border-color:var(--ok-ok-line)}.ok-topology-status.is-warning{color:var(--ok-warn);background:var(--ok-warn-soft);border-color:var(--ok-warn-line)}.ok-topology-status.is-problem{color:var(--ok-err);background:var(--ok-danger-soft);border-color:var(--ok-danger-line)}.ok-topology-details{min-width:0;padding:12px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card)}.ok-topology-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--ok-line)}.ok-topology-detail-head span:first-child{display:block;color:var(--ok-muted);font-size:11px;font-weight:800;text-transform:uppercase}.ok-topology-detail-head h3{margin:2px 0 0;font-size:16px;overflow-wrap:anywhere}.ok-topology-details dl{display:grid;gap:6px;margin:10px 0}.ok-topology-details dl div{display:grid;grid-template-columns:96px minmax(0,1fr);gap:8px;padding:6px 0;border-bottom:1px solid var(--ok-table-column-line)}.ok-topology-details dt{color:var(--ok-muted);font-weight:800;text-transform:capitalize}.ok-topology-details dd{margin:0;overflow-wrap:anywhere;color:var(--ok-ink)}.ok-topology-detail-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.ok-topology-empty{display:grid;align-content:center;min-height:240px;color:var(--ok-muted)}.ok-topology-empty h3{margin:0 0 4px;color:var(--ok-ink)}.ok-topology-empty p{margin:0}@media(max-width:1100px){.ok-topology-toolbar{grid-template-columns:repeat(2,minmax(160px,1fr))}.ok-topology-shell{grid-template-columns:1fr}.ok-topology-details{min-height:220px}}.ok-button{border:1px solid var(--ok-line);color:var(--ok-button-ink);background:var(--ok-button-bg);cursor:pointer;padding:7px 10px;border-radius:4px;font-weight:600;letter-spacing:0}.ok-button:hover{background:var(--ok-button-hover)}.ok-button:disabled{opacity:.55;cursor:not-allowed}.ok-button.primary{background:var(--ok-accent);color:#fff;border-color:var(--ok-accent)}.ok-button.danger{color:var(--ok-err);border-color:var(--ok-danger-line);background:var(--ok-card)}.ok-button.compact{padding:5px 8px;font-size:12px}.ok-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.ok-modern-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.ok-action-menu{position:relative}.ok-action-menu summary{list-style:none;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--ok-line);color:var(--ok-ink);background:var(--ok-card);cursor:pointer;padding:7px 12px;border-radius:999px;font-weight:700;box-shadow:0 1px 2px #1018280d;-webkit-user-select:none;user-select:none}.ok-action-menu summary::-webkit-details-marker{display:none}.ok-action-menu summary::marker{content:""}.ok-action-menu summary:after{content:"";width:6px;height:6px;border-right:1.8px solid var(--ok-muted);border-bottom:1.8px solid var(--ok-muted);transform:translateY(-1px) rotate(45deg);transition:transform .16s ease,border-color .16s ease}.ok-action-menu[open] summary{border-color:var(--ok-focus-line);background:var(--ok-soft-2)}.ok-action-menu[open] summary:after{transform:translateY(2px) rotate(225deg);border-color:var(--ok-focus)}.ok-action-menu>div{position:absolute;right:0;top:calc(100% + 6px);z-index:20;min-width:190px;display:grid;gap:2px;padding:6px;background:var(--ok-card);border:1px solid var(--ok-line);border-radius:8px;box-shadow:0 16px 32px #10182829}.ok-action-menu button{width:100%;border:0;background:transparent;text-align:left;padding:8px 9px;border-radius:6px;cursor:pointer;color:var(--ok-ink);font-weight:600}.ok-action-menu button:hover{background:var(--ok-soft)}.ok-action-menu button:disabled{opacity:.45;cursor:not-allowed}.ok-action-menu button.danger{color:var(--ok-err)}.ok-action-menu.is-disabled summary{opacity:.45;cursor:not-allowed}.ok-input,.ok-select,.ok-textarea{width:100%;margin-top:4px;padding:7px 9px;border-radius:8px;border:1px solid var(--ok-line);background:var(--ok-input-bg);color:var(--ok-ink)}label{display:block;color:var(--ok-muted);font-size:12px;margin-bottom:8px}.ok-help{display:block;margin-top:5px;color:var(--ok-muted);font-size:11px;line-height:1.35}.ok-help.danger{color:var(--ok-danger)}.ok-test-status{border-radius:8px;padding:9px 10px;font-weight:700;border:1px solid var(--ok-line);background:var(--ok-card)}.ok-test-status.ok{color:var(--ok-ok);background:var(--ok-ok-soft);border-color:var(--ok-ok-line)}.ok-test-status.warn{color:var(--ok-warn);background:var(--ok-warn-soft);border-color:var(--ok-warn-line)}.ok-error{color:var(--ok-err);margin-top:8px}.ok-error-box{color:var(--ok-err);background:var(--ok-danger-soft);border:1px solid var(--ok-danger-line);border-radius:8px;padding:10px 12px;margin-bottom:12px;font-weight:700}.ok-success-box{color:var(--ok-ok);background:color-mix(in srgb,var(--ok-ok) 10%,var(--ok-card));border:1px solid color-mix(in srgb,var(--ok-ok) 30%,var(--ok-line));border-radius:8px;padding:10px 12px;margin-bottom:12px;font-weight:700}.ok-pill{display:inline-flex;align-items:center;border-radius:99px;padding:2px 7px;font-size:12px;border:1px solid var(--ok-line)}.ok-pill.warn{color:var(--ok-warn);background:var(--ok-warn-soft);border-color:var(--ok-warn-line)}.ok-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:end;margin-bottom:10px}.ok-form-grid.compact{grid-template-columns:repeat(4,minmax(150px,1fr));align-items:start}.ok-storage-form{grid-template-columns:minmax(240px,1.2fr) repeat(3,minmax(150px,1fr));align-items:start}.ok-harvest-form{grid-template-columns:repeat(3,minmax(170px,1fr));align-items:start}.ok-harvest-collector-config{grid-column:1 / -1;width:100%}.ok-form-wide{grid-column:1 / -1}.ok-radio-field{min-height:60px;margin:0 0 8px;border:1px solid var(--ok-line);border-radius:8px;padding:7px 9px;background:var(--ok-input-bg);color:var(--ok-ink)}.ok-radio-field legend{padding:0 4px;color:var(--ok-muted);font-size:12px}.ok-radio-field label{display:inline-flex;align-items:center;gap:5px;margin:4px 12px 0 0;color:var(--ok-ink)}.ok-checkbox-field{margin:10px 0 0;border:1px solid var(--ok-line);border-radius:8px;padding:7px 9px;background:var(--ok-input-bg);color:var(--ok-ink)}.ok-checkbox-field legend{padding:0 4px;color:var(--ok-muted);font-size:12px}.ok-checkbox-field label{display:inline-flex;align-items:center;gap:5px;margin:4px 12px 0 0;color:var(--ok-ink)}.ok-config-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.ok-config-item{display:inline-flex;align-items:center;min-height:24px;padding:2px 8px;border:1px solid var(--ok-line);border-radius:999px;background:var(--ok-soft);color:var(--ok-ink);font-weight:700}.ok-container-stack{display:inline-flex;flex-direction:column;align-items:flex-start;gap:4px;line-height:1.25}.ok-container-sub{color:var(--ok-muted);font-size:12px;padding-left:8px}.ok-harvest-table .ok-container-stack{align-items:center}.ok-form-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;margin-top:10px}.ok-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.ok-metric{display:grid;gap:3px;border:1px solid var(--ok-line);border-radius:8px;padding:10px;background:var(--ok-soft)}.ok-metric span{color:var(--ok-muted);font-size:11px;font-weight:700}.ok-metric strong{font-size:18px;color:var(--ok-ink)}.ok-metric small{color:var(--ok-muted);overflow-wrap:anywhere}.ok-raw{white-space:pre-wrap;overflow-wrap:anywhere;background:#111827;color:#e5e7eb;padding:10px;border-radius:8px;max-height:320px;overflow:auto}.ok-table-wrap{overflow:auto;border:1px solid var(--ok-line);border-radius:8px;margin-top:10px}.ok-table{width:100%;border-collapse:collapse;background:var(--ok-card);min-width:680px}.ok-table th,.ok-table td{padding:8px 9px;border-bottom:1px solid var(--ok-line);text-align:left;font-size:12px;vertical-align:middle}.ok-table th+th,.ok-table td+td{border-left:1px solid var(--ok-table-column-line)}.ok-table th{position:sticky;top:0;background:var(--ok-table-head)}.ok-pagination{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;color:var(--ok-muted);font-size:12px}.ok-pagination .ok-actions{justify-content:flex-end}.ok-pagination-controls{display:inline-flex;align-items:center;gap:4px}.ok-pagination-controls .ok-button.compact{min-width:48px;justify-content:center}.ok-storage-table th,.ok-storage-table td{text-align:center}.ok-storage-table .ok-actions{justify-content:center}.ok-harvest-table th,.ok-harvest-table td{text-align:center}.ok-harvest-table .ok-actions{justify-content:center;min-width:236px}.ok-harvest-table .ok-actions .ok-button.compact{min-width:52px;min-height:28px;display:inline-flex;align-items:center;justify-content:center;line-height:1.2;white-space:nowrap}.ok-harvest-table .ok-actions .ok-button.compact:disabled{background:var(--ok-button-bg);color:var(--ok-button-ink);border-color:var(--ok-line)}.ok-vo-storage-table th,.ok-vo-storage-table td{text-align:center}.ok-vo-storage-table th:nth-child(2),.ok-vo-storage-table td:nth-child(2),.ok-vo-storage-table th:nth-child(8),.ok-vo-storage-table td:nth-child(8){text-align:left}.ok-fpolicy-modal{width:min(1180px,calc(100vw - 40px))}.ok-fpolicy-config{display:grid;grid-template-columns:minmax(240px,1fr) 120px 140px minmax(180px,auto);gap:8px;align-items:end;margin-bottom:10px}.ok-fpolicy-fixed{min-height:52px;display:grid;align-content:center;gap:2px;border:1px solid var(--ok-line);border-radius:8px;padding:7px 9px;background:var(--ok-soft)}.ok-fpolicy-fixed span{color:var(--ok-muted);font-size:11px;font-weight:700}.ok-fpolicy-fixed strong{color:var(--ok-ink);font-size:12px}.ok-fpolicy-table th,.ok-fpolicy-table td{text-align:center}.ok-fpolicy-table th:first-child,.ok-fpolicy-table td:first-child{text-align:left}.ok-fpolicy-switch{vertical-align:middle}.ok-fpolicy-switch-text{display:inline-flex;align-items:center;min-width:56px;margin-left:6px;color:var(--ok-muted);font-size:12px;font-weight:700;vertical-align:middle}.ok-inline-actions{display:inline-flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}.ok-inline-actions form{margin:0}.ok-settings-layout{display:grid;grid-template-columns:250px minmax(0,1fr);gap:12px;align-items:start}.ok-settings-breadcrumb{margin-bottom:3px;color:var(--ok-muted);font-size:12px;font-weight:700}.ok-subnav{position:sticky;top:9px;background:var(--ok-card);border:1px solid var(--ok-line);border-radius:8px;padding:8px}.ok-subnav-section{display:grid;gap:3px;padding:4px 0 7px;border-bottom:1px solid var(--ok-line)}.ok-subnav-section:last-child{border-bottom:0;padding-bottom:0}.ok-subnav-group{display:block;padding:5px 8px 4px;color:var(--ok-muted);font-size:11px;font-weight:800;letter-spacing:0}.ok-subnav button{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;min-height:32px;background:transparent;color:var(--ok-ink)}.ok-subnav button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-subnav button small{color:var(--ok-muted);font-size:11px;font-weight:700;white-space:nowrap}.ok-subnav button.is-active,.ok-subnav button:hover{background:var(--ok-soft-2)}.ok-subnav button.is-active{color:var(--ok-accent-ink);box-shadow:inset 3px 0 0 var(--ok-focus-line)}.ok-admin-panel{display:grid;gap:12px}.ok-section-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.ok-section-toolbar h3,.ok-section-toolbar h4{margin:0}.ok-settings-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.ok-settings-overview-section{display:grid;gap:8px;min-width:0}.ok-settings-overview-section h4{margin:0;font-size:14px}.ok-settings-overview-list{display:grid;gap:6px}.ok-settings-overview-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;min-height:58px;padding:10px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-soft);color:var(--ok-ink);text-align:left;cursor:pointer}.ok-settings-overview-row:hover{border-color:var(--ok-focus-line);background:var(--ok-soft-2)}.ok-settings-overview-row span{display:grid;gap:3px;min-width:0}.ok-settings-overview-row strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-settings-overview-row small{color:var(--ok-muted);font-size:12px;line-height:1.35}.ok-settings-overview-row em{color:var(--ok-muted);font-size:12px;font-style:normal;font-weight:800;white-space:nowrap}.ok-dcim-migration-panel{display:grid;gap:10px}.ok-dcim-migration-panel.is-complete{background:color-mix(in srgb,var(--ok-ok) 7%,var(--ok-card))}.ok-dcim-migration-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.ok-dcim-migration-summary span{min-width:0;padding:9px 10px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-dcim-migration-summary b{display:block;color:var(--ok-ink);font-size:18px;line-height:1.1}.ok-dcim-migration-summary small{display:block;margin-top:3px;color:var(--ok-muted);font-size:11px;font-weight:800;text-transform:uppercase}.ok-dcim-layout{display:grid;grid-template-columns:minmax(420px,1.15fr) minmax(320px,.85fr);gap:12px;align-items:start}.ok-dcim-rack-list,.ok-dcim-rack-detail,.ok-dcim-device-list{min-width:0}.ok-dcim-asset-summary{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.ok-dcim-asset-summary span{min-width:0;display:grid;gap:3px;padding:8px 10px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-dcim-asset-summary b{color:var(--ok-ink);font-size:18px;line-height:1}.ok-dcim-asset-summary small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-muted);font-size:10px;font-weight:800;text-transform:uppercase}.ok-dcim-asset-heading{display:flex;flex-wrap:wrap;align-items:center;gap:10px;min-width:0}.ok-dcim-asset-search{min-width:280px;display:grid;grid-template-columns:auto minmax(220px,340px);align-items:center;gap:7px;margin:0}.ok-dcim-asset-search span{color:var(--ok-muted);font-size:11px;font-weight:800}.ok-dcim-asset-search .ok-input{margin-top:0;min-height:31px}.ok-dcim-editor{display:grid;gap:10px}.ok-dcim-editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:start}.ok-check{min-height:34px;display:flex;align-items:center;gap:6px;margin-top:18px;color:var(--ok-ink);font-weight:800}.ok-check input{margin:0}.ok-table tr.is-selected td{background:color-mix(in srgb,var(--ok-accent) 9%,var(--ok-card))}.ok-table tbody tr[onclick]{cursor:pointer}.ok-table-subtext{display:block;margin-top:2px;color:var(--ok-muted);font-size:11px;line-height:1.2}.ok-dcim-multivalue{display:grid;gap:2px;min-width:0}.ok-dcim-multivalue span{min-width:0;overflow-wrap:anywhere;line-height:1.25}.ok-dcim-action-list{display:grid;gap:5px;justify-items:center;align-items:center;min-width:0}.ok-dcim-action-list .ok-button.compact{width:78px;min-height:26px;padding-left:4px;padding-right:4px;font-size:11px;white-space:nowrap}.ok-dcim-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.ok-dcim-detail-grid span{min-width:0;display:grid;gap:2px;padding:8px 9px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-dcim-detail-grid b{color:var(--ok-muted);font-size:10px;text-transform:uppercase}.ok-dcim-detail-grid em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-ink);font-style:normal;font-weight:800}.ok-dcim-rack-units{display:grid;grid-template-rows:repeat(var(--ok-dcim-rack-units, 42),minmax(18px,1fr));gap:2px;max-height:680px;overflow:auto;padding:4px;border:1px solid var(--ok-line);border-radius:7px;background:var(--ok-soft)}.ok-dcim-rack-units span{min-width:0;display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:6px;min-height:18px;padding:2px 6px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-card);color:var(--ok-muted)}.ok-dcim-rack-units span.is-controller{border-color:color-mix(in srgb,var(--ok-accent) 48%,var(--ok-line));background:color-mix(in srgb,var(--ok-accent) 10%,var(--ok-card));color:var(--ok-accent-ink)}.ok-dcim-rack-units span.is-shelf{border-color:color-mix(in srgb,var(--ok-ok) 38%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 8%,var(--ok-card));color:var(--ok-ink)}.ok-dcim-rack-units b{font-size:10px}.ok-dcim-rack-units em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:normal;font-size:11px;font-weight:800}.ok-dcim-component-cell{width:auto;max-width:none;min-width:0}.ok-dcim-asset-table{width:100%;table-layout:fixed;min-width:0}.ok-dcim-asset-table th,.ok-dcim-asset-table td{min-width:0;padding-left:5px;padding-right:5px;overflow:hidden;text-align:center;text-overflow:ellipsis}.ok-dcim-asset-table strong,.ok-dcim-asset-table small{min-width:0}.ok-dcim-asset-table .ok-table-subtext{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-dcim-asset-table .ok-dcim-multivalue{justify-items:center}.ok-dcim-col-device{width:11.5%}.ok-dcim-col-location{width:6.5%}.ok-dcim-col-rack{width:5%}.ok-dcim-col-unit{width:4.5%}.ok-dcim-col-type{width:8%}.ok-dcim-col-serial{width:7.5%}.ok-dcim-col-version{width:6.5%}.ok-dcim-col-mount,.ok-dcim-col-state{width:5.5%}.ok-dcim-col-component{width:18%}.ok-dcim-col-link{width:15%}.ok-dcim-col-action{width:6.5%}.ok-dcim-link-list,.ok-dcim-component-list{display:flex;flex-wrap:wrap;gap:4px;min-width:0}.ok-dcim-component-list{max-width:100%;justify-content:center;overflow:hidden}.ok-dcim-link-cell .ok-dcim-link-list{max-width:100%;justify-content:center;margin:0 auto;overflow:visible}.ok-dcim-link-list span,.ok-dcim-component-list span{max-width:260px;min-width:0;display:inline-grid;grid-template-columns:auto minmax(0,1fr) auto;gap:4px;align-items:center;padding:2px 6px;border:1px solid var(--ok-line);border-radius:999px;background:var(--ok-soft)}.ok-dcim-link-cell .ok-dcim-link-list span{max-width:100%;white-space:normal}.ok-dcim-link-cell .ok-dcim-link-list em{overflow:visible;text-overflow:clip;white-space:normal;overflow-wrap:anywhere;line-height:1.25}.ok-dcim-component-list span{max-width:112px}.ok-dcim-component-list span.is-problem{border-color:var(--ok-danger-line);background:var(--ok-danger-soft)}.ok-dcim-component-list span.is-problem b,.ok-dcim-component-list span.is-problem em{color:var(--ok-err)}.ok-dcim-component-list span.is-warning,.ok-dcim-component-list span.is-override{border-color:var(--ok-warn-line);background:var(--ok-warn-soft)}.ok-dcim-component-list span.is-warning b,.ok-dcim-component-list span.is-warning em,.ok-dcim-component-list span.is-override b,.ok-dcim-component-list span.is-override em{color:var(--ok-warn)}.ok-dcim-link-list b,.ok-dcim-component-list b{color:var(--ok-accent-ink);font-size:10px;text-transform:uppercase}.ok-dcim-link-list em,.ok-dcim-component-list em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-muted);font-style:normal;font-size:10px}.ok-infra-device-preview-actions{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;gap:6px;min-width:0}.ok-infra-device-type-card{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:8px}.ok-infra-device-type-card span{min-width:0;display:grid;gap:2px;padding:7px 8px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-infra-device-type-card b{color:var(--ok-muted);font-size:10px;text-transform:uppercase}.ok-infra-device-type-card em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-ink);font-style:normal;font-weight:800}.ok-license-panel{gap:12px}.ok-license-alert{padding:10px 12px;border:1px solid var(--ok-warn-line);border-radius:8px;background:var(--ok-warn-soft);color:var(--ok-warn);font-size:13px;font-weight:700;line-height:1.45}.ok-license-alert.is-danger{border-color:var(--ok-danger-line);background:var(--ok-danger-soft);color:var(--ok-err)}.ok-license-alert.is-dev{border-color:var(--ok-accent-line);background:var(--ok-accent-soft);color:var(--ok-accent-ink)}.ok-advanced-panel summary{cursor:pointer;color:var(--ok-muted);font-size:13px;font-weight:800}.ok-advanced-panel[open] summary{margin-bottom:10px;color:var(--ok-ink)}.ok-license-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:4px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-soft)}.ok-license-tabs button{border:1px solid transparent;border-radius:6px;padding:7px 11px;background:transparent;color:var(--ok-muted);font-weight:800;cursor:pointer}.ok-license-tabs button.is-active{border-color:var(--ok-accent-line);background:var(--ok-card);color:var(--ok-accent-ink)}.ok-license-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.ok-license-summary>div{min-width:0;padding:10px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-soft)}.ok-license-summary span{display:block;color:var(--ok-muted);font-size:12px;font-weight:700}.ok-license-summary strong{display:block;margin-top:4px;color:var(--ok-ink);overflow-wrap:anywhere}.ok-license-summary small{display:block;margin-top:2px;color:var(--ok-muted);font-size:12px;font-weight:700}.ok-license-feature-cell{grid-column:span 2}.ok-license-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:7px;margin-top:7px}.ok-license-feature-chip{min-width:0;display:grid;gap:2px;padding:8px 9px;border:1px solid var(--ok-accent-line);border-radius:8px;background:var(--ok-accent-soft)}.ok-license-feature-chip strong{margin:0;color:var(--ok-accent-ink);font-size:13px;line-height:1.2}.ok-license-feature-chip small{margin:0;color:var(--ok-muted);font-size:11px;line-height:1.35}.ok-license-danger{border-color:var(--ok-danger-line);background:var(--ok-danger-soft)}.ok-license-delete-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:end}.ok-license-audit-filters,.ok-audit-filters{display:grid;grid-template-columns:repeat(6,minmax(120px,1fr));gap:8px;margin-bottom:10px;align-items:end}.ok-audit-filters .ok-actions{align-self:end}.ok-license-rotation{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.ok-license-rotation h4{margin:0}.ok-license-fingerprint{display:grid;grid-template-columns:minmax(0,2fr) minmax(120px,1fr);gap:8px;margin-bottom:10px}.ok-license-fingerprint>div{min-width:0;padding:10px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card)}.ok-license-fingerprint span{display:block;color:var(--ok-muted);font-size:12px;font-weight:700}.ok-license-fingerprint strong{display:block;margin-top:4px;color:var(--ok-ink);overflow-wrap:anywhere}.ok-license-textarea{min-height:150px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;line-height:1.45}.ok-license-code{white-space:pre-wrap;overflow-wrap:anywhere}.ok-editor-panel{border:1px solid var(--ok-line);border-radius:8px;padding:12px;background:var(--ok-soft)}.ok-editor-panel.emphasis{background:var(--ok-soft-2);border-color:#4c6f9e}.ok-chip-list{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 8px}.ok-chip-list.compact{margin:0}.ok-chip,.ok-chip-check span{display:inline-flex;align-items:center;min-height:24px;border:1px solid var(--ok-line);border-radius:999px;padding:3px 8px;background:var(--ok-card);color:var(--ok-ink);font-size:12px}.ok-chip-check{margin:0;cursor:pointer}.ok-chip-check.is-disabled{opacity:.58;cursor:not-allowed}.ok-chip-check input{position:absolute;opacity:0;pointer-events:none}.ok-chip-check input:checked+span{color:var(--ok-accent-ink);background:var(--ok-accent-soft);border-color:var(--ok-focus-line)}.ok-badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 7px;border:1px solid var(--ok-line);background:var(--ok-card);font-size:12px;white-space:nowrap}.ok-badge.ok{color:var(--ok-ok);background:var(--ok-ok-soft);border-color:var(--ok-ok-line)}.ok-badge.warn{color:var(--ok-warn);background:var(--ok-warn-soft);border-color:var(--ok-warn-line)}.ok-badge.danger{color:var(--ok-err);background:var(--ok-danger-soft);border-color:var(--ok-danger-line)}.ok-badge.accent{color:var(--ok-accent-ink);background:var(--ok-accent-soft);border-color:var(--ok-accent-line)}.ok-permission-table{min-width:760px}.ok-permission-table th:not(:first-child),.ok-permission-table td:not(:first-child){text-align:center}.ok-permission-table tr.is-group td{background:var(--ok-soft);font-weight:800}.ok-permission-table tr.is-header td:not(:first-child){font-weight:600;text-align:left}.ok-permission-table tr.is-child td:first-child{padding-left:28px;position:relative}.ok-permission-table tr.is-child td:first-child:before{content:"";position:absolute;left:13px;top:50%;width:8px;height:1px;background:var(--ok-muted);opacity:.75}.ok-permission-detail{display:block;margin-top:3px;color:var(--ok-muted);font-size:12px;font-weight:600}.ok-switch{display:inline-flex;margin:0;cursor:pointer}.ok-switch input{position:absolute;opacity:0;pointer-events:none}.ok-switch span{width:34px;height:20px;border-radius:999px;border:1px solid var(--ok-line);background:var(--ok-switch-bg);position:relative;transition:.15s ease}.ok-switch span:after{content:"";position:absolute;width:14px;height:14px;border-radius:999px;background:var(--ok-switch-knob);left:2px;top:2px;box-shadow:0 1px 2px #10182833;transition:.15s ease}.ok-switch input:checked+span{background:var(--ok-accent);border-color:var(--ok-accent)}.ok-switch input:checked+span:after{transform:translate(14px)}.ok-dashboard-head{position:sticky;top:0;z-index:30;display:grid;gap:5px;margin:-9px -9px 0;padding:9px 9px 6px;background:var(--ok-card)}.ok-dashboard-head.has-widget-options{padding-right:329px}.ok-dashboard-topline{min-height:24px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;min-width:0}.ok-dashboard-head .ok-modern-actions{min-height:24px;align-items:center;padding-top:0}.ok-dashboard-head .ok-modern-actions>.ok-button,.ok-dashboard-head .ok-action-menu summary{min-height:24px;padding:3px 8px;border-radius:4px;font-size:12px;line-height:1.2}.ok-dashboard-title-line{flex:1 1 auto;min-height:24px;display:flex;flex-wrap:nowrap;align-items:center;gap:6px;min-width:0}.ok-dashboard-title-line h2{min-width:0;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:24px;font-size:16px}.ok-dashboard-title-line .ok-pill,.ok-dashboard-title-line .ok-badge{min-height:20px;padding:0 6px;font-size:11px;line-height:18px;transform:translateY(-1px)}.ok-dashboard-filterbar{width:100%;display:flex;flex-wrap:wrap;gap:6px;align-items:center}.ok-dashboard-main-filters{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-width:0}.ok-dashboard-time-controls{position:relative;margin-left:auto;display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-end}.ok-dashboard-time-controls>.ok-button{min-height:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:4px;font-size:12px;line-height:1.2}.ok-dashboard-filterbar label{display:flex;align-items:center;gap:5px;margin:0;color:var(--ok-muted);font-size:11px;font-weight:700}.ok-dashboard-filterbar .ok-select{width:auto;min-width:110px;min-height:28px;margin-top:0;padding:4px 26px 4px 8px;border-radius:4px;font-size:12px;background-color:var(--ok-card)}.ok-time-picker{position:relative}.ok-time-range-group{display:inline-flex;align-items:center}.ok-time-range-group .ok-button{min-height:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:4px;font-size:12px;line-height:1.2}.ok-time-range-button{min-width:116px;border-left:0;border-right:0;border-radius:0!important}.ok-time-shift-button{min-width:34px}.ok-time-shift-button:first-child{border-top-right-radius:0!important;border-bottom-right-radius:0!important}.ok-time-shift-button:last-child{border-top-left-radius:0!important;border-bottom-left-radius:0!important}.ok-refresh-menu summary{min-width:72px;justify-content:space-between}.ok-refresh-menu>div{min-width:92px}.ok-time-popover{position:absolute;right:0;top:calc(100% + 6px);z-index:35;width:min(520px,calc(100vw - 40px));display:grid;grid-template-columns:minmax(210px,.9fr) minmax(180px,1fr);gap:10px;padding:10px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card);box-shadow:0 18px 42px #1018282e}.ok-time-absolute{display:grid;gap:8px;align-content:start;padding-right:10px;border-right:1px solid var(--ok-line)}.ok-time-absolute strong{font-size:12px;color:var(--ok-ink)}.ok-time-absolute label{display:grid;align-items:start;gap:3px}.ok-time-absolute .ok-input{margin:0;min-height:30px;border-radius:4px;font-size:12px}.ok-time-manual-row{display:grid;grid-template-columns:minmax(0,1fr) 86px;gap:6px}.ok-time-quick-list{display:grid;gap:2px;max-height:330px;overflow:auto}.ok-time-quick-list button{border:0;border-radius:4px;background:transparent;color:var(--ok-ink);padding:6px 8px;text-align:left;cursor:pointer;font-size:12px}.ok-time-quick-list button:hover{background:var(--ok-soft)}.ok-dashboard-selector.modern{display:grid;gap:12px}.ok-dashboard-meta{flex:0 0 auto;display:flex;flex-wrap:nowrap;gap:6px;justify-content:flex-start}.ok-dashboard-picker{display:grid;grid-template-columns:minmax(220px,360px) auto;gap:10px;align-items:end}.ok-dashboard-picker label{margin:0}.ok-dashboard-message{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.ok-dashboard-message p{margin:0}.ok-dashboard-browser{display:grid;gap:12px}.ok-browser-create{display:grid;grid-template-columns:minmax(180px,260px) minmax(220px,1fr) auto;gap:8px;align-items:end;padding:10px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-soft)}.ok-browser-create .ok-input{margin:0}.ok-browser-grid{display:grid;gap:6px}.ok-browser-row{min-height:46px;display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:8px;align-items:center;padding:7px 8px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-card)}.ok-browser-main{min-width:0;display:grid;gap:2px;border:0;background:transparent;color:var(--ok-ink);text-align:left;cursor:pointer}.ok-browser-main strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.ok-browser-main span{color:var(--ok-muted);font-size:11px}.ok-browser-sort{display:flex;gap:4px;align-items:center}.ok-browser-move{width:180px;margin:0;border-radius:4px;font-size:12px}.ok-dashboard-form{display:grid;gap:10px}.ok-dashboard-settings-panel{gap:8px}.ok-dashboard-settings-panel .ok-section-toolbar{align-items:center}.ok-dashboard-settings-layout{display:grid;grid-template-columns:minmax(220px,22%) minmax(140px,.45fr) minmax(340px,1.05fr) minmax(420px,1.5fr);gap:8px;align-items:stretch}.ok-dashboard-settings-fields{display:grid;gap:6px;align-content:start}.ok-dashboard-settings-fields label{margin:0}.ok-dashboard-settings-fields .ok-input{width:100%;min-height:32px;margin-top:0;padding-top:6px;padding-bottom:6px}.ok-subdashboard-settings{display:grid;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--ok-line)}.ok-subdashboard-list{display:grid;gap:6px}.ok-subdashboard-item{display:grid;grid-template-columns:minmax(120px,.7fr) minmax(160px,1fr) auto auto;gap:6px;align-items:center;padding:6px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-card)}.ok-subdashboard-item.is-active{border-color:var(--ok-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 16%,transparent)}.ok-subdashboard-item .ok-input{margin:0;min-height:28px;padding-top:4px;padding-bottom:4px;border-radius:4px}.ok-dashboard-filter-defaults{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;align-content:start}.ok-dashboard-filter-defaults label{margin:0}.ok-dashboard-filter-defaults .ok-select{min-height:30px;margin-top:2px;padding:5px 7px}.ok-dashboard-datasources{margin:0;min-height:70px}.ok-dashboard-datasource-field,.ok-dashboard-filter-field{align-content:start;text-align:left}.ok-dashboard-filter-field{max-height:96px;overflow-y:auto;scrollbar-gutter:stable}.ok-dashboard-filter-field label{min-width:92px}.ok-dashboard-surface{min-width:0;margin:0 -9px;padding:0;background:var(--ok-card)}.ok-dashboard-surface.has-widget-options{padding-right:320px}.ok-dashboard-surface .ok-rgl{padding:0}.ok-dashboard-workspace{position:relative;min-width:0;display:grid;grid-template-columns:minmax(0,1fr);gap:8px;align-items:start}.ok-dashboard-workspace.has-infra-detail-view .ok-rgl{visibility:hidden;pointer-events:none}.ok-rgl{min-height:320px}.ok-rgl .react-grid-item{transition:none!important}.ok-rgl.is-editing{background-image:linear-gradient(var(--ok-line) 1px,transparent 1px),linear-gradient(90deg,var(--ok-line) 1px,transparent 1px);background-size:24px 24px;border:1px dashed var(--ok-line);border-radius:8px}.react-grid-item.react-grid-placeholder{background:#0f62fe2e;border-radius:8px}.react-resizable-handle:after{border-right-color:var(--ok-accent);border-bottom-color:var(--ok-accent)}.ok-widget-panel{min-width:0}.ok-widget-row{height:100%;min-height:0;display:grid;grid-template-columns:18px auto minmax(0,1fr);gap:7px;align-items:center;color:var(--ok-ink);cursor:default;padding:0 2px}.ok-widget-row.is-editing{cursor:pointer}.ok-widget-row.is-selected{outline:2px solid rgba(15,98,254,.28);outline-offset:-2px;border-radius:6px}.ok-widget-row h3{margin:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:800;letter-spacing:0;color:var(--ok-ink);line-height:1}.ok-widget-row-rule{height:0;border-top:1px dashed var(--ok-line)}.ok-widget-row:after{content:"";height:0;border-top:1px dashed var(--ok-line)}.ok-widget-card{position:relative;height:100%;min-height:0;background:var(--ok-card);border:1px solid var(--ok-line);border-radius:8px;padding:5px;overflow:hidden;box-shadow:0 1px 2px #1018280d}.ok-widget-card.is-editing{cursor:pointer}.ok-widget-card.is-selected{border-color:var(--ok-accent);box-shadow:0 0 0 2px #0f62fe24,0 1px 2px #1018280d}.ok-widget-card.is-threshold-active{border-color:var(--ok-widget-threshold-color);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color) 74%,transparent),0 0 0 3px color-mix(in srgb,var(--ok-widget-threshold-color) 20%,transparent),0 10px 22px color-mix(in srgb,var(--ok-widget-threshold-color) 20%,transparent)}.ok-widget-card.is-threshold-active:before{content:"";position:absolute;left:0;right:0;top:0;height:28px;border-bottom:1px solid color-mix(in srgb,var(--ok-widget-threshold-color) 30%,transparent);background:linear-gradient(180deg,color-mix(in srgb,var(--ok-widget-threshold-color) 24%,transparent),color-mix(in srgb,var(--ok-widget-threshold-color) 12%,transparent) 68%,transparent);pointer-events:none}.ok-widget-card.is-threshold-active header{position:relative;z-index:1}.ok-widget-card.is-threshold-active h3:before{content:"";display:inline-block;width:7px;height:7px;margin-right:6px;border-radius:50%;background:var(--ok-widget-threshold-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--ok-widget-threshold-color) 20%,transparent);vertical-align:1px}.ok-widget-card.is-highlight-active,.ok-widget-card:has(.ok-infra-widget.ok-infra-rack.is-highlight-active){--ok-widget-threshold-color: var(--ok-err);border-color:var(--ok-widget-threshold-color);animation:ok-card-highlight-pulse 2.1s ease-in-out infinite}.ok-widget-card:has(.ok-infra-widget.ok-infra-rack.is-highlight-active){animation-name:ok-rack-card-highlight-pulse}.ok-widget-card header{display:flex;justify-content:space-between;gap:6px;align-items:start}.ok-widget-card:not(.is-editing) header[title="랙 상세"]{cursor:pointer}.ok-widget-card h3{margin:0;font-size:13px}.ok-button.compact.ok-infra-face-toggle{min-height:16px;height:16px;padding:0 6px;font-size:10px;line-height:1;border-radius:3px}.ok-infra-widget{height:calc(100% - 26px);min-height:46px;display:grid;place-items:center;overflow:hidden;border:1px solid var(--ok-line);border-radius:6px;background:linear-gradient(180deg,var(--ok-soft),var(--ok-card))}.ok-infra-detail-rack-card.is-highlight-active{--ok-widget-threshold-color: var(--ok-err);border-color:var(--ok-widget-threshold-color);animation:ok-rack-card-highlight-pulse 2.1s ease-in-out infinite}.ok-infra-rack{grid-template-columns:12px minmax(0,1fr) 12px;grid-template-rows:minmax(0,1fr);column-gap:2px;row-gap:0;padding:8px 4px 0}.ok-infra-detail-view{position:absolute;top:0;right:0;bottom:0;left:0;z-index:12;display:grid;grid-template-columns:max-content minmax(0,1fr);gap:8px;align-items:start;background:var(--ok-bg)}.ok-infra-detail-racks{min-height:0;display:grid;grid-template-columns:repeat(2,var(--ok-infra-rack-detail-width, 240px));gap:6px;align-items:start}.ok-infra-detail-rack-card{height:auto;padding:5px}.ok-infra-detail-rack-card header{min-height:18px;align-items:center;cursor:pointer}.ok-infra-detail-rack-card .ok-button.compact{min-height:18px;padding:1px 6px;font-size:10px;line-height:1}.ok-infra-detail-rack-frame{height:calc(var(--ok-infra-rack-unit-height, 10px) * var(--ok-rack-slots, 42));min-height:0;display:grid;grid-template-columns:12px minmax(0,1fr) 12px;grid-template-rows:minmax(0,1fr);column-gap:2px;padding:4px 0 0}.ok-infra-rack-units{height:100%;display:grid;grid-template-rows:repeat(var(--ok-rack-slots, 42),minmax(4px,1fr));color:var(--ok-muted);font-size:8px;line-height:1;text-align:center;-webkit-user-select:none;user-select:none}.ok-infra-rack-units span{min-height:0;display:grid;place-items:center;border-radius:2px}.ok-infra-rack.is-selected .ok-infra-rack-units{color:var(--ok-accent)}.ok-infra-rack.is-selected .ok-infra-rack-units span{background:color-mix(in srgb,var(--ok-accent) 10%,transparent)}.ok-infra-rack-body{position:relative;width:100%;height:100%;display:grid;grid-template-rows:repeat(var(--ok-rack-slots, 42),minmax(4px,1fr));gap:0;padding:0;border:1px solid #cbd5e1;border-radius:6px;background:#f8fafc;overflow:hidden}.ok-infra-rack-body.is-selected{border-color:var(--ok-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent)}.ok-infra-rack-unit{grid-column:1;min-height:0;border:0;border-top:1px solid #d6dee9;border-radius:0;background:transparent;box-shadow:none}.ok-infra-rack-unit:first-child{border-top:0}.ok-infra-rack-unit:hover{background:#eff6ff}.ok-infra-rack-device{grid-column:1;z-index:2;min-height:0;display:grid;align-content:stretch;gap:1px;padding:3px 6px;border:1px solid #7fb2f0;border-radius:4px;cursor:grab;overflow:hidden;box-shadow:0 4px 10px #10182824}.ok-infra-rack-device.is-selected{border-color:var(--ok-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 28%,transparent),0 6px 14px #1018282e}.ok-infra-rack-device strong,.ok-infra-rack-device small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-rack-device strong{color:var(--ok-ink);font-size:11px;line-height:1.05}.ok-infra-rack-device small{color:var(--ok-muted);font-size:9px;line-height:1}.ok-infra-rack-device.is-controller{padding:3px;background:color-mix(in srgb,var(--ok-accent) 16%,var(--ok-card));border-color:#2f7bd4;border-width:1px}.ok-infra-rack-device.is-shelf{padding:3px;background:color-mix(in srgb,var(--ok-accent) 9%,var(--ok-card));border-color:#78adef}.ok-infra-rack-device.is-back.is-controller,.ok-infra-rack-device.is-back.is-shelf{padding:.75px}.ok-infra-rack-device.is-highlight-active{--ok-widget-threshold-color: #7f0000;animation:ok-infra-device-highlight-blink 1.05s steps(1,end) infinite}:root[data-theme=dark] .ok-infra-rack-device.is-highlight-active{--ok-widget-threshold-color: #ff3b30}:root[data-theme=dark] .ok-topology-disk-tile.is-highlight-active{--ok-widget-threshold-color: #ff3b30}.ok-infra-device-preview{min-width:0;min-height:0;width:100%;display:grid;grid-template-rows:auto calc(var(--ok-infra-preview-units, 2) * 80px) auto auto;gap:5px;align-self:start;height:auto;padding:7px;border:1px solid #7fb2f0;border-radius:6px;background:color-mix(in srgb,var(--ok-accent) 7%,var(--ok-card));overflow:hidden}.ok-infra-rack-detail-preview{min-width:0;width:100%;display:grid;align-self:start;gap:8px;padding:8px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-infra-device-preview.is-back{padding:2px}.ok-infra-device-preview.is-controller{border-color:#2f7bd4;border-width:2px;background:color-mix(in srgb,var(--ok-accent) 13%,var(--ok-card))}.ok-infra-device-preview-head{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.ok-infra-device-preview-head strong,.ok-infra-device-preview-head .ok-infra-device-title,.ok-infra-device-preview-head span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-device-preview-head strong,.ok-infra-device-preview-head .ok-infra-device-title{color:var(--ok-ink);font-size:12px;line-height:1.15}.ok-infra-device-title{flex:1 1 auto;border:0;padding:0;background:transparent;text-align:left;font-weight:800;cursor:pointer}.ok-infra-device-title:hover{color:var(--ok-accent-ink);text-decoration:underline}.ok-infra-device-preview-head span{flex:0 0 auto;color:var(--ok-muted);font-size:10px}.ok-infra-device-preview-head .ok-button.compact{min-height:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;padding:0 6px;font-size:10px;line-height:1;border-radius:3px;text-decoration:none;white-space:nowrap}.ok-infra-device-preview-face{min-width:0;min-height:0;display:grid;align-items:stretch}.ok-infra-device-preview-face.has-part-strip{grid-template-rows:minmax(0,1fr) 18px;gap:4px}.ok-infra-device-preview-face .ok-infra-controller-rack-face,.ok-infra-device-preview-face .ok-infra-shelf-slots{height:100%}.ok-infra-device-preview-meta{display:flex;flex-wrap:wrap;gap:4px;min-width:0;color:var(--ok-muted);font-size:10px}.ok-infra-device-preview-meta span{min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:1px 5px;border:1px solid var(--ok-line);border-radius:999px;background:var(--ok-soft)}.ok-infra-detail-info{min-width:0;display:grid;gap:5px;padding:6px;border:1px solid var(--ok-line);border-radius:5px;background:var(--ok-card)}.ok-infra-detail-info-head{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--ok-muted);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0}.ok-infra-detail-info-head strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-monitor-switch{flex:0 0 auto;width:32px;height:18px;position:relative;padding:0;border:1px solid color-mix(in srgb,var(--ok-ok) 58%,var(--ok-line));border-radius:999px;background:color-mix(in srgb,var(--ok-ok) 18%,var(--ok-card));cursor:pointer;transition:background .16s ease,border-color .16s ease}.ok-infra-monitor-switch span{position:absolute;top:2px;left:16px;width:12px;height:12px;border-radius:50%;background:color-mix(in srgb,var(--ok-ok) 82%,white);box-shadow:0 1px 2px #00000038;transition:left .16s ease,background .16s ease}.ok-infra-monitor-switch.is-off{border-color:color-mix(in srgb,var(--ok-muted) 48%,var(--ok-line));background:color-mix(in srgb,var(--ok-muted) 14%,var(--ok-card))}.ok-infra-monitor-switch.is-off span{left:2px;background:color-mix(in srgb,var(--ok-muted) 62%,white)}.ok-infra-detail-empty{min-height:46px;display:grid;place-items:center;padding:10px;border:1px dashed var(--ok-line);border-radius:5px;color:var(--ok-muted);font-size:11px;background:var(--ok-soft)}.ok-infra-fan-strip{min-width:0;display:flex;gap:4px;align-items:stretch;overflow:hidden}.ok-infra-fan-strip button{min-width:22px;height:18px;padding:0 5px;border:1px solid var(--ok-line);border-radius:3px;background:var(--ok-soft);color:var(--ok-ink);font-size:9px;line-height:1;cursor:pointer}.ok-infra-fan-strip button.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 64%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 18%,var(--ok-card))}.ok-infra-fan-strip button.is-failed{border-color:color-mix(in srgb,var(--ok-err) 78%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 34%,var(--ok-card))}.ok-infra-fan-strip button.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px}.ok-infra-detail-info-grid{min-width:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px}.ok-infra-info-tile{min-width:0;display:grid;gap:1px;padding:5px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-soft)}.ok-infra-info-tile b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-muted);font-size:9px;line-height:1.1}.ok-infra-info-tile em{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-ink);font-style:normal;font-size:11px;line-height:1.1}.ok-infra-info-tile.ok{border-color:color-mix(in srgb,var(--ok-ok) 50%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 10%,var(--ok-card))}.ok-infra-info-tile.fail{border-color:color-mix(in srgb,var(--ok-err) 58%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 10%,var(--ok-card))}.ok-infra-detail-list{min-width:0;display:grid;gap:3px;overflow:visible}.ok-infra-detail-section{margin-top:5px;padding-top:5px;border-top:1px dashed var(--ok-line);color:var(--ok-muted);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0}.ok-infra-detail-row{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;align-items:center;gap:6px;min-height:20px;padding:3px 5px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-soft);font-size:10px}.ok-infra-detail-row b,.ok-infra-detail-row em{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-detail-row b{color:var(--ok-ink)}.ok-infra-detail-row em{color:var(--ok-muted);font-style:normal}.ok-infra-detail-row i{font-style:normal;font-weight:700}.ok-infra-detail-row.ok i{color:var(--ok-ok)}.ok-infra-detail-row.fail{border-color:color-mix(in srgb,var(--ok-err) 48%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 9%,var(--ok-card))}.ok-infra-detail-row.fail i{color:var(--ok-err)}.ok-infra-detail-row.note i{color:var(--ok-muted);font-weight:600}.ok-infra-detail-table{min-width:0;overflow-x:auto;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-soft)}.ok-infra-detail-table table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:10px}.ok-infra-detail-table th,.ok-infra-detail-table td{min-width:0;padding:3px 5px;border-bottom:1px solid var(--ok-line);color:var(--ok-muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ok-infra-detail-table th{color:var(--ok-ink);font-weight:800;background:var(--ok-card)}.ok-infra-detail-table th:first-child,.ok-infra-detail-table td:first-child{width:28%;text-align:left;color:var(--ok-ink)}.ok-infra-detail-table tr:last-child td{border-bottom:0}.ok-infra-detail-table tr.fail td{background:color-mix(in srgb,var(--ok-err) 9%,var(--ok-card));color:var(--ok-err)}.ok-infra-controller-rack-face{width:100%;height:100%;min-height:0;display:grid;align-items:stretch}.ok-infra-controller-rack-face.is-fas8020{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;padding:3px}.ok-infra-controller-rack-face.is-fas8300{grid-template-columns:repeat(4,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));gap:4px;padding:3px}.ok-infra-controller-rack-face.is-aff-a1k{grid-template-columns:repeat(5,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));gap:4px;padding:3px}.ok-infra-controller-rack-face.is-fas8020 span,.ok-infra-controller-rack-face.is-fas8300 span,.ok-infra-controller-rack-face.is-aff-a1k span{min-width:0;min-height:0;position:relative;border:1px solid color-mix(in srgb,var(--ok-ok) 58%,var(--ok-line));border-radius:4px;background:color-mix(in srgb,var(--ok-ok) 12%,var(--ok-card));box-shadow:inset 0 0 0 1px #ffffff4d}.ok-infra-controller-rack-face.is-fas8020 span.is-ok,.ok-infra-controller-rack-face.is-fas8300 span.is-ok,.ok-infra-controller-rack-face.is-aff-a1k span.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-controller-rack-face.is-fas8020 span.is-failed,.ok-infra-controller-rack-face.is-fas8300 span.is-failed,.ok-infra-controller-rack-face.is-aff-a1k span.is-failed{border-color:color-mix(in srgb,var(--ok-err) 62%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 13%,var(--ok-card))}.ok-infra-controller-rack-face.is-fas8020 span.is-disabled,.ok-infra-controller-rack-face.is-fas8300 span.is-disabled,.ok-infra-controller-rack-face.is-aff-a1k span.is-disabled{border-color:color-mix(in srgb,var(--ok-muted) 48%,var(--ok-line));background:color-mix(in srgb,var(--ok-muted) 9%,var(--ok-card))}.ok-infra-device-preview .ok-infra-controller-rack-face.is-fas8020 span,.ok-infra-device-preview .ok-infra-controller-rack-face.is-fas8300 span,.ok-infra-device-preview .ok-infra-controller-rack-face.is-aff-a1k span{cursor:pointer}.ok-infra-controller-rack-face.is-fas8020 span.is-selected,.ok-infra-controller-rack-face.is-fas8300 span.is-selected,.ok-infra-controller-rack-face.is-aff-a1k span.is-selected,.ok-infra-shelf-slots span.is-selected,.ok-infra-shelf-back-module.is-selected,.ok-infra-shelf-back-ports i.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-controller-rack-face.is-fas8020 span:before,.ok-infra-controller-rack-face.is-fas8300 span:before,.ok-infra-controller-rack-face.is-aff-a1k span:before{content:"";position:absolute;left:50%;top:50%;width:auto;height:min(86%,calc(100% - 4px));max-width:calc(100% - 4px);aspect-ratio:1;transform:translate(-50%,-50%);border:1px solid color-mix(in srgb,var(--ok-ok) 68%,var(--ok-line));border-radius:50%;background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--ok-card) 80%,var(--ok-ok)) 0 18%,transparent 19%),conic-gradient(from 24deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 0 20deg,transparent 21deg 70deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 71deg 110deg,transparent 111deg 160deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 161deg 200deg,transparent 201deg 250deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 251deg 290deg,transparent 291deg 360deg);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-ok) 16%,transparent)}.ok-infra-controller-rack-face.is-fas8020 span:after,.ok-infra-controller-rack-face.is-fas8300 span:after,.ok-infra-controller-rack-face.is-aff-a1k span:after{content:"";position:absolute;left:50%;top:50%;width:min(18%,12px);min-width:3px;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;background:color-mix(in srgb,var(--ok-ok) 78%,var(--ok-card));box-shadow:0 0 0 1px color-mix(in srgb,var(--ok-card) 76%,var(--ok-ok))}.ok-infra-controller-rack-face.is-fas8020 span.is-failed:before,.ok-infra-controller-rack-face.is-fas8300 span.is-failed:before,.ok-infra-controller-rack-face.is-aff-a1k span.is-failed:before{border-color:color-mix(in srgb,var(--ok-err) 68%,var(--ok-line));background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--ok-card) 82%,var(--ok-err)) 0 18%,transparent 19%),conic-gradient(from 24deg,color-mix(in srgb,var(--ok-err) 72%,var(--ok-ink)) 0 20deg,transparent 21deg 70deg,color-mix(in srgb,var(--ok-err) 72%,var(--ok-ink)) 71deg 110deg,transparent 111deg 160deg,color-mix(in srgb,var(--ok-err) 72%,var(--ok-ink)) 161deg 200deg,transparent 201deg 250deg,color-mix(in srgb,var(--ok-err) 72%,var(--ok-ink)) 251deg 290deg,transparent 291deg 360deg)}.ok-infra-controller-rack-face.is-fas8020 span.is-failed:after,.ok-infra-controller-rack-face.is-fas8300 span.is-failed:after,.ok-infra-controller-rack-face.is-aff-a1k span.is-failed:after{background:color-mix(in srgb,var(--ok-err) 78%,var(--ok-card));box-shadow:0 0 0 1px color-mix(in srgb,var(--ok-card) 76%,var(--ok-err))}.ok-infra-controller-rack-face.is-fas8020-rear{grid-template-columns:minmax(10px,.14fr) minmax(0,1fr) minmax(10px,.14fr);grid-template-rows:repeat(2,minmax(0,1fr));gap:2px;padding:.5px;border-radius:3px;background:color-mix(in srgb,var(--ok-accent) 10%,var(--ok-table-head))}.ok-infra-fas8020-rear-psu{min-width:0;min-height:0;grid-row:1 / span 2;display:flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 13%,var(--ok-card));box-shadow:inset 0 0 0 1px #ffffff3d}.ok-infra-fas8020-rear-psu.is-left{grid-column:1}.ok-infra-fas8020-rear-psu.is-right{grid-column:3}.ok-infra-fas8020-rear-psu span{display:block;color:var(--ok-muted);font-size:9px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:0;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);transform-origin:center;pointer-events:none}.ok-infra-fas8020-rear-psu.is-right span{transform:translate(.08em) rotate(180deg)}.ok-infra-device-preview .ok-infra-fas8020-rear-psu{cursor:pointer}.ok-infra-fas8020-rear-psu.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-fas8020-rear-psu.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-fas8020-rear-psu.is-failed{border-color:color-mix(in srgb,var(--ok-err) 84%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 48%,var(--ok-card))}.ok-infra-fas8020-rear-psu.is-disabled{border-color:color-mix(in srgb,var(--ok-muted) 48%,var(--ok-line));background:color-mix(in srgb,var(--ok-muted) 9%,var(--ok-card))}.ok-infra-shelf-slots span.is-monitoring-disabled,.ok-infra-shelf-back.is-monitoring-disabled .ok-infra-shelf-back-module,.ok-infra-shelf-back-module.is-monitoring-disabled,.ok-infra-shelf-back-ports i.is-monitoring-disabled,.ok-infra-fas8020-rear-psu.is-monitoring-disabled,.ok-infra-controller-rack-face.is-fas8020 span.is-monitoring-disabled,.ok-infra-controller-rack-face.is-fas8300 span.is-monitoring-disabled,.ok-infra-controller-rack-face.is-aff-a1k span.is-monitoring-disabled,.ok-infra-fas8020-port.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;color:color-mix(in srgb,var(--ok-muted) 74%,transparent)!important;box-shadow:none!important;opacity:.58}.ok-infra-controller-rack-face.is-fas8020 span.is-monitoring-disabled:before,.ok-infra-controller-rack-face.is-fas8300 span.is-monitoring-disabled:before,.ok-infra-controller-rack-face.is-aff-a1k span.is-monitoring-disabled:before,.ok-infra-shelf-back-module.is-fan.is-monitoring-disabled span,.ok-infra-shelf-back.is-monitoring-disabled .ok-infra-shelf-back-module.is-fan span{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-controller-rack-face.is-fas8020 span.is-monitoring-disabled:after,.ok-infra-controller-rack-face.is-fas8300 span.is-monitoring-disabled:after,.ok-infra-controller-rack-face.is-aff-a1k span.is-monitoring-disabled:after,.ok-infra-shelf-back-module.is-fan.is-monitoring-disabled span:after,.ok-infra-shelf-back.is-monitoring-disabled .ok-infra-shelf-back-module.is-fan span:after{background:color-mix(in srgb,var(--ok-muted) 24%,transparent)!important;box-shadow:none!important}.ok-infra-fas8020-controller-module{--ok-fas8020-port-size: clamp(18px, calc((100cqh - 8px)/2) , 56px);min-width:0;min-height:0;position:relative;grid-column:2;display:grid;grid-template-columns:minmax(0,1fr) minmax(22px,30%);align-items:stretch;gap:3px;padding:3px 4px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 54%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 20%,var(--ok-card));box-shadow:inset 0 1px #ffffff3d;cursor:pointer;container-type:size}.ok-infra-fas8020-controller-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-fas8020-controller-module.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:inset 0 1px #ffffff3d,0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent)}.ok-infra-fas8020-controller-module.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-fas8020-controller-module.is-top{grid-row:1}.ok-infra-fas8020-controller-module.is-bottom{grid-row:2}.ok-infra-fas8020-port-layout{min-width:0;min-height:0;height:100%;display:grid;grid-template-columns:repeat(4,var(--ok-fas8020-port-size));grid-template-rows:repeat(2,minmax(0,1fr));gap:2px;margin-right:var(--ok-fas8020-port-size);align-content:stretch;align-items:center;justify-items:center;justify-content:end;align-self:stretch;justify-self:end}.ok-infra-fas8020-port-layout .ok-infra-fas8020-port,.ok-infra-fas8020-sas-layout .ok-infra-fas8020-port,.ok-infra-fas8020-slot-stack .ok-infra-fas8020-port,.ok-infra-aff-a400-slot .ok-infra-fas8020-port,.ok-infra-aff-c80-slot .ok-infra-fas8020-port,.ok-infra-aff-c30-slot .ok-infra-fas8020-port,.ok-infra-fas8020-port-layout i{width:var(--ok-fas8020-port-size);height:var(--ok-fas8020-port-size);min-width:0;min-height:0;position:relative;display:grid;place-items:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));color:var(--ok-muted);box-shadow:none;font-size:10px;font-style:normal;font-weight:700;line-height:1;padding:1px;letter-spacing:0}.ok-infra-fas8020-port-layout .ok-infra-fas8020-port.is-up,.ok-infra-fas8020-sas-layout .ok-infra-fas8020-port.is-up,.ok-infra-fas8020-slot-stack .ok-infra-fas8020-port.is-up,.ok-infra-aff-a400-slot .ok-infra-fas8020-port.is-up,.ok-infra-aff-c80-slot .ok-infra-fas8020-port.is-up,.ok-infra-aff-c30-slot .ok-infra-fas8020-port.is-up{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card));color:#052e16}.ok-infra-fas8020-port-layout .ok-infra-fas8020-port.is-down,.ok-infra-fas8020-sas-layout .ok-infra-fas8020-port.is-down,.ok-infra-fas8020-slot-stack .ok-infra-fas8020-port.is-down,.ok-infra-aff-a400-slot .ok-infra-fas8020-port.is-down,.ok-infra-aff-c80-slot .ok-infra-fas8020-port.is-down,.ok-infra-aff-c30-slot .ok-infra-fas8020-port.is-down{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card));color:#fff}.ok-infra-fas8020-port-layout .ok-infra-fas8020-port.is-missing,.ok-infra-fas8020-sas-layout .ok-infra-fas8020-port.is-missing,.ok-infra-fas8020-slot-stack .ok-infra-fas8020-port.is-missing,.ok-infra-aff-a400-slot .ok-infra-fas8020-port.is-missing,.ok-infra-aff-c80-slot .ok-infra-fas8020-port.is-missing,.ok-infra-aff-c30-slot .ok-infra-fas8020-port.is-missing{opacity:.55}.ok-infra-fas8020-port-layout .ok-infra-fas8020-port.is-selected,.ok-infra-fas8020-sas-layout .ok-infra-fas8020-port.is-selected,.ok-infra-fas8020-slot-stack .ok-infra-fas8020-port.is-selected,.ok-infra-aff-a400-slot .ok-infra-fas8020-port.is-selected,.ok-infra-aff-c80-slot .ok-infra-fas8020-port.is-selected,.ok-infra-aff-c30-slot .ok-infra-fas8020-port.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent)}.ok-infra-fas8020-port-layout .is-e0a{grid-column:1;grid-row:1}.ok-infra-fas8020-port-layout .is-e0b{grid-column:1;grid-row:2}.ok-infra-fas8020-port-layout .is-e0c{grid-column:2;grid-row:1}.ok-infra-fas8020-port-layout .is-e0d{grid-column:2;grid-row:2}.ok-infra-fas8020-port-layout .is-e0e{grid-column:3;grid-row:1}.ok-infra-fas8020-port-layout .is-e0f{grid-column:3;grid-row:2}.ok-infra-fas8020-port-layout .is-e0m{grid-column:4;grid-row:1}.ok-infra-fas8020-port-layout .is-e0p{grid-column:4;grid-row:2}.ok-infra-fas8020-port-layout.is-aff-a300{grid-template-columns:repeat(5,var(--ok-fas8020-port-size));margin-right:0;transform:translate(calc(-1 * var(--ok-fas8020-port-size)))}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0a{grid-column:1;grid-row:1}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0b{grid-column:1;grid-row:2}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0e{grid-column:2;grid-row:1}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0f{grid-column:2;grid-row:2}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0g{grid-column:3;grid-row:1}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0h{grid-column:3;grid-row:2}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0c{grid-column:4;grid-row:1}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0d{grid-column:4;grid-row:2}.ok-infra-fas8020-port-layout.is-aff-a300 .is-e0m{grid-column:5;grid-row:2}.ok-infra-fas8020-sas-layout{min-width:0;min-height:0;position:absolute;left:4px;top:calc(75% - (var(--ok-fas8020-port-size) / 2));display:grid;grid-template-columns:repeat(2,var(--ok-fas8020-port-size));grid-template-rows:var(--ok-fas8020-port-size);gap:2px}.ok-infra-fas8020-sas-layout.is-aff-a300{grid-template-columns:repeat(4,var(--ok-fas8020-port-size))}.ok-infra-fas8020-sas-layout:not(.is-aff-a300){grid-template-columns:repeat(2,calc(var(--ok-fas8020-port-size) * 2))}.ok-infra-fas8020-slot-stack{min-width:0;min-height:0;display:grid;grid-template-rows:repeat(2,minmax(0,1fr));gap:2px}.ok-infra-fas8020-slot{--ok-fas8020-slot-count: 4;min-width:0;min-height:0;display:grid;grid-template-columns:16px minmax(0,1fr);grid-template-rows:minmax(0,1fr);gap:1px;place-content:stretch;overflow:hidden;border:1px solid color-mix(in srgb,var(--ok-accent) 38%,var(--ok-line));border-radius:2px;background:color-mix(in srgb,var(--ok-accent) 8%,var(--ok-card));container-type:size}.ok-infra-fas8020-slot-label{min-width:0;min-height:0;display:grid;place-items:center;color:var(--ok-muted);font-size:8px;font-weight:700;line-height:1;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);white-space:nowrap;overflow:hidden;word-spacing:-.18em}.ok-infra-fas8020-slot-ports{min-width:0;min-height:0;display:grid;grid-template-columns:repeat(var(--ok-fas8020-slot-count),minmax(0,1fr));grid-template-rows:minmax(0,1fr);gap:1px}.ok-infra-fas8020-slot-port,.ok-infra-fas8020-slot-empty{min-width:0;min-height:0;display:grid;place-items:stretch;padding:1px;background:color-mix(in srgb,var(--ok-muted) 9%,var(--ok-card))}.ok-infra-fas8020-slot-empty:not(.is-label-only){border:1px solid color-mix(in srgb,var(--ok-accent) 46%,var(--ok-line));border-radius:1px;background:color-mix(in srgb,var(--ok-card) 78%,transparent);opacity:.72}.ok-infra-fas8020-slot-empty.is-label-only{width:100%;height:100%;aspect-ratio:auto;place-items:center;color:var(--ok-muted);font-size:10px;font-weight:800;line-height:1;text-align:center;white-space:nowrap;background:transparent;padding:0}.ok-infra-fas8020-slot-empty.is-label-only span{min-width:0;overflow:hidden;text-overflow:ellipsis}.ok-infra-fas8020-slot .ok-infra-fas8020-port{width:100%;height:100%;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent);font-size:10px}.ok-infra-fas8020-slot .ok-infra-fas8020-port.is-up{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card))}.ok-infra-fas8020-slot .ok-infra-fas8020-port.is-down{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card))}.ok-infra-fas8020-slot-stack .ok-infra-fas8020-slot{padding:1px}.ok-infra-rack-device .ok-infra-fas8020-controller-module{--ok-fas8020-port-size: 8px;padding:2px}.ok-infra-rack-device .ok-infra-fas8020-port-layout{gap:1px}.ok-infra-rack-device .ok-infra-fas8020-sas-layout{left:2px;top:calc(75% - (var(--ok-fas8020-port-size) / 2));gap:1px}.ok-infra-rack-device .ok-infra-fas8020-port-layout .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-fas8020-port-layout i,.ok-infra-rack-device .ok-infra-fas8020-sas-layout .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-fas8020-sas-layout i,.ok-infra-rack-device .ok-infra-fas8020-slot-stack .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-a400-slot .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent}.ok-infra-rack-device .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-fas8020-slot-empty{padding:0}.ok-infra-rack-device .ok-infra-fas8020-slot{grid-template-columns:minmax(0,1fr);padding:0}.ok-infra-rack-device .ok-infra-fas8020-slot-label{display:none}.ok-infra-rack-device .ok-infra-fas8020-slot-ports{display:flex;align-items:center;justify-content:center;gap:2px;padding:0 1px}.ok-infra-rack-device .ok-infra-fas8020-slot .ok-infra-fas8020-port{border-width:0;border-radius:0;box-shadow:none}.ok-infra-device-preview .ok-infra-fas8020-port-layout .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-port-layout i,.ok-infra-device-preview .ok-infra-fas8020-sas-layout .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-sas-layout i,.ok-infra-device-preview .ok-infra-fas8020-slot-stack .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-a400-slot .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-c80-slot .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-c30-slot .ok-infra-fas8020-port{font-size:10px}.ok-infra-device-preview .ok-infra-fas8020-slot{grid-template-columns:24px minmax(0,1fr)}.ok-infra-device-preview .ok-infra-fas8020-slot-label{font-size:11px}.ok-infra-device-preview .ok-infra-fas8020-slot-ports{display:flex;align-items:stretch;justify-content:flex-end}.ok-infra-device-preview .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-fas8020-slot-empty{flex:0 0 auto;width:auto;height:100%;aspect-ratio:1 / 1}.ok-infra-device-preview .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{aspect-ratio:2 / 1}.ok-infra-device-preview .ok-infra-fas8020-port-layout .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-sas-layout .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-slot-stack .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-a400-slot .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-c80-slot .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-c30-slot .ok-infra-fas8020-port{border-radius:2px;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 70%,transparent)}.ok-infra-device-preview .ok-infra-fas8020-slot .ok-infra-fas8020-port{font-size:10px}.ok-infra-device-preview .ok-infra-fas8020-rear-psu span{font-size:13px}.ok-infra-rack-device .ok-infra-fas8020-slot-stack,.ok-infra-rack-device .ok-infra-fas8020-slot{gap:1px}.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-fas8020-slot-label,.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-fas8020-slot-empty.is-label-only span,.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-fas8020-rear-psu span,.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-a200-rear-psu span,.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-aff-c80-psu span,.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-aff-c80-controller-box span,.ok-infra-rack-device .ok-infra-shelf-back-module.is-psu>span,.ok-infra-rack-device .ok-infra-shelf-back-module-label,.ok-infra-rack-device .ok-infra-shelf-back-slot-label,.ok-infra-rack-device .ok-infra-shelf-back-module>strong{display:none!important}.ok-infra-rack-device .ok-infra-controller-rack-face .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-shelf-back-ports i{font-size:0!important;color:transparent!important}.ok-infra-controller-rack-face.is-a200{padding:0}.ok-infra-controller-rack-face.is-a200-rear{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:.25px;border-radius:3px;background:color-mix(in srgb,var(--ok-accent) 8%,var(--ok-table-head))}.ok-infra-controller-rack-face.is-aff-c30-rear{grid-template-columns:minmax(18px,20%) minmax(0,80%);grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:.25px;border-radius:3px;background:color-mix(in srgb,var(--ok-accent) 8%,var(--ok-table-head))}.ok-infra-controller-rack-face.is-aff-a400-rear{grid-template-columns:minmax(0,1fr);grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:.25px;border-radius:3px;background:color-mix(in srgb,var(--ok-accent) 8%,var(--ok-table-head))}.ok-infra-controller-rack-face.is-aff-c80-rear{container-type:size;grid-template-columns:minmax(0,1fr);grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:.25px;border-radius:3px;background:color-mix(in srgb,var(--ok-accent) 8%,var(--ok-table-head))}.ok-infra-a200-controller-module{container-type:size;min-width:0;min-height:0;display:grid;align-items:center;padding:1px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 9%,var(--ok-card));box-shadow:none;cursor:pointer}.ok-infra-a200-controller-module.is-controller-1{grid-column:1;grid-row:1}.ok-infra-a200-controller-module.is-controller-2{grid-column:2;grid-row:1}.ok-infra-a200-controller-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-a200-controller-module.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-a200-controller-module.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-a200-port-row{--ok-a200-port-size: min(calc((100cqw - 18px) / 9), calc(100cqh - 6px) );width:100%;height:100%;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;gap:3px;overflow:hidden}.ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-row{--ok-a200-port-size: min( calc((100cqw - 22px)*.1) , calc(100cqh - 6px) );gap:3px}.ok-infra-a200-port-group{min-width:0;min-height:0;height:var(--ok-a200-port-size);display:flex;align-items:stretch;justify-content:center;gap:1px}.ok-infra-a200-port-group.is-count-1{width:var(--ok-a200-port-size)}.ok-infra-a200-port-group.is-count-2{width:calc(var(--ok-a200-port-size) * 2 + 1px)}.ok-infra-a200-port-group.is-count-3{width:calc(var(--ok-a200-port-size) * 3 + 2px)}.ok-infra-a200-port-group.is-count-4{width:calc(var(--ok-a200-port-size) * 4 + 3px)}.ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group{gap:0}.ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group.is-count-2{width:calc(var(--ok-a200-port-size) * 2)}.ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group.is-count-3{width:calc(var(--ok-a200-port-size) * 3)}.ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group.is-count-4{width:calc(var(--ok-a200-port-size) * 4)}.ok-infra-a200-port-cell{flex:0 0 var(--ok-a200-port-size);width:var(--ok-a200-port-size);height:var(--ok-a200-port-size);min-width:0;min-height:0;display:grid;place-items:stretch}.ok-infra-a200-port-row .ok-infra-fas8020-port{width:100%;height:100%;aspect-ratio:1 / 1;min-width:0;min-height:0;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));color:var(--ok-muted);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent);font-size:10px;font-style:normal;font-weight:700;line-height:1;letter-spacing:0;padding:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-a200-port-row .ok-infra-fas8020-port.is-up{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card));color:#052e16}.ok-infra-a200-port-row .ok-infra-fas8020-port.is-down{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card));color:#fff}.ok-infra-a200-port-row .ok-infra-fas8020-port.is-missing{opacity:.55}.ok-infra-a200-port-row .ok-infra-fas8020-port.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent)}.ok-infra-a200-rear-psu{position:relative;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 13%,var(--ok-card));box-shadow:none}.ok-infra-a200-rear-psu.is-psu-1{grid-column:1;grid-row:2}.ok-infra-a200-rear-psu.is-psu-2{grid-column:2;grid-row:2}.ok-infra-a200-rear-psu span{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--ok-muted);font-size:9px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:0;transform:translateY(.08em);pointer-events:none}.ok-infra-device-preview .ok-infra-a200-rear-psu,.ok-infra-device-preview .ok-infra-a200-controller-module{cursor:pointer}.ok-infra-a200-rear-psu.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-a200-rear-psu.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-a200-rear-psu.is-failed{border-color:color-mix(in srgb,var(--ok-err) 84%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 48%,var(--ok-card))}.ok-infra-a200-rear-psu.is-disabled{border-color:color-mix(in srgb,var(--ok-muted) 48%,var(--ok-line));background:color-mix(in srgb,var(--ok-muted) 9%,var(--ok-card))}.ok-infra-controller-rack-face.is-aff-c30-rear .ok-infra-a200-rear-psu.is-psu-1{grid-column:1;grid-row:1}.ok-infra-controller-rack-face.is-aff-c30-rear .ok-infra-a200-rear-psu.is-psu-2{grid-column:1;grid-row:2}.ok-infra-aff-a400-controller-module .ok-infra-a200-rear-psu.is-psu-1{grid-column:1 / 4;grid-row:2}.ok-infra-aff-a400-controller-module .ok-infra-a200-rear-psu.is-psu-2{grid-column:4 / 7;grid-row:2}.ok-infra-aff-c30-controller-module{container-type:size;min-width:0;min-height:0;display:grid;align-items:stretch;padding:1px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 9%,var(--ok-card));cursor:pointer}.ok-infra-aff-c30-controller-module.is-controller-1{grid-column:2;grid-row:1}.ok-infra-aff-c30-controller-module.is-controller-2{grid-column:2;grid-row:2}.ok-infra-aff-c30-controller-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-aff-c30-controller-module.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-aff-c30-controller-module.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-aff-c30-port-grid{--ok-aff-c30-port-size: min(calc((100cqw - 30px) / 6), calc((100cqh - 7px)/2) );min-width:0;min-height:0;display:grid;grid-template-columns:minmax(0,30%) var(--ok-aff-c30-port-size) minmax(0,30%);grid-template-rows:repeat(2,minmax(0,1fr));gap:1px 4px;align-items:stretch;justify-content:space-between}.ok-infra-aff-c30-slot{min-width:0;min-height:0;display:grid}.ok-infra-aff-c30-slot .ok-infra-fas8020-slot{width:100%;height:100%}.ok-infra-aff-c30-slot.is-slot-1{grid-column:1;grid-row:1}.ok-infra-aff-c30-e0m{min-width:0;min-height:0;grid-column:2;grid-row:1;display:grid;place-items:center;align-self:center}.ok-infra-aff-c30-e0m .ok-infra-fas8020-port{width:var(--ok-aff-c30-port-size);height:var(--ok-aff-c30-port-size);aspect-ratio:1 / 1;min-width:0;min-height:0;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));color:var(--ok-muted);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent);font-size:10px;font-style:normal;font-weight:700;line-height:1;letter-spacing:0;padding:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-aff-c30-e0m .ok-infra-fas8020-port.is-up{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card));color:#052e16}.ok-infra-aff-c30-e0m .ok-infra-fas8020-port.is-down{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card));color:#fff}.ok-infra-aff-c30-e0m .ok-infra-fas8020-port.is-missing{opacity:.55}.ok-infra-aff-c30-slot.is-slot-3-top{grid-column:3;grid-row:1}.ok-infra-aff-c30-slot.is-slot-2{grid-column:1;grid-row:2}.ok-infra-aff-c30-slot.is-slot-4{grid-column:3;grid-row:2}.ok-infra-aff-c30-slot .ok-infra-fas8020-slot-label{font-size:8px}.ok-infra-rack-device .ok-infra-aff-c30-port-grid{--ok-aff-c30-port-size: 7px;gap:1px 2px}.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-slot{grid-template-columns:minmax(0,1fr);padding:0;gap:0}.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-slot-label{display:none}.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-slot-ports{gap:1px;padding:0 1px}.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-slot-empty{padding:0}.ok-infra-rack-device .ok-infra-aff-c30-slot .ok-infra-fas8020-port{font-size:0;border-width:0;border-radius:0;color:transparent}.ok-infra-rack-device .ok-infra-aff-c30-e0m .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent;border-radius:0;box-shadow:none}.ok-infra-device-preview .ok-infra-aff-c30-port-grid{--ok-aff-c30-port-size: clamp(18px, calc((100cqh - 8px)/2) , 48px);gap:3px 8px}.ok-infra-device-preview .ok-infra-aff-c30-slot .ok-infra-fas8020-slot{grid-template-columns:24px minmax(0,1fr)}.ok-infra-device-preview .ok-infra-aff-c30-slot .ok-infra-fas8020-slot-label{font-size:11px}.ok-infra-device-preview .ok-infra-aff-c30-slot .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c30-slot .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{aspect-ratio:2 / 1}.ok-infra-aff-a400-controller-module{container-type:size;min-width:0;min-height:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:minmax(0,1fr);gap:1px;padding:1px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 9%,var(--ok-card));cursor:pointer}.ok-infra-aff-a400-controller-module.is-controller-1{grid-column:1;grid-row:1}.ok-infra-aff-a400-controller-module.is-controller-2{grid-column:1;grid-row:2}.ok-infra-aff-a400-controller-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-aff-a400-controller-module.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-aff-a400-controller-module.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-aff-a400-row{--ok-aff-a400-port-size: min( calc((100cqw - 16px)/8) , calc((100cqh - 12px) / 3));container-type:size;min-width:0;min-height:0;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:1px}.ok-infra-aff-a400-row.is-row-1{grid-column:1;grid-row:1;grid-template-rows:1fr 1.82fr}.ok-infra-aff-a400-row.is-row-2{grid-column:2;grid-row:1;grid-template-rows:1fr 1fr .82fr}.ok-infra-aff-a400-row.is-row-3{grid-column:3;grid-row:1;grid-template-rows:1fr 1fr .82fr}.ok-infra-aff-a400-slot{min-width:0;min-height:0;display:grid}.ok-infra-aff-a400-slot .ok-infra-fas8020-slot{width:100%;height:100%}.ok-infra-aff-a400-slot.is-slot-1,.ok-infra-aff-a400-slot.is-slot-2{grid-column:1 / 7;grid-row:1}.ok-infra-aff-a400-slot.is-slot-3{grid-column:1 / 7;grid-row:2}.ok-infra-aff-a400-slot.is-slot-4{grid-column:1 / 7;grid-row:1}.ok-infra-aff-a400-slot.is-slot-5{grid-column:1 / 7;grid-row:2}.ok-infra-aff-a400-ports{min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;gap:3px;overflow:hidden}.ok-infra-aff-a400-row .ok-infra-aff-a400-ports{grid-column:1 / 7;grid-row:3}.ok-infra-aff-a400-port-group{min-width:0;min-height:0;height:var(--ok-aff-a400-port-size);display:flex;align-items:stretch;justify-content:center;gap:0}.ok-infra-aff-a400-port-group.is-count-1{width:var(--ok-aff-a400-port-size)}.ok-infra-aff-a400-port-group.is-count-2{width:calc(var(--ok-aff-a400-port-size) * 2)}.ok-infra-aff-a400-port-group.is-count-4,.ok-infra-aff-a400-port-group.has-wide-port.is-count-2{width:calc(var(--ok-aff-a400-port-size) * 4)}.ok-infra-aff-a400-port-cell{flex:0 0 var(--ok-aff-a400-port-size);width:var(--ok-aff-a400-port-size);height:var(--ok-aff-a400-port-size);min-width:0;min-height:0;display:grid;place-items:stretch}.ok-infra-aff-a400-port-cell.is-wide{flex-basis:calc(var(--ok-aff-a400-port-size) * 2);width:calc(var(--ok-aff-a400-port-size) * 2)}.ok-infra-aff-a400-port-cell .ok-infra-fas8020-port{width:100%;height:100%;aspect-ratio:1 / 1;min-width:0;min-height:0;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));color:var(--ok-muted);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent);font-size:10px;font-style:normal;font-weight:700;line-height:1;letter-spacing:0;padding:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-aff-a400-port-cell.is-wide .ok-infra-fas8020-port{aspect-ratio:2 / 1}.ok-infra-aff-a400-ports.is-c800-row-2{justify-content:center}.ok-infra-aff-a400-ports.is-c800-row-3{justify-content:flex-end}.ok-infra-aff-a400-port-cell .ok-infra-fas8020-port.is-up{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card));color:#052e16}.ok-infra-aff-a400-port-cell .ok-infra-fas8020-port.is-down{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card));color:#fff}.ok-infra-aff-a400-port-cell .ok-infra-fas8020-port.is-missing{opacity:.55}.ok-infra-aff-c80-controller-module{--ok-aff-c80-slot-base: calc((100cqh - 7px)/8) ;--ok-aff-c80-slot-thickness: min(calc(var(--ok-aff-c80-slot-base) * 1.584), calc((100cqw - 10px) / 13.85));container-type:size;min-width:0;min-height:0;display:grid;grid-template-columns:repeat(5,var(--ok-aff-c80-slot-thickness)) minmax(calc(var(--ok-aff-c80-slot-thickness) * 1.925),1fr) minmax(calc(var(--ok-aff-c80-slot-thickness) * 1.925),1fr) repeat(5,var(--ok-aff-c80-slot-thickness));grid-template-rows:repeat(4,minmax(0,1fr));gap:1px;padding:1px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 9%,var(--ok-card));cursor:pointer}.ok-infra-aff-c80-controller-module.is-controller-1{grid-column:1;grid-row:1}.ok-infra-aff-c80-controller-module.is-controller-2{grid-column:1;grid-row:2}.ok-infra-aff-c80-controller-module.is-chassis{grid-column:1;grid-row:1}.ok-infra-aff-c80-controller-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-aff-c80-controller-module.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-aff-c80-controller-module.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-aff-c80-slot{min-width:0;min-height:0;display:grid}.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot{grid-template-columns:minmax(0,1fr);grid-template-rows:14px minmax(0,1fr)}.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-label{writing-mode:horizontal-tb;text-orientation:mixed;transform:none;word-spacing:-.18em}.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-ports{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-port,.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-empty{flex:0 0 auto;width:min(100%,32px);height:auto;aspect-ratio:1 / 1}.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{aspect-ratio:1 / 2}.ok-infra-aff-c80-slot.is-slot-1{grid-column:1;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-2{grid-column:2;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-3{grid-column:3;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-4-5{grid-column:4 / 6;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-6{grid-column:6;grid-row:4}.ok-infra-aff-c80-slot.is-slot-7{grid-column:7;grid-row:4}.ok-infra-aff-c80-mgmt{grid-column:8;grid-row:1 / 5;min-width:0;min-height:0;display:grid;place-items:center}.ok-infra-aff-c80-slot.is-slot-8{grid-column:9;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-9{grid-column:10;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-10{grid-column:11;grid-row:1 / 5}.ok-infra-aff-c80-slot.is-slot-11{grid-column:12;grid-row:1 / 5}.ok-infra-aff-c80-controller-box{position:relative;min-width:0;min-height:0;border:1px solid color-mix(in srgb,var(--ok-ok-line) 48%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 16%,var(--ok-card));color:color-mix(in srgb,var(--ok-ok) 62%,var(--ok-ink));overflow:hidden;cursor:pointer}.ok-infra-aff-c80-psu{position:relative;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 13%,var(--ok-card));color:var(--ok-muted);overflow:hidden}.ok-infra-aff-c80-psu.is-left{grid-column:6;grid-row:1 / 3}.ok-infra-aff-c80-psu.is-right{grid-column:7;grid-row:1 / 3}.ok-infra-aff-c80-psu span{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--ok-muted);font-size:9px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:0;transform:translateY(.08em);pointer-events:none}.ok-infra-aff-c80-controller-box.is-panel{grid-column:6 / 8;grid-row:3}.ok-infra-aff-c80-controller-box span{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;line-height:1;transform:translateY(.08em);font-size:10px;font-weight:800;letter-spacing:0;pointer-events:none}.ok-infra-aff-c80-controller-box.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-aff-c80-controller-box.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-aff-c80-controller-box.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;color:color-mix(in srgb,var(--ok-muted) 74%,transparent)!important;box-shadow:none!important;opacity:.58}.ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot-ports,.ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot-ports{display:flex;align-items:center;justify-content:center}.ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot-port,.ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot-empty,.ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot-port,.ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot-empty{flex:0 0 auto;width:auto;height:min(100%,32px);aspect-ratio:1 / 1}.ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{aspect-ratio:2 / 1}.ok-infra-aff-c80-slot .ok-infra-fas8020-slot-empty.is-label-only{width:100%;height:100%;aspect-ratio:auto}.ok-infra-rack-device .ok-infra-aff-a400-controller-module{--ok-aff-a400-port-size: 5px;gap:1px;padding:1px}.ok-infra-rack-device .ok-infra-aff-c80-controller-module{gap:1px;padding:1px}.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot{grid-template-columns:minmax(0,1fr);padding:0;gap:0}.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot-label{display:none}.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot-ports{gap:1px;padding:0 1px}.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent;border-radius:0;box-shadow:none}.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot-empty.is-label-only span,.ok-infra-rack-device .ok-infra-aff-c80-psu span,.ok-infra-rack-device .ok-infra-aff-c80-controller-box span{display:none}.ok-infra-rack-device .ok-infra-aff-a400-slot .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent}.ok-infra-rack-device .ok-infra-aff-a400-port-cell .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent;border-radius:0;box-shadow:none}.ok-infra-device-preview .ok-infra-aff-a400-controller-module{--ok-aff-a400-port-size: min( calc((100cqw - 64px)/8) , calc((100cqh - 18px)/8) , 42px);gap:2px;padding:1px}.ok-infra-device-preview .ok-infra-aff-c80-controller-module{gap:2px;padding:1px}.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot{grid-template-rows:18px minmax(0,1fr)}.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-label{font-size:11px}.ok-infra-device-preview .ok-infra-aff-c80-psu span{font-size:13px}.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{aspect-ratio:1 / 1}.ok-infra-device-preview .ok-infra-aff-a400-ports{gap:8px}.ok-infra-device-preview .ok-infra-aff-a400-port-cell .ok-infra-fas8020-port{font-size:10px;border-radius:2px}.ok-infra-a200-rear-psu.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;color:color-mix(in srgb,var(--ok-muted) 74%,transparent)!important;box-shadow:none!important;opacity:.58}.ok-infra-rack-device .ok-infra-a200-controller-module{padding:1px}.ok-infra-rack-device .ok-infra-a200-port-row{--ok-a200-port-size: min(calc((100cqw - 14px) / 9), calc(100cqh - 4px) );gap:4px}.ok-infra-rack-device .ok-infra-a200-port-group{gap:1px}.ok-infra-rack-device .ok-infra-a200-port-row .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent;border-radius:0;box-shadow:none}.ok-infra-rack-device .ok-infra-a200-rear-psu span{font-size:8px}.ok-infra-device-preview .ok-infra-a200-controller-module{padding:1px}.ok-infra-device-preview .ok-infra-a200-port-row{--ok-a200-port-size: min(calc((100cqw - 48px) / 9), calc(100cqh - 12px) , 56px);gap:8px;align-self:center;height:var(--ok-a200-port-size)}.ok-infra-device-preview .ok-infra-a200-port-group{gap:4px}.ok-infra-device-preview .ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group{gap:0}.ok-infra-device-preview .ok-infra-a200-port-group.is-count-2{width:calc(var(--ok-a200-port-size) * 2 + 4px)}.ok-infra-device-preview .ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group.is-count-2{width:calc(var(--ok-a200-port-size) * 2)}.ok-infra-device-preview .ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group.is-count-3{width:calc(var(--ok-a200-port-size) * 3)}.ok-infra-device-preview .ok-infra-a200-controller-module.is-fas2820 .ok-infra-a200-port-group.is-count-4{width:calc(var(--ok-a200-port-size) * 4)}.ok-infra-device-preview .ok-infra-a200-port-row .ok-infra-fas8020-port{font-size:10px;border-radius:2px}.ok-infra-device-preview .ok-infra-a200-rear-psu span{font-size:13px}.ok-infra-c250-controller-module{container-type:size;min-width:0;min-height:0;display:grid;grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:1px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 9%,var(--ok-card));box-shadow:none;cursor:pointer}.ok-infra-c250-controller-module.is-controller-1{grid-column:2;grid-row:1}.ok-infra-c250-controller-module.is-controller-2{grid-column:2;grid-row:2}.ok-infra-c250-controller-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-c250-controller-module.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px #ffffff5c}.ok-infra-c250-controller-module.is-monitoring-disabled{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-c250-row{min-width:0;min-height:0;display:grid;align-items:stretch;gap:1px}.ok-infra-c250-row.is-top{grid-template-columns:minmax(0,1fr) minmax(0,30%) minmax(0,30%)}.ok-infra-c250-row.is-bottom{--ok-c250-port-size: min(calc((100cqw - 30px) / 6), calc((100cqh - 7px)/2) );grid-template-columns:minmax(0,1fr) minmax(0,30%) minmax(0,30%);align-items:center}.ok-infra-c250-spacer{min-width:0;min-height:0}.ok-infra-c250-slot{min-width:0;min-height:0;display:grid}.ok-infra-c250-slot .ok-infra-fas8020-slot{width:100%;height:100%}.ok-infra-c250-slot .ok-infra-fas8020-slot-label{font-size:8px}.ok-infra-c250-e0m{min-width:0;min-height:0;display:grid;justify-items:center;align-items:center;justify-self:center}.ok-infra-c250-port-pair{min-width:0;min-height:0;display:flex;align-items:center;justify-content:flex-start;justify-self:stretch;gap:1px}.ok-infra-c250-port-cell,.ok-infra-c250-e0m{width:var(--ok-c250-port-size);height:var(--ok-c250-port-size)}.ok-infra-c250-port-cell{min-width:0;min-height:0;display:grid;place-items:stretch}.ok-infra-c250-port-pair .ok-infra-fas8020-port,.ok-infra-c250-e0m .ok-infra-fas8020-port{width:100%;height:100%;aspect-ratio:1 / 1;min-width:0;min-height:0;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));color:var(--ok-muted);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent);font-size:10px;font-style:normal;font-weight:700;line-height:1;letter-spacing:0;padding:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-c250-port-pair .ok-infra-fas8020-port.is-up,.ok-infra-c250-e0m .ok-infra-fas8020-port.is-up{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card));color:#052e16}.ok-infra-c250-port-pair .ok-infra-fas8020-port.is-down,.ok-infra-c250-e0m .ok-infra-fas8020-port.is-down{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card));color:#fff}.ok-infra-c250-port-pair .ok-infra-fas8020-port.is-missing,.ok-infra-c250-e0m .ok-infra-fas8020-port.is-missing{opacity:.55}.ok-infra-c250-port-pair .ok-infra-fas8020-port.is-selected,.ok-infra-c250-e0m .ok-infra-fas8020-port.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-accent) 24%,transparent),inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 58%,transparent)}.ok-infra-rack-device .ok-infra-c250-controller-module{padding:1px}.ok-infra-rack-device .ok-infra-c250-row{gap:2px}.ok-infra-rack-device .ok-infra-c250-slot .ok-infra-fas8020-slot{grid-template-columns:minmax(0,1fr);padding:0;gap:0}.ok-infra-rack-device .ok-infra-c250-slot .ok-infra-fas8020-slot-label{display:none}.ok-infra-rack-device .ok-infra-c250-slot .ok-infra-fas8020-slot-ports{gap:1px;padding:0 1px}.ok-infra-rack-device .ok-infra-c250-slot .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-c250-slot .ok-infra-fas8020-slot-empty{padding:0}.ok-infra-rack-device .ok-infra-c250-slot .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-c250-port-pair .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-c250-e0m .ok-infra-fas8020-port{font-size:0;padding:0;color:transparent;border-radius:0;box-shadow:none}.ok-infra-device-preview .ok-infra-c250-controller-module{gap:3px;padding:1px}.ok-infra-device-preview .ok-infra-c250-row{gap:8px}.ok-infra-device-preview .ok-infra-c250-row.is-bottom{--ok-c250-port-size: clamp(18px, calc((100cqh - 8px)/2) , 48px)}.ok-infra-device-preview .ok-infra-c250-port-pair{gap:3px}.ok-infra-device-preview .ok-infra-c250-slot .ok-infra-fas8020-slot{grid-template-columns:24px minmax(0,1fr)}.ok-infra-device-preview .ok-infra-c250-slot .ok-infra-fas8020-slot-label{font-size:11px}.ok-infra-device-preview .ok-infra-c250-port-pair .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-c250-e0m .ok-infra-fas8020-port{font-size:10px;border-radius:2px}.ok-infra-shelf-slots{width:100%;height:100%;min-height:0;display:grid;grid-template-columns:repeat(var(--ok-shelf-columns, 24),minmax(2px,1fr));grid-template-rows:repeat(var(--ok-shelf-rows, 1),minmax(4px,1fr));gap:2px;align-content:stretch}.ok-infra-shelf-slots span{min-width:0;min-height:0;border:1px solid color-mix(in srgb,var(--ok-ok-line) 45%,var(--ok-line));border-radius:2px;background:linear-gradient(180deg,var(--ok-card),var(--ok-soft));position:relative}.ok-infra-device-preview .ok-infra-shelf-slots span,.ok-infra-device-preview .ok-infra-shelf-back-module,.ok-infra-device-preview .ok-infra-shelf-back-ports i{cursor:pointer}.ok-infra-shelf-slots span.is-active{border-color:color-mix(in srgb,var(--ok-ok) 76%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 62%,var(--ok-card));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-ok) 34%,transparent)}.ok-infra-shelf-slots span.is-failed{border-color:color-mix(in srgb,var(--ok-err) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 72%,var(--ok-card));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-err) 40%,transparent)}.ok-infra-shelf-slots span.is-flashcache{background:repeating-linear-gradient(135deg,color-mix(in srgb,var(--ok-ok) 62%,var(--ok-card)) 0,color-mix(in srgb,var(--ok-ok) 62%,var(--ok-card)) 4px,color-mix(in srgb,var(--ok-ok) 48%,var(--ok-card)) 4px,color-mix(in srgb,var(--ok-ok) 48%,var(--ok-card)) 8px)}.ok-infra-shelf-slots span.is-flashcache.is-failed{background:repeating-linear-gradient(135deg,color-mix(in srgb,var(--ok-err) 72%,var(--ok-card)) 0,color-mix(in srgb,var(--ok-err) 72%,var(--ok-card)) 4px,color-mix(in srgb,var(--ok-err) 56%,var(--ok-card)) 4px,color-mix(in srgb,var(--ok-err) 56%,var(--ok-card)) 8px)}.ok-infra-shelf-back{width:100%;height:100%;min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:.25px;border-radius:3px;background:color-mix(in srgb,var(--ok-accent) 8%,var(--ok-table-head))}.ok-infra-shelf-back.is-ns224-rear{grid-template-columns:minmax(18px,20%) minmax(0,80%);grid-template-rows:repeat(2,minmax(0,1fr))}.ok-infra-shelf-back.is-wide-rear{grid-template-columns:minmax(0,.5fr) minmax(0,1fr) minmax(0,.5fr);grid-template-rows:repeat(4,minmax(0,1fr))}.ok-infra-shelf-back-module{min-width:0;min-height:0;display:grid;align-items:stretch;padding:1px;border:1px solid color-mix(in srgb,var(--ok-ok-line) 46%,var(--ok-line));border-radius:3px;background:color-mix(in srgb,var(--ok-ok) 9%,var(--ok-card));overflow:hidden}.ok-infra-shelf-back-module.is-iom{container-type:size;position:relative;align-items:center;justify-items:center;padding:1px}.ok-infra-shelf-back-iom-target{position:absolute;top:1px;right:1px;bottom:1px;left:1px;border:0;border-radius:inherit;background:transparent;cursor:pointer;z-index:0}.ok-infra-shelf-back.is-wide-rear .ok-infra-shelf-back-module.is-iom-a{grid-column:2;grid-row:1}.ok-infra-shelf-back.is-wide-rear .ok-infra-shelf-back-module.is-iom-b{grid-column:2;grid-row:3}.ok-infra-shelf-back-module.is-psu{position:relative;place-items:center;background:color-mix(in srgb,var(--ok-ok) 13%,var(--ok-card))}.ok-infra-shelf-back-module.is-fan{position:relative;place-items:center;background:color-mix(in srgb,var(--ok-ok) 10%,var(--ok-card))}.ok-infra-shelf-back.is-wide-rear .ok-infra-shelf-back-module.is-psu-1{grid-column:1;grid-row:1 / span 2}.ok-infra-shelf-back.is-wide-rear .ok-infra-shelf-back-module.is-psu-2{grid-column:1;grid-row:3 / span 2}.ok-infra-shelf-back.is-wide-rear .ok-infra-shelf-back-module.is-psu-3{grid-column:3;grid-row:1 / span 2}.ok-infra-shelf-back.is-wide-rear .ok-infra-shelf-back-module.is-psu-4{grid-column:3;grid-row:3 / span 2}.ok-infra-shelf-back.is-ds460c-rear .ok-infra-shelf-back-module.is-psu-1{grid-column:2;grid-row:1}.ok-infra-shelf-back.is-ds460c-rear .ok-infra-shelf-back-module.is-iom-a{grid-column:2;grid-row:2}.ok-infra-shelf-back.is-ds460c-rear .ok-infra-shelf-back-module.is-iom-b{grid-column:2;grid-row:3}.ok-infra-shelf-back.is-ds460c-rear .ok-infra-shelf-back-module.is-psu-2{grid-column:2;grid-row:4}.ok-infra-shelf-back.is-ds460c-rear .ok-infra-shelf-back-module.is-fan-left{grid-column:1;grid-row:1 / span 4}.ok-infra-shelf-back.is-ds460c-rear .ok-infra-shelf-back-module.is-fan-right{grid-column:3;grid-row:1 / span 4}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-module.is-iom-a{grid-column:2;grid-row:1}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-module.is-iom-b{grid-column:2;grid-row:2}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-module.is-psu-1{grid-column:1;grid-row:1}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-module.is-psu-2{grid-column:1;grid-row:2}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-module.is-iom{align-items:end;justify-items:center;padding:1px}.ok-infra-shelf-back-module-label{align-self:start;justify-self:start;margin:1px 2px;color:var(--ok-muted);font-size:9px;font-weight:800;line-height:1;pointer-events:none}.ok-infra-shelf-back-slot-label{position:absolute;left:4px;bottom:4px;color:var(--ok-muted);font-size:9px;font-weight:800;line-height:1;pointer-events:none}.ok-infra-shelf-back-ns224b-slot{position:absolute;left:4px;bottom:4px;width:min(62cqw,178px);height:min(46cqh,38px);z-index:2}.ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-ports{display:flex;align-items:stretch;justify-content:center}.ok-infra-shelf-back-module.is-psu span{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--ok-muted);font-size:9px;font-weight:700;line-height:1;letter-spacing:0;transform:translateY(.08em);pointer-events:none}.ok-infra-shelf-back-module.is-fan span{position:absolute;left:50%;top:50%;width:auto;height:min(86%,calc(100% - 4px));max-width:calc(100% - 4px);aspect-ratio:1;transform:translate(-50%,-50%);border:1px solid color-mix(in srgb,var(--ok-ok) 68%,var(--ok-line));border-radius:50%;background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--ok-card) 80%,var(--ok-ok)) 0 18%,transparent 19%),conic-gradient(from 24deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 0 20deg,transparent 21deg 70deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 71deg 110deg,transparent 111deg 160deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 161deg 200deg,transparent 201deg 250deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 251deg 290deg,transparent 291deg 360deg);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-ok) 16%,transparent);pointer-events:none}.ok-infra-shelf-back-module.is-fan span:after{content:"";position:absolute;left:50%;top:50%;width:min(18%,12px);min-width:3px;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;background:color-mix(in srgb,var(--ok-ok) 78%,var(--ok-card));box-shadow:0 0 0 1px color-mix(in srgb,var(--ok-card) 76%,var(--ok-ok))}.ok-infra-shelf-back-module.is-fan-module{display:grid;grid-template-rows:repeat(2,minmax(0,1fr));gap:1px;padding:1px;background:color-mix(in srgb,var(--ok-ok) 10%,var(--ok-card))}.ok-infra-shelf-back-fan{position:relative;min-width:0;min-height:0;padding:0;border:0;border-radius:2px;background:transparent;cursor:pointer;overflow:hidden}.ok-infra-shelf-back-fan span{position:absolute;left:50%;top:50%;width:auto;height:min(86%,calc(100% - 4px));max-width:calc(100% - 4px);aspect-ratio:1;transform:translate(-50%,-50%);border:1px solid color-mix(in srgb,var(--ok-ok) 68%,var(--ok-line));border-radius:50%;background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--ok-card) 80%,var(--ok-ok)) 0 18%,transparent 19%),conic-gradient(from 24deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 0 20deg,transparent 21deg 70deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 71deg 110deg,transparent 111deg 160deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 161deg 200deg,transparent 201deg 250deg,color-mix(in srgb,var(--ok-ok) 70%,var(--ok-ink)) 251deg 290deg,transparent 291deg 360deg);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-ok) 16%,transparent);pointer-events:none}.ok-infra-shelf-back-fan span:after{content:"";position:absolute;left:50%;top:50%;width:min(18%,12px);min-width:3px;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;background:color-mix(in srgb,var(--ok-ok) 78%,var(--ok-card));box-shadow:0 0 0 1px color-mix(in srgb,var(--ok-card) 76%,var(--ok-ok))}.ok-infra-shelf-back-fan.is-failed span{border-color:color-mix(in srgb,var(--ok-err) 80%,var(--ok-line));background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--ok-card) 76%,var(--ok-err)) 0 18%,transparent 19%),conic-gradient(from 24deg,color-mix(in srgb,var(--ok-err) 76%,var(--ok-ink)) 0 20deg,transparent 21deg 70deg,color-mix(in srgb,var(--ok-err) 76%,var(--ok-ink)) 71deg 110deg,transparent 111deg 160deg,color-mix(in srgb,var(--ok-err) 76%,var(--ok-ink)) 161deg 200deg,transparent 201deg 250deg,color-mix(in srgb,var(--ok-err) 76%,var(--ok-ink)) 251deg 290deg,transparent 291deg 360deg)}.ok-infra-shelf-back-fan.is-selected{outline:2px solid var(--ok-accent);outline-offset:-2px}.ok-infra-shelf-back-fan.is-monitoring-disabled span{border-color:color-mix(in srgb,var(--ok-muted) 34%,var(--ok-line))!important;background:color-mix(in srgb,var(--ok-card) 82%,transparent)!important;box-shadow:none!important}.ok-infra-shelf-back-fan.is-monitoring-disabled span:after{background:color-mix(in srgb,var(--ok-muted) 24%,transparent)!important;box-shadow:none!important}.ok-infra-device-preview .ok-infra-shelf-back-module.is-psu span{font-size:13px}.ok-infra-shelf-back-module.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 72%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 28%,var(--ok-card))}.ok-infra-shelf-back-module.is-failed{border-color:color-mix(in srgb,var(--ok-err) 84%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 48%,var(--ok-card))}.ok-infra-shelf-back-ports{--ok-shelf-rear-port-size: 10px;justify-self:center;align-self:center;width:min(82%,48px);height:var(--ok-shelf-rear-port-size);min-width:28px;min-height:var(--ok-shelf-rear-port-size);display:flex;align-items:center;justify-content:center;gap:2px}.ok-infra-shelf-back-ports.is-count-2{width:min(58%,26px);min-width:18px}.ok-infra-shelf-back-ports i{position:relative;z-index:1;flex:0 0 var(--ok-shelf-rear-port-size);width:var(--ok-shelf-rear-port-size);height:var(--ok-shelf-rear-port-size);min-width:0;min-height:0;align-self:center;box-sizing:border-box;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--ok-accent) 52%,var(--ok-line));border-radius:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card)),color-mix(in srgb,var(--ok-accent) 8%,var(--ok-soft)));box-shadow:none;color:var(--ok-muted);font-size:10px;font-style:normal;font-weight:700;line-height:1;letter-spacing:0;overflow:hidden;white-space:nowrap}.ok-infra-shelf-back-ports i.is-ok{border-color:color-mix(in srgb,var(--ok-ok) 82%,var(--ok-line));background:color-mix(in srgb,var(--ok-ok) 70%,var(--ok-card))}.ok-infra-shelf-back-ports i.is-failed{border-color:color-mix(in srgb,var(--ok-err) 86%,var(--ok-line));background:color-mix(in srgb,var(--ok-err) 74%,var(--ok-card))}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports i{flex-basis:calc(var(--ok-shelf-rear-port-size) * 2);width:calc(var(--ok-shelf-rear-port-size) * 2)}.ok-infra-shelf-back-ports.is-count-4 i:nth-child(2){margin-right:6px}.ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports.is-count-2{width:min(86%,160px);gap:96px}.ok-infra-rack-device .ok-infra-shelf-back-ports{--ok-shelf-rear-port-size: 8px;width:auto;min-width:0;height:var(--ok-shelf-rear-port-size);min-height:0;gap:1px}.ok-infra-rack-device .ok-infra-shelf-back-ports.is-count-2{width:auto;min-width:0}.ok-infra-rack-device .ok-infra-shelf-back-module-label{font-size:6px;margin:1px}.ok-infra-rack-device .ok-infra-shelf-back-module.is-iom,.ok-infra-rack-device .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-module.is-iom{align-items:center}.ok-infra-rack-device .ok-infra-shelf-back-ns224b-slot{left:1px;bottom:1px;width:min(65cqw,49px);height:min(48cqh,14px)}.ok-infra-rack-device .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports.is-count-2{gap:30px}.ok-infra-rack-device .ok-infra-shelf-back-ports i,.ok-infra-rack-device .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports i{font-size:0}.ok-infra-rack-device .ok-infra-shelf-back-ports.is-count-4 i:nth-child(2){margin-right:6px}.ok-infra-device-preview .ok-infra-shelf-back{gap:3px;padding:.75px}.ok-infra-device-preview .ok-infra-shelf-back-module{padding:5px;border-radius:5px}.ok-infra-device-preview .ok-infra-shelf-back-ns224b-slot{left:8px;bottom:8px;width:min(62cqw,213px);height:min(42cqh,50px)}.ok-infra-device-preview .ok-infra-shelf-back-ports{--ok-shelf-rear-port-size: 32px;width:min(56%,176px);height:var(--ok-shelf-rear-port-size);gap:6px}.ok-infra-device-preview .ok-infra-shelf-back-ports.is-count-2{width:min(38%,70px)}.ok-infra-device-preview .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports.is-count-2{width:min(86%,320px);gap:168px}.ok-infra-device-preview .ok-infra-shelf-back-ports i{border-radius:2px;font-size:10px;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-card) 70%,transparent)}.ok-infra-device-preview .ok-infra-shelf-back-ports.is-count-4 i:nth-child(2){margin-right:20px}.ok-infra-device-preview .ok-infra-fas8020-controller-module{--ok-fas8020-port-size: min(32px, calc((100cqw - 12px)/5) , calc((100cqh - 8px)/2) )}.ok-infra-device-preview .ok-infra-a200-port-row{--ok-a200-port-size: min(32px, calc((100cqw - 48px) / 9), calc(100cqh - 12px) )}.ok-infra-device-preview .ok-infra-aff-c30-port-grid{--ok-aff-c30-port-size: min(32px, calc((100cqw - 30px) / 6), calc((100cqh - 7px)/2) )}.ok-infra-device-preview .ok-infra-aff-a400-controller-module{--ok-aff-a400-port-size: min(32px, calc((100cqw - 64px)/8) , calc((100cqh - 18px)/8) )}.ok-infra-device-preview .ok-infra-c250-row.is-bottom{--ok-c250-port-size: min(32px, calc((100cqw - 30px) / 6), calc((100cqh - 7px)/2) )}.ok-infra-device-preview .ok-infra-shelf-back-ports{--ok-shelf-rear-port-size: 32px}.ok-infra-device-preview .ok-infra-shelf-back-ports,.ok-infra-device-preview .ok-infra-shelf-back-ports.is-count-2{width:auto;min-width:0;max-width:100%;height:32px;min-height:32px}.ok-infra-device-preview .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports.is-count-2{width:min(86%,320px);height:32px;min-height:32px}.ok-infra-device-preview .ok-infra-fas8020-port-layout .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-port-layout i,.ok-infra-device-preview .ok-infra-fas8020-sas-layout .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-sas-layout i,.ok-infra-device-preview .ok-infra-a200-port-cell,.ok-infra-device-preview .ok-infra-aff-a400-port-cell:not(.is-wide),.ok-infra-device-preview .ok-infra-c250-port-cell,.ok-infra-device-preview .ok-infra-c250-e0m,.ok-infra-device-preview .ok-infra-aff-c30-e0m .ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-shelf-back-ports i{width:min(32px,100%);height:min(32px,100%);aspect-ratio:1 / 1}.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-empty,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot-empty,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot-empty{height:min(32px,100%);aspect-ratio:1 / 1}.ok-infra-device-preview .ok-infra-fas8020-slot-ports,.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot-ports,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot-ports,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot-ports,.ok-infra-device-preview .ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-ports{align-items:center;justify-content:center}.ok-infra-device-preview .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-fas8020-slot-empty{flex:0 1 32px;width:min(32px,100%);height:min(32px,100%);aspect-ratio:1 / 1;align-self:center;justify-self:center}.ok-infra-device-preview .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty,.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{flex-basis:min(64px,100%);width:min(64px,100%);height:min(32px,100%);aspect-ratio:2 / 1}.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{flex-basis:min(64px,100%);width:min(32px,100%);height:min(64px,100%);aspect-ratio:1 / 2}.ok-infra-device-preview .ok-infra-aff-a400-port-cell.is-wide{flex-basis:min(64px,100%);width:min(64px,100%);height:min(32px,100%)}.ok-infra-device-preview .ok-infra-aff-a400-port-cell.is-wide>.ok-infra-fas8020-port{width:min(64px,100%)!important;height:min(32px,100%)!important;max-width:64px;max-height:32px;aspect-ratio:2 / 1!important}.ok-infra-rack-device .ok-infra-fas8020-controller-module{--ok-fas8020-port-size: 8px}.ok-infra-rack-device .ok-infra-a200-port-row{--ok-a200-port-size: 8px}.ok-infra-rack-device .ok-infra-aff-c30-port-grid{--ok-aff-c30-port-size: 8px}.ok-infra-rack-device .ok-infra-aff-a400-controller-module{--ok-aff-a400-port-size: 8px}.ok-infra-rack-device .ok-infra-c250-row.is-bottom{--ok-c250-port-size: 8px}.ok-infra-rack-device .ok-infra-shelf-back-ports{--ok-shelf-rear-port-size: 8px}.ok-infra-rack-device .ok-infra-shelf-back-ports,.ok-infra-rack-device .ok-infra-shelf-back-ports.is-count-2{width:auto;min-width:0;max-width:100%;height:8px;min-height:8px}.ok-infra-rack-device .ok-infra-fas8020-port-layout .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-fas8020-port-layout i,.ok-infra-rack-device .ok-infra-fas8020-sas-layout .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-fas8020-sas-layout i,.ok-infra-rack-device .ok-infra-fas8020-slot .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-a200-port-cell,.ok-infra-rack-device .ok-infra-aff-a400-port-cell,.ok-infra-rack-device .ok-infra-c250-port-cell,.ok-infra-rack-device .ok-infra-c250-e0m,.ok-infra-rack-device .ok-infra-aff-c30-e0m .ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot-empty,.ok-infra-rack-device .ok-infra-shelf-back-ports i{width:8px;height:8px;max-width:8px;max-height:8px;aspect-ratio:1 / 1;align-self:center;justify-self:center}.ok-infra-rack-device .ok-infra-fas8020-slot .ok-infra-fas8020-port{font-size:0!important;color:transparent!important;padding:0;border-radius:0;box-shadow:none}.ok-infra-rack-device .ok-infra-fas8020-port.is-monitoring-disabled,.ok-infra-rack-device .ok-infra-shelf-back-ports i.is-monitoring-disabled{opacity:1!important;border-color:color-mix(in srgb,var(--ok-muted) 42%,var(--ok-line))!important;background:transparent!important;box-shadow:none!important}.ok-infra-rack-device .ok-infra-fas8020-slot-port.is-monitoring-disabled{opacity:1!important;outline:1px solid color-mix(in srgb,var(--ok-muted) 42%,var(--ok-line))!important;outline-offset:-1px;border:0!important;background:transparent!important;box-shadow:none!important;box-sizing:border-box}.ok-infra-rack-device .ok-infra-fas8020-slot-port.is-monitoring-disabled>.ok-infra-fas8020-port{border-color:transparent!important;background:transparent!important;box-shadow:none!important;opacity:1!important}.ok-infra-rack-device .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-fas8020-slot-empty{width:8px;height:8px;max-width:8px;max-height:8px;align-self:center;justify-self:center}.ok-infra-rack-device .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty,.ok-infra-rack-device .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-aff-c80-slot.is-slot-6 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty,.ok-infra-rack-device .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-aff-c80-slot.is-slot-7 .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{width:16px;height:8px;max-width:16px;max-height:8px;aspect-ratio:2 / 1}.ok-infra-rack-device .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-aff-c80-slot:not(.is-slot-6):not(.is-slot-7) .ok-infra-fas8020-slot.is-count-2 .ok-infra-fas8020-slot-empty{width:8px;height:16px;max-width:8px;max-height:16px;aspect-ratio:1 / 2}.ok-infra-rack-device .ok-infra-fas8020-slot-ports,.ok-infra-rack-device .ok-infra-aff-c80-slot .ok-infra-fas8020-slot-ports,.ok-infra-rack-device .ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-ports{align-items:center;justify-content:center}.ok-infra-device-preview .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports i{flex-basis:min(64px,100%);width:min(64px,100%);height:min(32px,100%);aspect-ratio:2 / 1;font-size:10px}.ok-infra-device-preview .ok-infra-shelf-back.is-ns224b-rear .ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-port,.ok-infra-device-preview .ok-infra-shelf-back.is-ns224b-rear .ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-empty{flex-basis:min(64px,100%);width:min(64px,100%);height:min(32px,100%);aspect-ratio:2 / 1}.ok-infra-rack-device .ok-infra-shelf-back.is-ns224-rear .ok-infra-shelf-back-ports i{flex-basis:16px;width:16px;height:8px;max-width:16px;max-height:8px;aspect-ratio:2 / 1;font-size:0!important;color:transparent!important}.ok-infra-rack-device .ok-infra-shelf-back.is-ns224b-rear .ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-port,.ok-infra-rack-device .ok-infra-shelf-back.is-ns224b-rear .ok-infra-shelf-back-ns224b-slot .ok-infra-fas8020-slot-empty{width:16px;height:8px;max-width:16px;max-height:8px;aspect-ratio:2 / 1}.ok-infra-rack-device .ok-infra-aff-a400-port-cell.is-wide,.ok-infra-rack-device .ok-infra-aff-a400-port-cell.is-wide>.ok-infra-fas8020-port{width:16px!important;height:8px!important;max-width:16px;max-height:8px;aspect-ratio:2 / 1!important}.ok-infra-device-preview .ok-infra-fas8020-sas-layout:not(.is-aff-a300)>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-shelf-back.is-iom6-rear .ok-infra-shelf-back-ports i{flex-basis:min(64px,100%);width:min(64px,100%)!important;height:min(32px,100%)!important;max-width:64px;max-height:32px;aspect-ratio:2 / 1!important}.ok-infra-rack-device .ok-infra-fas8020-sas-layout:not(.is-aff-a300)>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-shelf-back.is-iom6-rear .ok-infra-shelf-back-ports i{flex-basis:16px;width:16px!important;height:8px!important;max-width:16px;max-height:8px;aspect-ratio:2 / 1!important}.ok-infra-device-preview .ok-infra-shelf-back.is-iom6-rear .ok-infra-shelf-back-ports.is-count-2{gap:45px}.ok-infra-device-preview .ok-infra-shelf-back.is-iom12-rear .ok-infra-shelf-back-ports.is-count-4 i:nth-child(2){margin-right:36px!important}.ok-infra-rack-device .ok-infra-shelf-back.is-iom6-rear .ok-infra-shelf-back-ports.is-count-2{gap:7.5px}.ok-infra-rack-device .ok-infra-shelf-back.is-iom12-rear .ok-infra-shelf-back-ports.is-count-4 i:nth-child(2){margin-right:6px!important}.ok-infra-device-preview .ok-infra-fas8020-port-layout>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-port-layout>i,.ok-infra-device-preview .ok-infra-fas8020-sas-layout>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-fas8020-sas-layout>i,.ok-infra-device-preview .ok-infra-a200-port-cell,.ok-infra-device-preview .ok-infra-a200-port-cell>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-a400-port-cell:not(.is-wide),.ok-infra-device-preview .ok-infra-aff-a400-port-cell:not(.is-wide)>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-c250-port-cell,.ok-infra-device-preview .ok-infra-c250-port-cell>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-c250-e0m,.ok-infra-device-preview .ok-infra-c250-e0m>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-c30-e0m>.ok-infra-fas8020-port,.ok-infra-device-preview .ok-infra-aff-c80-mgmt>.ok-infra-fas8020-port{width:min(32px,100%)!important;height:min(32px,100%)!important;max-width:32px;max-height:32px;aspect-ratio:1 / 1!important}.ok-infra-rack-device .ok-infra-fas8020-port-layout>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-fas8020-port-layout>i,.ok-infra-rack-device .ok-infra-fas8020-sas-layout>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-fas8020-sas-layout>i,.ok-infra-rack-device .ok-infra-a200-port-cell,.ok-infra-rack-device .ok-infra-a200-port-cell>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-a400-port-cell:not(.is-wide),.ok-infra-rack-device .ok-infra-aff-a400-port-cell:not(.is-wide)>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-c250-port-cell,.ok-infra-rack-device .ok-infra-c250-port-cell>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-c250-e0m,.ok-infra-rack-device .ok-infra-c250-e0m>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-c30-e0m>.ok-infra-fas8020-port,.ok-infra-rack-device .ok-infra-aff-c80-mgmt>.ok-infra-fas8020-port{width:8px!important;height:8px!important;max-width:8px;max-height:8px;aspect-ratio:1 / 1!important}.ok-infra-loose-tray{grid-column:1 / -1;min-height:28px;display:flex;flex-wrap:wrap;gap:4px;align-items:center;padding:4px;border:1px dashed var(--ok-line);border-radius:5px;background:var(--ok-soft)}.ok-infra-loose-device{display:inline-flex;align-items:center;min-height:20px;max-width:100%;padding:2px 6px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-card);color:var(--ok-ink);font-size:10px;cursor:grab}.ok-infra-loose-device.is-controller,.ok-infra-loose-device.is-shelf{border-color:#78adef}.ok-infra-device-layout{min-height:320px;display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.2fr);gap:6px;align-items:start}.ok-infra-device-list{display:grid;align-content:start;gap:4px;max-height:336px;overflow:auto}.ok-infra-device-list-item{display:grid;gap:1px;width:100%;padding:5px 6px;border:1px solid var(--ok-line);border-radius:5px;background:var(--ok-card);color:var(--ok-ink);text-align:left;cursor:pointer}.ok-infra-device-list-item strong,.ok-infra-device-list-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-infra-device-list-item strong{font-size:11px;line-height:1.1}.ok-infra-device-list-item span{color:var(--ok-muted);font-size:10px;line-height:1.1}.ok-infra-device-list-item.is-selected{border-color:var(--ok-accent);background:color-mix(in srgb,var(--ok-accent) 10%,var(--ok-card))}.ok-infra-device-detail{display:grid;gap:6px;padding:6px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-infra-device-detail label{margin-bottom:0}.ok-infra-device-detail .ok-input,.ok-infra-device-detail .ok-select{min-height:26px;padding-top:3px;padding-bottom:3px}.ok-infra-device-position{display:grid;grid-template-columns:1fr 1fr;gap:6px}.ok-infra-rack-summary,.ok-infra-rack-device-summary{display:grid;gap:6px}.ok-infra-rack-summary span,.ok-infra-rack-device-summary span{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;padding:6px 8px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-card)}.ok-infra-rack-summary b,.ok-infra-rack-device-summary b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-muted);font-size:11px;font-weight:700}.ok-infra-rack-summary em,.ok-infra-rack-device-summary em{flex:0 0 auto;color:var(--ok-ink);font-style:normal;font-size:12px;font-weight:700}.ok-infra-rack-device-summary .ok-infra-rack-device-power-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start}.ok-infra-rack-device-summary .ok-infra-rack-device-power-row b{grid-column:1}.ok-infra-rack-device-summary .ok-infra-rack-device-power-row em{grid-column:2}.ok-infra-rack-device-summary .ok-infra-rack-device-power-row small{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:4px;min-width:0;color:var(--ok-muted);font-size:10px}.ok-infra-rack-device-summary .ok-infra-rack-device-power-row i{font-style:normal;padding:1px 5px;border:1px solid var(--ok-line);border-radius:999px;background:var(--ok-soft)}.ok-infra-controller{padding:10px}.ok-infra-controller-face{width:100%;max-width:560px;min-height:96px;display:grid;grid-template-rows:auto 1fr auto;gap:10px;padding:12px;border:1px solid var(--ok-line);border-radius:8px;background:linear-gradient(180deg,var(--ok-table-head),var(--ok-soft));box-shadow:inset 0 1px #ffffff38}.ok-infra-controller-leds{display:flex;gap:6px;justify-content:flex-end}.ok-infra-led{width:8px;height:8px;border-radius:50%;background:var(--ok-muted);opacity:.6}.ok-infra-led.ok{background:var(--ok-ok);opacity:1;box-shadow:0 0 8px color-mix(in srgb,var(--ok-ok) 52%,transparent)}.ok-infra-led.warn{background:var(--ok-warn);opacity:1}.ok-infra-controller-modules{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.ok-infra-controller-modules span{min-height:32px;border:1px solid var(--ok-line);border-radius:5px;background:var(--ok-card)}.ok-infra-controller-ports{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:4px}.ok-infra-controller-ports span{aspect-ratio:1.45;border:1px solid var(--ok-line);border-radius:2px;background:color-mix(in srgb,var(--ok-accent) 14%,var(--ok-card))}.ok-infra-shelf{padding:10px}.ok-infra-shelf-frame{width:100%;height:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(18px,1fr));gap:4px;align-content:center;padding:8px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-table-head)}.ok-infra-shelf-frame span{min-height:28px;border:1px solid var(--ok-line);border-radius:3px;background:linear-gradient(180deg,var(--ok-card),var(--ok-soft));position:relative}.ok-infra-shelf-frame span:after{content:"";position:absolute;left:50%;bottom:4px;width:5px;height:5px;border-radius:50%;transform:translate(-50%);background:var(--ok-muted);opacity:.45}.ok-infra-shelf-frame span.is-active:after{background:var(--ok-ok);opacity:1;box-shadow:0 0 8px color-mix(in srgb,var(--ok-ok) 54%,transparent)}.ok-widget-editor{display:grid;gap:6px;align-items:end;margin-bottom:6px}.ok-widget-editor.compact{grid-template-columns:minmax(0,1fr)}.ok-widget-editor label,.ok-widget-options label{display:grid;gap:3px;margin:0;color:var(--ok-muted);font-size:11px;font-weight:700}.ok-widget-editor .wide{grid-column:1 / -1}.ok-widget-editor .ok-input,.ok-widget-editor .ok-select{min-height:28px;margin:0;padding-top:4px;padding-bottom:4px;border-radius:4px;font-size:12px}.ok-widget-query{min-height:92px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.45}.ok-widget-query.compact{min-height:68px}.ok-widget-json{min-height:120px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px}.ok-widget-options{position:fixed;top:0;right:0;bottom:0;z-index:45;width:min(320px,100vw);display:grid;align-content:start;gap:10px;overflow:auto;border-left:1px solid var(--ok-line);background:var(--ok-soft);padding:12px;box-shadow:-8px 0 24px #1118271f}.ok-widget-options-head{display:flex;justify-content:space-between;gap:8px;align-items:start;padding-bottom:8px;border-bottom:1px solid var(--ok-line)}.ok-widget-options-head h3{margin:0;font-size:14px}.ok-widget-options-head span{display:block;margin-top:2px;color:var(--ok-muted);font-size:12px;overflow-wrap:anywhere}.ok-widget-options-body{display:grid;gap:10px}.ok-widget-options-row{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1fr);gap:8px;align-items:end}.ok-widget-options .ok-input,.ok-widget-options .ok-select,.ok-widget-options .ok-textarea{margin:0}.ok-value-mapping-editor{display:grid;gap:6px;border:1px solid var(--ok-line);border-radius:6px;padding:8px;background:var(--ok-card)}.ok-value-mapping-head{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--ok-muted);font-size:11px}.ok-value-mapping-row{display:grid;grid-template-columns:minmax(0,.85fr) auto minmax(0,.85fr) 30px auto auto;gap:4px;align-items:center}.ok-value-mapping-row>span{color:var(--ok-muted);font-size:12px}.ok-threshold-row{display:grid;grid-template-columns:minmax(0,1fr) 32px auto auto;gap:5px;align-items:center}.ok-inline-check{display:inline-flex!important;grid-auto-flow:column;grid-template-columns:auto auto;align-items:center;justify-content:start;gap:3px!important;color:var(--ok-muted)!important;font-size:10px!important;white-space:nowrap}.ok-inline-check input{margin:0}.ok-value-mapping-row .ok-inline-check{grid-column:auto}.ok-table-column-editor{display:grid;gap:6px;border:1px solid var(--ok-line);border-radius:6px;padding:8px;background:var(--ok-card)}.ok-table-column-item{display:grid;gap:6px}.ok-table-column-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:5px;align-items:center}.ok-table-column-row label{display:flex;align-items:center;gap:6px;min-width:0;margin:0;color:var(--ok-ink);font-size:12px;font-weight:600}.ok-table-column-detail .ok-value-mapping-editor{padding:6px;gap:5px}.ok-table-column-detail .ok-value-mapping-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 28px auto 38px;gap:4px}.ok-table-column-detail .ok-value-mapping-row .ok-input{min-width:0;padding:5px 6px;font-size:11px;border-radius:5px}.ok-table-column-detail .ok-value-mapping-row .ok-color-input{width:28px;height:26px}.ok-table-column-detail .ok-value-mapping-row .ok-button{min-width:0;padding:4px 5px;font-size:11px;white-space:nowrap}.ok-line-summary-column-row{grid-template-columns:minmax(0,1fr) 118px}.ok-table-column-width .ok-input{width:72px}.ok-table-column-name{display:inline-flex;align-items:center;gap:3px;min-width:0}.ok-table-column-renamed{color:var(--ok-accent);font-weight:900}.ok-table-column-detail{display:grid;gap:6px;padding:6px;border:1px solid var(--ok-table-column-line);border-radius:6px;background:var(--ok-soft)}.ok-table-query-row{display:grid;gap:6px;padding-top:6px;border-top:1px solid var(--ok-table-column-line)}.ok-color-input{width:32px;height:28px;padding:2px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-card)}.ok-widget-error{color:var(--ok-err);background:var(--ok-danger-soft);border:1px solid var(--ok-danger-line);border-radius:6px;padding:6px 8px;margin-bottom:6px;font-size:12px}.ok-empty-panel{height:calc(100% - 18px);min-height:46px;display:grid;place-items:center;color:var(--ok-muted);border:1px dashed var(--ok-line);border-radius:8px;background:var(--ok-table-head)}.ok-widget-table{height:calc(100% - 18px);min-height:46px;overflow:auto;border:1px solid var(--ok-line);border-radius:6px;scrollbar-width:none}.ok-widget-table.is-paginated{display:grid;grid-template-rows:minmax(0,1fr) 28px;overflow:hidden}.ok-widget-table-scroll{min-height:0;overflow:visible;scrollbar-width:none}.ok-widget-table.is-paginated .ok-widget-table-scroll{overflow:auto}.ok-widget-table.is-scrolling,.ok-widget-table.is-scrolling .ok-widget-table-scroll{scrollbar-width:thin;scrollbar-color:var(--ok-muted) transparent}.ok-widget-table::-webkit-scrollbar{width:0;height:0}.ok-widget-table.is-scrolling::-webkit-scrollbar{width:6px;height:6px}.ok-widget-table.is-scrolling::-webkit-scrollbar-thumb{background:var(--ok-muted);border-radius:999px}.ok-widget-table-scroll::-webkit-scrollbar{width:0;height:0}.ok-widget-table.is-scrolling .ok-widget-table-scroll::-webkit-scrollbar{width:6px;height:6px}.ok-widget-table.is-scrolling .ok-widget-table-scroll::-webkit-scrollbar-thumb{background:var(--ok-muted);border-radius:999px}.ok-widget-card.is-editing .ok-empty-panel,.ok-widget-card.is-editing .ok-widget-table,.ok-widget-card.is-editing .ok-stat-surface,.ok-widget-card.is-editing .ok-line-widget{height:calc(100% - 18px);min-height:46px}.ok-widget-table table{width:100%;table-layout:fixed;border-collapse:collapse;font-size:12px}.ok-widget-table th,.ok-widget-table td{padding:6px 7px;border-bottom:1px solid var(--ok-line);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ok-widget-table td.is-clickable{cursor:pointer;color:inherit;text-decoration:none}.ok-widget-table td.is-clickable .ok-cell-truncate{cursor:pointer;pointer-events:none}.ok-widget-table td.is-clickable:hover{background:var(--ok-accent-soft)}.ok-cell-truncate{display:block;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:default}.ok-widget-table td.is-highlight-active{animation:ok-cell-highlight-pulse 2.1s ease-in-out infinite}.ok-widget-table th+th,.ok-widget-table td+td{border-left:1px solid var(--ok-table-column-line)}.ok-widget-table th{position:sticky;top:0;background:var(--ok-table-head)}.ok-table-pagination{display:flex;align-items:center;justify-content:flex-end;gap:6px;min-height:28px;padding:3px 6px;border-top:1px solid var(--ok-table-column-line);background:var(--ok-card);color:var(--ok-muted);font-size:11px}.ok-table-pagination button{min-height:20px;border:1px solid var(--ok-line);border-radius:4px;padding:2px 6px;background:var(--ok-input-bg);color:var(--ok-ink);font-size:11px;cursor:pointer}.ok-table-pagination button:disabled{opacity:.45;cursor:not-allowed}.ok-sort-header{width:100%;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:4px;border:0;background:transparent;color:inherit;cursor:pointer;padding:0;font:inherit;font-weight:700}.ok-sort-header span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-sort-header.is-active{color:var(--ok-accent)}.ok-sort-indicator{flex:0 0 auto;font-size:9px;line-height:1}.ok-stat-surface{height:calc(100% - 18px);min-height:46px;display:grid;place-items:center;margin:2px -5px -5px;border-radius:0 0 8px 8px;background:transparent}.ok-stat-surface.is-clickable{cursor:pointer}.ok-stat-surface.is-highlight-active{animation:ok-stat-highlight-pulse 2.1s ease-in-out infinite}.ok-line-widget{--ok-line-summary-row-height: 18px;height:calc(100% - 18px);min-height:46px;display:grid;grid-template-rows:minmax(0,1fr) calc((var(--ok-line-summary-row-height) * 4) + 2px);gap:0;overflow:hidden}.ok-line-chart{min-width:0;min-height:0;overflow:hidden}.ok-line-chart>div{min-height:0!important}.ok-line-summary{height:calc((var(--ok-line-summary-row-height) * 4) + 2px);overflow:auto;border:1px solid var(--ok-line);border-radius:4px;scrollbar-width:none}.ok-line-summary.is-scrolling{scrollbar-width:thin;scrollbar-color:var(--ok-muted) transparent}.ok-line-summary::-webkit-scrollbar{width:0;height:0}.ok-line-summary.is-scrolling::-webkit-scrollbar{width:6px;height:6px}.ok-line-summary.is-scrolling::-webkit-scrollbar-thumb{background:var(--ok-muted);border-radius:999px}.ok-line-summary table{width:100%;table-layout:fixed;border-collapse:collapse;font-size:10px}.ok-line-summary th,.ok-line-summary td{height:var(--ok-line-summary-row-height);padding:0 5px;border-bottom:1px solid var(--ok-table-column-line);line-height:calc(var(--ok-line-summary-row-height) - 1px);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ok-line-summary th+th,.ok-line-summary td+td{border-left:1px solid var(--ok-table-column-line)}.ok-line-summary th{position:sticky;top:0;background:var(--ok-table-head);font-weight:700}.ok-line-hover-tooltip{position:fixed;z-index:10000;max-width:260px;padding:6px 8px;border:1px solid var(--ok-line);border-radius:4px;background:var(--ok-card);color:var(--ok-ink);box-shadow:0 12px 28px #0f172a2e;font-size:11px;line-height:1.35;pointer-events:none;white-space:nowrap}.ok-line-hover-tooltip div{color:var(--ok-muted);margin-bottom:2px}.ok-line-hover-tooltip strong{font-weight:700}.ok-stat{width:100%;height:100%;min-height:46px;display:flex;align-items:center;justify-content:center;gap:.2em;font-size:2.25em;font-weight:800;color:var(--ok-ink);white-space:nowrap}.ok-stat small{align-self:center;color:var(--ok-muted);font-size:.5em;font-weight:800;line-height:1}@keyframes ok-card-highlight-pulse{0%,to{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color) 66%,transparent),0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color) 18%,transparent),0 6px 16px color-mix(in srgb,var(--ok-widget-threshold-color) 16%,transparent);filter:brightness(1)}48%{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color) 96%,transparent),0 0 0 6px color-mix(in srgb,var(--ok-widget-threshold-color) 42%,transparent),0 0 34px color-mix(in srgb,var(--ok-widget-threshold-color) 54%,transparent);filter:brightness(1.08)}}@keyframes ok-rack-card-highlight-pulse{0%,to{box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color) 18%,transparent),0 6px 16px color-mix(in srgb,var(--ok-widget-threshold-color) 16%,transparent);filter:brightness(1)}48%{box-shadow:0 0 0 6px color-mix(in srgb,var(--ok-widget-threshold-color) 42%,transparent),0 0 34px color-mix(in srgb,var(--ok-widget-threshold-color) 54%,transparent);filter:brightness(1.08)}}@keyframes ok-infra-device-highlight-blink{0%,to{background:color-mix(in srgb,var(--ok-widget-threshold-color) 10%,var(--ok-card));filter:brightness(1)}50%{background:color-mix(in srgb,var(--ok-widget-threshold-color) 34%,var(--ok-card));filter:brightness(1.12)}}@keyframes ok-topology-port-highlight-blink{0%,to{background:var(--ok-widget-threshold-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color) 22%,transparent);filter:brightness(1)}50%{background:var(--ok-widget-threshold-color);box-shadow:0 0 0 4px color-mix(in srgb,var(--ok-widget-threshold-color) 42%,transparent),0 0 16px color-mix(in srgb,var(--ok-widget-threshold-color) 48%,transparent);filter:brightness(1.18)}}@keyframes ok-stat-highlight-pulse{0%,to{filter:brightness(1);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-widget-threshold-color, currentColor) 22%,transparent)}48%{filter:brightness(1.2);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color, currentColor) 52%,transparent),0 0 28px color-mix(in srgb,var(--ok-widget-threshold-color, currentColor) 44%,transparent)}}@keyframes ok-cell-highlight-pulse{0%,to{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ok-widget-threshold-color, currentColor) 22%,transparent);filter:brightness(1)}48%{box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--ok-widget-threshold-color, currentColor) 58%,transparent),0 0 18px color-mix(in srgb,var(--ok-widget-threshold-color, currentColor) 38%,transparent);filter:brightness(1.18)}}@keyframes ok-spin{to{transform:rotate(360deg)}}.ok-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:20px;background:#1118278a}.ok-modal-panel{width:min(920px,calc(100vw - 40px));max-height:calc(100vh - 40px);overflow:auto;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card);box-shadow:0 22px 52px #1118273d;padding:12px}.ok-modal-head{display:flex;align-items:start;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--ok-line);margin-bottom:10px}.ok-modal-head h3{margin:0;font-size:15px}.ok-modal-head span{display:block;margin-top:2px;color:var(--ok-muted);font-size:12px}.ok-password-modal{width:min(760px,calc(100vw - 40px))}.ok-alert-modal{width:min(1800px,calc(100vw - 40px))}.ok-alert-modal-grid{display:grid;grid-template-columns:minmax(250px,.82fr) minmax(360px,1.15fr) minmax(300px,.95fr);gap:12px;align-items:start}.ok-alert-modal-grid>*{min-width:0}.ok-alert-widget-picker{display:grid;gap:8px;min-width:0}.ok-alert-widget-list{display:grid;gap:5px;max-height:62vh;overflow:auto;padding-right:2px}.ok-alert-widget-list button{display:grid;gap:2px;text-align:left;border:1px solid var(--ok-line);border-radius:6px;padding:7px 8px;background:var(--ok-input-bg);color:var(--ok-ink);cursor:pointer}.ok-alert-widget-list button:hover,.ok-alert-widget-list button.is-active{border-color:var(--ok-accent);background:color-mix(in srgb,var(--ok-accent) 10%,var(--ok-input-bg))}.ok-alert-widget-list span{color:var(--ok-muted);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-alert-widget-list code{overflow-wrap:anywhere;white-space:normal}.ok-alert-rule-editor{display:grid;gap:10px;min-width:0}.ok-alert-step-card,.ok-alert-live-preview{border:1px solid var(--ok-line);border-radius:8px;padding:10px;background:color-mix(in srgb,var(--ok-card) 92%,var(--ok-input-bg))}.ok-alert-step-title{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ok-alert-step-title>span{display:grid;place-items:center;width:22px;height:22px;border-radius:999px;background:var(--ok-accent);color:#fff;font-size:12px;font-weight:700;flex:0 0 auto}.ok-alert-step-title strong{display:block;font-size:13px;color:var(--ok-ink)}.ok-alert-step-title small{display:block;margin-top:1px;color:var(--ok-muted);font-size:11px;line-height:1.35}.ok-alert-advanced{border:1px dashed var(--ok-line);border-radius:8px;padding:9px 10px;background:var(--ok-input-bg)}.ok-alert-advanced summary{cursor:pointer;font-weight:700;color:var(--ok-ink)}.ok-alert-advanced[open]{display:grid;gap:10px}.ok-alert-template{min-height:88px;resize:vertical}.ok-alert-rule-meta{display:grid;gap:2px;min-width:150px}.ok-alert-rule-meta strong{color:var(--ok-ink);font-size:12px;line-height:1.3;overflow-wrap:anywhere}.ok-alert-rule-meta span{color:var(--ok-muted);font-size:11px;line-height:1.35;overflow-wrap:anywhere}.ok-alert-delivery-filters{align-items:end}.ok-alert-filter-actions{display:flex;align-items:end;min-height:58px}.ok-alert-preview{max-height:300px}.ok-alert-preview tbody tr{cursor:pointer}.ok-alert-preview tbody tr.is-matched td{background:color-mix(in srgb,var(--ok-warn-soft) 72%,var(--ok-card))}.ok-alert-preview tbody tr.is-selected td{background:color-mix(in srgb,var(--ok-accent-soft) 76%,var(--ok-card))}.ok-alert-preview tbody tr.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--ok-accent)}.ok-alert-preview tbody tr.is-test-row td{outline:1px solid color-mix(in srgb,var(--ok-accent) 44%,transparent);outline-offset:-1px}.ok-alert-preview tbody tr:hover td{background:color-mix(in srgb,var(--ok-accent-soft) 58%,var(--ok-card))}.ok-alert-preview td .ok-badge+.ok-badge{margin-left:4px;margin-top:3px}.ok-alert-test-result{border:1px solid var(--ok-line);border-radius:8px;padding:10px;background:color-mix(in srgb,var(--ok-accent) 5%,var(--ok-card))}.ok-alert-live-preview{position:sticky;top:8px;display:grid;gap:10px;max-height:72dvh;overflow:auto}.ok-alert-preview-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;padding-bottom:8px;border-bottom:1px solid var(--ok-line)}.ok-alert-preview-head h4{margin:0 0 2px;font-size:14px}.ok-alert-row-tools{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;padding:8px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-input-bg)}.ok-alert-row-tools>div:first-child{display:grid;gap:2px;min-width:0}.ok-alert-row-tools strong{color:var(--ok-ink);font-size:13px}.ok-alert-row-pager{display:flex;gap:4px;align-items:center}.ok-alert-row-pager .ok-button{min-width:30px;padding:4px 8px;font-size:15px;line-height:1}.ok-alert-preview-summary{display:grid;gap:7px}.ok-alert-preview-summary>div{display:grid;gap:2px;padding:7px 8px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-input-bg)}.ok-alert-preview-summary span,.ok-alert-message-preview span{color:var(--ok-muted);font-size:11px}.ok-alert-preview-summary strong{color:var(--ok-ink);font-size:12px;line-height:1.35;overflow-wrap:anywhere}.ok-alert-message-preview{display:grid;gap:6px;padding:9px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-input-bg)}.ok-alert-message-preview strong{overflow-wrap:anywhere}.ok-alert-message-preview pre{margin:0;max-height:190px;overflow:auto;white-space:pre-wrap;word-break:break-word;color:var(--ok-ink);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.45}.ok-alert-settings-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 10px;padding-bottom:10px;border-bottom:1px solid var(--ok-line)}.ok-alert-settings-tabs button{border:1px solid var(--ok-line);border-radius:6px;padding:7px 10px;background:var(--ok-input-bg);color:var(--ok-ink);font-size:12px;cursor:pointer}.ok-alert-settings-tabs button:hover,.ok-alert-settings-tabs button.is-active{border-color:var(--ok-accent);background:color-mix(in srgb,var(--ok-accent) 12%,var(--ok-card));color:var(--ok-accent-strong)}.ok-inline-loading{display:flex;align-items:center;gap:10px;margin:0 0 10px;padding:10px 12px;border:1px solid var(--ok-accent-line);border-radius:8px;background:var(--ok-accent-soft);color:var(--ok-accent-ink)}.ok-inline-loading strong{display:block;font-size:13px}.ok-inline-loading small{display:block;margin-top:1px;color:var(--ok-muted);font-size:11px}.ok-spinner{width:16px;height:16px;border:2px solid color-mix(in srgb,var(--ok-accent) 22%,transparent);border-top-color:var(--ok-accent);border-radius:50%;animation:ok-spin .72s linear infinite;flex:0 0 auto}.ok-settings-loading-panel{min-height:360px}.ok-settings-load-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin-top:12px}.ok-settings-load-row{display:grid;gap:3px;min-height:68px;padding:10px 12px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card);color:var(--ok-ink)}.ok-settings-load-row span{font-size:12px;color:var(--ok-muted)}.ok-settings-load-row strong{font-size:13px}.ok-settings-load-row small{color:var(--ok-muted);overflow-wrap:anywhere}.ok-settings-load-row.is-ready{border-color:var(--ok-ok-line);background:var(--ok-ok-soft)}.ok-settings-load-row.is-error{border-color:var(--ok-danger-line);background:var(--ok-danger-soft)}.ok-settings-load-row.is-loading,.ok-settings-load-row.is-idle{border-color:var(--ok-accent-line);background:var(--ok-accent-soft)}.ok-empty-panel.compact{height:auto;min-height:0;justify-items:start;padding:10px 12px;margin-bottom:10px}.ok-stat-popup .ok-table-wrap{max-height:58vh;overflow:auto}.ok-subdashboard-modal{width:min(1500px,calc(100vw - 32px));height:min(900px,calc(100vh - 32px));display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden}.ok-subdashboard-modal .ok-modal-head{margin-bottom:6px}.ok-subdashboard-loading{min-height:220px}.ok-subdashboard-rgl{min-height:0;height:100%;max-height:100%;overflow:auto;padding-bottom:6px;scrollbar-width:thin}.ok-subdashboard-rgl::-webkit-scrollbar{width:8px;height:8px}.ok-subdashboard-rgl::-webkit-scrollbar-thumb{background:var(--ok-muted);border-radius:999px}.ok-popup-dashboard-triggers{margin:0}.ok-popup-dashboard-map-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:6px;align-items:end}.ok-public-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:12px}.ok-update-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#11182794}.ok-update-overlay>div{width:min(420px,calc(100% - 32px));background:var(--ok-card);border-radius:8px;padding:18px;border:1px solid var(--ok-line);box-shadow:0 18px 48px #11182738}.ok-update-targets{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin:10px 0}.ok-update-targets label{border:1px solid var(--ok-line);border-radius:8px;padding:8px;background:var(--ok-card)}.ok-snapshot-page{display:grid;gap:8px;min-width:0}.ok-snapshot-head{margin-bottom:0}.ok-snapshot-toolbar{display:grid;grid-template-columns:minmax(220px,360px);gap:8px;align-items:end;margin-bottom:0}.ok-snapshot-toolbar label{display:flex;align-items:center;gap:6px;margin-bottom:0;white-space:nowrap}.ok-snapshot-toolbar .ok-select{min-width:240px;margin-top:0}.ok-snapshot-layout{display:grid;grid-template-columns:280px 300px minmax(0,1fr);gap:8px;align-items:start}.ok-snapshot-list,.ok-snapshot-files{margin-bottom:0}.ok-snapshot-list-head{align-items:flex-start;gap:8px}.ok-snapshot-value-filter{position:relative;width:24px;height:24px}.ok-snapshot-value-filter summary{position:relative;width:24px;height:24px;display:grid;place-items:center;padding:0;border:0;border-radius:4px;background:transparent;color:var(--ok-muted);cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.ok-snapshot-value-filter summary::-webkit-details-marker{display:none}.ok-snapshot-value-filter summary:hover{background:var(--ok-soft-2);color:var(--ok-ink)}.ok-snapshot-value-filter summary[aria-disabled=true]{cursor:not-allowed;opacity:.5}.ok-snapshot-value-filter.is-active summary{background:transparent;color:var(--ok-accent-ink)}.ok-snapshot-value-filter.is-active summary:hover{background:var(--ok-accent-soft)}.ok-snapshot-filter-icon{position:relative;width:15px;height:14px;display:block}.ok-snapshot-filter-icon:before{content:"";position:absolute;left:1px;top:2px;width:13px;height:1.5px;border-radius:999px;background:currentColor;box-shadow:0 4px 0 currentColor;opacity:.88}.ok-snapshot-filter-icon:after{content:"";position:absolute;left:5px;top:7px;width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg)}.ok-snapshot-filter-menu{position:absolute;top:calc(100% + 5px);right:0;z-index:20;width:238px;display:grid;gap:7px;padding:9px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-card);box-shadow:0 16px 42px #11182738}.ok-snapshot-filter-menu-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.ok-snapshot-filter-menu-head strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-ink);font-size:12px}.ok-snapshot-filter-menu-head span{flex:0 0 auto;color:var(--ok-muted);font-size:10px;font-weight:800}.ok-snapshot-filter-menu .ok-input{width:100%;height:28px;padding:4px 7px;font-size:11px}.ok-snapshot-filter-actions{display:grid;grid-template-columns:1fr 1fr;gap:5px}.ok-snapshot-filter-actions button{min-height:25px;border:1px solid var(--ok-line);border-radius:5px;background:var(--ok-soft);color:var(--ok-ink);cursor:pointer;font-size:10px;font-weight:800}.ok-snapshot-filter-actions button:hover:not(:disabled){border-color:var(--ok-accent-line);background:var(--ok-accent-soft);color:var(--ok-accent-ink)}.ok-snapshot-filter-actions button:disabled{cursor:not-allowed;opacity:.45}.ok-snapshot-filter-options{display:grid;gap:2px;max-height:220px;overflow:auto;padding-right:2px}.ok-snapshot-filter-options label{min-width:0;display:grid;grid-template-columns:16px minmax(0,1fr);gap:6px;align-items:center;margin:0;padding:5px 4px;border-radius:5px;color:var(--ok-ink);cursor:pointer;font-size:11px;font-weight:700}.ok-snapshot-filter-options label:hover{background:var(--ok-soft-2)}.ok-snapshot-filter-options input{width:13px;height:13px;margin:0;accent-color:var(--ok-accent)}.ok-snapshot-filter-options span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-snapshot-filter-options p{margin:4px 0;font-size:11px}.ok-snapshot-scroll{display:grid;gap:5px;max-height:calc(100vh - 232px);overflow:auto;padding-right:2px}.ok-snapshot-row{min-width:0;display:grid;gap:2px;width:100%;padding:8px 9px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-card);color:var(--ok-ink);text-align:left;cursor:pointer}.ok-snapshot-row:hover{border-color:var(--ok-accent-line);background:var(--ok-soft-2)}.ok-snapshot-row.is-active{border-color:var(--ok-accent);background:var(--ok-accent-soft);box-shadow:inset 3px 0 0 var(--ok-accent)}.ok-snapshot-row strong,.ok-snapshot-row span,.ok-snapshot-row small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ok-snapshot-row strong{font-size:12px}.ok-snapshot-row span,.ok-snapshot-row small{color:var(--ok-muted);font-size:11px}.ok-snapshot-row-main{display:grid;grid-template-columns:18px minmax(0,1fr);gap:7px;align-items:center}.ok-snapshot-row-main strong{color:var(--ok-ink)}.ok-snapshot-row-sub{padding-left:25px}.ok-snapshot-list-icon{position:relative;width:16px;height:16px;display:inline-block}.ok-snapshot-list-icon.volume:before{content:"";position:absolute;left:2px;top:2px;width:12px;height:11px;border:1px solid color-mix(in srgb,var(--ok-accent) 55%,var(--ok-line));border-radius:2px;background:color-mix(in srgb,var(--ok-accent) 10%,var(--ok-card));box-shadow:inset 0 3px color-mix(in srgb,var(--ok-accent) 18%,transparent)}.ok-snapshot-list-icon.volume:after{content:"";position:absolute;left:4px;top:5px;width:8px;height:1px;background:color-mix(in srgb,var(--ok-accent) 55%,var(--ok-muted));box-shadow:0 3px color-mix(in srgb,var(--ok-accent) 55%,var(--ok-muted))}.ok-snapshot-list-icon.snapshot:before{content:"";position:absolute;left:2px;top:3px;width:12px;height:10px;border:1px solid color-mix(in srgb,var(--ok-warn) 50%,var(--ok-line));border-radius:2px;background:color-mix(in srgb,var(--ok-warn) 10%,var(--ok-card))}.ok-snapshot-list-icon.snapshot:after{content:"";position:absolute;left:5px;top:1px;width:8px;height:10px;border:1px solid color-mix(in srgb,var(--ok-warn) 42%,var(--ok-line));border-radius:2px;background:color-mix(in srgb,var(--ok-warn) 7%,var(--ok-card))}.ok-snapshot-files{min-width:0}.ok-snapshot-filebar{display:grid;grid-template-columns:30px minmax(0,1fr) auto;gap:6px;align-items:center;margin:8px 0}.ok-snapshot-icon-button{width:30px;height:28px;display:grid;place-items:center;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-input-bg);color:var(--ok-ink);cursor:pointer;font-size:14px;font-weight:900}.ok-snapshot-icon-button:disabled{cursor:not-allowed;opacity:.5}.ok-up-icon{width:10px;height:10px;display:block;border-top:2px solid currentColor;border-left:2px solid currentColor;transform:rotate(45deg) translateY(2px)}.ok-snapshot-breadcrumb{min-width:0;min-height:30px;display:flex;flex-wrap:nowrap;gap:6px;align-items:center;overflow-x:auto;padding:3px 6px;border:1px solid var(--ok-line);border-radius:6px;background:var(--ok-soft)}.ok-snapshot-breadcrumb button{position:relative;max-width:220px;min-height:24px;padding:3px 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid var(--ok-line);border-radius:5px;background:var(--ok-card);color:var(--ok-ink);cursor:pointer;font-size:11px;font-weight:800;box-shadow:0 1px #1118270a}.ok-snapshot-breadcrumb-separator{color:var(--ok-muted);font-size:11px;font-weight:900;-webkit-user-select:none;user-select:none}.ok-snapshot-breadcrumb button:hover{border-color:var(--ok-accent-line);background:var(--ok-accent-soft);color:var(--ok-accent-ink)}.ok-snapshot-file-count{white-space:nowrap;color:var(--ok-muted);font-size:11px;font-weight:800}.ok-snapshot-file-wrap{position:relative;max-height:calc(100vh - 430px);min-height:240px;isolation:isolate}.ok-snapshot-file-table{min-width:820px;table-layout:fixed}.ok-snapshot-file-table th{z-index:3;background:var(--ok-table-head);box-shadow:0 1px 0 var(--ok-line)}.ok-snapshot-file-table td{position:relative;z-index:1}.ok-snapshot-file-table th:first-child,.ok-snapshot-file-table td:first-child{width:380px}.ok-snapshot-file-table th:nth-child(2),.ok-snapshot-file-table td:nth-child(2),.ok-snapshot-file-table th:nth-child(3),.ok-snapshot-file-table td:nth-child(3){width:86px;text-align:right}.ok-snapshot-file-table th:nth-child(4),.ok-snapshot-file-table td:nth-child(4){width:148px}.ok-snapshot-file-table th:nth-child(5),.ok-snapshot-file-table td:nth-child(5){width:86px}.ok-snapshot-file-table th:nth-child(6),.ok-snapshot-file-table td:nth-child(6){width:72px}.ok-snapshot-file-table tbody tr{cursor:pointer}.ok-snapshot-file-table tbody tr:hover td{background:var(--ok-soft-2)}.ok-snapshot-file-table tbody tr.is-directory td:first-child strong{color:var(--ok-accent-ink)}.ok-snapshot-file-table tbody tr.is-selected td{background:var(--ok-accent-soft)}.ok-snapshot-file-table tbody tr.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--ok-accent)}.ok-snapshot-parent-row td{color:var(--ok-muted);font-weight:700}.ok-file-cell{min-width:0;display:grid;grid-template-columns:18px minmax(0,1fr);gap:7px;align-items:center}.ok-file-cell strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.ok-file-icon{position:relative;width:16px;height:15px;display:inline-block;flex:0 0 auto}.ok-file-icon.folder:before{content:"";position:absolute;left:1px;top:4px;width:14px;height:10px;border:1px solid color-mix(in srgb,var(--ok-accent) 62%,var(--ok-line));border-radius:2px;background:color-mix(in srgb,var(--ok-accent) 14%,var(--ok-card))}.ok-file-icon.folder:after{content:"";position:absolute;left:2px;top:2px;width:7px;height:4px;border:1px solid color-mix(in srgb,var(--ok-accent) 62%,var(--ok-line));border-bottom:0;border-radius:2px 2px 0 0;background:color-mix(in srgb,var(--ok-accent) 18%,var(--ok-card))}.ok-file-icon.file:before{content:"";position:absolute;left:3px;top:1px;width:11px;height:13px;border:1px solid var(--ok-line);border-radius:2px;background:var(--ok-card)}.ok-file-icon.file:after{content:"";position:absolute;right:2px;top:1px;width:5px;height:5px;border-left:1px solid var(--ok-line);border-bottom:1px solid var(--ok-line);background:var(--ok-soft)}.ok-file-icon.up:before{border-color:var(--ok-muted);background:var(--ok-soft)}.ok-file-icon.up:after{border-color:var(--ok-muted);background:var(--ok-soft)}.ok-link-button{border:0;padding:0;background:transparent;color:var(--ok-accent-ink);cursor:pointer;font:inherit;font-weight:800;text-align:left}.ok-link-button:hover{text-decoration:underline}.ok-snapshot-detail-grid{display:grid;grid-template-columns:1fr;gap:6px;margin:6px 0}.ok-snapshot-meta{min-width:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:3px 8px;padding:7px 8px;border:1px solid var(--ok-line);border-radius:8px;background:var(--ok-soft)}.ok-snapshot-meta h4{grid-column:1 / -1;margin:0;font-size:12px;line-height:16px}.ok-snapshot-meta p{grid-column:1 / -1}.ok-snapshot-meta div{min-width:0;display:grid;grid-template-columns:64px minmax(0,1fr);gap:5px;padding-top:3px;border-top:1px solid var(--ok-table-column-line)}.ok-snapshot-meta div.is-wide{grid-column:span 2;grid-template-columns:64px minmax(0,1fr)}.ok-snapshot-meta span{color:var(--ok-muted);font-size:9px;font-weight:800;text-transform:uppercase}.ok-snapshot-meta strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ok-ink);font-size:10px;font-weight:700}@media(max-width:1180px){.ok-alert-modal-grid{grid-template-columns:minmax(250px,.8fr) minmax(0,1fr)}.ok-alert-live-preview{position:static;grid-column:1 / -1;max-height:none}.ok-snapshot-layout{grid-template-columns:1fr 1fr}.ok-snapshot-files{grid-column:1 / -1}.ok-snapshot-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.ok-snapshot-meta div.is-wide{grid-column:1 / -1}}@media(max-width:900px){.ok-layout,.ok-settings-layout,.ok-dashboard-form,.ok-form-grid,.ok-form-grid.compact,.ok-storage-form,.ok-harvest-form{grid-template-columns:1fr}.ok-subnav{position:static}.ok-subnav-section{padding-bottom:6px}.ok-settings-overview-grid,.ok-license-summary,.ok-license-fingerprint{grid-template-columns:1fr}.ok-license-feature-cell{grid-column:auto}.ok-license-audit-filters,.ok-audit-filters,.ok-license-delete-row{grid-template-columns:1fr}.ok-license-rotation,.ok-section-toolbar{flex-direction:column}.ok-dcim-layout,.ok-dcim-editor-grid,.ok-dcim-detail-grid,.ok-dcim-migration-summary{grid-template-columns:1fr}.ok-modern-actions{justify-content:flex-start}.ok-action-menu>div{left:0;right:auto}.ok-dashboard-topline{flex-direction:column;align-items:flex-start;gap:6px}.ok-dashboard-filterbar,.ok-dashboard-main-filters,.ok-dashboard-time-controls{width:100%}.ok-dashboard-time-controls{margin-left:0;justify-content:flex-start}.ok-dashboard-filterbar label{width:calc(50% - 3px);align-items:flex-start;flex-direction:column;gap:2px}.ok-dashboard-filterbar .ok-select{width:100%}.ok-dashboard-settings-layout{grid-template-columns:1fr}.ok-dashboard-settings-fields .ok-input{width:100%}.ok-subdashboard-item,.ok-popup-dashboard-map-row{grid-template-columns:1fr}.ok-time-popover{left:0;right:auto;grid-template-columns:1fr}.ok-time-absolute{padding-right:0;padding-bottom:8px;border-right:0;border-bottom:1px solid var(--ok-line)}.ok-browser-create,.ok-browser-row{grid-template-columns:1fr}.ok-browser-move{width:100%}.ok-dashboard-picker{grid-template-columns:1fr}.ok-dashboard-meta{justify-content:flex-start}.ok-dashboard-surface.has-widget-options{padding-right:0}.ok-dashboard-head.has-widget-options{padding-right:9px}.ok-widget-options{position:static;width:auto;max-height:none;border-left:0;border-top:1px solid var(--ok-line);box-shadow:none}.ok-sidebar{position:relative;height:auto}.ok-page-head,.ok-pagination{align-items:flex-start;flex-direction:column}.ok-modal-backdrop{padding:16px}.ok-modal-panel{max-height:calc(100dvh - 32px)}.ok-alert-modal{width:calc(100vw - 32px)}.ok-alert-modal-grid{grid-template-columns:1fr}.ok-alert-row-tools{grid-template-columns:1fr;align-items:start}.ok-alert-row-pager{justify-content:flex-start}.ok-widget-editor,.ok-widget-editor.compact{grid-template-columns:1fr}.ok-widget-json{grid-column:auto}.ok-public-grid,.ok-snapshot-toolbar,.ok-snapshot-layout,.ok-snapshot-detail-grid{grid-template-columns:1fr}.ok-snapshot-files{grid-column:auto}.ok-snapshot-value-filter{width:24px;align-self:flex-start}.ok-snapshot-filter-menu{left:0;right:auto;width:min(280px,100%)}.ok-snapshot-scroll,.ok-snapshot-file-wrap{max-height:none}}
