*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;margin:0;padding:0;overflow:hidden;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#111}#root{width:100%;height:100%}:root{--label-size: .06}.controls-container{display:flex;flex-direction:column;width:100%}.controls-toolbar{display:flex;background-color:#4a5568;padding:0 8px;gap:8px;border-bottom:1px solid #4a5568;justify-content:flex-start;align-items:center;position:relative;color:#fff}.controls-toolbar *{color:#fff!important}.vertical-separator{width:1px;height:24px;background-color:#e0e0e0;margin:0 12px}.menu-bar{display:flex;gap:0;align-items:center}.menu-item{color:#fff!important;padding:8px 12px;cursor:pointer;position:relative;font-size:13px;border-radius:0;border-right:1px solid transparent;border-left:1px solid transparent}.menu-item:hover{background-color:#f0f0f0;border-color:#e0e0e0}.menu-dropdown{position:absolute;top:100%;left:-1px;background-color:#fff;border:1px solid #e0e0e0;border-radius:5px;min-width:200px;box-shadow:0 4px 12px #0000001a;z-index:1000;display:none;padding:5px 0}.menu-dropdown.active,.menu-item.submenu:hover>.menu-dropdown{display:block}.menu-dropdown button{display:block;width:100%;text-align:left;padding:8px 15px;border:none;background:none;color:#333!important;font-size:13px;cursor:pointer}.menu-dropdown button:hover{background-color:#007acc}.menu-divider{height:1px;background-color:#f0f0f0;margin:5px 0}.menu-item.submenu{position:relative;padding-right:24px;color:#333!important}.menu-item.submenu:after{content:"▶";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:10px;color:#fff!important}.submenu-dropdown{top:-6px;left:100%}.control-group{display:flex;gap:8px;align-items:center}.toolbar-button{background-color:#3d3d3d;border:1px solid #4d4d4d;padding:6px 12px;border-radius:3px;cursor:pointer;font-size:13px;transition:background-color .2s}.toolbar-button:hover{background-color:#4d4d4d}.toolbar-button.upload-json{background-color:#2196f3;border-color:#1976d2}.toolbar-button.upload-json:hover{background-color:#1976d2}.toolbar-button.sample-button{background-color:#4caf50;border-color:#388e3c}.toolbar-button.sample-button:hover{background-color:#388e3c}.file-loaded{color:#4caf50;font-size:13px}.load-case-select{background-color:#3d3d3d;border:1px solid #4d4d4d;padding:4px 8px;border-radius:3px;font-size:13px}label{font-size:13px}.left-section{display:flex;align-items:center;gap:0}.undo-redo-buttons{display:flex;align-items:center;gap:4px}.toolbar-actions{display:flex;align-items:center;gap:8px;position:absolute;right:8px}.toolbar-icon-button{background:transparent;border:1px solid transparent;color:#555;font-size:15px;cursor:pointer;padding:6px;border-radius:4px;transition:all .2s ease}.toolbar-icon-button:hover{color:#000;background-color:#f0f0f0;border-color:#e0e0e0}.toolbar-icon-button.disabled{opacity:.5;cursor:not-allowed}.toolbar-icon-button.disabled:hover{color:#555;background-color:transparent;border-color:transparent}.file-name-container{position:absolute;left:50%;transform:translate(-50%);text-align:center;max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:5px 10px;font-size:14px;color:#555;cursor:default;-webkit-user-select:none;user-select:none}.file-name{font-weight:500}.user-menu{position:relative;display:flex;align-items:center}.login-button{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid #e0e0e0;color:#555;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.login-button:hover{background-color:#f0f0f0;color:#000}.user-button{display:flex;align-items:center;gap:8px;background:transparent;border:1px solid transparent;color:#555;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.user-button:hover{background-color:#f0f0f0;border-color:#e0e0e0}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.user-icon{font-size:16px}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown{position:absolute;top:100%;right:0;background-color:#fff;border:1px solid #e0e0e0;border-radius:5px;min-width:200px;box-shadow:0 4px 12px #0000001a;z-index:1000;padding:8px 0;margin-top:4px}.user-info{padding:8px 16px}.user-display-name{font-weight:600;color:#333;font-size:14px}.user-email{color:#666;font-size:12px;margin-top:2px}.menu-divider{height:1px;background-color:#f0f0f0;margin:8px 0}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 16px;border:none;background:none;color:#333;font-size:13px;cursor:pointer;transition:background-color .2s ease}.dropdown-item:hover{background-color:#f0f0f0}.ribbon{display:flex;flex-direction:column;background-color:#fff;border-bottom:1px solid #d1d1d1;font-family:Segoe UI,sans-serif;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;position:relative}.ribbon-pin-button{position:absolute;bottom:5px;right:5px;z-index:1002}.ribbon-pin-button .pin-button{font-size:.8rem;padding:2px 4px;line-height:1;border:none;background:transparent;cursor:pointer;color:#666;border-radius:2px;transition:background-color .2s ease}.ribbon-pin-button .pin-button:hover{background-color:#0000001a}.ribbon-section{display:flex;flex-direction:column;padding:5px 5px 1px;border-right:1px solid #d1d1d1;justify-content:space-between;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;min-height:80px}.ribbon-section:last-child{padding:5px 5px 1px}.ribbon-buttons{display:flex;align-items:flex-start;gap:5px;flex-grow:1;min-height:60px;padding:1px 0}.section-label{text-align:center;font-size:11px;color:#595959;margin-top:2px}.ribbon-button{display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent!important;border:1px solid transparent!important;padding:5px!important;border-radius:2px!important;cursor:pointer;min-width:50px;gap:3px;height:100%;color:#333!important}.ribbon-button:hover{background-color:#cce8ff!important;border-color:#99d1ff!important;color:#333!important}.ribbon-button.active{background-color:#99d1ff!important;border-color:#0078d7!important;color:#333!important}.ribbon-button svg{font-size:22px;color:#333!important}.ribbon-button span{font-size:11px;color:#333!important;text-align:center;white-space:normal;line-height:1.2}.ribbon-select{border:1px solid #ababab;border-radius:0;background-color:#fff;padding:4px;font-size:12px;align-self:center;width:150px}.button-group-column{display:flex;flex-direction:column;gap:2px}.button-group-row{display:flex;flex-direction:row;gap:2px}.button-group-column .ribbon-button,.button-group-row .ribbon-button{padding:2px;min-width:auto;gap:1px;height:auto}.button-group-column .ribbon-button svg,.button-group-row .ribbon-button svg{font-size:16px;margin:0}.button-group-column .ribbon-button span,.button-group-row .ribbon-button span{display:none}.button-group-wrapper:first-child .button-group-column .ribbon-button span{display:block;font-size:9px;line-height:1.1}.button-group-wrapper{display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;min-height:60px;justify-content:flex-start;padding:1px 0}.button-group-wrapper>span{font-size:11px;text-align:center}.select-wrapper{display:flex;flex-direction:column;gap:2px;align-items:flex-start;justify-content:flex-start;height:100%;min-height:60px;padding:1px 5px}.select-wrapper .select-label{font-size:11px;color:#333;margin-bottom:2px}.edit-button-group{display:flex;gap:5px;padding:1px 0;min-height:60px;align-items:flex-start}.edit-button-column{display:flex;flex-direction:column;gap:2px;height:100%;min-height:60px;justify-content:flex-start}.ribbon-button.edit-button{flex-direction:row;justify-content:flex-start;align-items:center;gap:8px;width:auto;min-width:fit-content;height:22px;padding:3px 6px!important;font-size:11px;background:transparent!important;border:1px solid transparent!important;color:#333!important}.button-group-wrapper .button-group-column .ribbon-button.edit-button{width:auto;min-width:fit-content;padding:3px 6px!important}.button-group-wrapper .button-group-column .ribbon-button.edit-button span{display:inline!important}.ribbon-button.edit-button.active{background-color:#99d1ff!important;border-color:#0078d7!important;color:#333!important}.ribbon-button.edit-button:hover{background-color:#cce8ff!important;border-color:#99d1ff!important;color:#333!important}.ribbon-button.edit-button svg{font-size:14px;flex-shrink:0;font-family:Consolas,Menlo,monospace;color:#333!important}.ribbon-button.edit-button span{text-align:left;color:#333!important}.ribbon-button.edit-button .renumber-icon{font-weight:700;font-size:13px;width:16px;text-align:center;font-family:Consolas,Menlo,monospace;flex-shrink:0}.ribbon-button.edit-button .delete-icon{color:#d9534f}.ribbon-button.disabled{opacity:.5!important;cursor:not-allowed!important;pointer-events:none}.ribbon-button.disabled:hover{background-color:transparent!important;border-color:transparent!important}.select-button-wrapper{position:relative;display:flex;flex-direction:column;align-items:stretch;border:1px solid transparent;border-radius:2px}.select-button-wrapper:hover{border-color:#99d1ff;background-color:#cce8ff}.select-button-wrapper>.ribbon-button{background:transparent!important;border:none!important}.select-button-wrapper>.ribbon-button:hover{background:transparent!important;border:none!important}.select-dropdown-trigger{background:transparent;border:none;border-top:1px solid #c1d3e2;padding:1px 0;cursor:pointer;line-height:1;transition:none}.select-dropdown-trigger:hover{background:transparent}.select-button-wrapper:hover .select-dropdown-trigger{border-top-color:#99d1ff;background:transparent}.select-dropdown-trigger .caret-down{font-size:10px;color:#666}.select-button-wrapper .ribbon-button svg{font-size:28px;color:#4caf50;margin-bottom:2px}.select-button-wrapper .caret-down{font-size:10px;margin-top:-2px;color:#666}.dropdown-menu{position:absolute;top:100%;left:0;background-color:#fff;border:1px solid #ababab;box-shadow:0 4px 8px #0000001a;z-index:10;min-width:100%;border-radius:2px;padding:0}.dropdown-menu .dropdown-item{padding:6px 12px;font-size:11px;color:#333;display:block;text-decoration:none;white-space:nowrap}.dropdown-menu .dropdown-item:hover{background-color:#cce8ff}.tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;white-space:nowrap;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;margin-bottom:5px}.tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#333}.ribbon-button:hover .tooltip{opacity:1;visibility:visible}.ribbon-button.geometry-button{min-width:50px!important;height:60px!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:3px!important}.ribbon-button.check-structure-button{min-width:70px!important;max-width:70px!important}.ribbon-button.check-structure-button span{white-space:normal!important;word-wrap:break-word!important;text-align:center!important;line-height:1.1!important;width:100%!important}.table-button-wrapper{position:relative;display:flex;flex-direction:column;align-items:stretch;border:1px solid transparent;border-radius:2px}.table-button-wrapper:hover{border-color:#99d1ff;background-color:#cce8ff}.table-button-wrapper>.ribbon-button{background:transparent;border:none}.table-caret{font-size:10px;color:#666;margin-left:4px}.dropdown-menu.table-dropdown{min-width:180px;padding:0}.dropdown-submenu{border-bottom:1px solid #e0e0e0}.dropdown-submenu:last-child{border-bottom:none}.submenu-header{font-weight:700;background-color:#f5f5f5;padding:8px 12px!important;color:#333!important;border-bottom:1px solid #e0e0e0;cursor:default}.submenu-header:hover{background-color:#f5f5f5!important}.submenu-items{padding:0}.submenu-item{padding:6px 20px!important;font-size:11px!important;color:#555!important}.submenu-item:hover{background-color:#cce8ff!important;color:#333!important}.operations-button-wrapper{position:relative;display:flex;flex-direction:column;align-items:stretch;border:1px solid transparent;border-radius:2px}.operations-button-wrapper:hover{border-color:#99d1ff;background-color:#cce8ff}.operations-button-wrapper>.ribbon-button{background:transparent;border:none}.operations-caret{font-size:10px;color:#666;margin-left:auto}.dropdown-menu.operations-dropdown{min-width:140px}.dropdown-item.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.dropdown-item.disabled:hover{background-color:transparent}.plates-button-wrapper{position:relative;display:flex;flex-direction:column;align-items:stretch;border:1px solid transparent;border-radius:2px}.plates-button-wrapper:hover{border-color:#99d1ff;background-color:#cce8ff}.plates-button-wrapper>.ribbon-button{background:transparent;border:none}.plates-caret{font-size:10px;color:#666;margin-left:auto}.dropdown-menu.plates-dropdown{min-width:120px}.dropdown-menu.parallel-dropdown{min-width:100%;width:100%}.dropdown-separator{height:1px;background-color:#e0e0e0;margin:4px 0;border:none}.general-button{height:68px!important;min-height:68px!important;min-width:60px!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:3px!important}.ribbon-tabs{display:flex;background-color:#4a5568;padding:0;margin:0;height:24px;align-items:stretch}.ribbon-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:none;padding:2px 10px;cursor:pointer;min-width:60px;height:24px;gap:0;color:#fff;font-size:11px;transition:background-color .2s ease;margin-bottom:-1px;position:relative;z-index:2;border-radius:0}.ribbon-tab span{font-size:11px;color:#fff;text-align:center;white-space:nowrap;line-height:1}.ribbon-tab:hover{background-color:#2d3748}.ribbon-tab.active{background-color:#fff;color:#2d3748;z-index:3;border-radius:0}.ribbon-tab.active span{color:#2d3748}.ribbon-content{display:flex;align-items:stretch;background:#fff;margin:0;border-top:none;position:relative;z-index:1;height:101px;transition:height .3s ease-in-out;overflow:visible}.ribbon-content.hidden{height:0!important}.ribbon-content.visible{height:101px}.file-tab-wrapper{position:relative}.ribbon-tab.file-tab{background-color:#4a5568}.ribbon-tab.file-tab:hover{background-color:#2d3748}.file-dropdown{position:absolute;top:100%;left:0;background-color:#fff;border:1px solid #d1d1d1;box-shadow:0 4px 8px #0000001a;z-index:1000;min-width:150px;border-radius:2px;padding:4px 0}.file-dropdown-item{padding:8px 16px;font-size:12px;color:#333;cursor:pointer;transition:background-color .2s ease}.file-dropdown-item:hover{background-color:#cce8ff}.file-dropdown-divider{height:1px;background-color:#e0e0e0;margin:4px 0}.file-dropdown-submenu{position:relative;padding:8px 16px;font-size:12px;color:#333;cursor:pointer;transition:background-color .2s ease}.file-dropdown-submenu:hover{background-color:#cce8ff}.file-dropdown-submenu:hover .file-dropdown-submenu-items{display:block}.file-dropdown-submenu-items{display:none;position:absolute;top:0;left:100%;background-color:#fff;border:1px solid #d1d1d1;box-shadow:0 4px 8px #0000001a;min-width:150px;border-radius:2px;padding:4px 0;z-index:1001}.file-dropdown-submenu-items .file-dropdown-item{padding:6px 12px;font-size:11px}.ribbon-button.analyze-button{min-width:80px!important;max-width:90px!important}.ribbon-button.analyze-button span{white-space:normal!important;word-wrap:break-word!important;text-align:center!important;line-height:1.1!important;width:100%!important}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fffc;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.loading-content{display:flex;flex-direction:column;align-items:center;background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #0000001a}.loading-spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-message{font-size:1.2rem;color:#333;font-weight:500}.loading-timer{font-size:1rem;color:#666;margin-top:.5rem;font-family:monospace}.loading-cancel-btn{margin-top:1rem;padding:.5rem 1rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.loading-cancel-btn:hover{background-color:#c0392b}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.load-case-selector{position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:999;background:#fff;border:1px solid #d1d1d1;border-top:none;border-radius:0 0 4px 4px;padding:8px 12px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:8px}.load-case-selector label{font-size:14px;font-weight:500;color:#333;margin:0}.load-case-selector select{padding:4px 8px;border:1px solid #ccc;border-radius:3px;font-size:14px;min-width:150px;outline:none}.box-selection-indicator{position:absolute;border:1px solid #55aaff;background-color:#4ba0ff1a;pointer-events:none;z-index:1000}.box-selection-cursor{cursor:default}.left-sidebar{background:linear-gradient(135deg,#f8f9fa,#e9ecef);box-shadow:2px 0 10px #0000001a;width:320px;min-width:320px;position:absolute;z-index:1000;height:calc(100vh - 28px);transition:transform .3s ease-in-out;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;left:0}.left-sidebar>div{padding:0 0 30px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;max-height:calc(100vh - 140px);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;display:flex;flex-direction:column}.sidebar-option label{color:#333!important;font-weight:500}.sidebar-header{padding:2px 4px;margin:0;display:flex;align-items:center;justify-content:space-between}.sidebar-header h3{margin:0;font-size:.9rem;line-height:1}.sidebar-tabs-container{display:flex;background-color:#f8f9fa;padding:0;margin:0;height:32px;align-items:center;justify-content:space-between;border-bottom:1px solid #e9ecef}.sidebar-tabs{display:flex;flex:1;height:100%;align-items:stretch}.sidebar-tab{display:flex;align-items:center;justify-content:center;background:transparent;border:none;padding:2px 10px;cursor:pointer;min-width:60px;height:32px;color:#333;font-size:12px;font-weight:500;transition:background-color .2s ease;margin-bottom:-1px;position:relative;z-index:2;border-radius:0}.sidebar-tab:hover{background-color:#e9ecef;color:#000}.sidebar-tab.active{background-color:#fff;color:#000;font-weight:600;z-index:3;border-radius:0}.pin-button{font-size:.8rem;padding:0 8px;line-height:1;border:none;background:transparent;cursor:pointer;color:#666;height:100%;display:flex;align-items:center;justify-content:center}.pin-button:hover{background-color:#e9ecef}.sidebar-section{margin-bottom:10px;background-color:#fff;border:1px solid #dcdcdc;border-radius:2px}.sidebar-section h4{margin:0;font-weight:700;font-size:12px;padding:6px 10px;color:#444;background:#e9e9e9;border-radius:0;border-left:none;border-bottom:1px solid #dcdcdc}.sidebar-button{padding:8px 12px;font-size:.9rem;font-weight:500;border:1px solid #dee2e6;border-radius:6px;background:linear-gradient(135deg,#fff,#f8f9fa);color:#212529;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.sidebar-button:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6);border-color:#adb5bd;color:#000;transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.sidebar-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.sidebar-section-content{padding:10px;display:flex;flex-direction:column;gap:5px}.sidebar-top-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;align-items:start}.sidebar-groups-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:start}.sidebar-option{display:flex;align-items:center;gap:0px;padding:0;margin-bottom:2px}.sidebar-option input[type=checkbox]{margin-top:1px;width:14px;height:14px}.sidebar-option label{font-size:.75rem!important;margin:0;display:flex;align-items:center}.sidebar-option label input[type=checkbox],.sidebar-option label input[type=radio]{margin-right:5px}.sidebar-select,.sidebar-input{width:100%;padding:5px;margin-bottom:10px}.sidebar-slider-container{padding:0;display:flex;flex-direction:column;width:100%}.sidebar-slider-container h4{margin:0 0 5px;font-size:12px;font-weight:400}.sidebar-slider{width:100%;margin-bottom:5px}.slider-value{font-size:11px;text-align:center;color:#555;margin-top:2px}.left-sidebar>div::-webkit-scrollbar{width:8px}.left-sidebar>div::-webkit-scrollbar-thumb{background:#aaa;border-radius:4px}.sidebar{background:linear-gradient(135deg,#f8f9fa,#e9ecef);box-shadow:2px 0 10px #0000001a;width:320px;min-width:320px;position:absolute;z-index:1000;height:100%;top:0;bottom:0;transition:transform .3s ease-in-out;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;overflow:hidden}.left-sidebar{left:0}.right-sidebar{right:0}.sidebar-section{margin:0;background-color:#fff;border:1px solid #dcdcdc;border-radius:2px;display:flex;flex-direction:column;height:100%;overflow:hidden;flex:1;min-height:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:2px solid #e9ecef;flex-shrink:0;background:linear-gradient(135deg,#fff,#f8f9fa);box-shadow:0 2px 4px #0000000d}.sidebar-header h3{color:#2c3e50;margin:0;font-size:14px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.sidebar-close-button{background:none;border:none;cursor:pointer;font-size:20px;font-weight:700;color:#6c757d;padding:4px 8px;border-radius:4px;transition:all .2s ease}.sidebar-close-button:hover{background-color:#e9ecef;color:#495057;transform:scale(1.1)}.sidebar-content{padding:10px 10px 20px;flex:1 1 auto;overflow-y:auto;scrollbar-width:thin;min-height:0}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.sidebar-item{margin-bottom:15px}.sidebar-item:last-child{margin-bottom:0}.sidebar-item label{display:block;margin-bottom:5px;color:#333;font-weight:500;font-size:14px}.sidebar-select,.sidebar-input{width:100%;padding:8px;border:1px solid #dcdcdc;border-radius:4px;background-color:#f8f9fa;color:#333;font-size:14px}.sidebar-select:focus,.sidebar-input:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px #4285f433}.sidebar-empty-state{color:#666;font-style:italic;text-align:center;padding:20px 0}.sidebar-info-box{padding:8px;background-color:#e9f5e9;border-radius:4px;font-size:14px;color:#333}.status-bar{position:fixed;bottom:0;left:0;right:0;background-color:#1a1a1a;padding:0 10px;display:flex;font-size:12px;border-top:1px solid #444;z-index:1000;font-family:monospace;height:28px;min-height:28px;color:#fff;align-items:center;-webkit-user-select:none;user-select:none}.status-item{display:flex;align-items:center;margin-right:10px}.status-left{display:flex;align-items:center;flex:1}.status-center{display:flex;align-items:center;justify-content:center;flex:1}.status-right{display:flex;align-items:center;justify-content:flex-end;flex:1}.modified-indicator{width:70px;text-align:center}.status-label{font-weight:700;margin-right:5px}.status-value{color:#4af;font-weight:700;text-shadow:0 0 2px rgba(0,100,255,.5)}.mode-label{width:80px;text-align:left;display:inline-block}.state-controls{display:flex;justify-content:center;flex-grow:1}.radio-label{display:flex;align-items:center;justify-content:center;padding:0 15px;height:24px;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:2px solid transparent;transition:all .2s ease}.radio-label input[type=radio]{display:none}.radio-label span{color:#aaa;font-size:12px}.radio-label:hover span{color:#ddd}.radio-label input[type=radio]:checked+span{color:#4af;font-weight:700}.radio-label.selected{border-bottom:2px solid #4af;background-color:#44aaff1a}.radio-label input[type=radio]:checked+span{color:#4af}.import-logs-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.import-logs-modal-content{background:#fff;border-radius:8px;width:90%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 6px #0000001a}.import-logs-modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.import-logs-modal-header h2{margin:0;font-size:1.5rem;color:#333}.import-logs-modal-close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.import-logs-modal-close-button:hover{color:#333}.import-logs-modal-body{padding:20px;flex:1;display:flex;flex-direction:column;min-height:0}.import-logs-tab-buttons{display:flex;margin-bottom:15px;border-bottom:1px solid #e0e0e0}.import-logs-tab-button{background:none;border:none;padding:10px 20px;cursor:pointer;border-bottom:2px solid transparent;font-size:14px;color:#666}.import-logs-tab-button.active{color:#007bff;border-bottom-color:#007bff}.import-logs-tab-button:hover{color:#333}.import-logs-textarea{flex:1;width:100%;min-height:400px;padding:15px;border:1px solid #ddd;border-radius:4px;font-family:Courier New,monospace;font-size:13px;line-height:1.4;resize:none;overflow:auto;white-space:pre;word-wrap:break-word}.import-logs-textarea:focus{outline:none;border-color:#007bff}.cookie-consent{position:fixed;bottom:0;left:0;right:0;background-color:#1f1e1ef2;z-index:9999;display:flex;justify-content:center;padding:15px;box-shadow:0 -2px 10px #0000004d;animation:slide-up .5s ease-out}.cookie-content{max-width:900px;padding:15px 20px;border-radius:6px;background-color:#252525;border:1px solid #444;color:#e0e0e0}.cookie-content h3{margin:0 0 10px;color:#4285f4;font-size:18px}.cookie-content p{margin:0 0 15px;line-height:1.5;font-size:14px}.cookie-buttons{display:flex;gap:10px;justify-content:flex-end}.cookie-button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.cookie-button.accept{background-color:#4285f4;color:#fff}.cookie-button.accept:hover{background-color:#3367d6}.cookie-button.decline{background-color:#353232;color:#e0e0e0;border:1px solid #666}.cookie-button.decline:hover{background-color:#444}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.app{display:flex;flex-direction:column;height:100vh;background-color:#1f1e1e}.top-controls{display:flex;flex-direction:column;width:100%;flex-shrink:0;z-index:2}.controls{padding:10px;background-color:#252525;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;align-items:center}.control-row{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:10px}.main-content{flex:1;display:flex;overflow:hidden;position:relative;z-index:1}.left-sidebar{width:250px;background-color:#353232;border-right:1px solid #ddd;position:absolute;z-index:1000;box-shadow:2px 0 5px #0000001a;height:100vh;transition:transform .3s ease-in-out;display:flex;flex-direction:column}.left-sidebar>div{padding:8px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.left-sidebar.hidden{transform:translate(-100%)}.left-sidebar.visible{transform:translate(0)}.sidebar-toggle{position:absolute;top:50%;left:10px;width:30px;height:30px;background-color:#4285f4;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;transition:left .3s ease-in-out;font-size:12px}.sidebar-toggle.visible{left:260px}.sidebar-toggle.hidden{left:10px}.sidebar-toggle:hover{background-color:#3367d6}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px}.sidebar-header h3{margin:0;color:#333}.pin-button{background:none;border:none;cursor:pointer;font-size:16px;padding:0;border-radius:3px}.pin-button:hover{background-color:#e0e0e0}.sidebar-section{margin-bottom:6px}.sidebar-section h4{margin-top:0;color:#333;border-bottom:1px solid #eee;padding-bottom:3px}.sidebar-option{margin-bottom:2px;display:flex;align-items:center}.sidebar-option input[type=checkbox]{margin-right:8px}.sidebar-select{width:100%;padding:5px;margin-bottom:10px}.sidebar-button-container{display:flex;justify-content:center}.sidebar-button{padding:5px 15px;background-color:#4caf50;border:none;border-radius:4px;cursor:pointer}.sidebar-button:hover{background-color:#45a049}.canvas-container{flex:1;position:relative;overflow:hidden;transition:margin-left .3s ease-in-out;margin-bottom:28px}.canvas-container.sidebar-pinned{margin-left:250px}.selection-panel1{width:300px;background-color:#524d4d;padding:15px;border-left:1px solid #ddd;overflow-y:auto;position:absolute;right:0;top:60px;height:calc(100% - 60px);z-index:1000;box-shadow:-2px 0 5px #0000001a}.selection-panel{width:250px;background-color:#353232;padding:15px;border-right:1px solid #ddd;overflow-y:auto;position:absolute;z-index:1000;right:0;box-shadow:2px 0 5px #0000001a;height:100%;transition:transform .3s ease-in-out}button{padding:5px 10px;background-color:#4285f4;border:none;border-radius:4px;cursor:pointer;font-size:14px}button:hover{background-color:#3367d6}.sample-button{background-color:#34a853}.sample-button:hover{background-color:#2d9249}.file-loaded{color:#34a853;font-weight:700}.load-case-select{padding:5px;border-radius:4px;border:1px solid #ddd}.selection-panel h3{margin-top:0;border-bottom:1px solid #eee;padding-bottom:10px}.selection-panel .no-selection{color:#666;font-style:italic}.selection-panel .property-group{margin-bottom:15px}.selection-panel .property-label{font-weight:700;margin-bottom:5px;display:block}.selection-panel input[type=text],.selection-panel input[type=number]{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;margin-bottom:10px}.selection-panel .apply-button{background-color:#34a853;margin-top:10px}.selection-panel .apply-button:disabled{background-color:#ccc;cursor:not-allowed}.selection-panel .validation-error{color:#ea4335;font-size:12px;margin-top:-5px;margin-bottom:10px}canvas{display:block;outline:none}.modal-button.apply{background-color:#28a745;color:#fff;box-shadow:0 2px 4px #28a74533}.modal-button.apply:disabled{background-color:#6c757d;color:#fff;cursor:not-allowed;box-shadow:none;opacity:.6}.modal-button.apply:disabled:hover{background-color:#6c757d;box-shadow:none}.modal-button.cancel{background-color:#6c757d;color:#fff;border:1px solid #6c757d}.modal-button.cancel:hover{background-color:#5a6268;border-color:#545b62}@media (max-width: 768px){.main-content{flex-direction:column}.selection-panel{width:100%;max-width:none;border:none;border-bottom:1px solid #ddd}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:2px;max-width:90vw;max-height:80vh;box-shadow:0 5px 15px #0003;outline:none;overflow:hidden;animation:slideUp .3s ease-out;display:flex;flex-direction:column;width:auto;height:auto}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#2c3e50;position:relative;min-height:24px;cursor:move!important;-webkit-user-select:none;user-select:none}.modal-header h3{margin:0;font-weight:500;font-size:16px;color:#fff;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center;width:100%;line-height:1.5}.modal-close{background:transparent;border:none;font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;position:absolute;right:3px;top:50%;transform:translateY(-50%);color:#fff}.modal-close:hover{background:transparent;color:#fff}.modal-body{padding:8px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:8px;background-color:#f8f9fa;border-top:1px solid #e9ecef}.modal-button{padding:4px 12px;border:none;border-radius:2px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.modal-button.cancel{background-color:transparent;color:#6c757d;border:1px solid #ced4da}.modal-button.cancel:hover{background-color:#f1f3f5;border-color:#adb5bd}.modal-button.ok{background-color:#007bff;color:#fff;box-shadow:0 2px 4px #007bff33}.modal-button.ok:hover{background-color:#0069d9;box-shadow:0 4px 8px #007bff4d}.modal-button.ok:disabled{background-color:#6c757d;color:#fff;cursor:not-allowed;box-shadow:none;opacity:.6}.modal-button.ok:disabled:hover{background-color:#6c757d;box-shadow:none}.modal-button.delete{background-color:#dc3545;color:#fff;box-shadow:0 2px 4px #dc354533}.modal-button.delete:hover{background-color:#c82333;box-shadow:0 4px 8px #dc35454d}.modal-button.edit{background-color:#2196f3;color:#fff;box-shadow:0 2px 4px #2196f333}.modal-button.edit:hover{background-color:#0d8bf2;box-shadow:0 4px 8px #2196f34d}.modal-button.add{background-color:#4a6da7;color:#fff;box-shadow:0 2px 4px #4a6da733}.modal-button.add:hover{background-color:#3a5a8c;box-shadow:0 4px 8px #4a6da74d}.modal-button.export{background-color:#28a745;color:#fff;box-shadow:0 2px 4px #28a74533}.modal-button.export:hover{background-color:#218838;box-shadow:0 4px 8px #28a7454d}.data-table{width:100%;border-collapse:collapse;font-size:14px;color:#333;background-color:#fff;border:1px solid #dee2e6}.data-table th,.data-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #dee2e6}.data-table th{background-color:#e9ecef;font-weight:500;color:#212529}.data-table tr:nth-child(2n){background-color:#f8f9fa}.data-table tr:hover{background-color:#e2e6ea}.grid-table{width:100%;border-collapse:collapse;margin:10px 0}.grid-table th,.grid-table td{border:1px solid #ddd;padding:8px;text-align:left}.grid-table th{background-color:#f5f5f5;font-weight:700}.action-btn{background:none;border:none;cursor:pointer;padding:4px 8px;margin:0 2px;border-radius:3px;font-size:14px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500}.checkbox-label{display:flex;align-items:center;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin-right:8px;cursor:pointer;vertical-align:middle}.modal-content input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin-right:6px;accent-color:#007bff}.checkbox-group{display:flex;align-items:center;margin-bottom:8px}.checkbox-group label{font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.modal-content input,.modal-content select{height:24px;width:100%;padding:3px;border:1px solid #ddd;border-radius:1px;font-size:14px}.modal-content input:focus,.modal-content select:focus{outline:none!important;box-shadow:none!important;border-color:#ced4da!important}.form-group input,.form-group select{width:100%;padding:3px;border:1px solid #ddd;border-radius:1px;font-size:14px}.form-row{display:flex;gap:15px}.form-row .form-group{flex:1}.gridlines-section{margin:10px 0;border:1px solid #ddd;padding:0 10px;border-radius:4px}.gridlines-section h4{margin:0 0 10px;color:#333}.gridlines-container{max-height:120px;overflow-y:auto;border:1px solid #eee;margin-bottom:10px}.gridlines-table{width:100%;border-collapse:collapse;margin-bottom:10px}.gridlines-table th,.gridlines-table td{border:1px solid #ddd;padding:4px;text-align:left}.gridlines-table th{background-color:#f5f5f5;font-size:12px}.compact-form-row{display:flex;gap:10px;margin-bottom:15px;align-items:end}.calculate-output{width:100%;height:500px;border:1px solid #ddd;border-radius:4px;padding:10px;font-family:Courier New,monospace;font-size:12px;resize:none;background-color:#f8f9fa}.modal-close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#000;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.modal-close-button:hover{background-color:#fff3}.check-structure-modal{width:800px;height:600px}.check-structure-output{width:100%;height:500px;border:1px solid #ddd;border-radius:4px;padding:10px;font-family:Courier New,monospace;font-size:12px;resize:none;background-color:#f8f9fa}.table-modal{width:95vw;max-width:1600px;height:85vh}.table-modal .modal-body{padding:10px;height:calc(85vh - 120px);overflow:hidden}.spreadsheet-container{height:100%;overflow:auto;border:1px solid #ddd;border-radius:4px;position:relative}.Spreadsheet{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.Spreadsheet__table{border-collapse:separate;border-spacing:0;width:100%}.Spreadsheet__header{background:linear-gradient(180deg,#fff,#f8f9fa)!important;font-weight:600;border:1px solid #dee2e6!important;border-bottom:2px solid #dee2e6!important;padding:10px 12px;text-align:left;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #0000001a!important;color:#2c3e50!important;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.Spreadsheet__header:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#dee2e6;z-index:1001}.Spreadsheet__cell{border:1px solid #dee2e6;padding:6px 8px;min-width:100px;background-color:#fff}.Spreadsheet__cell:hover{background-color:#f8f9fa}.Spreadsheet__cell--selected{background-color:#e3f2fd!important;border-color:#2196f3!important}.Spreadsheet__cell input{border:none;outline:none;width:100%;padding:0;background:transparent;font-size:inherit;font-family:inherit}.export-button{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:8px 16px;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #28a74533}.export-button:hover{background:linear-gradient(135deg,#218838,#1ea085);box-shadow:0 4px 8px #28a7454d;transform:translateY(-1px)}.tab-buttons{display:flex;margin-bottom:0;background:transparent;border-radius:2px 2px 0 0;-webkit-user-select:none;user-select:none}.tab-button{padding:8px 16px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent}.tab-button.active{font-weight:700;color:#007bff;background:#e9ecef;position:relative;border-radius:2px 2px 0 0;outline:none}.tab-button:hover,.tab-button:focus{background-color:#0000000d;color:#495057;outline:none}.properties-modal .modal-content{min-width:600px}.properties-modal .modal-header{padding:3px 6px;height:28px}.properties-modal .modal-header h3{font-size:15px;letter-spacing:.3px}.modal-tabs{display:flex;background:#2c3e50}.tab-button{background:transparent;border:none;padding:4px 16px;cursor:pointer;font-size:13px;color:#fff;outline:none;transition:all .2s ease}.tab-button:hover{color:#fff;background:#ffffff1a}.tab-button.active{color:#495057;border-bottom-color:#fff;background:#fff;font-weight:500}.tab-content{background-color:#e9ecef;padding:12px;border-radius:0 0 2px 2px;margin-top:0;min-height:250px;box-sizing:border-box}.property-section{padding:8px 12px;border-bottom:1px solid #eee;transition:background-color .2s ease}.property-section:hover{background-color:#f9f9f9}.property-section:last-child{border-bottom:none}.section-title{margin:0 0 4px;color:#2c3e50;font-size:12px;font-weight:500;display:flex;align-items:center;height:16px}.section-title:before{content:"";display:inline-block;width:2px;height:10px;background:#3498db;margin-right:4px;border-radius:1px}.property-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px}.property-grid.coordinates{grid-template-columns:1fr 1fr 1fr}.property-field{margin-bottom:4px}.field-label{display:block;font-size:11px;color:#7f8c8d;margin-bottom:2px;font-weight:500}.field-value{font-size:14px;color:#2c3e50;padding:8px 0}.field-value.readonly{background-color:#f8f9fa;padding:4px 8px;border-radius:4px;border:1px solid #e9ecef;transition:background-color .2s ease}.field-value.readonly:hover{background-color:#e9ecef}.modal-button.apply{background-color:#28a745;box-shadow:0 2px 4px #28a74533}.modal-button.apply:hover{background-color:#218838;box-shadow:0 4px 8px #28a7454d}.connections-list{display:flex;flex-direction:column;gap:6px;max-height:150px;overflow-y:auto}.connection-item{display:flex;align-items:center;gap:10px;padding:6px 10px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;transition:background-color .2s ease}.connection-item:hover{background-color:#e2e6ea}.connection-id{font-weight:600;color:#007bff;min-width:70px;font-size:12px}.connection-name{flex:1;color:#333;font-size:12px}.connection-nodes{font-size:11px;color:#6c757d;font-family:monospace}.no-connections{text-align:center;color:#6c757d;font-style:italic;padding:15px;background-color:#f8f9fa;border-radius:4px;font-size:12px}.loads-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.load-item{padding:8px 12px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;transition:background-color .2s ease;margin-bottom:8px}.load-item:hover{background-color:#e2e6ea}.load-name{font-weight:600;color:#28a745;font-size:13px;margin-bottom:6px;border-bottom:1px solid #dee2e6;padding-bottom:4px}.load-branches{margin-left:8px}.load-branch{margin-bottom:4px;font-size:12px;color:#495057}.load-values{margin-left:12px;display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.load-values span{background:#fff;padding:2px 6px;border-radius:3px;border:1px solid #dee2e6;font-size:11px}.no-loads{text-align:center;color:#6c757d;font-style:italic;padding:15px;background-color:#f8f9fa;border-radius:4px;font-size:12px}.button-radio-group{display:flex;gap:2px;margin-top:5px}.radio-button{flex:1;padding:4px 12px;border:none;border-radius:2px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;text-align:center;background-color:transparent;color:#6c757d;border:1px solid #ced4da}.radio-button:hover{background-color:#f1f3f5;border-color:#adb5bd}.radio-button.active{background-color:#007bff;color:#fff;border-color:#007bff;box-shadow:0 2px 4px #007bff33}.divide-modal-content{width:400px}.radio-group{padding:10px}.radio-option{display:flex;align-items:center;margin-bottom:10px}.radio-option input[type=radio]{width:16px;height:16px;margin-right:8px;accent-color:#007bff;cursor:pointer}.radio-option label{margin-bottom:0;font-size:14px;cursor:pointer;font-weight:400}.field-display{padding:4px 8px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;min-height:24px;line-height:24px;font-size:14px;color:#333}.modal-button.ok.disabled{background-color:#b3d7ff;color:#6c757d;cursor:not-allowed;box-shadow:none}.modal-button.ok.disabled:hover{background-color:#b3d7ff;box-shadow:none}.modal-button.edit:disabled{background-color:#b3d7ff;color:#6c757d;cursor:not-allowed;box-shadow:none}.modal-button.edit:disabled:hover{background-color:#b3d7ff;box-shadow:none}.modal-button.delete:disabled{background-color:#f8d7da;color:#6c757d;cursor:not-allowed;box-shadow:none}.modal-button.delete:disabled:hover{background-color:#f8d7da;box-shadow:none}
