.app-shell{display:flex;flex-direction:column;min-height:100dvh;height:100dvh;width:100%;max-width:100%;overflow:hidden;background:#e2e8f0}.workspace{display:grid;grid-template-rows:auto 1fr auto;min-height:100dvh;height:100dvh;background:#f8fafc;overflow:hidden}.toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;padding:14px 24px;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a14}.toolbar_section{display:flex;flex-direction:column;gap:8px}.toolbar_icon_button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:6px;border:1px solid #cbd5f5;background:#f1f5f9;color:#0f172a;cursor:pointer;transition:background .2s ease,border .2s ease}.toolbar_icon_button:hover{background:#e2e8f0}.room_editor_popover{position:absolute;top:calc(100% + 10px);left:0;z-index:12;min-width:220px;padding:16px;border-radius:10px;border:1px solid #cbd5f5;background:#fff;box-shadow:0 12px 28px #0f172a29}.room_editor_form{display:flex;flex-direction:column;gap:14px}.room_editor_heading{font-size:.85rem;font-weight:600;color:#0f172a}.toolbar_label{font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:#64748b}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.room_inputs{display:flex;gap:12px;align-items:flex-end}.room_inputs input{border-radius:6px;border:1px solid #cbd5f5;padding:6px 8px;background:#f8fafc;width:90px;font-size:.85rem}.room_input_label{display:flex;flex-direction:column;gap:6px;font-size:.7rem;letter-spacing:.02em;color:#475569}.dimension_separator{font-weight:600;color:#475569}.room_editor_actions{display:flex;justify-content:flex-end;gap:8px}.toolbar_action_wrapper{position:relative}.toolbar_tools,.toolbar_controls{display:flex;gap:8px}.toolbar_controls{display:flex;gap:8px;align-items:center}.toolbar_controls button+button{margin-left:0}.toolbar_action_group{display:flex;gap:8px}.toolbar_tool_button,.toolbar_control_button{display:inline-flex;align-items:center;gap:6px;border-radius:6px;border:1px solid #cbd5f5;background:#f1f5f9;color:#0f172a;padding:6px 10px;font-size:.85rem;cursor:pointer;transition:background .2s ease,border .2s ease}.toolbar_tool_button svg,.toolbar_control_button svg,.toolbar_icon_button svg{width:20px;height:20px;pointer-events:none}.toolbar_tool_button--icon,.toolbar_control_button--icon{width:40px;height:40px;padding:6px;gap:0;justify-content:center}.toolbar_control_button--icon{position:relative}.toolbar_button_label{display:inline-flex;align-items:center;gap:6px}.toolbar_tool_button.active,.toolbar_control_button.active{background:#2563eb;border-color:#2563eb;color:#fff}.toolbar_control_button:hover,.toolbar_tool_button:hover{background:#e2e8f0}.toolbar_control_button:disabled:not(.active),.toolbar_tool_button:disabled{cursor:not-allowed;opacity:.65}.toolbar_control_button--icon .toolbar_spinner{position:absolute;top:4px;right:4px;width:12px;height:12px;margin:0}.canvas-container{position:relative;display:flex;flex:1;background:#dde7f0;min-height:0;overflow:hidden}.canvas-shell{flex:1;position:relative;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.canvas-shell.cursor-add{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='32'><path fill='%231f2937' d='M2 2l11 11-5 0 5 10-5 2-5-10-3 3z'/><path fill='%232563eb' d='M20 10h4v4h4v4h-4v4h-4v-4h-4v-4h4z'/></svg>") 2 2,crosshair}.canvas-shell.cursor-erase{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='32'><path fill='%23f97316' d='M6 22l10-10 8 8-10 10z'/><path fill='%23dc2626' d='M16 8l4-4 10 10-4 4z'/><path fill='%239ca3af' d='M6 22l8 8H6z'/></svg>") 6 6,pointer}.canvas-shell canvas{width:100%!important;height:100%!important;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.texture-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#f8fafcd1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#0f172a;text-align:center;padding:16px;font-size:.95rem;font-weight:500}.texture-loading-text{font-size:.9rem}.texture-loading-overlay--error{background:#fee2e2eb;color:#b91c1c}.texture-spinner{width:28px;height:28px;border-radius:50%;border:3px solid rgba(37,99,235,.25);border-top-color:#2563eb;animation:spin .9s linear infinite}.toolbar_spinner{margin-left:0;width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.6);border-top-color:#fff;animation:spin .8s linear infinite;display:inline-block;vertical-align:middle;pointer-events:none}.toolbar_control_button:not(.active) .toolbar_spinner{border:2px solid rgba(37,99,235,.25);border-top-color:#2563eb}@keyframes spin{to{transform:rotate(360deg)}}.pip_viewport{position:absolute;top:18px;right:18px;width:clamp(120px,14vw,220px);max-width:calc(100% - 36px);max-height:calc(100% - 36px);aspect-ratio:var(--pip-aspect, 1);border-radius:12px;pointer-events:none;overflow:hidden;background:#0f172a73;border:1px solid rgba(148,163,184,.4);box-shadow:0 12px 28px #0f172a47;z-index:3}.pip_viewport canvas{width:100%!important;height:100%!important;display:block}.pip_viewport--hidden{display:none}.warnings-panel{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:2;display:flex;flex-direction:column;gap:8px}.warning{padding:8px 12px;border-radius:6px;font-size:.8rem;box-shadow:0 2px 6px #0f172a1f}.warning.info{background:#3b82f626;color:#1d4ed8}.warning.warning{background:#facc1533;color:#b45309}.warning.error{background:#f8717133;color:#b91c1c}.stats-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:12px 24px;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -1px 6px #0f172a0f;font-size:.9rem;z-index:3}.status-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:220px}.status-heading{display:flex;align-items:baseline;gap:12px;color:#0f172a;font-size:.85rem}.status-tool{font-weight:500;color:#475569}.status-message{color:#1d4ed8;font-weight:500}.status-tip{color:#475569;font-size:.8rem}.stats-metrics{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end}.stats-bar strong{color:#0f172a;margin-right:6px}@media (max-width: 720px){.workspace{grid-template-rows:auto 1fr 0}.toolbar{flex-wrap:wrap;align-items:flex-start;gap:12px;padding:12px 16px}.toolbar_section{flex:1 1 48%;min-width:0}.toolbar_section--actions{flex:1 1 100%}.toolbar_controls,.toolbar_tools{flex-wrap:wrap}.room_editor_popover{left:50%;transform:translate(-50%);width:min(320px,calc(100vw - 40px))}.stats-bar{position:absolute;bottom:16px;left:16px;right:16px;border-radius:12px;box-shadow:0 12px 24px #0f172a2e;padding:16px;background:#fffffff0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.warnings-panel{max-width:calc(100% - 24px)}.pip_viewport{max-width:calc(100% - 32px)}}:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#101828;background-color:#f4f6f8;line-height:1.5}body{margin:0}#root{width:100%;min-height:100vh;display:flex}button,input{font-family:inherit}
