:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#202427;background:#e9ece6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--panel: #fbfaf6;--ink-soft: #697074;--line: #c8cec8;--line-strong: #87918d;--accent: #227181;--success: #2f8b4d;--warning: #a15d18;--danger: #9f403b}.app-shell{display:grid;grid-template-rows:minmax(0,1fr) 72px;width:100vw;height:100vh;min-height:0;overflow:hidden;background:#fbfaf6}*{box-sizing:border-box}html,body,#root{width:100%;min-width:100%;height:100%;min-height:100%;margin:0}button{font:inherit}.app-shell{display:grid;grid-template-rows:minmax(0,1fr) 68px;width:100vw;height:100vh;min-height:0;overflow:hidden;background:#fbfaf6}.debug-popover{position:fixed;top:10px;right:10px;background:#f8fafcfa;border:1px solid #e2e8f0;border-radius:8px;padding:10px;width:220px;max-height:80vh;display:flex;flex-direction:column;gap:8px;box-shadow:0 10px 25px -5px #0000001a;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.65rem;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.debug-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.debug-version{min-width:0;flex:1;overflow:hidden;color:#475569;font-weight:700;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.debug-close{background:none;border:none;font-size:.85rem;line-height:1;color:#94a3b8;cursor:pointer;padding:4px 6px;border-radius:4px}.debug-close:hover{background:#f1f5f9;color:#ef4444}.debug-actions{display:grid;grid-template-columns:1fr;gap:6px}.debug-action{min-height:28px;padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;background:#f1f5f9;color:#475569;cursor:pointer;font-family:inherit;font-size:.6rem;font-weight:700;line-height:1.1;text-align:center}.debug-action:hover{border-color:#9f403b66;color:var(--danger)}.debug-metrics{display:flex;flex-direction:column;gap:6px}.debug-log{display:flex;flex-direction:column;gap:3px;flex:1 1 auto;min-height:0;margin-top:4px;padding-top:4px;border-top:1px solid rgba(105,112,116,.15);overflow:hidden}.debug-log span{white-space:pre-wrap;word-break:break-all}.debug-launcher{position:fixed;top:10px;right:10px;z-index:1000;width:21px;height:21px;padding:0;border:0;background:transparent;color:#2f3338;cursor:pointer}.debug-launcher svg{width:100%;height:100%;display:block}.debug-launcher-helmet{fill:#8d939b;stroke:currentColor;stroke-linejoin:round;stroke-width:2}.debug-launcher-face{fill:#c5c7ca;stroke:currentColor;stroke-linejoin:round;stroke-width:2}.debug-launcher-brow,.debug-launcher-mouth{fill:none;stroke:currentColor;stroke-linecap:round;stroke-width:3}.workspace{position:relative;min-width:0;min-height:0;overflow:hidden;outline:0}.bottom-controls-wrap{position:absolute;left:12px;bottom:12px;z-index:6;display:flex;align-items:flex-end;gap:8px;pointer-events:none}.bottom-controls-wrap>*{pointer-events:auto}.floorplan-controls-stack{display:flex;flex-direction:column;align-items:center;gap:6px}.floorplan-controls{display:grid;align-items:stretch;gap:5px;padding:6px 8px;border:1px solid rgba(105,112,116,.22);border-radius:7px;background:#ffffffd6;color:var(--ink-soft);font-size:.75rem;font-weight:800;text-transform:lowercase;-webkit-user-select:none;user-select:none}.floorplan-controls label,.floorplan-controls button{position:relative;display:inline-flex;align-items:center;justify-content:flex-start;gap:4px;min-height:24px;cursor:pointer}.floorplan-controls [data-tooltip]:after,.diskette-status[data-tooltip]:before{content:attr(data-tooltip);position:absolute;left:calc(100% + 11px);top:50%;z-index:20;padding:3px 6px;border:1px solid rgba(32,36,39,.16);border-radius:4px;background:#202427f0;color:#fff;font-size:.68rem;font-weight:800;line-height:1;letter-spacing:0;text-transform:none;white-space:pre;pointer-events:none;opacity:0;transform:translateY(-50%) translate(-2px)}.floorplan-controls [data-tooltip]:hover:after,.floorplan-controls [data-tooltip]:focus-visible:after,.floorplan-controls label[data-tooltip]:has(input:focus-visible):after,.diskette-status[data-tooltip]:hover:before,.diskette-status[data-tooltip]:focus-visible:before,.diskette-status[data-tooltip].persistent-tooltip:before{opacity:1;transform:translateY(-50%)}.diskette-status{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--line-strong)}.diskette-status svg{width:33px;height:33px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.diskette-status .disk-body{fill:#ffffff9e}.diskette-status .disk-badge{stroke-width:2}.diskette-status .disk-badge circle{fill:#fff}.diskette-status .danger{color:var(--danger)}.diskette-status .warning{color:#d99a18}.diskette-status .success{color:var(--success)}.diskette-status.saving .success{animation:sync-flash .65s ease-in-out infinite}.diskette-status.offline:after{content:"";position:absolute;left:4px;bottom:5px;width:36px;height:5px;border-radius:999px;background:var(--danger);transform:rotate(-45deg);transform-origin:left center;pointer-events:none}@keyframes sync-flash{0%,to{opacity:1}50%{opacity:.3}}.floorplan-controls button{padding:3px 6px;border:1px solid rgba(105,112,116,.25);border-radius:5px;background:#fff;color:var(--ink-soft);font:inherit;cursor:pointer}.snap-control,.dims-control{cursor:pointer}.floorplan-controls input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-grid;place-items:center;width:13px;height:13px;margin:0;border:1px solid rgba(105,112,116,.45);border-radius:2px;background:#fff;box-sizing:border-box;cursor:pointer}.floorplan-controls input[type=checkbox]:before{content:"";width:7px;height:7px;background:#202427;transform:scale(0)}.floorplan-controls input[type=checkbox]:checked:before,.snap-control.top-left .snap-checkbox:before{transform:scale(1)}.snap-control.center .snap-checkbox:before,.dims-control.all .dims-checkbox:before{content:"X";width:auto;height:auto;background:transparent;color:#202427;font-family:Arial,Helvetica,sans-serif;font-size:.72rem;font-weight:900;line-height:1;text-align:center;transform:scale(1)}.add-tool-form{display:grid;gap:4px;width:130px;padding:6px;border:1px solid rgba(200,206,200,.4);border-radius:6px;background:#ffffffd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--ink-soft);font-size:.75rem;box-shadow:0 4px 12px #0000000d;text-transform:lowercase;box-sizing:border-box}.add-tool-form label{position:relative;display:flex;flex-direction:column;gap:1px;font-weight:700}.add-tool-form .error-bubble{position:absolute;top:0;right:0;background:var(--danger);color:#fff;font-size:.6rem;padding:1px 4px;border-radius:3px;font-weight:800;pointer-events:none}.add-tool-form input[type=text],.add-tool-form select{padding:2px 4px;border:1px solid rgba(105,112,116,.28);border-radius:4px;background:#fff;color:#202427;font:inherit;font-size:.75rem;box-sizing:border-box;width:100%}.add-tool-form .row{display:grid;grid-template-columns:1fr 1fr;gap:4px}.add-tool-form .hazards{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:2px}.add-tool-form .hazards label{flex-direction:row;align-items:center;gap:3px;font-weight:400}.add-tool-form button[type=submit]{margin-top:2px;padding:4px;border:1px solid rgba(34,113,129,.45);border-radius:4px;background:var(--accent);color:#fff;font-weight:700;cursor:pointer;box-sizing:border-box;width:100%;font-size:.75rem}.add-tool-form button[type=submit]:hover{background:#1c5f6c}.floorplan-controls button:hover{border-color:var(--accent);color:var(--accent)}.floorplan-controls button:disabled{border-color:#69707429;background:#ffffff94;color:#69707494;cursor:default}.delete-zone{--delete-zone-center: translateX(-50%);--delete-zone-level: 0;--delete-zone-opacity: .15;--delete-zone-active: #ef4444;--delete-zone-pulse-shadow: rgba(239, 68, 68, .42);--delete-zone-pulse-fade: rgba(239, 68, 68, 0);position:absolute;bottom:20px;left:calc(50% - 72px);transform:var(--delete-zone-center);width:48px;height:48px;background:#cbd5e1;color:#fff;display:grid;place-items:center;border-radius:999px;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:var(--delete-zone-opacity);transition:opacity .15s ease,transform .1s ease;z-index:100;box-shadow:0 4px 12px #0000001a}.delete-zone.copy-zone{--delete-zone-active: var(--accent);--delete-zone-pulse-shadow: rgba(34, 113, 129, .42);--delete-zone-pulse-fade: rgba(34, 113, 129, 0);left:calc(50% + 72px)}.delete-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:var(--delete-zone-active);opacity:var(--delete-zone-level);transition:opacity .15s ease;pointer-events:none}.delete-zone svg{position:relative;z-index:1;width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.delete-zone.shaking{animation:bin-shake .15s ease-in-out infinite;--delete-zone-level: 1}@keyframes bin-shake{0%,to{transform:var(--delete-zone-center) rotate(0) scale(1.1)}25%{transform:var(--delete-zone-center) rotate(8deg) scale(1.1)}75%{transform:var(--delete-zone-center) rotate(-8deg) scale(1.1)}}.workspace:has(.dragging) .delete-zone{pointer-events:all}.floorplan{width:100%;height:100%;min-height:0;display:block;border:0;border-radius:0;background:#fbfaf6;box-shadow:none;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-user-drag:none;cursor:grab}.floorplan *,.floorplan text{user-select:none;-webkit-user-select:none;-webkit-user-drag:none}.floorplan.panning{cursor:grabbing}.grid-line{fill:none;stroke:#20242714;stroke-width:.8}.floorplan.grid-dark .grid-line{stroke:#2024271a;stroke-width:.8}.base-svg-layer{pointer-events:none}.infra-layer{display:none;pointer-events:none}.floorplan.show-infra .infra-layer{display:block}.mezzanine-layer{display:none;pointer-events:none}.floorplan.show-mezz .mezzanine-layer{display:block}.tool-node{cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-user-drag:none;transition:opacity .1s ease}.tool-node:active{cursor:grabbing}.tool-node.selected>rect{stroke-width:2.5;stroke-opacity:.95}.selected-tool-overlay{color:#202427;pointer-events:none}.dimension-line,.dimension-extension{fill:none;stroke:#2024279e;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.dimension-line{stroke-width:.7}.dimension-extension{stroke-width:.55;stroke-dasharray:2 3}.dimension-arrow{fill:none;stroke:#2024279e;stroke-width:.7;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.dimension-label{fill:#202427;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:8px;font-weight:700;letter-spacing:0;text-transform:none;pointer-events:none}.rotate-handle{pointer-events:auto;cursor:grab;color:#202427b8}.rotate-handle:active{cursor:grabbing}.rotate-hit-area{fill:transparent;stroke:none}.rotate-handle path{fill:none;stroke:currentColor;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.rotate-handle:hover,.rotate-handle:focus-visible{color:var(--accent);outline:none}.tool-node foreignObject{overflow:hidden;pointer-events:none}.tool-label{display:flex;align-items:flex-start;width:100%;height:100%;overflow:hidden;fill:currentColor;color:inherit;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:10px;font-weight:600;text-transform:uppercase;line-height:1.1;overflow-wrap:anywhere;padding:4px;text-wrap:balance;word-break:break-word}.tool-node text{fill:currentColor;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:10px;font-weight:600;text-transform:uppercase;pointer-events:none}.tool-node .dimension-label{fill:#202427;font-size:8px;font-weight:700;text-transform:none}.sheet-tabs{position:relative;z-index:10;grid-column:1 / -1;display:flex;align-items:flex-start;gap:4px;min-width:0;padding:0 10px 18px;border-top:1px solid var(--line-strong);background:#fbfaf6;overflow-x:auto;overflow-y:hidden}.sheet-tab-wrap{position:relative;flex:0 0 auto;padding-top:0}.sheet-tab{position:relative;min-width:120px;height:37px;padding:0 18px;border:1px solid var(--line);border-top:0;border-radius:0 0 8px 8px;background:#ecefeb;color:#202427;font-family:inherit;font-size:1rem;font-weight:800;line-height:1;cursor:pointer}.sheet-tab:hover,.sheet-tab.active{border-color:var(--accent)}.sheet-tab.active{height:45px;background:#fff;color:var(--accent);box-shadow:0 -1px #fff}.clone-tab{position:absolute;z-index:12;top:26px;left:calc(50% + 36px);display:grid;place-items:center;width:28px;height:28px;padding:0;border:1px solid rgba(47,139,77,.55);border-radius:999px;background:var(--success);color:#fff;font-family:Arial,sans-serif;font-size:1.4rem;font-weight:850;line-height:1;opacity:0;transform:translate(-50%) translateY(6px);transition:opacity .12s ease,transform .12s ease;cursor:pointer}.clone-tab span{display:block;height:1em;line-height:.88;transform:translateY(-.02em)}.rename-tab{position:absolute;z-index:12;top:26px;left:calc(50% - 36px);display:grid;place-items:center;width:28px;height:28px;padding:0;border:1px solid rgba(34,113,129,.45);border-radius:999px;background:#fff;color:var(--accent);opacity:0;transform:translate(-50%) translateY(6px);transition:opacity .12s ease,transform .12s ease;cursor:pointer}.delete-tab{position:absolute;z-index:12;top:33px;left:50%;display:grid;place-items:center;width:15px;height:15px;padding:0;border:1px solid rgba(159,64,59,.62);border-radius:999px;background:var(--danger);color:#fff;font-family:Arial,sans-serif;font-size:.74rem;font-weight:900;line-height:1;opacity:0;transform:translate(-50%) translateY(6px);transition:opacity .12s ease,transform .12s ease;cursor:pointer}.sheet-tab-wrap.deleting .rename-tab,.sheet-tab-wrap.deleting .clone-tab{opacity:0;pointer-events:none}.sheet-tab-wrap.deleting .sheet-tab{animation:tab-delete-vanish 2.2s ease-in forwards}.delete-tab.confirming{z-index:14;transition:none;animation:tab-delete-countdown 2.2s linear forwards,tab-delete-wiggle .12s steps(2,end) infinite}@keyframes tab-delete-countdown{0%{top:26px;width:28px;height:28px;font-size:1.35rem;opacity:1;box-shadow:0 0 0 8px #9f403b14}99%{top:35px;width:9px;height:9px;font-size:.45rem;opacity:1;box-shadow:0 0 #9f403b00}to{top:35px;width:9px;height:9px;font-size:.45rem;opacity:0;box-shadow:0 0 0 10px #9f403b00}}@keyframes tab-delete-wiggle{0%,to{transform:translate(-50%) translateY(0) translate(-3px) rotate(-8deg)}50%{transform:translate(-50%) translateY(0) translate(3px) rotate(8deg)}}@keyframes tab-delete-vanish{0%,99%{opacity:1}to{opacity:0}}.rename-tab svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.sheet-tab-wrap:hover .clone-tab,.sheet-tab-wrap:hover .rename-tab,.sheet-tab-wrap:hover .delete-tab,.clone-tab:focus-visible,.rename-tab:focus-visible,.delete-tab:focus-visible{opacity:1;transform:translate(-50%) translateY(0)}.tab-name-input{width:120px;height:37px;padding:0 18px;box-sizing:border-box;outline:0;border:1px solid var(--line);border-top:0;border-radius:0 0 8px 8px;text-align:center;cursor:text;caret-color:var(--accent);font-family:inherit;font-size:1rem;font-weight:800;line-height:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ecefeb;color:#202427}.tab-name-input.active{height:45px;background:#fff;color:var(--accent);border-color:var(--accent);box-shadow:0 -1px #fff}.tab-name-input:focus{border-bottom:3px solid rgba(34,113,129,.4)}@media(max-width:840px){.app-shell{grid-template-rows:minmax(0,1fr) 68px}.debug-popover{top:10px;right:10px}}.clone-tab.always-visible{opacity:1;transform:translate(-50%) translateY(0)}.clone-tab.flashing{animation:flash-clone .3s ease-in-out 3}@keyframes flash-clone{0%,to{transform:translate(-50%) translateY(0) scale(1);background:var(--success)}50%{transform:translate(-50%) translateY(-6px) scale(1.32);background:var(--accent)}}.delete-zone.tutorial-pulse{--delete-zone-level: 1;animation:delete-pulse 1s ease-in-out infinite;opacity:1!important}@keyframes delete-pulse{0%,to{transform:var(--delete-zone-center) scale(1);box-shadow:0 0 0 0 var(--delete-zone-pulse-shadow)}50%{transform:var(--delete-zone-center) scale(1.3);box-shadow:0 0 20px 10px var(--delete-zone-pulse-fade)}}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;pointer-events:auto;display:flex;align-items:flex-start;justify-content:center;padding:18px;cursor:pointer}.tutorial-tip{position:absolute;pointer-events:auto;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 18px;box-shadow:0 15px 45px #0003;display:flex;flex-direction:column;align-items:center;gap:6px;width:auto;min-width:160px;text-align:center;animation:tip-in .4s cubic-bezier(.175,.885,.32,1.275)}.scroll-tip{top:50%;left:50%;transform:translate(-50%,-50%);padding:24px 30px;min-width:240px}.add-tip,.drop-tip,.rename-tip{animation:tip-in .4s cubic-bezier(.175,.885,.32,1.275),tip-pulse 2s ease-in-out infinite}@keyframes tip-pulse{0%,to{box-shadow:0 15px 45px #0003,0 0 #22718100;border-color:var(--line)}50%{box-shadow:0 15px 45px #0003,0 0 0 6px #22718140;border-color:var(--accent)}}.add-tip{bottom:320px;left:180px}.drop-tip{bottom:180px;left:50%;transform:translate(-50%)}.rename-tip{bottom:65px;left:320px}@media(max-width:800px){.rename-tip{left:auto;right:20px;transform:none}}@keyframes tip-in{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.tutorial-tip h3{margin:0;font-size:1.2rem;color:var(--accent)}.tutorial-highlight{outline:3px solid var(--accent);outline-offset:4px;animation:pulse-highlight 2s ease-in-out infinite}@keyframes pulse-highlight{0%,to{outline-color:var(--accent)}50%{outline-color:transparent}}.floorplan.tutorial-zooming{transform-origin:center center;animation:floorplan-zoom-demo 2.8s ease-in-out infinite}@keyframes floorplan-zoom-demo{0%,to{transform:scale(1)}45%{transform:scale(1.025)}70%{transform:scale(.992)}}.tutorial-zoom-callout{position:relative;width:70px;height:48px;color:var(--accent)}.tutorial-mouse{position:absolute;left:50%;top:3px;width:26px;height:40px;border:2px solid currentColor;border-radius:14px;transform:translate(-50%);background:#fff}.tutorial-mouse span{position:absolute;left:50%;top:7px;width:4px;height:8px;border-radius:999px;background:currentColor;transform:translate(-50%);animation:tutorial-wheel 1.4s ease-in-out infinite}.tutorial-zoom-rings span{position:absolute;top:8px;right:18px;bottom:0;left:18px;border:2px solid rgba(34,113,129,.28);border-radius:999px;animation:tutorial-ring 2.8s ease-out infinite}.tutorial-zoom-rings span:nth-child(2){animation-delay:1.4s}@keyframes tutorial-wheel{0%,to{transform:translate(-50%) translateY(0);opacity:.95}50%{transform:translate(-50%) translateY(12px);opacity:.45}}@keyframes tutorial-ring{0%{transform:scale(.72);opacity:.6}to{transform:scale(1.7);opacity:0}}.tutorial-tip strong{color:var(--accent);font-size:.85rem;text-transform:uppercase;letter-spacing:.02em}.tutorial-tip span{color:var(--ink-soft);font-size:.78rem;font-weight:700;line-height:1.3}.tutorial-dismiss-hint{margin-top:12px;font-size:.8rem;color:var(--ink-soft);font-weight:700;opacity:.5;text-transform:uppercase;letter-spacing:.1em}.clone-tab.always-visible,.rename-tab.always-visible,.delete-tab.always-visible{opacity:1;transform:translate(-50%) translateY(0)}.rename-tab.flashing{animation:flash-rename 1.5s ease-in-out infinite}@keyframes flash-rename{0%,to{transform:translate(-50%) scale(1);background:#fff;border-color:var(--accent)}50%{transform:translate(-50%) scale(1.15);background:#fff;border-color:#fff;box-shadow:0 0 15px var(--accent)}}.rename-tab.tutorial-highlight{border:2px solid var(--accent);box-shadow:0 0 10px var(--accent)}@media(max-width:640px){.tutorial-actions{grid-template-columns:repeat(2,minmax(0,1fr))}}
