:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#172026;background:#f2f5f4;font-family:Inter,Pretendard,Noto Sans KR,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45}*{box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{min-width:320px;margin:0}button,input,select{font:inherit}button{cursor:pointer}.appShell{background:linear-gradient(#ffffffe0,#f2f5f4f5),#f2f5f4;flex-direction:column;height:100vh;display:flex;overflow:hidden}.topbar{z-index:10;background:#ffffffeb;border-bottom:1px solid #d8e1df;flex:none;justify-content:space-between;align-items:center;gap:18px;padding:14px 18px;display:flex;position:relative}.brand{align-items:center;gap:12px;min-width:270px;display:flex}.brand svg{color:#0f766e}.brand strong{letter-spacing:0;font-size:18px;display:block}.brand span{color:#5f6f6b;margin-top:2px;font-size:12px;display:block}.summaryStrip{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.moduleSwitch{background:#f4f8f7;border:1px solid #d8e1df;border-radius:8px;grid-template-columns:repeat(4,minmax(58px,1fr));gap:4px;padding:4px;display:grid}.moduleSwitch button{color:#53605d;background:0 0;border:0;border-radius:6px;min-width:0;height:32px;font-size:12px;font-weight:900}.moduleSwitch button.active{color:#fff;background:#0f766e}.metric{background:#fff;border:1px solid #d8e1df;border-radius:8px;grid-template-rows:auto auto;grid-template-columns:auto auto;align-items:center;gap:0 7px;min-width:96px;padding:7px 9px;display:grid}.metric svg{color:#0f766e;grid-row:span 2}.metric small{color:#687873;font-size:11px}.metric strong{color:#1e2930;font-size:13px}.workspace{flex:auto;grid-template-rows:minmax(280px,42vh) minmax(0,1fr);grid-template-columns:minmax(340px,1fr) minmax(340px,1fr) 520px;align-items:stretch;gap:14px;min-height:0;padding:14px;display:grid;overflow:hidden}.leftPanel,.rightPanel{display:contents}.canvasPanel,.panelBlock,.emptyState{background:#fffffff0;border:1px solid #d8e1df;border-radius:8px;box-shadow:0 12px 34px #212e2d12}.panelBlock{min-height:0;padding:13px}.canvasPanel{flex-direction:column;grid-area:1/1/auto/3;min-width:0;min-height:0;padding:14px;display:flex;overflow:hidden}.canvasHeader{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.canvasControls{justify-items:end;gap:8px;display:grid}.viewToggle{background:#f4f8f7;border:1px solid #d8e1df;border-radius:8px;grid-template-columns:repeat(2,minmax(58px,1fr));gap:4px;padding:4px;display:grid}.viewToggle button{color:#53605d;background:0 0;border:0;border-radius:6px;height:30px;font-size:12px;font-weight:900}.viewToggle button.active{color:#fff;background:#0f766e}.eyebrow{color:#0f766e;letter-spacing:0;text-transform:uppercase;font-size:11px;font-weight:800}h1{letter-spacing:0;margin:1px 0 0;font-size:22px}.legend{color:#52615d;flex-wrap:wrap;justify-content:flex-end;gap:10px;font-size:12px;display:flex}.legend span{align-items:center;gap:5px;display:inline-flex}.legend i{border-radius:999px;width:20px;height:4px;display:inline-block}.frontKey{background:#14b8a6}.rearKey{background:#f97316}.selectedKey{background:#22d3ee;box-shadow:0 0 0 2px #22d3ee2e}.cableKey{background:#7c3aed}.sectionTitle{align-items:center;gap:7px;margin-bottom:11px;font-weight:800;display:flex}.sectionTitle svg{color:#0f766e}.sectionTitle.spaceBetween{justify-content:space-between}.sectionTitle.spaceBetween>span{align-items:center;gap:7px;display:inline-flex}.formGrid{gap:10px;display:grid}label{color:#53605d;gap:5px;font-size:12px;font-weight:700;display:grid}input,select{color:#172026;background:#fbfdfc;border:1px solid #cdd9d6;border-radius:6px;outline:none;width:100%;min-width:0;height:34px;padding:0 9px}input:focus,select:focus{border-color:#0f9f7a;box-shadow:0 0 0 3px #0f9f7a21}.twoCols{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:9px;display:grid}.fourCols{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.primaryButton,.segmented button,.iconButton{border:0;border-radius:7px;transition:transform .12s,background .12s,opacity .12s}.primaryButton{color:#fff;background:#0f766e;justify-content:center;align-items:center;gap:7px;min-height:36px;font-weight:800;display:inline-flex}.primaryButton.compact{min-height:31px;padding:0 10px}.secondaryButton{color:#334155;background:#fff;border:1px solid #cdd9d6;border-radius:7px;justify-content:center;align-items:center;gap:6px;min-height:31px;padding:0 10px;font-weight:800;display:inline-flex}.primaryButton:hover,.segmented button:hover,.iconButton:hover,.secondaryButton:hover{transform:translateY(-1px)}.primaryButton:disabled,.segmented button:disabled,.iconButton:disabled{cursor:not-allowed;opacity:.55;transform:none}.segmented{background:#f4f8f7;border:1px solid #d8e1df;border-radius:8px;grid-template-columns:repeat(3,1fr);gap:5px;padding:4px;display:grid}.segmented button{color:#53605d;background:0 0;height:34px;font-weight:800}.segmented button.active{color:#fff;background:#0f766e}.hintText{color:#65736f;min-height:38px;margin:9px 0 0;font-size:12px}.pendingPlacement{background:#ecfdf5;border:1px solid #99f6e4;border-radius:8px;gap:8px;padding:9px;display:grid}.pendingPlacement span{color:#0f766e;font-size:12px;font-weight:900}.pendingPlacement div{gap:7px;display:flex}.mobilePendingAction,.mobileBottomNav{display:none}.subSection{border-top:1px solid #d8e1df;gap:10px;margin-top:14px;padding-top:14px;display:grid}.orientationControl{background:#f6faf9;border:1px solid #cdd9d6;border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:7px;min-height:34px;padding:4px 9px;display:grid}.orientationControl span{color:#53605d;gap:1px;font-size:11px;font-weight:800;display:grid}.orientationControl strong{color:#0f766e;font-size:13px}.orientationControl div{gap:5px;display:flex}.iconButton{color:#334155;background:#eef4f2;justify-content:center;align-items:center;width:31px;height:31px;display:inline-flex}.iconButton.danger{color:#b91c1c;background:#fee2e2}.errorBanner{color:#b91c1c;background:#fff1f2;border:1px solid #fecaca;border-radius:8px;flex:none;margin:12px 14px 0;padding:10px 12px;font-weight:800}.floorFrame{background:linear-gradient(135deg,#0f766e14,#0000 30%),linear-gradient(315deg,#f9731614,#0000 34%),#eef4f2;border:1px solid #d9e4e1;border-radius:8px;flex:auto;min-height:0;position:relative;overflow:hidden}.viewportTools{z-index:2;background:#ffffffeb;border:1px solid #d8e1df;border-radius:8px;gap:6px;padding:5px;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 10px 28px #212e2d14}.floorSvg{touch-action:none;width:100%;min-width:620px;height:100%;display:block}.floorTile{fill:#f9fcfb;stroke:#c9d8d4;stroke-width:1px}.floorTile.occupied{fill:#e4ebe9}.floorTile.pending{fill:#a7f3d0;stroke:#0f766e;stroke-width:2px}.floorTile:not(.occupied){cursor:copy}.floorTile.editable{cursor:crosshair}.floorTile:not(.occupied):hover{fill:#ccfbf1;stroke:#0f766e;stroke-width:2px}.rackGroup{cursor:pointer;filter:drop-shadow(0 14px 12px #1f293738)}.rackGroup.selected{filter:drop-shadow(0 16px 12px #1f293733)drop-shadow(0 0 10px #22d3eeb8)}.rackGroup.assetRackSelected{filter:drop-shadow(0 16px 12px #1f293733)drop-shadow(0 0 12px #facc15c7)}.rackGroup:active{cursor:grabbing}.rackGroup.selected polygon{stroke:#22d3ee;stroke-width:3.4px;vector-effect:non-scaling-stroke}.rackGroup.assetRackSelected polygon{stroke:#facc15;stroke-width:3.8px;vector-effect:non-scaling-stroke}.canvasCableLayer{pointer-events:none}.canvasCableLayer.muted{opacity:.42}.canvasCablePath{fill:none;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round;opacity:.86;vector-effect:non-scaling-stroke}.canvasCablePath.topVisible{stroke-width:2.8px;opacity:.96}.canvasCablePath.routeBlocked{stroke-dasharray:7 6;opacity:.72}.canvasCableEndpoint{stroke:#fff;stroke-width:1.4px;vector-effect:non-scaling-stroke}.dragFootprint{pointer-events:none;stroke-width:2.4px;stroke-dasharray:7 5;vector-effect:non-scaling-stroke}.dragFootprint.valid{fill:#14b8a638;stroke:#0f766e}.dragFootprint.invalid{fill:#dc262633;stroke:#dc2626}.frontEdge,.rearEdge{fill:none;stroke-width:5px;stroke-linecap:round}.frontEdge{stroke:#14b8a6}.rearEdge{stroke:#f97316;stroke-dasharray:8 5}.rackFaceStatus,.rackSelectionLayer,.rackNameLayer,.rackNameTag{pointer-events:none}.rackSelectionMark{filter:drop-shadow(0 0 7px #22d3eee6)}.rackSelectionHalo{fill:#22d3ee33;stroke:#22d3ee;stroke-width:5.5px;stroke-linejoin:round;vector-effect:non-scaling-stroke}.rackSelectionBase{fill:#22d3ee14;stroke:#22d3eeb8;stroke-width:3.8px;stroke-linejoin:round;vector-effect:non-scaling-stroke}.rackSelectionMark.assetRackMark{filter:drop-shadow(0 0 9px #facc15f2)}.assetRackMark .rackSelectionHalo{fill:#facc1542;stroke:#facc15;stroke-width:6.2px}.assetRackMark .rackSelectionBase{fill:#facc151f;stroke:#facc15cc}.rackFacePanel{stroke-width:1.1px;vector-effect:non-scaling-stroke}.frontFacePanel{fill:#14b8a61a;stroke:#14b8a699}.rearFacePanel{fill:#f973161a;stroke:#f973168c}.rackFaceAsset{opacity:.88;stroke:#ffffff9e;stroke-width:.55px;vector-effect:non-scaling-stroke}.rackFaceAsset.selectedFaceAsset{opacity:1;stroke:#facc15;stroke-width:2.6px;filter:drop-shadow(0 0 5px #facc15bf)}.rackNameTag rect{fill:#0f172ad1;stroke:#ffffff8a;stroke-width:1px;vector-effect:non-scaling-stroke}.rackNameTag.selectedNameTag rect{fill:#0f172af0;stroke:#14b8a6e6}.rackLabel{paint-order:stroke;stroke:#0f172a80;stroke-width:2px;stroke-linejoin:round;text-anchor:middle;pointer-events:none;letter-spacing:0;fill:#fff;font-size:12px;font-weight:900}.elevationBlock{flex-direction:column;grid-area:1/3/3;padding-bottom:10px;display:flex;overflow:hidden}.elevationLayout{flex:auto;grid-template-rows:minmax(0,1fr) auto;grid-template-columns:1fr 1fr;gap:10px;min-height:0;display:grid}.rackElevation{flex-direction:column;min-width:0;min-height:0;display:flex}.elevationTitle{color:#334155;background:#eef4f2;border:1px solid #d8e1df;border-bottom:0;border-radius:7px 7px 0 0;justify-content:center;align-items:center;height:28px;font-size:12px;font-weight:900;display:flex}.rackShell{--ru-capacity:42;cursor:copy;background:#f8fafc;border:8px solid #26343f;border-radius:0 0 7px 7px;flex:auto;min-height:180px;position:relative;overflow:hidden}.ruRows{grid-template-rows:repeat(var(--ru-capacity), 1fr);z-index:0;display:grid;position:absolute;inset:0}.ruLine{color:#94a3b8;border-bottom:1px solid #94a3b852;padding-left:3px;font-size:9px;line-height:1}.assetLayer{z-index:2;position:absolute;inset:0 6px 0 28px}.cableLayer{z-index:1;pointer-events:none;position:absolute;inset:0 6px 0 28px;overflow:visible}.cablePath{fill:none;stroke-width:1.8px;stroke-linecap:round;opacity:.9;vector-effect:non-scaling-stroke}.assetBlock{z-index:2;color:#fff;text-align:left;cursor:default;border:1px solid #ffffffd1;border-radius:4px;align-content:center;gap:1px;min-height:12px;padding:2px 5px;display:grid;position:absolute;overflow:hidden;box-shadow:inset 0 -12px 20px #00000024}.assetBlock.selectedAssetBlock{z-index:6;outline-offset:2px;border-color:#fff7ed;outline:4px solid #facc15;box-shadow:0 0 0 2px #78350f80,0 0 18px #facc15d9,inset 0 -12px 20px #00000024}.assetBlock.warning,.assetBlock.critical{outline:2px solid #f973168c}.assetBlock.selectedAssetBlock.warning,.assetBlock.selectedAssetBlock.critical{outline:4px solid #facc15}.assetBlock strong,.assetBlock span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.assetBlock strong{font-size:11px}.assetBlock span{opacity:.9;font-size:10px}.resizeHandle{z-index:2;background:#ffffff47;position:absolute}.resizeHandle.top{cursor:ns-resize;height:7px;top:0;left:0;right:0}.resizeHandle.bottom{cursor:ns-resize;height:7px;bottom:0;left:0;right:0}.resizeHandle.left{cursor:ew-resize;z-index:4;width:7px;top:0;bottom:0;left:0}.resizeHandle.right{cursor:ew-resize;z-index:4;width:7px;top:0;bottom:0;right:0}.resizeHandle:hover{background:#ffffffa3}.assetTable{grid-column:1/-1;gap:6px;max-height:88px;padding-top:2px;display:grid;overflow:auto}.assetRow{cursor:pointer}.assetRow.selectedAssetRow{background:#fef9c3;border-color:#facc15;box-shadow:inset 4px 0 #facc15,0 0 0 1px #facc1573}.elevationBlock .assetTable{display:none}.detailAssetTable{max-height:none;margin-top:12px}.editorTabs{background:#fffffff0;border:1px solid #d8e1df;border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));align-self:start;gap:5px;padding:5px;display:grid;box-shadow:0 12px 34px #212e2d12}.editorTabs button{color:#53605d;background:0 0;border:0;border-radius:7px;justify-content:center;align-items:center;gap:6px;min-width:0;height:34px;font-weight:900;display:inline-flex}.editorTabs button.active{color:#fff;background:#0f766e}.editorTabs button:disabled{cursor:not-allowed;opacity:.5}.editorTabs button svg{flex:none}.configTabs{grid-area:2/1}.opsTabs{grid-area:2/2}.detailPane{grid-row:2;margin-top:58px;overflow:auto}.dcSettingsBlock,.rackConfigBlock{grid-column:1}.assetConfigBlock,.cableConfigBlock{grid-column:2}.tabHidden{display:none}.rightPanel>.emptyState{grid-area:1/3/-1}.assetRow{background:#fff;border:1px solid #d8e1df;border-radius:7px;grid-template-columns:auto minmax(78px,.7fr) minmax(120px,1fr) auto;align-items:center;gap:7px;min-height:36px;padding:5px;display:grid}.assetRow strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;overflow:hidden}.assetRow small{color:#65736f;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:11px;overflow:hidden}.typeDot{border-radius:999px;width:9px;height:9px}.emptyLine{color:#65736f;text-align:center;border:1px dashed #cdd9d6;border-radius:7px;padding:12px;font-size:12px}.cableTypeCreate,.cableCreate{margin-top:10px}.cableTypeInputs{grid-template-columns:minmax(0,1fr) 78px}.cableTypeInputs input[type=color],.cableTypeRow input[type=color]{padding:2px}.cableTypeRows,.cableList{gap:6px;margin-top:10px;display:grid}.cableTypeRow,.cableRow{background:#fff;border:1px solid #d8e1df;border-radius:7px;align-items:center;gap:7px;min-height:38px;padding:5px;display:grid}.cableTypeRow{grid-template-columns:auto minmax(96px,1fr) 56px auto auto}.cableRow{grid-template-columns:auto minmax(0,1fr) auto}.cableRow div{gap:2px;min-width:0;display:grid}.cableRow strong,.cableRow small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.cableRow strong{color:#172026;font-size:12px}.cableRow small{color:#65736f;font-size:11px}.colorSwatch{border:1px solid #0f172a2e;border-radius:999px;width:11px;height:22px}.emptyState,.bootScreen{color:#65736f;text-align:center;align-content:center;place-items:center;gap:9px;min-height:260px;padding:20px;display:grid}.emptyState strong,.bootScreen strong{color:#172026}.bootScreen{min-height:100vh}.inventoryWorkspace{flex:auto;min-height:0;padding:14px;overflow:hidden}.inventoryPanel{background:#fffffff5;border:1px solid #d8e1df;border-radius:8px;flex-direction:column;gap:12px;height:100%;min-height:0;padding:14px;display:flex;box-shadow:0 12px 34px #212e2d12}.inventoryHeader{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.inventoryHeader h1{color:#0f1f2a;margin:4px 0 0;font-size:24px;line-height:1.15}.inventoryHeader p{color:#5f6f6b;margin:5px 0 0;font-size:12px;font-weight:800}.inventoryCards{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.inventoryCard{background:#f8fbfa;border:1px solid #d8e1df;border-radius:8px;min-width:0;padding:12px}.inventoryCard span{color:#667772;font-size:11px;font-weight:900;display:block}.inventoryCard strong{color:#0f1f2a;margin-top:3px;font-size:24px;line-height:1;display:block}.inventoryCard small{color:#667772;margin-top:6px;font-size:11px;font-weight:800;display:block}.inventoryFilters{grid-template-columns:minmax(260px,1fr) repeat(3,minmax(150px,220px));align-items:end;gap:10px;display:grid}.inventoryFilters label{min-width:0}.searchField{position:relative}.searchField svg{color:#64748b;pointer-events:none;position:absolute;bottom:10px;left:10px}.searchField input{padding-left:34px}.inventoryActions{grid-template-columns:minmax(0,auto) minmax(360px,1fr);align-items:center;gap:10px;display:grid}.actionButtons{flex-wrap:wrap;gap:7px;min-width:0;display:flex}.bulkEditor{grid-template-columns:auto minmax(130px,180px) minmax(130px,180px) auto;justify-content:end;align-items:center;gap:8px;min-width:0;display:grid}.bulkEditor span{color:#53605d;white-space:nowrap;font-size:12px;font-weight:900}.bulkEditor select{height:31px;min-height:31px}.inventoryMessage{color:#0f766e;background:#ecfdf5;border:1px solid #99f6e4;border-radius:8px;align-items:center;min-height:30px;padding:6px 10px;font-size:12px;font-weight:900;display:flex}.inventoryTableWrap{background:#fff;border:1px solid #d8e1df;border-radius:8px;flex:auto;min-height:0;overflow:auto}.inventoryTable{border-collapse:separate;border-spacing:0;width:100%;min-width:900px}.inventoryTable th,.inventoryTable td{text-align:left;vertical-align:middle;border-bottom:1px solid #e4ecea;padding:10px 12px;font-size:12px}.inventoryTable th{z-index:1;color:#475569;white-space:nowrap;background:#f4f8f7;font-weight:900;position:sticky;top:0}.inventoryTable tbody tr:hover{background:#f8fbfa}.inventoryTable td{color:#27363c}.inventoryTable td strong{color:#0f1f2a;font-size:13px;line-height:1.25;display:block}.inventoryTable td small{color:#667772;margin-top:3px;font-size:11px;line-height:1.25;display:block}.inventoryTable .selectCol{text-align:center;width:38px;min-width:38px;padding-right:6px}.inventoryTable input[type=checkbox]{accent-color:#0f766e;cursor:pointer;width:16px;height:16px}.secondaryButton.compact{min-height:29px;padding:0 11px;font-size:12px}.statusPill,.typeCell{white-space:nowrap;border-radius:999px;align-items:center;gap:6px;min-height:24px;padding:3px 8px;font-size:11px;font-weight:900;display:inline-flex}.statusPill{color:#475569;background:#f8fafc;border:1px solid #d8e1df}.status-planned{color:#475569;background:#f8fafc}.status-installed,.status-active{color:#0f766e;background:#ccfbf1}.status-warning{color:#a16207;background:#fef3c7}.status-critical{color:#b91c1c;background:#fee2e2}.status-retired{color:#64748b;background:#e2e8f0}.typeCell{color:#1f2937;background:#f8fbfa;border:1px solid #e2e8f0}.typeCell i{border-radius:999px;width:9px;height:9px;box-shadow:inset 0 0 0 1px #0f172a1f}@media (width<=1260px){.workspace{grid-template-columns:minmax(300px,1fr) minmax(300px,1fr) 440px;gap:10px;padding:10px}.metric{min-width:82px}}@media (width<=860px){.topbar,.canvasHeader{flex-direction:column;align-items:stretch}.summaryStrip,.legend{justify-content:flex-start}.workspace{grid-template-columns:minmax(390px,1fr) minmax(390px,1fr) minmax(390px,1fr);overflow-x:auto}.canvasPanel{grid-column:1/3}.elevationBlock{grid-column:3}.configTabs,.dcSettingsBlock,.rackConfigBlock{grid-column:1}.opsTabs,.assetConfigBlock,.cableConfigBlock{grid-column:2}.fourCols{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=520px){.workspace{padding:9px}.twoCols,.fourCols{grid-template-columns:1fr}.floorSvg{min-width:540px}}@media (width<=760px){body{min-width:0}.appShell{height:100dvh}.topbar{align-items:stretch;gap:8px;padding:8px 10px}.brand{gap:8px;min-width:0}.brand strong{font-size:16px}.brand span{display:none}.summaryStrip{scrollbar-width:none;grid-auto-columns:minmax(74px,1fr);grid-auto-flow:column;justify-content:start;gap:6px;padding-bottom:1px;display:grid;overflow-x:auto}.summaryStrip::-webkit-scrollbar{display:none}.metric{gap:0 5px;min-width:74px;padding:5px 6px}.metric small{font-size:10px}.metric strong{font-size:12px}.workspace{grid-template-rows:minmax(170px,28dvh) minmax(245px,40dvh) 44px minmax(0,1fr);grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px;padding:8px;overflow:hidden}.canvasPanel{grid-area:1/1/auto/-1;padding:8px;position:relative}.canvasHeader{flex-direction:row;flex:none;align-items:center;margin-bottom:6px}.canvasHeader h1{text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:16px;overflow:hidden}.eyebrow,.legend{display:none}.canvasControls{gap:0}.viewToggle{grid-template-columns:repeat(2,56px)}.viewToggle button{height:36px;font-size:12px}.floorFrame{min-height:0}.floorSvg{width:100%;min-width:0;height:100%}.viewportTools{gap:5px;padding:4px;top:8px;right:8px}.mobilePendingAction{z-index:5;background:#ecfdf5f5;border:1px solid #99f6e4;border-radius:8px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:7px;padding:7px;display:grid;position:absolute;bottom:12px;left:12px;right:12px;box-shadow:0 12px 30px #0f766e2e}.mobilePendingAction span{color:#0f766e;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;font-weight:900;overflow:hidden}.elevationBlock{grid-area:2/1/auto/-1;padding:8px}.elevationBlock .sectionTitle{flex:none;margin-bottom:6px}.elevationLayout{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(185px,1fr) minmax(185px,1fr);padding-bottom:2px;overflow:auto hidden}.rackElevation{min-width:185px}.elevationTitle{height:30px}.rackShell{touch-action:manipulation;border-width:6px;min-height:0}.assetLayer,.cableLayer{inset:0 5px 0 23px}.assetBlock{min-height:14px;padding:1px 4px}.assetBlock strong{font-size:10px}.assetBlock span{font-size:9px}.resizeHandle.top,.resizeHandle.bottom{height:14px}.resizeHandle.left,.resizeHandle.right{width:14px}.configTabs{grid-area:3/1}.opsTabs{grid-area:3/2}.editorTabs{align-self:stretch;padding:4px}.editorTabs button{gap:4px;height:36px;font-size:12px}.detailPane{grid-row:4;margin-top:0;padding:10px;overflow:auto}.dcSettingsBlock,.rackConfigBlock{grid-column:1}.assetConfigBlock,.cableConfigBlock{grid-column:2}.rightPanel>.emptyState{grid-area:2/1/5/-1}.twoCols,.fourCols{grid-template-columns:1fr;gap:8px}.formGrid{gap:9px}label{font-size:11px}input,select,.primaryButton,.secondaryButton{height:44px;min-height:44px;font-size:16px}.primaryButton.compact,.secondaryButton{padding:0 10px}.iconButton{width:40px;height:40px}.orientationControl{min-height:44px}.pendingPlacement{display:none}.assetRow{grid-template-columns:auto minmax(0,1fr) auto;align-items:start;min-height:44px}.assetRow small{white-space:normal;grid-column:2/3}.cableTypeRow{grid-template-columns:auto minmax(0,1fr) auto}.cableTypeRow input[type=color]{grid-column:2}}@media (width<=430px){.workspace{grid-template-rows:minmax(165px,27dvh) minmax(235px,39dvh) 44px minmax(0,1fr);gap:7px;padding:7px}.canvasHeader h1{max-width:112px}.viewToggle{grid-template-columns:repeat(2,50px)}.rackElevation{min-width:178px}.elevationLayout{grid-template-columns:minmax(178px,1fr) minmax(178px,1fr)}.panelBlock{border-radius:7px}}@media (width<=760px){html,body,#root{overflow:hidden}body{min-width:0}.appShell{height:100dvh;padding-bottom:calc(70px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch;overflow:hidden auto}.topbar{align-items:center;gap:0;padding:9px 12px;position:static}.brand{gap:8px;min-width:0}.brand strong{font-size:16px}.brand span,.summaryStrip{display:none}.workspace{flex-direction:column;gap:9px;min-height:auto;padding:8px;display:flex;overflow:visible}.canvasPanel,.elevationBlock,.dcSettingsBlock,.rackConfigBlock,.assetConfigBlock,.cableConfigBlock,.rightPanel>.emptyState{grid-area:auto;width:100%;margin-top:0}.configTabs,.opsTabs{display:none}.mobileMode-floor .elevationBlock,.mobileMode-floor .rackConfigBlock,.mobileMode-floor .assetConfigBlock,.mobileMode-floor .cableConfigBlock,.mobileMode-rack .canvasPanel,.mobileMode-rack .dcSettingsBlock,.mobileMode-rack .assetConfigBlock,.mobileMode-rack .cableConfigBlock,.mobileMode-asset .canvasPanel,.mobileMode-asset .dcSettingsBlock,.mobileMode-asset .rackConfigBlock,.mobileMode-asset .cableConfigBlock,.mobileMode-cable .canvasPanel,.mobileMode-cable .dcSettingsBlock,.mobileMode-cable .rackConfigBlock,.mobileMode-cable .assetConfigBlock{display:none!important}.mobileMode-floor .canvasPanel,.mobileMode-floor .dcSettingsBlock,.mobileMode-rack .elevationBlock,.mobileMode-rack .rackConfigBlock,.mobileMode-asset .elevationBlock,.mobileMode-asset .assetConfigBlock,.mobileMode-cable .elevationBlock,.mobileMode-cable .cableConfigBlock{display:flex!important}.mobileMode-floor .dcSettingsBlock,.mobileMode-rack .rackConfigBlock,.mobileMode-asset .assetConfigBlock,.mobileMode-cable .cableConfigBlock{order:2;display:block!important}.canvasPanel{height:calc(100dvh - 124px - env(safe-area-inset-bottom));order:1;min-height:470px;padding:10px}.canvasHeader{flex-direction:row;flex:none;align-items:center;margin-bottom:8px}.canvasHeader h1{text-overflow:ellipsis;white-space:nowrap;max-width:190px;font-size:17px;overflow:hidden}.eyebrow,.legend,.viewportTools{display:none}.canvasControls{gap:0}.viewToggle{grid-template-columns:repeat(2,54px);padding:3px}.viewToggle button{height:40px;font-size:12px}.floorFrame{min-height:0}.floorSvg{touch-action:none;width:100%;min-width:0;height:100%}.mobilePendingAction{z-index:5;background:#ecfdf5f5;border:1px solid #99f6e4;border-radius:8px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:7px;padding:7px;display:grid;position:absolute;bottom:14px;left:14px;right:14px;box-shadow:0 12px 30px #0f766e2e}.mobilePendingAction span{color:#0f766e;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;font-weight:900;overflow:hidden}.pendingPlacement{display:none}.elevationBlock{height:calc(100dvh + 48px - env(safe-area-inset-bottom));order:1;min-height:780px;padding:10px}.elevationBlock .sectionTitle{flex:none;margin-bottom:8px}.elevationLayout{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(172px,1fr) minmax(172px,1fr);padding-bottom:2px;overflow:auto hidden}.rackElevation{min-width:172px}.elevationTitle{height:32px}.rackShell{touch-action:manipulation;border-width:6px;min-height:0}.assetLayer,.cableLayer{inset:0 5px 0 23px}.assetBlock{min-height:14px;padding:1px 4px}.assetBlock strong{font-size:10px}.assetBlock span{font-size:9px}.resizeHandle.top,.resizeHandle.bottom{height:16px}.resizeHandle.left,.resizeHandle.right{width:16px}.detailPane{padding:12px;overflow:visible}.twoCols,.fourCols{grid-template-columns:1fr;gap:9px}.formGrid{gap:10px}label{font-size:12px}input,select,.primaryButton,.secondaryButton{height:46px;min-height:46px;font-size:16px}.primaryButton.compact,.secondaryButton{padding:0 12px}.iconButton{width:42px;height:42px}.orientationControl{min-height:46px}.assetRow{grid-template-columns:auto minmax(0,1fr) auto;align-items:start;min-height:48px}.assetRow small{white-space:normal;grid-column:2/3}.assetTable,.detailAssetTable,.cableTypeRows,.cableList{max-height:none;overflow:visible}.cableTypeRow{grid-template-columns:auto minmax(0,1fr) auto}.cableTypeRow input[type=color]{grid-column:2}.mobileBottomNav{z-index:30;padding:7px 8px calc(7px + env(safe-area-inset-bottom));background:#fffffff5;border-top:1px solid #cdd9d6;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -12px 32px #0f172a1f}.mobileBottomNav button{color:#53605d;background:0 0;border:0;border-radius:9px;place-items:center;gap:2px;min-width:0;min-height:54px;font-size:11px;font-weight:900;display:grid}.mobileBottomNav button.active{color:#fff;background:#0f766e}.mobileBottomNav button:disabled{opacity:.38}.rightPanel>.emptyState{min-height:240px}}@media (width<=430px){.canvasPanel{min-height:445px}.canvasHeader h1{max-width:150px}.viewToggle{grid-template-columns:repeat(2,50px)}.elevationBlock{min-height:760px}.elevationLayout{grid-template-columns:minmax(166px,1fr) minmax(166px,1fr)}.rackElevation{min-width:166px}}@media (width<=760px){.topbar{flex-wrap:wrap}.brand{width:100%}.moduleSwitch{order:2;grid-template-columns:repeat(4,minmax(0,1fr));width:100%}.moduleSwitch button{height:40px;font-size:12px}.inventoryWorkspace{min-height:auto;padding:8px;overflow:visible}.inventoryPanel{gap:10px;height:auto;min-height:calc(100dvh - 74px);padding:10px;overflow:visible}.inventoryHeader{flex-direction:column;gap:8px}.inventoryHeader h1{font-size:20px}.inventoryHeader .secondaryButton{width:100%}.inventoryCards{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.inventoryCard{padding:10px}.inventoryCard strong{font-size:20px}.inventoryFilters,.inventoryActions{grid-template-columns:minmax(0,1fr);gap:8px}.actionButtons{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.actionButtons .secondaryButton{min-width:0}.bulkEditor{background:#f8fbfa;border:1px solid #d8e1df;border-radius:8px;grid-template-columns:minmax(0,1fr);justify-content:stretch;padding:9px}.bulkEditor select,.bulkEditor .primaryButton{width:100%;min-height:42px}.inventoryMessage{min-height:36px;font-size:12px}.inventoryTableWrap{flex:none;max-height:none;overflow:auto}.inventoryTable{min-width:760px}.inventoryTable th,.inventoryTable td{padding:9px 10px}}
