*{margin:0;padding:0}body{width:100vw;height:100vh;overflow:hidden}:root{--sidebar-width: 400px;--font-family: Arial, Helvetica, sans-serif}#root{margin:0 auto;font-family:var(--font-family)}.loader{position:absolute;width:100%;text-align:center;color:#ccc;height:100%;display:flex;justify-content:center;align-items:center;flex-direction:column;opacity:0;animation:fadeIn .5s forwards}.loader .loader-icon{margin-bottom:10px;animation:spin 2s linear infinite;display:block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{to{opacity:1}}.mapping-label{-webkit-user-select:none;user-select:none;pointer-events:none;backface-visibility:hidden}.mapping-label .label{padding:4px 6px;opacity:.9;border-radius:2px;position:absolute;bottom:14px;left:-15px;box-shadow:0 1px 2px #0003}.mapping-label .label .arrow{position:absolute;top:100%;left:10px;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid transparent}.mapping-label h1{display:block;white-space:nowrap;font-size:16px;font-family:monospace;letter-spacing:1px;line-height:1}.mapping-label h2{display:block;white-space:nowrap;font-size:7px;font-weight:400;text-transform:uppercase;letter-spacing:1px;line-height:1}#auth form{margin:100px auto}#auth form input{border:1px solid #ccc;padding:5px 10px;background-color:#fff;border-radius:4px;line-height:20px}#auth form input:hover{border-color:#666}#auth form button{background-color:#000;border:1px solid #000;color:#fff;padding:5px 10px;line-height:20px;justify-content:center;text-transform:uppercase;font-weight:700}#auth form button:hover{cursor:pointer;background-color:#0cf;color:#fff;border-color:#0cf}#auth h2{text-align:center;margin-bottom:20px}#auth .logo{margin:0 auto 20px;width:100px;opacity:.8}#auth p{font-size:12px;text-align:center}.creator{display:flex;height:100vh;width:100vw;flex-direction:row;background-color:#f0f0f0;overflow:hidden}.scene{display:flex;flex-direction:column;justify-content:space-between;transition:ease-in-out .3s;height:100%;overflow:hidden}.sidebar{flex-shrink:1}.bottom-menus{display:flex;flex-direction:row;justify-content:space-between}.schematic{display:flex;height:100vh;width:100vw;flex-direction:row;background-color:#fff;overflow:hidden;justify-content:center;align-items:center}.schematic .lighten-50{fill:color-mix(in srgb,var(--fill) 40%,white)}.schematic text{font-family:Roboto,Arial,Helvetica,sans-serif}.cameraMenu{display:flex;gap:8px;padding:10px;justify-content:end;z-index:1000}button{padding:5px 10px;background:#fffc;box-shadow:0 1px 3px #0000001a;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid #ccc;border-radius:3px;display:flex;align-items:center;gap:5px}button:hover{cursor:pointer;background-color:#f15a24;color:#fff;border-color:#f15a24}.contextMenu{position:absolute;background:#ffffffe6;border:1px solid #ccc;box-shadow:0 4px 8px #0000001a;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:1001;top:0;left:0;-webkit-user-select:none;user-select:none;font-size:12px}.contextMenu li{display:flex;padding:5px 10px;cursor:pointer;list-style:none;width:200px;border-bottom:1px solid #eee;position:relative;z-index:1001;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.contextMenu li .label{display:flex;align-items:center;gap:8px;flex:1}.contextMenu li .shortcut{text-transform:capitalize;font-size:11px;color:#aaa}.contextMenu li:hover{background-color:#0000000d}.contextMenu li:hover .submenu{display:block}.contextMenu li:has(.submenu):after{content:"›";float:right;color:#aaa;font-size:12px;margin-top:2px}.contextMenu .submenu{display:none;position:absolute;left:100%;top:-1px;background:#ffffffd9;border:1px solid #ccc;box-shadow:0 4px 8px #0000001a}.elevation-settings{display:flex;flex-direction:column;gap:10px}.elevation-settings .elevation-item{display:flex;align-items:center;justify-content:start;gap:10px}.elevation-settings .elevation-item .elevation-label{font-size:13px;width:100px}.elevation-settings .elevation-item input{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:13px;flex:2;text-align:left;width:60px}.elevation-settings .elevation-item button{height:28px;gap:0}.modal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;padding:20px;background:#fff;border:1px solid #ccc;box-shadow:0 3px 3px #00000026;border-radius:2px;z-index:1000;flex-direction:column}.modal .modal-content{flex-grow:1}.modal .modal-actions button{float:right;margin-left:10px;margin-top:10px}.modal h2{margin-top:0;font-size:18px;color:#333;margin-bottom:20px}.modal button{float:right}.modal-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:2000}#floorplan-modal{position:relative;box-sizing:border-box;border:1px solid #ccc;width:100%;height:100%}#floorplan-modal .position-overlay{position:absolute;bottom:10px;left:50%;color:#000;z-index:10;transform:translate(-50%);padding:10px;background:#ffffffe6;border:1px solid #ccc;box-shadow:0 4px 8px #0000001a;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.shortcuts{display:flex;flex-direction:column;gap:8px;margin:10px 0 20px}.shortcuts .shortcut{display:flex;justify-content:space-between;font-size:14px}.shortcuts .shortcut .shortcut-key{color:#999}.layer-settings{display:flex;flex-direction:column;gap:10px}.layer-settings .layer-item{display:flex;align-items:center;justify-content:start;gap:10px}.layer-settings .layer-item .layer-label{font-size:13px;width:100px}.layer-settings .layer-item input{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:13px;flex:2;text-align:left;width:60px}.layer-settings .layer-item button{height:28px;gap:0}.project-list{display:flex;font-size:12px;align-items:start;margin-bottom:10px;padding:10px;border:1px solid #eee;border-radius:4px;background:#fffc;cursor:pointer;-webkit-user-select:none;user-select:none;gap:10px}.project-list.header{font-weight:700;background-color:#eee!important;cursor:default}.project-list:hover{background-color:#0000000d}.project-list .project-code{font-weight:700;color:#333;width:60px;flex-grow:0}.project-list .project-name{color:#555;width:calc((100% - 110px)/2)}.project-list .client-name,.project-list .project-owner{color:#777;width:calc((100% - 110px)/4)}.project-list .versions{color:#777;width:30px;flex-grow:0;text-align:center}.load-project-modal{max-height:calc(100vh - 200px);overflow-y:auto}.mapping-zone-modal{display:flex;flex-direction:column;gap:8px}.mapping-zone-modal .zone-option{border:1px solid #ccc;padding:8px;font-size:12px;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center}.mapping-zone-modal .zone-option svg{margin-right:6px}.mapping-zone-modal .zone-option:hover{background-color:#f0f0f0;cursor:pointer}.mapping-zone-modal .zone-color{width:12px;height:12px;border-radius:2px;margin-right:8px}.settings{display:flex;flex-direction:column;gap:10px}.settings .row{display:flex;flex-direction:row;gap:10px}.settings .row label{font-size:13px;width:200px;line-height:28px}.settings .row input{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:13px;flex:2}.quotation-builder-modal{width:100%;height:100%;max-height:calc(100vh - 200px);overflow-y:auto}.quotation-builder-modal h1{font-size:16px;margin:10px 0}.quotation-builder-modal .layer-table{display:grid;grid-template-columns:30px 110px 360px 60px 110px 110px 1fr;font-size:11px}.quotation-builder-modal .layer-table div{padding:8px 10px}.quotation-builder-modal .layer-table .header{font-weight:400;border-bottom:2px solid #000}.quotation-builder-modal .layer-table .row-subheader{font-weight:700;grid-column:span 7;background-color:#eee;text-transform:uppercase;letter-spacing:1px}.quotation-builder-modal .layer-table .row{border-top:1px solid #eee}.quotation-builder-modal .layer-table .row.editable{padding:0;position:relative}.quotation-builder-modal .layer-table .row .editable-value{padding:8px 10px;white-space:pre-wrap}.quotation-builder-modal .layer-table .row .editable-value div{padding:0}.quotation-builder-modal .layer-table .row .editable-value.overwritten{background-color:#ffd3644d;border:1px solid rgba(255,211,100,1);box-sizing:border-box;padding:7px 8px}.quotation-builder-modal .layer-table .row .editable-value.index{min-width:20px}.quotation-builder-modal .layer-table .row .originalValue{position:absolute;top:-7px;right:-7px;-webkit-user-select:none;user-select:none;pointer-events:none;opacity:.5;text-align:right;width:100px;font-size:10px}.quotation-builder-modal .layer-table .row-price{text-align:right}.quotation-builder-modal .layer-table .row-price span{float:left}.quotation-builder-modal .layer-table .description{font-size:10px}.quotation-builder-modal .layer-table .index,.quotation-builder-modal .layer-table .quantity{text-align:center}.quotation-builder-modal .layer-table .additional-cost-index{position:relative;display:flex;align-items:flex-start;justify-content:center;gap:4px}.quotation-builder-modal .layer-table .remove-cost-btn{cursor:pointer;color:#ccc;font-size:14px;line-height:1;-webkit-user-select:none;user-select:none;position:absolute;top:8px;right:10px}.quotation-builder-modal .layer-table .remove-cost-btn:hover{color:#e7a900}.quotation-builder-modal .layer-table .add-cost-row{grid-column:span 7;cursor:pointer;color:#aaa;border-top:1px solid #000;font-size:11px;position:relative;-webkit-user-select:none;user-select:none}.quotation-builder-modal .layer-table .add-cost-row:hover{color:#333;background-color:#f9f9f9}.quotation-builder-modal .layer-table .add-cost-row .preset-dropdown{position:absolute;bottom:100%;left:0;min-width:200px;background:#fff;border:1px solid #ddd;box-shadow:0 -4px 12px #0000001a;z-index:100}.quotation-builder-modal .layer-table .add-cost-row .preset-option{padding:8px 12px;color:#333;cursor:pointer}.quotation-builder-modal .layer-table .add-cost-row .preset-option:hover{background-color:#f5f5f5}.quotation-builder-modal .layer-table .add-cost-row .preset-divider{border-top:1px solid #eee;margin:2px 0;padding:0}.replace-module-modal{display:flex;flex-direction:column;gap:8px}.replace-module-modal .module-type{border:1px solid #ccc;padding:8px;font-size:12px}.replace-module-modal .module-type svg{margin-right:6px}.replace-module-modal .module-type:hover{background-color:#f0f0f0;cursor:pointer}.zone-settings{display:flex;flex-direction:column;gap:10px}.zone-settings .zone-item{display:flex;align-items:center;justify-content:start;gap:10px}.zone-settings .zone-item .zone-label{font-size:13px;width:100px}.zone-settings .zone-item input{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:13px;flex:2;text-align:left;width:60px}.zone-settings .zone-item button{height:28px;gap:0}.debugOverlay{position:absolute;bottom:10px;right:10px;min-width:300px;padding:10px;background-color:#ffffffe6;border:1px solid #ccc;font-size:10px;font-family:monospace;display:flex;flex-direction:column;gap:20px;z-index:10000}.debugOverlay button{float:right;margin-left:5px;padding:0 5px}.elevationMenu{display:flex;gap:8px;padding:10px;justify-content:end;z-index:1000;overflow:hidden}.elevationMenu .elevation-level{position:absolute;bottom:0;left:25px;transform:scaleY(.5)}.elevationMenu .elevation-level span{display:block;width:60px;height:60px;position:relative;transform:rotate(45deg);background:#ffffff1a;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid #ccc;border-radius:3px;box-shadow:0 2px 2px #0000001a;cursor:pointer;box-sizing:border-box}.elevationMenu .elevation-level.active span{background-color:#fff;border-color:#999;border-width:1px}.elevationMenu .elevation-level.active div{opacity:1}.elevationMenu .elevation-level div{position:absolute;top:30px;left:18px;width:50px;opacity:.3;transform:rotate(-45deg);pointer-events:none;text-align:center}.inspector{position:absolute;top:120px;left:20px;width:300px;padding:10px 10px 20px;background:#ffffffe6;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid #ccc;border-radius:3px;box-shadow:0 2px 2px #0000001a;display:flex;flex-direction:column;gap:10px;z-index:110}.inspector .inspector-header{display:flex;gap:10px;align-items:center;margin-bottom:10px}.inspector .inspector-header h2{font-size:14px;letter-spacing:1px}.inspector .row{display:flex;flex-direction:row;gap:5px;align-items:center}.inspector .section{padding:10px 0 0;display:flex;flex-direction:column;gap:10px;border-top:1px solid #ddd}.inspector input{box-sizing:border-box;flex:0;font-size:13px;padding:5px;border:1px solid #ccc;border-radius:3px;width:100%;font-family:system-ui}.inspector input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.inspector input:disabled{border:1px solid transparent}.inspector label{font-size:13px;flex:0;flex-basis:90px}.inspector select{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:13px;background-color:#fff;flex:1;width:205px}.inspector .unit{text-align:left;font-size:13px;position:absolute;top:0;padding:6px;pointer-events:none;font-family:system-ui}.inspector .unit span{color:#f90;visibility:hidden}.inspector .inspector-notes{position:absolute;top:calc(100% + 10px);left:-1px;width:300px;padding:10px 10px 20px;background:#ffffffe6;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid #ccc;border-radius:3px;box-shadow:0 2px 2px #0000001a;display:flex;flex-direction:column;gap:10px}.inspector .inspector-notes textarea{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:12px;flex:2;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.inspector .inspector-notes label{font-size:13px;flex:0;flex-basis:0}.inspector .inspector-notes-button{position:absolute;top:calc(100% + 10px);left:-1px;height:28px}.menu{display:flex;padding:20px;gap:20px;align-items:center;z-index:1000}.menu ul{display:flex;gap:1px;border:1px solid #ccc;background-color:#fff;border-radius:3px;box-shadow:0 2px 2px #0000001a}.menu ul li{padding:5px 10px;list-style:none;font-size:13px;position:relative;line-height:20px;-webkit-user-select:none;user-select:none;display:flex;gap:10px;justify-content:space-between;align-items:center}.menu ul li .disabled{text-decoration:line-through;color:#aaa;cursor:default}.menu ul li .description{font-size:11px;color:#aaa}.menu ul li.version{flex-direction:column;align-items:flex-start;gap:0;border-bottom:1px solid #eee}.menu ul li.version.version-active{border-left:3px solid black;padding-left:7px}.menu ul li.version.version-active .label{font-weight:700}.menu ul li.version .description{display:flex;justify-content:space-between;width:100%}.menu ul li.divider{height:0;border-top:1px solid #ddd;padding:0}.menu ul li:not(.logo):hover{cursor:pointer;background-color:#0000000d}.menu ul li:not(.logo):hover .submenu{display:block}.menu ul li:after{content:"";display:block;height:20px;background-color:#ccc;right:-1px;width:1px;position:absolute;top:5px}.menu ul li:last-of-type:after,.menu ul li .submenu li:after{display:none}.menu ul a{text-decoration:none;color:#000}.menu ul .submenu{display:none;position:absolute;left:0;top:calc(100% + 10px);min-width:250px;max-height:90vh;overflow-y:auto;background:#ffffffe6;border:1px solid #ccc;box-shadow:0 4px 8px #0000001a}.menu ul .submenu:after{display:block;content:"";width:100%;height:20px;top:42px;position:fixed}.menu .project-name{font-size:12px;white-space:nowrap}.menu .unsaved{color:#c00000;font-weight:700;font-size:12px;text-align:right;margin-left:auto}.sidebar{font-size:12px;border-left:1px solid #ddd;z-index:1000;background-color:#fff;box-shadow:-1px 0 3px #0000000d;position:relative;height:100vh}.sidebar.hidden{transform:translate(calc(100% - 30px));transition:all .3s ease-in-out;width:30px}.sidebar.visible{transition:all .3s ease-in-out;width:var(--sidebar-width)}.sidebar .sidebar-content{width:calc(var(--sidebar-width) - 40px);display:flex;flex-direction:column;flex-grow:1;gap:20px;padding:20px;height:calc(100vh - 40px);overflow-y:auto;overflow-x:hidden}.sidebar button{margin-right:10px}.sidebar h1{font-size:14px;text-transform:uppercase;color:#000;display:flex;align-items:center;gap:8px;margin-bottom:10px}.sidebar h1 div.color-label{width:12px;height:12px;border-radius:2px;border:1px solid rgba(0,0,0,.2)}.sidebar h2{font-size:12px;text-transform:uppercase;border-bottom:1px solid #ccc;margin-bottom:5px;margin-top:5px;color:#aaa}.sidebar .group{display:flex;flex-direction:column;gap:5px;width:100%}.sidebar .group.total h2{color:#000;border-bottom:1px solid #000}.sidebar .item{display:flex;align-items:center;gap:20px;cursor:pointer}.sidebar .item .amount{letter-spacing:1px;width:30px}.sidebar .item .type{font-weight:700;cursor:pointer;flex:1}.sidebar .item .length{flex:1;font-size:10px}.sidebar .item .specs{display:flex;flex-direction:row;gap:1px}.sidebar .item .voltage{flex:0;font-size:9px;padding:1px 5px;border-radius:5px;color:#fff;background-color:#ccc}.sidebar .item .voltage.v48{background-color:#8a6629}.sidebar .item .voltage.v24{background-color:#9f335e}.sidebar .item .rpm{flex:0;font-size:9px;padding:1px 5px;border-radius:5px;color:#fff;background-color:#ccc}.sidebar .item .rpm.r506{background-color:#336f99}.sidebar .item .rpm.r1033{background-color:#339972}.sidebar .item .cost{width:64px;display:flex;justify-content:space-between;font-size:11px}.sidebar .item .cost.hide{background-color:#eee;color:transparent}.sidebar .item.selected:after{content:"›";position:absolute;left:10px;font-size:12px;color:#f15a24;margin-top:3px}.sidebar .total-cost{justify-content:flex-end}.sidebar .total-cost .total{font-weight:700}.sidebar .sidebar-toggle{position:absolute;bottom:10px;left:-5px;width:28px;height:28px;background-color:#fff;color:#000;box-shadow:0 1px 3px #0000001a;border:1px solid #ccc;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:3px;font-size:15px;line-height:20px;-webkit-user-select:none;user-select:none;z-index:1001;box-sizing:border-box;padding:6px}.sidebar .sidebar-toggle:hover{opacity:1;background-color:#f15a24;color:#fff;border-color:#f15a24}.cameraView{position:absolute;top:0;left:0;height:100%}.layersPanel{position:absolute;left:10px;bottom:10px;font-size:12px;display:flex;flex-direction:column;gap:2px;z-index:109}.layersPanel .layers-header{font-weight:700;margin-bottom:5px}.layersPanel .layer{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;gap:5px;align-items:center;padding:5px 10px 5px 5px;background:#fffc;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid #ccc;border-radius:3px}.layersPanel .layer.inactive{opacity:.5}.layersPanel .layer .color-indicator{width:6px;height:6px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}.preview{position:absolute;top:0;left:0;width:calc(100% - var(--sidebar-width));height:100%}.preview-inspector{top:20px;width:240px}.preview-inspector .row{display:flex;flex-direction:row;gap:5px;align-items:start}.preview-inspector span.value{font-size:14px;color:var(--text-color);font-weight:500;text-align:right;display:inline-block;width:50%;white-space:pre-line}.mapping-inspector{width:240px}.mapping-inspector span.value{font-size:14px;color:var(--text-color);font-weight:500;text-align:right;display:inline-block;width:50%;white-space:pre-line}.quote{height:100vh;width:100vw;background-color:#f0f0f0;overflow-y:auto;display:flex;flex-direction:column;align-items:center}.quote-table{padding:60px;background-color:#fff;margin:20px 0;box-shadow:0 2px 5px #0000001a}.quote-table table tr,.quote-table table td{page-break-inside:avoid;break-inside:avoid}.quote-table img.logo{float:right}.quote-table h1{font-size:24px;color:#333;margin-top:5px}.quote-table h2{margin-top:2px;font-size:18px;color:#666}.quote-table table{border-collapse:collapse;background-color:#fff;font-size:12px;margin-top:40px;box-sizing:border-box}.quote-table table .price{text-align:right;width:80px}.quote-table table .price span{float:left}.quote-table table .product-name{text-align:left;width:120px}.quote-table table .amount{text-align:center;width:60px}.quote-table table .additional-info{text-align:left;white-space:pre-wrap;font-size:11px;line-height:14px;border-right:10px solid transparent;page-break-inside:avoid;break-inside:avoid}.quote-table table .price{text-align:right}.quote-table tbody tr{border-left:1px solid #eee;border-right:1px solid #eee}.quote-table table tr{padding:0;margin:0;border-bottom:1px solid #eee}.quote-table table tr.total-row{border-left:0;border-right:0;font-weight:700;border-bottom:none}.quote-table table tr.total-row td{padding:10px}.quote-table table tr.group-header{background-color:#f9f9f9;font-weight:700}.quote-table table td{margin:0;padding:5px 10px;vertical-align:top}.quote-table table th{text-align:left;padding:10px;text-transform:uppercase;font-size:10px;font-weight:400;color:#999}.quote-table table th.layer-name{width:50px}.quote-table .layer-row{border-left:0;border-right:0}.quote-table .layer-row th{padding-top:60px;padding-left:0;font-size:14px;color:#000;font-weight:700}
