*,*:before{box-sizing:border-box}html,body,#root{margin:0;width:100%;height:100%;overflow:hidden}body{font-family:var(--om-font, Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);color:var(--om-text, #09090b);background:var(--om-bg, #f4f4f5);-webkit-font-smoothing:antialiased;transition:background .2s,color .2s}.planner{height:100vh;overflow:hidden;display:flex;flex-direction:column;background:var(--om-bg);color:var(--om-text)}.topbar{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 20px;border-bottom:1px solid var(--om-border);background:var(--om-surface);gap:16px;flex-shrink:0;overflow:visible;position:relative;z-index:40}.topbarSearch{display:flex;flex-direction:column;align-items:stretch;flex:1;max-width:min(560px,52vw);overflow:visible;padding-top:2px}.searchPanelStatic{display:flex;flex-direction:column;gap:6px;width:100%}.searchInputStaticWrap{position:relative;width:100%;flex:0 0 auto;z-index:50}.searchMetaRow{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;min-height:28px;width:100%;flex-wrap:wrap}.searchFilterRow{display:flex;flex-wrap:wrap;gap:4px;flex:1;min-width:0}.searchFilterChip{font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--om-border);background:var(--om-surface-2);cursor:pointer;color:var(--om-muted);transition:all .15s}.searchFilterChip:hover{border-color:var(--om-border-strong);color:var(--om-text)}.searchFilterChip.active{background:var(--om-primary);color:#fff;border-color:var(--om-primary)}.searchResults{position:absolute;top:calc(100% + 4px);left:0;right:0;margin:0;padding:6px;list-style:none;background:var(--om-surface);border:1px solid var(--om-border);border-radius:var(--om-radius);box-shadow:0 12px 32px var(--om-shadow-lg);z-index:200;max-height:min(70vh,520px);overflow-y:auto;overflow-x:hidden}.searchResults li{margin:0}.searchResults button{width:100%;border:0;background:transparent;text-align:left;padding:10px 12px;border-radius:6px;font-size:13px;line-height:1.4;cursor:pointer;color:var(--om-text);white-space:normal;word-break:break-word}.searchResultMain{font-weight:600}.searchResultMeta,.searchResultFloor{color:var(--om-muted);font-weight:500}.searchResults button:hover,.searchResults button.active{background:var(--om-primary-soft);color:var(--om-primary)}.searchInput{display:block;width:100%;height:38px;box-sizing:border-box;border:1px solid var(--om-border);border-radius:var(--om-radius);padding:8px 12px;font-size:14px;background:var(--om-surface-2);color:var(--om-text);outline:none;transition:border-color .15s;flex:none}.searchInput:focus{border-color:var(--om-primary)}.searchCount{flex:0 0 auto;max-width:42%;font-size:12px;color:var(--om-warning);font-weight:600;white-space:normal;line-height:1.35;text-align:right}.searchCountHidden{visibility:hidden}.topbar h1{margin:0;font-size:20px;font-weight:600;color:var(--om-text)}.topbar p{margin:4px 0 0;color:var(--om-muted);font-size:13px}.coords{color:var(--om-muted);font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;padding:6px 10px;background:var(--om-surface-2);border-radius:6px;border:1px solid var(--om-border);flex-shrink:0;margin-top:2px}.toolToolbar{display:flex;align-items:center;gap:10px;padding:8px 20px;border-bottom:1px solid var(--om-border);background:var(--om-surface);flex-shrink:0}.toolToolbarLabel{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--om-muted);margin-right:4px}.toolBtn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--om-btn-border);background:var(--om-btn-bg);color:var(--om-btn-text);padding:7px 14px;font-size:13px;cursor:pointer;border-radius:6px}.toolBtn:hover{background:var(--om-btn-hover-bg);border-color:var(--om-btn-hover-border);color:var(--om-btn-text)}.toolBtn.active{background:var(--om-btn-active-bg);border-color:var(--om-btn-active-border);color:var(--om-btn-active-text)}.toolBtnIcon{width:16px;height:16px;flex:0 0 auto;display:inline-block}.toolBtnIcon.move{background:linear-gradient(var(--om-btn-text),var(--om-btn-text)) center/2px 10px no-repeat,linear-gradient(var(--om-btn-text),var(--om-btn-text)) 3px 5px/8px 2px no-repeat,linear-gradient(var(--om-btn-text),var(--om-btn-text)) 3px 9px/8px 2px no-repeat}.toolBtn.active .toolBtnIcon.move{background:linear-gradient(var(--om-btn-active-text),var(--om-btn-active-text)) center/2px 10px no-repeat,linear-gradient(var(--om-btn-active-text),var(--om-btn-active-text)) 3px 5px/8px 2px no-repeat,linear-gradient(var(--om-btn-active-text),var(--om-btn-active-text)) 3px 9px/8px 2px no-repeat}.toolBtnIcon.cursorSel{border:2px solid var(--om-btn-text);border-radius:2px;box-sizing:border-box}.toolBtn.active .toolBtnIcon.cursorSel{border-color:var(--om-btn-active-text)}.toolBtnIcon.here{border-radius:50%;background:radial-gradient(circle at center,var(--om-primary) 0 35%,transparent 36%),radial-gradient(circle at center,var(--om-primary) 0 2px,transparent 3px);border:2px solid var(--om-primary)}.toolBtn.active .toolBtnIcon.here{border-color:var(--om-btn-active-text);background:radial-gradient(circle at center,var(--om-btn-active-text) 0 35%,transparent 36%),radial-gradient(circle at center,var(--om-btn-active-text) 0 2px,transparent 3px)}.boardWrap.here-mode{cursor:crosshair}.boardWrap.room-fill-mode{cursor:cell}.boardWrap.room-fill-mode .roomArea{cursor:inherit}.routePath{fill:none;stroke:#16a34a;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:10 6}.hereLabel{fill:#1d4ed8;font-size:11px;font-weight:700;paint-order:stroke;stroke:#fff;stroke-width:3px;stroke-linecap:round}.routeStairLabel{fill:#b45309;font-size:11px;font-weight:700;paint-order:stroke;stroke:#fff;stroke-width:3px;stroke-linecap:round}.toolToolbarHint{margin-left:auto;font-size:12px;color:var(--om-muted)}.boardWrap.select-mode{cursor:default}.boardWrap.cursor-tool-mode{cursor:crosshair}.boardWrap.select-mode .furniture.movable{cursor:grab}.boardWrap.select-mode .furniture.movable:active{cursor:grabbing}.boardWrap.select-mode .planZoneRect.movable{cursor:grab}.boardWrap.select-mode .planZoneRect.movable:active{cursor:grabbing}.workspace{display:flex;flex-direction:row;min-height:0;flex:1;overflow:hidden}.panel{position:relative;flex:0 0 560px;width:560px;min-width:0;border-right:1px solid var(--om-border);padding:10px;background:var(--om-surface);overflow:auto;transition:flex-basis .25s ease,width .25s ease,padding .25s ease,border-color .25s ease}.panel.collapsed{flex:0 0 40px;width:40px;padding:0;overflow:hidden;border-right:1px solid var(--om-border)}.panelToggleButton{position:absolute;top:12px;right:8px;z-index:2;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--om-border);background:var(--om-surface);color:var(--om-text);font-size:12px;padding:6px 10px;cursor:pointer;border-radius:6px;box-shadow:0 2px 8px var(--om-shadow)}.panelToggleButton:hover{background:var(--om-surface-hover)}.panel.collapsed .panelToggleButton{top:0;right:0;left:0;width:100%;height:100%;padding:0;border:0;border-radius:0;box-shadow:none;background:var(--om-surface-2);font-size:18px;line-height:1}.panelToggleIcon{font-size:14px;line-height:1}.panel h2{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--om-muted)}.menuHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-right:96px}.menuHeader h2{margin:0}.actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}.materialMenu{display:grid;grid-template-columns:250px 1fr;background:var(--om-menu-bg);border:1px solid var(--om-menu-border);margin-bottom:18px;min-height:480px;border-radius:var(--om-radius);overflow:hidden;box-shadow:0 6px 16px var(--om-shadow)}.materialMenu.compact{grid-template-columns:1fr;min-height:auto}.menuPrimary{border-right:1px solid var(--om-menu-divider)}.menuRow{width:100%;display:flex;align-items:center;gap:10px;background:var(--om-menu-row-bg);color:var(--om-menu-text);border:0;border-bottom:1px solid var(--om-menu-divider);padding:11px 10px;font-size:14px;cursor:pointer;text-align:left;min-height:44px;line-height:1.15}.menuRow.active{background:var(--om-toolbar-accent);color:#fff}.menuRow:hover{background:var(--om-menu-row-hover-bg);color:var(--om-menu-row-hover-text)}.menuRow.active:hover{background:var(--om-toolbar-accent-hover);color:#fff}.menuDragItem{cursor:grab}.menuDragItem:active{cursor:grabbing}.menuHint{font-size:11px;opacity:.65;font-weight:400}.menuRow.active .menuHint{opacity:.85}.boardWrap.opening-drag-active{cursor:grabbing;-webkit-user-select:none;user-select:none}.boardWrap.opening-drag-active #plan-svg{outline:2px dashed #2563eb;outline-offset:-2px}.openingDragGhost{position:fixed;z-index:1000;pointer-events:none;transform:translate(-50%,-50%);filter:drop-shadow(0 2px 6px rgba(15,23,42,.18))}.openingDragGhost svg{display:block}.menuIcon{width:14px;height:14px;border:1px solid var(--om-icon-stroke);opacity:.95;flex:0 0 auto}.menuRow.active .menuIcon{border-color:#ffffffd9}.menuIcon.striped{background:repeating-linear-gradient(135deg,rgba(63,63,70,.65),rgba(63,63,70,.65) 2px,transparent 2px,transparent 4px)}.menuIcon.rectWall{border-width:2px;border-radius:1px;background:transparent}.boardWrap.wall-rect-mode{cursor:crosshair}.draftRectWall .draftRectFill{fill:#0ea5e914;stroke:none;pointer-events:none}.draftRectWall .draftRectDim{font-size:11px;font-weight:700;fill:#0c4a6e;font-family:JetBrains Mono,Fira Code,monospace;paint-order:stroke;stroke:#fff;stroke-width:2px;stroke-linecap:round}.menuIcon.window{border-width:2px}.menuIcon.door{border-width:1px;border-left-width:3px}.menuIcon.hatch{background:repeating-linear-gradient(45deg,rgba(63,63,70,.75),rgba(63,63,70,.75) 1px,transparent 1px,transparent 3px)}.menuIcon.furniture{border-radius:2px;width:16px}.menuIcon.employee{border-radius:50%;background:#dbeafe;border-color:#2563eb}.boardWrap.employee-place-mode{cursor:copy}.boardWrap.employee-place-mode .furniture.deskEmployeeTarget{cursor:copy;stroke:#2563eb;stroke-width:2}.employeeMarker{cursor:default}.employeeMarker.movable{cursor:grab}.employeeInitials{font-size:11px;font-weight:700;fill:#1e3a8a;pointer-events:none}.employeeNameTag{font-size:12px;font-weight:700;fill:#1e3a8a;paint-order:stroke;stroke:#fff;stroke-width:3px;pointer-events:none}.employeePositionTag{font-size:11px;font-weight:600;fill:#475569;paint-order:stroke;stroke:#fff;stroke-width:3px;pointer-events:none}.deskEmployeeHint{font-size:11px;font-weight:600;fill:#64748b;pointer-events:none}.employeeWarning{color:#b45309}.menuIcon.room{border-radius:3px;background:#fef9c3;border-color:#ca8a04}.menuIcon.zoneMark{border-radius:3px;background:linear-gradient(135deg,#bfdbfe 40%,#93c5fd 40%);border:1px dashed #1d4ed8}.boardWrap.zone-tool-mode{cursor:crosshair}.wallEndpointHandle{fill:#fff;stroke:#2563eb;stroke-width:2;cursor:grab}.wallEndpointHandle:active{cursor:grabbing}.spaceFillArea{pointer-events:auto}.planZoneLabel{font-size:12px;font-weight:700;fill:#1e3a8a;paint-order:stroke;stroke:#fff;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}.roomArea{cursor:default}.roomArea.movable{cursor:grab}.roomAreaLabel{font-size:13px;font-weight:600;fill:#854d0e;pointer-events:none}.roomAreaStat{margin:4px 0 10px;font-size:13px;color:var(--om-hint-text)}.roomInfoCardWrap{overflow:visible;pointer-events:none}.roomInfoCard{box-sizing:border-box;width:100%;padding:12px 14px;border:1px solid var(--om-card-border);border-radius:10px;background:var(--om-card-bg);box-shadow:0 8px 24px var(--om-shadow-lg);font-family:var(--om-font);font-size:13px;color:var(--om-card-text)}.roomInfoCardHeader{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--om-menu-divider);font-size:14px}.roomInfoCardBody{margin:0;display:grid;gap:6px}.roomInfoCardBody div{display:flex;justify-content:space-between;gap:12px}.roomInfoCardBody dt{margin:0;color:var(--om-muted);font-weight:500}.roomInfoCardBody dd{margin:0;text-align:right;font-weight:600}.menuRow .chevron{margin-left:auto;font-size:17px;opacity:.8}.menuFlyout{background:var(--om-menu-flyout-bg);max-height:480px;overflow-y:auto}.menuFlyout button{width:100%;display:block;text-align:left;border:0;border-top:1px solid var(--om-menu-divider);background:var(--om-menu-flyout-bg);color:var(--om-menu-flyout-text);padding:10px 14px 10px 16px;font-size:13px;cursor:pointer}.menuFlyout button:hover{background:var(--om-menu-flyout-hover-bg);color:var(--om-menu-row-hover-text)}.menuFlyout button.active{background:var(--om-menu-flyout-active-bg);color:var(--om-menu-flyout-active-text)}.menuFlyout button.group{display:flex;justify-content:space-between;color:var(--om-menu-flyout-group-text);border-left:1px solid var(--om-menu-flyout-group-text)}.materialMenu.compact .menuPrimary{border-right:none}.templatePicker{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--om-menu-divider)}.templatePicker h2{margin:0 0 8px;font-size:13px;font-weight:600;color:var(--om-text)}.templateGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:280px;overflow-y:auto;padding-right:2px}.templateCard{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border:1px solid var(--om-btn-border);border-radius:var(--om-radius);background:var(--om-btn-bg);cursor:pointer;font-size:10px;color:var(--om-text)}.templateCard.locked{opacity:.55;cursor:not-allowed}.templateCard.locked:hover{border-color:var(--om-btn-border);background:var(--om-btn-bg)}.templateLockBadge{position:absolute;top:2px;right:2px;font-size:9px;line-height:1}.templateCard:hover{border-color:var(--tpl-accent, var(--om-primary));background:var(--om-btn-hover-bg)}.templateCard.active{border-color:var(--tpl-accent, var(--om-primary));background:color-mix(in srgb,var(--tpl-accent, var(--om-primary)) 12%,var(--om-btn-bg));box-shadow:0 0 0 1px var(--tpl-accent, var(--om-primary));font-weight:600;color:var(--om-text)}.templateEmoji{font-size:16px;line-height:1}.templateShort{line-height:1.2;text-align:center}.templateDesc{margin:8px 0 0;font-size:11px;color:var(--om-muted);line-height:1.35}.roomDrawParams{margin-bottom:14px;padding:10px 12px;border:1px solid var(--om-primary);border-radius:var(--om-radius);background:var(--om-primary-soft)}.roomDrawParams h2{margin:0 0 8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--om-primary)}.templateExtrasTitle{margin:12px 0 6px;font-size:12px;font-weight:600;color:var(--om-hint-text)}.menuIcon.bed{border-radius:2px 2px 0 0;background:linear-gradient(#f4f4f5 60%,#a1a1aa 60%)}.menuIcon.kitchen{background:#fef3c7;border-color:#b45309}.menuIcon.bath{background:#ecfeff;border-color:#0891b2;border-radius:0 0 4px 4px}.menuIcon.stall,.menuIcon.shelf{background:#fef9c3;border-color:#ca8a04}.menuIcon.fridge{background:#dbeafe;border-color:#1d4ed8}.menuIcon.cashier,.menuIcon.reception{background:#f4f4f5;border-width:2px}.menuIcon.pallet,.menuIcon.dock{background:#ffedd5;border-color:#9a3412}.menuIcon.bar{background:#44403c;border-color:#1c1917}.menuIcon.showcase,.menuIcon.fitting{background:#dbeafe;border-color:#1d4ed8}.menuIcon.board{background:#166534;border-color:#14532d}.menuIcon.locker{width:10px;background:repeating-linear-gradient(180deg,#e4e4e7,#e4e4e7 3px,#fff 3px,#fff 5px)}.menuIcon.lab{background:#ecfccb;border-color:#4d7c0f}.menuIcon.stretcher{width:8px;height:18px}.menuIcon.machine{background:#e4e4e7;border-width:2px}.menuIcon.conveyor{width:18px;background:repeating-linear-gradient(90deg,#fef3c7,#fef3c7 4px,#fff 4px,#fff 6px)}.menuIcon.parking{width:12px;height:22px;background:repeating-linear-gradient(0deg,#f4f4f5 0,#f4f4f5 4px,#d4d4d8 4px,#d4d4d8 5px)}.menuIcon.barrier{background:#fef2f2;border-color:#dc2626}.menuIcon.ev{background:#dcfce7;border-color:#15803d}.menuIcon.pool{background:#bae6fd;border-color:#0284c7}.menuIcon.pedestal,.menuIcon.kiosk{border-radius:2px;background:#e7e5e4}.menuIcon.unit,.menuIcon.hall{border-radius:4px;background:color-mix(in srgb,var(--tpl-accent, #ca8a04) 15%,#fff)}.menuIcon.mailbox{width:16px;height:8px}.menuIcon.ramp{transform:skew(-12deg);background:#f4f4f5}.menuIcon.comm{background:#ecfeff;border-color:#0f766e}.menuIcon.plot{background:#d7e8d4;border-color:#166534}.menuIcon.fence{background:#fff7ed;border-color:#9a3412}.menuIcon.treadmill{width:8px;height:18px}.menuIcon.rack{border-width:2px}.depthRow.wallShapeRow{grid-template-columns:repeat(3,1fr)}.wallCurveDegControl input[type=range]{width:100%;margin-top:6px}.depthRow.wallCurvePresets{grid-template-columns:repeat(4,1fr)}.depthRow{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.depthRow button,.actions button{border:1px solid var(--om-btn-border);background:var(--om-btn-bg);color:var(--om-btn-text);font-size:13px;font-weight:500;line-height:1.2;padding:10px 8px;cursor:pointer;border-radius:6px}.depthRow button:hover,.actions button:hover{background:var(--om-btn-hover-bg);color:var(--om-btn-text)}.depthRow button.active,.actions button.active{background:var(--om-btn-active-bg);color:var(--om-btn-active-text);border-color:var(--om-btn-active-border)}.depthRow button:disabled,.actions button:disabled{opacity:.45;cursor:not-allowed}.currentMaterial{margin:0 0 16px;color:var(--om-hint-text);font-size:12px;line-height:1.4}.statusText{margin:0 0 14px;color:var(--om-danger);font-size:12px;line-height:1.35}.saveStatus{margin:0 0 10px;color:var(--om-success);font-size:12px;line-height:1.35}.sizeControl{display:grid;gap:6px;color:var(--om-label-text);font-size:12px;margin-bottom:12px}.sizeControl input{border:1px solid var(--om-input-border);background:var(--om-input-bg);color:var(--om-input-text);font-size:13px;padding:8px;border-radius:6px}.zoomControl{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;font-size:13px;color:var(--om-text)}.zoomControl input{grid-column:1 / -1;width:100%;accent-color:var(--om-primary)}.hint{margin-top:14px;color:var(--om-hint-text);font-size:12px;line-height:1.4}.estimateBox{border:1px solid var(--om-estimate-border);background:var(--om-estimate-bg);color:var(--om-estimate-text);font-size:12px;line-height:1.5;padding:10px;display:grid;gap:4px;margin-bottom:14px;border-radius:var(--om-radius)}.boardWrap{overflow:hidden;background:var(--om-bg);flex:1;position:relative;cursor:crosshair}.boardWrap.pan-mode,.boardWrap.panning{cursor:grab}.boardWrap.panning{cursor:grabbing}.boardWrap .board{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:var(--om-board-bg)}.boardWrap .board.boardPanVisual{will-change:transform}#plan-svg{width:100%;height:100%;display:block;-webkit-user-select:none;user-select:none}.gridMinor{stroke:var(--om-grid-minor);stroke-width:1;fill:none}.gridMajor{stroke:var(--om-grid-major);stroke-width:1;fill:none}.draftLine{stroke:#0ea5e9;stroke-width:2;stroke-dasharray:6 4;pointer-events:none}.draftWallHints .draftWallDim{font-size:11px;font-weight:700;fill:#0c4a6e;font-family:JetBrains Mono,Fira Code,monospace;paint-order:stroke;stroke:#fff;stroke-width:2px;stroke-linecap:round}.draftWallHints .draftAngleTag{font-size:10px;font-weight:700;fill:#0369a1;font-family:JetBrains Mono,Fira Code,monospace;paint-order:stroke;stroke:#fff;stroke-width:1.6px;stroke-linecap:round}.wallAngleDim .wallAngleTag{font-size:9px;font-weight:700;fill:#9a3412;font-family:JetBrains Mono,Fira Code,monospace;paint-order:stroke;stroke:#fff;stroke-width:1.6px;stroke-linecap:round}.furniture{stroke:#3f3f46;stroke-width:1.5}.itemLabel{fill:#18181b;font-size:11px;pointer-events:none}.dimension{font-size:11px;fill:#52525b;font-family:JetBrains Mono,Fira Code,monospace}.openingTag{font-size:10px;fill:#111827;font-family:JetBrains Mono,Fira Code,monospace}.modelDims{font-size:10px;fill:#334155;font-family:JetBrains Mono,Fira Code,monospace}.wallLengthTag{font-size:9px;fill:#111827;font-weight:700;font-family:JetBrains Mono,Fira Code,monospace;paint-order:stroke;stroke:#fff;stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round}.deskWorkerName{fill:#18181b;font-size:10px;font-weight:600;pointer-events:none;paint-order:stroke;stroke:#fff;stroke-width:2px;stroke-linecap:round}.deskParamRow{display:flex;gap:8px}.deskParamRow .sizeControl{flex:1}.sizeControlHint{margin:10px 0 4px;font-size:12px;color:var(--om-hint-text);text-transform:uppercase;letter-spacing:.05em}.resizeHandle{fill:#fff7ed;stroke:#ea580c;stroke-width:2;cursor:nwse-resize}.resizeHandle:active{cursor:grabbing}.rotationHandleStem{stroke:#2563eb;stroke-width:1.5;stroke-dasharray:4 3}.rotationHandle{fill:#fff;stroke:#2563eb;stroke-width:2;cursor:grab}.rotationHandle:active{cursor:grabbing}.rotationPresetRow{flex-wrap:wrap}.selectionRect{fill:none;stroke:#f97316;stroke-width:1.5;stroke-dasharray:4 3;pointer-events:none}.selectionLine{stroke:#f97316;stroke-width:2;stroke-dasharray:4 3;pointer-events:none}@media (max-width: 1100px){.workspace{flex-direction:column}.panel{flex:0 0 auto;width:100%;max-width:none;border-right:none;border-bottom:1px solid var(--om-border)}.boardWrap{min-height:320px}.materialMenu{grid-template-columns:1fr}.menuPrimary{border-right:none;border-bottom:1px solid var(--om-menu-divider)}}.topbarActions{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-top:2px}.topbarViewBtn{border:1px solid var(--om-border);background:var(--om-surface-2);color:var(--om-text);border-radius:var(--om-radius);padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;transition:all .15s}.topbarViewBtn:hover,.topbarViewBtn.active{background:var(--om-primary-soft);border-color:var(--om-primary);color:var(--om-primary)}.floorTabs{display:flex;align-items:center;gap:8px;padding:8px 20px;border-bottom:1px solid var(--om-border);background:var(--om-surface);overflow-x:auto;flex-shrink:0}.floorTab{border:1px solid var(--om-border);background:var(--om-surface-2);color:var(--om-text);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.floorTab:before{content:"";display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:8px;background:var(--floor-color, #94a3b8);vertical-align:-1px}.floorTab.active{border-color:var(--om-primary);box-shadow:inset 0 0 0 1px var(--om-primary);background:var(--om-primary-soft)}.floorTabAdd{border:1px dashed var(--om-border-strong);background:var(--om-surface-2);color:var(--om-text);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.floorAddControls{display:inline-flex;align-items:center;gap:6px}.floorLevelPicker{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--om-btn-border);background:var(--om-btn-bg);border-radius:999px;padding:4px 10px;font-size:13px;color:var(--om-muted)}.floorLevelPicker input{width:44px;border:0;background:transparent;font-size:13px;font-weight:600;color:var(--om-text);outline:none;text-align:center}.floorLevelPicker input::-webkit-outer-spin-button,.floorLevelPicker input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.floorTabAdd:hover{background:var(--om-primary-soft);border-color:var(--om-primary);color:var(--om-primary)}.floorTabRemove{border:1px dashed var(--om-danger-border);background:var(--om-danger-soft);color:var(--om-danger);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.floorTabRemove:hover:not(:disabled){background:var(--om-danger-soft);border-color:var(--om-danger);color:var(--om-danger);filter:brightness(1.08)}.floorTabRemove:disabled{opacity:.45;cursor:not-allowed}.floorTabHint{margin-left:auto;font-size:12px;color:var(--om-muted);white-space:nowrap}.stairDirectionLabel{font-size:16px;font-weight:700;fill:#334155;pointer-events:none}.sideViewOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:24px}.sideViewPanel{width:min(1100px,100%);max-height:calc(100vh - 48px);background:#fff;border-radius:14px;box-shadow:0 24px 60px #0f172a38;overflow:hidden;display:flex;flex-direction:column}.sideViewHeader{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;border-bottom:1px solid #e4e4e7}.sideViewHeader h2{margin:0;font-size:20px}.sideViewHeader p{margin:4px 0 0;color:#71717a;font-size:13px}.sideViewClose{border:1px solid #d4d4d8;background:#fff;border-radius:8px;padding:8px 14px;cursor:pointer;font-weight:600}.sideViewBody{display:grid;grid-template-columns:180px 1fr;min-height:520px}.sideViewLabels{display:flex;flex-direction:column;gap:10px;padding:24px 16px;border-right:1px solid #e4e4e7;background:#fafafa}.sideViewLabel{display:flex;align-items:center;gap:10px;border:1px solid #e4e4e7;background:#fff;border-radius:10px;padding:10px 12px;cursor:pointer;text-align:left}.sideViewLabel.active{border-color:#2563eb;background:#eff6ff}.sideViewLabelNum{width:28px;height:28px;border-radius:999px;background:#0f172a;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.sideViewLabelText{display:flex;flex-direction:column;gap:2px;font-size:11px;color:#52525b}.sideViewLabelText strong{font-size:12px;color:#18181b}.sideViewSvg{width:100%;height:100%;min-height:520px}.sideViewSlabTitle{font-size:13px;font-weight:700;fill:#0f172a;pointer-events:none}.sideViewDeskLabel,.sideViewPropLabel{font-size:9px;font-weight:600;fill:#27272a;pointer-events:none}.sideViewStairMarker{font-size:14px;font-weight:700;fill:#334155;pointer-events:none}.sideViewOpeningLabel{font-size:8px;font-weight:600;fill:#1e293b;pointer-events:none}.sideViewSlab.active .sideViewWallFill{filter:drop-shadow(0 8px 16px rgba(37,99,235,.18))}.building3dOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#09090b80;display:flex;align-items:center;justify-content:center;padding:20px}.building3dPanel{width:min(1200px,100%);height:min(720px,calc(100vh - 40px));background:#fafafa;border:1px solid #e4e4e7;border-radius:12px;box-shadow:0 20px 50px #00000026;display:flex;flex-direction:column;overflow:hidden}.building3dHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px 20px;border-bottom:1px solid #e4e4e7;background:#fff}.building3dHeader h2{margin:0;font-size:18px;font-weight:600;color:#09090b}.building3dHeader p{margin:4px 0 0;font-size:13px;color:#71717a}.building3dHeaderActions{display:flex;gap:8px}.building3dBtn{border:1px solid #18181b;background:#18181b;color:#fff;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;cursor:pointer}.building3dBtn--ghost{background:#fff;color:#18181b;border-color:#e4e4e7}.building3dBody{flex:1;display:grid;grid-template-columns:160px 1fr;min-height:0}.building3dFloors{display:flex;flex-direction:column;gap:6px;padding:16px 12px;border-right:1px solid #e4e4e7;background:#fff;overflow:auto}.building3dFloorBtn{display:flex;align-items:center;gap:10px;border:1px solid #e4e4e7;background:#fafafa;border-radius:8px;padding:10px 12px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.building3dFloorBtn:hover{border-color:#a1a1aa}.building3dFloorBtn.active{border-color:#18181b;background:#f4f4f5}.building3dFloorNum{width:26px;height:26px;border-radius:6px;background:#18181b;color:#fff;font-size:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.building3dFloorName{font-size:13px;color:#18181b}.building3dCanvasWrap{position:relative;flex:1;min-height:320px;background:#f4f4f5;overflow:hidden}.building3dIsoWrap{background:linear-gradient(180deg,#f8fafc,#eef2ff);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.building3dIsoWrap.dragging{cursor:grabbing}.building3dIsoSvg{width:100%;height:100%;display:block}.isoLevelNum{font-size:42px;font-weight:700;fill:#0f172a1f;font-family:Inter,system-ui,sans-serif;-webkit-user-select:none;user-select:none}.isoFloorTitle{font-size:11px;font-weight:600;fill:#334155;font-family:Inter,system-ui,sans-serif}.isoDeskLabel,.isoPropLabel{font-size:8px;font-weight:600;fill:#27272a;pointer-events:none}.isoStairMarker{font-size:13px;font-weight:700;fill:#334155}.isoGroundLabel{font-size:8px;font-weight:600;fill:#166534;pointer-events:none}.isoFloorLayer.active .isoLevelNum{fill:#0f172a38}.isoFloorLayer.focus{filter:drop-shadow(0 10px 20px rgba(15,23,42,.12))}.building3dFloorBtn.active .building3dFloorNum{background:var(--floor-color, #18181b)!important;box-shadow:0 0 0 2px #fff,0 0 0 4px var(--floor-color, #18181b)}.building3dCanvasWrap canvas,.building3dCanvas{width:100%!important;height:100%!important;display:block;touch-action:none}.building3dFloorBadge{position:absolute;top:14px;right:14px;z-index:2;background:linear-gradient(135deg,#0d9488,#14b8a6);color:#fff;font-size:13px;font-weight:600;padding:8px 16px;border-radius:8px;box-shadow:0 4px 12px #0d948859;pointer-events:none}.building3dStackLegend{position:absolute;left:12px;top:50%;transform:translateY(-50%);z-index:2;list-style:none;margin:0;padding:10px 12px;background:#ffffffeb;border-radius:10px;border:1px solid #e2e8f0;box-shadow:0 4px 16px #00000014;pointer-events:none;display:flex;flex-direction:column;gap:8px;font-size:12px;color:#334155}.building3dStackLegend li{display:flex;align-items:center;gap:8px}.building3dStackLegendNum{width:22px;height:22px;border-radius:5px;background:var(--legend-color, #64748b);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.building3dDeskMarker{display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;-webkit-user-select:none;user-select:none}.building3dDeskMarkerIcon{width:32px;height:32px;border-radius:50%;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000001f;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1}.building3dMarkerLabel{font-size:10px;font-weight:600;color:#334155;background:#fffffff2;padding:2px 6px;border-radius:4px;white-space:nowrap;box-shadow:0 1px 4px #0000001a}.building3dEmpty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:3;background:#f1f5f9;color:#64748b;font-size:14px;text-align:center;padding:24px}.building3dEmpty p{margin:0}.building3dHint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);margin:0;font-size:12px;color:#71717a;background:#ffffffe6;padding:4px 12px;border-radius:999px;border:1px solid #e4e4e7;pointer-events:none}.planner.readOnly .materialMenu,.planner.readOnly .menuHeader{display:none}.readOnlyBanner{padding:12px 14px;border:1px solid var(--om-banner-border);border-radius:10px;background:var(--om-banner-bg);color:var(--om-banner-text);margin-bottom:16px}.readOnlyBanner strong{display:block;margin-bottom:6px;font-size:14px}.readOnlyBanner p{margin:0;font-size:13px;line-height:1.45}.readOnlyRoomMeta{display:grid;gap:8px;margin-bottom:16px;font-size:13px}.readOnlyRoomMeta div{display:flex;justify-content:space-between;gap:12px}.readOnlyRoomMeta span{color:var(--om-muted)}.planner.readOnly .roomArea,.planner.readOnly .planZoneRect,.planner.readOnly .furniture,.planner.readOnly .employeeMarker{cursor:pointer}.readOnlyBoardDock{position:absolute;right:12px;bottom:12px;z-index:60;display:flex;flex-direction:column;gap:6px;align-items:stretch}.readOnlyDockBtn{padding:8px 12px;border-radius:var(--om-radius);border:1px solid var(--om-btn-border);background:var(--om-surface);font-size:12px;font-weight:600;color:var(--om-text);cursor:pointer;box-shadow:0 2px 10px var(--om-shadow-lg);white-space:nowrap}.readOnlyDockBtn:hover:not(:disabled){background:var(--om-btn-hover-bg);border-color:var(--om-btn-hover-border)}.readOnlyDockBtn:disabled{opacity:.45;cursor:default}.readOnlyDockBtn.active{background:var(--om-primary);border-color:var(--om-primary);color:#fff}.readOnlyBubbleCard{position:fixed;padding:12px 36px 12px 12px;border-radius:10px;border:1px solid var(--om-card-border);background:var(--om-card-bg);box-shadow:0 12px 40px var(--om-shadow-lg);font-size:13px;color:var(--om-card-text);max-height:min(70vh,320px);overflow:auto}.readOnlyBubbleClose{position:absolute;top:6px;right:8px;width:28px;height:28px;border:0;border-radius:6px;background:transparent;font-size:20px;line-height:1;color:var(--om-muted);cursor:pointer}.readOnlyBubbleClose:hover{background:var(--om-surface-hover);color:var(--om-text)}.readOnlyBubbleTitle{margin:0 0 10px;font-size:15px;font-weight:700;color:var(--om-text);padding-right:8px}.readOnlyBubbleDl{margin:0;display:grid;gap:8px}.readOnlyBubbleDl div{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.readOnlyBubbleDl dt{margin:0;color:var(--om-muted);font-weight:500;flex:0 0 auto}.readOnlyBubbleDl dd{margin:0;text-align:right;font-weight:600;color:var(--om-text)}.plannerToast{position:fixed;top:12px;left:50%;transform:translate(-50%);z-index:300;display:flex;align-items:flex-start;gap:10px;max-width:min(560px,calc(100vw - 24px));padding:12px 14px;border:1px solid var(--om-toast-border);border-radius:10px;background:var(--om-toast-bg);color:var(--om-toast-text);font-size:14px;line-height:1.4;box-shadow:0 10px 28px var(--om-shadow-lg);pointer-events:auto}.plannerToastIcon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#dc2626;color:#fff;font-size:13px;font-weight:700;line-height:1}.plannerToastText{margin:0;flex:1;padding-top:2px}.plannerToastClose{flex-shrink:0;border:0;background:transparent;color:var(--om-toast-text);font-size:20px;line-height:1;padding:0 2px;cursor:pointer;opacity:.75}.shareLoadError{margin:0 24px 8px;padding:10px 14px;border:1px solid var(--om-toast-border);border-radius:var(--om-radius);background:var(--om-toast-bg);color:var(--om-toast-text);font-size:13px}.shareTopBtn.copied,.shareLinkBtn.copied{border-color:var(--om-success-border);background:var(--om-success-soft);color:var(--om-success)}.shareLinkBtn{grid-column:1 / -1;font-weight:600}.themeTopBtn{min-width:42px;justify-content:center;font-size:16px;padding-inline:10px}.topbarViewBtn.shareTopBtn{text-decoration:none}.view3dOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#02060ed1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:stretch;justify-content:center;padding:16px}.view3dShell{width:100%;max-width:1320px;margin:0 auto;display:flex;flex-direction:column;background:#0f1419;border:1px solid #1e293b;border-radius:16px;overflow:hidden;box-shadow:0 32px 80px #0000008c}.view3dTopbar{display:flex;align-items:center;gap:20px;padding:14px 20px;border-bottom:1px solid #1e293b;background:#0c1018;flex-shrink:0}.view3dTopbarLeft{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.view3dLogo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.view3dTitle{margin:0;font-size:16px;font-weight:600;color:#f1f5f9}.view3dSubtitle{margin:2px 0 0;font-size:12px;color:#64748b}.view3dModeSwitch{display:flex;background:#1a2332;border-radius:10px;padding:3px;gap:2px}.view3dModeBtn{border:none;background:transparent;color:#94a3b8;font-size:13px;font-weight:500;padding:8px 18px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.view3dModeBtn:hover{color:#e2e8f0}.view3dModeBtn.active{background:#334155;color:#f8fafc}.view3dTopbarActions{display:flex;align-items:center;gap:8px}.view3dIconBtn{width:36px;height:36px;border:1px solid #334155;background:#1a2332;color:#cbd5e1;border-radius:8px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.view3dIconBtn:hover{background:#334155}.view3dCloseBtn{border:none;background:#ef4444;color:#fff;font-size:13px;font-weight:600;padding:8px 16px;border-radius:8px;cursor:pointer}.view3dCloseBtn:hover{background:#dc2626}.view3dMain{flex:1;display:flex;min-height:0}.view3dFloors{width:148px;flex-shrink:0;display:flex;flex-direction:column;gap:6px;padding:12px 10px;border-right:1px solid #1e293b;background:#0c1018;overflow-y:auto}.view3dFloorCard{display:flex;align-items:center;gap:8px;border:1px solid transparent;background:transparent;border-radius:10px;padding:10px;cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.view3dFloorCard:hover{background:#1a2332}.view3dFloorCard.active{background:#1e293b;border-color:#475569}.view3dFloorCard.on-route{border-color:#22c55e;box-shadow:inset 0 0 0 1px #22c55e59}.view3dFloorDot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.view3dFloorLevel{font-size:14px;font-weight:700;color:#f1f5f9;min-width:14px}.view3dFloorLabel{font-size:11px;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view3dViewport{flex:1;position:relative;min-height:400px;background:#121820}.view3dCanvas{width:100%!important;height:100%!important;display:block;touch-action:none}.view3dControls{position:absolute;bottom:0;left:0;right:0;display:flex;flex-wrap:wrap;justify-content:center;gap:12px 20px;padding:10px 16px;background:linear-gradient(transparent,#0c1018eb);font-size:11px;color:#64748b;pointer-events:none}.view3dRouteHint{flex:1 1 100%;text-align:center;color:#4ade80;font-weight:600}.view3dEmpty{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px;text-align:center;color:#94a3b8}.view3dEmptyTitle{margin:0;font-size:16px;font-weight:600;color:#e2e8f0}.view3dEmpty p{margin:0;font-size:13px;max-width:280px}.view3dObjTip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;background:#0f172af0;border:1px solid #475569;border-radius:8px;box-shadow:0 8px 24px #00000073;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.view3dObjTipTitle{font-size:13px;font-weight:600;color:#f8fafc;line-height:1.2}.view3dObjTipMeta{font-size:11px;color:#94a3b8;line-height:1.2}.view3dOpeningLabel{padding:4px 10px;border-radius:999px;border:2px solid currentColor;background:#0c1018eb;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;box-shadow:0 4px 12px #00000059}.view3dLegendGroup{display:inline-flex;flex-wrap:wrap;align-items:center;gap:10px 14px;padding:4px 10px;border-radius:999px;background:#0f172a8c}.view3dLegendItem{display:inline-flex;align-items:center;gap:6px;color:#cbd5e1;font-weight:600}.view3dLegendSwatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.25);flex-shrink:0}.view3dLegendSwatch--door{background:#f59e0b}.view3dLegendSwatch--window{background:linear-gradient(135deg,#38bdf8,#0ea5e9)}.view3dLegendSwatch--wall{background:#f1f5f9}.view3dStackLabel{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#0c1018eb;border:2px solid #38bdf8;box-shadow:0 4px 16px #00000073;white-space:nowrap;font-size:12px;color:#f8fafc}.view3dStackLabelNum{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:999px;background:#1e293b;font-weight:800;font-size:11px}.view3dStackLabelName{font-weight:600}:root,[data-theme=light]{--om-canvas-bg: #e8edf5;--om-header-bg: #ffffff;--om-radius-lg: 14px;--om-radius-xl: 18px;--om-shadow-md: 0 4px 24px rgba(15, 23, 42, .08);--om-shadow-lg: 0 12px 40px rgba(15, 23, 42, .12);--om-gradient-brand: linear-gradient(135deg, #4f46e5 0%, #2563eb 100%)}[data-theme=dark]{--om-canvas-bg: #0f1117;--om-header-bg: #14161d;--om-shadow-md: 0 4px 24px rgba(0, 0, 0, .35);--om-shadow-lg: 0 12px 40px rgba(0, 0, 0, .45);--om-gradient-brand: linear-gradient(135deg, #6366f1 0%, #3b82f6 100%)}.planner{background:var(--om-canvas-bg)}.plannerHeader.topbar{align-items:flex-start;padding:10px 16px 12px;gap:12px;background:var(--om-header-bg);border-bottom:1px solid var(--om-border);box-shadow:0 1px 0 var(--om-shadow);overflow:visible}.plannerHeaderActions.topbarActions{flex-wrap:nowrap;gap:6px;padding-top:4px}.plannerHeaderBrand{display:flex;align-items:center;gap:12px;flex-shrink:0;min-width:0;max-width:240px}.plannerLogo{width:40px;height:40px;border-radius:12px;background:var(--om-gradient-brand);color:#fff;display:grid;place-items:center;font-size:18px;font-weight:700;box-shadow:0 4px 14px #2563eb59;flex-shrink:0}.plannerHeaderBrand h1{font-size:15px;font-weight:700;letter-spacing:-.02em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plannerHeaderSubtitle{margin:2px 0 0;font-size:11px;color:var(--om-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbarSearch{max-width:min(720px,100%);flex:1;padding-top:2px;min-width:280px}.searchInput{height:42px;border-radius:999px;padding:0 16px 0 40px;background:var(--om-surface-2);border-color:transparent;box-shadow:inset 0 0 0 1px var(--om-border);font-size:14px}.searchInput:focus{box-shadow:inset 0 0 0 2px var(--om-primary);border-color:transparent}.searchInputStaticWrap:before{content:"⌕";position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--om-muted);pointer-events:none;z-index:1}.searchFilterChip{font-size:11px;padding:5px 11px;border-radius:999px;background:var(--om-surface)}.searchFilterChip.active{background:var(--om-primary);box-shadow:0 2px 8px #2563eb40}.topbarViewBtn{border-radius:999px;padding:8px 12px;font-size:12px;font-weight:500;background:var(--om-surface-2);border-color:transparent;box-shadow:inset 0 0 0 1px var(--om-border);white-space:nowrap}.topbarViewBtn:hover,.topbarViewBtn.active{background:var(--om-primary-soft);border-color:transparent;box-shadow:inset 0 0 0 1px var(--om-primary);color:var(--om-primary)}.topbarViewBtn.shareTopBtn.copied{background:var(--om-success-soft);color:var(--om-success);box-shadow:inset 0 0 0 1px var(--om-success-border)}.plannerControlBar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--om-header-bg);border-bottom:1px solid var(--om-border);flex-shrink:0;overflow-x:auto}.plannerControlBar .floorTabs{border-bottom:0;padding:0;background:transparent;flex:1;min-width:0}.plannerControlBar .toolToolbar{border-bottom:0;padding:0;background:transparent;flex-shrink:0;margin-left:auto}.plannerControlBar .toolBtn{border-radius:999px;padding:7px 12px;font-size:12px;background:var(--om-surface-2);border-color:transparent;box-shadow:inset 0 0 0 1px var(--om-border)}.plannerControlBar .toolBtn.active{background:var(--om-primary);color:#fff;box-shadow:0 2px 10px #2563eb4d}.plannerControlBar .toolToolbar{flex-wrap:wrap;max-width:min(720px,55vw)}.plannerControlBar .toolToolbarHint{flex:1 1 100%;order:99;margin:4px 0 0;padding:4px 10px;font-size:11px;line-height:1.35;color:var(--om-muted);background:var(--om-surface-2);border-radius:999px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.floorTab{padding:7px 16px;font-size:12px;background:var(--om-surface);border-color:transparent;box-shadow:inset 0 0 0 1px var(--om-border)}.floorTab.active{background:var(--om-surface);border-color:transparent;box-shadow:inset 0 0 0 2px var(--om-primary),0 2px 10px #2563eb26;color:var(--om-primary)}.floorTabHint{font-size:11px;padding:4px 10px;border-radius:999px;background:var(--om-surface-2)}.workspace{padding:12px;gap:12px;background:var(--om-canvas-bg)}.panel{flex:0 0 min(420px,36vw);width:min(420px,36vw);border:1px solid var(--om-border);border-radius:var(--om-radius-xl);background:var(--om-surface);box-shadow:var(--om-shadow-md);padding:12px}.panelBody{min-width:0}.panel h2,.menuHeader h2{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--om-muted);text-transform:uppercase}.materialMenu{border-radius:var(--om-radius-lg);border-color:var(--om-border);box-shadow:none;background:var(--om-surface-2)}.menuRow.active,.menuFlyoutItem.active{background:var(--om-primary-soft)!important;color:var(--om-primary)!important}.templateCard{border-radius:12px;transition:transform .15s,box-shadow .15s}.templateCard.active{box-shadow:0 0 0 2px var(--om-primary)}.estimateBox{border-radius:var(--om-radius-lg)}.actions button{border-radius:10px}.boardWrap{border-radius:var(--om-radius-xl);border:1px solid var(--om-border);box-shadow:var(--om-shadow-md);background:var(--om-board-bg);overflow:hidden}.boardCoordsBadge{position:absolute;bottom:14px;left:14px;z-index:30;margin-top:0;border-radius:999px;padding:6px 12px;font-size:11px;background:color-mix(in srgb,var(--om-surface) 92%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--om-shadow-md);pointer-events:none}.plannerToast{border-radius:var(--om-radius-lg);box-shadow:var(--om-shadow-lg)}.appNav{height:52px;padding:0 20px;background:var(--om-header-bg);border-bottom:1px solid var(--om-border)}.appNavBrand{display:inline-flex;align-items:center;gap:10px;text-transform:none;letter-spacing:-.02em;font-size:15px;font-weight:700}.appNavBrand:before{content:"⌂";width:28px;height:28px;border-radius:8px;background:var(--om-gradient-brand);color:#fff;display:grid;place-items:center;font-size:14px}.plannerMapsBar{padding:8px 20px;background:var(--om-header-bg);border-bottom:1px solid var(--om-border)}.mapSwitcher{gap:8px}.mapSwitcherItem{border-radius:999px;padding:6px 14px;font-size:12px;border:1px solid var(--om-border);background:var(--om-surface-2)}.mapSwitcherItem.active{background:var(--om-primary);color:#fff;border-color:var(--om-primary);box-shadow:0 2px 8px #2563eb40}.mapSwitcherCreate{border-radius:999px}@media (max-width: 1200px){.plannerHeaderSubtitle{display:none}.plannerHeaderBrand{max-width:160px}.topbarViewBtn{padding:8px 10px;font-size:11px}}.authPage{background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(79,70,229,.12),transparent),var(--om-bg)}.authCard,.billingShell{animation:omScaleIn .4s ease both}.authBrand{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:700;letter-spacing:-.02em;text-transform:none;color:var(--om-text)}.authBrand:before{content:"⌂";width:32px;height:32px;border-radius:10px;background:var(--om-gradient-brand);color:#fff;display:grid;place-items:center;font-size:15px;box-shadow:0 4px 14px #4f46e54d}.authCard{border-radius:var(--om-radius-xl);box-shadow:var(--om-shadow-md)}.authSubmit,.billingSelectBtnPrimary,.billingContinueBtn{border-radius:999px}.billingPage{background:radial-gradient(ellipse 90% 50% at 50% -5%,rgba(79,70,229,.1),transparent),var(--om-bg)}.billingCard{border-radius:var(--om-radius-xl);transition:transform .15s,box-shadow .15s}.billingCard:hover{transform:translateY(-2px);box-shadow:var(--om-shadow-lg)}.billingCardPopular{box-shadow:0 8px 28px #4f46e52e}@media (max-width: 768px){.plannerHeaderActions.topbarActions{flex-wrap:wrap}.topbarSearch{min-width:0}}@media (max-width: 900px){.plannerHeader.topbar{flex-wrap:wrap}.topbarSearch{order:3;flex:1 1 100%;max-width:100%}.plannerControlBar{flex-wrap:wrap}.plannerControlBar .toolToolbar{margin-left:0;width:100%}}@keyframes omShellSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes omModalBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes omModalPopIn{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes omDropdownIn{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes omFocusBarIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.collapsibleShellSection{flex-shrink:0;border-bottom:1px solid var(--om-border);background:var(--om-header-bg);transition:background-color var(--om-transition-fast)}.collapsibleShellSection.collapsed .collapsibleShellBody{grid-template-rows:0fr;opacity:0}.collapsibleShellHead{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:28px;padding:4px 12px;background:color-mix(in srgb,var(--om-surface-2) 65%,transparent)}.collapsibleShellLabel{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--om-muted)}.collapsibleShellToggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:24px;border:0;border-radius:8px;background:transparent;color:var(--om-muted);cursor:pointer;transition:background-color var(--om-transition-fast),color var(--om-transition-fast),transform var(--om-transition-spring)}.collapsibleShellToggle:hover{background:var(--om-surface-hover);color:var(--om-text)}.collapsibleShellToggle:active{transform:scale(.92)}.collapsibleShellChevron{font-size:11px;line-height:1;transition:transform .28s cubic-bezier(.34,1.4,.64,1)}.collapsibleShellSection.collapsed .collapsibleShellChevron{transform:rotate(180deg)}.collapsibleShellBody{display:grid;grid-template-rows:1fr;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1),opacity .28s ease;opacity:1}.collapsibleShellInner{overflow:hidden;min-height:0}.collapsibleShellSection.collapsedOnly{border-bottom:1px solid var(--om-border);padding:4px 12px;background:var(--om-header-bg)}.collapsibleShellRestore{display:inline-flex;align-items:center;gap:6px;border:0;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;background:var(--om-surface-2);color:var(--om-muted);cursor:pointer;transition:background-color var(--om-transition-fast),color var(--om-transition-fast),transform var(--om-transition-spring);animation:omShellSlideDown .25s ease both}.collapsibleShellRestore:hover{background:var(--om-primary-soft);color:var(--om-primary)}.collapsibleShellRestoreIcon{font-size:10px}.shellNavSection.collapsedOnly,.shellMapsSection.collapsedOnly{flex-shrink:0}.shellNavSection:not(.collapsedOnly) .appNav,.shellMapsSection:not(.collapsedOnly) .plannerMapsBar{border-bottom:0}.planner.focusMode .workspace{padding:0}.planner.focusMode .boardWrap{border-radius:0;border-left:0;border-right:0}.omModalBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:20px;background:#09090b73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:omModalBackdropIn .22s ease both}.omModal{width:min(520px,100%);max-height:min(90vh,860px);overflow:auto;border-radius:var(--om-radius-xl, 18px);border:1px solid var(--om-border);background:var(--om-surface);box-shadow:var(--om-shadow-lg);animation:omModalPopIn .32s cubic-bezier(.34,1.2,.64,1) both}.omModalHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 22px 0}.omModalHeader h2{margin:0 0 6px;font-size:20px;font-weight:700;letter-spacing:-.02em}.omModalSubtitle{margin:0;font-size:13px;line-height:1.45;color:var(--om-muted)}.omModalClose{flex-shrink:0;width:34px;height:34px;border:0;border-radius:999px;background:var(--om-surface-2);color:var(--om-muted);font-size:22px;line-height:1;cursor:pointer;transition:background-color var(--om-transition-fast),color var(--om-transition-fast),transform var(--om-transition-spring)}.omModalClose:hover{background:var(--om-surface-hover);color:var(--om-text)}.omModalClose:active{transform:scale(.92)}.shareModalBody{padding:18px 22px 22px}.shareModalFieldLabel{display:block;margin-bottom:8px;font-size:12px;font-weight:600;color:var(--om-muted);text-transform:uppercase;letter-spacing:.05em}.shareModalLinkRow{display:flex;gap:8px}.shareModalLinkInput{flex:1;min-width:0;height:42px;border:1px solid var(--om-border);border-radius:12px;padding:0 12px;font-size:13px;background:var(--om-surface-2);color:var(--om-text)}.shareModalCopyBtn{flex-shrink:0;height:42px;border:0;border-radius:999px;padding:0 18px;font-size:13px;font-weight:600;background:var(--om-primary);color:#fff;cursor:pointer;transition:background-color var(--om-transition-fast),transform var(--om-transition-spring)}.shareModalCopyBtn:hover:not(:disabled){background:var(--om-primary-hover)}.shareModalCopyBtn:active:not(:disabled){transform:scale(.97)}.shareModalCopyBtn.copied{background:var(--om-success)}.shareModalCopyBtn:disabled{opacity:.55;cursor:not-allowed}.shareModalHints{margin:16px 0 0;padding:0 0 0 18px;font-size:12px;line-height:1.5;color:var(--om-muted)}.shareModalPreviewLink{display:inline-flex;margin-top:14px;font-size:13px;font-weight:600;color:var(--om-primary);text-decoration:none}.shareModalPreviewLink:hover{text-decoration:underline}.shareModalLocked,.shareModalError{padding:0 22px 22px;font-size:13px;color:var(--om-muted)}.shareModalError{color:var(--om-danger);padding-top:8px}.billingModal{width:min(1180px,96vw)}.billingModalBackdrop{align-items:flex-start;padding-top:28px}.billingPanelModal{padding:8px 8px 16px}.billingModalHeadRow{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.billingPlansScroller{overflow-x:auto;padding-bottom:4px;margin:0 -4px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.billingGridPlans{display:grid;grid-template-columns:repeat(5,minmax(200px,1fr));gap:14px;min-width:min(100%,1040px);padding:4px}@media (max-width: 1100px){.billingGridPlans{grid-template-columns:repeat(5,minmax(220px,1fr));width:max-content}}@media (max-width: 640px){.billingGridPlans{grid-template-columns:repeat(5,minmax(260px,1fr))}}.shellNavSection .collapsibleShellInner,.shellNavSection .collapsibleShellBody{overflow:visible}.accountMenuRoot{position:relative;z-index:50}.accountMenuTrigger{display:inline-flex;align-items:center;gap:8px;height:36px;border:1px solid var(--om-border);border-radius:999px;padding:0 12px 0 4px;background:var(--om-surface-2);color:var(--om-text);cursor:pointer;transition:border-color var(--om-transition-fast),box-shadow var(--om-transition-fast),transform var(--om-transition-spring)}.accountMenuTrigger:hover,.accountMenuTrigger.open{border-color:var(--om-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--om-primary) 18%,transparent)}.accountMenuTrigger:active{transform:scale(.98)}.accountMenuAvatar{width:28px;height:28px;border-radius:999px;background:var(--om-gradient-brand, linear-gradient(135deg, #4f46e5, #2563eb));color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700}.accountMenuAvatarLarge{width:40px;height:40px;font-size:14px}.accountMenuTriggerText{font-size:12px;font-weight:600}.accountMenuDropdown{position:absolute;top:calc(100% + 8px);right:0;z-index:120;width:min(300px,88vw);border:1px solid var(--om-border);border-radius:16px;background:var(--om-surface);box-shadow:var(--om-shadow-lg);padding:10px;animation:omDropdownIn .24s cubic-bezier(.34,1.2,.64,1) both}.accountMenuDropdownPortal{position:fixed;top:0;left:0;right:auto;z-index:1100}.accountMenuProfile{display:flex;align-items:center;gap:10px;padding:6px 4px 8px}.accountMenuProfileText{display:flex;flex-direction:column;gap:3px;min-width:0}.accountMenuProfileText strong{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.accountMenuPlanBadge{font-size:11px;font-weight:700;color:var(--om-primary)}.accountMenuExpiry{font-size:11px;color:var(--om-muted)}.accountMenuExpiryWarn{color:var(--om-warning)}.accountMenuDivider{height:1px;margin:6px 0;background:var(--om-border)}.accountMenuItem{display:flex;align-items:center;gap:10px;width:100%;border:0;border-radius:10px;padding:10px 12px;font-size:13px;text-align:left;background:transparent;color:var(--om-text);cursor:pointer;transition:background-color var(--om-transition-fast),transform var(--om-transition-fast)}.accountMenuItem:hover{background:var(--om-surface-2)}.accountMenuItem:active{transform:scale(.99)}.accountMenuItemIcon{width:18px;text-align:center;opacity:.85}.accountMenuItemDanger{color:var(--om-danger)}.workspaceFocusBar{position:absolute;top:12px;left:50%;z-index:60;transform:translate(-50%);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;padding:6px;border-radius:999px;border:1px solid var(--om-border);background:color-mix(in srgb,var(--om-surface) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--om-shadow-md);animation:omFocusBarIn .3s ease both}.workspaceFocusBtn{border:0;border-radius:999px;padding:7px 12px;font-size:11px;font-weight:600;background:var(--om-surface-2);color:var(--om-text);cursor:pointer;transition:background-color var(--om-transition-fast),transform var(--om-transition-spring)}.workspaceFocusBtn:hover{background:var(--om-primary-soft);color:var(--om-primary)}.workspaceFocusBtn.primary{background:var(--om-primary);color:#fff}.workspaceFocusBtn.primary:hover{background:var(--om-primary-hover);color:#fff}.workspaceFocusBtn.focusModeBtn{font-size:14px;padding:7px 10px}.workspace{position:relative}.plannerHeaderShell.collapsedOnly,.plannerControlShell.collapsedOnly{flex-shrink:0;padding:6px 12px;background:var(--om-header-bg);border-bottom:1px solid var(--om-border)}.toolToolbarCollapseBtn{flex:0 0 auto;align-self:center;width:28px;height:28px;border:0;border-radius:999px;background:var(--om-surface-2);color:var(--om-muted);cursor:pointer;transition:background-color var(--om-transition-fast),transform var(--om-transition-spring)}.toolToolbarCollapseBtn:hover{background:var(--om-primary-soft);color:var(--om-primary)}.toolToolbarCollapseBtn:active{transform:scale(.92)}.topbarFocusBtn.active{background:var(--om-primary);color:#fff;box-shadow:0 2px 10px #4f46e559}.panel,.boardWrap,.collapsibleShellSection,.plannerMapsBar,.appNav{transition:opacity .32s ease,transform .38s cubic-bezier(.4,0,.2,1),flex-basis .38s cubic-bezier(.4,0,.2,1),width .38s cubic-bezier(.4,0,.2,1),padding .32s ease,border-radius .32s ease}@media (prefers-reduced-motion: reduce){.omModalBackdrop,.omModal,.accountMenuDropdown,.workspaceFocusBar,.collapsibleShellRestore{animation:none!important}}:root,[data-theme=light]{color-scheme:light;--om-bg: #eef1f7;--om-surface: #ffffff;--om-surface-2: #fafafa;--om-surface-hover: #f4f4f5;--om-border: #e4e4e7;--om-border-strong: #d4d4d8;--om-text: #09090b;--om-muted: #71717a;--om-accent: #18181b;--om-accent-hover: #27272a;--om-primary: #4f46e5;--om-primary-hover: #4338ca;--om-primary-soft: #eef2ff;--om-danger: #b91c1c;--om-warning: #d97706;--om-success: #16a34a;--om-shadow: rgba(15, 23, 42, .08);--om-shadow-lg: rgba(15, 23, 42, .12);--om-radius: 8px;--om-font: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--om-board-bg: #ffffff;--om-grid-minor: #e4e4e7;--om-grid-major: #d4d4d8;--om-toolbar-accent: #ef9200;--om-toolbar-accent-hover: #dd8500;--om-btn-bg: #fafafa;--om-btn-text: #18181b;--om-btn-border: #d4d4d8;--om-btn-hover-bg: #f4f4f5;--om-btn-hover-border: #a1a1aa;--om-btn-active-bg: #18181b;--om-btn-active-text: #ffffff;--om-btn-active-border: #18181b;--om-menu-bg: #ffffff;--om-menu-border: #d4d4d8;--om-menu-divider: #e4e4e7;--om-menu-text: #18181b;--om-menu-row-bg: #ffffff;--om-menu-row-hover-bg: #f4f4f5;--om-menu-row-hover-text: #09090b;--om-menu-flyout-bg: #ffffff;--om-menu-flyout-text: #27272a;--om-menu-flyout-hover-bg: #f4f4f5;--om-menu-flyout-active-bg: #fff7ed;--om-menu-flyout-active-text: #9a3412;--om-menu-flyout-group-text: #f59e0b;--om-input-bg: #ffffff;--om-input-text: #111827;--om-input-border: #d4d4d8;--om-card-bg: #ffffff;--om-card-text: #27272a;--om-card-border: #d4d4d8;--om-estimate-bg: #fafafa;--om-estimate-text: #111827;--om-estimate-border: #e4e4e7;--om-hint-text: #52525b;--om-label-text: #374151;--om-icon-stroke: #71717a;--om-icon-active-stroke: #ffffff;--om-toast-bg: #fef2f2;--om-toast-text: #991b1b;--om-toast-border: #fecaca;--om-banner-bg: #eff6ff;--om-banner-text: #1e3a8a;--om-banner-border: #dbeafe;--om-success-soft: #f0fdf4;--om-success-border: #16a34a;--om-danger-soft: #fef2f2;--om-danger-border: #fca5a5;--om-transition: .22s cubic-bezier(.4, 0, .2, 1);--om-transition-fast: .15s ease;--om-transition-spring: .28s cubic-bezier(.34, 1.4, .64, 1)}[data-theme=dark]{color-scheme:dark;--om-bg: #0a0a0b;--om-surface: #18181b;--om-surface-2: #1f1f23;--om-surface-hover: #27272a;--om-border: #3f3f46;--om-border-strong: #52525b;--om-text: #fafafa;--om-muted: #a1a1aa;--om-accent: #fafafa;--om-accent-hover: #e4e4e7;--om-primary: #3b82f6;--om-primary-hover: #60a5fa;--om-primary-soft: rgba(59, 130, 246, .15);--om-danger: #f87171;--om-warning: #fbbf24;--om-success: #4ade80;--om-shadow: rgba(0, 0, 0, .35);--om-shadow-lg: rgba(0, 0, 0, .5);--om-board-bg: #141416;--om-grid-minor: #27272a;--om-grid-major: #3f3f46;--om-toolbar-accent: #f59e0b;--om-toolbar-accent-hover: #d97706;--om-btn-bg: #27272a;--om-btn-text: #fafafa;--om-btn-border: #52525b;--om-btn-hover-bg: #3f3f46;--om-btn-hover-border: #71717a;--om-btn-active-bg: #fafafa;--om-btn-active-text: #09090b;--om-btn-active-border: #fafafa;--om-menu-bg: #18181b;--om-menu-border: #3f3f46;--om-menu-divider: #3f3f46;--om-menu-text: #fafafa;--om-menu-row-bg: #18181b;--om-menu-row-hover-bg: #27272a;--om-menu-row-hover-text: #ffffff;--om-menu-flyout-bg: #1f1f23;--om-menu-flyout-text: #fafafa;--om-menu-flyout-hover-bg: #27272a;--om-menu-flyout-active-bg: rgba(245, 158, 11, .18);--om-menu-flyout-active-text: #fcd34d;--om-menu-flyout-group-text: #fbbf24;--om-input-bg: #27272a;--om-input-text: #fafafa;--om-input-border: #52525b;--om-card-bg: #1f1f23;--om-card-text: #fafafa;--om-card-border: #52525b;--om-estimate-bg: #1f1f23;--om-estimate-text: #fafafa;--om-estimate-border: #3f3f46;--om-hint-text: #a1a1aa;--om-label-text: #d4d4d8;--om-icon-stroke: #a1a1aa;--om-icon-active-stroke: #09090b;--om-toast-bg: #450a0a;--om-toast-text: #fecaca;--om-toast-border: #991b1b;--om-banner-bg: rgba(59, 130, 246, .12);--om-banner-text: #93c5fd;--om-banner-border: rgba(59, 130, 246, .35);--om-success-soft: rgba(74, 222, 128, .12);--om-success-border: #4ade80;--om-danger-soft: rgba(248, 113, 113, .12);--om-danger-border: #f87171;--om-transition: .22s cubic-bezier(.4, 0, .2, 1);--om-transition-fast: .15s ease;--om-transition-spring: .28s cubic-bezier(.34, 1.4, .64, 1)}html{transition:background-color var(--om-transition),color var(--om-transition)}@media (prefers-reduced-motion: reduce){html,html *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@keyframes omFadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes omFadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes omSlideInRight{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@keyframes omScaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes omThemeSpin{0%{transform:rotate(-90deg) scale(.8);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}.planner .topbar{animation:omFadeInDown .35s ease both}.planner .plannerControlBar{animation:omFadeInDown .35s .05s ease both}.planner .panel{animation:omSlideInRight .4s .08s ease both}.planner .boardWrap{animation:omScaleIn .45s .12s ease both}.materialMenu{animation:omScaleIn .3s ease both}.menuFlyout{animation:omSlideInRight .22s ease both}.menuRow,.menuFlyout button,.toolBtn,.depthRow button,.actions button,.templateCard,.topbarViewBtn,.floorTab,.panelToggleButton{transition:background-color var(--om-transition-fast),border-color var(--om-transition-fast),color var(--om-transition-fast),box-shadow var(--om-transition-fast),transform var(--om-transition-spring),opacity var(--om-transition-fast)}.menuRow:hover{transform:translate(3px)}.menuFlyout button:hover,.toolBtn:hover,.depthRow button:hover,.actions button:hover,.templateCard:hover,.topbarViewBtn:hover,.floorTab:hover{transform:translateY(-1px)}.toolBtn:active,.depthRow button:active,.actions button:active,.topbarViewBtn:active,.floorTab:active,.templateCard:active{transform:scale(.97)}.appNavThemeToggle:active,.themeTopBtn:active{animation:omThemeSpin .35s ease}.searchResults{animation:omFadeInDown .2s ease both}.multiSelectPanel{animation:omScaleIn .25s ease both}.plannerToast{animation:omFadeInUp .3s ease both}.readOnlyBubbleCard{animation:omScaleIn .2s ease both}.authBrand{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:700;letter-spacing:-.02em;color:var(--om-text);margin:0 0 8px}.authBrand:before{content:"⌂";width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,#4f46e5,#2563eb);color:#fff;display:grid;place-items:center;font-size:15px;box-shadow:0 4px 14px #4f46e54d}.authError{font-size:13px;color:var(--om-danger);margin:0}.topbarSearchLocked{margin:0;padding:8px 12px;font-size:13px;color:var(--om-muted);border:1px dashed var(--om-border);border-radius:var(--om-radius)}.billingPage{min-height:100vh;background:var(--om-bg);padding:32px 20px 48px;font-family:var(--om-font)}.billingShell{max-width:1120px;margin:0 auto}.billingHeader{text-align:center;margin-bottom:32px}.billingModal .billingHeader h1,.billingPanel .billingHeader h1{margin:0 0 10px;font-size:28px;font-weight:600;color:var(--om-text)}.billingSubtitle{margin:0 auto;max-width:640px;font-size:15px;line-height:1.55;color:var(--om-muted)}.billingUserLine{margin:16px 0 0;font-size:14px;color:var(--om-muted)}.billingGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}.billingPage .billingGridPlans{display:grid;grid-template-columns:repeat(5,minmax(200px,1fr));gap:14px}@media (max-width: 1100px){.billingPage .billingPlansScroller{overflow-x:auto;scroll-snap-type:x proximity}.billingPage .billingGridPlans{grid-template-columns:repeat(5,minmax(220px,1fr));width:max-content;min-width:min(100%,1040px)}}.billingCard{position:relative;display:flex;flex-direction:column;min-height:100%;background:var(--om-surface);border:1px solid var(--om-border);border-radius:14px;padding:24px 20px 20px;box-shadow:0 4px 20px var(--om-shadow)}.billingCardPopular{border-color:var(--om-primary);box-shadow:0 8px 28px #2563eb24}.billingCardTrial{border-color:#059669;box-shadow:0 8px 28px #0596691f}.billingCardCurrent{border-color:#16a34a}.billingBadge{position:absolute;top:14px;right:14px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--om-primary);border-radius:999px;padding:4px 10px}.billingBadgeCurrent{right:auto;left:14px;background:#16a34a}.billingBadgeTrial{background:#059669}.billingCard h2{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--om-text)}.billingCardDesc{margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--om-muted);min-height:40px}.billingPrice{margin:0 0 16px}.billingPriceValue{font-size:28px;font-weight:700;color:var(--om-text)}.billingPricePeriod{font-size:14px;color:var(--om-muted)}.billingFeatures{margin:0 0 20px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;flex:1}.billingFeatures li{position:relative;padding-left:18px;font-size:13px;line-height:1.45;color:var(--om-text)}.billingFeatures li:before{content:"✓";position:absolute;left:0;top:0;color:#16a34a;font-weight:700}.billingSelectBtn{width:100%;border:1px solid var(--om-border);border-radius:var(--om-radius);padding:11px 14px;font-size:14px;font-weight:500;background:var(--om-surface-2);color:var(--om-text);cursor:pointer;transition:background .15s,border-color .15s}.billingSelectBtn:hover:not(:disabled){background:var(--om-surface-hover);border-color:var(--om-text)}.billingSelectBtnPrimary{background:var(--om-primary);border-color:var(--om-primary);color:#fff}.billingSelectBtnPrimary:hover:not(:disabled){background:var(--om-primary-hover);border-color:var(--om-primary-hover)}.billingSelectBtn:disabled{opacity:.6;cursor:not-allowed}.billingFooter{margin-top:28px;text-align:center}.billingFooter p{margin:0 0 12px;font-size:13px;color:var(--om-muted)}.billingContinueBtn{border:0;border-radius:var(--om-radius);padding:10px 18px;font-size:14px;font-weight:500;background:var(--om-primary);color:#fff;cursor:pointer}.billingContinueBtn:hover{background:var(--om-primary-hover)}.billingError{margin-top:16px;text-align:center}.billingInfo{margin:0 0 16px;text-align:center;font-size:14px;color:#0369a1}.billingModeLine{margin:12px 0 0;font-size:13px;color:var(--om-muted)}.billingModeLineTest{color:#059669;font-weight:600}.billingFooter code{font-size:12px;background:var(--om-surface-2);padding:1px 5px;border-radius:4px}.appNav{display:flex;align-items:center;gap:12px;padding:0 16px;height:48px;border-bottom:1px solid var(--om-border);background:var(--om-surface);flex-shrink:0}.appNavBrand{font-size:15px;font-weight:700;letter-spacing:-.02em;text-transform:none;color:var(--om-text);text-decoration:none;flex-shrink:0}.appNavSpacer{flex:1}.appNavLink{font-size:13px;color:var(--om-muted);text-decoration:none;padding:6px 10px;border-radius:6px;border:0;background:transparent;cursor:pointer;font-family:inherit}.appNavLink:hover,.appNavLink.active{color:var(--om-text);background:var(--om-surface-hover)}.appNavUser{display:inline-flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:13px;color:var(--om-muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appNavPlan{font-size:11px;font-weight:600;color:var(--om-primary);letter-spacing:.02em}.appNavThemeToggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--om-border);background:var(--om-surface-2);color:var(--om-text);font-size:16px;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.appNavThemeToggle:hover{background:var(--om-surface-hover);border-color:var(--om-border-strong)}.appNavLogout{border:1px solid var(--om-border);background:transparent;color:var(--om-text);font-size:12px;padding:6px 12px;border-radius:6px;cursor:pointer;transition:background .15s}.appNavLogout:hover{background:var(--om-surface-hover)}.authLoading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:var(--om-font);background:var(--om-bg)}.authLoading .authSpinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--om-border);border-top-color:var(--om-primary);animation:authSpin .8s linear infinite}.plannerWithNav{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--om-bg)}.plannerWithNav .planner{flex:1;min-height:0}.multiSelectPanel{background:var(--om-primary-soft);border:1px solid var(--om-primary);border-radius:var(--om-radius);padding:12px 14px;margin-bottom:16px}.multiSelectPanel h2{margin:0 0 6px!important;color:var(--om-primary)!important}.multiSelectPanel p{margin:0 0 10px;font-size:13px;color:var(--om-muted)}.multiSelectPanel button{width:100%;border:1px solid var(--om-danger);background:transparent;color:var(--om-danger);padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px}.multiSelectPanel button:hover{background:#b91c1c14}[data-theme=dark] .multiSelectPanel button:hover{background:#f871711f}.plannerMapsBar{display:flex;align-items:center;gap:12px;padding:8px 16px;border-bottom:1px solid var(--om-border);background:var(--om-surface);flex-shrink:0}.mapSwitcher{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}.mapSwitcherLoading{font-size:13px;color:var(--om-muted)}.mapSwitcherHead{display:flex;align-items:center;gap:8px}.mapSwitcherTitle{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--om-muted)}.mapSwitcherLimit{font-size:12px;font-weight:700;color:var(--om-primary)}.mapSwitcherList{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.mapSwitcherItem{border:1px solid var(--om-border);background:var(--om-surface-2);color:var(--om-text);border-radius:999px;padding:6px 12px;font-size:13px;cursor:pointer}.mapSwitcherItem.active{border-color:var(--om-primary);background:#2563eb1a;color:var(--om-primary);font-weight:600}.mapSwitcherItem:disabled{opacity:.55;cursor:not-allowed}.mapSwitcherCreate{border:1px dashed var(--om-border);background:transparent;color:var(--om-text);border-radius:999px;padding:6px 12px;font-size:13px;cursor:pointer}.mapSwitcherCreate:disabled{opacity:.45;cursor:not-allowed}.mapSwitcherHint,.mapSwitcherError{margin:0;font-size:12px}.mapSwitcherHint{color:var(--om-muted)}.mapSwitcherError{color:var(--om-danger)}@keyframes authFadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes authFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes authGlowPulse{0%,to{opacity:.45}50%{opacity:.75}}.authShell{min-height:100vh;display:grid;grid-template-columns:minmax(320px,1.05fr) minmax(360px,.95fr);font-family:var(--om-font);background:var(--om-bg)}.authHero{position:relative;overflow:hidden;padding:clamp(32px,5vw,56px);background:linear-gradient(145deg,#312e81,#1e3a8a 42%,#0f172a);color:#f8fafc;display:flex;align-items:center}.authHeroGlow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:authGlowPulse 8s ease-in-out infinite}.authHeroGlowA{width:420px;height:420px;top:-120px;right:-80px;background:#6366f18c}.authHeroGlowB{width:360px;height:360px;bottom:-100px;left:-60px;background:#2563eb66;animation-delay:-3s}.authHeroContent{position:relative;z-index:1;max-width:440px;animation:authFadeUp .55s ease both}.authHeroBrand{display:inline-flex;align-items:center;gap:12px;margin-bottom:28px}.authHeroLogo{width:44px;height:44px;border-radius:14px;background:#ffffff24;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;font-size:20px;font-weight:700}.authHeroName{font-size:18px;font-weight:700;letter-spacing:-.03em}.authHeroTitle{margin:0 0 14px;font-size:clamp(28px,3.2vw,38px);font-weight:700;letter-spacing:-.03em;line-height:1.15}.authHeroText{margin:0 0 24px;font-size:15px;line-height:1.6;color:#f8fafcd1}.authHeroFeatures{margin:0 0 32px;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}.authHeroFeatures li{position:relative;padding-left:22px;font-size:14px;color:#f8fafce6}.authHeroFeatures li:before{content:"✓";position:absolute;left:0;font-weight:700;color:#a5b4fc}.authHeroPreview{border-radius:16px;border:1px solid rgba(255,255,255,.15);background:#0f172a59;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:14px;animation:authFloat 6s ease-in-out infinite}.authHeroPreviewBar{height:8px;width:42%;border-radius:999px;background:#ffffff40;margin-bottom:12px}.authHeroPreviewGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.authHeroPreviewGrid span{aspect-ratio:1.4;border-radius:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.1)}.authHeroPreviewGrid span.active{background:#818cf859;border-color:#a5b4fc80;box-shadow:0 0 20px #6366f159}.authMain{display:flex;align-items:center;justify-content:center;padding:clamp(24px,4vw,48px);background:radial-gradient(ellipse 70% 50% at 80% 0%,rgba(79,70,229,.08),transparent),var(--om-bg)}.authPanel{width:100%;max-width:420px;animation:authFadeUp .5s .08s ease both}.authPanelBadge{display:inline-block;margin-bottom:12px;padding:5px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--om-primary);background:var(--om-primary-soft)}.authPanelTitle{margin:0 0 8px;font-size:clamp(26px,4vw,32px);font-weight:700;letter-spacing:-.03em;color:var(--om-text)}.authPanelSubtitle{margin:0 0 28px;font-size:15px;line-height:1.55;color:var(--om-muted)}.authPanelBody{display:flex;flex-direction:column;gap:0}.authPanelFooter{margin-top:28px;padding-top:20px;border-top:1px solid var(--om-border);text-align:center;font-size:14px;color:var(--om-muted)}.authPanelFooter a{color:var(--om-primary);font-weight:600;text-decoration:none}.authPanelFooter a:hover{text-decoration:underline}.authForm{display:flex;flex-direction:column;gap:18px}.authField{display:flex;flex-direction:column;gap:8px}.authField label{font-size:13px;font-weight:600;color:var(--om-text)}.authField input{width:100%;box-sizing:border-box;height:48px;border:1px solid var(--om-border);border-radius:12px;padding:0 14px;font-size:15px;background:var(--om-surface);color:var(--om-text);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.authField input::placeholder{color:var(--om-muted)}.authField input:focus{border-color:var(--om-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--om-primary) 18%,transparent)}.authFormRow{display:flex;justify-content:flex-end;margin-top:-6px}.authFormRow a{font-size:13px;font-weight:500;color:var(--om-muted);text-decoration:none}.authFormRow a:hover{color:var(--om-primary)}.authAlert{margin:0;padding:12px 14px;border-radius:12px;font-size:13px;line-height:1.45}.authAlertError{color:var(--om-danger);background:var(--om-danger-soft);border:1px solid color-mix(in srgb,var(--om-danger) 25%,transparent)}.authAlertSuccess{color:#15803d;background:var(--om-success-soft);border:1px solid color-mix(in srgb,var(--om-success) 30%,transparent)}.authAlertHint{color:var(--om-muted);background:var(--om-surface-2);border:1px dashed var(--om-border);word-break:break-all}.authAlertHint a{color:var(--om-primary)}.authSubmit{margin-top:4px;width:100%;height:48px;border:0;border-radius:12px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5,#2563eb);box-shadow:0 4px 18px #4f46e559;transition:transform .2s cubic-bezier(.34,1.2,.64,1),box-shadow .2s ease,opacity .2s ease}.authSubmit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #4f46e566}.authSubmit:active:not(:disabled){transform:scale(.98)}.authSubmit:disabled{opacity:.6;cursor:not-allowed}.authLoadingState{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:200px;color:var(--om-muted);font-size:14px}.authSpinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--om-border);border-top-color:var(--om-primary);animation:authSpin .8s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.authLinkButton{display:inline-flex;align-items:center;gap:6px;margin-top:8px;border:0;background:none;padding:0;font:inherit;font-size:14px;font-weight:600;color:var(--om-primary);cursor:pointer}.authLinkButton:hover{text-decoration:underline}@media (max-width: 960px){.authShell{grid-template-columns:1fr;min-height:100dvh;height:auto}.authHero{min-height:auto;padding:32px 24px 28px}.authHeroPreview{display:none}.authHeroFeatures{margin-bottom:0}.authMain{padding:28px 20px 40px}}@media (prefers-reduced-motion: reduce){.authHeroContent,.authPanel,.authHeroPreview,.authHeroGlow{animation:none!important}}@media (max-width: 768px){html{-webkit-text-size-adjust:100%;text-size-adjust:100%}html,body,#root{height:100%;overflow:auto;overscroll-behavior-y:none}.plannerWithNav{height:100dvh;max-height:100dvh;overflow:hidden}.plannerWithNav .planner{height:100%;min-height:0;overflow:hidden}.planner{height:100%;min-height:0}.authShell{min-height:100dvh;height:auto}.authHero{padding:24px 20px 20px}.authHeroTitle{font-size:24px}.authHeroText,.authHeroFeatures li{font-size:14px}.authMain{align-items:flex-start;padding:20px 16px 32px}.authPanelTitle{font-size:24px}.authPanelSubtitle{margin-bottom:22px;font-size:14px}.authLoading{min-height:100dvh}.billingPage{min-height:100dvh;padding:20px 14px 32px}.billingModal .billingHeader h1,.billingPanel .billingHeader h1{font-size:22px}.billingPage .billingGridPlans{grid-template-columns:1fr;width:100%;min-width:0}.billingPlansScroller{overflow-x:visible;scroll-snap-type:none}.billingModal{width:min(100%,calc(100vw - 16px))}.billingModalBackdrop,.omModalBackdrop{padding:12px;align-items:flex-end}.omModal{width:100%;max-height:calc(100dvh - 24px);border-bottom-left-radius:0;border-bottom-right-radius:0}.shareModalLinkRow{flex-direction:column}.shareModalCopyBtn{width:100%}.appNav{height:auto;min-height:48px;padding:8px 12px;gap:8px}.accountMenuTriggerText{display:none}.accountMenuTrigger{padding:0 8px 0 4px}.plannerMapsBar{padding:8px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.mapSwitcher{flex-wrap:nowrap;min-width:min-content}.collapsibleShellHead{min-height:36px;padding:6px 12px}.collapsibleShellToggle{width:36px;height:32px}.plannerHeader.topbar{padding:10px 12px;gap:10px}.plannerHeaderBrand{max-width:none;flex:1 1 auto;min-width:0}.plannerHeaderBrand h1{white-space:normal;font-size:14px}.plannerHeaderActions.topbarActions{flex-wrap:wrap;justify-content:flex-end;gap:6px;width:100%;order:4}.topbarSearch{order:3;flex:1 1 100%;max-width:100%;min-width:0;padding-top:0}.topbarViewBtn{min-height:40px;padding:8px 12px;font-size:12px}.searchInput{height:44px;font-size:16px}.plannerControlBar{padding:8px 12px;gap:8px;align-items:stretch}.plannerControlBar .floorTabs{flex:1 1 100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.plannerControlBar .toolToolbar{flex:1 1 100%;max-width:100%;width:100%;margin-left:0;gap:6px}.plannerControlBar .toolBtn,.floorTab,.floorTabAdd{min-height:40px}.plannerControlBar .toolToolbarHint{white-space:normal}.workspace{flex-direction:column;padding:8px;gap:8px;min-height:0}.boardWrap{order:1;flex:1 1 auto;min-height:min(52dvh,calc(100dvh - 240px));border-radius:14px;touch-action:none}.panel{order:2;flex:0 0 auto;width:100%;max-width:none;max-height:min(42dvh,380px);border-right:none;border-top:1px solid var(--om-border);border-radius:14px;padding:10px;overflow:auto;-webkit-overflow-scrolling:touch}.panelBody{min-width:0}.panel.collapsed{flex:0 0 44px;width:100%;max-height:44px;padding:0;overflow:hidden}.panel.collapsed .panelToggleButton{flex-direction:row;gap:8px;font-size:13px}.panelToggleButton{min-height:40px;min-width:40px;top:8px;right:8px}.panel.collapsed .panelToggleButton{top:0;right:0;left:0;height:44px}.workspaceFocusBar{top:auto;bottom:calc(min(42dvh,380px) + 20px);left:12px;right:12px;transform:none;max-width:none;border-radius:14px;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.workspaceFocusBar:has(+.panel.collapsed),.workspace:has(.panel.collapsed) .workspaceFocusBar{bottom:56px}.workspaceFocusBtn{min-height:40px;flex-shrink:0}.materialMenu.compact{min-height:0}.materialMenu.compact .menuPrimary{overflow-x:auto;-webkit-overflow-scrolling:touch}.actions button{min-height:44px}.boardCoordsBadge{bottom:10px;left:10px;max-width:calc(100% - 20px);font-size:10px}.plannerToast{left:12px!important;right:12px!important;max-width:none}}@media (max-width: 480px){.plannerHeaderBrand .plannerLogo{width:36px;height:36px;font-size:16px}.authHeroBrand{margin-bottom:16px}.authHeroFeatures{gap:8px}.topbarViewBtn{flex:1 1 calc(50% - 4px);justify-content:center;text-align:center}.panel{max-height:min(46dvh,360px)}.boardWrap{min-height:min(48dvh,calc(100dvh - 220px))}}@media (max-width: 1100px){.panelBody{min-width:0}}
