*{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}}#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}.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}#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}.settings{display:flex;flex-direction:column;gap:10px}.settings .row{display:flex;flex-direction:row;gap:10px}.settings .row label{font-size:13px;width:140px;line-height:28px}.settings .row input{padding:5px;border:1px solid #ccc;border-radius:3px;font-size:13px;flex:2}.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}.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}.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}.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 h2{font-size:12px;text-transform:uppercase;border-bottom:1px solid #ccc;margin-bottom:5px;color:#aaa}.sidebar .group{display:flex;flex-direction:column;gap:5px;width:100%}.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%}.preview{position:absolute;top:0;left:0;width:calc(100% - var(--sidebar-width));height:100%}.preview-inspector{top:20px;width:240px}.preview-inspector span.value{font-size:14px;color:var(--text-color);font-weight:500;text-align:right;display:inline-block;width:50%}
