*,:before,:after{box-sizing:border-box}html,body,#root{margin:0;padding:0}:root{--bg:#0d1117;--panel:#161b22;--panel-2:#1c2230;--line:#2a313c;--line-soft:#222834;--text:#e6edf3;--muted:#8b949e;--muted-2:#6b7280;--blue:#3b82f6;--storage:#2563eb;--compute:#7c3aed;--network:#0d9488;--other:#39414e;--green:#34d399;--amber:#f59e0b;--red:#f87171;--neutral:#3a424e;--radius:10px;--u:15px}*{box-sizing:border-box}html,body{margin:0}body{background:radial-gradient(1200px 600px at 70% -10%, #131a26 0%, var(--bg) 60%);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;padding:28px clamp(16px,4vw,48px) 64px;font:14px/1.5 -apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,Helvetica,Arial,sans-serif}.wrap{max-width:1180px;margin:0 auto}header.page{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:6px;display:flex}h1{letter-spacing:-.01em;margin:0;font-size:22px;font-weight:650}.sub{color:var(--muted);max-width:62ch;margin:4px 0 0;font-size:13px}.verdict{white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:9px;padding:9px 15px;font-size:13px;font-weight:600;display:inline-flex}.verdict.ok{color:var(--green);background:#34d3991a;border-color:#34d39959}.verdict.warn{color:var(--amber);background:#f59e0b1a;border-color:#f59e0b59}.dot{width:9px;height:9px;box-shadow:0 0 0 4px color-mix(in srgb, currentColor 18%, transparent);background:currentColor;border-radius:50%;animation:2s ease-in-out infinite pulse}@keyframes pulse{50%{opacity:.55}}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin:18px 0 2px;display:flex}.btn{appearance:none;border:1px solid var(--line);background:var(--panel);color:var(--text);font:inherit;cursor:pointer;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:550;transition:background .15s,border-color .15s}.btn:hover{background:var(--panel-2);border-color:var(--blue)}.btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.btn.ghost{color:var(--muted);background:0 0}.toolbar-error{color:var(--amber);font-size:12.5px}.layout{grid-template-columns:1fr 320px;align-items:start;gap:22px;margin-top:18px;display:grid}@media (width<=900px){.layout{grid-template-columns:1fr}}.floor{flex-wrap:wrap;align-items:flex-start;gap:26px;display:flex}.rack{flex:1;min-width:230px}.rack h2{align-items:center;gap:8px;margin:0 0 2px;font-size:14px;font-weight:600;display:flex}.rack .meta{color:var(--muted);margin:0 0 10px;font-size:11.5px}.rack .meta .muted{color:var(--muted-2)}.depthtag{letter-spacing:.03em;color:var(--muted);border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:10px;font-weight:600}.frame{gap:6px;display:flex}.ruler{flex-direction:column-reverse;flex:none;width:22px;display:flex}.ruler span{height:var(--u);color:var(--muted-2);text-align:right;font-size:9px;line-height:var(--u);padding-right:3px}.ruler span.major{color:var(--muted)}.bay{background:repeating-linear-gradient(0deg, var(--line-soft) 0 1px, transparent 1px var(--u));border:1px solid var(--line);border-radius:7px;flex-direction:column-reverse;flex:1;display:flex;position:relative;overflow:hidden}.unit{cursor:default;border-radius:5px;justify-content:center;align-items:center;margin:1.5px;transition:transform .15s,box-shadow .15s,filter .15s;display:flex;position:relative;overflow:hidden}.unit .name{text-align:center;text-shadow:0 1px 2px #00000059;z-index:1;padding:0 8px;font-size:11px;font-weight:600;line-height:1.15}.unit .ustag{opacity:.7;font-size:9.5px;font-weight:600;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.unit .flagmark{color:#fde68a}.unit.int:hover{filter:brightness(1.12);transform:translate(2px);box-shadow:inset -3px 0 #fff}.unit.int:focus-visible{outline-offset:-2px;outline:2px solid #fff}.unit.free{border:1px dashed var(--line);color:var(--muted-2);background:repeating-linear-gradient(135deg,#161b22 0 8px,#131820 8px 16px)}.unit.free .name{color:var(--muted-2);text-shadow:none;font-weight:500}.unit.other{color:#c4ccd6;background:linear-gradient(#39414e,#2c333d);border:1px solid #454e5b}.unit.storage{color:#fff;background:linear-gradient(#2563eb,#1d4ed8)}.unit.compute{color:#fff;background:linear-gradient(#7c3aed,#6d28d9)}.unit.network,.unit.av,.unit.patch{color:#fff;background:linear-gradient(#0d9488,#0f766e)}.unit.power{color:#fff;background:linear-gradient(#b45309,#92400e)}.unit.shelf,.unit.blank{color:#c4ccd6;background:linear-gradient(#39414e,#2c333d)}.unit.planned{opacity:.9;border:1px dashed #f59e0b99}.unit.planned:after{content:"";pointer-events:none;background:repeating-linear-gradient(135deg,#0000 0 9px,#0000001a 9px 11px);position:absolute;inset:0}aside{flex-direction:column;gap:14px;display:flex;position:sticky;top:18px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px}.card h3{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 11px;font-size:12px;font-weight:600}.row{justify-content:space-between;align-items:baseline;gap:10px;padding:5px 0;font-size:13px;display:flex}.row .k{color:var(--muted)}.row .v{font-variant-numeric:tabular-nums;font-weight:650}.row.total{border-top:1px solid var(--line);margin-top:4px;padding-top:9px}.budget-row{margin-bottom:13px}.budget-head{justify-content:space-between;margin-bottom:3px;font-size:12.5px;font-weight:600;display:flex}.budget-sub{color:var(--muted);justify-content:space-between;font-size:11px;display:flex}.meter{background:var(--panel-2);border-radius:5px;height:8px;margin:6px 0 2px;display:flex;overflow:hidden}.meter i{height:100%;display:block}.meter i.used{background:linear-gradient(90deg, var(--blue), var(--network))}.legend{flex-direction:column;gap:7px;display:flex}.legend div{color:var(--muted);align-items:center;gap:9px;font-size:12.5px;display:flex}.sw{border-radius:4px;flex:none;width:13px;height:13px}.sw.storage{background:#2563eb}.sw.compute{background:#7c3aed}.sw.network{background:#0d9488}.sw.other{background:#39414e}.sw.planned{background:#1c2230;border:1px dashed #f59e0bb3}.sw.free{border:1px dashed var(--line);background:repeating-linear-gradient(135deg,#161b22 0 5px,#131820 5px 10px)}.notes{color:var(--muted);margin:0;font-size:12px;line-height:1.55}.notes b{color:var(--text);font-weight:600}footer{color:var(--muted-2);margin-top:30px;font-size:11.5px}.tip{z-index:50;pointer-events:none;border:1px solid var(--line);opacity:0;background:#0b0f16;border-radius:8px;max-width:240px;padding:9px 11px;font-size:12px;transition:opacity .12s,transform .12s;position:fixed;transform:translateY(4px);box-shadow:0 8px 24px #00000080}.tip.on{opacity:1;transform:translateY(0)}.tip .tname{margin-bottom:3px;font-weight:650}.tip .tmeta{color:var(--muted)}.rack-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.rack-head h2{cursor:text}.kebab{appearance:none;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex:none;width:26px;height:26px;font-size:16px;line-height:1;transition:background .15s,color .15s}.kebab:hover{background:var(--panel-2);color:var(--text)}.kebab:focus-visible{outline:2px solid var(--blue);outline-offset:1px}.unit.dragging{opacity:.25}.drag-ghost{cursor:grabbing;opacity:.96;border-radius:6px;box-shadow:0 10px 30px #0000008c}.unit.int{cursor:grab}.drop-band{pointer-events:none;z-index:5;border-radius:5px;justify-content:center;align-items:center;font-size:10.5px;font-weight:650;display:flex;position:absolute;left:2px;right:2px}.drop-band.ok{border:1.5px dashed var(--green);color:var(--green);background:#34d39929}.drop-band.bad{border:1.5px dashed var(--red);color:var(--red);background:#f8717124}.drop-band span{text-align:center;padding:0 6px}.inline-edit{width:calc(100% - 12px);font:inherit;color:var(--text);border:1px solid var(--blue);text-align:center;background:#00000073;border-radius:4px;outline:none;padding:2px 6px;font-size:11px;font-weight:600}.rack-head .inline-edit{text-align:left;max-width:220px;font-size:14px}.menu{z-index:100;border:1px solid var(--line);background:#0b0f16;border-radius:9px;min-width:200px;padding:5px;font-size:13px;position:fixed;box-shadow:0 12px 36px #0009}.menu-item{cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:12px;padding:7px 9px;display:flex;position:relative}.menu-item:hover,.menu-item:focus-visible{background:var(--panel-2);outline:none}.menu-item .menu-label{white-space:nowrap;flex:1}.menu-shortcut{color:var(--muted-2);font-variant-numeric:tabular-nums;font-size:11.5px}.menu-caret{color:var(--muted);margin-left:-6px}.menu-item.danger{color:var(--red)}.menu-item.danger:hover{background:#f871711f}.menu-item.disabled{color:var(--muted-2);cursor:default;opacity:.55}.menu-item.disabled:hover{background:0 0}.menu-div{background:var(--line);height:1px;margin:4px 6px}.menu-header{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:6px 9px 5px;font-size:11px;font-weight:600}.menu.submenu{margin-left:3px;top:-5px;left:100%}.btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.wrap{transition:margin-left .2s}.wrap.catalog-open{margin-left:300px}@media (width<=1100px){.wrap.catalog-open{margin-left:288px}}.catalog{z-index:80;background:var(--panel);border-right:1px solid var(--line);flex-direction:column;gap:10px;width:280px;padding:16px 14px;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:6px 0 24px #00000059}.catalog-head{justify-content:space-between;align-items:center;display:flex}.catalog-head h3{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0;font-size:13px;font-weight:600}.catalog-head .muted{color:var(--muted-2)}.catalog-target{color:var(--muted);align-items:center;gap:8px;font-size:12px;display:flex}.catalog-target select{background:var(--panel-2);color:var(--text);border:1px solid var(--line);font:inherit;border-radius:7px;flex:1;padding:6px 8px;font-size:12.5px}.catalog-search{background:var(--panel-2);color:var(--text);border:1px solid var(--line);font:inherit;border-radius:8px;outline:none;padding:9px 11px;font-size:13px}.catalog-search:focus{border-color:var(--blue)}.catalog-chips{flex-wrap:wrap;gap:5px;display:flex}.chip{appearance:none;border:1px solid var(--line);color:var(--muted);font:inherit;cursor:pointer;text-transform:capitalize;background:0 0;border-radius:999px;padding:3px 9px;font-size:11px;transition:background .15s,color .15s}.chip:hover{color:var(--text)}.chip.on{background:var(--blue);border-color:var(--blue);color:#fff}.catalog-results{flex-direction:column;flex:1;gap:4px;margin:2px -4px 0;padding:0 4px;display:flex;overflow-y:auto}.catalog-row{border:1px solid var(--line-soft);background:var(--panel-2);cursor:grab;border-radius:7px;align-items:center;gap:8px;padding:7px 8px;transition:border-color .15s,transform .12s;display:flex}.catalog-row:hover{border-color:var(--blue);transform:translate(2px)}.catalog-row.dragging{opacity:.4}.cat-dot{background:var(--other);border-radius:3px;flex:none;width:9px;height:9px}.cat-network .cat-dot,.cat-av .cat-dot,.cat-patch .cat-dot{background:var(--network)}.cat-storage .cat-dot{background:var(--storage)}.cat-compute .cat-dot{background:var(--compute)}.cat-power .cat-dot{background:#b45309}.catalog-name{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12.5px;font-weight:550;overflow:hidden}.catalog-spec{color:var(--muted-2);font-variant-numeric:tabular-nums;flex:none;font-size:11px}.catalog-empty,.catalog-more{color:var(--muted);padding:8px 4px;font-size:12px}.catalog-more{text-align:center;color:var(--muted-2)}.research{border-top:1px dashed var(--line);flex-direction:column;gap:7px;margin-top:8px;padding-top:10px;display:flex}.research-head{text-transform:uppercase;letter-spacing:.04em;color:var(--muted-2);font-size:11px;font-weight:600}.research-btn{width:100%;padding:8px 10px;font-size:12.5px}.catalog-row.researched{cursor:default;border-style:dashed;border-color:#f59e0b73}.catalog-row.researched:hover{transform:none}.research-spec{color:var(--muted-2);margin-top:1px;font-size:10.5px;font-weight:400;display:block}.research-badge{color:var(--amber);background:#f59e0b1f;border:1px solid #f59e0b59;border-radius:4px;flex:none;padding:1px 4px;font-size:9.5px;font-weight:700}.research-src{color:var(--muted);flex:none;font-size:13px;text-decoration:none}.research-src:hover{color:var(--blue)}.research-add{appearance:none;border:1px solid var(--blue);color:#bcd3ff;font:inherit;cursor:pointer;background:#3b82f61f;border-radius:7px;flex:none;padding:3px 10px;font-size:11.5px;font-weight:600}.research-add:hover{background:var(--blue);color:#fff}.rc-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.rc-head h3{margin:0}.rc-pill{white-space:nowrap;font-variant-numeric:tabular-nums;border:1px solid #0000;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:650}.rc-pill.clean{color:var(--green);background:#34d3991a;border-color:#34d39959}.rc-pill.advisory{border-color:var(--line);color:var(--muted);background:#8b949e1f}.rc-pill.warning{color:var(--amber);background:#f59e0b1f;border-color:#f59e0b59}.rc-pill.error{color:var(--red);background:#f871711f;border-color:#f8717159}.rc-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.rc-item{align-items:stretch;gap:6px;display:flex}.rc-main{text-align:left;background:var(--panel-2);border:1px solid var(--line-soft);cursor:pointer;color:var(--text);font:inherit;border-radius:8px;flex:1;align-items:flex-start;gap:9px;padding:8px 9px;transition:border-color .15s;display:flex}.rc-main:hover{border-color:var(--blue)}.rc-dot{border-radius:50%;flex:none;width:8px;height:8px;margin-top:4px}.rc-item.error .rc-dot{background:var(--red)}.rc-item.warning .rc-dot{background:var(--amber)}.rc-item.advisory .rc-dot{background:var(--muted)}.rc-text{flex-direction:column;gap:2px;min-width:0;display:flex}.rc-title{font-size:12.5px;font-weight:600}.rc-rack{color:var(--muted-2);font-weight:500}.rc-detail{color:var(--muted);font-size:11.5px;line-height:1.4}.rc-fix{appearance:none;border:1px solid var(--blue);color:#bcd3ff;font:inherit;cursor:pointer;white-space:nowrap;background:#3b82f61f;border-radius:8px;flex:none;padding:0 10px;font-size:11.5px;font-weight:600}.rc-fix:hover{background:var(--blue);color:#fff}.seg{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;gap:3px;padding:3px;display:inline-flex}.seg button{appearance:none;color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:6px;padding:5px 14px;font-size:12.5px;font-weight:550;transition:background .15s,color .15s}.seg button:hover{color:var(--text)}.seg button.on{background:var(--blue);color:#fff}.back-hint{color:var(--muted);margin-left:2px;font-size:12px}.floor{position:relative}.side-col{flex-direction:column;gap:14px;display:flex}.cabling{z-index:4;overflow:visible}.unit.back{cursor:default;filter:saturate(.72)brightness(.92);flex-direction:row;justify-content:space-between;align-items:center;gap:6px;padding:0 8px}.unit.back .back-name{white-space:nowrap;text-overflow:ellipsis;text-shadow:0 1px 2px #00000059;font-size:10px;font-weight:600;overflow:hidden}.unit.back .ports{flex:none;align-items:center;gap:5px;display:flex}.unit.back.int:hover{box-shadow:none;filter:saturate(.85)brightness();transform:none}.unit.free.back{background:repeating-linear-gradient(135deg,#11161e 0 8px,#0f131a 8px 16px)}.port{cursor:pointer;background:#0b0f16;border:1.5px solid #fff9;border-radius:50%;flex:none;width:9px;height:9px;padding:0;transition:transform .12s,box-shadow .12s}.port:hover{transform:scale(1.35)}.port.connected{background:var(--pc);border-color:var(--pc)}.port.armed{box-shadow:0 0 0 2px #fff, 0 0 8px 1px var(--blue);transform:scale(1.35)}.cable-bom{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.cable-bom-pill{color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:999px;align-items:center;gap:6px;padding:3px 9px;font-size:11.5px;display:inline-flex}.cable-list{flex-direction:column;gap:5px;margin:0;padding:0;list-style:none;display:flex}.cable-item{border-bottom:1px solid var(--line-soft);align-items:center;gap:9px;padding:5px 0;font-size:12px;display:flex}.cable-item:last-child{border-bottom:0}.cable-sw{border-radius:2px;flex:none;width:12px;height:4px}.cable-ends{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.cable-ends span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.cable-arrow{color:var(--muted)}.cable-x{appearance:none;color:var(--muted-2);cursor:pointer;background:0 0;border:0;border-radius:4px;flex:none;padding:2px 4px;font-size:12px}.cable-x:hover{color:var(--red);background:#f871711a}.unit.flash{z-index:2;animation:1.8s flash}@keyframes flash{0%,to{box-shadow:none}12%,55%{box-shadow:0 0 0 2px #fff, 0 0 16px 3px var(--blue)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition:none!important;animation:none!important}}
